/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Oct 07 2025 | 18:59:21 */
/* ==========================================================================
   Base
   ========================================================================== */
* { box-sizing: border-box; }
html, body { overflow-x: hidden; }

/* ==========================================================================
   Header: phone block + "Get a Quote" button
   ========================================================================== */
.header-contact {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
  line-height: 1.3;
}
.header-contact__label {
  font-size: 14px;
  font-weight: 500;
  color: #0b2239;
  opacity: 0.85;
  margin-bottom: 2px;
}
.header-contact__phone {
  font-size: 16px;
  font-weight: 600;
  color: #1a73ff;
  text-decoration: none;
  letter-spacing: 0.2px;
  transition: color .25s ease;
}
.header-contact__phone:hover { color: #0046c8; text-decoration: underline; }

@media (max-width: 768px){
  .header-contact{ align-items: flex-start; text-align: left; }
  .header-contact__label{ font-size: 13px; }
  .header-contact__phone{ font-size: 15px; }
}

/* Clean header CTA (вместо инлайновых стилей) */
.header-btn{
  all: unset;
  display: inline-block;
  cursor: pointer;
  padding: 13px 26px;
  border-radius: 15px;
  background: linear-gradient(180deg,#60a5fa 0%,#2563eb 100%);
  color: #fff;
  font: 700 17px/1 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  letter-spacing: .01em;
  white-space: nowrap;
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(37,99,235,.25);
  transition: transform .15s ease, box-shadow .2s ease, opacity .2s ease;
}
.header-btn:hover{ transform: translateY(-2px); box-shadow: 0 14px 32px rgba(37,99,235,.35); }
.header-btn:active{ transform: translateY(0); opacity:.95; }

/* ==========================================================================
   Hero (общие заголовки и абзацы)
   ========================================================================== */
.aa-h1{
  font: 800 44px/1.16 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  letter-spacing: -0.02em;
  color:#0b2239;
  margin:0 0 12px;
}
.aa-blue{ color:#2563eb; }
.aa-lead{
  font-size:16.5px; color:#4b5563; line-height:1.7; max-width:56ch; margin:0 0 16px;
}

/* Layout контейнера hero */
.aa-hero{ padding:36px 5% 64px; background:none; }
.aa-hero-inner{
  max-width:1120px; margin:0 auto;
  display:grid; grid-template-columns: 1.1fr .9fr; gap:40px; align-items:start;
}

/* CTA-ряд и кнопки */
.aa-cta-row{ display:flex; gap:12px; align-items:center; margin:8px 0 14px; }
.aa-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:700; border-radius:12px; text-decoration:none;
  padding:12px 16px; border:1px solid rgba(2,6,23,.10); background:#fff; color:#0b2239;
}
.aa-btn--primary{
  background: linear-gradient(180deg, #60a5fa 0%, #2563eb 100%);
  color:#fff; border:0; box-shadow:0 10px 24px rgba(37,99,235,.25);
}

/* Chip с телефоном */
.aa-phone-chip{
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  background:#fff; border:1px solid rgba(2,6,23,.10);
  padding:12px 14px; border-radius:10px; color:#0b2239; font-weight:700;
}
.aa-phone-dot{ width:6px; height:6px; border-radius:50%; background:#22c55e; display:inline-block; }

/* Pills / chips / статистика */
.aa-pill{
  display:inline-flex; align-items:center; gap:8px; background:#fff;
  border:1px solid rgba(2,6,23,.10); border-radius:999px; padding:8px 12px;
  color:#0b2239; font-weight:600; font-size:13px;
}
.aa-pill--light{ background:#f8fafc; border-color:rgba(2,6,23,.06); margin:8px 0 14px; }
.aa-stat-row{ display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 0; }
.aa-chip{
  background:#fff; border:1px solid rgba(2,6,23,.10); border-radius:10px;
  padding:8px 10px; font-size:13px; color:#0b2239; font-weight:600;
}
.aa-chip--small{ font-weight:500; font-size:12px; }

/* Review */
.aa-review{ margin-top:14px; color:#0b2239; }
.aa-review blockquote{ margin:6px 0 0; color:#334155; font-size:14px; line-height:1.6; }
.aa-quote-author{ color:#64748b; }
.aa-stars{ color:#f59e0b; letter-spacing:.5px; font-size:14px; line-height:1; }

/* Hero Right: карточка формы + бейджи */
.aa-hero-right{ display:flex; flex-direction:column; align-items:flex-start; gap:12px; }
.aa-card{
  width:360px; max-width:100%;
  background:#fff; border:1px solid rgba(2,6,23,.06);
  border-radius:18px; box-shadow:0 14px 40px rgba(2,6,23,.10);
  padding:12px 12px 10px;
}
.aa-card-top{ display:flex; align-items:center; gap:8px; margin:3px 4px 6px; }
.aa-rating{ font-size:14px; color:#0b2239; }
.aa-rating span{ color:#64748b; }
.aa-badge{
  margin-left:auto; white-space:nowrap; font-size:12px; color:#1e3a8a; background:#dbeafe;
  border:1px solid #c7ddff; border-radius:18px; padding:8px 12px;
}

/* CF7 normalizer (скоупим к .aa-card) */
.aa-card .wpcf7-form-control-wrap{ display:block; }
.aa-card .wpcf7-form p{ margin:0 0 10px; }
.aa-card input[type="text"],
.aa-card input[type="tel"],
.aa-card input[type="email"],
.aa-card select{
  width:100%;
  font:600 14px/1.2 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  color:#0b2239; background:#fff; border:1px solid rgba(2,6,23,.10);
  border-radius:12px; padding:12px; outline:none;
  box-shadow: 0 3px 10px rgba(2,6,23,.04) inset;
  transition: border-color .2s, box-shadow .2s;
  margin: 0 0 10px;
}
.aa-card input::placeholder{ color:#94a3b8; font-weight:500; }
.aa-card select{ appearance:none; background-image:none; }
.aa-card input:focus, .aa-card select:focus{
  border-color:#2563eb; box-shadow:0 0 0 3px rgba(37,99,235,.12);
}
#aa-submit{
  width:100%; cursor:pointer; border:0;
  background: linear-gradient(180deg,#60a5fa 0%, #2563eb 100%);
  color:#fff; font:700 14.5px/1 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  border-radius:12px; padding:13px 14px; margin-top:2px;
  box-shadow:0 10px 24px rgba(37,99,235,.25); transition: transform .15s, box-shadow .2s, opacity .2s;
}
#aa-submit:hover{ transform:translateY(-1px); box-shadow:0 14px 32px rgba(37,99,235,.32); }
#aa-submit:active{ transform:translateY(0); opacity:.96; }

/* Пилюли под карточкой */
.aa-badges-under{ display:flex; gap:8px; flex-wrap:wrap; }
.aa-dot{ width:8px; height:8px; border-radius:50%; display:inline-block; }
.aa-badges-under .aa-pill{ font-size:12px; padding:6px 10px; }

/* Hero responsiveness */
@media (max-width: 960px){
  .aa-hero-inner{ grid-template-columns: 1fr; gap:22px; }
  .aa-card{ width:100%; max-width:420px; }
  .aa-hero-right{ align-items:center; }
}
@media (max-width: 640px){
  .aa-cta-row{ flex-direction:column; align-items:stretch; }
  .aa-cta-row .aa-btn, .aa-cta-row .aa-phone-chip{ width:100%; justify-content:center; }
}

/* ==========================================================================
   Promise (Arctic Promise)
   ========================================================================== */
.ap-wrap{
  --fg:#0b2239; --muted:#577089; --brand:#1a96ff; --brand-2:#4db8ff;
  --glass: rgba(255,255,255,.55); --glass-2: rgba(245,250,255,.35); --border: rgba(15,40,72,.12);
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  padding: clamp(20px, 2.8vw, 40px) 5%;
  position: relative; isolation:isolate;
}
.ap-card{
  max-width:1100px; margin:0 auto; padding:clamp(28px, 3.6vw, 56px);
  border-radius:clamp(18px, 2.2vw, 28px);
  background:
    radial-gradient(120% 150% at 80% 0%, rgba(77,184,255,.25) 0%, rgba(77,184,255,0) 60%),
    linear-gradient(160deg, var(--glass) 0%, var(--glass-2) 100%);
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border:1px solid var(--border);
  box-shadow:0 18px 40px rgba(3,23,46,.12), inset 0 1px 0 rgba(255,255,255,.35);
  color:var(--fg); position:relative; overflow:hidden;
}
.ap-card::after{
  content:""; position:absolute; inset:-1px -1px auto auto; width:min(38%,420px); height:52%;
  background: radial-gradient(80% 80% at 100% 0%, rgba(26,150,255,.20), rgba(26,150,255,0) 70%);
  pointer-events:none; filter: blur(2px);
}
.ap-kicker{
  display:inline-block; font-weight:700; font-size:clamp(12px,1.1vw,13px);
  letter-spacing:.12em; text-transform:uppercase; margin-bottom:clamp(10px,.9vw,12px);
  background: linear-gradient(90deg, var(--brand-2), var(--brand));
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:var(--brand);
}
.ap-title{
  margin:0 0 clamp(14px,1.2vw,18px); font-weight:800; color:var(--fg);
  font-size:clamp(22px,2.2vw,28px); letter-spacing:-.015em;
}
.ap-lane{
  display:flex; flex-wrap:wrap; align-items:center;
  gap: clamp(10px,1.6vw,16px) clamp(14px,2.2vw,26px);
  line-height:1.45; margin:0; padding:0; list-style:none; color:var(--fg);
  font-size:clamp(15px,1.4vw,17px); font-weight:600;
}
.ap-lane li{ position:relative; padding-left:0; white-space:nowrap; }
.ap-lane li + li::before{
  content:"•"; position:relative; margin-right:clamp(10px,1.4vw,14px); color:#7fa4c4; opacity:.9;
}
.ap-note{ margin-top:clamp(12px,1.6vw,16px); color:var(--muted); font-size:clamp(13px,1.2vw,15px); }
@media (max-width: 640px){
  .ap-card{ padding:24px; }
  .ap-lane{ gap:10px 14px; }
  .ap-lane li{ white-space: normal; }
}
@supports not ((-webkit-backdrop-filter: blur(12px)) or (backdrop-filter: blur(12px))){
  .ap-card{ background: rgba(255,255,255,.85); }
}

/* ==========================================================================
   About (glass photo + stats)
   ========================================================================== */
.about-glass-wrap{
  position:relative; display:inline-block; width:100%; max-width:720px;
  font-family:"Outfit", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  isolation:isolate;
}
.about-glass-photo{ width:100%; display:block; border-radius:24px; box-shadow:0 20px 40px rgba(2,6,23,.12); }
.about-glass-wrap::after{
  content:""; position:absolute; inset:auto 0 0 0; height:38%;
  border-radius:0 0 24px 24px;
  background: linear-gradient(180deg, rgba(0, 8, 20, 0) 0%, rgba(0, 8, 20, .12) 35%, rgba(0, 8, 20, .22) 100%);
  pointer-events:none;
}
.about-chip{
  position:absolute; top:16px; padding:9px 14px; border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,.36));
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border:1px solid rgba(255,255,255,.45); color:#0b2239; font-weight:600; font-size:14px; line-height:1;
  box-shadow:0 8px 20px rgba(2,6,23,.12); white-space:nowrap;
}
.about-chip.left{ left:16px; } .about-chip.right{ right:16px; }
.about-glass-card{
  position:absolute; left:20px; right:20px; bottom:20px;
  display:flex; flex-direction:column; gap:12px; padding:18px 18px 16px; border-radius:20px;
  background:
    radial-gradient(120% 140% at 0% 0%, rgba(255,255,255,.66) 0, rgba(255,255,255,.30) 100%),
    linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,.24));
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border:1px solid rgba(255,255,255,.55); box-shadow:0 16px 36px rgba(2,6,23,.18); color:#0b2239;
}
.about-rating-row{ display:flex; flex-wrap:wrap; align-items:center; gap:10px; }
.rating-chip{
  display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:12px;
  background:linear-gradient(180deg, #ffffffaa, #ffffff66); border:1px solid rgba(255,255,255,.7);
}
.rating-chip .num{ font-size:18px; font-weight:800; letter-spacing:.2px; }
.rating-chip .stars{ color:#f59e0b; font-size:18px; line-height:1; }
.rating-chip .cnt{ color:#1f2937; opacity:.85; font-size:14px; }
.trust-note{ font-size:14px; color:#0b2239; opacity:.92; font-weight:500; }
.about-pills{ display:flex; flex-wrap:wrap; gap:8px; }
.pill{
  padding:8px 12px; border-radius:999px; font-size:13px; font-weight:600; color:#0b2239;
  border:1px solid rgba(2,6,23,.06); background:#f9fafb;
}
.pill.brand{ background:#f0f7ff; border-color:rgba(37,99,235,.14); box-shadow:0 6px 14px rgba(37,99,235,.12); }
@media (max-width:560px){
  .about-glass-photo{ border-radius:20px; }
  .about-glass-wrap::after{ border-radius:0 0 20px 20px; height:44%; }
  .about-chip{ font-size:13px; padding:8px 12px; top:12px; }
  .about-chip.left{ left:12px; } .about-chip.right{ right:12px; }
  .about-glass-card{ left:12px; right:12px; bottom:12px; padding:14px 14px 12px; border-radius:16px; }
  .rating-chip{ padding:7px 10px; } .rating-chip .num,.rating-chip .stars{ font-size:16px; }
  .rating-chip .cnt{ font-size:13px; }
  .trust-note{ font-size:13px; }
  .pill{ font-size:12.5px; padding:7px 10px; }
}
@media (max-width:360px){
  .about-chip{ font-size:12.5px; }
  .about-glass-card{ gap:10px; }
  .pill{ font-size:12px; padding:6px 9px; }
}
@media (prefers-reduced-motion: reduce){
  .about-glass-wrap, .about-glass-card, .about-chip{ transition:none !important; }
}

/* ==========================================================================
   Highlights list under About
   ========================================================================== */
.hlx-list{
  --ink:#0b2239; --muted:#5f7289; --chip:rgba(37,99,235,.10);
  width:min(1100px,100%); margin:12px auto 0; color:var(--ink);
  font-family:"Outfit",system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
}
.hlx-list__ul{ display:grid; gap:18px; margin:0; padding:0; list-style:none; }
.hlx-item{ display:grid; grid-template-columns:28px 1fr; align-items:start; gap:12px; }
.hlx-ico{ inline-size:26px; block-size:26px; border-radius:8px; display:grid; place-items:center; background:var(--chip); color:#2563eb; }
.hlx-ico svg{ width:16px; height:16px; stroke:currentColor; stroke-width:2; fill:none; }
.hlx-text{ font-size:18px; line-height:1.55; color:var(--ink); }
@media (max-width:820px){ .hlx-text{ font-size:16px; } }

/* ==========================================================================
   KPI card
   ========================================================================== */
.kpi-card{
  --r:22px; --shadow:0 18px 40px rgba(25,40,60,.12); --brand:#1e63ff; --brand2:#5aa8ff; --muted:#6b7b8f; --fg:#0b2239;
  font-family:'Outfit',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:radial-gradient(120% 120% at 95% 0%,#eaf3ff 0,#fff 50%);
  border:1px solid rgba(2,6,23,.06); border-radius:var(--r); box-shadow:var(--shadow);
  overflow:hidden; width:min(920px,100%); margin:clamp(14px,2.6vw,24px) auto; color:var(--fg);
}
.kpi-wrap{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(18px,3vw,28px); align-items:center; padding:clamp(18px,3.2vw,28px); min-width:0; }
.kpi-head{ display:flex; align-items:center; gap:12px; margin-bottom:clamp(10px,1.6vw,14px); min-width:0; flex-wrap:nowrap; }
.kpi-chip{
  flex-shrink:0; width:44px; height:44px; border-radius:12px;
  background:linear-gradient(150deg,var(--brand2),var(--brand)); color:#fff; display:grid; place-items:center;
  box-shadow:0 12px 24px rgba(30,99,255,.25);
}
.kpi-chip svg{ width:20px; height:20px; }
.kpi-title{ font-weight:800; font-size:clamp(16px,1.8vw,18px); line-height:1.2; letter-spacing:.2px; margin:0; }
.kpi-sub{ font-size:13px; color:var(--muted); margin-top:2px; line-height:1.2; white-space:normal; overflow-wrap:anywhere; }
.kpi-left{ display:grid; justify-items:center; gap:10px; text-align:center; }
.ring{ --d:clamp(160px,26vw,220px); width:var(--d); height:var(--d); position:relative; display:grid; place-items:center; }
.ring canvas{ width:100%; height:100%; display:block; }
.ring .pct{ position:absolute; inset:0; display:grid; place-items:center; font-weight:800; font-size:clamp(28px,4.2vw,40px); letter-spacing:.3px; }
.fix-label{
  font-size:13px; color:var(--muted); margin-top:2px; display:flex; gap:12px; justify-content:center; line-height:1.1;
}
.fix-label span{ display:flex; align-items:center; gap:6px; line-height:1.1; }
.dot{ width:9px; height:9px; border-radius:50%; display:inline-block; }
.dot--fix{ background:var(--brand); } .dot--follow{ background:#a9b6c9; }
.kpi-right{ display:grid; gap:12px; min-width:0; }
.kpi-badge{
  display:flex; align-items:center; gap:10px; padding:12px 14px; background:#fff;
  border:1px solid rgba(2,6,23,.08); border-radius:16px; box-shadow:0 8px 18px rgba(2,6,23,.05); min-width:0;
}
.kpi-badge svg{ width:18px; height:18px; flex-shrink:0; color:var(--brand); }
.kpi-badge span{ font-size:14px; color:var(--fg); line-height:1.3; overflow-wrap:anywhere; white-space:normal; min-width:0; }
.kpi-note{ margin-top:6px; font-size:12px; color:var(--muted); overflow-wrap:anywhere; line-height:1.3; }
@media(max-width:820px){
  .kpi-wrap{ grid-template-columns:1fr; text-align:center; }
  .kpi-head{ justify-content:center; flex-wrap:wrap; text-align:center; }
  .kpi-title{ font-size:17px; line-height:1.1; }
  .kpi-sub{ font-size:12px; line-height:1.1; }
  .fix-label{ flex-direction:column; gap:4px; line-height:1.1; }
  .kpi-badge{ justify-content:center; flex-wrap:wrap; }
  .kpi-badge span{ text-align:center; }
}
@media(max-width:420px){
  .kpi-chip{ width:38px; height:38px; }
  .kpi-title{ font-size:16px; }
  .kpi-sub{ font-size:11.5px; }
  .fix-label{ font-size:12px; }
}

/* ==========================================================================
   Services Grid
   ========================================================================== */
:root { --media-col: 190px; }
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:24px; width:min(100%, 1200px); margin-inline:auto;
  padding-inline:clamp(16px, 4vw, 24px); overflow-x:hidden;
}
.service-card{
  display:flex; width:100%; max-width:100%; background:#fff; border-radius:18px;
  box-shadow:0 4px 10px rgba(0,0,0,.05); overflow:hidden; text-decoration:none;
  transition:box-shadow .25s ease, transform .25s ease; align-items:stretch;
}
@media (hover:hover){
  .service-card:hover{ transform:translateY(-4px); box-shadow:0 8px 20px rgba(0,0,0,.08); }
}
.service-card img{ flex:0 0 34%; width:34%; max-width:34%; display:block; object-fit:cover; }
.service-content{ padding:20px 22px; display:flex; flex-direction:column; gap:10px; min-width:0; }
.service-content h3{ font-size:18px; color:#0b2239; margin:0; font-weight:600; }
.service-content p{ font-size:15px; color:#4b5563; line-height:1.55; margin:0; }
.service-link{ margin-top:auto; font-size:15px; font-weight:600; color:#1e80ff; }
.service-link:hover{ color:#0f62d6; }
@media (max-width:640px){
  .service-card{ flex-direction:column; }
  .service-card img{ width:100%; max-width:100%; height:200px; flex:0 0 auto; }
}

/* ==========================================================================
   Process Steps
   ========================================================================== */
.cc-process{
  display:flex; flex-direction:column; gap:28px; max-width:920px; margin:0 auto;
  font-family:'Outfit',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
.cc-step{
  display:flex; align-items:flex-start; gap:22px; background:#fff; border-radius:20px;
  padding:22px 26px; box-shadow:0 4px 12px rgba(0,0,0,.05);
  transition:transform .25s ease, box-shadow .25s ease;
}
.cc-step:hover{ transform:translateY(-3px); box-shadow:0 10px 22px rgba(0,0,0,.08); }
.cc-media{ position:relative; display:flex; align-items:center; justify-content:center; flex-shrink:0; width:88px; }
.cc-step:not(:last-child) .cc-media:after{
  content:""; position:absolute; left:44px; top:92px; bottom:-22px; width:2px;
  background:linear-gradient(to bottom, rgba(16,112,235,.16), rgba(16,112,235,.06));
}
.cc-iconbox{
  width:88px; height:88px; border-radius:28px;
  background:linear-gradient(180deg,#F3F7FB 0%, #EAF1F7 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 6px 14px rgba(9,30,66,.08);
  display:flex; align-items:center; justify-content:center; position:relative;
}
.cc-badge{
  position:absolute; top:-8px; right:6px; width:28px; height:28px; border-radius:50%;
  background:#1aa2ff; color:#fff; font-size:14px; font-weight:700;
  display:flex; align-items:center; justify-content:center; box-shadow:0 4px 10px rgba(26,162,255,.35);
}
.cc-ico{ width:42px; height:42px; color:#2A7BE4; }
.cc-text h3{ font-size:20px; line-height:1.25; margin:6px 0 6px; color:#0b2239; font-weight:700; }
.cc-text p{ font-size:16px; line-height:1.7; color:#4b5563; margin:0; }
@media (max-width:680px){
  .cc-step{ padding:18px 20px; gap:18px; }
  .cc-media{ width:76px; }
  .cc-iconbox{ width:76px; height:76px; border-radius:22px; }
  .cc-ico{ width:36px; height:36px; }
  .cc-media:after{ left:38px; top:80px; }
  .cc-text h3{ font-size:18px; }
  .cc-text p{ font-size:15px; }
}

/* ==========================================================================
   Testimonials
   ========================================================================== */
.testi{
  --bg:#ffffff; --ink:#0b2239; --muted:#4b5563; --ring:#e8f2ff; --glass:rgba(255,255,255,.6);
  --brand:#2A7BE4; --brand-2:#41C2FF; --shadow:0 10px 28px rgba(9,30,66,.08); --radius:20px;
  color:var(--ink);
}
.testi-grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:24px; }
@media (max-width: 980px){ .testi-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 640px){ .testi-grid{ grid-template-columns: 1fr; } }
.testi-card{
  background: linear-gradient(180deg, var(--glass) 0%, #fff 100%);
  border-radius: var(--radius);
  padding:22px;
  box-shadow: var(--shadow);
  position:relative; overflow:hidden;
  border:1px solid rgba(16,112,235,.08);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.testi-card::before{
  content:""; position:absolute; inset:-60px auto auto -60px;
  width:180px; height:180px; border-radius:50%;
  background: radial-gradient(closest-side, rgba(65,194,255,.28), transparent 70%);
  filter: blur(4px); pointer-events:none;
}
.testi-card:hover{ transform: translateY(-4px); box-shadow: 0 16px 36px rgba(9,30,66,.12); border-color: rgba(16,112,235,.18); }
.testi-top{ display:flex; align-items:center; gap:14px; margin-bottom:12px; }
.testi-avatar{
  width:46px; height:46px; border-radius:14px; display:grid; place-items:center;
  font-weight:700; color:#fff; background: linear-gradient(135deg, var(--brand), var(--brand-2));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5); letter-spacing:.3px;
}
.testi-head{ line-height:1.25; }
.testi-name{ font-weight:700; font-size:16px; margin:0 0 2px; }
.testi-role{ margin:0; color:var(--muted); font-size:14px; }
.testi-quote{ margin:12px 0 16px; color:var(--ink); font-size:16px; line-height:1.7; }
.testi-quote::before{ content:"“"; margin-right:2px; opacity:.6; }
.testi-quote::after{ content:"”"; margin-left:2px; opacity:.6; }
.testi-meta{
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  border-top:1px dashed rgba(16,112,235,.12); padding-top:12px;
}
.testi-stars{ display:flex; gap:4px; color:#FFB200; }
.star{ width:18px; height:18px; fill:currentColor; }
.testi-date{ color:var(--muted); font-size:13px; }

/* ==========================================================================
   Brand Partners
   ========================================================================== */
.brand-partners { padding: 48px 5%; }
.brands-container{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 260px));
  justify-content:center; gap:24px; max-width:1200px; margin:0 auto;
}
.brand-card{
  background:#fff; border-radius:18px; border:1px solid rgba(2,6,23,.06);
  box-shadow:0 6px 16px rgba(2,6,23,.06); padding:28px 22px 22px; text-align:center;
  transition: all .3s ease; height:220px; display:flex; flex-direction:column; justify-content:space-between;
}
.brand-card:hover{ transform: translateY(-6px); box-shadow:0 14px 34px rgba(2,6,23,.12); border-color:rgba(2,6,23,.10); }
.brand-card img{
  width:100%; height:56px; object-fit:contain; margin-bottom:14px;
  filter: grayscale(100%) brightness(0.35); transition: all .3s ease;
}
.brand-card:hover img{ filter: grayscale(0%) brightness(1); }
.brand-card p{ font-size:15px; color:#374151; line-height:1.5; margin:0; }
@media (max-width: 1200px){ .brands-container{ grid-template-columns: repeat(auto-fit, minmax(240px, 240px)); } }
@media (max-width: 992px){ .brands-container{ grid-template-columns: repeat(auto-fit, minmax(220px, 220px)); } }
@media (max-width: 560px){
  .brands-container{ grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
  .brand-card{ height:auto; }
}

/* ==========================================================================
   CTA Section
   ========================================================================== */
.cta-wrap{ padding:72px 5%; background:none; }
.cta{
  max-width:1100px; margin:0 auto; display:grid; grid-template-columns:1.2fr .9fr;
  gap:40px; align-items:center;
}
.cta-title{
  font:700 42px/1.15 "Outfit", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color:#0b2239; letter-spacing:-.02em; margin:0 0 14px;
}
.cta-accent{ color:#1e40af; }
.cta-sub{ font-size:18px; color:#4b5563; line-height:1.65; margin:0 0 18px; }
.cta-points{ display:grid; gap:10px; padding:0; margin:0; list-style:none; color:#213245; font-size:16px; }
.tick{
  inline-size:20px; block-size:20px; display:inline-block; margin:0 8px -4px 0; border-radius:50%;
  background: radial-gradient(circle at 30% 30%, #60a5fa 0, #2563eb 60%, #1e40af 100%);
  position:relative; box-shadow:0 4px 10px rgba(37,99,235,.25);
}
.tick::after{
  content:""; position:absolute; inset:0; margin:auto; width:9px; height:5px;
  border:2px solid #fff; border-top:none; border-right:none; transform: rotate(-45deg) translate(-1px,1px);
}
.cta-card{
  background:#fff; border:1px solid rgba(2,6,23,.06); border-radius:20px;
  box-shadow:0 14px 40px rgba(2,6,23,.10); padding:28px; display:flex; flex-direction:column; gap:14px;
}
.btn-primary{
  background: linear-gradient(180deg, #60a5fa 0%, #2563eb 100%); color:#fff; text-decoration:none; text-align:center;
  font-weight:700; font-size:17px; padding:14px 18px; border-radius:14px; box-shadow:0 10px 24px rgba(37,99,235,.25);
  transition: transform .15s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 14px 32px rgba(37,99,235,.32); }
.btn-primary:active{ transform:translateY(0); opacity:.95; }
.btn-ghost{
  display:flex; align-items:center; justify-content:center; gap:10px; text-decoration:none; color:#0b2239;
  background:#f8fafc; border:1px solid rgba(2,6,23,.08); padding:12px 16px; border-radius:12px; font-weight:600;
  transition: background .2s ease, border-color .2s ease;
}
.btn-ghost:hover{ background:#f1f5f9; border-color:rgba(2,6,23,.12); }
.phone-ico{
  inline-size:18px; block-size:18px; border-radius:5px; position:relative;
  background: conic-gradient(from 210deg, #2563eb, #60a5fa);
}
.phone-ico::before, .phone-ico::after{
  content:""; position:absolute; inset:0; margin:auto; background:#fff; border-radius:1px;
}
.phone-ico::before{ width:10px; height:2px; top:5px; }
.phone-ico::after{ width:8px; height:8px; bottom:3px; border-radius:2px; }
.cta-note{ font-size:14px; color:#64748b; margin:4px 0 2px; text-align:center; }
.cta-badges{ display:flex; gap:8px; flex-wrap:wrap; justify-content:center; }
.cta-badges span{
  font-size:12px; color:#0b2239; padding:6px 10px; border:1px solid rgba(2,6,23,.08); background:#fff; border-radius:999px;
}
@media (max-width: 960px){
  .cta{ grid-template-columns: 1fr; }
  .cta-title{ font-size:36px; }
}
@media (max-width: 520px){
  .cta-wrap{ padding:56px 4%; }
  .cta-title{ font-size:30px; }
  .cta-sub{ font-size:16px; }
  .btn-primary{ font-size:16px; padding:13px 16px; }
}

/* ==========================================================================
   FAQ Section
   ========================================================================== */
.faq-section { padding: 60px 5%; background: none; }
.faq-container { max-width: 880px; margin: 0 auto; }
.faq-item{
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  padding: 22px 0;
  font-family: "Inter", "SF Pro Text", sans-serif;
}
.faq-item summary{
  list-style: none; position: relative; cursor: pointer;
  font-size: 18px; font-weight: 600; color: #0b2239; padding-right: 28px; transition: color 0.3s ease;
}
.faq-item summary::after{
  content:'+'; position: absolute; right: 0; top: 0; font-size: 22px; color: #2563eb;
  transition: transform 0.3s ease, color 0.3s ease;
}
.faq-item[open] summary::after{ content:'–'; transform: rotate(180deg); color:#2563eb; }
.faq-item summary:hover{ color:#2563eb; }
.faq-item p{
  margin: 12px 0 0; font-size: 16px; color: #4b5563; line-height: 1.6;
  opacity: 0; max-height: 0; overflow: hidden; transition: all 0.35s ease;
}
.faq-item[open] p{ opacity: 1; max-height: 400px; margin-top: 14px; }
@media (max-width: 600px){
  .faq-item summary{ font-size: 16px; }
  .faq-item p{ font-size: 15px; }
}




.aa-hero{ padding: 36px 5% 64px; background: none; }
.aa-hero-inner{
  max-width:1120px; margin:0 auto;
  display:grid; grid-template-columns: 1.1fr .9fr; gap:40px; align-items:start;
}
.aa-h1{
  font:800 44px/1.16 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  letter-spacing:-.02em; color:#0b2239; margin:0 0 12px;
}
.aa-blue{ color:#2563eb; }
.aa-lead{ font-size:16.5px; color:#4b5563; line-height:1.7; max-width:56ch; margin:0 0 16px; }

/* ===== Left: CTAs & chips ===== */
.aa-cta-row{ display:flex; gap:12px; align-items:center; margin: 8px 0 14px; }
.aa-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-weight:700; border-radius:12px; text-decoration:none;
  padding:12px 16px; border:1px solid rgba(2,6,23,.10); background:#fff; color:#0b2239;
}
.aa-btn--primary{
  background: linear-gradient(180deg, #60a5fa 0%, #2563eb 100%); color:#fff; border:0;
  box-shadow:0 10px 24px rgba(37,99,235,.25);
}
.aa-phone-chip{
  display:inline-flex; align-items:center; gap:8px; text-decoration:none;
  background:#fff; border:1px solid rgba(2,6,23,.10); padding:12px 14px; border-radius:10px; color:#0b2239; font-weight:700;
}
.aa-phone-dot{ width:6px; height:6px; border-radius:50%; background:#22c55e; display:inline-block; }

.aa-pill{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; border:1px solid rgba(2,6,23,.10);
  border-radius:999px; padding:8px 12px; color:#0b2239; font-weight:600; font-size:13px;
}
.aa-pill--light{ background:#f8fafc; border-color:rgba(2,6,23,.06); margin:8px 0 14px; }

.aa-stat-row{ display:flex; gap:10px; flex-wrap:wrap; margin:10px 0 0; }
.aa-chip{
  background:#fff; border:1px solid rgba(2,6,23,.10); border-radius:10px; padding:8px 10px; font-size:13px; color:#0b2239; font-weight:600;
}
.aa-chip--small{ font-weight:500; font-size:12px; }

.aa-review{ margin-top:14px; color:#0b2239; }
.aa-review blockquote{ margin:6px 0 0; color:#334155; font-size:14px; line-height:1.6; }
.aa-quote-author{ color:#64748b; }

/* ===== Right: Card ===== */
.aa-hero-right{ display:flex; flex-direction:column; align-items:flex-start; gap:12px; }
.aa-card{
  width:360px; max-width:100%;
  background:#fff; border:1px solid rgba(2,6,23,.06);
  border-radius:18px; box-shadow:0 14px 40px rgba(2,6,23,.10);
  padding:12px 12px 10px;
}
.aa-card-top{ display:flex; align-items:center; gap:8px; margin:3px 4px 6px; }
.aa-stars{ color:#f59e0b; letter-spacing:.5px; font-size:14px; line-height:1; }
.aa-rating{ font-size:14px; color:#0b2239; }
.aa-rating span{ color:#64748b; }
.aa-badge{
  margin-left:auto; white-space:nowrap;
  font-size:12px; color:#1e3a8a; background:#dbeafe;
  border:1px solid #c7ddff; border-radius:18px; padding:8px 12px;
}

/* ===== CF7 normalizer (scoped to card) ===== */
.aa-quote-card .wpcf7-form-control-wrap{ display:block; }
.aa-quote-card .wpcf7-form p{ margin:0 0 10px; }

.aa-quote-card input[type="text"],
.aa-quote-card input[type="tel"],
.aa-quote-card input[type="email"],
.aa-quote-card select{
  width:100%;
  font:600 14px/1.2 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  color:#0b2239; background:#fff; border:1px solid rgba(2,6,23,.10);
  border-radius:12px; padding:12px; outline:none;
  box-shadow: 0 3px 10px rgba(2,6,23,.04) inset;
  transition: border-color .2s, box-shadow .2s;
  margin: 0 0 10px;
}
.aa-quote-card input::placeholder{ color:#94a3b8; font-weight:500; }
.aa-quote-card select{ appearance:none; background-image: none; }

.aa-quote-card input:focus,
.aa-quote-card select:focus{
  border-color:#2563eb; box-shadow:0 0 0 3px rgba(37,99,235,.12);
}

#aa-submit{
  width:100%; cursor:pointer; border:0;
  background: linear-gradient(180deg,#60a5fa 0%, #2563eb 100%);
  color:#fff; font: 700 14.5px/1 "Outfit", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
  border-radius:12px; padding:13px 14px; margin-top:2px;
  box-shadow:0 10px 24px rgba(37,99,235,.25); transition: transform .15s, box-shadow .2s, opacity .2s;
}
#aa-submit:hover{ transform:translateY(-1px); box-shadow:0 14px 32px rgba(37,99,235,.32); }
#aa-submit:active{ transform:translateY(0); opacity:.96; }

/* tiny lines below */
.aa-quote-note{ font-size:11.5px; color:#94a3b8; margin:10px 2px 6px; }
.aa-quote-note a{ color:#0b2239; text-decoration:none; font-weight:700; }
.aa-quote-meta,
.aa-quote-area{
  font-size:11.5px; color:#94a3b8; margin:2px 2px;
  border-top:1px dashed rgba(2,6,23,.10); padding-top:8px;
}
.aa-quote-area{ border-top:none; }

/* Pills row under card */
.aa-badges-under{ display:flex; gap:8px; flex-wrap:wrap; }
.aa-dot{ width:8px; height:8px; border-radius:50%; display:inline-block; }
.aa-badges-under .aa-pill{ font-size:12px; padding:6px 10px; }

/* ===== Responsive ===== */
@media (max-width: 960px){
  .aa-hero-inner{ grid-template-columns: 1fr; gap:22px; }
  .aa-card{ width:100%; max-width:420px; }
  .aa-hero-right{ align-items:center; }
}




.aa-benefits {
  padding: 0;
  background: transparent;
}
.aa-benefits__inner {
  max-width: 1100px;
  margin: 0 auto;
}
.aa-benefits__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 36px;
}
.aa-benefit {
  background: #fff;
  border-radius: 18px;
  padding: 28px 24px;
  box-shadow: 0 6px 22px rgba(0,0,0,0.05);
  text-align: center;
  transition: transform .25s ease, box-shadow .25s ease;
}
.aa-benefit:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0,0,0,0.08);
}
.aa-benefit__icon {
  font-size: 2rem;
  margin-bottom: 14px;
  color: #1a73ff;
}
.aa-benefit__title {
  font-size: 1.15rem;
  font-weight: 600;
  color: #0b2239;
  margin-bottom: 10px;
}
.aa-benefit__text {
  color: #4b5563;
  font-size: 0.97rem;
  line-height: 1.55;
}
@media (max-width: 640px) {
  .aa-benefits__grid {
    gap: 24px;
  }
  .aa-benefit {
    padding: 24px 20px;
  }
}