/* plex.hypertv.org — FULL REPLACE CSS (no template dependency)
   Designed for the new index.html provided in this chat.
*/

/* ====== THEME ====== */
:root{
  --bg:#0b0f17;
  --panel:#0f1624;
  --panel2:#141c2f;
  --text:#e9eef9;
  --muted:#cfd6e4;
  --muted2:#9fb0cc;
  --border:rgba(255,255,255,.10);
  --accent:#df0e62;
  --accent2:#66b2ff;
  --shadow: 0 18px 55px rgba(0,0,0,.45);
  --radius: 14px;
  --radius2: 10px;
  --container: 1180px;
}

html[data-theme="light"]{
  --bg:#f6f7fb;
  --panel:#ffffff;
  --panel2:#f0f2f8;
  --text:#101425;
  --muted:#2f3a57;
  --muted2:#42527b;
  --border:rgba(16,20,37,.12);
  --shadow: 0 14px 40px rgba(0,0,0,.12);
}

/* ====== RESET ====== */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Open Sans",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
button{font:inherit}
:focus{outline: none}
:focus-visible{outline: 2px solid var(--accent2); outline-offset: 3px}

/* ====== LAYOUT ====== */
.container{
  width: min(var(--container), calc(100% - 32px));
  margin: 0 auto;
}
.section{
  padding: 52px 0;
}
.section-alt{
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.03));
}
.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin-bottom: 18px;
}
.section-title{
  margin:0;
  font-size: 28px;
  font-weight: 900;
  letter-spacing:.2px;
}
.section-desc{
  color:var(--muted2);
  font-weight:600;
  margin-top:6px;
}
.section-link{
  color: var(--accent);
  font-weight: 800;
}
.section-link:hover{text-decoration:underline}

/* ====== BUTTONS ====== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 11px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  font-weight: 800;
  cursor:pointer;
  transition: .22s ease;
  user-select:none;
}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0)}
.btn-primary{
  background: var(--accent);
  border-color: var(--accent);
  color:#fff;
  box-shadow: 0 12px 30px rgba(223,14,98,.30);
}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{
  background: rgba(255,255,255,.03);
}
html[data-theme="light"] .btn-ghost{
  background: rgba(16,20,37,.04);
}

/* ====== HEADER ====== */
.site-header{
  position: sticky;
  top:0;
  z-index: 50;
  background: rgba(15,22,36,.75);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
html[data-theme="light"] .site-header{
  background: rgba(255,255,255,.75);
}
.site-header.scrolled{
  box-shadow: 0 10px 35px rgba(0,0,0,.25);
}
.header-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding: 12px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  min-width: 220px;
}
.brand-ico{
  color: var(--accent);
  font-size: 18px;
}
.brand-text{
  font-weight: 900;
  letter-spacing:.2px;
}
.brand-sub{
  display:inline-block;
  margin-left: 8px;
  font-size: 12px;
  padding: 3px 8px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted2);
}

.nav{
  display:flex;
  align-items:center;
  gap: 16px;
}
.nav-link{
  color: var(--muted);
  font-weight: 800;
  font-size: 14px;
  padding: 8px 6px;
  border-radius: 10px;
  transition:.2s ease;
}
.nav-link:hover{
  color: var(--text);
  background: rgba(255,255,255,.04);
}
html[data-theme="light"] .nav-link:hover{
  background: rgba(16,20,37,.04);
}

.nav-actions{
  display:flex;
  align-items:center;
  gap: 10px;
  margin-left: 10px;
}

.nav-toggle{
  display:none;
  width: 44px;
  height: 40px;
  border-radius: 12px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.02);
  cursor:pointer;
  padding: 10px;
}
.nav-toggle span{
  display:block;
  height: 2px;
  background: var(--text);
  margin: 5px 0;
  border-radius: 2px;
  transition: .2s ease;
}
.nav-toggle.open span:nth-child(1){transform: translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform: translateY(-7px) rotate(-45deg)}

/* ====== THEME SWITCH ====== */
.theme-switch{
  display:inline-flex;
  align-items:center;
  cursor:pointer;
}
.theme-switch input{display:none}
.switch-ui{
  position: relative;
  width: 62px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 0 10px;
}
html[data-theme="light"] .switch-ui{
  background: rgba(16,20,37,.04);
}
.switch-ui .moon{opacity:.85}
.switch-ui .sun{opacity:.75}
.switch-ui .knob{
  position:absolute;
  top: 4px;
  left: 4px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--panel2);
  border: 1px solid var(--border);
  box-shadow: 0 10px 25px rgba(0,0,0,.25);
  transition: .22s ease;
}
.theme-switch input:checked + .switch-ui .knob{
  transform: translateX(24px);
}

