/* Castora — IPTV France | Design DNA cloned from ultratv.fr */
:root{
  --bg:#0a0d14;
  --bg-2:#0e1320;
  --surface:#191c26;
  --surface-2:#1f2433;
  --border:#2a2f3d;
  --text:#ffffff;
  --muted:#c8cdd8;
  --muted-2:#9aa1b1;
  --primary:#1863dc;
  --primary-hover:#1556bf;
  --primary-soft:rgba(24,99,220,.12);
  --accent:#ff6900;
  --accent-hover:#e65d00;
  --success:#22c55e;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:12px;
  --radius-sm:8px;
  --container:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter','Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--primary);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent)}
h1,h2,h3,h4{font-family:'Poppins','Inter',sans-serif;font-weight:700;line-height:1.25;color:#fff;letter-spacing:-.01em}
h1{font-size:clamp(2rem,5vw,3.5rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem);margin-bottom:.6rem}
h3{font-size:1.25rem;margin-bottom:.4rem}
p{color:var(--muted);margin-bottom:1rem}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* Header / Nav */
.site-header{position:sticky;top:0;z-index:100;background:rgba(10,13,20,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;max-width:var(--container);margin:0 auto;gap:24px}
.logo{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.6rem;color:#fff;letter-spacing:-.02em;display:flex;align-items:center}
.logo span{color:var(--primary)}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{color:var(--muted);font-weight:500;padding:8px 12px;border-radius:6px;font-size:.95rem;transition:all .2s}
.nav-links a:hover{color:#fff;background:var(--surface)}
.nav-cta{background:var(--accent);color:#fff!important;padding:10px 20px!important;border-radius:30px;font-weight:600}
.nav-cta:hover{background:var(--accent-hover);color:#fff!important}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:1.4rem;cursor:pointer}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 28px;border-radius:30px;font-weight:600;font-size:1rem;cursor:pointer;border:none;transition:all .25s;text-decoration:none;min-height:48px;gap:8px}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 20px rgba(24,99,220,.35)}
.btn-primary:hover{background:var(--primary-hover);color:#fff;transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 6px 20px rgba(255,105,0,.35)}
.btn-accent:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px)}
.btn-outline{background:transparent;color:#fff;border:2px solid var(--border)}
.btn-outline:hover{background:var(--surface);border-color:var(--primary);color:#fff}
.btn-lg{padding:16px 36px;font-size:1.1rem}

/* Hero */
.hero{position:relative;padding:80px 0 60px;overflow:hidden;background:radial-gradient(1100px 600px at 15% -10%, rgba(24,99,220,.18), transparent 60%),radial-gradient(900px 500px at 110% 30%, rgba(255,105,0,.10), transparent 60%)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--primary-soft);color:#7fb3ff;padding:6px 14px;border-radius:30px;font-weight:600;font-size:.85rem;margin-bottom:18px;border:1px solid rgba(24,99,220,.3)}
.hero h1{margin-bottom:18px}
.hero h1 .accent{color:var(--primary)}
.hero p.lead{font-size:1.15rem;color:var(--muted);max-width:560px;margin-bottom:28px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:26px}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap;color:var(--muted-2);font-size:.9rem}
.hero-trust span::before{content:"✓ ";color:var(--success);font-weight:700}
.hero-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.hero-form h3{margin-bottom:6px;color:#fff}
.hero-form .small{color:var(--muted-2);font-size:.88rem;margin-bottom:18px}

/* Forms */
.form-group{margin-bottom:14px}
.form-group label{display:block;color:var(--muted);font-weight:500;font-size:.9rem;margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border-radius:8px;background:var(--bg-2);border:1px solid var(--border);color:#fff;font-size:1rem;font-family:inherit;min-height:48px;transition:border-color .2s, box-shadow .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(24,99,220,.15)}
.form-group textarea{min-height:120px;resize:vertical}
.honeypot{position:absolute!important;left:-10000px!important;opacity:0;pointer-events:none}
.form-message{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:.9rem}
.form-message--success{background:rgba(34,197,94,.12);color:#86efac;border:1px solid rgba(34,197,94,.4)}
.form-message--error{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.4)}
.trust-row{display:flex;gap:14px;align-items:center;justify-content:center;color:var(--muted-2);font-size:.82rem;margin-top:12px}
.trust-row span::before{content:"🔒 ";margin-right:2px}

/* Sections */
.section{padding:72px 0}
.section-title{text-align:center;margin-bottom:46px}
.section-title h2{margin-bottom:10px}
.section-title p{color:var(--muted);max-width:680px;margin:0 auto}
.eyebrow{display:inline-block;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;margin-bottom:8px}

/* Feature highlight strip */
.highlight-strip{padding:50px 0;background:linear-gradient(180deg,#0e1320,#0a0d14);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.highlight-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.highlight-item{padding:20px}
.highlight-item .icon{font-size:2rem;margin-bottom:10px}
.highlight-item h4{color:#fff;margin-bottom:4px}
.highlight-item p{font-size:.9rem;color:var(--muted-2);margin:0}

/* Stats */
.stats{padding:60px 0;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-num{font-size:2.4rem;font-weight:800;color:var(--primary);font-family:'Poppins'}
.stat-label{color:var(--muted);font-size:.95rem;margin-top:4px}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.plan{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;display:flex;flex-direction:column;position:relative;transition:transform .3s, border-color .3s, box-shadow .3s}
.plan:hover{transform:translateY(-6px);border-color:var(--primary);box-shadow:0 16px 40px rgba(24,99,220,.18)}
.plan.featured{border-color:var(--primary);background:linear-gradient(180deg,#1a2238,#161a26)}
.plan-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:4px 14px;border-radius:30px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.plan h3{font-size:1.35rem;margin-bottom:10px;color:#fff}
.plan .price{display:flex;align-items:baseline;gap:6px;margin:10px 0 6px}
.plan .price .amount{font-size:2.6rem;font-weight:800;color:#fff;font-family:'Poppins'}
.plan .price .cur{font-size:1.4rem;color:var(--muted);font-weight:700}
.plan .per{color:var(--muted-2);font-size:.9rem;margin-bottom:18px}
.plan ul{list-style:none;padding:0;margin:0 0 22px;flex:1}
.plan ul li{position:relative;padding:7px 0 7px 26px;color:var(--muted);font-size:.95rem;border-bottom:1px dashed rgba(255,255,255,.06)}
.plan ul li:last-child{border-bottom:none}
.plan ul li::before{content:"✓";position:absolute;left:0;top:7px;color:var(--primary);font-weight:800}
.plan .btn{width:100%}

/* Feature cards */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cards-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;transition:border-color .3s, transform .3s}
.card:hover{border-color:var(--primary);transform:translateY(-3px)}
.card .icon{width:54px;height:54px;border-radius:12px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.6rem;margin-bottom:18px}
.card h3{margin-bottom:8px}
.card p{font-size:.95rem;margin:0}

/* Sports / Channels strip */
.brands-strip{display:grid;grid-template-columns:repeat(8,1fr);gap:18px;align-items:center}
.brands-strip img{filter:grayscale(50%) brightness(.95);opacity:.85;height:38px;width:auto;margin:0 auto;transition:all .2s}
.brands-strip img:hover{filter:none;opacity:1}

/* VOD posters */
.posters-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.poster{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:2/3;background:var(--surface)}
.poster img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.poster:hover img{transform:scale(1.06)}
.poster::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.7));pointer-events:none}

/* FAQ */
.faq-list{max-width:850px;margin:0 auto}
.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:12px;overflow:hidden}
.faq-question{width:100%;padding:18px 22px;background:none;border:none;color:#fff;font-size:1.02rem;font-weight:600;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;font-family:inherit}
.faq-question::after{content:"+";font-size:1.6rem;font-weight:300;color:var(--primary);transition:transform .25s}
.faq-item.active .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-answer-inner{padding:0 22px 20px;color:var(--muted)}

/* Testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px}
.testi .stars{color:#ffb800;margin-bottom:10px}
.testi p{font-style:italic;margin-bottom:14px}
.testi .who{display:flex;align-items:center;gap:12px}
.testi .avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.testi .who strong{color:#fff;display:block}
.testi .who span{color:var(--muted-2);font-size:.82rem}

/* Channels page */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;text-align:center;transition:all .2s}
.cat:hover{border-color:var(--primary);background:var(--surface-2)}
.cat .ico{font-size:2.2rem;margin-bottom:8px}
.cat h4{margin-bottom:4px}
.cat .num{color:var(--primary);font-weight:700;font-size:1.6rem;font-family:'Poppins'}
.flag-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.flag-pill{background:var(--surface);border:1px solid var(--border);border-radius:30px;padding:10px 16px;text-align:center;font-size:.92rem;color:var(--muted)}

/* CTA banner */
.cta-banner{background:linear-gradient(135deg,#1a2342 0%,#0e1320 100%);border:1px solid var(--border);border-radius:var(--radius);padding:48px;text-align:center;margin-top:36px}
.cta-banner h2{margin-bottom:14px}
.cta-banner p{max-width:600px;margin:0 auto 22px}

/* Setup guide */
.guide-steps{display:grid;grid-template-columns:1fr;gap:22px;max-width:900px;margin:0 auto}
.guide-step{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;display:grid;grid-template-columns:60px 1fr;gap:20px;align-items:start}
.guide-step .num{width:48px;height:48px;border-radius:12px;background:var(--primary);color:#fff;font-weight:800;font-size:1.4rem;display:flex;align-items:center;justify-content:center;font-family:'Poppins'}
.guide-step h3{margin-bottom:6px}
.device-tabs{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.device-tab{padding:10px 18px;background:var(--surface);border:1px solid var(--border);border-radius:30px;color:var(--muted);font-weight:500}

/* Legal pages */
.legal{padding:80px 0;max-width:880px;margin:0 auto}
.legal h2{font-size:1.5rem;margin:32px 0 12px;color:#fff}
.legal h3{font-size:1.15rem;margin:24px 0 8px}
.legal p,.legal li{color:var(--muted);margin-bottom:12px}
.legal ul{padding-left:22px;margin-bottom:14px}
.legal a{color:var(--primary)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:36px}
.contact-info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:26px;margin-bottom:14px}
.contact-info-card .ico{width:42px;height:42px;border-radius:10px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:10px}
.contact-info-card h4{margin-bottom:4px}
.contact-info-card a{color:var(--muted)}
.contact-info-card a:hover{color:var(--primary)}

/* Checkout */
.checkout-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.checkout-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:sticky;top:100px;align-self:start}
.summary-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border);color:var(--muted)}
.summary-row.total{font-size:1.2rem;font-weight:700;color:#fff;border:none;padding-top:14px}

/* Footer */
.site-footer{background:var(--bg-2);border-top:1px solid var(--border);padding:60px 0 20px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:34px}
.footer-grid h4{color:#fff;margin-bottom:14px;font-size:1.02rem}
.footer-grid ul{list-style:none;padding:0}
.footer-grid ul li{margin-bottom:8px}
.footer-grid ul li a{color:var(--muted);font-size:.92rem}
.footer-grid ul li a:hover{color:var(--primary)}
.footer-brand p{font-size:.92rem;margin-bottom:14px}
.footer-bottom{border-top:1px solid var(--border);padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;color:var(--muted-2);font-size:.85rem}

/* Breadcrumbs */
.breadcrumbs{padding:16px 0;font-size:.88rem;color:var(--muted-2);border-bottom:1px solid var(--border)}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--primary)}

/* Responsive */
@media (max-width:1024px){
  .hero-grid,.contact-grid,.checkout-grid{grid-template-columns:1fr}
  .pricing-grid,.cards-grid-4,.stats-grid,.highlight-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid,.testi-grid{grid-template-columns:repeat(2,1fr)}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .posters-grid{grid-template-columns:repeat(4,1fr)}
  .brands-strip{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .nav-toggle{display:block}
  .nav-links{position:absolute;top:100%;left:0;right:0;background:var(--surface);flex-direction:column;align-items:stretch;padding:14px;border-bottom:1px solid var(--border);display:none}
  .nav-links.open{display:flex}
  .nav-links a{padding:11px 14px}
  .pricing-grid,.cards-grid,.cards-grid-4,.testi-grid,.stats-grid,.highlight-grid,.cat-grid{grid-template-columns:1fr}
  .posters-grid{grid-template-columns:repeat(2,1fr)}
  .brands-strip{grid-template-columns:repeat(3,1fr)}
  .flag-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .guide-step{grid-template-columns:1fr}
  .section{padding:54px 0}
  .hero{padding:50px 0}
}
