/*
Theme Name: Officiel IPTV Smarters Pro
Theme URI: https://officieliptvsmarterspro.io
Author: Officiel IPTV Smarters Pro
Author URI: https://officieliptvsmarterspro.io
Description: Thème IPTV moderne et coloré (français) — accueil, tarifs, chaînes, appareils, blog, commande et contact. Pages et menu créés automatiquement à l'activation.
Version: 1.1.0
Requires at least: 5.9
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: iptv-smarters-pro
*/

/* ============================================================
   OFFICIEL IPTV SMARTERS PRO — Design system
   Moderne · coloré · énergique  ·  base sombre premium
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  /* surfaces */
  --bg:        #07070c;
  --bg-2:      #0c0c14;
  --surface:   #13131f;
  --surface-2: #1a1a29;
  --border:    rgba(255,255,255,.08);
  --border-2:  rgba(255,255,255,.14);

  /* text */
  --text:  #f5f5fa;
  --muted: #9a9ab0;
  --dim:   #6c6c82;

  /* accents */
  --rose:        #e11d48;
  --rose-bright: #fb2e63;
  --violet:      #8b3dff;
  --cyan:        #19d3e0;
  --amber:       #ffb020;
  --grad:        linear-gradient(120deg, #fb2e63 0%, #8b3dff 100%);
  --grad-soft:   linear-gradient(120deg, rgba(251,46,99,.16), rgba(139,61,255,.16));
  --grad-text:   linear-gradient(100deg, #ff5b7f 0%, #b06bff 60%, #19d3e0 120%);

  /* shape */
  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --maxw: 1200px;

  --shadow:     0 24px 60px -20px rgba(0,0,0,.7);
  --glow-rose:  0 18px 50px -12px rgba(225,29,72,.55);
  --glow-violet:0 18px 50px -12px rgba(139,61,255,.5);

  color-scheme: dark;
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; }
*::selection{ background:var(--rose); color:#fff; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:17px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
h1,h2,h3,h4{ font-family:'Space Grotesk',sans-serif; font-weight:700; line-height:1.08; margin:0; letter-spacing:-.02em; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }
.section{ padding-block:clamp(64px,9vw,120px); position:relative; }
.center{ text-align:center; }
.grad-text{ background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:'Space Grotesk',sans-serif; font-weight:600;
  font-size:13px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--rose-bright);
  padding:7px 15px; border-radius:99px;
  background:rgba(251,46,99,.1); border:1px solid rgba(251,46,99,.24);
}
.eyebrow::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--rose-bright); box-shadow:0 0 10px var(--rose-bright); }
.section-head{ max-width:660px; margin-inline:auto; margin-bottom:56px; }
.section-head.left{ margin-inline:0; }
h2.title{ font-size:clamp(30px,4.4vw,52px); margin-top:18px; }
h2.title + .sub{ margin-top:18px; color:var(--muted); font-size:clamp(16px,2vw,19px); }
.lead{ color:var(--muted); font-size:clamp(16px,2vw,19px); }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:'Space Grotesk',sans-serif; font-weight:600; font-size:16px;
  padding:14px 26px; border-radius:99px; white-space:nowrap;
  transition:transform .2s cubic-bezier(.2,.8,.2,1), box-shadow .25s, background .25s, border-color .25s;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--grad); color:#fff; box-shadow:var(--glow-rose); }
.btn-primary:hover{ transform:translateY(-3px); box-shadow:0 24px 60px -12px rgba(225,29,72,.7); }
.btn-ghost{ background:rgba(255,255,255,.05); color:var(--text); border:1px solid var(--border-2); }
.btn-ghost:hover{ background:rgba(255,255,255,.1); transform:translateY(-3px); }
.btn-lg{ padding:17px 34px; font-size:17px; }
.btn-block{ width:100%; }

