/* IPTV Fast - Dark Theme (UK Colors) - Full Stylesheet
   Palette:
   - Primary (UK Blue): #00247d
   - Secondary (UK Red): #cf142b
   - Accent (Gold): #ffd700
   Dark Surfaces & Text tuned for readability and contrast
*/

/* =========================
   Root & Design Tokens
   ========================= */
:root {
  /* Brand */
  --primary-color: #00247d;   /* Royal Blue */
  --secondary-color: #cf142b; /* Red */
  --accent-color: #ffd700;    /* Gold */

  /* Dark surfaces */
  --bg-900: #0b1220;          /* Page background */
  --bg-850: #0d1528;          /* Deep surface */
  --bg-800: #101a32;          /* Card base */
  --bg-750: #13203d;          /* Raised card / hovers */
  --bg-700: #18294e;          /* Subtle elevated */

  /* Text */
  --text-100: #e9eef7;        /* High-emphasis */
  --text-200: #c9d3ea;        /* Medium */
  --text-300: #9fb0d6;        /* Muted */
  --white: #ffffff;

  /* Borders & outlines */
  --border-color: #263252;    /* Subtle border for dark */
  --focus-ring: 0 0 0 4px rgba(0,36,125,.25);

  /* Effects */
  --shadow: 0 10px 25px rgba(0, 0, 0, 0.35);
  --shadow-lg: 0 20px 40px rgba(0, 0, 0, 0.45);
  --glow-blue: 0 8px 28px rgba(0,36,125,.45);
  --glow-red: 0 8px 28px rgba(207,20,43,.35);
  --glow-gold: 0 8px 28px rgba(255,215,0,.25);

  /* Gradients */
  --gradient: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);
  --gradient-soft: linear-gradient(135deg, rgba(0,36,125,.9), rgba(207,20,43,.9));

  /* Misc */
  --border-radius: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --transition: all .25s ease;
}

/* =========================
   Base & Layout
   ========================= */
* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  line-height: 1.6;
  color: var(--text-100);
  background: radial-gradient(1200px 800px at 20% -10%, rgba(0,36,125,.18) 0%, transparent 60%),
              radial-gradient(900px 600px at 120% 30%, rgba(207,20,43,.12) 0%, transparent 60%),
              var(--bg-900);
  font-weight: 400;
}

.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* Links */
a { color: var(--accent-color); text-decoration: none; }
a:hover { opacity: .9; }

/* =========================
   Navigation
   ========================= */
.navbar {
  background: rgba(13, 21, 40, .85) !important;
  backdrop-filter: blur(12px);
  padding: 1rem 0;
  box-shadow: var(--shadow);
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,.06) !important;
  transition: var(--transition);
}

.navbar-brand {
  font-size: 1.8rem !important;
  font-weight: 900 !important;
  color: var(--text-100) !important;
  letter-spacing: 2px;
  text-transform: uppercase;
}

.navbar-nav .nav-link {
  color: var(--text-200) !important;
  font-weight: 600;
  margin: 0 .35rem;
  padding: .6rem 1rem !important;
  border-radius: 10px;
  transition: var(--transition);
}

.navbar-nav .nav-link:hover {
  color: var(--white) !important;
  background: rgba(255,255,255,.06);
  transform: translateY(-2px);
}

.navbar-nav .btn-primary {
  background: var(--gradient) !important;
  border: none !important;
  font-weight: 700;
  padding: .6rem 1.5rem !important;
  border-radius: 999px;
  box-shadow: var(--glow-red);
  color: var(--white) !important;
}
.navbar-nav .btn-primary:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(207,20,43,.45); }

/* Mobile toggler */
.navbar-toggler { width: 32px; height: 32px; border: none !important; background: transparent !important; padding: 0; cursor: pointer; }
.navbar-toggler:focus { box-shadow: none !important; }
.navbar-toggler-icon { display: none; }
.navbar-toggler span {
  display: block; width: 24px; height: 2px; background: #fff; margin: 5px 0; transition: var(--transition); position: relative;
}
.navbar-toggler:not(.collapsed) span:nth-child(1){ transform: rotate(45deg); top: 7px; }
.navbar-toggler:not(.collapsed) span:nth-child(2){ opacity: 0; }
.navbar-toggler:not(.collapsed) span:nth-child(3){ transform: rotate(-45deg); top: -7px; }

/* Mobile menu */
.menu-open { overflow: hidden; }

@media (max-width: 991.98px){
  .navbar-collapse{
    background: rgba(10,18,40,.96);
    position: fixed !important; top: 0 !important; left: 0;
    width: 100vw !important; height: 100vh !important;
    padding: 80px 2rem 2rem; overflow-y: auto !important;
    display: none !important; z-index: 9999; border: none !important;
  }
  .navbar-collapse.show{
    display: flex !important; flex-direction: column; align-items: center;
  }
  .navbar-nav{ flex-direction: column !important; gap: 1.25rem; margin-top: 1rem; width: 100%; max-width: 420px; }
  .navbar-nav .nav-link{
    font-size: 1.1rem; width: 100%; text-align: center; padding: 1rem !important; border-radius: 12px;
    background: rgba(255,255,255,.06); color: var(--text-100) !important;
  }
  .navbar-nav .nav-link:hover{ background: var(--gradient-soft); transform: translateY(-2px) scale(1.01); }
  .navbar-nav .btn-primary{ width: 100%; text-align: center; margin-top: .5rem; padding: 1.1rem !important; font-size: 1.05rem; }
}

/* =========================
   Hero
   ========================= */
.main-content { margin-top: 0; }

.hero {
  background: linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.1) 25%, rgba(0,0,0,.25) 100%), var(--gradient);
  color: var(--white);
  position: relative; overflow: hidden; min-height: 100vh;
  display: flex; align-items: center; justify-content: center; text-align: center; padding: 0 20px; margin-top: 0;
}
.hero::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(700px 350px at 10% 25%, rgba(255,215,0,.15) 0%, transparent 60%);
  opacity: .6;
}
.hero .container{ position: relative; z-index: 2; padding-top: 80px; }
.hero h1{
  font-size: 3.5rem; font-weight: 900; margin-bottom: 1.25rem; line-height: 1.1;
  text-shadow: 0 8px 24px rgba(0,0,0,.35);
}
.hero-subtitle{
  font-size: 1.25rem; margin-bottom: 2.2rem; opacity: .98; font-weight: 400; max-width: 820px; margin-inline: auto;
}

/* Buttons */
.btn{
  font-weight: 700; padding: .95rem 1.8rem; border-radius: 999px; border: none;
  transition: var(--transition); display: inline-flex; align-items:center; gap:.5rem; cursor: pointer;
}
.btn-lg{ font-size: 1.05rem; padding: 1.1rem 2.2rem; }
.btn-hero{
  background: var(--white); color: var(--primary-color); box-shadow: var(--glow-gold);
}
.btn-hero:hover{ transform: translateY(-2px); box-shadow: 0 12px 30px rgba(255,255,255,.35); }

