/* ============================================================
   Đào Tạo Lái Xe Saigon — Landing page styles
   ============================================================ */
:root{
  --blue:#1573E6;
  --blue-700:#0F5AC0;
  --blue-50:#EAF2FE;
  --navy:#0A2A5E;
  --navy-800:#0C2F66;
  --navy-700:#143A78;
  --amber:#FFB81C;
  --amber-600:#F0A200;
  --amber-tint:#FFF7E6;
  --ink:#102744;
  --body:#42526B;
  --muted:#6B7A93;
  --line:#E4E9F1;
  --line-2:#EDF1F7;
  --bg:#FFFFFF;
  --bg-soft:#F5F8FC;
  --green:#15A35A;
  --green-tint:#E8F6EE;
  --shadow-sm:0 1px 2px rgba(16,39,68,.06), 0 1px 3px rgba(16,39,68,.08);
  --shadow:0 8px 24px rgba(16,39,68,.10);
  --shadow-lg:0 24px 60px rgba(10,42,94,.22);
  --r:14px;
  --r-lg:22px;
  --maxw:1180px;
  --font:"Be Vietnam Pro",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--font);color:var(--ink);
  background:var(--bg);line-height:1.6;font-size:17px;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{margin:0;line-height:1.15;font-weight:800;letter-spacing:-.01em;color:var(--ink)}