/* ---------- generic card ---------- */
.card{
  background:linear-gradient(180deg, var(--surface), var(--bg-2));
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:32px;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.card:hover{ transform:translateY(-5px); border-color:var(--border-2); box-shadow:var(--shadow); }

/* ============================================================
   HEADER  (injecté par site.js)
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:80;
  backdrop-filter:blur(18px);
  background:rgba(7,7,12,.72);
  border-bottom:1px solid var(--border);
  transition:background .3s, border-color .3s;
}
.site-header.scrolled{ background:rgba(7,7,12,.92); }
.nav{ display:flex; align-items:center; gap:18px; height:72px; }
.brand{ display:flex; align-items:center; gap:11px; font-family:'Space Grotesk',sans-serif; font-weight:700; font-size:19px; letter-spacing:-.02em; white-space:nowrap; }
.brand > span{ line-height:1.05; }
.brand .logo-mark{
  width:38px; height:38px; border-radius:11px; flex:none;
  display:grid; place-items:center;
  background:var(--grad); box-shadow:var(--glow-rose);
}
.brand .logo-mark svg{ width:18px; height:18px; }
.brand small{ display:block; font-family:'Manrope'; font-weight:600; font-size:10px; letter-spacing:.22em; color:var(--rose-bright); text-transform:uppercase; margin-top:1px; }
.nav-links{ display:flex; align-items:center; gap:5px; margin-left:8px; }
.nav-links a{
  font-size:15px; font-weight:600; color:var(--muted); white-space:nowrap;
  padding:9px 13px; border-radius:99px; transition:color .2s, background .2s;
}
.nav-links a:hover{ color:var(--text); background:rgba(255,255,255,.05); }
.nav-links a.active{ color:var(--text); }
.nav-cta{ margin-left:auto; display:flex; align-items:center; gap:12px; }
.nav-cta .btn{ padding:11px 22px; font-size:15px; }
.menu-toggle{ display:none; width:44px; height:44px; border-radius:12px; border:1px solid var(--border-2); align-items:center; justify-content:center; }
.menu-toggle svg{ width:22px; height:22px; }

/* mobile drawer */
.mobile-menu{
  position:fixed; inset:0; z-index:90; display:none;
  background:rgba(5,5,9,.96); backdrop-filter:blur(10px);
  padding:24px; flex-direction:column;
}
.mobile-menu.open{ display:flex; }
.mobile-menu .mm-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:30px; }
.mobile-menu a{ font-family:'Space Grotesk',sans-serif; font-weight:600; font-size:24px; padding:16px 0; border-bottom:1px solid var(--border); }
.mobile-menu .btn{ margin-top:24px; }

/* ============================================================
   FOOTER (injecté par site.js)
   ============================================================ */