.btn-primary{ background: var(--gradient); color: var(--white); box-shadow: var(--glow-blue); }
.btn-primary:hover{ transform: translateY(-2px); box-shadow: 0 14px 36px rgba(0,36,125,.55); color: var(--white); }

.btn-cta{ background: var(--accent-color); color: var(--bg-900); font-weight: 800; box-shadow: var(--glow-gold); }
.btn-cta:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px rgba(255,215,0,.35); color: var(--bg-900); }

/* =========================
   Sections & Headings
   ========================= */
section { padding: 96px 0; }
section h2{
  font-size: 2.4rem; font-weight: 800; text-align: center; color: var(--text-100); margin-bottom: .75rem;
}
.section-subtitle{
  font-size: 1.05rem; color: var(--text-300); text-align: center; max-width: 760px; margin: 0 auto 3rem;
}

/* =========================
   Cards & Grids (Generic)
   ========================= */
.content-grid,
.playlist-grid,
.vod-showcase,
.pricing-grid,
.steps-grid,
.features-showcase { display: grid; gap: 1.5rem; }
.content-grid{ grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); }
.playlist-grid{ grid-template-columns: repeat(auto-fit, minmax(340px,1fr)); }
.vod-showcase{ grid-template-columns: repeat(auto-fit, minmax(320px,1fr)); gap: 2rem; }
.pricing-grid{ grid-template-columns: repeat(auto-fit, minmax(340px,1fr)); max-width: 1200px; margin: 0 auto; }
.steps-grid{ grid-template-columns: repeat(auto-fit, minmax(250px,1fr)); max-width: 1000px; margin: 0 auto; }

/* Content cards */
.universe-content { background: var(--bg-900); }
.content-card{
  background: var(--bg-800); padding: 2rem; border-radius: var(--border-radius); text-align: center;
  transition: var(--transition); border: 1px solid var(--border-color);
}
.content-card:hover{
  transform: translateY(-8px);
  background: var(--bg-750);
  border-color: rgba(0,36,125,.6);
  box-shadow: var(--shadow-lg);
}
.content-card i{ font-size: 2.6rem; color: var(--accent-color); margin-bottom: 1rem; }
.content-card h3{ font-size: 1.2rem; font-weight: 800; color: var(--text-100); margin-bottom: .35rem; }
.content-card p{ color: var(--text-300); font-weight: 500; }

/* Playlist */
.playlist-section{ background: var(--bg-900); }
.playlist-card{
  background: var(--bg-800); padding: 2.2rem; border-radius: var(--border-radius); text-align: center;
  box-shadow: var(--shadow); transition: var(--transition); border: 1px solid var(--border-color);
}
.playlist-card:hover{ transform: translateY(-6px); box-shadow: var(--shadow-lg); background: var(--bg-750); }
.playlist-card i{ font-size: 2.2rem; color: var(--text-200); margin-bottom: 1.25rem; }
.playlist-card h4{ font-size: 1.35rem; font-weight: 800; color: var(--text-100); margin-bottom: .75rem; }
.playlist-card p{ color: var(--text-300); }

/* VOD */
.vod-section{ background: var(--bg-900); padding: 110px 0; }
.vod-item{
  text-align: center; transition: var(--transition); background: var(--bg-800);
  border-radius: var(--border-radius); padding: 1.25rem; box-shadow: var(--shadow); border: 1px solid var(--border-color);
}
.vod-item:hover{ transform: translateY(-6px); box-shadow: var(--shadow-lg); background: var(--bg-750); }
.vod-item img{
  width: 100%; height: 260px; object-fit: cover; border-radius: var(--border-radius);
  margin-bottom: 1rem; box-shadow: var(--shadow); transition: var(--transition); filter: saturate(1.05) contrast(1.05);
}
.vod-item img:hover{ transform: scale(1.02); }
.vod-item h4{ font-weight: 800; color: var(--text-100); font-size: 1.25rem; margin-bottom: .6rem; }
.vod-description{ color: var(--text-300); font-size: .95rem; line-height: 1.55; font-weight: 500; max-width: 300px; margin: 0 auto; }

/* =========================
   Pricing
   ========================= */
.pricing-section{ background: var(--bg-900); }
.pricing-section h2{ color: var(--text-100); }
.pricing-section .section-subtitle{ color: var(--text-300); }

.pricing-card{
  background: var(--bg-800); border-radius: var(--radius-lg); padding: 2.2rem; box-shadow: var(--shadow);
  border: 1px solid var(--border-color); position: relative; transition: var(--transition); text-align: center;
}
.pricing-card:hover{ transform: translateY(-8px); box-shadow: var(--shadow-lg); }

.pricing-card.featured{
  border-color: rgba(207,20,43,.6);
  box-shadow: 0 16px 40px rgba(207,20,43,.25);
}
.pricing-card.premium{
  border-color: rgba(255,215,0,.6);
  background: linear-gradient(135deg, rgba(255,215,0,.06) 0%, var(--bg-800) 100%);
}

.popular-badge,
.premium-badge{
  position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
  padding: .45rem 1.3rem; border-radius: 999px; font-size: .85rem; font-weight: 800; color: var(--white);
}
.popular-badge{ background: var(--secondary-color); }
.premium-badge{ background: var(--accent-color); color: var(--bg-900); }

.pricing-card h3{ font-size: 1.6rem; font-weight: 900; color: var(--text-100); margin-bottom: 1.1rem; }
.price{ display: flex; justify-content: center; align-items: baseline; margin-bottom: 1.6rem; gap: 4px; }
.currency{ font-size: 1.25rem; font-weight: 700; color: var(--text-200); }
.amount{ font-size: 2.6rem; font-weight: 900; color: var(--text-100); }

/* Feature list */
.features-list{
  list-style: none; padding: 0; margin: 0 0 1.6rem; display: flex; flex-direction: column; gap: .65rem;
}
.features-list li{
  display: flex; align-items: center; gap: .65rem; font-size: .95rem; color: var(--text-200); font-weight: 500;
}
.features-list li::before{
  content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900; font-size: .7rem;
  display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px;
  background: var(--primary-color); color: #fff; border-radius: 50%;
}
.features-list.premium li.premium-feature::before{ background: var(--accent-color); color: var(--bg-900); }

.secure-payment{
  background: var(--bg-850); padding: 1rem; border-radius: 10px; font-size: .9rem;
  color: var(--accent-color); font-weight: 700; margin: 1rem 0; border-left: 4px solid var(--accent-color);
}

.btn-block{
  width: 100%; display: inline-block; padding: 1rem; background: var(--gradient); color: var(--white);
  text-transform: uppercase; font-weight: 800; letter-spacing: .6px; border-radius: 999px; text-align: center;
  box-shadow: var(--glow-blue); transition: var(--transition);
}
.btn-block:hover{ transform: translateY(-2px); box-shadow: 0 16px 38px rgba(0,36,125,.55); }

/* =========================
   How to Order / Steps
   ========================= */
