
/* ── Theme Variables ─────────────────────────────── */
:root{
  /* Brand tokens (paleta extraida do logo) */
  --brand-orange:#FCA540;--brand-coral:#F8714B;--brand-pink:#CE418E;--brand-purple:#462673;--brand-navy:#192057;
  --grad-brand:linear-gradient(135deg,#FCA540 0%,#F8714B 30%,#CE418E 65%,#462673 100%);
  /* Neutrals dark */
  --bg:#0F1117;--bg-card:#1A1D25;--bg-card-hover:#242830;--bg-input:#242830;
  --text:#E8E8E8;--text-muted:#8A8E99;--text-dim:#5A5E69;
  --border:#2D3142;--border-light:#3A3F4F;
  /* Accents */
  --accent:#F8714B;--accent-hover:#CE418E;--accent-soft:#462673;
  --accent-danger:#ef4444;--accent-success:#4ade80;--accent-warning:#facc15;--accent-info:#06b6d4;
  --shadow:0 2px 8px rgba(0,0,0,.3);--radius:10px;
  color-scheme:dark
}
body.light{
  --bg:#FFFFFF;--bg-card:#F8F9FB;--bg-card-hover:#F0F2F5;--bg-input:#FFFFFF;
  --text:#192057;--text-muted:#5A6070;--text-dim:#8A8E99;
  --border:#E0E4E8;--border-light:#C5CBD3;
  --accent:#E85A32;--accent-hover:#CE418E;--accent-soft:#462673;
  --shadow:0 2px 8px rgba(0,0,0,.08);
  color-scheme:light
}

/* ── Reset + Base ────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,system-ui,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);color:var(--text);
  padding-bottom:calc(68px + env(safe-area-inset-bottom));padding-top:52px;
  -webkit-tap-highlight-color:transparent;
  transition:background .2s,color .2s}
a{color:var(--accent);text-decoration:none}

/* ── Header ──────────────────────────────────────── */
#hdr{position:fixed;top:0;left:0;right:0;height:52px;background:var(--bg-card);
  display:flex;align-items:center;padding:0 16px;z-index:20;
  border-bottom:1px solid var(--border);transition:background .2s}
#hdr-back{margin-right:12px;cursor:pointer;display:none;color:var(--text)}
.hdr-icon{width:22px;height:22px}
#hdr-brand{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer;
  user-select:none;-webkit-user-select:none}
#hdr-logo{width:32px;height:32px;object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 1px 3px rgba(248,113,75,.25))}
#hdr-title{font-size:18px;font-weight:700;letter-spacing:.3px;
  background:var(--grad-brand);background-clip:text;-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent}
body.light #hdr-title{color:var(--brand-navy);-webkit-text-fill-color:var(--brand-navy);background:none}
#hdr-search{cursor:pointer;padding:8px}
.theme-toggle{background:none;border:none;cursor:pointer;padding:8px;color:var(--text);
  display:flex;align-items:center}
.theme-icon{width:18px;height:18px}

/* ── Bottom Bar ──────────────────────────────────── */
#bottombar{position:fixed;bottom:0;left:0;right:0;height:60px;
  background:rgba(15,17,23,.85);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;border-top:1px solid var(--border);z-index:20;
  padding-bottom:env(safe-area-inset-bottom);transition:background .2s}
body.light #bottombar{background:rgba(255,255,255,.85)}
@supports not ((backdrop-filter: blur(12px)) or (-webkit-backdrop-filter: blur(12px))){
  #bottombar{background:rgba(15,17,23,.96)}
  body.light #bottombar{background:rgba(255,255,255,.96)}
}
.bb-btn{flex:1;background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  transition:color .15s;position:relative;padding-top:2px}
.bb-btn svg.bb-icon{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;transition:stroke-width .15s,transform .15s}
.bb-btn.active{color:var(--accent);font-weight:600}
.bb-btn.active svg.bb-icon{stroke-width:2.5;transform:translateY(-1px)}
.bb-btn.active::after{content:'';position:absolute;bottom:4px;left:50%;
  transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 6px var(--accent)}
