/* ============================================================
   tv.alkamali.uk — cinematic dark theme
   Identity taken directly from the published library (books.alkamali.uk):
   deep emerald + gold + cream, Amiri display / Tajawal UI.
   ============================================================ */

@font-face { font-family:"Amiri";   src:url("/fonts/amiri-400.woff2")   format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Amiri";   src:url("/fonts/amiri-700.woff2")   format("woff2"); font-weight:700; font-display:swap; }
@font-face { font-family:"Tajawal"; src:url("/fonts/tajawal-400.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Tajawal"; src:url("/fonts/tajawal-500.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Tajawal"; src:url("/fonts/tajawal-700.woff2") format("woff2"); font-weight:700; font-display:swap; }

:root{
  --font-display:"Amiri","Georgia",serif;
  --font-ui:"Tajawal","Segoe UI",system-ui,sans-serif;

  /* library palette */
  --gold:#C9A24B;
  --gold-soft:#E6C977;
  --gold-deep:#A5822F;
  --cream:#F3E9D2;

  --bg-deep:#081814;
  --bg:#0A1E1A;
  --bg-2:#0C2420;
  --bg-3:#123430;

  --surface:rgba(255,255,255,.045);
  --surface-2:rgba(201,162,75,.10);
  --surface-hi:rgba(255,255,255,.09);
  --border:rgba(201,162,75,.20);
  --border-hi:rgba(201,162,75,.5);

  --text:#F3E9D2;
  --muted:#8FB3A6;
  --faint:#5F7D71;

  --live:#F26D6D;
  --ok:#63C9A0;

  --radius-sm:8px; --radius:14px; --radius-lg:20px; --radius-xl:26px;
  --shadow:0 8px 30px rgba(0,0,0,.5);
  --shadow-lg:0 18px 55px rgba(0,0,0,.6);
  --glow:0 0 0 1px rgba(201,162,75,.4), 0 12px 40px rgba(201,162,75,.18);
  --t:.2s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:var(--font-ui);
  background:
    radial-gradient(120% 90% at 50% -8%, var(--bg-3) 0%, var(--bg-2) 42%, var(--bg-deep) 100%);
  background-attachment:fixed;
  color:var(--text);
  direction:rtl;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
::selection{background:rgba(201,162,75,.35);color:#fff}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
[hidden]{display:none !important}
::-webkit-scrollbar{height:8px;width:8px}
::-webkit-scrollbar-thumb{background:rgba(201,162,75,.30);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}

/* ---------------------------- LOGIN GATE ---------------------------- */
#gate{
  position:fixed;inset:0;z-index:1000;display:grid;place-items:center;
  background:radial-gradient(320px 320px at 50% 16%,rgba(201,162,75,.12),transparent 70%),
    radial-gradient(120% 90% at 50% -8%, var(--bg-3), var(--bg-deep));
  padding:24px;
}
.gate-card{
  width:min(430px,100%);text-align:center;
  background:linear-gradient(180deg, rgba(18,52,48,.55), rgba(10,30,26,.7));
  border:1px solid var(--border);border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);padding:42px 32px;backdrop-filter:blur(10px);
  animation:pop .5s cubic-bezier(.2,.8,.2,1);
}
.gate-logo{font-family:var(--font-display);font-size:42px;font-weight:700;letter-spacing:.5px;color:var(--cream)}
.gate-logo .dot{color:var(--gold)}
.gate-sub{color:var(--muted);margin:8px 0 30px;font-size:14px}
.pin-wrap{display:flex;flex-direction:row;gap:10px;justify-content:center;margin-bottom:8px;direction:ltr}
.pin{
  width:46px;height:60px;border-radius:14px;background:var(--surface);
  border:1.5px solid var(--border);display:grid;place-items:center;
  font-size:26px;font-weight:700;color:var(--cream);transition:var(--t);
}
.pin.filled{border-color:var(--gold);background:var(--surface-2);box-shadow:0 0 0 3px rgba(201,162,75,.14)}
.pin.err{border-color:var(--live);animation:shake .4s}
.pad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px;direction:ltr}
.key{
  height:64px;border-radius:16px;background:var(--surface);border:1px solid var(--border);
  font-size:24px;font-weight:600;color:var(--cream);transition:var(--t);
}
.key:hover{border-color:var(--border-hi)}
.key:active{background:var(--surface-2);transform:scale(.96)}
.key .ic{font-size:20px;color:var(--muted)}
.gate-hint{margin-top:22px;color:var(--faint);font-size:12.5px}

/* ------------------------------ SHELL ------------------------------ */
#app{display:flex;min-height:100dvh}
.side{
  position:sticky;top:0;height:100dvh;flex:0 0 96px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:20px 0;background:linear-gradient(180deg,rgba(12,36,32,.6),rgba(8,24,20,.3));
  border-inline-start:1px solid var(--border);backdrop-filter:blur(8px);z-index:40;
}
.brand{font-family:var(--font-display);font-weight:700;font-size:17px;line-height:1.1;text-align:center;margin-bottom:16px;color:var(--cream)}
.brand .dot{color:var(--gold)}
.navbtn{
  width:68px;padding:11px 6px;border-radius:16px;display:flex;flex-direction:column;
  align-items:center;gap:5px;color:var(--muted);transition:var(--t);font-size:11px;font-weight:500;
}
.navbtn svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.7}
.navbtn:hover{color:var(--cream);background:var(--surface)}
.navbtn.active{color:var(--gold-soft);background:var(--surface-2);box-shadow:inset 0 0 0 1px var(--border-hi)}
.navbtn.active svg{stroke:var(--gold)}
.side .spacer{flex:1}

.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* top bar */
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;
  padding:16px 26px;backdrop-filter:blur(12px);
  background:linear-gradient(180deg,rgba(8,24,20,.9),rgba(8,24,20,.35));
  border-bottom:1px solid var(--border);
}
.page-title{font-family:var(--font-display);font-size:27px;font-weight:700;color:var(--cream)}
.topbar .grow{flex:1}
.search{
  display:flex;align-items:center;gap:10px;background:var(--surface);
  border:1px solid var(--border);border-radius:999px;padding:10px 16px;width:min(340px,42vw);transition:var(--t);
}
.search:focus-within{border-color:var(--border-hi);box-shadow:0 0 0 3px rgba(201,162,75,.12)}
.search input{background:none;border:none;outline:none;color:var(--text);width:100%;font-size:14.5px}
.search input::placeholder{color:var(--faint)}
.search svg{width:18px;height:18px;stroke:var(--muted);fill:none;stroke-width:1.8;flex:none}
.icon-btn{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:var(--surface);border:1px solid var(--border);transition:var(--t);flex:none;
}
.icon-btn:hover{background:var(--surface-2);border-color:var(--border-hi)}
.icon-btn svg{width:20px;height:20px;stroke:var(--cream);fill:none;stroke-width:1.8}