.how-to-order{ background: var(--bg-900); }
.step-item{
  background: var(--bg-800); padding: 2rem; border-radius: 16px; text-align: center;
  box-shadow: var(--shadow); transition: var(--transition); position: relative; border: 1px solid var(--border-color);
}
.step-item:hover{ transform: translateY(-4px); background: var(--bg-750); box-shadow: var(--shadow-lg); }
.step-number{
  width: 60px; height: 60px; background: var(--gradient); color: var(--white); border-radius: 50%;
  display: flex; align-items: center; justify-content: center; font-size: 1.4rem; font-weight: 900; margin: 0 auto 1.1rem;
  box-shadow: var(--glow-blue);
}
.step-item h4{ font-size: 1.15rem; font-weight: 800; color: var(--text-100); margin-bottom: .5rem; }
.step-item p{ color: var(--text-300); }

/* =========================
   Devices Carousel
   ========================= */
.devices-section{ background: var(--bg-900); position: relative; }
.devices-carousel{ display: flex; gap: 1.2rem; overflow-x: auto; padding: 1rem 0 2rem; margin-top: 1.2rem; scrollbar-width: none; -ms-overflow-style: none; scroll-behavior: smooth; }
.devices-carousel::-webkit-scrollbar{ display: none; }
.device-item{
  display: flex; flex-direction: column; align-items: center; padding: 1.5rem 1.2rem; background: var(--bg-800);
  border-radius: 14px; transition: var(--transition); min-width: 140px; cursor: pointer; box-shadow: var(--shadow);
  border: 1px solid var(--border-color); flex-shrink: 0; color: var(--text-200);
}
.device-item:hover{
  background: var(--gradient-soft); color: var(--white); transform: translateY(-6px); box-shadow: var(--glow-blue);
}
.device-item i{ font-size: 2.4rem; margin-bottom: .8rem; }
.device-item span{ font-weight: 700; font-size: .92rem; text-align: center; }

.devices-dots{ display: flex; justify-content: center; margin-top: .5rem; gap: 8px; }
.devices-dots .dot{ width: 10px; height: 10px; border-radius: 50%; background: var(--text-300); opacity: .5; cursor: pointer; transition: opacity .25s ease; }
.devices-dots .dot.active{ opacity: 1; background: var(--secondary-color); }

/* =========================
   Testimonials / WhatsApp
   ========================= */
.testimonials-section{ background: var(--bg-900); }
.whatsapp-carousel{ display:flex; gap:1.4rem; overflow-x:auto; padding:1rem 0 2rem; scroll-behavior:smooth; scrollbar-width:none; -ms-overflow-style:none; }
.whatsapp-carousel::-webkit-scrollbar{ display:none; }
.whatsapp-review{ flex:0 0 300px; text-align:center; }
.whatsapp-review img{
  width:100%; max-width:300px; border-radius: var(--border-radius); box-shadow: var(--shadow);
  transition: var(--transition); border:1px solid var(--border-color); filter: contrast(1.05);
}
.whatsapp-review img:hover{ transform: scale(1.03); box-shadow: var(--shadow-lg); }

.whatsapp-dots{ display:flex; justify-content:center; margin-top:.6rem; gap:8px; }
.whatsapp-dots .dot{ width:10px; height:10px; border-radius:50%; background: var(--text-300); opacity:.5; cursor:pointer; transition: opacity .25s ease; }
.whatsapp-dots .dot.active{ opacity:1; background: var(--secondary-color); }

/* =========================
   Final CTA
   ========================= */
.final-cta{
  background: var(--gradient);
  color: var(--white);
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 88px; padding-bottom: 88px;
}
.final-cta h2{ color: var(--white); font-size: 2.3rem; font-weight: 900; margin-bottom: .8rem; }
.final-cta .section-subtitle{ color: rgba(255,255,255,.92); margin-bottom: 1.8rem; }

/* =========================
   SEO / Why Choose
   ========================= */
.seo-section{ background: var(--bg-900); }
.seo-section h2{ text-align:left; margin-bottom: 1.2rem; }
.seo-section .section-subtitle{ text-align:left; margin-bottom: 1.6rem; }
.seo-section p{ font-size: 1.05rem; line-height: 1.75; color: var(--text-200); margin-bottom: 1.1rem; }

.why-choose-section{ background: var(--bg-900); }
.feature-highlight{
  text-align:center; padding:1.8rem; background: var(--bg-800); border-radius: var(--border-radius);
  transition: var(--transition); border:1px solid var(--border-color);
}
.feature-highlight:hover{ transform: translateY(-4px); background: var(--bg-750); box-shadow: var(--shadow); }
.feature-highlight i{ font-size: 2.2rem; color: var(--accent-color); margin-bottom: .8rem; }
.feature-highlight h4{ font-weight: 800; color: var(--text-100); margin-bottom: .5rem; }
.feature-highlight p{ color: var(--text-300); }

/* =========================
   Footer
   ========================= */
.footer{
  background: #0a1224 !important; color: var(--text-200);
  border-top: 1px solid rgba(255,255,255,.06);
}
.footer h5, .footer h6{ font-weight: 800; margin-bottom: 1.1rem; color: var(--text-100); }
.footer .contact-info p{ margin-bottom: .6rem; }
.footer .contact-info i{ color: var(--accent-color); margin-right: .5rem; }
.social-links a{ color: var(--text-200); font-size: 1.4rem; transition: var(--transition); }
.social-links a:hover{ color: var(--accent-color); transform: translateY(-2px); }

/* =========================
   Checkout (Dark)
   ========================= */
.professional-checkout{ background: var(--bg-900); padding: 96px 0; min-height: 100vh; }
.checkout-header{ text-align: center; margin-bottom: 3rem; }
.main-title{ font-size: 2.6rem; font-weight: 900; color: var(--text-100); margin-bottom: .75rem; }
.main-subtitle{ font-size: 1.05rem; color: var(--text-300); }

.checkout-grid{ display:grid; grid-template-columns: 1fr 400px; gap: 2.2rem; max-width: 1200px; margin: 0 auto; }

.form-card, .summary-card{
  background: var(--bg-800); border-radius: var(--radius-lg); padding: 2rem; box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-color);
}
.card-header{
  display:flex; align-items:center; gap: 1rem; margin-bottom: 2rem; padding-bottom: 1.2rem; border-bottom: 1px solid var(--border-color);
}
.header-icon{
  width: 46px; height: 46px; background: var(--gradient); border-radius: 12px; display:flex; align-items:center; justify-content:center; color:#fff; font-size: 1.1rem;
}
.header-text h2{ font-size: 1.35rem; font-weight: 900; color: var(--text-100); margin: 0 0 .2rem 0; }
.header-text p{ font-size: .92rem; color: var(--text-300); margin: 0; }

/* Inputs */
.form-field{ margin-bottom: 1.6rem; }
.field-label{ display:block; font-size: .98rem; font-weight: 700; color: var(--text-200); margin-bottom: .5rem; display:flex; align-items:center; gap: 8px; }
.field-label i{ color: var(--accent-color); width: 16px; text-align: center; }
.required{ color: var(--secondary-color); font-weight: 800; }

