/*
Theme Name: Tanie IPTV Polska
Theme URI: https://tanie-iptv.pl
Author: StreamPL Studio
Author URI: https://tanie-iptv.pl
Description: Professional IPTV theme targeting Polish market — tanie IPTV Polska, abonament IPTV, telewizja internetowa bez umowy
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: tanie-iptv
Tags: iptv, streaming, poland, television
*/

/* ============================================================
   DESIGN SYSTEM — Dark cinema aesthetic, electric-cyan accent
   ============================================================ */
:root {
  --bg-dark:       #080c14;
  --bg-card:       #0e1520;
  --bg-card2:      #131d2e;
  --border:        #1e2d45;
  --cyan:          #00d4ff;
  --cyan-dim:      #00a8cc;
  --cyan-glow:     rgba(0,212,255,.18);
  --gold:          #f5c842;
  --text-primary:  #eef2f8;
  --text-muted:    #7a8ca0;
  --text-dim:      #4a5c70;
  --radius:        12px;
  --radius-lg:     20px;
  --transition:    .28s cubic-bezier(.4,0,.2,1);
  --font-display:  'Sora', 'Segoe UI', sans-serif;
  --font-body:     'Inter', 'Segoe UI', sans-serif;
  --shadow-card:   0 4px 32px rgba(0,0,0,.55);
  --shadow-cyan:   0 0 32px rgba(0,212,255,.22);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;font-size:16px}

body{
  background:var(--bg-dark);
  color:var(--text-primary);
  font-family:var(--font-body);
  line-height:1.65;
  overflow-x:hidden;
}

/* Typography */
h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.2;
  letter-spacing:-.02em;
}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}