/* content scroller */
.content{padding:22px 26px 60px;flex:1}

/* hero ring (signature echo of the library) */
.hero{position:relative;text-align:center;padding:8px 0 4px;margin-bottom:6px}
.ring-wrap{position:relative;height:290px;display:flex;align-items:center;justify-content:center;perspective:1100px}
.ring{--w:126px;--h:184px;--tz:200px;--rx:-6deg;--q:1;position:absolute;width:var(--w);height:var(--h);top:6%;
  transform-style:preserve-3d;transform:perspective(1100px);animation:ring-spin 46s linear infinite}
.ring:hover,.ring.paused{animation-play-state:paused}
@keyframes ring-spin{from{transform:perspective(1100px) rotateX(var(--rx)) rotateY(0)}
  to{transform:perspective(1100px) rotateX(var(--rx)) rotateY(1turn)}}
.ring-card{position:absolute;inset:0;border:1.5px solid rgba(201,162,75,.55);border-radius:12px;overflow:hidden;
  box-shadow:0 12px 34px rgba(0,0,0,.5);cursor:pointer;
  transform:rotateY(calc((360deg / var(--q)) * var(--i))) translateZ(var(--tz));backface-visibility:hidden}
.ring-card img{width:100%;height:100%;object-fit:cover;display:block}
.ring-card .rc-fallback{width:100%;height:100%;display:grid;place-items:center;text-align:center;padding:8px;
  font-family:var(--font-display);font-size:14px;color:var(--cream);
  background:linear-gradient(150deg,var(--bg-3),var(--bg-2))}