p{margin:0}
input,select,textarea{font-family:inherit;font-size:16px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:74px 0}
.section--soft{background:var(--bg-soft)}
.section--navy{background:linear-gradient(160deg,#0A2A5E,#0C326E 55%,#0E3A82)}
.section--amber{background:var(--amber-tint)}

/* ---- shared section heads ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue);background:var(--blue-50);
  padding:7px 14px;border-radius:999px;margin-bottom:18px;
}
.section--navy .eyebrow{color:#BBD3FF;background:rgba(255,255,255,.10)}
.s-head{max-width:760px;margin:0 auto 46px;text-align:center}
.s-head.left{margin-left:0;text-align:left}
.s-head h2{font-size:clamp(28px,3.4vw,42px);text-wrap:balance}
.section--navy .s-head h2,.section--navy h2,.section--navy h3{color:#fff}
.s-head p{margin-top:14px;color:var(--body);font-size:18px;text-wrap:pretty}
.section--navy .s-head p{color:#C5D5F0}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:16px;line-height:1;border:none;border-radius:12px;
  padding:15px 22px;transition:transform .12s ease,box-shadow .18s ease,background .18s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn svg{width:19px;height:19px;flex:none}
.btn--amber{background:var(--amber);color:#3A2A00;box-shadow:0 6px 16px rgba(255,184,28,.38)}
.btn--amber:hover{background:var(--amber-600);box-shadow:0 10px 22px rgba(255,184,28,.45)}
.btn--blue{background:var(--blue);color:#fff;box-shadow:0 6px 16px rgba(21,115,230,.30)}
.btn--blue:hover{background:var(--blue-700)}
.btn--zalo{background:#0068FF;color:#fff;box-shadow:0 6px 16px rgba(0,104,255,.28)}
.btn--zalo:hover{background:#0057D6}
.btn--ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn--lg{padding:17px 28px;font-size:17px}
.btn--block{width:100%}
.btn--white{background:#fff;color:var(--navy)}
.btn--white:hover{background:#F0F4FA}

/* ============================================================
   1 — Sticky top contact bar
   ============================================================ */
.topbar{
  background:var(--navy);color:#D9E4F7;font-size:14px;font-weight:500;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px;gap:18px}
.topbar a{display:inline-flex;align-items:center;gap:7px;color:#D9E4F7}
.topbar a:hover{color:#fff}
.topbar svg{width:15px;height:15px;color:var(--amber)}
.topbar .tb-left{display:flex;align-items:center;gap:22px;min-width:0}
.topbar .tb-left .addr{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar .tb-right{display:flex;align-items:center;gap:14px}
.topbar .tb-zalo{
  background:#0068FF;color:#fff;padding:6px 13px;border-radius:8px;font-weight:700;
}
.topbar .tb-zalo:hover{background:#0057D6;color:#fff}
.topbar .tb-hot{font-weight:700;color:#fff}
@media(max-width:860px){.topbar .tb-left .addr{display:none}}
@media(max-width:1000px){.topbar{display:none}}

/* ============================================================
   2 — Header / nav
   ============================================================ */
.header{
  position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line);
}
.header .wrap{display:flex;align-items:center;gap:20px;height:74px}
.brand{display:flex;align-items:center;gap:13px;margin-right:auto}
.brand img{width:50px;height:50px;border-radius:50%}
.brand .bt{display:flex;flex-direction:column;line-height:1.1}
.brand .bt b{font-size:17px;font-weight:800;color:var(--navy);letter-spacing:-.01em}
.brand .bt span{font-size:11.5px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.nav{display:flex;align-items:center;gap:4px}
.nav a{
  padding:9px 13px;border-radius:9px;font-size:15px;font-weight:600;color:#33425C;
  transition:background .15s,color .15s;
}
.nav a:hover{background:var(--blue-50);color:var(--blue)}
.header .btn{padding:12px 18px}
.burger{display:none;border:1.5px solid var(--line);background:#fff;border-radius:10px;width:46px;height:44px;align-items:center;justify-content:center}
.burger svg{width:24px;height:24px;color:var(--navy)}
@media(max-width:1000px){.nav,.header .header-cta{display:none}.burger{display:inline-flex}}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:200;display:none;
}
.drawer.open{display:block}
.drawer__scrim{position:absolute;inset:0;background:rgba(10,42,94,.45)}
.drawer__panel{
  position:absolute;top:0;right:0;height:100%;width:min(82vw,330px);
  background:#fff;box-shadow:var(--shadow-lg);padding:20px;display:flex;flex-direction:column;gap:6px;
  transform:translateX(100%);transition:transform .26s ease;
}
.drawer.open .drawer__panel{transform:none}
.drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.drawer__head b{font-weight:800;color:var(--navy)}
.drawer__close{border:none;background:var(--bg-soft);width:40px;height:40px;border-radius:10px;font-size:20px;color:var(--navy)}
.drawer a.dl{padding:14px 12px;border-radius:10px;font-weight:600;font-size:16px;color:#27364D}
.drawer a.dl:hover{background:var(--blue-50);color:var(--blue)}
.drawer .btn{margin-top:14px}

/* ============================================================
   3 — HERO (final: navy split)
   ============================================================ */

.qform{
  background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  padding:26px 24px;border:1px solid var(--line-2);
}
.qform h3{font-size:21px;color:var(--navy)}
.qform .qf-sub{color:var(--muted);font-size:14.5px;margin-top:5px;margin-bottom:16px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:13px}
.field label{font-size:13.5px;font-weight:700;color:#33425C}
.field input,.field select,.field textarea{
  width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:11px;
  background:#fff;color:var(--ink);transition:border .15s,box-shadow .15s;
}
.field input::placeholder,.field textarea::placeholder{color:#9AA7BC}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--blue);box-shadow:0 0 0 4px var(--blue-50);
}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%236B7A93' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:40px}
.form-note{font-size:12.5px;color:var(--muted);margin-top:12px;text-align:center;line-height:1.5}
.form-help{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--body);background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin:4px 0 14px;line-height:1.45}
.form-help svg{width:16px;height:16px;flex:none;color:var(--blue);margin-top:1px}

/* form success */
.form-success{display:none;text-align:center;padding:18px 6px}
form.sent .form-body{display:none}
form.sent .form-success{display:block}
.form-success .fs-ic{width:62px;height:62px;border-radius:50%;background:var(--green-tint);color:var(--green);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.form-success .fs-ic svg{width:32px;height:32px}
.form-success h4{font-size:20px;color:var(--navy)}
.form-success p{color:var(--body);margin:8px 0 16px;font-size:15px}
.form-success .fs-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* trust bullets row */
.trust-row{display:flex;flex-wrap:wrap;gap:12px 22px;margin-top:26px}
.trust-row .ti{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px}
.trust-row .ti svg{width:20px;height:20px;flex:none;color:var(--green)}
.section--navy .trust-row .ti,.hero-a .trust-row .ti{color:#E7EEFA}
.hero-a .trust-row .ti svg,.section--navy .trust-row .ti svg{color:var(--amber)}

/* HERO A — split navy */
.hero-a{position:relative;overflow:hidden;background:linear-gradient(150deg,#0A2A5E 0%,#0C336F 50%,#103F88 100%);color:#fff;padding:64px 0 70px}
.hero-a::before{content:"";position:absolute;inset:0;background:
  radial-gradient(680px 420px at 78% -8%,rgba(21,115,230,.40),transparent 60%),
  radial-gradient(540px 360px at -6% 112%,rgba(255,184,28,.14),transparent 60%);pointer-events:none}
.hero-a .wrap{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero-a .badge-pill{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);color:#DCE7FA;font-weight:600;font-size:14px;padding:8px 15px;border-radius:999px;margin-bottom:22px}
.hero-a .badge-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 4px rgba(255,184,28,.25)}
.hero-a h1{font-size:clamp(30px,3.9vw,49px);color:#fff;text-wrap:balance}
.hero-a h1 .hl{color:var(--amber)}
.hero-a .sub{margin-top:18px;font-size:18.5px;color:#C9D8F0;max-width:540px;text-wrap:pretty}
.hero-a .cta-row{display:flex;flex-wrap:wrap;gap:13px;margin-top:28px}

@media(max-width:920px){
  .hero-a .wrap{grid-template-columns:1fr;gap:34px}
}

/* ============================================================
   4 — Pricing
   ============================================================ */
.price-badge{display:flex;align-items:center;justify-content:center;gap:9px;max-width:max-content;margin:0 auto 26px;background:var(--green-tint);color:#0B7A40;font-weight:700;font-size:14.5px;padding:10px 18px;border-radius:999px}
.price-badge svg{width:18px;height:18px;flex:none}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
.pcard{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;
  display:flex;flex-direction:column;position:relative;
  box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease,border-color .18s;
}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:#CFE0FB}
.pcard--featured{border-color:var(--blue);box-shadow:0 20px 50px rgba(21,115,230,.18)}
.pcard__media{position:relative;height:160px;background:linear-gradient(135deg,#EAF2FE,#D6E6FB)}
.pcard__media image-slot{width:100%;height:100%}
.pcard__media--manual{background:linear-gradient(135deg,#E7EEFC,#D2E0F8)}
.pcard__media--c1{background:linear-gradient(135deg,#FFF3D8,#FFE6B4)}
.pcard__tag{position:absolute;top:12px;left:12px;z-index:3;background:rgba(10,42,94,.86);color:#fff;font-size:12px;font-weight:700;padding:5px 12px;border-radius:999px;letter-spacing:.02em}
.pcard__flag{position:absolute;top:12px;right:12px;z-index:3;background:var(--blue);color:#fff;font-size:12.5px;font-weight:700;padding:6px 13px;border-radius:999px;letter-spacing:.02em;box-shadow:0 4px 12px rgba(21,115,230,.35)}
.pcard__body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.pcard h3{font-size:22px;color:var(--navy)}
.pcard .pc-for{color:var(--muted);font-size:14px;margin-top:7px;min-height:42px}
.pcard .pc-price{margin:16px 0 4px;font-size:33px;font-weight:800;color:var(--navy);letter-spacing:-.02em}
.pcard .pc-price small{font-size:15px;font-weight:600;color:var(--muted)}
.pcard .pc-unit{font-size:13px;color:var(--muted);margin-bottom:18px}
.pcard ul{list-style:none;padding:0;margin:0 0 22px;display:flex;flex-direction:column;gap:11px}
.pcard ul li{display:flex;gap:10px;font-size:15px;color:var(--body)}
.pcard ul li svg{width:20px;height:20px;flex:none;color:var(--green);margin-top:1px}
.pcard .btn{margin-top:auto}
.price-note{display:flex;align-items:center;gap:10px;justify-content:center;margin-top:26px;color:var(--muted);font-size:14px;text-align:center}
.price-note svg{width:18px;height:18px;flex:none;color:var(--blue)}

/* ============================================================
   5 — Pain points
   ============================================================ */
.pain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcell{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:24px;box-shadow:var(--shadow-sm);transition:border-color .15s,transform .15s;
}
.pcell:hover{border-color:#CFE0FB;transform:translateY(-3px)}
.pcell__top{display:flex;align-items:center;gap:13px;margin-bottom:12px}
.pcell__ic{width:46px;height:46px;border-radius:12px;background:var(--amber-tint);color:var(--amber-600);display:flex;align-items:center;justify-content:center;flex:none}
.pcell__ic svg{width:24px;height:24px}
.pcell h3{font-size:18px;color:var(--navy)}
.pcell .solve{display:flex;gap:9px;color:var(--body);font-size:14.5px;margin-top:4px}
.pcell .solve svg{width:18px;height:18px;flex:none;color:var(--green);margin-top:2px}

/* ============================================================
   6 — Why us
   ============================================================ */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.wcell{display:flex;gap:15px;padding:24px;border-radius:var(--r);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.wcell__ic{width:52px;height:52px;border-radius:13px;background:rgba(255,184,28,.16);color:var(--amber);display:flex;align-items:center;justify-content:center;flex:none}
.wcell__ic svg{width:27px;height:27px}
.wcell h3{font-size:18px;color:#fff}
.wcell p{color:#BFD0EC;font-size:14.5px;margin-top:6px}

/* ============================================================
   7 — Process timeline
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;position:relative}
.steps::before{content:"";position:absolute;top:33px;left:9%;right:9%;height:2px;background:repeating-linear-gradient(90deg,var(--line) 0 14px,transparent 14px 26px)}
.step{position:relative;text-align:center;padding:0 4px}
.step__n{width:66px;height:66px;border-radius:50%;background:#fff;border:2px solid var(--blue);color:var(--blue);font-size:24px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;position:relative;z-index:1;box-shadow:0 6px 16px rgba(21,115,230,.16)}
.step h3{font-size:17px;color:var(--navy)}
.step p{color:var(--body);font-size:14px;margin-top:6px}
.process-cta{display:flex;justify-content:center;margin-top:42px}
.step__txt{display:contents}

/* shared section CTA */
.sec-cta{display:flex;justify-content:center;margin-top:38px}

/* ============================================================
   5b — Comparison
   ============================================================ */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:920px;margin:0 auto}
.compare__col{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px 26px 28px;box-shadow:var(--shadow-sm)}
.compare__col--bad{background:#FBF6F4;border-color:#F0DAD2}
.compare__col--good{border-color:#BFE3CD;box-shadow:0 16px 40px rgba(21,163,90,.12)}
.compare__head{display:flex;align-items:center;gap:11px;font-size:18px;font-weight:800;color:var(--navy);padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--line-2)}
.compare__ic{width:30px;height:30px;border-radius:9px;background:#F4C9BC;color:#B5481F;display:flex;align-items:center;justify-content:center;font-weight:800;flex:none}
.compare__ic--ok{background:var(--green-tint);color:var(--green)}
.compare__ic--ok svg{width:18px;height:18px}
.compare__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.compare__col li{display:flex;gap:11px;font-size:15px;color:var(--body)}
.compare__col li svg{width:20px;height:20px;flex:none;margin-top:1px}
.compare__col--bad li svg{color:#C75A35}
.compare__col--good li svg{color:var(--green)}

/* ============================================================
   6b — Quiz
   ============================================================ */
.quiz{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;max-width:920px;margin:0 auto;align-items:start}
.quiz__opts{display:flex;flex-direction:column;gap:11px}
.quiz__opt{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:16px 18px;font-size:16px;font-weight:600;color:#2A3A52;transition:border-color .15s,background .15s,box-shadow .15s}
.quiz__opt:hover{border-color:#BFD4F6;background:var(--blue-50)}
.quiz__dot{width:20px;height:20px;border-radius:50%;border:2px solid #C4D2E6;flex:none;transition:.15s;position:relative}
.quiz__opt.sel{border-color:var(--blue);background:var(--blue-50);box-shadow:0 6px 16px rgba(21,115,230,.12)}
.quiz__opt.sel .quiz__dot{border-color:var(--blue);background:var(--blue)}
.quiz__opt.sel .quiz__dot::after{content:"";position:absolute;inset:4px;border-radius:50%;background:#fff}
.quiz__result{background:linear-gradient(160deg,#0A2A5E,#103F88);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow);position:sticky;top:90px}
.quiz__hint{color:#CBD9F1;font-size:15px;line-height:1.55;margin-bottom:18px;min-height:66px}
.quiz__hint b{color:#fff}
.quiz__result .btn{margin-top:0}

/* perks 4-up */
.perk-grid--4{grid-template-columns:repeat(4,1fr)}

/* testimonials 5-up: first card spans for balance on wide */
.tgrid--5{grid-template-columns:repeat(3,1fr)}

/* ============================================================
   7b — Đặc quyền / perks
   ============================================================ */
.perk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.perk{background:#fff;border:1px solid #F0E2C0;border-radius:var(--r-lg);padding:30px 26px;box-shadow:0 8px 22px rgba(154,107,0,.07);text-align:center;transition:transform .15s,box-shadow .15s}
.perk:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(154,107,0,.12)}
.perk__ic{width:62px;height:62px;border-radius:16px;background:var(--amber);color:#3A2A00;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;box-shadow:0 8px 18px rgba(255,184,28,.35)}
.perk__ic svg{width:31px;height:31px}
.perk h3{font-size:19px;color:var(--navy)}
.perk p{color:var(--body);font-size:14.5px;margin-top:9px;text-wrap:pretty}

/* ============================================================
   8 — Gallery
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gitem{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);background:#fff}
.gitem .gphoto{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;color:rgba(10,42,94,.30);background:
  repeating-linear-gradient(135deg,rgba(255,255,255,.5) 0 14px,rgba(255,255,255,0) 14px 28px),
  linear-gradient(135deg,#E6EEF8,#DAE6F3 55%,#E9EEF5)}
.gitem .gphoto svg{width:48px;height:48px}
.gitem image-slot{position:relative;z-index:1;width:100%;height:240px;background:transparent}
.gitem .gcap{position:absolute;z-index:2;left:0;right:0;bottom:0;padding:34px 16px 14px;color:#fff;font-weight:700;font-size:15px;background:linear-gradient(transparent,rgba(8,28,62,.86));pointer-events:none}
.gitem--wide{grid-column:span 2}
@media(min-width:921px){.gitem--tall image-slot{height:240px}}

/* ============================================================
   9 — Testimonials
   ============================================================ */
.tgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.tcard .stars{display:flex;gap:3px;color:var(--amber);margin-bottom:13px}
.tcard .stars svg{width:18px;height:18px}
.tcard .quote{font-size:16.5px;color:#27364D;line-height:1.62;flex:1;text-wrap:pretty}
.tcard .who{display:flex;align-items:center;gap:13px;margin-top:20px;padding-top:18px;border-top:1px solid var(--line-2)}
.tcard .who .av{width:46px;height:46px;border-radius:50%;background:var(--blue-50);color:var(--blue);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:17px;flex:none}
.tcard .who b{display:block;font-size:15px;color:var(--navy)}
.tcard .who span{font-size:13px;color:var(--muted)}

/* ============================================================
   10 — Main form
   ============================================================ */
.form-split{display:grid;grid-template-columns:1.25fr .75fr;gap:26px;align-items:start}
.bigform{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:32px;box-shadow:var(--shadow)}
.form-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}
.form-2 .field.full{grid-column:1 / -1}
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{position:relative}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer}
.chip span{display:block;padding:11px 16px;border:1.5px solid var(--line);border-radius:10px;font-weight:600;font-size:14.5px;color:#41526B;transition:.15s}
.chip input:checked+span{border-color:var(--blue);background:var(--blue-50);color:var(--blue)}
.chip:hover span{border-color:#BFD4F6}

.contact-box{background:linear-gradient(160deg,#0A2A5E,#103F88);color:#fff;border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow)}
.contact-box h3{color:#fff;font-size:21px}
.contact-box .cintro{color:#C5D5F0;font-size:14.5px;margin-top:8px;margin-bottom:22px}
.cline{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-top:1px solid rgba(255,255,255,.12)}
.cline__ic{width:44px;height:44px;border-radius:12px;background:rgba(255,255,255,.10);color:var(--amber);display:flex;align-items:center;justify-content:center;flex:none}
.cline__ic svg{width:22px;height:22px}
.cline .cl-k{font-size:12.5px;color:#9FB6DC;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.cline .cl-v{font-size:17px;font-weight:700;color:#fff;margin-top:2px}
.cline .cl-v.small{font-size:14.5px;font-weight:600;color:#D9E4F7;line-height:1.45}
.contact-box .cbtns{display:flex;flex-direction:column;gap:10px;margin-top:20px}

/* ============================================================
   11 — FAQ
   ============================================================ */
.faq{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.fitem{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.fitem.open{border-color:#BFD4F6;box-shadow:var(--shadow-sm)}
.fq{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:none;border:none;padding:20px 22px;font-size:17px;font-weight:700;color:var(--navy)}
.fq .fq-ic{width:30px;height:30px;border-radius:8px;background:var(--blue-50);color:var(--blue);display:flex;align-items:center;justify-content:center;flex:none;transition:transform .25s,background .2s,color .2s}
.fq .fq-ic svg{width:18px;height:18px}
.fitem.open .fq .fq-ic{background:var(--blue);color:#fff;transform:rotate(45deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .3s ease}
.fa .fa-in{padding:0 22px 22px 66px;color:var(--body);font-size:15.5px;text-wrap:pretty}

/* ============================================================
   12 — Final contact
   ============================================================ */
.final{position:relative;overflow:hidden;background:linear-gradient(150deg,#0A2A5E,#0C3470 55%,#103F88);color:#fff}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 380px at 88% 0,rgba(255,184,28,.16),transparent 60%)}
.final .wrap{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.final h2{font-size:clamp(27px,3.2vw,40px);color:#fff;text-wrap:balance}
.final .fsub{color:#C9D8F0;font-size:18px;margin-top:14px}
.final .final-cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:26px}
.final .fcontacts{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:26px}
.final .fcontacts a{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:#E7EEFA}
.final .fcontacts svg{width:18px;height:18px;color:var(--amber)}
.mapcard{border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(255,255,255,.16);background:#fff;box-shadow:var(--shadow-lg)}
.mapview{position:relative;display:block;height:300px;text-decoration:none;
  background:
    radial-gradient(120px 90px at 50% 46%,rgba(21,115,230,.10),transparent 70%),
    linear-gradient(160deg,#EAF3EA,#E3EEF6 60%,#E9F0F7);overflow:hidden}
.mapview__roads{position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg,transparent 0 46px,rgba(120,140,160,.18) 46px 48px),
    repeating-linear-gradient(90deg,transparent 0 64px,rgba(120,140,160,.18) 64px 66px)}
.mapview__road-main{position:absolute;background:#fff;box-shadow:0 0 0 1px rgba(120,140,160,.22)}
.mapview__road-main--a{height:14px;left:-5%;right:-5%;top:44%;transform:rotate(-7deg)}
.mapview__road-main--b{width:14px;top:-5%;bottom:-5%;left:38%;transform:rotate(6deg)}
.mapview__marker{position:absolute;left:50%;top:46%;transform:translate(-50%,-100%);color:var(--blue);filter:drop-shadow(0 6px 8px rgba(10,42,94,.3));z-index:2}
.mapview__marker svg{width:42px;height:42px}
.mapview__marker::after{content:"";position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);width:26px;height:9px;border-radius:50%;background:rgba(10,42,94,.18)}
.mapview__open{position:absolute;top:14px;right:14px;background:#fff;color:var(--blue);font-weight:700;font-size:13px;padding:8px 13px;border-radius:9px;box-shadow:var(--shadow-sm);z-index:2;transition:background .15s,color .15s}
.mapview:hover .mapview__open{background:var(--blue);color:#fff}
.mapcard__info{display:flex;gap:13px;align-items:center;padding:16px 18px;background:#fff;border-top:1px solid var(--line)}
.mapcard__pin{width:44px;height:44px;border-radius:12px;background:var(--blue-50);color:var(--blue);display:flex;align-items:center;justify-content:center;flex:none}
.mapcard__pin svg{width:23px;height:23px}
.mapcard__info b{display:block;font-size:15px;color:var(--navy)}
.mapcard__info span{font-size:13px;color:var(--muted)}

/* footer */
.foot{background:#08234F;color:#9FB6DC;font-size:14px;padding:30px 0}
.foot .wrap{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between}
.foot .fbrand{display:flex;align-items:center;gap:12px;color:#fff;font-weight:700}
.foot .fbrand img{width:40px;height:40px;border-radius:50%}

/* ============================================================
   Mobile sticky bottom bar
   ============================================================ */
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;
  grid-template-columns:1fr 1fr;gap:10px;padding:10px 12px;
  background:rgba(255,255,255,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);box-shadow:0 -6px 22px rgba(10,42,94,.12);
}
.mobile-bar .btn{padding:15px;font-size:16px}
@media(max-width:1000px){.mobile-bar{display:grid}body{padding-bottom:74px}}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .price-grid,.pain-grid,.why-grid,.perk-grid{grid-template-columns:repeat(2,1fr)}
  .perk-grid{max-width:560px;margin:0 auto}
  .perk-grid--4{max-width:none}
  .tgrid--5{grid-template-columns:repeat(2,1fr)}
  .quiz{grid-template-columns:1fr}
  .quiz__result{position:static}
  .steps{grid-template-columns:repeat(2,1fr);gap:30px 16px}
  .steps::before{display:none}
  .form-split{grid-template-columns:1fr}
  .final .wrap{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .gitem--wide{grid-column:span 2}
}
@media(max-width:680px){
  .section{padding:54px 0}
  .price-grid,.pain-grid,.why-grid,.tgrid,.tgrid--5,.gallery,.perk-grid,.perk-grid--4,.compare{grid-template-columns:1fr}
  .perk-grid{max-width:none}
  .gitem--wide{grid-column:auto}
  /* compact vertical timeline cards */
  .steps{grid-template-columns:1fr;gap:12px}
  .step{display:flex;align-items:flex-start;gap:14px;text-align:left;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 16px;box-shadow:var(--shadow-sm)}
  .step__n{width:42px;height:42px;font-size:18px;margin:0;flex:none}
  .step__txt{display:block}
  .step h3{font-size:16px}
  .step p{font-size:13.5px;margin-top:3px}
  .process-cta{margin-top:24px}
  .process-cta .btn,.sec-cta .btn{width:100%}
  /* compact perks */
  .perk{padding:20px 20px}
  .perk__ic{width:50px;height:50px;margin-bottom:13px}
  .perk__ic svg{width:26px;height:26px}
  .compare__col{padding:20px}
  .form-2{grid-template-columns:1fr}
  .bigform{padding:24px}
  .topbar .tb-left{gap:14px}
  body{font-size:16px}
}
@media(max-width:1000px){
  body{padding-bottom:84px}
}