p{color:var(--text-muted);line-height:1.75;margin-bottom:1rem}
a{color:var(--cyan);text-decoration:none;transition:color var(--transition)}
a:hover{color:#fff}

img{max-width:100%;height:auto;display:block}

/* ============================================================
   UTILITIES
   ============================================================ */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.container--narrow{max-width:860px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section--sm{padding:56px 0}

.text-cyan{color:var(--cyan)}
.text-gold{color:var(--gold)}
.text-muted{color:var(--text-muted)}
.text-center{text-align:center}

.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 14px;border-radius:99px;font-size:.75rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.08em;
}
.badge--cyan{background:rgba(0,212,255,.12);color:var(--cyan);border:1px solid rgba(0,212,255,.25)}
.badge--gold{background:rgba(245,200,66,.12);color:var(--gold);border:1px solid rgba(245,200,66,.3)}

/* Grid helpers */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

@media(max-width:900px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .section{padding:56px 0}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 32px;border-radius:var(--radius);font-weight:600;
  font-size:.95rem;letter-spacing:.01em;cursor:pointer;
  border:none;transition:all var(--transition);white-space:nowrap;
  text-decoration:none;
}
.btn--primary{
  background:var(--cyan);color:#000;
  box-shadow:0 0 24px rgba(0,212,255,.35);
}
.btn--primary:hover{
  background:#fff;color:#000;
  box-shadow:0 0 36px rgba(0,212,255,.55);
  transform:translateY(-2px);
}
.btn--outline{
  background:transparent;color:var(--cyan);
  border:1.5px solid var(--cyan);
}
.btn--outline:hover{background:var(--cyan);color:#000;transform:translateY(-2px)}
.btn--whatsapp{
  background:#25d366;color:#fff;
  box-shadow:0 0 24px rgba(37,211,102,.3);
}
.btn--whatsapp:hover{background:#1ebe5d;transform:translateY(-2px)}
.btn--lg{padding:18px 40px;font-size:1.05rem}
.btn--sm{padding:10px 22px;font-size:.85rem}

/* ============================================================
   HEADER & NAV
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:999;
  padding:14px 0;
  background:rgba(8,12,20,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:all .3s ease;
}
.site-header.scrolled{
  background:rgba(8,12,20,.97);
  padding:10px 0;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1200px;margin:0 auto;padding:0 24px;
}
.site-logo{
  font-family:var(--font-display);font-weight:800;font-size:1.45rem;
  color:#fff;letter-spacing:-.03em;
  display:flex;align-items:center;gap:8px;
}
.site-logo span{color:var(--cyan)}
.logo-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 10px var(--cyan);
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.4)}}

.nav-menu{display:flex;align-items:center;gap:8px;list-style:none}
.nav-menu a{
  color:var(--text-muted);font-size:.9rem;font-weight:500;
  padding:8px 14px;border-radius:8px;
  transition:all var(--transition);
}
.nav-menu a:hover,.nav-menu a.active{color:#fff;background:rgba(255,255,255,.07)}
.nav-cta{margin-left:12px}

.hamburger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  padding:8px;border:none;background:transparent;
}
.hamburger span{
  display:block;width:24px;height:2px;
  background:var(--text-primary);border-radius:2px;
  transition:all .3s ease;
}
.mobile-menu{
  display:none;position:absolute;top:100%;left:0;right:0;
  background:rgba(8,12,20,.98);border-bottom:1px solid var(--border);
  padding:16px 24px 24px;
}
.mobile-menu.open{display:block}
.mobile-menu .nav-menu{flex-direction:column;align-items:flex-start;gap:4px}
.mobile-menu .nav-menu a{display:block;width:100%;padding:12px 16px}

@media(max-width:860px){
  .nav-menu:not(.mobile-menu .nav-menu){display:none}
  .nav-cta:not(.mobile-menu .nav-cta){display:none}
  .hamburger{display:flex}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:120px 0 80px;
  position:relative;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 60% 30%, rgba(0,212,255,.08) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 10% 80%, rgba(245,200,66,.05) 0%, transparent 50%);
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(30,45,69,.4) 1px, transparent 1px),
    linear-gradient(90deg, rgba(30,45,69,.4) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%, black 20%, transparent 80%);
}
.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;
  gap:60px;align-items:center;
  position:relative;z-index:1;
}
.hero-tag{margin-bottom:20px}
.hero h1{margin-bottom:20px}
.hero-lead{
  font-size:1.15rem;color:var(--text-muted);
  margin-bottom:36px;max-width:520px;
}
.hero-actions{
  display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  margin-bottom:48px;
}
.hero-stats{
  display:flex;gap:36px;padding-top:32px;
  border-top:1px solid var(--border);
}
.stat-item{}
.stat-num{
  font-family:var(--font-display);font-size:1.8rem;font-weight:800;
  color:#fff;line-height:1;
}
.stat-num span{color:var(--cyan)}
.stat-label{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}

/* TV mockup */
.hero-visual{
  display:flex;justify-content:center;align-items:center;
  position:relative;
}
.tv-mockup{
  width:100%;max-width:520px;
  background:var(--bg-card);
  border:2px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-cyan), var(--shadow-card);
  position:relative;
}
.tv-bar{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;background:var(--bg-card2);
  border-bottom:1px solid var(--border);
}
.tv-dot{width:10px;height:10px;border-radius:50%}
.tv-dot:nth-child(1){background:#ff5f56}
.tv-dot:nth-child(2){background:#febc2e}
.tv-dot:nth-child(3){background:#27c93f}
.tv-screen{
  aspect-ratio:16/9;
  background:linear-gradient(135deg,#0a1628 0%,#0d1f35 50%,#071018 100%);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.tv-screen-content{text-align:center;z-index:1}
.tv-live-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:6px;
  background:rgba(255,59,59,.9);color:#fff;font-size:.75rem;font-weight:700;
  letter-spacing:.1em;margin-bottom:16px;
}
.tv-live-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:blink 1.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.tv-channels-preview{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  padding:0 12px;
}
.tv-ch{
  padding:6px 14px;border-radius:6px;font-size:.75rem;font-weight:600;
  background:rgba(255,255,255,.08);color:var(--text-muted);
  border:1px solid rgba(255,255,255,.1);
}
.tv-ch.active{background:rgba(0,212,255,.15);color:var(--cyan);border-color:rgba(0,212,255,.3)}
.tv-glow{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 50%, rgba(0,212,255,.06) 0%, transparent 70%);
}
.tv-footer{
  padding:14px 16px;display:flex;align-items:center;justify-content:space-between;
  border-top:1px solid var(--border);
}
.tv-quality{
  display:flex;gap:8px;
}
.quality-badge{
  font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:4px;
  background:rgba(0,212,255,.1);color:var(--cyan);border:1px solid rgba(0,212,255,.2);
}
.quality-badge.hd{background:rgba(245,200,66,.1);color:var(--gold);border-color:rgba(245,200,66,.2)}
.channels-count{font-size:.8rem;color:var(--text-muted)}
.channels-count strong{color:#fff}

@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
}

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust-bar{
  padding:28px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--bg-card);
}
.trust-items{
  display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap;
}
.trust-item{
  display:flex;align-items:center;gap:10px;
  font-size:.85rem;color:var(--text-muted);font-weight:500;
}
.trust-item svg{color:var(--cyan);flex-shrink:0}

/* ============================================================
   FEATURES
   ============================================================ */
.feature-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  transition:all var(--transition);
  position:relative;overflow:hidden;
}
.feature-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--cyan-glow),transparent 60%);
  opacity:0;transition:opacity var(--transition);
}
.feature-card:hover{
  border-color:rgba(0,212,255,.3);
  transform:translateY(-4px);
  box-shadow:var(--shadow-cyan);
}
.feature-card:hover::before{opacity:1}
.feature-icon{
  width:52px;height:52px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,212,255,.1);
  border:1px solid rgba(0,212,255,.2);
  margin-bottom:20px;font-size:1.4rem;
}
.feature-card h3{font-size:1.1rem;margin-bottom:10px;color:#fff}
.feature-card p{font-size:.9rem;margin:0}

/* ============================================================
   PRICING
   ============================================================ */
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:48px;
}
@media(max-width:1000px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pricing-grid{grid-template-columns:1fr}}