.ring-card.soon{border-style:dashed;border-color:rgba(143,179,166,.4);box-shadow:none;
  display:flex;align-items:center;justify-content:center;color:var(--muted);
  font-family:var(--font-display);font-size:15px;background:linear-gradient(150deg,#153b34,#0f2b26)}

/* chips */
.chips{display:flex;gap:10px;overflow-x:auto;padding:4px 2px 16px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{
  flex:none;padding:9px 18px;border-radius:999px;background:var(--surface);
  border:1px solid var(--border);color:var(--muted);font-weight:500;font-size:14px;
  transition:var(--t);white-space:nowrap;
}
.chip:hover{color:var(--cream);border-color:var(--border-hi)}
.chip.active{
  background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));
  color:#20160a;border-color:transparent;box-shadow:0 6px 18px rgba(165,130,47,.4);font-weight:700;
}

/* section heading */
.row-head{display:flex;align-items:baseline;gap:12px;margin:26px 2px 14px}
.row-head h2{font-family:var(--font-display);font-size:23px;font-weight:700;color:var(--cream)}
.row-head .count{color:var(--faint);font-size:13px}
.row-head .more{margin-inline-start:auto;color:var(--gold);font-size:13px;font-weight:600}

/* card grid */
.grid{
  display:grid;gap:20px;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
}
.grid.live{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}

/* horizontal rail */
.rail{display:flex;gap:20px;overflow-x:auto;padding:4px 2px 16px;scroll-snap-type:x mandatory}
.rail::-webkit-scrollbar{height:6px}
.rail .card{flex:0 0 216px;scroll-snap-align:start}

.card{
  position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-hi)}
.poster{aspect-ratio:2/3;width:100%;object-fit:cover;background:linear-gradient(135deg,var(--bg-3),var(--bg-2))}
.card.ch .poster{aspect-ratio:16/10;object-fit:contain;padding:14px;background:radial-gradient(circle at 50% 40%,rgba(201,162,75,.10),var(--bg-2))}
.poster.ph{display:grid;place-items:center;color:var(--muted);font-family:var(--font-display);font-size:15px;text-align:center;padding:10px;line-height:1.5}
.card-body{padding:12px 14px 14px}
.card-title{font-size:15.5px;font-weight:500;line-height:1.4;color:var(--cream);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.8em}
.card-sub{color:var(--faint);font-size:12.5px;margin-top:4px}
.card .fav{
  position:absolute;top:8px;inset-inline-start:8px;width:34px;height:34px;border-radius:10px;
  display:grid;place-items:center;background:rgba(8,24,20,.6);backdrop-filter:blur(4px);
  opacity:0;transition:var(--t);
}
.card:hover .fav,.card .fav.on{opacity:1}
.card .fav svg{width:18px;height:18px;stroke:var(--cream);fill:none;stroke-width:1.8}
.card .fav.on svg{fill:var(--gold);stroke:var(--gold)}
.card .badge{
  position:absolute;top:8px;inset-inline-end:8px;padding:3px 9px;border-radius:8px;font-size:11px;font-weight:700;
  background:rgba(8,24,20,.62);backdrop-filter:blur(4px);color:var(--gold-soft);
}
.card .live-dot{position:absolute;top:8px;inset-inline-end:8px;display:flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:8px;background:rgba(8,24,20,.62);backdrop-filter:blur(4px);font-size:11px;font-weight:700;color:var(--cream)}
.card .live-dot i{width:7px;height:7px;border-radius:50%;background:var(--live);animation:blink 1.4s infinite}
.progress{position:absolute;bottom:0;inset-inline:0;height:4px;background:rgba(255,255,255,.14)}
.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-soft),var(--gold-deep))}

/* empty / states */
.empty{text-align:center;padding:70px 20px;color:var(--muted)}
.empty .em-ic{font-size:52px;margin-bottom:14px;opacity:.7}
.empty h3{font-family:var(--font-display);font-size:23px;color:var(--cream);margin-bottom:8px}
.empty p{max-width:460px;margin:0 auto 18px;line-height:1.8;font-size:14.5px}
.btn{
  display:inline-flex;align-items:center;gap:9px;padding:12px 22px;border-radius:14px;font-weight:700;font-size:14.5px;
  background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:#20160a;
  box-shadow:0 8px 24px rgba(165,130,47,.32);transition:var(--t);
}
.btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.btn.ghost{background:var(--surface);border:1px solid var(--border);color:var(--cream);box-shadow:none}
.btn.ghost:hover{border-color:var(--border-hi)}
.btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}

