*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0a0a0a;
  --s1:#111;
  --s2:#181818;
  --s3:#222;
  --line:#2c2c2c;
  --line2:#383838;
  --t1:#ddd5c8;
  --t2:#a09890;
  --t3:#5a5450;
  --acc:#d4a843;
  --acc2:#c45a3a;
  --th:#d4a843;
  --nf:#e50914;
  --amz:#1a9ed4;
  --hbo:#7b4fa0;
  --hlu:#19d47a;
  --pck:#e8a830;
  --par:#0055ee;
  --dis:#1a65e0;
  --apl:#f03040;
  --shd:#44b844;
  --mub:#e04030;
  --vod:#666;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--t1);font-family:'Roboto',sans-serif;font-size:15px;line-height:1.5}

/* ─── HEADER ─────────────────────────────────────────── */
#hdr{
  position:sticky;top:0;z-index:200;
  background:var(--bg);
  border-bottom:1px solid var(--line2);
  overflow:visible;
}
.hdr-top{
  display:flex;align-items:center;gap:16px;
  padding:12px 20px 10px;
  border-bottom:1px solid var(--line);
}
.logo{
  font-family:'Roboto Condensed',sans-serif;
  font-size:26px;font-weight:700;letter-spacing:.14em;
  color:var(--acc);line-height:1;text-transform:uppercase;
}
.logo-init{
  color:var(--acc);font-size:26px;display:inline-block;line-height:1;
}
.logo-sub{
  font-family:'Roboto',sans-serif;
  font-size:11px;color:var(--t3);letter-spacing:.1em;
  text-transform:uppercase;margin-top:3px;
}
.hdr-stats{display:none}
.hdr-stats b{color:var(--t2);font-weight:500}

