:root{--ink:#0e0a06;--ink-2:#17110a;--surf:#211710;--gold:#e8b04b;--gold-soft:#caa24f;
  --cream:#f5eee3;--muted:#a89a86;--faint:#7d7263;--line:rgba(245,238,227,.12);
  --line-gold:rgba(232,176,75,.16);--ok:#1d9e75;--danger:#e0473c;--r:12px;--r-lg:16px;
  --tinte:rgba(232,176,75,.10);
  --cine:#e0473c;--net:#cfc7b8;--dx:#7fe0e3;
  --tab-h:calc(64px + env(safe-area-inset-bottom,0px))}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
[hidden]{display:none!important}
body{margin:0;background:var(--ink);color:var(--cream);font-family:'Hanken Grotesk',system-ui,sans-serif;line-height:1.5}
.tinte{position:fixed;inset:0;z-index:0;pointer-events:none;transition:background .8s ease;
  background:radial-gradient(120% 70% at 50% -10%, var(--tinte), transparent 60%)}
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E")}
#app{position:relative;z-index:2;min-height:100vh;padding-bottom:var(--tab-h)}
.eyebrow{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 6px}
.word{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(26px,6vw,38px);line-height:1;margin:0 0 6px}
.word em{font-style:italic;font-weight:500;color:var(--gold)}
.gate{position:fixed;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center}
.gate-box{max-width:340px}
.gate-sub{color:var(--muted);font-size:14px} .gate code{color:var(--gold-soft)}