/* skeletons */
.sk{border-radius:var(--radius);background:linear-gradient(100deg,var(--bg-3) 30%,var(--surface-hi) 50%,var(--bg-3) 70%);
  background-size:200% 100%;animation:shimmer 1.3s infinite;aspect-ratio:2/3}

/* --------------------------- DETAIL / MODAL --------------------------- */
.overlay{
  position:fixed;inset:0;z-index:200;background:rgba(4,12,10,.75);backdrop-filter:blur(6px);
  display:grid;place-items:center;padding:24px;animation:fade .2s;
}
.sheet{
  width:min(940px,100%);max-height:90dvh;overflow:auto;border-radius:var(--radius-xl);
  background:linear-gradient(180deg,var(--bg-3),var(--bg-2));border:1px solid var(--border);
  box-shadow:var(--shadow-lg);animation:pop .3s;
}
.sheet-hero{position:relative;padding:28px;display:flex;gap:22px}
.sheet-hero .poster{flex:0 0 190px;aspect-ratio:2/3;border-radius:var(--radius);box-shadow:var(--shadow)}
.sheet-hero .meta{flex:1;min-width:0}
.sheet-hero h2{font-family:var(--font-display);font-size:32px;font-weight:700;line-height:1.2;color:var(--cream)}
.sheet-hero .tags{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}
.tag{padding:4px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:12.5px;color:var(--muted)}
.tag.gold{color:var(--gold-soft);border-color:rgba(201,162,75,.3)}
.plot{color:var(--muted);line-height:1.9;font-size:14.5px;margin:10px 0 18px;max-height:8.5em;overflow:auto}
.sheet-actions{display:flex;gap:12px;flex-wrap:wrap}
.close-x{position:absolute;top:16px;inset-inline-start:16px;width:40px;height:40px;border-radius:12px;
  background:rgba(8,24,20,.6);display:grid;place-items:center;backdrop-filter:blur(6px)}
.close-x svg{width:20px;height:20px;stroke:var(--cream);stroke-width:2;fill:none}