.form-input, .form-textarea{
  width: 100%; padding: .95rem 1.1rem; font-size: 1rem; border: 1px solid var(--border-color);
  border-radius: 12px; background: var(--bg-850); transition: var(--transition); font-family: inherit; color: var(--text-100);
}
.form-input::placeholder, .form-textarea::placeholder{ color: var(--text-300); }
.form-input:focus, .form-textarea:focus{
  outline: none; border-color: rgba(0,36,125,.7); background: var(--bg-750); box-shadow: var(--focus-ring);
}
.form-textarea{ resize: vertical; min-height: 110px; }

/* intl-tel-input dark */
.iti{ width: 100% !important; }
.iti__flag-container{
  background: var(--bg-850); border: 1px solid var(--border-color);
  border-right: 1px solid var(--border-color); border-radius: 12px 0 0 12px; transition: var(--transition);
}
.iti__selected-flag{ background: transparent; border: none; padding: 0 12px; }
.iti input[type=tel]{
  width: 100%; padding: .95rem 1.1rem; font-size: 1rem; border: 1px solid var(--border-color);
  border-left: 1px solid var(--border-color); border-radius: 0 12px 12px 0; background: var(--bg-850);
  transition: var(--transition); color: var(--text-100);
}
.iti input[type=tel]:focus{ outline: none; border-color: rgba(0,36,125,.7); background: var(--bg-750); box-shadow: var(--focus-ring); }
.iti input[type=tel]:focus + .iti__flag-container{ border-color: rgba(0,36,125,.7); background: var(--bg-750); }

/* Terms */
.terms-section{
  margin: 1.4rem 0; padding: 1.2rem; background: var(--bg-850); border-radius: 12px; border: 1px solid var(--border-color);
}
.checkbox-container{ display:flex; align-items:flex-start; gap: 12px; cursor:pointer; position:relative; }
.checkbox-container input[type="checkbox"]{ position:absolute; opacity:0; cursor:pointer; }
.checkbox-checkmark{
  width:20px; height:20px; background: var(--bg-900); border: 1px solid var(--border-color); border-radius: 4px; position:relative; flex-shrink:0; margin-top:2px; transition: var(--transition);
}
.checkbox-checkmark:after{
  content:""; position:absolute; display:none; left:5px; top:2px; width:6px; height:10px; border: solid #fff; border-width:0 2px 2px 0; transform: rotate(45deg);
}
.checkbox-container input:checked ~ .checkbox-checkmark{ background: var(--primary-color); border-color: var(--primary-color); }
.checkbox-container input:checked ~ .checkbox-checkmark:after{ display:block; }
.checkbox-text{ font-size: .92rem; line-height: 1.55; color: var(--text-200); }
.checkbox-text a{ color: var(--accent-color); font-weight: 700; }
.checkbox-text a:hover{ text-decoration: underline; }

/* Submit */
.submit-button{
  width: 100%; padding: 1.05rem 1.25rem; background: var(--gradient); color: #fff; border:none; border-radius: 12px;
  font-size: 1.05rem; font-weight: 900; cursor:pointer; transition: var(--transition); display:flex; align-items:center; justify-content: space-between;
  text-transform: uppercase; letter-spacing: .5px; box-shadow: var(--glow-blue);
}
.submit-button:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px rgba(0,36,125,.55); }
.submit-button i{ transition: transform .25s ease; }
.submit-button:hover i{ transform: translateX(4px); }

/* Summary / order */
.order-summary-section{ position: sticky; top: 120px; height: fit-content; }

.selected-plan{
  background: var(--gradient-soft); color: var(--white); padding: 1.6rem; border-radius: 16px; margin-bottom: 1.4rem; box-shadow: var(--glow-blue);
}
.plan-header{ display:flex; justify-content: space-between; align-items: flex-start; margin-bottom: 1.1rem; }
.plan-details h3{ font-size: 1.2rem; font-weight: 900; margin: 0 0 .15rem 0; }
.plan-duration{ font-size: .82rem; opacity: .95; }
.plan-badge{ padding: .28rem .7rem; border-radius: 12px; font-size: .68rem; font-weight: 900; text-transform: uppercase; }
.plan-badge.most-popular{ background: rgba(255,255,255,.22); }
.plan-badge.best-value{ background: var(--accent-color); color: var(--bg-900); }

.plan-pricing{ text-align:center; }
.price-display{ display:flex; align-items: baseline; justify-content: center; gap: 3px; margin-bottom: .35rem; }
.price-subtitle{ font-size: .82rem; opacity: .95; }

.plan-features{ margin-bottom: 1.6rem; }
.plan-features h4{
  font-size: 1rem; font-weight: 900; color: var(--text-100); margin-bottom: 1.1rem; display:flex; align-items:center; gap: 8px;
}
.plan-features h4 i{ color: var(--accent-color); }
.plan-features .features-list li{
  padding: .5rem 0; font-size: .92rem; color: var(--text-200); border-bottom: 1px solid var(--border-color);
}
.plan-features .features-list li:last-child{ border-bottom: none; }
.plan-features .features-list li i{ color: var(--accent-color); font-size: .8rem; width: 14px; text-align:center; }
.plan-features .features-list li.premium-feature{
  background: rgba(255,215,0,.08); padding: .7rem; border-radius: 8px; border: 1px solid rgba(255,215,0,.25); font-weight: 700;
}
.plan-features .features-list li.premium-feature i{ color: var(--accent-color); }