.bb-icon{width:22px;height:22px}

/* ── Pages ───────────────────────────────────────── */
.page{display:none;padding:8px 12px}
.page.active{display:block}

/* ── Filter Bar ──────────────────────────────────── */
.filter-bar{padding:6px 0 8px;display:flex;gap:6px;flex-wrap:wrap;
  position:sticky;top:52px;background:var(--bg);z-index:10;transition:background .2s}
.filter-select{background:var(--bg-input);color:var(--text);
  border:1px solid var(--border);border-radius:8px;
  padding:7px 28px 7px 10px;font-size:13px;flex:1;min-width:0;max-width:180px;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23888'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 8px center;cursor:pointer;
  transition:border-color .15s}
.filter-select:focus{border-color:var(--accent);outline:none}
.filter-search{background:var(--bg-input);color:var(--text);border:1px solid var(--border);
  border-radius:6px;padding:6px 10px;font-size:12px;width:120px;outline:none}
.filter-search:focus{border-color:var(--accent)}
.filter-count{font-size:11px;color:var(--text-muted);padding:2px 0;text-align:center}

/* ── Filter bar mobile (default hidden, shown <=600px) ── */
.filter-bar-mobile{display:none;gap:8px;position:sticky;top:52px;z-index:10;
  padding:8px 0;background:var(--bg);align-items:center}
.filters-open{flex:0 0 auto;background:var(--bg-card);border:1px solid var(--border);
  border-radius:20px;padding:8px 14px;color:var(--text);display:flex;gap:6px;
  align-items:center;cursor:pointer;font-size:13px;font-weight:500;
  transition:border-color .15s,background .15s}
.filters-open:hover{border-color:var(--accent)}
.filters-open svg{width:16px;height:16px}
.fc-badge{background:var(--accent);color:#fff;border-radius:10px;padding:1px 7px;
  font-size:11px;font-weight:600;min-width:18px;text-align:center;display:inline-block}
.fc-badge[hidden]{display:none}
.filter-search-mobile{flex:1;background:var(--bg-input);color:var(--text);
  border:1px solid var(--border);border-radius:20px;padding:8px 14px;font-size:13px;
  width:auto;outline:none}
.filter-chips{display:none;gap:6px;overflow-x:auto;padding:0 0 10px;
  scrollbar-width:none;-ms-overflow-style:none}
.filter-chips::-webkit-scrollbar{display:none}
.filter-chip{flex:0 0 auto;background:rgba(248,113,75,.14);
  border:1px solid var(--accent);color:var(--accent);border-radius:16px;
  padding:4px 6px 4px 10px;font-size:12px;font-weight:500;white-space:nowrap;
  display:inline-flex;align-items:center;gap:4px}
.filter-chip .chip-x{cursor:pointer;padding:0 6px;font-size:14px;opacity:.8;line-height:1}
.filter-chip .chip-x:hover{opacity:1}

@media(max-width:600px){
  /* paginas com bottom-sheet: esconde filter-bar desktop */
  .filter-bar:has(+ .filter-bar-mobile){display:none}
  /* paginas sem bottom-sheet (streaming, news): compacta filters em 2 colunas */
  .filter-bar:not(:has(+ .filter-bar-mobile)) .filter-select{
    flex:1 0 calc(50% - 3px);max-width:none}
  .filter-bar-mobile{display:flex}
  .filter-chips:not(:empty){display:flex}
}

/* ── Filters sheet (bottom sheet mobile, side panel desktop) ── */
#filters-sheet-overlay{display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:39;opacity:0;transition:opacity .25s ease}
#filters-sheet-overlay.open{display:block;opacity:1}
#filters-sheet{position:fixed;right:-440px;top:0;bottom:0;width:420px;max-width:100vw;
  background:var(--bg-card);z-index:40;transition:right .3s ease;
  box-shadow:-4px 0 20px rgba(0,0,0,.3);display:flex;flex-direction:column;overflow:hidden}