.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;justify-content:center;gap:6px;
  padding:10px 10px calc(10px + env(safe-area-inset-bottom,0px));
  background:linear-gradient(to top,#0e0a06 62%,transparent);backdrop-filter:blur(8px)}
.tabbar button{font-family:inherit;font-size:13px;color:var(--muted);background:transparent;border:0;
  padding:10px 18px;border-radius:999px;cursor:pointer;min-height:42px;transition:color .18s,background .18s}
.tabbar button.on{background:var(--gold);color:#1a1107;font-weight:700}
.vista{animation:fade .35s both}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* Hero */
.hero{position:relative;min-height:62vh;display:flex;flex-direction:column;justify-content:flex-end;padding:18px}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:-1}
.hero-bg.skel{background:var(--surf)}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,var(--ink) 6%,transparent 60%),linear-gradient(to right,rgba(14,10,6,.6),transparent 70%)}
.hero h1{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(30px,9vw,46px);line-height:.96;margin:0 0 6px;max-width:82%}
.hero .meta{font-size:12px;color:#cbbfa9;margin:0 0 12px}
.hero .meta b{color:var(--gold);font-weight:500}
.cta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.cta button{font-family:inherit;font-weight:700;font-size:13px;border:0;border-radius:10px;padding:11px 16px;cursor:pointer;min-height:42px}
.cta .play{background:var(--gold);color:#1a1107;display:inline-flex;align-items:center;gap:7px;font-size:15px}
.cta .play span{font-size:13px}
.cta .add{background:rgba(245,238,227,.12);color:var(--cream);border:1px solid rgba(245,238,227,.2)}
#hero-donde{margin-top:10px}

/* Hileras */
.fila{padding:18px 0 2px}
.fila h2{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:16px;margin:0 0 10px;padding:0 18px}
.scroll{display:flex;gap:11px;overflow-x:auto;padding:0 18px 8px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.scroll::-webkit-scrollbar{display:none}
.cardp{flex:0 0 118px;width:118px;cursor:pointer}
.cardp .art{position:relative;width:118px;height:177px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:var(--surf)}
.cardp .art img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .45s}
.cardp .art img.cargada{opacity:1}
.cardp:focus-visible{outline:none}
.cardp:focus-visible .art{outline:2px solid var(--gold);outline-offset:2px}
.cardp .badge{position:absolute;bottom:6px;left:6px;font-size:9px;font-weight:700;color:#04181a;background:linear-gradient(110deg,#7fe0e3,#ffd36b);padding:2px 6px;border-radius:4px;letter-spacing:.04em}
.cardp .ct{font-size:12.5px;margin:7px 0 0;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cardp .cy{font-size:10px;color:var(--muted);margin:2px 0 0}
.skel{background:linear-gradient(100deg,#1a130b 30%,#241a10 50%,#1a130b 70%);background-size:200% 100%;animation:sk 1.2s infinite}
@keyframes sk{from{background-position:200% 0}to{background-position:-200% 0}}

/* Detalle (overlay) */
body.sin-scroll{overflow:hidden}
.overlay{position:fixed;inset:0;z-index:25;background:var(--ink);overflow-y:auto;-webkit-overflow-scrolling:touch}
.dt-back{position:relative;height:46vh;background-size:cover;background-position:center;background-color:var(--surf)}
.dt-back::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,var(--ink) 5%,transparent 62%)}
.dt-top{position:absolute;top:calc(14px + env(safe-area-inset-top,0px));left:14px;right:14px;z-index:2;display:flex;justify-content:space-between}
.dt-top button{display:flex;align-items:center;justify-content:center;background:rgba(10,7,4,.5);border:1px solid rgba(245,238,227,.2);color:#f0e9db;border-radius:999px;width:40px;height:40px;font-size:20px;cursor:pointer;backdrop-filter:blur(4px)}
.dt-body{padding:0 18px 110px;margin-top:-60px;position:relative;z-index:2;max-width:760px;margin-left:auto;margin-right:auto}
.dt-poster{width:108px;height:162px;border-radius:10px;border:1px solid rgba(245,238,227,.18);background:var(--surf);box-shadow:0 16px 40px rgba(0,0,0,.55);object-fit:cover;margin-bottom:14px;display:block}
.dt-title{font-family:'Fraunces',serif;font-weight:600;font-size:clamp(26px,7vw,34px);line-height:1.02;margin:0 0 6px}
.dt-meta{font-size:12px;color:#c8bca6;margin:0 0 14px} .dt-meta b{color:var(--gold);font-weight:500}
.dt-syn{font-size:14.5px;line-height:1.66;color:#d8cdb9;margin:0 0 18px}
.skel-line{display:block;height:12px;border-radius:6px;margin:0 0 9px;background:linear-gradient(100deg,#1a130b 30%,#241a10 50%,#1a130b 70%);background-size:200% 100%;animation:sk 1.2s infinite}
.skel-line.corta{width:55%}
.dt-cta{display:flex;gap:9px;margin-bottom:18px}
.dt-cta button{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:inherit;font-weight:700;font-size:14px;border:0;border-radius:11px;padding:13px;cursor:pointer;min-height:46px}
.dt-cta .play{background:var(--gold);color:#1a1107}
.dt-cta .add{background:rgba(245,238,227,.1);color:var(--cream);border:1px solid rgba(245,238,227,.2)}
.dt-label{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);margin:0 0 8px}
.dt-cast{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}.dt-cast::-webkit-scrollbar{display:none}
.dt-actor{flex:0 0 64px;text-align:center}
.dt-face{width:64px;height:64px;border-radius:50%;object-fit:cover;background:var(--surf);border:1px solid var(--line);margin-bottom:5px;display:block}
.dt-an{font-size:10px;color:#b6aa95;line-height:1.2;margin:0}
.donde-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.donde-row .prov{width:36px;height:36px;border-radius:9px;object-fit:cover;background:var(--surf)}
.donde-no{font-size:12px;color:var(--faint);margin:0} .jw{font-size:10px;color:#6f6552}

/* Cartelera (vista de estrenos) */
#vista-cartelera{max-width:1120px;margin:0 auto}
.ct-top{padding:18px 18px 4px}
.ct-top .count{font-size:13px;color:var(--muted);margin:0 0 14px}
.seg{display:flex;gap:3px;background:var(--ink-2);border:1px solid var(--line-gold);border-radius:11px;padding:3px;margin-bottom:12px;max-width:320px}
.seg button{flex:1;border:0;background:transparent;color:var(--muted);font-family:inherit;font-size:13px;font-weight:500;padding:9px;border-radius:8px;cursor:pointer;transition:.18s}
.seg button.on{background:var(--gold);color:#1a1107;font-weight:700}
.filt{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:10px}
.gen{display:flex;gap:7px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.gen::-webkit-scrollbar{display:none}
.filt button,.gen button{font-family:inherit;font-size:12px;padding:7px 13px;border-radius:999px;white-space:nowrap;min-height:36px;
  border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:.15s}
.filt button.on,.gen button.on{background:rgba(245,238,227,.10);color:var(--cream);border-color:rgba(245,238,227,.32)}
.filt button.dx{border-color:rgba(127,224,227,.4);color:var(--dx)}
.filt button.dx.on{background:rgba(127,224,227,.14);color:#aef0f2;border-color:var(--dx)}
#ct-stream{padding:8px 18px 8px}
#vista-cartelera .sec{display:flex;align-items:center;gap:12px;margin:26px 0 14px}
#vista-cartelera .sec:first-child{margin-top:6px}
#vista-cartelera .sec h2{font-family:'Fraunces',serif;font-style:italic;font-weight:500;font-size:18px;margin:0;white-space:nowrap}
#vista-cartelera .sec .rule{height:1px;flex:1;background:linear-gradient(90deg,var(--line-gold),transparent)}
#vista-cartelera .sec .tag{font-size:11px;color:var(--gold-soft);white-space:nowrap;background:none;padding:0}
#vista-cartelera .sec.hoy h2{color:var(--gold)}
#vista-cartelera .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(min-width:560px){#vista-cartelera .grid{grid-template-columns:repeat(3,1fr);gap:16px}}
@media(min-width:820px){#vista-cartelera .grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1040px){#vista-cartelera .grid{grid-template-columns:repeat(5,1fr)}}
#vista-cartelera .card{position:relative;animation:rise .5s both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
#vista-cartelera .art{position:relative;aspect-ratio:2/3;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  background:var(--surf);transition:transform .25s ease, box-shadow .25s ease;cursor:pointer}
#vista-cartelera .card:hover .art{transform:translateY(-4px);box-shadow:0 14px 34px rgba(0,0,0,.5)}
#vista-cartelera .art:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
#vista-cartelera .art img{width:100%;height:100%;object-fit:cover;display:block}
#vista-cartelera .card.vista .art img{filter:grayscale(.5) brightness(.62)}
#vista-cartelera .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(8,5,3,.85) 6%,transparent 46%);opacity:0;transition:.22s}
#vista-cartelera .card:hover .scrim{opacity:1}
#vista-cartelera .src{position:absolute;top:8px;left:8px;z-index:2;font-size:9px;letter-spacing:.12em;text-transform:uppercase;
  display:flex;align-items:center;gap:5px;color:var(--cream);text-shadow:0 1px 3px rgba(0,0,0,.7)}
#vista-cartelera .src .dot{width:6px;height:6px;border-radius:50%}
#vista-cartelera .acts{position:absolute;top:7px;right:7px;z-index:3;display:flex;gap:5px}
#vista-cartelera .acts button{width:30px;height:30px;border-radius:50%;border:1px solid rgba(245,238,227,.2);
  background:rgba(10,7,4,.55);color:var(--cream);display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:.15s}
#vista-cartelera .acts button:hover{background:rgba(10,7,4,.8)}
#vista-cartelera .acts button.on[data-acc="quiero"]{background:var(--gold);color:#1a1107;border-color:var(--gold)}
#vista-cartelera .acts button.on[data-acc="vista"]{background:var(--ok);color:#04150e;border-color:var(--ok)}
#vista-cartelera .play{position:absolute;bottom:8px;right:8px;z-index:3;width:32px;height:32px;border-radius:50%;
  background:rgba(245,238,227,.94);color:#13100b;display:flex;align-items:center;justify-content:center;font-size:15px;text-decoration:none}
#vista-cartelera .badge-dx{position:absolute;bottom:8px;left:8px;z-index:2;font-weight:700;font-size:11px;letter-spacing:.06em;
  color:#04181a;padding:3px 9px;border-radius:6px;overflow:hidden;
  background:linear-gradient(110deg,#7fe0e3,#bda6ff 45%,#ffd36b 90%)}
#vista-cartelera .badge-dx::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.75),transparent);transform:skewX(-20deg);animation:sheen 3.4s ease-in-out infinite}
@keyframes sheen{0%,62%{left:-60%}100%{left:130%}}
#vista-cartelera .ribbon{position:absolute;bottom:8px;left:8px;z-index:2;font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(29,158,117,.92);color:#04150e;padding:2px 8px;border-radius:6px;font-weight:700}
#vista-cartelera .name{font-family:'Fraunces',serif;font-weight:600;font-size:15px;line-height:1.15;margin:9px 0 3px}
#vista-cartelera .when{font-size:11.5px;color:var(--muted);margin:0 0 7px}
#vista-cartelera .when b{color:var(--gold);font-weight:500}
#vista-cartelera .when .past{color:var(--faint)}
#vista-cartelera .tags{display:flex;gap:5px;flex-wrap:wrap}
#vista-cartelera .tag{font-size:10px;padding:1px 7px;border-radius:5px;background:rgba(245,238,227,.08);color:#c9bda9}
#vista-cartelera .tag.fmt{color:var(--gold);background:rgba(232,176,75,.12)}
.empty{color:var(--faint);font-size:14px;text-align:center;padding:50px 0}

/* Mi diario + "Tu año en cine" */
#vista-diario{max-width:760px;margin:0 auto}
.dia-top{padding:18px 18px 4px}
.add{font-family:inherit;cursor:pointer;border-radius:var(--r);border:0;background:var(--gold);color:#1a1107;font-weight:700;font-size:15px;padding:12px 18px;min-height:46px}
.anio{display:flex;gap:10px;flex-wrap:wrap;margin:12px 0 14px}
.anio .stat{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;min-width:92px}
.anio .stat b{font-family:'Fraunces',serif;font-size:24px;display:block;color:var(--gold);font-variant-numeric:tabular-nums;line-height:1.1}
.anio .stat span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.anio .stat.wide{flex:1;min-width:150px;display:flex;flex-direction:column;justify-content:center}
.anio .stat.wide b{font-size:16px}
#dia-lista{padding:8px 18px 24px}
.mes{font-family:'Fraunces',serif;font-style:italic;font-size:18px;margin:22px 0 12px;color:var(--gold)}
.entrada{display:flex;gap:14px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:12px;margin-bottom:12px;cursor:pointer;transition:border-color .15s}
.entrada:hover{border-color:var(--line-gold)}
.entrada img{flex:0 0 70px;width:70px;height:105px;object-fit:cover;border-radius:8px;background:var(--surf)}
.entrada .info{flex:1;min-width:0}
.entrada h3{font-family:'Fraunces',serif;font-size:16px;margin:0 0 2px}
.entrada h3 .anioe{color:var(--faint);font-weight:400}
.entrada .sub{font-size:12px;color:var(--muted);margin:0 0 6px}
.entrada .stars-ro{color:var(--gold);letter-spacing:1px}
.entrada .nota{font-size:13px;color:#cfc3b0;margin:6px 0 0}
.entrada .ctx{font-size:11px;color:var(--faint);margin-top:4px}

/* Modal (formulario del diario) */
.modal{position:fixed;inset:0;z-index:28;background:rgba(8,5,3,.7);display:flex;align-items:flex-end;justify-content:center}
@media(min-width:560px){.modal{align-items:center;padding:20px}}
.sheet{background:#15100a;border:1px solid var(--line-gold);border-radius:18px 18px 0 0;width:100%;max-width:520px;max-height:90vh;overflow:auto;padding:20px;position:relative}
@media(min-width:560px){.sheet{border-radius:18px}}
.sheet h2{font-family:'Fraunces',serif;font-style:italic;margin:0 0 12px}
.x{position:absolute;top:12px;right:12px;background:transparent;border:0;color:var(--muted);font-size:18px;cursor:pointer;width:36px;height:36px}
.sheet input,.sheet textarea{width:100%;margin:4px 0 12px;padding:11px;border-radius:var(--r);border:1px solid var(--line);background:var(--ink-2);color:var(--cream);font-family:inherit;font-size:15px}
.sheet textarea{resize:vertical}
.sheet label{font-size:12px;color:var(--gold-soft);text-transform:uppercase;letter-spacing:.1em}
.resultados{display:flex;flex-direction:column;gap:8px;margin-top:10px;max-height:52vh;overflow:auto}
.res{display:flex;gap:10px;align-items:center;padding:6px;border-radius:10px;cursor:pointer;border:1px solid transparent}
.res:hover{border-color:var(--line-gold);background:var(--ink-2)}
.res img{width:40px;height:60px;object-fit:cover;border-radius:6px;background:var(--surf)}
.res .rt{font-weight:500} .res .ry{font-size:12px;color:var(--muted)}
.elegida{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.elegida img{width:54px;height:81px;object-fit:cover;border-radius:8px;background:var(--surf)}
.elegida .et{font-family:'Fraunces',serif;font-size:18px} .elegida .ey{color:var(--muted);font-size:13px}
.stars{display:flex;gap:2px;margin:4px 0 14px;font-size:28px;color:var(--faint);cursor:pointer;width:max-content}
.stars .s{position:relative;width:28px}
.stars .s .full{color:var(--gold);position:absolute;inset:0;overflow:hidden;width:0}
.form-acts{display:flex;justify-content:space-between;gap:10px;margin-top:8px}
.form-acts #dia-guardar{flex:1;font-family:inherit;cursor:pointer;border-radius:var(--r);border:0;background:var(--gold);color:#1a1107;font-weight:700;font-size:15px;padding:12px 18px;min-height:46px}
.danger{background:transparent;border:1px solid var(--danger);color:var(--danger);border-radius:var(--r);padding:11px 16px;font-family:inherit;font-size:15px;cursor:pointer}

@media(prefers-reduced-motion:no-preference){
  .overlay:not([hidden]){animation:dtzoom .34s cubic-bezier(.2,.7,.2,1) both}
  @keyframes dtzoom{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
}

@media(prefers-reduced-motion:reduce){
  .vista,.skel,.skel-line{animation:none}
  .tinte{transition:none}
  .cardp .art img{transition:opacity .15s}
  #vista-cartelera .card{animation:none}
  #vista-cartelera .badge-dx::after{animation:none;display:none}
  .overlay:not([hidden]){animation:none}
}
