/* ═══════════════════════════════════════════════════════════
   canlitv.ltd — "Nightshade Violet" rail + accordion EPG
   Diğer 3 siteden bağımsız: koyu antrasit zemin, mor vurgu,
   amber "canlı" rengi, sol kategori rayı + akordeon kanal
   listesi, çizgili EPG tablosu, Space Grotesk. Önek: ltv-
═══════════════════════════════════════════════════════════ */

:root {
  --bg:       #100e15;
  --bg2:      #171320;
  --surf:     #1c1828;
  --surf2:    #251f36;
  --line:     #2e2742;
  --line2:    #272034;
  --acc:      #a78bfa;
  --acc2:     #8b5cf6;
  --acc-soft: rgba(167,139,250,.14);
  --ink:      #ece9f5;
  --ink2:     #a99fc4;
  --ink3:     #70678a;
  --live:     #fbbf24;
  --live-soft:rgba(251,191,36,.15);
  --r:        13px;
  --r-sm:     8px;
  --pill:     999px;
  --tr:       .18s ease;
  --top-h:    62px;
  --wrap:     1200px;

  /* legacy — admin panel (değiştirilmedi) */
  --cream:#fef9f0; --white:#fff; --orange:#f97316; --orange-dark:#ea580c;
  --orange-light:#fff7ed; --border:#fde8d0; --text:#1c1917; --text-dim:#78716c;
  --text-mute:#a8a29e; --radius:8px; --transition:.18s ease; --nav-h:58px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(720px 460px at 88% -8%, rgba(139,92,246,.12), transparent 60%),
    var(--bg);
  background-attachment: fixed;
  color: var(--ink);
  font-family: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  font-size: 14px; line-height: 1.6; min-height: 100vh;
  display: flex; flex-direction: column; -webkit-font-smoothing: antialiased;
}
h1, h2, h3, .ltv-logo { font-family: 'Space Grotesk', system-ui, sans-serif; }
a { color: var(--acc); text-decoration: none; }
a:hover { color: var(--acc2); }