#filters-sheet.open{right:0}
@media(max-width:600px){
  #filters-sheet{right:auto;top:auto;bottom:-92vh;left:0;width:100%;height:85vh;
    max-width:none;transition:bottom .3s ease;
    border-radius:16px 16px 0 0;box-shadow:0 -4px 20px rgba(0,0,0,.3)}
  #filters-sheet.open{bottom:0}
}
.fs-header{padding:16px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;flex:0 0 auto}
.fs-title{font-size:17px;font-weight:600;color:var(--text)}
.fs-x{background:transparent;border:0;color:var(--text);font-size:26px;
  line-height:1;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}
.fs-x:hover{background:var(--bg-card-hover)}
.fs-content{flex:1 1 auto;padding:16px;display:flex;flex-direction:column;gap:14px;
  overflow-y:auto;-webkit-overflow-scrolling:touch}
.fs-row{display:flex;flex-direction:column;gap:6px}
.fs-row label{font-size:12px;color:var(--text-muted);font-weight:500;
  text-transform:uppercase;letter-spacing:.5px}
.fs-row select{width:100%;background:var(--bg-input);color:var(--text);
  border:1px solid var(--border);border-radius:8px;padding:10px 32px 10px 12px;
  font-size:16px;appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%238A8E99'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;outline:none}
.fs-row select:focus{border-color:var(--accent)}
.fs-footer{padding:12px 16px;border-top:1px solid var(--border);
  display:flex;gap:10px;flex:0 0 auto;padding-bottom:calc(12px + env(safe-area-inset-bottom))}
.fs-clear{flex:1;background:transparent;border:1px solid var(--border);
  color:var(--text);border-radius:10px;padding:12px;font-size:14px;font-weight:500;
  cursor:pointer;transition:border-color .15s}
.fs-clear:hover{border-color:var(--accent)}
.fs-apply{flex:2;background:var(--accent);color:#fff;border:0;border-radius:10px;
  padding:12px;font-size:14px;font-weight:600;cursor:pointer;
  transition:background .15s}
.fs-apply:hover{background:var(--accent-hover)}

/* ── Section Headers ─────────────────────────────── */
.sec-header{font-size:13px;font-weight:600;padding:10px 0 4px;margin-top:8px;
  border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:6px}
.sec-dot{width:6px;height:6px;border-radius:50%}
.sh{font-size:14px;font-weight:600;margin:14px 0 6px;color:var(--text)}

/* ── Card (list view) ────────────────────────────── */
.card{display:flex;background:var(--bg-card);border-radius:var(--radius);
  margin-bottom:6px;overflow:hidden;cursor:pointer;
  box-shadow:var(--shadow);transition:background .15s,transform .1s}
.card:active{transform:scale(.99)}
.card.st-feito{opacity:.5}
.card-poster{width:80px;min-height:100px;object-fit:cover;flex-shrink:0;background:var(--bg-input)}
.card-placeholder{display:flex;align-items:center;justify-content:center;color:var(--text-muted);border-radius:var(--radius) 0 0 var(--radius)}
.card-placeholder svg{width:32px;height:32px;opacity:.3}
.card-body{flex:1;padding:8px 10px;min-width:0}
.card-title{font-size:14px;font-weight:600;line-height:1.3;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-meta{font-size:11px;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:3px 8px}
.card-status{font-size:10px;padding:1px 6px;border-radius:3px;display:inline-block;margin-top:3px}

/* Date badges */
.badge-date{font-size:9px;padding:1px 5px;border-radius:3px;font-weight:600;display:inline-block;margin-top:2px}
.badge-estreia{background:#4ade8030;color:#4ade80}
.badge-cartaz{background:#4a9eff20;color:#4a9eff}
.badge-ultimos{background:#f9731630;color:#f97316}
.badge-ultimo-dia{background:#ef444430;color:#ef4444}
.badge-fora{background:#66666630;color:#888}

/* Sessions preview */
.sess-prev{margin-top:3px;font-size:11px;color:var(--text-muted)}
.sess-prev .sn{color:var(--text);font-weight:500}
.sess-prev .st{padding:1px 4px;background:rgba(74,158,255,.1);border-radius:3px;color:var(--accent);font-size:10px}

/* Providers preview */
.prov-prev{margin-top:2px;font-size:10px;color:var(--accent-info)}

/* ── Card Expand ─────────────────────────────────── */
.card-details{display:none;width:100%;font-size:13px;color:var(--text-muted);
  padding:8px 10px;border-top:1px solid var(--border-light)}
.card.expanded{flex-wrap:wrap}
.card.expanded .card-details{display:block}
.card.expanded .card-poster{width:120px;min-height:160px}
.cd-row{margin-bottom:4px;overflow-wrap:break-word}
.cd-label{color:var(--text-dim);font-size:10px;text-transform:uppercase;letter-spacing:.5px}
.cd-actions{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.cd-btn{padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;
  border:none;cursor:pointer;color:#fff;transition:opacity .15s}
.cd-btn:active{opacity:.8}
.btn-quero{background:var(--accent)}
.btn-agendar{background:#f97316}
.btn-feito{background:var(--accent-success);color:#000}
.btn-desc{background:var(--border);color:var(--text-muted)}
.btn-ingresso{background:var(--accent-warning);color:#000}
.btn-danger{background:var(--accent-danger)}

/* Sessions full */
.sess-full{margin-top:6px}
.sess-cinema{padding:4px 0;border-top:1px solid var(--border-light)}
.sess-name{font-size:12px;font-weight:600;color:var(--text)}
.sess-fav{color:var(--accent-warning)}
.sess-times{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}
.sess-t{font-size:11px;padding:2px 6px;background:var(--bg-input);border-radius:4px;
  color:var(--text);text-decoration:none;transition:background .15s}
.sess-t:hover{background:var(--border)}
.sess-t-sala{color:var(--accent-warning)}

/* Providers full */
.providers{display:flex;gap:4px;flex-wrap:wrap;margin-top:3px}
.prov{font-size:10px;padding:2px 6px;border-radius:4px}
.prov-stream{background:rgba(6,182,212,.1);color:var(--accent-info)}
.prov-rent{background:rgba(250,204,21,.1);color:var(--accent-warning)}
.prov-buy{background:rgba(239,68,68,.1);color:var(--accent-danger)}

/* ── Streaming Page ──────────────────────────────── */
.streaming-tabs,.page-tabs{display:flex;gap:0;border-radius:8px;overflow:hidden;
  border:1px solid var(--border);margin-bottom:8px}
.streaming-tabs button,.page-tabs button{flex:1;padding:9px;background:var(--bg-card);border:none;
  color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.streaming-tabs button.active,.page-tabs button.active{background:var(--accent);color:#fff}
.ml-container{padding:4px 0}
.ml-section{margin-bottom:12px}
.streaming-search{width:100%;padding:10px 14px;font-size:14px;
  background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);
  color:var(--text);outline:none;margin-bottom:6px;transition:border-color .15s}
.streaming-search:focus{border-color:var(--accent)}
.streaming-status{display:flex;align-items:center;justify-content:space-between;
  font-size:11px;color:var(--text-muted);padding:2px 0 6px}
.streaming-clear{background:none;border:none;color:var(--accent);cursor:pointer;font-size:11px}

/* Stream card (rendered by JS) */
.stream-card{display:flex;background:var(--bg-card);border-radius:var(--radius);
  margin-bottom:6px;overflow:hidden;cursor:pointer;box-shadow:var(--shadow);transition:all .15s}
.stream-card:active{transform:scale(.99)}
.stream-card .sc-poster{width:80px;min-height:110px;object-fit:cover;flex-shrink:0;background:var(--bg-input)}
.stream-card .sc-body{flex:1;padding:8px 10px;min-width:0}
.stream-card .sc-title{font-size:14px;font-weight:600;line-height:1.3;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stream-card .sc-meta{font-size:11px;color:var(--text-muted);display:flex;flex-wrap:wrap;gap:3px 8px}
.stream-card .sc-providers{margin-top:3px;font-size:10px;color:var(--accent-info)}
.stream-card .sc-status{font-size:10px;padding:1px 6px;border-radius:3px;display:inline-block;margin-top:3px}

/* Stream card expand */
.stream-card .sc-details{display:none;width:100%;font-size:13px;color:var(--text-muted);
  padding:8px 10px;border-top:1px solid var(--border-light)}
.stream-card.expanded{flex-wrap:wrap}
.stream-card.expanded .sc-details{display:block}
.stream-card.expanded .sc-poster{width:120px;min-height:160px}

/* Scroll sentinel */
.scroll-sentinel{height:50px;display:flex;align-items:center;justify-content:center;
  color:var(--text-dim);font-size:12px}
.scroll-sentinel.done{display:none}

/* Badge provider inline */
.badge-prov{font-size:9px;padding:1px 5px;border-radius:3px;
  background:rgba(6,182,212,.1);color:var(--accent-info);display:inline-block}

/* ── Cinema Page ─────────────────────────────────── */
.cinema-filter-bar{padding:6px 0 8px;display:flex;gap:6px;flex-wrap:wrap;
  position:sticky;top:52px;background:var(--bg);z-index:10}

/* ── Modal ────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:50;
  align-items:center;justify-content:center}
.modal-overlay.active{display:flex}
.modal{background:var(--bg-card);border-radius:12px;padding:20px;width:90%;max-width:340px;
  box-shadow:0 8px 32px rgba(0,0,0,.4)}
.modal h3{font-size:16px;margin-bottom:12px}
.modal input[type=date]{width:100%;padding:10px;background:var(--bg-input);
  border:1px solid var(--border);border-radius:8px;color:var(--text);
  font-size:14px;margin-bottom:12px}
.modal-btns{display:flex;gap:8px}
.modal-btn{flex:1;padding:10px;border-radius:8px;border:none;font-size:14px;
  font-weight:600;cursor:pointer;transition:opacity .15s}
.modal-btn:active{opacity:.8}

/* ── Home ─────────────────────────────────────────── */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0}
.cat-tile{border-radius:var(--radius);padding:14px 8px;text-align:center;cursor:pointer;
  transition:transform .1s}
.cat-tile:active{transform:scale(.95)}
.cat-icon{width:28px;height:28px;display:block;margin:0 auto 4px}
.cat-count{font-size:22px;font-weight:700;display:block;margin:2px 0}
.cat-name{font-size:11px;color:var(--text-muted)}
.am-item{display:flex;align-items:center;gap:8px;padding:7px 10px;
  background:var(--bg-card);border-radius:8px;margin-bottom:4px;cursor:pointer;
  box-shadow:var(--shadow)}
.am-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.am-date{font-size:11px;color:var(--text-muted);width:55px;flex-shrink:0}
.am-title{font-size:13px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.alert-bar{background:var(--accent-danger);color:#fff;padding:7px 10px;border-radius:8px;
  font-size:12px;margin-bottom:6px;cursor:pointer;box-shadow:var(--shadow)}
.rec-item{display:flex;align-items:center;gap:8px;padding:6px 10px;
  background:var(--bg-card);border-radius:6px;margin-bottom:3px}
.rec-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.rec-title{font-size:13px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-cat{font-size:10px;color:var(--text-muted)}

/* ── Agenda ───────────────────────────────────────── */
.agenda-toggle{display:flex;gap:0;margin-bottom:8px;border-radius:8px;overflow:hidden;
  border:1px solid var(--border)}
.agenda-toggle button{flex:1;padding:8px;background:var(--bg-card);border:none;
  color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .15s}
.agenda-toggle button.active{background:var(--accent);color:#fff}
.tl-date{font-size:13px;font-weight:700;margin:12px 0 4px;padding-bottom:3px;
  border-bottom:1px solid var(--border)}
.tl-item{display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:var(--bg-card);border-radius:8px;margin-bottom:4px;box-shadow:var(--shadow)}
.tl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.tl-time{font-size:11px;color:var(--text-muted);width:42px;flex-shrink:0}
.tl-info{flex:1}.tl-title{font-size:13px}.tl-loc{font-size:11px;color:var(--text-dim)}
.tl-alert{font-size:10px;padding:2px 5px;border-radius:3px;background:var(--accent-danger);
  color:#fff;margin-left:4px}

/* ── Search ───────────────────────────────────────── */
#search-input{width:100%;padding:10px 14px;font-size:15px;background:var(--bg-card);
  border:1px solid var(--border);border-radius:var(--radius);color:var(--text);
  outline:none;margin-bottom:8px;transition:border-color .15s}
#search-input:focus{border-color:var(--accent)}
.sr-group{margin-bottom:12px}
.sr-header{font-size:13px;font-weight:600;margin-bottom:4px;padding:3px 0;
  border-bottom:1px solid var(--border-light)}
.sr-card{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;
  transition:background .15s}
.sr-card:active{background:var(--bg-card-hover)}
.sr-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.sr-title{font-size:13px;flex:1}.sr-meta{font-size:10px;color:var(--text-dim)}
.empty{text-align:center;color:var(--text-dim);padding:30px 0;font-size:13px}

/* ── Status Badges (CSS classes, not inline) ─────── */
.status-quero{background:rgba(74,158,255,.13);color:var(--accent)}
.status-agendado{background:rgba(250,204,21,.13);color:var(--accent-warning)}
.status-assistindo{background:rgba(6,182,212,.13);color:var(--accent-info)}
.status-pausei{background:rgba(249,115,22,.13);color:#f97316}
.status-feito{background:rgba(74,222,128,.13);color:var(--accent-success)}
.st-feito{opacity:.5}
.st-descartei{display:none}

/* ── Modal button variants (no inline styles) ────── */
.btn-modal-cancel{background:var(--border);color:var(--text-muted)}
.btn-modal-confirm{background:var(--accent);color:#fff}
.btn-modal-warning{background:var(--accent-warning);color:#000}
.btn-modal-success{background:var(--accent-success);color:#000}

/* ── Notes ────────────────────────────────────────── */
.cd-notas{color:var(--accent-warning)}

/* ── Favoritos Page ──────────────────────────────── */
.fav-item{display:flex;align-items:center;gap:8px;padding:8px 10px;
  background:var(--bg-card);border-radius:8px;margin-bottom:4px;box-shadow:var(--shadow)}
.fav-nome{font-size:13px;font-weight:500;flex:1}
.fav-bairro{font-size:11px;color:var(--text-muted)}
.fav-ig{font-size:10px;color:var(--accent-info)}
.fav-monitor{font-size:9px;padding:1px 5px;border-radius:3px;
  background:rgba(74,222,128,.15);color:var(--accent-success)}
.fav-remove{background:none;border:none;color:var(--accent-danger);
  font-size:11px;cursor:pointer;padding:4px}
.fav-form{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.fav-input{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);
  border-radius:8px;color:var(--text);font-size:13px}
.fav-input:focus{border-color:var(--accent);outline:none}

/* ── Drawer (lateral desktop, bottom sheet mobile) ── */
#drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:29}
#drawer-overlay.open{display:block}
#drawer{position:fixed;right:-420px;top:0;bottom:0;width:400px;max-width:100vw;
  background:var(--bg-card);z-index:30;transition:right .3s ease;overflow-y:auto;
  box-shadow:-4px 0 20px rgba(0,0,0,.3);padding:16px}
#drawer.open{right:0}
#drawer-close{position:absolute;top:12px;right:16px;font-size:28px;cursor:pointer;
  color:var(--text-muted);z-index:1;line-height:1}
#drawer-content{padding-top:8px}
@media(max-width:600px){
  /* top:auto resets desktop's top:0 — sem isso, WebKit/Safari ignora bottom:-92vh
     e usa top:0+height:90vh, cobrindo a tela (tela preta no iOS). */
  #drawer{right:auto;top:auto;bottom:-92vh;left:0;width:100%;height:90vh;
    transition:bottom .3s ease;border-radius:16px 16px 0 0;padding:20px 16px}
  #drawer.open{bottom:0}
}

/* Drawer internal elements */
.dr-hero{height:180px;background-size:cover;background-position:center;border-radius:var(--radius) var(--radius) 0 0;margin:-16px -16px 12px}
.dr-poster{width:100%;max-height:300px;object-fit:cover;border-radius:var(--radius);margin-bottom:12px}
.dr-title{font-size:18px;font-weight:700;margin-bottom:4px}
.dr-meta{font-size:12px;color:var(--text-muted);margin-bottom:8px;display:flex;flex-wrap:wrap;gap:4px 10px}
.dr-desc{font-size:13px;color:var(--text-muted);margin-bottom:12px;line-height:1.5}
.dr-section{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 6px}
.dr-row{font-size:13px;margin-bottom:4px}
.dr-row a{color:var(--accent)}
.dr-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}
.dr-badge{font-size:10px;padding:2px 6px;border-radius:4px;display:inline-block}

/* Drawer sessions */
.dr-cinema{margin-bottom:8px}
.dr-cinema-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.dr-cinema-name.fav{color:var(--accent-warning)}
.dr-date{font-size:11px;color:var(--text-muted);margin:4px 0 2px}
.dr-times{display:flex;flex-wrap:wrap;gap:3px}
.dr-time{font-size:11px;padding:2px 6px;background:var(--bg-input);border-radius:4px;
  color:var(--text);text-decoration:none;transition:background .15s}
.dr-time:hover{background:var(--border)}
.dr-time-sala{color:var(--accent-warning);font-size:10px}
.dr-time-preco{color:var(--accent-success);font-size:10px}
.dr-rede{font-size:11px;color:var(--text-muted);font-weight:400}
.dr-cinema-addr{font-size:11px;margin-bottom:4px}
.dr-cinema-addr a{color:var(--text-muted);text-decoration:none}
.dr-notas{width:100%;min-height:60px;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:8px;font-size:13px;resize:vertical;font-family:inherit}

/* ── Toast ────────────────────────────────────────── */
.toast{position:fixed;bottom:70px;left:50%;transform:translateX(-50%);
  background:var(--accent-success);color:#000;padding:8px 20px;border-radius:8px;
  font-size:13px;font-weight:500;z-index:50;pointer-events:none;
  animation:toastfade 2s ease forwards}
@keyframes toastfade{0%{opacity:1}70%{opacity:1}100%{opacity:0}}

/* ── Utilities ────────────────────────────────────── */
.hidden{display:none!important}
.text-center{text-align:center}
.text-muted{color:var(--text-muted);font-size:11px}
.home-link{font-size:12px;color:var(--accent);text-align:right;padding:4px 0;cursor:pointer}

/* ── News Page ───────────────────────────────────── */
.news-entry{display:flex;align-items:center;gap:6px;padding:6px 0;border-bottom:1px solid var(--border);cursor:pointer}
.news-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.news-fonte{font-size:10px;color:var(--text-muted);min-width:60px}
.news-title{flex:1;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.news-cat{font-size:10px;color:var(--text-muted)}

/* ── Config Page ─────────────────────────────────── */
.cfg-section{margin-bottom:12px}
.cfg-cat-header{font-size:13px;font-weight:600;margin-bottom:4px}
.cfg-venue{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-size:12px;border-bottom:1px solid var(--border)}
.cfg-venue.cfg-fav{background:var(--accent)08}
.cfg-venue-name{flex:1}
.cfg-actions{display:flex;gap:4px}
.cfg-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:2px 8px;font-size:11px;cursor:pointer}
.cfg-btn:hover{border-color:var(--accent)}
.cfg-btn-danger{color:var(--accent-danger)}
.cfg-add{display:flex;gap:4px;padding:4px 0;flex-wrap:wrap}
.cfg-input{background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:4px 8px;font-size:11px;flex:1;min-width:80px}
.cfg-sub{font-size:12px;padding:2px 0 2px 16px}