/* ─── CONTROLS ───────────────────────────────────────── */
.ctrl-bar{
  display:flex;align-items:center;flex-wrap:nowrap;gap:12px;
  padding:8px 20px;
  border-bottom:1px solid var(--line);
  overflow:visible;
  width:100%;
}
.ctrl-lbl{
  font-family:'Roboto',sans-serif;
  font-size:12px;color:var(--t3);text-transform:uppercase;letter-spacing:.064em;
  margin-right:2px;
}
.btn-row{display:flex;gap:1px}
.btn{
  background:var(--s1);border:1px solid var(--line);
  color:var(--t3);font-family:'Roboto',sans-serif;
  font-size:12px;letter-spacing:.04em;padding:6px 10px;
  cursor:pointer;transition:all .12s;white-space:nowrap;
}
.btn:hover{background:var(--s2);border-color:var(--line2);color:var(--t2)}
.btn.on{background:var(--acc);border-color:var(--acc);color:#000;font-weight:500}

.search-box{
  margin-left:auto;position:relative;
}
.search-box input{
  background:var(--s1);border:1px solid var(--line);
  color:var(--t1);font-family:'Roboto',sans-serif;
  font-size:13px;padding:6px 10px 4px 26px;width:200px;
  outline:none;letter-spacing:.04em;transition:border-color .12s;
}
.search-box input:focus{border-color:var(--acc)}
.search-box input::placeholder{color:var(--t3)}
.search-icon{
  position:absolute;left:8px;top:50%;transform:translateY(-50%);
  color:var(--t3);font-size:12px;pointer-events:none;
}

/* ─── LEGEND BAR ─────────────────────────────────────── */
.legend-bar{
  display:flex;align-items:center;gap:10px;flex-wrap:nowrap;
  padding:6px 20px;
  background:var(--s1);
  border-bottom:1px solid var(--line);
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.legend-bar::-webkit-scrollbar{display:none}
.leg{
  display:flex;align-items:center;gap:5px;
  font-family:'Roboto',sans-serif;font-size:12px;
  color:var(--t3);letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;padding:5px 8px;border:1px solid transparent;border-radius:2px;
  transition:all .12s;user-select:none;flex-shrink:0;
}
.leg:hover{color:var(--t2);border-color:var(--line)}
.leg.active{color:var(--t1);border-color:var(--line2);background:var(--s2)}
.leg.dimmed{opacity:.3}
.leg-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.leg-bar{width:3px;height:12px;border-radius:1px;background:var(--acc)}

/* ─── BODY ───────────────────────────────────────────── */
#body{padding:0 20px 60px}

/* month header */
.mo-hdr{
  display:flex;align-items:center;gap:14px;
  padding:24px 0 10px;
}
.mo-name{
  font-family:'Roboto Condensed',sans-serif;
  font-size:18px;font-weight:600;letter-spacing:.14em;
  color:var(--t3);text-transform:uppercase;
}
.mo-rule{flex:1;height:1px;background:var(--line)}
.mo-ct{
  font-family:'Roboto',sans-serif;
  font-size:9px;color:var(--t3);letter-spacing:.1em;
}

/* week block */
.wk{margin-bottom:4px;border:1px solid var(--line);overflow:visible}
.wk-hdr{
  display:flex;align-items:center;gap:12px;
  background:var(--s1);padding:6px 10px;
  border-bottom:1px solid var(--line);
  cursor:pointer;user-select:none;
  position:sticky;
  top:var(--hdr-h, 120px);
  z-index:30;
  border-left:1px solid var(--line);
  border-right:1px solid var(--line);
}
.wk-hdr:hover{background:var(--s2)}
.wk-lbl{
  font-family:'Roboto Condensed',sans-serif;
  font-size:18px;font-weight:600;letter-spacing:.1em;
  color:var(--acc);min-width:130px;
}
.wk-meta{
  font-family:'Roboto',sans-serif;
  font-size:9px;color:var(--t3);
  display:flex;gap:10px;
}
.wk-meta em{color:var(--t2);font-style:normal;font-weight:500}
.wk-chevron{margin-left:auto;color:var(--t3);font-size:11px;transition:transform .18s}
.wk.closed .wk-chevron{transform:rotate(-90deg)}
.wk.closed .wk-body{display:none}

/* matrix table */
.mtx{width:100%;border-collapse:collapse;table-layout:fixed}
.mtx thead{position:sticky;top:var(--thead-h, 155px);z-index:20}
.mtx th{
  font-family:'Roboto Mono',monospace;
  font-size:9px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  padding:5px 4px;text-align:left;
  background:var(--s1);border-bottom:1px solid var(--line);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.mtx th.plat-th{text-align:left}
.mtx th.date-th{width:46px}

.mtx tr.dr{border-bottom:1px solid var(--line);scroll-margin-top:calc(var(--hdr-h, 186px) + 8px)}
.mtx tr.dr:last-child{border-bottom:none}
.mtx td{padding:5px 8px;vertical-align:top;border-right:1px solid var(--line);overflow:hidden}
.mtx td:last-child{border-right:none}
.mtx td.datecell{width:46px;white-space:nowrap;padding:6px 4px}
.day-num{
  font-family:'Roboto Condensed',sans-serif;
  font-size:26px;font-weight:400;line-height:1;color:var(--t1)
}
.day-wd{
  font-family:'Roboto Mono',monospace;
  font-size:10px;color:var(--t2);letter-spacing:.12em;text-transform:uppercase;margin-top:2px
}
.mtx td.platcell{overflow:hidden}

/* film pill */
.fp{
  display:flex;align-items:baseline;gap:5px;
  padding:2px 3px;cursor:pointer;border-radius:2px;
  transition:background .1s;
}
.fp:hover{background:rgba(212,168,67,.07)}
.fp .fd{
  width:5px;height:5px;border-radius:50%;flex-shrink:0;
  margin-top:4px;
}
.fp .ft{
  font-size:11px;color:var(--t2);line-height:1.35;flex:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.fp.fkey .ft{color:var(--t1);font-weight:500}
.fp.fdebut .ft::after{content:' ★';font-size:8px;color:var(--acc)}
.fp .fkbar{
  width:2px;height:100%;min-height:14px;align-self:stretch;
  background:var(--acc);border-radius:1px;flex-shrink:0;
}
.fp:not(.fkey) .fkbar{display:none}
.empty-dash{color:var(--t3);font-size:11px;opacity:.25;padding:2px 0;font-family:'Roboto Mono',monospace}

/* platform header colors */
.c-th{color:var(--th)} .c-nf{color:var(--nf)} .c-amz{color:var(--amz)}
.c-hbo{color:var(--hbo)} .c-hlu{color:var(--hlu)} .c-pck{color:var(--pck)}
.c-par{color:var(--par)} .c-dis{color:var(--dis)} .c-apl{color:var(--apl)}
.c-shd{color:var(--shd)} .c-mub{color:var(--mub)} .c-vod{color:var(--vod)}

/* dot bg colors */
.d-th{background:var(--th)} .d-nf{background:var(--nf)} .d-amz{background:var(--amz)}
.d-hbo{background:var(--hbo)} .d-hlu{background:var(--hlu)} .d-pck{background:var(--pck)}
.d-par{background:var(--par)} .d-dis{background:var(--dis)} .d-apl{background:var(--apl)}
.d-shd{background:var(--shd)} .d-mub{background:var(--mub)} .d-vod{background:var(--vod)}

/* ─── MODAL ──────────────────────────────────────────── */
#moverlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.8);z-index:200;
  align-items:center;justify-content:center;
  backdrop-filter:blur(6px);
}
#moverlay.open{display:flex}
#mbox{
  background:var(--s1);border:1px solid var(--line2);
  width:640px;max-width:94vw;max-height:88vh;overflow-y:auto;
}
.mhdr{
  padding:18px 18px 12px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:var(--s1);
}
.mplat{
  font-family:'Roboto Mono',monospace;
  font-size:11px;color:var(--t3);letter-spacing:.08em;text-transform:uppercase;
  display:flex;align-items:center;gap:6px;margin-top:6px;
  flex-wrap:wrap;padding-right:52px;
}
.mtitle{
  font-family:'Roboto Condensed',sans-serif;
  font-size:22px;font-weight:600;letter-spacing:.04em;
  color:var(--t1);line-height:1.1;padding-right:52px;
}
.mclose{
  position:absolute;top:14px;right:14px;
  background:none;border:1px solid var(--line2);
  color:var(--t2);width:34px;height:34px;
  cursor:pointer;font-size:12px;
  display:flex;align-items:center;justify-content:center;
}
.mclose:hover{border-color:var(--t2);color:var(--t1)}
.mbody{padding:12px 14px;flex:1}
.mrow{
  display:flex;gap:12px;padding:10px 0;
  border-bottom:1px solid var(--line);
}
.mrow:last-child{border-bottom:none}
.mbody{padding:12px 14px;flex:1}
.mkey{
  font-family:'Roboto Mono',monospace;
  font-size:10px;color:var(--t3);text-transform:uppercase;
  letter-spacing:.04em;min-width:100px;width:100px;flex-shrink:0;padding-top:2px;
}
.mval{font-size:13px;color:var(--t1)}
.imdb-link{
  display:flex;align-items:center;justify-content:center;flex:1;
  background:#f5c518;color:#000;
  font-family:'Roboto Mono',monospace;
  font-size:13px;font-weight:500;white-space:nowrap;
  padding:10px 14px;text-decoration:none;letter-spacing:.06em;
}
.imdb-link:hover{opacity:.85}

#noresults{
  display:none;text-align:center;padding:80px 20px;
  font-family:'Roboto Mono',monospace;font-size:11px;color:var(--t3);
}

/* ─── MOBILE LIST VIEW ───────────────────────────────── */
.mob-list{display:none}
.mob-day-hdr{
  scroll-margin-top:calc(var(--hdr-h, 186px) + 8px);
  display:flex;align-items:baseline;gap:8px;
  padding:10px 12px 6px;
  border-bottom:1px solid var(--line);
  position:sticky;top:var(--hdr-h,120px);z-index:20;
  background:var(--bg);
}
.mob-day-num{
  font-family:'Roboto Condensed',sans-serif;
  font-size:24px;font-weight:400;color:var(--t1);line-height:1;
}
.mob-day-wd{
  font-family:'Roboto Mono',monospace;
  font-size:11px;color:var(--t2);letter-spacing:.12em;text-transform:uppercase;
}
.mob-film{
  display:flex;align-items:center;gap:8px;
  padding:12px 12px;border-bottom:1px solid var(--line);
  cursor:pointer;transition:background .1s;
}
.mob-film:hover{background:var(--s1)}
.mob-film.fkey{border-left:2px solid var(--acc);padding-left:10px}
.mob-plat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.mob-title{flex:1;font-size:15px;color:var(--t2);line-height:1.35}
.mob-film.fkey .mob-title{color:var(--t1);font-weight:500}
.mob-film.fdebut .mob-title::after{content:' ★';font-size:9px;color:var(--acc)}
.mob-plat-lbl{
  font-family:'Roboto Mono',monospace;
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  flex-shrink:0;
}

.mbtns{display:flex;gap:8px;padding:16px 0 4px}

@media(max-width:374px){
  .mbtns{flex-direction:column}
  .mbtns .imdb-link, .mbtns }

@media(max-width:1024px) and (orientation:portrait), (max-width:767px){
  .mplat{font-size:10px}
  .mkey{font-size:15px}
  .mval{font-size:20px}
  .mtitle{font-size:28px}
  .mtx-wrap{display:none}
  .mob-list{display:block}
  #body{padding:0 0 60px}
  .hdr-top{padding:8px 12px 8px}
  .logo{font-size:5.5vw;letter-spacing:.06em;white-space:nowrap;color:var(--acc)}
  .logo-init{font-size:7vw}
  .logo-sub{font-size:3vw;letter-spacing:.05em;white-space:nowrap}
  .hdr-stats{display:none}
  #mbox{width:94vw;max-width:94vw}
  .mposter-col{width:100%!important;min-width:unset!important;min-height:unset!important;border-right:none;border-bottom:1px solid var(--line)}
  .mposter-col img{width:100%!important;height:auto!important;max-width:100%!important;object-fit:cover}
  .ctrl-bar{padding:6px 12px;gap:6px;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .ctrl-bar::-webkit-scrollbar{display:none}
  .ctrl-lbl{display:none}
  .search-box{margin-left:0;width:100%}
  .search-box input{width:100%}
  .legend-bar{padding:6px 12px;gap:8px}
  .mo-hdr{padding:16px 12px 8px}
  .wk-hdr{padding:6px 10px}
  .wk-meta{display:none}
  .wk-lbl{min-width:unset}
}

/* ─── TMDB POSTER ────────────────────────────────────── */
.mposter-col{
  flex-shrink:0;
  border-right:1px solid var(--line);
  position:relative;
  width:220px;min-width:220px;
  min-height:320px;
  display:flex;
  align-items:stretch;
}
.mposter-col img{
  width:100%;
  height:100%;
  max-width:220px;
  display:block;
  object-fit:contain;
}
.mposter-loading{
  width:120px;height:100%;min-height:200px;
  background:var(--s2);
  display:flex;align-items:center;justify-content:center;
  font-family:'Roboto Mono',monospace;font-size:9px;
  color:var(--t3);letter-spacing:.08em;
}
.mbody-col{
  flex:1;min-width:0;
  display:flex;flex-direction:column;
}

.mtrailer-btn{
  display:flex;align-items:center;justify-content:center;gap:6px;flex:1;
  background:var(--acc2);color:#fff;
  font-family:'Roboto Mono',monospace;
  font-size:13px;letter-spacing:.06em;white-space:nowrapm;
  padding:10px 14px;text-decoration:none;
  border:none;cursor:pointer;
  transition:opacity .15s;
}
.mtrailer-btn:hover{opacity:.85}


/* ─── FOOTER ─────────────────────────────────────────── */
#footer{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  padding:16px 20px;
  border-top:1px solid var(--line);
  margin-top:20px;
}
.footer-text{
  font-family:'Roboto Mono',monospace;
  font-size:9px;color:var(--t2);letter-spacing:.06em;
  line-height:1.5;flex:1;min-width:200px;
}
.tmdb-logo{
  display:flex;align-items:center;flex-shrink:0;
}
.tmdb-logo img{
  height:16px;width:auto;opacity:.6;transition:opacity .15s;
}
.tmdb-logo:hover img{opacity:1}

@media(max-width:1024px) and (orientation:portrait), (max-width:767px){
  #mbox{
    width:94vw;
    max-height:88vh;
  }
  #mcontents{
    flex-direction:column;
  }
  .mposter-col{
    width:100%;max-width:100%;
    border-right:none;
    border-bottom:1px solid var(--line);
    overflow:hidden;
  }
  .mposter-col img{
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    margin:0 !important;
    display:block;
    object-fit:cover;
  }
  .mposter-loading{
    width:100%;height:80px;min-height:unset;
  }
  .mbody-col{
    width:100%;
  }
  .mhdr{
    padding:14px 14px 10px;
  }
  .mtitle{
    font-size:20px;
  }
  .mbody{
    padding:10px 14px;
  }
  .mrow{
    gap:8px;
  }
  .mkey{
    min-width:70px;font-size:9px;
  }
  .mval{
    font-size:11px;
  }
}