/* seasons/episodes */
.season-tabs{display:flex;gap:8px;overflow-x:auto;padding:0 28px 8px;scrollbar-width:none}
.season-tabs::-webkit-scrollbar{display:none}
.eps{padding:6px 28px 28px;display:flex;flex-direction:column;gap:10px}
.ep{
  display:flex;gap:14px;align-items:center;padding:12px;border-radius:14px;
  background:var(--surface);border:1px solid var(--border);transition:var(--t);cursor:pointer;
}
.ep:hover{background:var(--surface-2);border-color:var(--border-hi)}
.ep .num{flex:none;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--bg-3);font-weight:700;color:var(--gold-soft)}
.ep .ei{flex:1;min-width:0}
.ep .et{font-weight:600;font-size:14.5px;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ep .es{color:var(--faint);font-size:12px;margin-top:2px}
.ep .eprog{flex:none;font-size:11.5px;color:var(--gold)}
.ep .play-ic{flex:none;width:34px;height:34px;border-radius:10px;background:var(--surface-2);display:grid;place-items:center}
.ep .play-ic svg{width:16px;height:16px;fill:var(--gold-soft)}
.ep.done .num{color:var(--ok)}

/* ----------------------------- PLAYER ----------------------------- */
#player{position:fixed;inset:0;z-index:300;background:#000;display:flex;flex-direction:column}
#player video{width:100%;height:100%;flex:1;background:#000;object-fit:contain}
#player .yt{flex:1;width:100%;border:0}
.pl-top{
  position:absolute;top:0;inset-inline:0;z-index:5;display:flex;align-items:center;gap:14px;
  padding:18px 22px;background:linear-gradient(180deg,rgba(0,0,0,.8),transparent);
  transition:opacity .3s;
}
.pl-top.hide{opacity:0;pointer-events:none}
.pl-back{width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.12);display:grid;place-items:center;flex:none;backdrop-filter:blur(6px)}
.pl-back svg{width:22px;height:22px;stroke:#fff;stroke-width:2;fill:none}
.pl-title{font-family:var(--font-display);font-size:21px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pl-sub{color:rgba(255,255,255,.72);font-size:13px}
.pl-spinner{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.pl-spinner .ring2{width:60px;height:60px;border-radius:50%;border:3px solid rgba(255,255,255,.18);border-top-color:var(--gold-soft);animation:spin 1s linear infinite}
.pl-err{position:absolute;inset:0;display:grid;place-items:center;padding:30px;text-align:center}
.pl-err .box{max-width:480px}
.pl-err h3{font-family:var(--font-display);font-size:25px;margin-bottom:10px;color:#fff}
.pl-err p{color:rgba(255,255,255,.72);line-height:1.8;margin-bottom:18px;font-size:14.5px}

/* toast */
#toast{position:fixed;bottom:26px;inset-inline-start:50%;transform:translateX(50%) translateY(20px);
  z-index:500;background:var(--bg-3);border:1px solid var(--border-hi);color:var(--cream);
  padding:13px 22px;border-radius:14px;box-shadow:var(--shadow-lg);opacity:0;transition:.3s;font-weight:500;font-size:14px;max-width:88vw;text-align:center}
#toast.show{opacity:1;transform:translateX(50%) translateY(0)}

/* settings form */
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;padding:0 28px}
.form-row label{font-size:13px;color:var(--muted);font-weight:500}
.form-row input{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:13px 14px;color:var(--text);font-size:14.5px;outline:none;transition:var(--t)}
.form-row input:focus{border-color:var(--border-hi);box-shadow:0 0 0 3px rgba(201,162,75,.12)}
.form-row input::placeholder{color:var(--faint)}
.form-row .hint{font-size:11.5px;color:var(--faint)}
.sheet .sheet-head{padding:26px 28px 8px}
.sheet .sheet-head h2{font-family:var(--font-display);font-size:27px;color:var(--cream)}
.sheet .sheet-head p{color:var(--muted);font-size:13.5px;margin-top:6px;line-height:1.7}
.status-line{padding:4px 28px 8px;font-size:13px}
.status-line.ok{color:var(--ok)}
.status-line.bad{color:var(--live)}

/* youtube grid item */
.yt-card .poster{aspect-ratio:16/9;object-fit:cover}
.yt-card .card-title{-webkit-line-clamp:2;min-height:2.7em}
.yt-hero{text-align:center;padding:42px 20px 14px;background:radial-gradient(460px 220px at 50% 0,rgba(201,162,75,.09),transparent);border-radius:var(--radius-xl);margin-bottom:6px}
.yt-hero .yt-badge{width:66px;height:66px;border-radius:19px;background:linear-gradient(135deg,#F26D6D,#c0392b);display:grid;place-items:center;font-size:28px;color:#fff;margin:0 auto 16px;box-shadow:0 12px 32px rgba(242,109,109,.32)}
.yt-hero h3{font-family:var(--font-display);font-size:27px;color:var(--cream);margin-bottom:10px}
.yt-hero p{max-width:540px;margin:0 auto 20px;color:var(--muted);line-height:1.85;font-size:14.5px}

/* ---------------------------- RESPONSIVE ---------------------------- */
@media(max-width:820px){
  #app{flex-direction:column-reverse}
  .side{
    position:fixed;bottom:0;inset-inline:0;top:auto;height:auto;flex-direction:row;
    justify-content:space-around;padding:8px 6px;border-inline-start:none;border-top:1px solid var(--border);
    backdrop-filter:blur(14px);background:rgba(8,24,20,.92);
  }
  .brand{display:none}
  .side .spacer{display:none}
  .navbtn{width:auto;flex:1;padding:6px 2px;font-size:10.5px}
  .navbtn svg{width:22px;height:22px}
  .main{padding-bottom:74px}
  .topbar{padding:14px 16px}
  .page-title{font-size:22px}
  .content{padding:16px 16px 40px}
  .search{width:auto;flex:1}
  .ring-wrap{height:220px;perspective:820px}
  .ring{--w:96px;--h:140px;--tz:128px}
  .sheet-hero{flex-direction:column}
  .sheet-hero .poster{flex:none;width:140px;align-self:center}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
  .grid.live{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
}

/* keyframes */
@keyframes shimmer{to{background-position:-200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes blink{50%{opacity:.35}}
@keyframes fade{from{opacity:0}}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(8px)}}
@keyframes shake{25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