/* ====== OVERLAY SEARCH ====== */
.overlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 18px;
  z-index: 80;
}
body.overlay-open .overlay{display:flex}
.overlay-card{
  width: min(900px, 100%);
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.overlay-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}
.overlay-title{
  font-weight: 900;
  font-size: 18px;
}
.overlay-close{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid var(--border);
  display:grid;
  place-items:center;
  font-size: 22px;
  background: rgba(255,255,255,.03);
}
.overlay-close:hover{filter:brightness(1.07)}
.overlay-body{
  padding: 14px 16px 18px;
}
.overlay-hint{
  margin-top: 10px;
  color: var(--muted2);
  font-weight: 600;
  font-size: 13px;
}

/* ====== HERO ====== */
.hero{
  padding: 30px 0 8px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
  align-items:stretch;
}
.hero-left{
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow);
}
.hero-title{
  margin:0;
  font-size: 36px;
  line-height: 1.15;
  font-weight: 900;
}
.hero-subtitle{
  margin: 10px 0 16px;
  color: var(--muted);
  font-weight: 700;
}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap}
.hero-stats{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.stat{
  border-radius: 14px;
  border: 1px solid var(--border);
  padding: 12px;
  background: rgba(255,255,255,.02);
}
html[data-theme="light"] .stat{background: rgba(16,20,37,.03)}
.stat-val{
  font-weight: 900;
  font-size: 18px;
}
.stat-lab{
  color: var(--muted2);
  font-weight: 700;
  font-size: 13px;
  margin-top: 2px;
}

.hero-right{
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  background: var(--panel);
}

/* ====== SLIDER ====== */
.slider{
  position:relative;
  height: 100%;
  min-height: 330px;
}
.slide{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transform: scale(1.02);
  transition: opacity .35s ease, transform .55s ease;
}
.slide.active{
  opacity:1;
  transform: scale(1);
}
.slide::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(0,0,0,.55), rgba(0,0,0,.10));
}
.slide-overlay{
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  padding: 14px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.35);
}
.slide-badge{
  display:inline-block;
  font-weight:900;
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(223,14,98,.22);
  border: 1px solid rgba(223,14,98,.50);
  color:#fff;
}
.slide-title{
  font-weight: 900;
  font-size: 22px;
  margin-top: 8px;
  color:#fff;
}
.slide-meta{
  margin-top: 6px;
  color: rgba(255,255,255,.85);
  font-weight: 700;
  font-size: 13px;
}
.slider-btn{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(0,0,0,.35);
  color:#fff;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:.2s ease;
}
.slider-btn:hover{filter:brightness(1.12)}
.slider-btn.prev{left: 12px}
.slider-btn.next{right: 12px}
.dots{
  position:absolute;
  left: 14px;
  right: 14px;
  top: 14px;
  display:flex;
  gap: 8px;
}
.dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.15);
  cursor:pointer;
  padding:0;
}
.dot.active{
  background: var(--accent);
  border-color: var(--accent);
}

/* ====== CARDS ====== */
.cards-4{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.cards-6{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}

.card{
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  overflow:hidden;
  background: rgba(255,255,255,.02);
  transition: .22s ease;
  box-shadow: 0 10px 30px rgba(0,0,0,.18);
}
html[data-theme="light"] .card{background: rgba(16,20,37,.02); box-shadow: 0 10px 26px rgba(0,0,0,.08)}
.card:hover{transform: translateY(-2px)}
.card-img{
  height: 190px;
  background-size: cover;
  background-position:center;
}
.card.small .card-img{height: 150px}
.card-body{
  padding: 12px 12px 14px;
}
.card-title{
  font-weight: 900;
  margin: 0 0 6px;
}
.card-meta{
  color: var(--muted2);
  font-weight: 700;
  font-size: 13px;
  display:flex;
  align-items:center;
  gap: 8px;
}

/* ====== FEATURE BLOCK ====== */
.feature{
  position:relative;
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  min-height: 320px;
  background: var(--panel);
}
.feature-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  filter: saturate(1.05);
  transform: scale(1.03);
}
.feature::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(0,0,0,.68), rgba(0,0,0,.18));
}
.feature-content{
  position:relative;
  padding: 22px;
  max-width: 520px;
}
.feature-tag{
  display:inline-block;
  font-weight: 900;
  font-size: 12px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(102,178,255,.18);
  border: 1px solid rgba(102,178,255,.38);
}
.feature-title{
  margin: 10px 0 8px;
  font-size: 30px;
  line-height:1.15;
  font-weight: 900;
  color:#fff;
}
.feature-meta{
  color: rgba(255,255,255,.86);
  font-weight: 700;
}
.feature-actions{
  margin-top: 14px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ====== TABS ====== */
.tabs{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.02);
}
html[data-theme="light"] .tabs{background: rgba(16,20,37,.02)}
.tab-head{
  display:flex;
  gap: 8px;
  padding: 10px;
  border-bottom: 1px solid var(--border);
  flex-wrap:wrap;
}
.tab-btn{
  border-radius: 12px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  padding: 10px 12px;
  font-weight: 900;
  cursor:pointer;
  transition:.2s ease;
}
.tab-btn:hover{filter:brightness(1.08)}
.tab-btn.active{
  color:#fff;
  background: var(--accent);
  border-color: var(--accent);
}
.tab-body{padding: 14px}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* ====== MINI GRID ====== */
.grid-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.mini{
  display:grid;
  grid-template-columns: 110px 1fr;
  gap: 12px;
  align-items:center;
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow:hidden;
  background: rgba(255,255,255,.02);
  transition: .22s ease;
}
html[data-theme="light"] .mini{background: rgba(16,20,37,.02)}
.mini:hover{transform: translateY(-2px)}
.mini img{
  width: 110px;
  height: 90px;
  object-fit:cover;
}
.mini-info{padding-right: 10px}
.mini-top{color: var(--muted2); font-weight: 800; font-size: 12px}
.mini-title{font-weight: 900; margin-top: 2px}
.mini-meta{color: var(--muted2); font-weight: 700; font-size: 12px; margin-top: 6px; display:flex; gap:8px; align-items:center}