.genre-drop{position:relative;margin-left:8px;flex-shrink:0;overflow:visible}
.genre-drop-btn{
  background:var(--s1);border:1px solid var(--line);
  color:var(--t3);font-family:'Roboto',sans-serif;
  font-size:12px;letter-spacing:.04em;padding:5px 9px;
  cursor:pointer;transition:all .12s;white-space:nowrap;
  display:flex;align-items:center;gap:6px;flex-shrink:0;
}
.genre-drop-btn:hover{background:var(--s2);border-color:var(--line2);color:var(--t2)}
.genre-drop-btn.on{background:var(--acc);border-color:var(--acc);color:#000;font-weight:500}
.genre-drop-btn .arrow{font-size:9px;transition:transform .15s}
.genre-drop-btn.open .arrow{transform:rotate(180deg)}
.genre-menu{
  display:none;position:fixed;
  background:var(--s1);border:1px solid var(--line2);
  z-index:1000;min-width:140px;
  max-height:280px;overflow-y:auto;
}
.genre-menu.open{display:block}
.genre-opt{
  display:block;width:100%;text-align:left;
  background:none;border:none;
  font-family:'Roboto',sans-serif;font-size:12px;
  letter-spacing:.06em;color:var(--t2);
  padding:6px 10px;cursor:pointer;
  transition:background .1s;white-space:nowrap;
}
.genre-opt:hover{background:var(--s2);color:var(--t1)}
.genre-opt.on{color:var(--acc);font-weight:500}

/* ─── SEARCH PANEL ───────────────────────────────────── */
#search-panel{
  position:fixed;top:0;right:-400px;width:380px;height:100vh;
  background:var(--s1);border-left:1px solid var(--line2);
  z-index:150;display:flex;flex-direction:column;
  transition:right .25s ease;
}
#search-panel.open{right:0}
#panel-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.5);z-index:149;
}
#panel-overlay.open{display:block}
.panel-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:13px 16px;border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.panel-hdr-title{
  font-family:'Roboto Condensed',sans-serif;
  font-size:16px;font-weight:600;letter-spacing:.1em;
  color:var(--acc);
}
.panel-close{
  background:none;border:1px solid var(--line);
  color:var(--t3);width:26px;height:26px;
  cursor:pointer;font-size:12px;
  display:flex;align-items:center;justify-content:center;
}
.panel-close:hover{border-color:var(--t2);color:var(--t1)}
.panel-search-wrap{
  padding:10px 16px;border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.panel-search-wrap input{
  width:100%;background:var(--s2);border:1px solid var(--line);
  color:var(--t1);font-family:'Roboto Mono',monospace;
  font-size:13px;padding:6px 10px;outline:none;
  letter-spacing:.04em;transition:border-color .12s;
}
.panel-search-wrap input:focus{border-color:var(--acc)}
.panel-search-wrap input::placeholder{color:var(--t2)}
.panel-results{flex:1;overflow-y:auto}
.panel-empty{
  padding:40px 16px;text-align:center;
  font-family:'Roboto Mono',monospace;
  font-size:10px;color:var(--t3);letter-spacing:.08em;
}
.presult{
  border-bottom:1px solid var(--line);cursor:pointer;
  transition:background .1s;
}
.presult:hover{background:var(--s2)}
.presult-row{
  display:flex;gap:10px;padding:10px 16px;align-items:flex-start;
}
.presult-thumb{
  width:36px;height:54px;object-fit:cover;
  border:1px solid var(--line);flex-shrink:0;
  background:var(--s2);display:block;
}
.presult-thumb-empty{
  width:36px;height:54px;flex-shrink:0;
  background:var(--s2);border:1px solid var(--line);
}
.presult-main{flex:1;min-width:0}
.presult-title{
  font-size:13px;font-weight:500;color:var(--t1);line-height:1.3;
}
.presult-sub{
  font-family:'Roboto Mono',monospace;
  font-size:10px;color:var(--t3);margin-top:3px;letter-spacing:.04em;
}
.presult-overview{
  font-size:11px;color:var(--t2);margin-top:4px;
  line-height:1.45;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.presult-chevron{
  font-size:12px;color:var(--t3);flex-shrink:0;margin-top:2px;
  transition:transform .15s;
}
.presult.expanded .presult-chevron{transform:rotate(90deg)}
.presult-detail{
  display:none;padding:0 16px 12px;
  border-top:1px solid var(--line);margin:0 16px;
}
.presult.expanded .presult-detail{display:block}
.pdet-row{
  display:flex;gap:8px;padding:5px 0;
  border-bottom:1px solid var(--line);
}
.pdet-row:last-child{border-bottom:none}
.pdet-key{
  font-family:'Roboto Mono',monospace;
  font-size:9px;color:var(--t3);text-transform:none;
  letter-spacing:.08em;min-width:72px;padding-top:2px;flex-shrink:0;
}
.pdet-val{
  font-size:11px;color:var(--t1);line-height:1.45;
  user-select:all;text-transform:none;
}
.pdet-val.mono{font-family:'Roboto Mono',monospace;font-size:10px}

/* Search trigger button */
#search-trigger{
  display:flex;align-items:center;gap:6px;
  background:var(--s1);border:1px solid var(--line);
  color:var(--t3);font-family:'Roboto',sans-serif;
  font-size:13px;letter-spacing:.04em;padding:6px 10px 4px 10px;
  cursor:pointer;transition:all .12s;white-space:nowrap;text-align:left;
}

#search-trigger:hover{background:var(--s2);border-color:var(--line2);color:var(--t1)}