.security-section{
  display:grid; grid-template-columns: 1fr; gap: .65rem; margin-bottom: 1.4rem; padding: 1.2rem; background: var(--bg-850); border-radius: 12px;
}
.security-item{ display:flex; align-items:center; gap: 10px; font-size: .85rem; color: var(--text-200); }
.security-item i{ color: #22c55e; font-size: 1rem; width: 20px; text-align:center; }

.price-breakdown{ border-top: 1px solid var(--border-color); padding-top: 1.1rem; margin-bottom: 1.6rem; }
.price-row{ display:flex; justify-content: space-between; align-items: center; padding: .45rem 0; font-size: .98rem; color: var(--text-200); }
.price-row.total-row{
  font-size: 1.15rem; font-weight: 900; color: var(--text-100);
  border-top: 1px solid var(--border-color); padding-top: .9rem; margin-top: .9rem;
}

.guarantee-box{
  display:flex; align-items:center; gap: 1rem; padding: 1.2rem;
  background: linear-gradient(135deg, rgba(34,197,94,.14) 0%, rgba(20,83,45,.14) 100%); border-radius: 12px; border: 1px solid rgba(34,197,94,.25);
}
.guarantee-icon{ width: 38px; height: 38px; background:#22c55e; color:#fff; border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 1.05rem; }
.guarantee-text strong{ display:block; font-size:.95rem; color: var(--text-100); margin-bottom: .1rem; }
.guarantee-text p{ font-size:.82rem; color: var(--text-300); margin:0; }

/* Flash message */
.success-message{
  background: linear-gradient(135deg, rgba(52,211,153,.18) 0%, rgba(16,185,129,.14) 100%);
  color: #9ff2c8; padding: 1.2rem; border-radius: 12px; margin-bottom: 1.6rem; display:flex; align-items:center; gap: 12px;
  border: 1px solid rgba(16,185,129,.35);
}
.success-message i{ font-size: 1.1rem; color: #34d399; }

/* =========================
   Channels Library (Dark)
   ========================= */
.channels-library{
  position: relative; padding-top: 120px; z-index: 5; background: var(--bg-900); min-height: 100vh;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif; color: var(--text-100);
}
.channels-library .container{ max-width: 1200px; margin: 0 auto; padding: 0 20px; }

.channels-library .library-header{
  margin: 0 auto 2.2rem; padding: 2.4rem 1.8rem; background: var(--gradient);
  color: #fff; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); position: relative; overflow: hidden;
}
.channels-library .library-header::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(circle at 30% 20%, rgba(255,215,0,.12) 0%, transparent 55%);
}
.channels-library .header-content{ position: relative; z-index: 2; margin-bottom: 1.4rem; }
.channels-library .header-content h1{
  font-size: 2.2rem; font-weight: 900; margin-bottom: .6rem; display:flex; align-items:center; justify-content:center; gap: .8rem;
  text-shadow: 0 8px 22px rgba(0,0,0,.35);
}
.channels-library .header-content h1 i{ color: var(--accent-color); font-size: 1.8rem; }
.channels-library .header-content p{ font-size: 1.02rem; opacity: .98; max-width: 700px; margin: 0 auto; line-height: 1.55; }

.channels-library .premium-status{
  display:flex; justify-content: space-between; align-items:center; background: rgba(255,255,255,.14);
  backdrop-filter: blur(14px); border: 1px solid rgba(255,255,255,.22); border-radius: 28px; padding: .85rem 1.4rem; margin: 0 auto;
  max-width: 820px; position: relative; z-index: 2;
}
.channels-library .status-info{ display:flex; align-items:center; gap: 1.4rem; }
.channels-library .plan-indicator{ display:flex; align-items:center; gap:.5rem; font-weight: 900; font-size: 1rem; }
.channels-library .plan-indicator i{ color: var(--accent-color); font-size: 1.2rem; }
.channels-library .expiry-info{ font-size: .9rem; opacity: .95; font-weight: 600; }
.channels-library .connections-badge{
  display:flex; align-items:center; gap:.5rem; background: rgba(255,255,255,.22);
  padding: .45rem .9rem; border-radius: 20px; font-weight: 700; font-size: .9rem;
}

.channels-library .search-section{ margin-bottom: 2rem; padding: 0 1rem; }
.channels-library .search-container{ max-width: 820px; margin: 0 auto; display:flex; gap: .8rem; align-items: stretch; }
.channels-library .search-input-wrapper{ flex: 1; position: relative; }
.channels-library .search-icon{ position:absolute; left: 1.2rem; top: 50%; transform: translateY(-50%); color: var(--text-300); font-size: 1.05rem; z-index:2; }
.channels-library .search-input{
  width: 100%; padding: .95rem 1.2rem .95rem 2.6rem; border: 1px solid var(--border-color); border-radius: 999px;
  background: var(--bg-850); font-size: 1rem; font-weight: 600; transition: var(--transition); color: var(--text-100); box-shadow: var(--shadow);
}
.channels-library .search-input:focus{ outline:none; border-color: rgba(0,36,125,.65); box-shadow: var(--focus-ring); }
.channels-library .search-input::placeholder{ color: var(--text-300); }
.channels-library .clear-search{
  position:absolute; right: .8rem; top: 50%; transform: translateY(-50%); background: var(--bg-700); color: var(--text-200);
  border:none; border-radius: 50%; width: 26px; height: 26px; cursor: pointer; display:flex; align-items:center; justify-content:center; transition: var(--transition); font-size: .8rem;
}
.channels-library .clear-search:hover{ background: var(--secondary-color); color:#fff; }
.channels-library .search-btn{
  padding: .95rem 1.6rem; background: var(--gradient); color: #fff; border: none; border-radius: 999px; font-weight: 800; cursor: pointer;
  transition: var(--transition); display:flex; align-items:center; gap: .5rem; font-size: 1rem; box-shadow: var(--glow-blue); white-space: nowrap;
}
.channels-library .search-btn:hover{ transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,36,125,.55); }

/* Tabs */
.channels-library .content-tabs{
  display:grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; max-width: 640px; margin: 0 auto 2.2rem;
}
.channels-library .tab-btn{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius);
  padding: 1.2rem; color: var(--text-200); transition: var(--transition); display:flex; align-items:center; gap: 1rem; box-shadow: var(--shadow);
}
.channels-library .tab-btn:hover, .channels-library .tab-btn.active{
  border-color: rgba(0,36,125,.66); transform: translateY(-3px); box-shadow: var(--shadow-lg); color: var(--text-100);
}
.channels-library .tab-icon{
  width: 48px; height: 48px; background: var(--bg-850); border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 1.4rem; color: var(--text-200);
}
.channels-library .tab-btn.active .tab-icon{ background: var(--gradient); color: #fff; }
.channels-library .tab-content h4{ font-size: 1.12rem; font-weight: 900; color: var(--text-100); margin: 0 0 .2rem 0; }
.channels-library .tab-content p{ color: var(--text-300); margin: 0; font-size: .92rem; }

/* Warnings / Availability / Cards */
.channels-library .adult-warning{
  background: linear-gradient(135deg, rgba(239,68,68,.18), rgba(239,68,68,.12));
  border: 1px solid rgba(239,68,68,.35); border-radius: var(--border-radius); padding: 1.6rem; margin-bottom: 2rem; box-shadow: var(--shadow);
}
.channels-library .warning-content{ display:flex; align-items:center; gap: 1.2rem; }
.channels-library .warning-icon{
  width: 56px; height: 56px; background: #ef4444; border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 1.6rem; color:#fff; flex-shrink: 0;
}
.channels-library .warning-text h3{ font-size: 1.25rem; font-weight: 900; color: #fecaca; margin-bottom: .35rem; }
.channels-library .warning-text p{ color: #fca5a5; font-size: .98rem; }

.channels-library .availability-card{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius);
  padding: 2.2rem; box-shadow: var(--shadow); display:flex; align-items:center; gap: 1.6rem; max-width: 820px; margin: 0 auto 2rem;
}
.channels-library .availability-icon{
  width: 74px; height: 74px; background: linear-gradient(135deg, #22c55e, #16a34a); border-radius: 50%;
  display:flex; align-items:center; justify-content:center; font-size: 2rem; color:#fff; flex-shrink: 0;
}
.channels-library .availability-content h3{ font-size: 1.6rem; font-weight: 900; color: var(--text-100); margin-bottom: .7rem; }
.channels-library .availability-content p{ color: var(--text-300); font-size: 1.02rem; line-height: 1.55; margin-bottom: 1rem; }
.channels-library .content-features{ display:flex; gap:.7rem; flex-wrap: wrap; }
.channels-library .feature-badge{
  background: var(--bg-850); color: var(--text-100); padding: .45rem .9rem; border-radius: 999px; font-size: .88rem; font-weight: 700; display:flex; align-items:center; gap:.45rem; border:1px solid var(--border-color);
}

/* Grids */
.channels-library .section-header{ text-align:center; margin-bottom: 2rem; }
.channels-library .section-header h2{
  font-size: 2rem; font-weight: 900; color: var(--text-100); margin-bottom: .45rem; display:flex; align-items:center; justify-content:center; gap:.8rem;
}
.channels-library .section-header h2 i{ color: var(--secondary-color); }
.channels-library .section-header p{ color: var(--text-300); font-size: 1.02rem; }

.channels-library .categories-grid,
.channels-library .vod-grid,
.channels-library .countries-grid{ display:grid; gap: 1.2rem; }
.channels-library .categories-grid{ grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); }
.channels-library .vod-grid{ grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); }
.channels-library .countries-grid{ grid-template-columns: repeat(auto-fill, minmax(260px,1fr)); padding: 0 1rem; }

.channels-library .category-info-card,
.channels-library .vod-info-card,
.channels-library .country-card{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius);
  padding: 1.8rem; box-shadow: var(--shadow); transition: var(--transition); text-align:center; color: var(--text-200);
}
.channels-library .category-info-card:hover,
.channels-library .vod-info-card:hover,
.channels-library .country-card:hover{
  transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: rgba(0,36,125,.65); color: var(--text-100);
}
.channels-library .country-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height: 4px; background: var(--gradient); transform: scaleX(0); transition: var(--transition);
}
.channels-library .country-card:hover::before{ transform: scaleX(1); }
.channels-library .country-flag{ font-size: 2.4rem; margin-bottom: .8rem; display:block; }
.channels-library .category-icon, .channels-library .vod-icon{
  width: 60px; height: 60px; background: var(--gradient); border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 1.5rem; color:#fff; margin: 0 auto 1rem;
}
.channels-library .category-content h3, .channels-library .vod-content h3{ font-size: 1.15rem; font-weight: 900; color: var(--text-100); margin-bottom: .6rem; }
.channels-library .availability-indicator, .channels-library .availability-status{
  display:flex; align-items:center; justify-content:center; gap:.5rem; color:#22c55e; font-weight: 800; font-size: .9rem;
}