/* ====== FOOTER ====== */
.footer{
  border-top: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent);
  padding-top: 22px;
  position:relative;
}
.footer-top{padding: 18px 0 6px}
.footer-cards{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.fcard{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
  background: rgba(255,255,255,.02);
}
html[data-theme="light"] .fcard{background: rgba(16,20,37,.02)}
.fcard-title{
  padding: 10px 12px;
  font-weight: 900;
  text-align:center;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.fcard img{width:100%; height: 150px; object-fit:cover}

.footer-links{
  margin-top: 16px;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr 1.2fr;
  gap: 14px;
}
.flist{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255,255,255,.02);
  display:flex;
  flex-direction:column;
  gap: 8px;
}
html[data-theme="light"] .flist{background: rgba(16,20,37,.02)}
.flist a{
  color: var(--muted);
  font-weight: 800;
}
.flist a:hover{color: var(--accent); text-decoration: underline}

.fsub{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px;
  background: rgba(255,255,255,.02);
}
html[data-theme="light"] .fsub{background: rgba(16,20,37,.02)}
.subscribe{
  display:flex;
  gap: 10px;
  align-items:center;
}
.subscribe input{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel2);
  color: var(--text);
  font-weight: 800;
}
.subscribe input::placeholder{color: var(--muted2)}
.subscribe button{
  width: 46px;
  height: 46px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--accent);
  color:#fff;
  cursor:pointer;
  transition:.2s ease;
}
.subscribe button:hover{filter:brightness(1.06)}
.fsub-text{
  margin-top: 10px;
  color: var(--muted2);
  font-weight: 700;
  font-size: 13px;
}

.footer-bottom{
  margin-top: 16px;
  padding: 14px 0 18px;
  border-top: 1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  flex-wrap:wrap;
}
.copy{color: var(--muted2); font-weight: 700; font-size: 13px}
.social{
  display:flex;
  gap: 10px;
}
.social a{
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--border);
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.02);
  transition:.2s ease;
}
html[data-theme="light"] .social a{background: rgba(16,20,37,.02)}
.social a:hover{transform: translateY(-1px); color: var(--accent); border-color: rgba(223,14,98,.5)}

.to-top{
  display:none;
  position: fixed;
  right: 18px;
  bottom: 18px;
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--accent);
  color:#fff;
  cursor:pointer;
  box-shadow: 0 18px 40px rgba(223,14,98,.30);
}
.to-top:hover{filter:brightness(1.06)}

/* ====== RESPONSIVE ====== */
@media (max-width: 1100px){
  .cards-6{grid-template-columns: repeat(3, 1fr)}
  .cards-4{grid-template-columns: repeat(2, 1fr)}
  .footer-links{grid-template-columns: 1fr 1fr}
}

@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr}
  .slider{min-height: 290px}
  .hero-title{font-size: 32px}
  .footer-cards{grid-template-columns: repeat(2, 1fr)}
  .grid-3{grid-template-columns: 1fr}
}

@media (max-width: 860px){
  .nav-toggle{display:block}
  .nav{
    position:absolute;
    left: 0;
    right: 0;
    top: 66px;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap: 10px;
    padding: 12px;
    background: rgba(15,22,36,.96);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--border);
  }
  html[data-theme="light"] .nav{background: rgba(255,255,255,.96)}
  .nav.open{display:flex}
  .nav-actions{
    width:100%;
    margin-left:0;
    flex-wrap:wrap;
    justify-content:flex-start;
  }
  .nav-link{padding: 10px 10px}
}

@media (max-width: 520px){
  .section{padding: 42px 0}
  .hero-left{padding: 16px}
  .hero-title{font-size: 28px}
  .hero-stats{grid-template-columns: 1fr}
  .cards-4{grid-template-columns: 1fr}
  .cards-6{grid-template-columns: 1fr 1fr}
  .footer-links{grid-template-columns: 1fr}
  .footer-cards{grid-template-columns: 1fr}
  .mini{grid-template-columns: 96px 1fr}
  .mini img{width:96px; height: 82px}
}