/* ════════ HEADER ════════ */
.ltv-top { position: sticky; top: 0; z-index: 100; background: rgba(16,14,21,.86); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.ltv-top__in { max-width: var(--wrap); margin: 0 auto; padding: 0 22px; height: var(--top-h); display: flex; align-items: center; gap: 18px; }
.ltv-logo { display: inline-flex; align-items: center; gap: 9px; font-size: 19px; font-weight: 700; letter-spacing: -.4px; color: var(--ink); white-space: nowrap; flex-shrink: 0; }
.ltv-logo:hover { color: var(--ink); }
.ltv-logo i { color: var(--acc); font-style: normal; }
.ltv-logo__b { display: grid; place-items: center; width: 30px; height: 30px; border-radius: 8px; background: linear-gradient(135deg, var(--acc), var(--acc2)); color: #1a1030; font-size: 12px; box-shadow: 0 4px 14px rgba(139,92,246,.4); }
.ltv-nav { display: flex; align-items: center; gap: 3px; margin-left: 6px; }
.ltv-nav a { color: var(--ink2); font-size: 13.5px; font-weight: 600; padding: 7px 13px; border-radius: var(--pill); transition: var(--tr); }
.ltv-nav a:hover { color: var(--ink); background: var(--surf2); }
.ltv-nav a.on { color: var(--acc); background: var(--acc-soft); }
.ltv-find { display: flex; align-items: center; margin-left: auto; background: var(--surf); border: 1px solid var(--line); border-radius: var(--pill); overflow: hidden; transition: var(--tr); }
.ltv-find:focus-within { border-color: var(--acc); }
.ltv-find input { background: transparent; border: none; color: var(--ink); padding: 8px 15px; font-size: 13px; width: 190px; outline: none; }
.ltv-find input::placeholder { color: var(--ink3); }
.ltv-find button { background: transparent; border: none; color: var(--ink2); padding: 8px 13px; cursor: pointer; font-size: 14px; transition: var(--tr); }
.ltv-find button:hover { color: var(--acc); }
.ltv-clock { font-variant-numeric: tabular-nums; font-weight: 700; color: var(--acc); font-size: 14px; letter-spacing: .5px; flex-shrink: 0; }
.ltv-burger { display: none; margin-left: auto; background: var(--surf2); border: 1px solid var(--line); color: var(--ink); border-radius: var(--r-sm); width: 40px; height: 38px; font-size: 19px; cursor: pointer; }

/* ad slots */
.ltv-ad { display: flex; align-items: center; justify-content: center; }
.ltv-ad--top { background: var(--bg2); border-bottom: 1px solid var(--line); min-height: 54px; padding: 6px; }
.ltv-ad--mid { max-width: var(--wrap); margin: 26px auto; padding: 0 22px; }
.ltv-ad--row { margin: 6px 0; }

.ltv-main { flex: 1; padding: 24px 0 50px; }

/* ════════ INTRO ════════ */
.ltv-intro { max-width: var(--wrap); margin: 0 auto 20px; padding: 0 22px; }
.ltv-intro__h { font-size: 26px; font-weight: 700; letter-spacing: -.6px; line-height: 1.22; margin-bottom: 9px; }
.ltv-intro__h b { color: var(--acc); }
.ltv-intro__p { color: var(--ink2); font-size: 14.5px; line-height: 1.75; max-width: 880px; }
.ltv-intro__p strong { color: var(--ink); }
.ltv-intro__p em { color: var(--live); font-style: normal; font-weight: 600; }

/* ════════ SHELL: rail + feed ════════ */
.ltv-shell { max-width: var(--wrap); margin: 0 auto; padding: 0 22px; display: flex; gap: 18px; align-items: flex-start; }
.ltv-rail {
  width: 200px; flex-shrink: 0; position: sticky; top: calc(var(--top-h) + 12px);
  background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); padding: 12px;
}
.ltv-rail__t { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: var(--ink3); padding: 4px 8px 10px; }
.ltv-cat { display: block; width: 100%; text-align: left; background: transparent; border: none; color: var(--ink2); font-size: 13px; font-weight: 600; padding: 9px 12px; border-radius: var(--r-sm); cursor: pointer; transition: var(--tr); font-family: inherit; margin-bottom: 2px; }
.ltv-cat:hover { background: var(--surf2); color: var(--ink); }
.ltv-cat.on { background: linear-gradient(135deg, var(--acc), var(--acc2)); color: #160f29; }
.ltv-feed { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 12px; }

/* ════════ CHANNEL ACCORDION ════════ */
.ltv-ch { background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.ltv-ch.is-hidden { display: none; }
.ltv-ch__hd { display: flex; align-items: center; gap: 11px; padding: 13px 16px; cursor: pointer; user-select: none; transition: background var(--tr); }
.ltv-ch__hd:hover { background: var(--surf2); }
.ltv-ch__bar { width: 4px; height: 22px; border-radius: 3px; flex-shrink: 0; }
.ltv-ch__name { font-family: 'Space Grotesk', sans-serif; font-size: 15.5px; font-weight: 700; color: var(--ink); flex-shrink: 0; }
.ltv-ch__name:hover { color: var(--acc); }
.ltv-ch__cat { font-size: 10px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--ink3); background: var(--bg2); border: 1px solid var(--line); border-radius: 6px; padding: 3px 8px; flex-shrink: 0; }
.ltv-ch__now { margin-left: auto; display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--ink2); min-width: 0; }
.ltv-ch__now b { display: inline-flex; align-items: center; gap: 5px; color: var(--live); font-weight: 700; flex-shrink: 0; }
.ltv-ch__now span { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; max-width: 240px; }
.ltv-ch__chev { color: var(--ink3); font-size: 20px; line-height: 1; transition: transform var(--tr); flex-shrink: 0; }
.ltv-ch.is-open .ltv-ch__chev { transform: rotate(90deg); color: var(--acc); }
.ltv-ch__body { display: none; border-top: 1px solid var(--line2); }
.ltv-ch.is-open .ltv-ch__body { display: block; }

.ltv-progs { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 2px 18px; padding: 12px 16px; }
.ltv-p { display: flex; align-items: center; gap: 11px; padding: 8px 10px; border-radius: var(--r-sm); transition: background var(--tr); }
.ltv-p:hover { background: var(--surf2); }
.ltv-p__t { font-size: 12px; font-weight: 700; color: var(--ink2); font-variant-numeric: tabular-nums; width: 42px; flex-shrink: 0; }
.ltv-p__n { flex: 1; font-size: 13px; color: var(--ink); overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.ltv-p__air { color: var(--live); font-size: 11px; flex-shrink: 0; }
.ltv-p.air { background: var(--live-soft); }
.ltv-p.air .ltv-p__t { color: var(--live); }
.ltv-p.air .ltv-p__n { font-weight: 600; }
.ltv-p.past { opacity: .42; }
.ltv-progs__empty { padding: 14px 6px; color: var(--ink3); font-style: italic; font-size: 12.5px; }

/* empty */
.ltv-empty { max-width: var(--wrap); margin: 0 auto; padding: 56px 22px; text-align: center; color: var(--ink3); }
.ltv-empty__i { font-size: 44px; margin-bottom: 12px; }
.ltv-empty p { font-size: 15px; margin-bottom: 12px; }
.ltv-empty a { font-weight: 700; }

/* ════════ ABOUT / DOC ════════ */
.ltv-about, .ltv-doc { max-width: var(--wrap); margin: 30px auto 0; padding: 0 22px; }
.ltv-doc { max-width: 820px; }
.ltv-slab { background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); padding: 28px 30px; }
.ltv-about h2, .ltv-doc h1 { font-size: 21px; font-weight: 700; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.ltv-about h2 { font-size: 18px; }
.ltv-doc h2 { font-size: 15px; font-weight: 700; color: var(--acc); margin: 22px 0 8px; }
.ltv-about p, .ltv-doc p, .ltv-doc li { color: var(--ink2); font-size: 14px; line-height: 1.85; margin-bottom: 11px; }
.ltv-about strong, .ltv-doc strong { color: var(--ink); }
.ltv-doc ul { padding-left: 20px; }
.ltv-doc a { color: var(--acc); font-weight: 600; }

/* ════════ FAQ ════════ */
.ltv-faq { max-width: var(--wrap); margin: 28px auto 0; padding: 0 22px; }
.ltv-faq__h { font-size: 18px; font-weight: 700; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.ltv-faq__item { background: var(--surf); border: 1px solid var(--line); border-radius: var(--r-sm); margin-bottom: 9px; overflow: hidden; transition: var(--tr); }
.ltv-faq__item[open] { border-color: var(--acc); }
.ltv-faq__q { list-style: none; cursor: pointer; user-select: none; padding: 14px 46px 14px 18px; font-weight: 700; font-size: 14px; color: var(--ink); position: relative; }
.ltv-faq__q::-webkit-details-marker { display: none; }
.ltv-faq__q::after { content: '+'; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); font-size: 20px; font-weight: 400; color: var(--acc); transition: var(--tr); }
.ltv-faq__item[open] .ltv-faq__q::after { transform: translateY(-50%) rotate(45deg); }
.ltv-faq__a { padding: 2px 18px 16px; font-size: 13.5px; color: var(--ink2); line-height: 1.8; }

/* ════════ CHANNEL DETAIL ════════ */
.ltv-hero { max-width: 920px; margin: 0 auto 18px; padding: 0 22px; display: flex; align-items: center; gap: 16px; }
.ltv-hero__bar { width: 6px; height: 50px; border-radius: 4px; flex-shrink: 0; }
.ltv-hero__meta { flex: 1; min-width: 0; }
.ltv-hero__name { font-size: 27px; font-weight: 700; letter-spacing: -.5px; line-height: 1.1; }
.ltv-hero__cat { font-size: 12.5px; color: var(--ink2); margin-top: 4px; text-transform: capitalize; }
.ltv-hero__back { font-size: 13px; font-weight: 600; color: var(--ink2); white-space: nowrap; border: 1px solid var(--line); border-radius: var(--pill); padding: 8px 14px; transition: var(--tr); }
.ltv-hero__back:hover { color: var(--acc); border-color: var(--acc); }

.ltv-lead { max-width: 920px; margin: 0 auto 18px; padding: 16px 20px; background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); font-size: 14px; color: var(--ink2); line-height: 1.85; }
.ltv-lead strong { color: var(--ink); }

.ltv-nownext { max-width: 920px; margin: 0 auto 18px; padding: 0 22px; display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ltv-nn { background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); padding: 14px 16px; }
.ltv-nn--now { border-left: 4px solid var(--live); }
.ltv-nn--next { border-left: 4px solid var(--acc); }
.ltv-nn__k { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--ink3); margin-bottom: 6px; }
.ltv-nn--now .ltv-nn__k { color: var(--live); }
.ltv-nn--next .ltv-nn__k { color: var(--acc); }
.ltv-nn__n { font-size: 15px; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
.ltv-nn__t { font-size: 12.5px; color: var(--ink2); font-variant-numeric: tabular-nums; }

/* Striped EPG table */
.ltv-epg-wrap { max-width: 920px; margin: 0 auto 24px; padding: 0 22px; }
.ltv-epg { width: 100%; border-collapse: collapse; background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.ltv-epg th { text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: var(--ink3); font-weight: 700; padding: 11px 16px; border-bottom: 1px solid var(--line); }
.ltv-epg td { padding: 11px 16px; border-bottom: 1px solid var(--line2); color: var(--ink); font-size: 13.5px; }
.ltv-epg tr:last-child td { border-bottom: none; }
.ltv-epg tbody tr:nth-child(even) { background: rgba(255,255,255,.018); }
.ltv-epg tbody tr:hover { background: var(--surf2); }
.ltv-epg__t { width: 70px; font-weight: 700; color: var(--ink2); font-variant-numeric: tabular-nums; white-space: nowrap; }
.ltv-epg tr.air td { background: var(--live-soft); }
.ltv-epg tr.air .ltv-epg__t { color: var(--live); }
.ltv-epg tr.air .ltv-epg__n { font-weight: 700; }
.ltv-epg tr.past td { opacity: .45; }
.ltv-epg__air { display: inline-block; margin-left: 8px; background: var(--live); color: #2a1c02; font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: var(--pill); }

.ltv-prime { max-width: 920px; margin: 0 auto 24px; padding: 0 22px; }
.ltv-prime__h { font-size: 17px; font-weight: 700; margin-bottom: 8px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.ltv-prime__lead { font-size: 13.5px; color: var(--ink2); margin-bottom: 14px; }
.ltv-prime__grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 9px; }
.ltv-prime__i { display: flex; align-items: center; gap: 12px; background: var(--surf); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 11px 14px; transition: var(--tr); }
.ltv-prime__i:hover { border-color: var(--acc); }
.ltv-prime__t { font-size: 13px; font-weight: 700; color: var(--acc); font-variant-numeric: tabular-nums; min-width: 46px; flex-shrink: 0; }
.ltv-prime__n { font-size: 13px; color: var(--ink); }

/* ════════ SEARCH ════════ */
.ltv-search { max-width: 820px; margin: 0 auto 22px; padding: 0 22px; }
.ltv-search__box { background: var(--surf); border: 1px solid var(--line); border-radius: var(--r); padding: 26px; }
.ltv-search__h { font-size: 20px; font-weight: 700; margin-bottom: 16px; }
.ltv-search__form { display: flex; gap: 10px; }
.ltv-search__form input { flex: 1; background: var(--bg2); border: 1px solid var(--line); color: var(--ink); border-radius: var(--r-sm); padding: 12px 16px; font-size: 14px; outline: none; transition: var(--tr); font-family: inherit; }
.ltv-search__form input:focus { border-color: var(--acc); box-shadow: 0 0 0 3px var(--acc-soft); }
.ltv-search__form input::placeholder { color: var(--ink3); }
.ltv-search__form button { background: linear-gradient(135deg, var(--acc), var(--acc2)); border: none; color: #160f29; border-radius: var(--r-sm); padding: 12px 26px; font-weight: 700; font-size: 14px; cursor: pointer; transition: var(--tr); font-family: inherit; }
.ltv-search__form button:hover { box-shadow: 0 4px 16px rgba(139,92,246,.4); }
.ltv-count { max-width: 820px; margin: 14px auto; padding: 0 22px; font-size: 13px; color: var(--ink2); }
.ltv-count strong { color: var(--ink); }
.ltv-hit { display: flex; align-items: center; gap: 13px; max-width: 820px; margin: 0 auto 8px; background: var(--surf); border: 1px solid var(--line); border-radius: var(--r-sm); padding: 13px 16px; transition: var(--tr); }
.ltv-hit:hover { border-color: var(--acc); transform: translateX(3px); }
.ltv-hit__bar { width: 4px; height: 36px; border-radius: 3px; flex-shrink: 0; }
.ltv-hit__ch { font-size: 12px; font-weight: 700; color: var(--ink2); width: 110px; flex-shrink: 0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.ltv-hit__t { font-size: 12px; font-weight: 700; color: var(--acc); width: 50px; flex-shrink: 0; font-variant-numeric: tabular-nums; }
.ltv-hit__n { flex: 1; font-size: 14px; color: var(--ink); }
.ltv-hit__air { display: inline-flex; align-items: center; gap: 4px; background: var(--live); color: #2a1c02; font-size: 10px; font-weight: 800; padding: 2px 8px; border-radius: var(--pill); }

/* forms */
.ltv-form label { display: block; font-size: 11.5px; font-weight: 700; color: var(--ink2); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .4px; }
.ltv-form input, .ltv-form textarea { width: 100%; background: var(--bg2); border: 1px solid var(--line); color: var(--ink); border-radius: var(--r-sm); padding: 12px 14px; font-size: 14px; margin-bottom: 16px; outline: none; transition: var(--tr); font-family: inherit; }
.ltv-form input:focus, .ltv-form textarea:focus { border-color: var(--acc); box-shadow: 0 0 0 3px var(--acc-soft); }
.ltv-form textarea { resize: vertical; min-height: 130px; }
.ltv-btn { background: linear-gradient(135deg, var(--acc), var(--acc2)); border: none; color: #160f29; border-radius: var(--r-sm); padding: 12px 28px; font-size: 14px; font-weight: 700; cursor: pointer; transition: var(--tr); font-family: inherit; }
.ltv-btn:hover { box-shadow: 0 6px 18px rgba(139,92,246,.4); }
.ltv-msg { padding: 13px 16px; border-radius: var(--r-sm); font-size: 13.5px; font-weight: 500; margin-bottom: 18px; }
.ltv-msg--ok { background: var(--acc-soft); border: 1px solid var(--acc); color: var(--acc); }
.ltv-msg--err { background: var(--live-soft); border: 1px solid var(--live); color: var(--live); }

.ltv-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: currentColor; animation: ltv-pulse 1.4s ease-in-out infinite; }
@keyframes ltv-pulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .35; transform: scale(.7); } }

/* footer */
.ltv-foot { margin-top: auto; background: var(--bg2); border-top: 1px solid var(--line); padding: 30px 0; }
.ltv-foot__in { max-width: var(--wrap); margin: 0 auto; padding: 0 22px; text-align: center; }
.ltv-foot__note { font-size: 12px; color: var(--ink3); line-height: 1.75; max-width: 880px; margin: 0 auto 16px; }
.ltv-foot__nav { display: flex; justify-content: center; gap: 22px; margin-bottom: 12px; flex-wrap: wrap; }
.ltv-foot__nav a { font-size: 13px; color: var(--ink2); font-weight: 600; transition: var(--tr); }
.ltv-foot__nav a:hover { color: var(--acc); }
.ltv-foot__copy { font-size: 11.5px; color: var(--ink3); }

/* responsive */
@media (max-width: 820px) {
  .ltv-shell { flex-direction: column; }
  .ltv-rail { width: 100%; position: static; display: flex; flex-wrap: wrap; gap: 6px; }
  .ltv-rail__t { width: 100%; padding: 0 4px 6px; }
  .ltv-cat { width: auto; margin-bottom: 0; }
  .ltv-nownext { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .ltv-top__in { gap: 10px; }
  .ltv-nav, .ltv-clock { display: none; }
  .ltv-burger { display: inline-flex; align-items: center; justify-content: center; }
  .ltv-nav { position: absolute; top: var(--top-h); left: 0; right: 0; flex-direction: column; gap: 4px; padding: 12px; background: var(--bg2); border-bottom: 1px solid var(--line); margin-left: 0; }
  .ltv-nav.open { display: flex; }
  .ltv-nav a { width: 100%; }
  .ltv-find { order: 3; flex: 1; }
  .ltv-find input { width: 100%; }
  .ltv-ch__now { display: none; }
  .ltv-intro__h { font-size: 21px; }
  .ltv-hero__name { font-size: 22px; }
  .ltv-prime__grid { grid-template-columns: 1fr; }
  .ltv-search__form { flex-direction: column; }
}

/* ═══════════════ ADMIN PANEL — değiştirilmedi ═══════════════ */
.admin-layout { display: flex; min-height: 100vh; background: var(--cream); color: var(--text); }
.admin-sidebar { width: 220px; min-height: 100vh; background: var(--white); border-right: 1.5px solid var(--border); padding: 20px 0; flex-shrink: 0; display: flex; flex-direction: column; }
.admin-sidebar .brand { padding: 0 16px 16px; font-family: Georgia, serif; font-weight: 700; font-size: 15px; border-bottom: 1.5px solid var(--border); margin-bottom: 12px; color: var(--text); }
.admin-nav-link { display: flex; align-items: center; gap: 10px; padding: 10px 16px; color: var(--text-dim); font-size: 13px; font-weight: 500; text-decoration: none; transition: all var(--transition); border-left: 3px solid transparent; }
.admin-nav-link:hover { background: var(--orange-light); color: var(--text); text-decoration: none; }
.admin-nav-link.active { color: var(--orange-dark); background: var(--orange-light); border-left-color: var(--orange); }
.admin-content { flex: 1; padding: 30px; max-width: 1300px; color: var(--text); }
.admin-content h1 { font-family: Georgia, serif; font-size: 22px; margin-bottom: 24px; font-weight: 700; letter-spacing: -.3px; color: var(--text); }
.admin-card { background: var(--white); border: 1.5px solid var(--border); border-radius: var(--radius); padding: 24px; margin-bottom: 18px; }
.admin-card h2 { font-size: 14px; margin-bottom: 18px; color: var(--text); font-weight: 700; }
.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: 12px; font-weight: 600; color: var(--text-dim); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .3px; }
.form-ctrl { width: 100%; background: var(--cream); border: 1.5px solid var(--border); color: var(--text); border-radius: var(--radius); padding: 10px 14px; font-size: 13px; outline: none; transition: border-color var(--transition), box-shadow var(--transition); font-family: inherit; }
.form-ctrl:focus { border-color: var(--orange); box-shadow: 0 0 0 3px rgba(249,115,22,.15); }
select.form-ctrl { cursor: pointer; }
.btn { border: none; border-radius: var(--radius); padding: 9px 18px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all var(--transition); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; font-family: inherit; }
.btn:hover { transform: translateY(-1px); text-decoration: none; }
.btn-primary { background: var(--orange); color: var(--white); }
.btn-primary:hover { background: var(--orange-dark); box-shadow: 0 2px 8px rgba(249,115,22,.3); }
.btn-danger  { background: #dc2626; color: var(--white); }
.btn-sm      { padding: 6px 11px; font-size: 12px; }
.btn-ghost   { background: var(--cream); color: var(--text); border: 1.5px solid var(--border); }
.btn-ghost:hover { background: var(--border); }
.w-100 { width: 100%; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-table th { text-align: left; padding: 10px 14px; font-size: 11px; text-transform: uppercase; letter-spacing: .4px; color: var(--text-mute); border-bottom: 2px solid var(--border); font-weight: 700; }
.admin-table td { padding: 12px 14px; border-bottom: 1px solid var(--border); vertical-align: middle; color: var(--text); }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: var(--orange-light); }
.admin-table code { background: var(--cream); padding: 3px 8px; border-radius: 4px; font-size: 11px; color: var(--orange-dark); }
.badge { display: inline-block; padding: 3px 10px; border-radius: 10px; font-size: 11px; font-weight: 700; }
.badge-green { background: #dcfce7; color: #15803d; }
.badge-red   { background: #fee2e2; color: #b91c1c; }
.admin-login { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: var(--cream); color: var(--text); padding: 20px; }
.login-card { background: var(--white); border: 1.5px solid var(--border); border-radius: 12px; padding: 40px; width: 360px; box-shadow: 0 8px 30px rgba(0,0,0,.08); }
.login-card h2 { font-family: Georgia, serif; text-align: center; margin-bottom: 28px; font-size: 18px; font-weight: 700; color: var(--text); }
.alert { padding: 12px 16px; border-radius: var(--radius); font-size: 13px; font-weight: 500; margin-bottom: 16px; }
.alert-danger  { background: #fee2e2; border: 1px solid #fecaca; color: #b91c1c; }
.alert-success { background: #dcfce7; border: 1px solid #bbf7d0; color: #15803d; }
@media (max-width: 768px) {
  .admin-layout { flex-direction: column; }
  .admin-sidebar { width: 100%; min-height: auto; border-right: none; border-bottom: 1.5px solid var(--border); flex-direction: row; flex-wrap: wrap; padding: 10px; }
  .admin-sidebar .brand { width: 100%; border-bottom: none; padding-bottom: 8px; }
  .admin-nav-link { border-left: none; border-radius: 6px; flex: 1; justify-content: center; }
  .admin-content { padding: 16px; }
}