.pricing-card{
  background:var(--bg-card);
  border:1.5px solid var(--border);
  border-radius:var(--radius-lg);
  padding:32px 24px;
  text-align:center;
  position:relative;
  transition:all var(--transition);
}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.pricing-card.featured{
  border-color:var(--cyan);
  background:linear-gradient(160deg,rgba(0,212,255,.07) 0%,var(--bg-card) 60%);
  box-shadow:var(--shadow-cyan);
}
.pricing-popular{
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  padding:4px 20px;border-radius:99px;
  background:var(--cyan);color:#000;font-size:.75rem;font-weight:700;
  white-space:nowrap;letter-spacing:.06em;
}
.pricing-period{
  font-size:.8rem;color:var(--text-muted);text-transform:uppercase;
  letter-spacing:.12em;font-weight:600;margin-bottom:16px;
}
.pricing-price{
  font-family:var(--font-display);
  font-size:2.8rem;font-weight:800;color:#fff;line-height:1;
  margin-bottom:4px;
}
.pricing-price span{font-size:1.1rem;color:var(--text-muted);font-weight:400}
.pricing-save{
  font-size:.8rem;color:var(--gold);font-weight:600;
  margin-bottom:20px;min-height:20px;
}
.pricing-features{
  list-style:none;margin-bottom:28px;text-align:left;
}
.pricing-features li{
  display:flex;align-items:center;gap:10px;
  padding:8px 0;font-size:.88rem;color:var(--text-muted);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.pricing-features li:last-child{border-bottom:none}
.pricing-features .check{color:var(--cyan);font-size:1rem}
.pricing-card .btn{width:100%}

/* ============================================================
   CHANNEL LIST
   ============================================================ */
.channels-filter{
  display:flex;gap:10px;flex-wrap:wrap;justify-content:center;
  margin-bottom:36px;
}
.filter-btn{
  padding:8px 22px;border-radius:99px;border:1.5px solid var(--border);
  background:transparent;color:var(--text-muted);font-size:.85rem;
  cursor:pointer;transition:all var(--transition);font-weight:500;
}
.filter-btn:hover,.filter-btn.active{
  background:rgba(0,212,255,.12);color:var(--cyan);border-color:rgba(0,212,255,.35);
}
.channels-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:12px;
}
.channel-item{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px 12px;
  text-align:center;
  transition:all var(--transition);
  cursor:default;
}
.channel-item:hover{
  border-color:rgba(0,212,255,.25);
  transform:translateY(-2px);
}
.ch-flag{font-size:1.6rem;margin-bottom:8px}
.ch-name{font-size:.8rem;font-weight:600;color:#fff;margin-bottom:4px}
.ch-cat{font-size:.7rem;color:var(--text-dim)}

/* ============================================================
   INSTALLATION (Tutorial)
   ============================================================ */
.install-steps{
  counter-reset:step;
  display:flex;flex-direction:column;gap:24px;
  max-width:760px;margin:0 auto;
}
.install-step{
  display:flex;gap:24px;align-items:flex-start;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px;
  position:relative;
  transition:border-color var(--transition);
}
.install-step:hover{border-color:rgba(0,212,255,.25)}
.step-num{
  width:44px;height:44px;border-radius:12px;flex-shrink:0;
  background:rgba(0,212,255,.1);border:1.5px solid rgba(0,212,255,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.1rem;font-weight:800;
  color:var(--cyan);
}
.step-content h3{font-size:1.05rem;margin-bottom:8px}
.step-content p{font-size:.9rem;margin:0}
.step-devices{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:12px;
}
.device-tag{
  padding:3px 12px;border-radius:6px;font-size:.72rem;font-weight:600;
  background:rgba(255,255,255,.06);color:var(--text-muted);
  border:1px solid var(--border);
}

/* ============================================================
   BLOG
   ============================================================ */
.blog-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:all var(--transition);
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:rgba(0,212,255,.2)}
.blog-thumb{
  aspect-ratio:16/9;
  background:linear-gradient(135deg,#0a1a30,#0d2340);
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;border-bottom:1px solid var(--border);
}
.blog-body{padding:24px}
.blog-meta{
  display:flex;align-items:center;gap:16px;
  font-size:.78rem;color:var(--text-dim);margin-bottom:12px;
}
.blog-card h3{font-size:1.05rem;margin-bottom:10px;line-height:1.35}
.blog-card h3 a{color:#fff}
.blog-card h3 a:hover{color:var(--cyan)}
.blog-card p{font-size:.88rem;margin:0}
.read-more{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.85rem;font-weight:600;color:var(--cyan);
  margin-top:16px;
}
.read-more:hover{gap:10px}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;
}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr}}
.contact-info h2{margin-bottom:16px}
.contact-info p{font-size:1rem;margin-bottom:32px}
.contact-methods{display:flex;flex-direction:column;gap:16px}
.contact-method{
  display:flex;align-items:center;gap:16px;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;
  transition:border-color var(--transition);
}
.contact-method:hover{border-color:rgba(0,212,255,.25)}
.method-icon{
  width:48px;height:48px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;
}
.method-icon.whatsapp{background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.2)}
.method-label{font-size:.78rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.method-value{font-weight:600;color:#fff;font-size:.95rem}

/* FAQ */
.faq-list{max-width:760px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--border);
}
.faq-question{
  width:100%;background:none;border:none;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;cursor:pointer;text-align:left;
  color:#fff;font-family:var(--font-body);font-size:.95rem;font-weight:600;
  transition:color var(--transition);
}
.faq-question:hover{color:var(--cyan)}
.faq-icon{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-card);border:1px solid var(--border);
  font-size:.9rem;flex-shrink:0;transition:all var(--transition);
  color:var(--cyan);
}
.faq-answer{
  display:none;padding:0 0 20px;
}
.faq-answer p{margin:0;font-size:.9rem}
.faq-item.open .faq-answer{display:block}
.faq-item.open .faq-icon{transform:rotate(45deg);background:rgba(0,212,255,.12);border-color:rgba(0,212,255,.3)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.testimonials-grid{grid-template-columns:1fr}}
.testimonial-card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px;
}
.stars{color:var(--gold);font-size:1rem;margin-bottom:14px;letter-spacing:2px}
.testimonial-card p{font-size:.9rem;margin-bottom:20px;font-style:italic}
.reviewer{display:flex;align-items:center;gap:12px}
.reviewer-avatar{
  width:38px;height:38px;border-radius:50%;
  background:linear-gradient(135deg,var(--cyan),var(--cyan-dim));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.9rem;color:#000;flex-shrink:0;
}
.reviewer-name{font-weight:600;font-size:.88rem;color:#fff}
.reviewer-loc{font-size:.78rem;color:var(--text-dim)}

/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner{
  background:linear-gradient(135deg,rgba(0,212,255,.1) 0%,rgba(245,200,66,.06) 100%);
  border:1px solid rgba(0,212,255,.2);
  border-radius:var(--radius-lg);
  padding:60px 40px;text-align:center;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 50% 50%, rgba(0,212,255,.07) 0%, transparent 70%);
}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{margin-bottom:16px}
.cta-banner p{max-width:560px;margin:0 auto 32px}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:var(--bg-card);
  border-top:1px solid var(--border);
  padding:60px 0 32px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;
  margin-bottom:48px;
}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}

