/* JACKTV OTT — Premium dark news mobile UI */
:root{
  --bg:#0a0a0a;
  --bg2:#141414;
  --bg3:#1c1c1c;
  --line:#262626;
  --line2:#1f1f1f;
  --red:#E60000;
  --red-soft:rgba(230,0,0,.15);
  --red-glow:0 0 28px rgba(230,0,0,.45);
  --txt:#ffffff;
  --txt2:#b8b8b8;
  --txt3:#7d7d7d;
  --radius:18px;
  --radius-l:24px;
  --pad:20px;
  --bottom-nav-h:84px;
  --header-h:74px;
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg);color:var(--txt);font-family:'Poppins','Noto Sans Devanagari',-apple-system,sans-serif;font-weight:500;overflow-x:hidden}
body{min-height:100vh;padding-bottom:calc(var(--bottom-nav-h) + env(safe-area-inset-bottom,0))}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
.hidden{display:none!important}

/* ───── Splash ───── */
.splash{position:fixed;inset:0;background:radial-gradient(circle at 50% 40%,#1a0000,#0a0a0a 70%);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;animation:splashOut .5s .6s forwards}
.splash-logo{font-size:48px;font-weight:900;letter-spacing:1px;animation:popIn .5s ease}
.splash-logo span{color:#fff}
.splash-logo b{color:var(--red);text-shadow:var(--red-glow)}
.splash-tag{font-family:'Noto Sans Devanagari','Poppins',sans-serif;color:var(--txt2);font-size:16px;font-weight:500;letter-spacing:.5px}
.splash-ring{width:34px;height:34px;border:3px solid #2a2a2a;border-top-color:var(--red);border-radius:50%;animation:spin .9s linear infinite;margin-top:10px}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes popIn{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes splashOut{to{opacity:0;visibility:hidden;pointer-events:none}}

/* ───── Header ───── */
.hdr{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px var(--pad) 14px;background:linear-gradient(180deg,rgba(10,10,10,.95),rgba(10,10,10,.85) 80%,rgba(10,10,10,0));backdrop-filter:blur(8px)}
.hdr-brand{display:flex;flex-direction:column;gap:2px}
.logo{font-size:28px;font-weight:900;letter-spacing:.5px;line-height:1}
.logo.small{font-size:22px;margin-bottom:8px}
.logo span{color:#fff}
.logo b{color:var(--red);text-shadow:0 0 18px rgba(230,0,0,.35)}
.logo-tag{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:11px;color:var(--txt3);letter-spacing:.5px;font-weight:500}
.hdr-menu{background:rgba(255,255,255,.06);border:1px solid var(--line);color:#fff;width:42px;height:42px;border-radius:12px;font-size:16px;transition:.2s}
.hdr-menu:hover{background:var(--red-soft);border-color:var(--red)}

/* ───── Dropdown ───── */
.dropdown{position:fixed;top:72px;right:var(--pad);background:rgba(20,20,20,.96);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:16px;padding:8px;z-index:200;min-width:220px;box-shadow:0 20px 50px rgba(0,0,0,.6),0 0 0 1px rgba(230,0,0,.1);animation:dropIn .2s ease}
.dropdown a{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:10px;color:#fff;font-size:14px;font-weight:500;transition:.15s}
.dropdown a:hover{background:var(--red-soft);color:#fff}
.dropdown a i{width:18px;color:var(--red);font-size:13px}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ───── Sections ───── */
.view{padding:0 0 30px;animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.section{margin-top:28px}
.section-head{display:flex;align-items:center;justify-content:space-between;padding:0 var(--pad);margin-bottom:14px}
.section-title{font-size:14px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
.section-title b{color:var(--red)}
.section-link{color:var(--txt2);font-size:12px;font-weight:600;letter-spacing:.5px;transition:.15s}
.section-link:hover{color:var(--red)}

.scroll-x{display:flex;gap:14px;overflow-x:auto;padding:4px var(--pad) 8px;scroll-snap-type:x mandatory;scrollbar-width:none}
.scroll-x::-webkit-scrollbar{display:none}
.scroll-x>*{scroll-snap-align:start;flex-shrink:0}

/* ───── Hero slider ───── */
.hero{padding:0 var(--pad);margin-top:8px}
.hero-track{position:relative;border-radius:var(--radius-l);overflow:hidden;height:200px;background:#1a0707}
.hero-slide{position:absolute;inset:0;display:flex;align-items:flex-end;padding:24px;opacity:0;transition:opacity .6s;background-size:cover;background-position:center}
.hero-slide.active{opacity:1}
.hero-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(180,0,0,.85) 0%,rgba(40,0,0,.7) 60%,rgba(0,0,0,.5) 100%)}
.hero-content{position:relative;z-index:2;max-width:90%}
.hero-tag{display:inline-block;background:#fff;color:#000;font-size:10px;font-weight:800;letter-spacing:1px;padding:4px 10px;border-radius:6px;margin-bottom:10px}
.hero-title{font-size:24px;font-weight:900;line-height:1.05;margin-bottom:8px;text-shadow:0 3px 12px rgba(0,0,0,.5)}
.hero-sub{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:13px;color:#ffd6d6;margin-bottom:14px;font-weight:500;line-height:1.4}
.hero-cta{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;padding:9px 16px;border-radius:24px;font-size:12px;font-weight:700;letter-spacing:.5px;box-shadow:var(--red-glow);transition:.2s}
.hero-cta:hover{transform:translateY(-1px);background:#ff1a1a}
.hero-cta i{font-size:10px}
.hero-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:center;gap:6px;z-index:3}
.hero-dot{width:6px;height:6px;background:rgba(255,255,255,.35);border-radius:50%;transition:.3s;cursor:pointer}
.hero-dot.active{background:var(--red);width:18px;border-radius:3px;box-shadow:0 0 10px var(--red)}

/* ───── Live TV cards ───── */
.live-card{width:200px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.2s}
.live-card:hover{transform:translateY(-2px);border-color:var(--red);box-shadow:0 8px 24px rgba(230,0,0,.2)}
.live-thumb{position:relative;aspect-ratio:16/10;background:#1a0707 center/cover no-repeat}
.live-thumb::before{content:"LIVE";position:absolute;top:10px;left:10px;background:var(--red);color:#fff;font-size:9px;font-weight:800;padding:3px 7px;border-radius:4px;letter-spacing:.8px;box-shadow:0 0 12px rgba(230,0,0,.6)}
.live-thumb::before{animation:livePulse 1.4s ease-in-out infinite}
@keyframes livePulse{50%{opacity:.5}}
.live-play{position:absolute;bottom:10px;right:10px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.95);color:#000;display:flex;align-items:center;justify-content:center;font-size:11px}
.live-meta{padding:12px}
.live-name{font-size:13px;font-weight:700;letter-spacing:.4px;color:#fff;margin-bottom:2px}
.live-desc{font-size:11px;color:var(--txt3);line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}

/* ───── Top stories cards ───── */
.story-card{width:220px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.2s}
.story-card:hover{border-color:var(--red);transform:translateY(-2px)}
.story-thumb{position:relative;aspect-ratio:16/10;background:#1a0707 center/cover no-repeat}
.story-time{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.75);color:#fff;font-size:10px;padding:3px 8px;border-radius:6px;font-weight:600;backdrop-filter:blur(4px)}
.story-meta{padding:12px}
.story-cat{font-size:10px;color:var(--red);font-weight:800;letter-spacing:1.2px;margin-bottom:6px;text-transform:uppercase}
.story-title{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:13px;font-weight:600;line-height:1.35;color:#fff;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ───── Shorts cards (9:16) ───── */
.short-card{width:140px;aspect-ratio:9/16;background:#1a0707 center/cover no-repeat;border-radius:var(--radius);position:relative;cursor:pointer;border:1px solid var(--line);overflow:hidden;transition:.2s}
.short-card:hover{transform:translateY(-2px) scale(1.02);border-color:var(--red)}
.short-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.85) 100%)}
.short-dur{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:#fff;font-size:10px;padding:3px 7px;border-radius:6px;font-weight:700;backdrop-filter:blur(4px);z-index:2}
.short-title{font-family:'Noto Sans Devanagari','Poppins',sans-serif;position:absolute;bottom:10px;left:10px;right:10px;font-size:11px;font-weight:600;color:#fff;line-height:1.3;z-index:2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ───── Grid lists (full-page views) ───── */
.grid-page{padding:8px var(--pad) 30px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-1{display:grid;grid-template-columns:1fr;gap:14px}
.page-title{font-size:22px;font-weight:800;margin:18px 0 14px;padding:0 var(--pad)}
.page-title b{color:var(--red)}

/* ───── Live TV full grid ───── */
.live-full{aspect-ratio:16/10;border-radius:var(--radius)}

/* ───── News full list ───── */
.news-row{display:flex;gap:14px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:.2s}
.news-row:hover{border-color:var(--red)}
.news-row-thumb{width:120px;aspect-ratio:4/3;background:#1a0707 center/cover no-repeat;flex-shrink:0}
.news-row-body{padding:12px;display:flex;flex-direction:column;justify-content:center;min-width:0;flex:1}
.news-row-cat{font-size:10px;color:var(--red);font-weight:800;letter-spacing:1px;margin-bottom:4px}
.news-row-title{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:13px;font-weight:600;line-height:1.35;color:#fff;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ───── Detail page ───── */
.detail{padding:0 0 30px}
.player{aspect-ratio:16/9;background:#000;position:relative;overflow:hidden}
.player iframe,.player video{width:100%;height:100%;border:0}
.player-poster{position:absolute;inset:0;background:#1a0707 center/cover no-repeat;display:flex;align-items:center;justify-content:center}
.player-play{width:74px;height:74px;border-radius:50%;background:var(--red);box-shadow:var(--red-glow);color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;border:0;cursor:pointer;transition:.2s}
.player-play:hover{transform:scale(1.08)}
.detail-body{padding:20px var(--pad)}
.detail-cat{font-size:11px;color:var(--red);font-weight:800;letter-spacing:1.5px}
.detail-title{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:22px;font-weight:700;margin:8px 0 6px;line-height:1.25}
.detail-sub{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:14px;color:var(--txt2);line-height:1.5;margin-bottom:18px}
.detail-desc{font-family:'Noto Sans Devanagari','Poppins',sans-serif;font-size:14px;color:#dcdcdc;line-height:1.7}
.detail-back{display:inline-flex;align-items:center;gap:8px;background:rgba(0,0,0,.6);color:#fff;padding:8px 14px;border-radius:24px;font-size:12px;border:1px solid var(--line);position:absolute;top:14px;left:14px;z-index:5;backdrop-filter:blur(8px)}

/* ───── Bottom navigation ───── */
.botnav{position:fixed;bottom:14px;left:14px;right:14px;height:var(--bottom-nav-h);background:rgba(20,20,20,.85);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:28px;display:flex;align-items:center;justify-content:space-around;padding:0 8px;z-index:100;box-shadow:0 -2px 30px rgba(0,0,0,.5),0 0 0 1px rgba(230,0,0,.15)}
.navbtn{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--txt3);font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:10px;transition:.2s;cursor:pointer}
.navbtn i{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.04);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:16px;transition:.2s}
.navbtn.active{color:#fff}
.navbtn.active i{background:var(--red);border-color:var(--red);box-shadow:var(--red-glow);color:#fff}
.navbtn:not(.active):hover i{border-color:var(--red);color:#fff}

/* ───── Modal / auth ───── */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .25s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-card{width:100%;max-width:480px;background:var(--bg2);border:1px solid var(--line);border-top-left-radius:28px;border-top-right-radius:28px;padding:28px 24px 32px;position:relative;animation:slideUp .35s cubic-bezier(.2,.8,.2,1)}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
.modal-close{position:absolute;top:14px;right:18px;background:transparent;border:0;color:#fff;font-size:30px;line-height:1;padding:4px 8px}
.modal-card h3{margin:8px 0 4px;font-size:20px;font-weight:700}
.muted{color:var(--txt3);font-size:13px;margin-bottom:20px}
.modal-card label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--txt3);margin:14px 0 6px;font-weight:600}
.modal-card input,.modal-card select{width:100%;background:var(--bg);border:1px solid var(--line);color:#fff;padding:13px 14px;border-radius:12px;font-size:14px;outline:none;font-family:inherit;transition:.15s}
.modal-card input:focus,.modal-card select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(230,0,0,.15)}
.check{display:flex;align-items:flex-start;gap:10px;margin-top:18px;text-transform:none;letter-spacing:0;color:var(--txt2);font-size:12px;line-height:1.5}
.check input{width:18px;height:18px;margin-top:1px;accent-color:var(--red);flex-shrink:0}
.check a{color:var(--red);text-decoration:underline}
.btn-red{margin-top:22px;width:100%;background:var(--red);color:#fff;border:0;padding:14px;border-radius:12px;font-size:14px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;box-shadow:var(--red-glow);transition:.2s}
.btn-red:hover{background:#ff1a1a;transform:translateY(-1px)}
.btn-red:disabled{opacity:.5;cursor:wait}
.err{background:#3a0e0e;border:1px solid #6a1a1a;color:#ffb4b4;padding:10px 12px;border-radius:8px;font-size:12px;margin-top:12px}

/* ───── Toast ───── */
.toast{position:fixed;bottom:calc(var(--bottom-nav-h) + 32px);left:50%;transform:translateX(-50%);background:var(--bg2);border:1px solid var(--line);color:#fff;padding:12px 20px;border-radius:24px;font-size:13px;z-index:2000;box-shadow:0 10px 30px rgba(0,0,0,.5);animation:toastIn .3s}
.toast.ok{border-color:#16a34a}
.toast.err{border-color:var(--red)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translateX(-50%)}}

.empty{text-align:center;padding:60px 20px;color:var(--txt3);font-size:13px}
.empty i{font-size:36px;color:var(--line);margin-bottom:14px;display:block}

/* ───── Responsive — tablet/desktop ───── */
@media (min-width:768px){
  :root{--pad:32px}
  .hero-track{height:300px}
  .hero-title{font-size:38px}
  .hero-sub{font-size:16px}
  .botnav{max-width:520px;margin:0 auto}
  .live-card{width:280px}
  .story-card{width:280px}
  .short-card{width:180px}
  .grid-2{grid-template-columns:repeat(3,1fr)}
}
@media (min-width:1100px){
  .grid-2{grid-template-columns:repeat(4,1fr)}
  .app{max-width:1280px;margin:0 auto}
  .hero-track{height:380px}
  .hero-title{font-size:48px}
}
