:root{
  --bg:#fff;          /* fondo blanco como el original */
  --panel:#ffffff;    /* tarjetas blancas */
  --text:#333;        /* texto base */
  --muted:#555;       /* texto secundario */
  --ring:#ccc;        /* borde suave */
  --primary:#2a6ebb;  /* botón azul original */
  --primary-pressed:#1d4f8a;
  --result:#d7e7f6;   /* caja azul pálido */

  /* Ancho máximo del contenido: ampliamos para hacer la página más “horizontal” */
  --container: min(96vw, 1360px);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0; font-family:"Trebuchet MS", Arial, Helvetica, sans-serif; background:var(--bg); color:var(--text)}

/* Top bar */
.topbar{background:#fff; border-bottom:1px solid var(--ring)}
.topbar-inner{max-width:var(--container); margin:0 auto; padding:12px 16px; display:flex; gap:16px; align-items:center}
.brand{display:flex; align-items:center}
/* Solo logo; más grande y proporcional */
.brand .logo{
  height:80px;
  width:auto;
  display:block;
  object-fit:contain;
}
@media (max-width:640px){
  .brand .logo{ height:56px; }
}

/* Navbar */
.navbar{background:linear-gradient(to right,#2570a8,#42a2c8)}
.navbar-inner{max-width:var(--container); margin:0 auto; padding:10px 16px; display:flex; gap:18px}
.navlink{color:#fff; text-decoration:none; font-weight:600; padding:8px 12px; border-radius:3px}
.navlink.active{background:#16608a}

/* Layout (más horizontal: más ancho y con gutter izquierdo) */
.wrap{
  max-width:var(--container);
  margin:0 auto;
  padding:16px 20px 16px 56px; /* empuja contenido a la derecha como en el ejemplo */
}
.grid{
  display:grid;
  /* Columna izquierda flexible y sidebar ancho para ocupar más el horizontal */
  grid-template-columns: minmax(560px, 1fr) 420px;
  gap:42px; /* más separación entre columnas */
}
@media(max-width:1200px){
  .wrap{ padding-left:44px; }
  .grid{ grid-template-columns:minmax(520px,1fr) 380px; gap:36px; }
}
@media(max-width:1000px){
  .wrap{ padding-left:24px; }
  .grid{ grid-template-columns:1fr; gap:20px; }
}

/* Cards */
.card{background:var(--panel); border:1px solid var(--ring); border-radius:4px}
.card-body{padding:16px 18px}

h1{font-size:34px; margin:0 0 12px; font-weight:800; color:#6b3e2e} 
label{font-weight:bold; display:block; margin-top:8px}
.help{color:#7b8896; font-size:13px; margin:6px 0} 

/* Inputs (reducimos altura para quitar scroll vertical general) */
textarea{
  width:100%;
  min-height:200px; /* antes 240px */
  border:1px solid #cfcfcf;
  border-radius:4px;
  padding:10px;
  background:#fff;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.05)
}
input[type="number"]{
  width:100%; height:34px;
  border:1px solid #cfcfcf; border-radius:4px; padding:0 10px; background:#fff;
  box-shadow:inset 0 1px 2px rgba(0,0,0,.05)
}

.row{display:flex; gap:12px; align-items:flex-end; margin-top:10px; flex-wrap:wrap}
.actions{display:flex; gap:10px; align-items:center}
.btn{
  height:34px; padding:0 16px; border-radius:6px;
  border:1px solid #bfc7d0; background:#fff; cursor:pointer;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset, 0 1px 1px rgba(0,0,0,.06)
}
.btn.primary{background:var(--primary); color:#fff; border:1px solid #1b5e97}
.btn.primary:hover{background:var(--primary-pressed)}
.stats{display:flex; gap:10px; color:var(--muted); font-size:12px; margin-top:6px}

/* Results */
.result-box{
  background:var(--result);
  border:1px solid #b1d2ee;
  border-radius:3px;
  padding:10px;
  color:#224e6f;
  white-space:pre-line;
  font-size:14px;
}

/* Animación: ticker y revelado */
.result-rolling{
  font-size:18px;
  font-weight:700;
  letter-spacing:0.2px;
  animation: throb 0.6s ease-in-out infinite alternate;
}
@keyframes throb{
  from{ opacity:0.6; transform:translateY(2px) }
  to  { opacity:1;   transform:translateY(-2px) }
}

.reveal{
  opacity:0;
  transform: translateY(8px);
  animation: reveal 400ms ease forwards;
}
@keyframes reveal{
  to { opacity:1; transform:none; }
}

.result-box.celebrate{
  animation: flash 800ms ease-out 2;
}
@keyframes flash{
  0%{   box-shadow:0 0 0 0 rgba(38,132,255,0.0) }
  30%{  box-shadow:0 0 0 6px rgba(38,132,255,0.25) }
  100%{ box-shadow:0 0 0 0 rgba(38,132,255,0.0) }
}

/* Footer (centrado y links blancos) */
footer{
  background:#222;
  color:#fff;
  padding:14px 0;
  margin-top:18px;
}
.footer-inner{
  max-width:var(--container);
  margin:0 auto;
  font-size:13px;
  text-align:center;         /* centra el contenido del footer */
}
footer a{
  color:#fff !important;     /* fuerza blanco para los enlaces */
  text-decoration:none;
}
footer a:hover{
  color:#fff !important;
  text-decoration:underline;
}
footer .copyright{
  display:block;
  margin-top:8px;
  color:#cfcfcf;
}

/* Respeto de preferencias de movimiento */
@media (prefers-reduced-motion: reduce){
  .result-rolling,
  .reveal,
  .result-box.celebrate{
    animation: none !important;
  }
}

/* ============== Ajustes para la columna derecha (sidebar) ============== */
/* Títulos marrones como el de "Sortee" */
aside h2,
aside h3,
.sidebar h2,
.sidebar h3{
  color:#6b3e2e !important;
}

/* Quitar el recuadro/borde de las tarjetas del sidebar */
aside .card,
.sidebar .card{
  border:none !important;
  box-shadow:none !important;
  background:transparent !important;
}

/* Mantener aire entre bloques aún sin recuadro */
aside .card .card-body,
.sidebar .card .card-body{
  padding:16px 0;
}

/* Separación entre tarjetas en el sidebar */
aside .card + .card,
.sidebar .card + .card{
  margin-top:16px;
}