.footer-brand .site-logo{margin-bottom:16px}
.footer-brand p{font-size:.88rem;max-width:280px;margin:0}
.footer-col h4{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff;margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{font-size:.88rem;color:var(--text-muted);transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--cyan)}

.footer-bottom{
  padding-top:24px;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:.82rem;margin:0}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:.82rem;color:var(--text-dim)}
.footer-legal a:hover{color:var(--text-muted)}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.section-header{text-align:center;margin-bottom:48px}
.section-header .badge{margin-bottom:14px}
.section-header h2{margin-bottom:14px}
.section-header p{max-width:560px;margin:0 auto;font-size:1rem}

/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero{
  padding:140px 0 80px;
  text-align:center;
  background:radial-gradient(ellipse 70% 50% at 50% 0%, rgba(0,212,255,.07) 0%, transparent 60%);
  border-bottom:1px solid var(--border);
}
.page-hero h1{margin-bottom:16px}
.page-hero p{font-size:1.05rem;max-width:600px;margin:0 auto}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
.anim-up{
  opacity:0;animation:fadeInUp .7s ease forwards;
}
.anim-up:nth-child(1){animation-delay:.1s}
.anim-up:nth-child(2){animation-delay:.2s}
.anim-up:nth-child(3){animation-delay:.3s}
.anim-up:nth-child(4){animation-delay:.4s}

/* ============================================================
   SCROLLBAR
   ============================================================ */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg-dark)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--cyan-dim)}