/* Premium CTA */
.channels-library .premium-cta{
  background: var(--gradient); border-radius: 20px; padding: 2.2rem 1.6rem; margin: 2rem 1rem 1rem; position: relative; overflow:hidden; box-shadow: var(--shadow-lg);
}
.channels-library .premium-cta::before{
  content:''; position:absolute; inset:0; background: radial-gradient(circle at 35% 20%, rgba(255,215,0,.12) 0%, transparent 55%);
}
.channels-library .cta-content{ display:grid; grid-template-columns: auto 1fr auto; gap: 1.4rem; align-items:center; position:relative; z-index: 1; }
.channels-library .cta-icon{
  width: 64px; height: 64px; background: rgba(255,255,255,.22); border-radius: 50%; display:flex; align-items:center; justify-content:center;
  font-size: 1.8rem; color: var(--accent-color); backdrop-filter: blur(10px);
}
.channels-library .cta-text{ color: #fff; }
.channels-library .cta-text h2{ font-size: 1.6rem; font-weight: 900; margin-bottom: .6rem; }
.channels-library .cta-text p{ font-size: .98rem; margin-bottom: 1.1rem; opacity: .98; }
.channels-library .cta-features{ display:flex; gap:.6rem; flex-wrap: wrap; }
.channels-library .feature-item{
  background: rgba(255,255,255,.18); padding: .45rem .9rem; border-radius: 14px; font-size: .82rem; font-weight: 800; display:flex; align-items:center; gap:.4rem; backdrop-filter: blur(8px);
}
.channels-library .premium-btn{
  background: #fff; color: var(--primary-color); padding: .95rem 1.6rem; border-radius: 999px; font-weight: 900; transition: var(--transition); display:flex; align-items:center; gap: .7rem; box-shadow: var(--shadow);
}
.channels-library .premium-btn:hover{ color: var(--primary-color); transform: translateY(-2px); box-shadow: 0 14px 34px rgba(255,255,255,.25); }

/* =========================
   Contact Page (Dark)
   ========================= */
.contact-page{ position: relative; padding-top: 120px; background: var(--bg-900); min-height: 100vh; color: var(--text-100); }
.contact-header{
  text-align:center; margin-bottom: 3rem; padding: 2.4rem 1.8rem; background: var(--gradient);
  color: #fff; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); position: relative; overflow: hidden;
}
.contact-header::before{ content:''; position:absolute; inset:0; background: radial-gradient(circle at 30% 20%, rgba(255,215,0,.12) 0%, transparent 55%); }
.header-content{ position: relative; z-index: 1; }
.header-content h1{ font-size: 2.1rem; font-weight: 900; margin-bottom: .6rem; display:flex; align-items:center; justify-content:center; gap:.8rem; }
.header-content h1 i{ color: var(--accent-color); font-size: 1.8rem; }
.header-content p{ font-size: 1.06rem; opacity: .98; max-width: 700px; margin: 0 auto; line-height: 1.6; }

.contact-content{ display:grid; grid-template-columns: 1fr 2fr; gap: 2.6rem; margin-bottom: 3rem; }
.info-card{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius);
  padding: 1.6rem; box-shadow: var(--shadow); transition: var(--transition); display:flex; align-items:center; gap: 1.2rem;
}
.info-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: rgba(0,36,125,.6); }
.info-icon{
  width: 56px; height: 56px; background: var(--gradient); border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 1.4rem; color: #fff; flex-shrink: 0;
}
.info-content h3{ font-size: 1.2rem; font-weight: 900; color: var(--text-100); margin-bottom: .35rem; }
.info-content p{ color: var(--text-300); font-size: .98rem; line-height: 1.55; margin: 0 0 .6rem 0; }