.site-footer{ border-top:1px solid var(--border); background:var(--bg-2); padding-block:64px 32px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer-grid h4{ font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:var(--dim); margin-bottom:18px; font-family:'Manrope'; font-weight:700; }
.footer-grid a{ display:block; color:var(--muted); padding:6px 0; font-size:15px; transition:color .2s; }
.footer-grid a:hover{ color:var(--rose-bright); }
.footer-about p{ color:var(--muted); font-size:15px; margin-top:16px; max-width:320px; }
.footer-bottom{ display:flex; flex-wrap:wrap; gap:16px; justify-content:space-between; align-items:center; margin-top:48px; padding-top:24px; border-top:1px solid var(--border); color:var(--dim); font-size:14px; }
.pay-badges{ display:flex; gap:8px; flex-wrap:wrap; }
.pay-badge{ font-size:11px; font-weight:700; letter-spacing:.04em; color:var(--muted); padding:6px 11px; border:1px solid var(--border-2); border-radius:8px; background:var(--surface); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:clamp(60px,9vw,110px); padding-bottom:clamp(60px,9vw,110px); overflow:hidden; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero h1{ font-size:clamp(40px,6.4vw,74px); line-height:1.02; }
.hero .lead{ margin-top:24px; max-width:520px; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
.hero-trust{ display:flex; align-items:center; gap:22px; margin-top:34px; flex-wrap:wrap; }
.stars{ color:var(--amber); letter-spacing:2px; font-size:18px; }
.hero-trust .t-meta{ font-size:14px; color:var(--muted); }
.hero-trust .t-meta b{ color:var(--text); }

/* glowing backdrop blobs */
.blob{ position:absolute; border-radius:50%; filter:blur(90px); opacity:.5; z-index:-1; pointer-events:none; }
.blob.rose{ width:520px; height:520px; background:var(--rose); top:-180px; right:-120px; }
.blob.violet{ width:460px; height:460px; background:var(--violet); bottom:-200px; left:-150px; opacity:.4; }

/* hero visual : screen mockup */
.hero-visual{ position:relative; }
.screen{
  position:relative; border-radius:var(--r-lg);
  border:1px solid var(--border-2);
  background:linear-gradient(160deg, #161622, #0a0a12);
  box-shadow:var(--shadow);
  overflow:hidden; aspect-ratio:16/10;
}
.screen .screen-top{ display:flex; align-items:center; gap:7px; padding:14px 18px; border-bottom:1px solid var(--border); }
.screen .dot{ width:11px; height:11px; border-radius:50%; background:#2a2a3a; }
.screen .dot.r{ background:#ff5f57; } .screen .dot.y{ background:#febc2e; } .screen .dot.g{ background:#28c840; }
.screen-body{ padding:18px; display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.poster{ aspect-ratio:2/3; border-radius:12px; position:relative; overflow:hidden; }
.floating-badge{
  position:absolute; z-index:3; background:var(--surface); border:1px solid var(--border-2);
  border-radius:16px; padding:14px 18px; box-shadow:var(--shadow); display:flex; align-items:center; gap:12px;
}
.floating-badge .fb-icon{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; background:var(--grad-soft); }
.floating-badge .fb-icon svg{ width:20px; height:20px; color:var(--rose-bright); }
.floating-badge b{ font-family:'Space Grotesk'; font-size:16px; display:block; }
.floating-badge span{ font-size:12px; color:var(--muted); }
.fb-1{ top:24px; left:-28px; }
.fb-2{ bottom:30px; right:-26px; }

/* ============================================================
   PLACEHOLDER (striped) — pour visuels à fournir
   ============================================================ */
.ph{
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 10px, transparent 10px 20px),
    linear-gradient(160deg, var(--surface-2), var(--bg-2));
  display:grid; place-items:center; color:var(--dim);
  font-family:'Space Grotesk',monospace; font-size:12px; letter-spacing:.08em; text-transform:uppercase;
  text-align:center; padding:10px;
}

/* ============================================================
   LOGO WALL / channels
   ============================================================ */
.logo-wall{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; }
.logo-tile{
  aspect-ratio:16/10; border-radius:14px; border:1px solid var(--border);
  background:var(--surface); display:grid; place-items:center; position:relative; overflow:hidden;
  transition:transform .2s, border-color .2s;
}
.logo-tile:hover{ transform:translateY(-4px) scale(1.02); border-color:var(--border-2); }
.logo-tile .lt-name{ font-family:'Space Grotesk'; font-weight:700; font-size:15px; color:var(--text); opacity:.9; }
.logo-tile .lt-cat{ position:absolute; bottom:8px; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--dim); }
.logo-tile::after{ content:""; position:absolute; inset:0; background:var(--grad-soft); opacity:0; transition:opacity .25s; }
.logo-tile:hover::after{ opacity:1; }

/* marquee */
.marquee{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track{ display:flex; gap:14px; width:max-content; animation:scrollx 38s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee .logo-tile{ width:150px; }
@keyframes scrollx{ to{ transform:translateX(-50%); } }

/* ============================================================
   FEATURES
   ============================================================ */
.feature-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.feature{ position:relative; }
.feature .f-icon{
  width:54px; height:54px; border-radius:15px; display:grid; place-items:center;
  background:var(--grad-soft); border:1px solid var(--border-2); margin-bottom:20px;
}
.feature .f-icon svg{ width:25px; height:25px; color:var(--rose-bright); }
.feature h3{ font-size:21px; margin-bottom:10px; }
.feature p{ color:var(--muted); font-size:15.5px; }

/* stat strip */
.stat-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.stat{ text-align:center; padding:26px 18px; }
.stat .num{ font-family:'Space Grotesk'; font-weight:700; font-size:clamp(34px,4.4vw,52px); line-height:1; }
.stat .lbl{ color:var(--muted); margin-top:10px; font-size:14.5px; }

/* ============================================================
   PRICING
   ============================================================ */
.conn-switch{ display:inline-flex; gap:4px; padding:5px; background:var(--surface); border:1px solid var(--border); border-radius:99px; margin-top:26px; }
.conn-switch button{ padding:10px 20px; border-radius:99px; font-weight:600; font-size:14.5px; color:var(--muted); transition:.2s; font-family:'Space Grotesk'; }
.conn-switch button.active{ background:var(--grad); color:#fff; box-shadow:var(--glow-rose); }

.price-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; align-items:stretch; }
.price-card{
  position:relative; display:flex; flex-direction:column;
  background:linear-gradient(180deg,var(--surface),var(--bg-2));
  border:1px solid var(--border); border-radius:var(--r-lg); padding:30px 26px;
  transition:transform .25s, border-color .25s, box-shadow .25s;
}
.price-card:hover{ transform:translateY(-6px); border-color:var(--border-2); box-shadow:var(--shadow); }
.price-card.featured{ border-color:transparent; background:linear-gradient(180deg, rgba(251,46,99,.1), var(--bg-2)); box-shadow:var(--glow-rose); }
.price-card.featured::before{ content:""; position:absolute; inset:0; border-radius:var(--r-lg); padding:1px; background:var(--grad); -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0); -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none; }
.price-tag{ position:absolute; z-index:2; top:-13px; left:50%; transform:translateX(-50%); background:var(--grad); color:#fff; font-family:'Space Grotesk'; font-weight:600; font-size:12px; letter-spacing:.08em; text-transform:uppercase; padding:6px 16px; border-radius:99px; white-space:nowrap; box-shadow:var(--glow-rose); }
.pp-media{ aspect-ratio:16/10; overflow:hidden; margin:-8px -4px 24px; border:1px solid var(--border); border-radius:18px; background:var(--surface-2); }
.pp-media img{ width:100%; height:100%; object-fit:cover; transition:transform .35s ease; }
.price-card:hover .pp-media img{ transform:scale(1.04); }
.price-card .pp-name{ font-family:'Space Grotesk'; font-weight:600; font-size:15px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); }
.price-card .pp-price{ display:flex; align-items:baseline; gap:4px; margin-top:14px; }
.price-card .pp-price .amt{ font-family:'Space Grotesk'; font-weight:700; font-size:54px; line-height:1; }
.price-card .pp-price .cur{ font-family:'Space Grotesk'; font-weight:700; font-size:24px; }
.price-card .pp-per{ color:var(--muted); font-size:14px; margin-top:6px; }
.price-card .pp-eq{ color:var(--rose-bright); font-size:13px; font-weight:600; margin-top:4px; }
.price-card ul{ margin:24px 0; display:flex; flex-direction:column; gap:12px; }
.price-card li{ display:flex; gap:11px; align-items:flex-start; font-size:14.5px; color:var(--text); }
.price-card li svg{ width:18px; height:18px; color:var(--rose-bright); flex:none; margin-top:2px; }
.price-card .btn{ margin-top:auto; }
.price-card del{ color:var(--dim); font-size:15px; }

/* ============================================================
   STEPS  (comment ça marche)
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; counter-reset:step; }
.step{ position:relative; padding-top:8px; }
.step .s-num{ font-family:'Space Grotesk'; font-weight:700; font-size:15px; width:46px; height:46px; border-radius:13px; display:grid; place-items:center; background:var(--grad); color:#fff; box-shadow:var(--glow-rose); margin-bottom:20px; }
.step h3{ font-size:21px; margin-bottom:10px; }
.step p{ color:var(--muted); font-size:15.5px; }
.step-line{ position:absolute; top:23px; left:46px; right:-24px; height:2px; background:linear-gradient(90deg,var(--rose),transparent); opacity:.4; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-grid{ columns:3; column-gap:22px; }
.testi{ break-inside:avoid; margin-bottom:22px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:26px; }
.testi .t-stars{ color:var(--amber); letter-spacing:2px; font-size:15px; }
.testi p{ margin:14px 0 18px; font-size:15.5px; line-height:1.65; }
.testi .t-author{ display:flex; align-items:center; gap:12px; }
.testi .t-ava{ width:42px; height:42px; border-radius:50%; background:var(--grad); display:grid; place-items:center; font-family:'Space Grotesk'; font-weight:700; color:#fff; font-size:16px; flex:none; }
.testi .t-author b{ display:block; font-size:14.5px; }
.testi .t-author span{ font-size:12.5px; color:var(--muted); }

/* ============================================================
   DEVICES
   ============================================================ */
.device-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.device{ text-align:center; padding:30px 18px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); transition:transform .2s, border-color .2s; }
.device:hover{ transform:translateY(-5px); border-color:var(--border-2); }
.device .d-icon{ width:60px; height:60px; margin:0 auto 16px; border-radius:16px; background:var(--grad-soft); border:1px solid var(--border-2); display:grid; place-items:center; }
.device .d-icon svg{ width:30px; height:30px; color:var(--rose-bright); }
.device b{ font-family:'Space Grotesk'; font-size:16px; }
.device p{ font-size:13px; color:var(--muted); margin-top:6px; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:820px; margin-inline:auto; display:flex; flex-direction:column; gap:12px; }
.faq-item{ border:1px solid var(--border); border-radius:var(--r); background:var(--surface); overflow:hidden; }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 24px; text-align:left; font-family:'Space Grotesk'; font-weight:600; font-size:17px; }
.faq-q .chev{ width:22px; height:22px; flex:none; color:var(--rose-bright); transition:transform .3s; }
.faq-item.open .chev{ transform:rotate(180deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.faq-a p{ padding:0 24px 22px; color:var(--muted); font-size:15.5px; }

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{ position:relative; border-radius:var(--r-xl); padding:clamp(40px,6vw,72px); text-align:center; overflow:hidden; background:linear-gradient(135deg, rgba(251,46,99,.16), rgba(139,61,255,.16)); border:1px solid var(--border-2); }
.cta-band h2{ font-size:clamp(30px,4.5vw,52px); }
.cta-band p{ color:var(--muted); max-width:540px; margin:18px auto 0; font-size:18px; }
.cta-band .hero-cta{ justify-content:center; }

/* ============================================================
   PAGE HEAD (sous-pages)
   ============================================================ */
.page-head{ position:relative; padding-top:clamp(56px,8vw,96px); padding-bottom:clamp(40px,6vw,64px); overflow:hidden; }
.page-head h1{ font-size:clamp(36px,5.4vw,62px); margin-top:18px; }
.page-head .lead{ margin-top:18px; max-width:620px; }
.breadcrumb{ font-size:13.5px; color:var(--dim); }
.breadcrumb a:hover{ color:var(--rose-bright); }

/* ============================================================
   FORMS  (commande / contact)
   ============================================================ */
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:14px; font-weight:600; margin-bottom:8px; color:var(--text); }
.field input,.field select,.field textarea{
  width:100%; padding:14px 16px; border-radius:12px; font-family:inherit; font-size:15px;
  background:var(--bg-2); border:1px solid var(--border-2); color:var(--text); transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--rose); box-shadow:0 0 0 3px rgba(225,29,72,.18); }
.field textarea{ resize:vertical; min-height:130px; }
.field .hint{ font-size:12.5px; color:var(--dim); margin-top:6px; }
.form-card{ background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:clamp(24px,3vw,38px); }

.plan-radio{ display:flex; flex-direction:column; gap:10px; }
.plan-opt{ display:flex; align-items:center; gap:14px; padding:16px 18px; border:1px solid var(--border-2); border-radius:14px; cursor:pointer; transition:.2s; }
.plan-opt:hover{ border-color:var(--rose); }
.plan-opt.sel{ border-color:var(--rose); background:rgba(225,29,72,.08); }
.plan-opt .po-radio{ width:20px; height:20px; border-radius:50%; border:2px solid var(--border-2); flex:none; position:relative; transition:.2s; }
.plan-opt .po-image{ width:62px; height:46px; flex:none; object-fit:cover; border:1px solid var(--border); border-radius:9px; background:var(--surface-2); }
.plan-opt.sel .po-radio{ border-color:var(--rose); }
.plan-opt.sel .po-radio::after{ content:""; position:absolute; inset:3px; border-radius:50%; background:var(--rose); }
.plan-opt .po-name{ font-family:'Space Grotesk'; font-weight:600; }
.plan-opt .po-price{ margin-left:auto; font-family:'Space Grotesk'; font-weight:700; font-size:20px; }
.plan-opt .po-price small{ font-size:12px; color:var(--muted); font-weight:500; }

.order-summary{ position:sticky; top:96px; }
.summary-row{ display:flex; justify-content:space-between; padding:11px 0; border-bottom:1px solid var(--border); font-size:15px; }
.summary-row.total{ border-bottom:none; padding-top:18px; font-family:'Space Grotesk'; font-weight:700; font-size:22px; }
.summary-row .muted{ color:var(--muted); }

/* trust pills */
.trust-row{ display:flex; flex-wrap:wrap; gap:10px; }
.trust-pill{ display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--muted); padding:8px 14px; border:1px solid var(--border); border-radius:99px; background:var(--surface); }
.trust-pill svg{ width:15px; height:15px; color:#28c840; }

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.post{ display:flex; flex-direction:column; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; transition:transform .25s, border-color .25s; }
.post:hover{ transform:translateY(-5px); border-color:var(--border-2); }
.post .post-img{ aspect-ratio:16/10; }
.post .post-body{ padding:24px; display:flex; flex-direction:column; flex:1; }
.post .post-cat{ font-size:11px; letter-spacing:.12em; text-transform:uppercase; font-weight:700; color:var(--rose-bright); }
.post h3{ font-size:20px; margin:12px 0 10px; }
.post p{ color:var(--muted); font-size:14.5px; flex:1; }
.post .post-meta{ display:flex; align-items:center; gap:10px; margin-top:18px; font-size:13px; color:var(--dim); }
.post.featured-post{ grid-column:span 3; flex-direction:row; }
.post.featured-post .post-img{ aspect-ratio:auto; flex:1.1; }
.post.featured-post .post-body{ flex:1; justify-content:center; padding:clamp(28px,4vw,48px); }
.post.featured-post h3{ font-size:clamp(24px,3vw,34px); }

/* contact cards */
.contact-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:32px; align-items:start; }
.contact-method{ display:flex; gap:16px; padding:22px; border:1px solid var(--border); border-radius:var(--r); background:var(--surface); margin-bottom:14px; }
.contact-method .cm-icon{ width:48px; height:48px; border-radius:13px; flex:none; background:var(--grad-soft); border:1px solid var(--border-2); display:grid; place-items:center; }
.contact-method .cm-icon svg{ width:22px; height:22px; color:var(--rose-bright); }
.contact-method b{ font-family:'Space Grotesk'; font-size:16px; }
.contact-method p{ color:var(--muted); font-size:14px; margin-top:3px; }
.contact-method .cm-val{ color:var(--rose-bright); font-weight:600; margin-top:6px; font-size:15px; }

/* badge inline */
.badge{ display:inline-flex; align-items:center; gap:7px; font-size:12.5px; font-weight:700; padding:6px 13px; border-radius:99px; background:rgba(40,200,64,.12); color:#3ddc6a; border:1px solid rgba(40,200,64,.3); }
.badge.live::before{ content:""; width:7px; height:7px; border-radius:50%; background:#3ddc6a; box-shadow:0 0 8px #3ddc6a; animation:pulse 1.6s infinite; }
@keyframes pulse{ 0%,100%{ opacity:1; } 50%{ opacity:.3; } }

/* reveal on scroll */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.8,.2,1), transform .7s cubic-bezier(.2,.8,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .feature-grid,.price-grid,.device-grid{ grid-template-columns:repeat(2,1fr); }
  .stat-strip{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:1fr; }
  .step-line{ display:none; }
  .testi-grid{ columns:2; }
  .blog-grid{ grid-template-columns:repeat(2,1fr); }
  .post.featured-post{ grid-column:span 2; }
  .logo-wall{ grid-template-columns:repeat(4,1fr); }
}
@media (max-width:960px){
  .nav-links{ display:none; }
  .nav-cta .btn.nav-secondary{ display:none; }
  .menu-toggle{ display:flex; }
  .hero-grid{ grid-template-columns:1fr; gap:40px; }
  .hero-visual{ order:-1; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .contact-grid{ grid-template-columns:1fr; }
  .fb-1{ left:0; } .fb-2{ right:0; }
}
@media (max-width:620px){
  body{ font-size:16px; }
  .feature-grid,.price-grid,.device-grid,.blog-grid{ grid-template-columns:1fr; }
  .post.featured-post{ grid-column:span 1; flex-direction:column; }
  .stat-strip{ grid-template-columns:repeat(2,1fr); }
  .testi-grid{ columns:1; }
  .logo-wall{ grid-template-columns:repeat(3,1fr); }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .btn{ width:100%; }
  .hero-cta .btn,.cta-band .btn{ width:100%; }
}