.whatsapp-link{
  display:inline-flex; align-items:center; gap:.5rem; background:#25d366; color:#fff; padding:.6rem 1.1rem; border-radius: 999px; font-weight: 800; font-size: .9rem; transition: var(--transition);
}
.whatsapp-link:hover{ background:#128c7e; transform: translateY(-2px); box-shadow: 0 10px 22px rgba(37,211,102,.22); }
.whatsapp-link i{ font-size: 1rem; }

.contact-form-section{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius); padding: 2.2rem; box-shadow: var(--shadow);
}
.success-message, .error-message{
  display:flex; align-items:center; gap: 1.2rem; padding: 1.1rem; border-radius: var(--border-radius); margin-bottom: 1.4rem; transition: var(--transition);
}
.success-message{ background: linear-gradient(135deg, rgba(34,197,94,.16), rgba(16,185,129,.12)); border: 1px solid rgba(34,197,94,.35); color: #bef7d9; }
.error-message{ background: linear-gradient(135deg, rgba(239,68,68,.16), rgba(239,68,68,.12)); border: 1px solid rgba(239,68,68,.35); color: #fecaca; }
.message-icon{ width: 46px; height: 46px; border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 1.3rem; }
.success-message .message-icon{ background:#22c55e; color:#fff; }
.error-message .message-icon{ background:#ef4444; color:#fff; }
.message-content h3{ font-size: 1.05rem; font-weight: 900; margin-bottom: .35rem; }

.contact-form{ display:flex; flex-direction: column; gap: 1.6rem; }
.form-group{ display:flex; flex-direction: column; gap: .65rem; }
.form-row{ display:grid; grid-template-columns: 1fr 2fr; gap: 1rem; }
.form-group label{ font-weight: 800; color: var(--text-200); display:flex; align-items:center; gap: .5rem; font-size: .98rem; }
.form-group label i{ color: var(--accent-color); font-size: 1rem; }
.form-control{
  padding: .95rem 1.1rem; border: 1px solid var(--border-color); border-radius: var(--border-radius);
  background: var(--bg-850); font-size: 1rem; font-weight: 600; color: var(--text-100); transition: var(--transition);
}
.form-control:focus{ outline:none; border-color: rgba(0,36,125,.65); box-shadow: var(--focus-ring); background: var(--bg-750); }
.form-control::placeholder{ color: var(--text-300); }
select.form-control{ cursor: pointer; }
textarea.form-control{ resize: vertical; min-height: 120px; line-height: 1.6; }

.form-actions{ display:flex; justify-content:center; margin-top: .6rem; }
.submit-btn{
  background: var(--gradient); color:#fff; border:none; padding: 1rem 2.2rem; border-radius: 999px; font-weight: 900; font-size: 1.05rem; cursor:pointer;
  transition: var(--transition); display:flex; align-items:center; gap: .7rem; box-shadow: var(--glow-blue); min-width: 200px; justify-content:center;
}
.submit-btn:hover:not(:disabled){ transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,36,125,.55); }
.submit-btn:disabled{ opacity:.6; cursor:not-allowed; }

/* FAQ */
.faq-section{ margin-top: 3rem; margin-bottom: 2rem; }
.faq-grid{ display:grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: 1.2rem; }
.faq-item{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius);
  padding: 1.6rem; box-shadow: var(--shadow); transition: var(--transition);
}
.faq-item:hover{ transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: rgba(0,36,125,.6); }
.faq-question{ display:flex; align-items:center; gap: .8rem; margin-bottom: .6rem; }
.faq-question i{ color: var(--accent-color); font-size: 1.2rem; flex-shrink:0; }
.faq-question h3{ font-size: 1.08rem; font-weight: 900; color: var(--text-100); margin: 0; }
.faq-item p{ color: var(--text-300); line-height: 1.6; margin: 0; }

/* Validation */
.form-control:invalid:not(:focus):not(:placeholder-shown){
  border-color: #ef4444; box-shadow: 0 0 0 3px rgba(239,68,68,.18);
}
.form-control:valid:not(:focus):not(:placeholder-shown){
  border-color: #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,.16);
}

/* Utilities */
@keyframes fadeInUp{
  from{ opacity:0; transform: translateY(24px); }
  to{ opacity:1; transform: translateY(0); }
}
.pricing-card, .step-item, .content-card, .playlist-card{ animation: fadeInUp .6s ease forwards; }

/* =========================
   Installation Page (Dark)
   ========================= */
.installation-page{ position:relative; padding-top:120px; background: var(--bg-900); min-height: 100vh; color: var(--text-100); }
.installation-header{
  text-align:center; margin-bottom: 3rem; padding: 2.4rem 1.8rem; background: var(--gradient);
  color:#fff; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); position: relative; overflow:hidden;
}
.installation-header::before{ content:''; position:absolute; inset:0; background: radial-gradient(circle at 30% 20%, rgba(255,215,0,.12) 0%, transparent 55%); }

.section-header{ text-align:center; margin-bottom: 2.2rem; }
.section-header h2{
  font-size: 2rem; font-weight: 900; color: var(--text-100); margin-bottom: .5rem; display:flex; align-items:center; justify-content:center; gap:.8rem;
}
.section-header h2 i{ color: var(--secondary-color); }
.section-header p{ color: var(--text-300); font-size: 1.02rem; }

.device-selector{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: 1rem; max-width: 1000px; margin: 0 auto 2rem; padding: 0 1rem;
}
.device-tab{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius);
  padding: 1.2rem .9rem; cursor: pointer; transition: var(--transition); display:flex; flex-direction:column; align-items:center; gap:.7rem; text-align:center; font-weight: 800; color: var(--text-200); box-shadow: var(--shadow);
}
.device-tab:hover, .device-tab.active{ border-color: rgba(0,36,125,.66); transform: translateY(-3px); box-shadow: var(--shadow-lg); color: var(--text-100); }
.device-tab.active{ background: var(--gradient-soft); color: #fff; }
.device-tab i{ font-size: 1.7rem; }
.device-tab span{ font-size: .9rem; line-height: 1.2; }

.installation-content{ margin-bottom: 3rem; }
.device-guide{
  display:none; background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius); padding: 2rem; box-shadow: var(--shadow);
}
.device-guide.active{ display: block; }
.guide-header{ display:flex; align-items:center; gap: 1.4rem; margin-bottom: 2rem; padding-bottom: 1.4rem; border-bottom: 1px solid var(--border-color); }
.device-icon{
  width: 74px; height: 74px; background: var(--gradient); border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 2.1rem; color:#fff;
}
.device-info h3{ font-size: 1.45rem; font-weight: 900; color: var(--text-100); margin-bottom: .35rem; }
.device-info p{ color: var(--text-300); font-size: 1.02rem; }

.installation-steps{ display:flex; flex-direction:column; gap: 1.4rem; }
.step-visual{ display:flex; align-items:center; gap: .8rem; padding: .8rem; background: var(--bg-850); border-radius: 12px; border: 1px solid var(--border-color); }
.step-visual i{ color: var(--accent-color); font-size: 1.2rem; }
.step-visual span{ font-weight: 800; color: var(--text-100); }

.video-wrapper{ position: relative; padding-bottom: 56.25%; height:0; overflow:hidden; border-radius: var(--border-radius); box-shadow: var(--shadow); }
.video-wrapper iframe{ position:absolute; inset:0; width:100%; height:100%; border-radius: var(--border-radius); }

.code-highlight{ display:flex; align-items:center; gap: .8rem; margin: .7rem 0; }
.code{
  background: #0b1220; color: var(--accent-color); padding: .85rem 1.1rem; border-radius: 12px; font-family: 'Monaco','Consolas',monospace; font-size: 1.2rem; font-weight: 800; letter-spacing: 1.25px; border:1px solid rgba(255,215,0,.25);
}
.copy-btn{ background: var(--primary-color); color:#fff; border:none; width: 40px; height: 40px; border-radius: 50%; cursor:pointer; transition: var(--transition); display:flex; align-items:center; justify-content:center; }
.copy-btn:hover{ background: var(--secondary-color); transform: scale(1.06); }

.activation-card{
  background: var(--bg-800); border: 1px solid var(--border-color); border-radius: var(--border-radius); padding: 2.2rem; box-shadow: var(--shadow); text-align:center;
}
.activation-header h3{ font-size: 1.6rem; font-weight: 900; color: var(--text-100); margin-bottom: .6rem; display:flex; align-items:center; justify-content:center; gap: .7rem; }
.activation-header h3 i{ color: var(--accent-color); }
.activation-header p{ color: var(--text-300); font-size: 1.02rem; margin-bottom: 1.4rem; }

/* Support */
.support-section{ margin: 3rem 0 1.6rem; }
.support-card{
  background: var(--gradient); border-radius: var(--border-radius); padding: 2.2rem; text-align:center; color:#fff; position:relative; overflow:hidden;
}
.support-card::before{ content:''; position:absolute; inset:0; background: radial-gradient(circle at 30% 20%, rgba(255,215,0,.12) 0%, transparent 55%); }
.support-icon{
  width: 74px; height: 74px; background: rgba(255,255,255,.22); border-radius: 50%; display:flex; align-items:center; justify-content:center; font-size: 2rem; color: var(--accent-color); margin: 0 auto 1.4rem; backdrop-filter: blur(10px);
}
.support-content h3{ font-size: 1.6rem; font-weight: 900; margin-bottom: .6rem; }
.support-content p{ font-size: 1.02rem; margin-bottom: 1.4rem; opacity: .98; }
.support-actions{ display:flex; gap: .8rem; justify-content:center; flex-wrap: wrap; }
.support-btn{
  background:#fff; color: var(--primary-color); padding: .95rem 1.6rem; border-radius: 999px; font-weight: 900; transition: var(--transition);
  display:flex; align-items:center; gap:.7rem; box-shadow: 0 10px 22px rgba(255,255,255,.25);
}
.support-btn:hover{ transform: translateY(-2px); box-shadow: 0 14px 34px rgba(255,255,255,.3); }
.support-btn.whatsapp{ background:#25d366; color:#fff; }
.support-btn.whatsapp:hover{ background:#128c7e; color:#fff; }

/* =========================
   Login (Dark)
   ========================= */
.login-container{
  display:flex; justify-content:center; align-items:center; height: 100vh;
  background: radial-gradient(900px 600px at 15% 20%, rgba(0,36,125,.16) 0%, transparent 60%),
              radial-gradient(900px 600px at 100% 80%, rgba(207,20,43,.12) 0%, transparent 60%),
              var(--bg-900);
}
.login-form{
  background: var(--bg-800); border: 1px solid var(--border-color); padding: 2rem; border-radius: var(--border-radius);
  box-shadow: var(--shadow); width: 340px; color: var(--text-100);
}
.login-form h2{ text-align: center; margin-bottom: 1.2rem; font-weight: 900; }
.error-box{
  background: rgba(239,68,68,.14); border: 1px solid rgba(239,68,68,.35); color: #fecaca; padding: .75rem; border-radius: 8px; margin-bottom: 1rem; text-align: center;
}
.login-form .form-group{ margin-bottom: 1rem; }
.login-form label{ display:block; margin-bottom: .45rem; font-weight: 800; color: var(--text-200); }
.login-form input{
  width: 100%; padding: .85rem; border: 1px solid var(--border-color); border-radius: 12px; font-size: 1rem; background: var(--bg-850); color: var(--text-100);
}
.login-form input:focus{ outline:none; border-color: rgba(0,36,125,.65); box-shadow: var(--focus-ring); background: var(--bg-750); }
.login-btn{
  width: 100%; padding: .9rem; background: var(--gradient); color:#fff; border:none; border-radius: 12px; font-weight: 900; cursor: pointer; transition: var(--transition); margin-top: .5rem;
}
.login-btn:hover{ opacity: .95; transform: translateY(-1px); box-shadow: var(--glow-blue); }

/* =========================
   Responsive Tweaks
   ========================= */
@media (max-width: 992px){
  .checkout-grid{ grid-template-columns: 1fr; gap: 1.6rem; }
  .customer-form-section{ order: 1; }
  .order-summary-section{ order: 2; position: static; }
  .main-title{ font-size: 2.2rem; }
}

@media (max-width: 768px){
  .hero h1{ font-size: 2.5rem; }
  .hero-subtitle{ font-size: 1.02rem; }
  section{ padding: 60px 0; }
  .pricing-grid, .content-grid, .playlist-grid, .steps-grid, .features-showcase{ grid-template-columns: 1fr; }
  .pricing-card.featured{ transform: none; }
  .devices-carousel{ flex-wrap: wrap; justify-content:center; }
  .whatsapp-carousel{ justify-content:flex-start; }
  .vod-showcase{ grid-template-columns: 1fr; gap: 1.2rem; }
  .vod-item img{ height: 220px; }
  .professional-checkout{ padding: 80px 0; }
  .form-card, .summary-card{ padding: 1.6rem; }
  .card-header{ flex-direction: column; text-align: center; gap: .5rem; }
  .form-input, .form-textarea, .iti input[type=tel]{ padding: .9rem 1rem; font-size: .96rem; }
  .channels-library .content-tabs{ grid-template-columns: 1fr; }
  .contact-content{ grid-template-columns: 1fr; gap: 1.6rem; }
  .form-row{ grid-template-columns: 1fr; }
  .device-selector{ grid-template-columns: repeat(2,1fr); }
  .cta-content{ grid-template-columns: 1fr; text-align:center; gap: 1rem; }
}

@media (max-width: 480px){
  .container{ padding: 0 15px; }
  .hero{ padding: 80px 0 60px; }
  .hero h1{ font-size: 2rem; }
  .btn{ padding: .85rem 1.4rem; }
  .btn-lg{ padding: 1rem 1.9rem; }
  .navbar-brand{ font-size: 1.4rem !important; }
  .vod-item img{ height: 200px; }
  .vod-item{ padding: 1rem; }
  .main-title{ font-size: 1.9rem; }
  .form-card, .summary-card{ padding: 1.4rem 1rem; }
  .submit-button{ font-size: .98rem; padding: 1rem 1.1rem; }
  .channels-library .header-content h1{ font-size: 1.6rem; }
  .channels-library .section-header h2{ font-size: 1.6rem; }
  .country-flag{ font-size: 2.2rem; }
}

/* =========================
   Motion Preferences
   ========================= */
@media (prefers-reduced-motion: no-preference){
  *{ scroll-behavior: smooth; }
}

/* =========================
   Icons & Helpers
   ========================= */
.fa-spin{ animation: spin 1s linear infinite; }
@keyframes spin{ 0%{ transform: rotate(0deg);} 100%{ transform: rotate(360deg);} }
