/* ============================================================
   EDGE Energy — Divi 5 Template System
   Shared design system. Every token here → a Divi global preset.
   Palette & type reverse-engineered from the live EDGE site,
   with structural/decorative cues borrowed from TRoo Solar.
   ============================================================ */

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

:root{
  /* ---- Brand ---- */
  --navy:        #14223f;   /* EDGE headline ink (near-black navy) */
  --navy-2:      #1b2c4d;
  --footer:      #0c1a35;   /* deep navy footer */

  --blue:        #2766e0;   /* primary action (EDGE "Get a Solar Quote") */
  --blue-600:    #1f57c6;
  --blue-700:    #1a49a6;
  --blue-soft:   #e9f0fd;

  --green:       #1f9e51;   /* eco / go-green accent + TRoo bridge */
  --green-600:   #178a45;
  --green-700:   #0f6f37;
  --green-soft:  #e7f3ec;
  --green-line:  #cde6d7;

  --gold:        #f5a623;   /* stars / small highlights */
  --gold-soft:   #fdf1d9;

  /* ---- Neutrals ---- */
  --ink:         #14223f;   /* same as navy, used as text-dark */
  --body:        #46505f;   /* body copy slate */
  --muted:       #6d7585;   /* secondary text */
  --line:        #e4e8ee;   /* hairlines */
  --bg:          #ffffff;
  --sage:        #e9f0ea;   /* EDGE signature sage section */
  --sage-2:      #eef3ee;
  --mist:        #f4f7fa;   /* cool light section */
  --white:       #ffffff;

  /* ---- Type ---- */
  --font-head: 'Archivo', system-ui, sans-serif;
  --font-body: 'Manrope', system-ui, sans-serif;

  /* ---- Radius + shadow ---- */
  --r-sm: 8px;
  --r:    14px;
  --r-lg: 22px;
  --r-pill: 999px;
  --shadow-sm: 0 2px 10px rgba(20,34,63,.06);
  --shadow:    0 16px 44px -18px rgba(20,34,63,.22);
  --shadow-lg: 0 34px 80px -30px rgba(20,34,63,.34);

  /* ---- Layout ---- */
  --maxw: 1260px;
  --gut: clamp(20px, 5vw, 44px);
  --section-y: clamp(40px, 5vw, 74px);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--body);
  font-family:var(--font-body); font-size:17px; line-height:1.65; font-weight:450;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-head); color:var(--ink); margin:0; line-height:1.04;
  font-weight:800; letter-spacing:-.03em; text-wrap:balance;
}
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:var(--gut); }
.wrap--narrow{ max-width:880px; }
.section{ padding-block:var(--section-y); }
.section--sage{ background:var(--sage); }
.section--mist{ background:var(--mist); }
.section--navy{ background:var(--navy); color:#c3ccda; }
.section--navy h1,.section--navy h2,.section--navy h3,.section--navy h4{ color:#fff; }
.section--blue{ background:var(--blue); color:#dfe9fc; }
.section--blue h2,.section--blue h3{ color:#fff; }
.center{ text-align:center; }

.grid{ display:grid; gap:22px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media(max-width:980px){ .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:640px){ .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; } }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.split--wide-l{ grid-template-columns:1.1fr .9fr; }
.split--wide-r{ grid-template-columns:.9fr 1.1fr; }
@media(max-width:900px){ .split,.split--wide-l,.split--wide-r{ grid-template-columns:1fr; gap:36px; } }

/* ---------- Typography ---------- */
.eyebrow{
  font-family:var(--font-head); font-weight:700; font-size:13px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--muted);
  display:inline-flex; align-items:center; gap:.45em;
}
.eyebrow::before{ content:"//"; color:var(--green); font-weight:800; letter-spacing:-.04em; }
.section--navy .eyebrow,.section--blue .eyebrow{ color:rgba(255,255,255,.7); }
.section--navy .eyebrow::before{ color:var(--gold); }

/* TRoo-style pill label (dot + text) — friendly alt to eyebrow */
.plabel{
  display:inline-flex; align-items:center; gap:.55em; font-family:var(--font-head);
  font-weight:700; font-size:13px; letter-spacing:.02em; color:#fff;
  background:var(--green); padding:8px 16px 8px 14px; border-radius:var(--r-pill);
}
.plabel::before{ content:""; width:7px; height:7px; border-radius:50%; background:#fff; }
.plabel--blue{ background:var(--blue); }
.plabel--soft{ background:var(--green-soft); color:var(--green-700); }
.plabel--soft::before{ background:var(--green); }

.display{ font-size:clamp(40px,6.2vw,82px); letter-spacing:-.04em; font-weight:800; line-height:.98; }
.h1{ font-size:clamp(34px,5vw,62px); font-weight:800; letter-spacing:-.035em; }
.h2{ font-size:clamp(28px,3.7vw,48px); font-weight:800; letter-spacing:-.03em; }
.h3{ font-size:clamp(20px,2.1vw,27px); font-weight:700; letter-spacing:-.02em; }
.lead{ font-size:clamp(16.5px,1.35vw,19.5px); color:var(--muted); line-height:1.62; max-width:62ch; font-weight:500; }
.muted{ color:var(--muted); }

.section-head{ max-width:760px; }
.section-head .h2{ margin-top:10px; }
.section-head .lead{ margin-top:13px; }
.section-head.center{ margin-inline:auto; }
.section-head.center .lead{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55em; justify-content:center;
  font-family:var(--font-head); font-weight:700; font-size:15px; letter-spacing:-.01em;
  padding:14px 16px 14px 24px; border-radius:var(--r-pill); border:1.5px solid transparent;
  transition:transform .18s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-2px); }
/* circular arrow chip (TRoo cue) */
.btn .chip{ width:26px; height:26px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.22); transition:transform .2s; }
.btn:hover .chip{ transform:translateX(3px); }
.btn .chip svg{ width:13px; height:13px; }
.btn--primary{ background:var(--blue); color:#fff; box-shadow:0 12px 26px -12px rgba(39,102,224,.8); }
.btn--primary:hover{ background:var(--blue-600); }
.btn--green{ background:var(--green); color:#fff; box-shadow:0 12px 26px -12px rgba(31,158,81,.75); }
.btn--green:hover{ background:var(--green-600); }
.btn--navy{ background:var(--navy); color:#fff; }
.btn--navy:hover{ background:var(--navy-2); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); padding-right:24px; }
.btn--ghost .chip{ background:var(--green-soft); color:var(--green-700); }
.btn--ghost:hover{ border-color:var(--green); color:var(--green-700); }
.btn--light{ background:#fff; color:var(--navy); }
.btn--light .chip{ background:var(--blue-soft); color:var(--blue); }
.btn--on-dark{ background:transparent; color:#fff; border-color:rgba(255,255,255,.3); padding-right:24px; }
.btn--on-dark .chip{ background:rgba(255,255,255,.16); }
.btn--on-dark:hover{ background:rgba(255,255,255,.08); }
.btn--lg{ padding:17px 18px 17px 30px; font-size:16px; }
.btn--sm{ padding:10px 18px; font-size:13.5px; }
.btn--block{ width:100%; }

.textlink{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--font-head);
  font-weight:700; color:var(--blue); font-size:15px; }
.textlink svg{ width:16px; height:16px; transition:transform .2s; }
.textlink:hover svg{ transform:translateX(4px); }
.textlink--green{ color:var(--green-700); }
.section--navy .textlink,.section--blue .textlink{ color:var(--gold); }

/* ---------- Badges / tags ---------- */
.pill{ display:inline-flex; align-items:center; gap:.5em; font-family:var(--font-head);
  font-weight:700; font-size:12px; letter-spacing:.02em; padding:6px 13px; border-radius:var(--r-pill);
  background:var(--green-soft); color:var(--green-700); }
.pill--blue{ background:var(--blue-soft); color:var(--blue-700); }
.pill--gold{ background:var(--gold-soft); color:#9a6a08; }
.pill--outline{ background:transparent; border:1px solid var(--line); color:var(--muted); }
.tag{ font-family:var(--font-head); font-weight:700; font-size:11.5px; letter-spacing:.07em;
  text-transform:uppercase; color:var(--blue); }

/* ---------- Cards ---------- */
.card{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--green-line); }
.card__body{ padding:28px; }

/* Image placeholder (swap real photo in Divi) */
.ph{ position:relative; background:repeating-linear-gradient(135deg,#e8eef0 0 13px,#eef3f4 13px 26px);
  display:grid; place-items:center; color:#9aa6ad; overflow:hidden; }
.ph::after{ content:attr(data-label); font-family:ui-monospace,Menlo,monospace; font-size:11.5px;
  letter-spacing:.03em; color:#7f8c93; padding:6px 12px; background:rgba(255,255,255,.72);
  border-radius:6px; border:1px solid rgba(0,0,0,.05); text-align:center; max-width:80%; }
.ph img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.ratio-16x9{ aspect-ratio:16/9; } .ratio-4x3{ aspect-ratio:4/3; } .ratio-1x1{ aspect-ratio:1/1; }
.ratio-3x4{ aspect-ratio:3/4; } .ratio-3x2{ aspect-ratio:3/2; } .ratio-5x4{ aspect-ratio:5/4; }

/* ---------- Icon tile ---------- */
.itile{ width:58px; height:58px; border-radius:15px; display:grid; place-items:center;
  background:var(--green-soft); color:var(--green-700); flex:none; }
.itile svg{ width:27px; height:27px; }
.itile--blue{ background:var(--blue-soft); color:var(--blue); }
.itile--gold{ background:var(--gold-soft); color:#b9790a; }
.itile--navy{ background:var(--navy); color:var(--gold); }

/* ---------- Feature ---------- */
.feature{ display:flex; gap:16px; align-items:flex-start; }
.feature h3{ font-size:18.5px; margin-bottom:6px; }
.feature p{ color:var(--muted); font-size:15px; }
.feature--tick{ gap:13px; }
.feature--tick .tk{ flex:none; width:24px; height:24px; margin-top:2px; border-radius:50%;
  background:var(--green-soft); display:grid; place-items:center; color:var(--green-700); }
.feature--tick .tk svg{ width:14px; height:14px; }

/* ---------- Stat ---------- */
.stat__num{ font-family:var(--font-head); font-weight:800; font-size:clamp(38px,4.6vw,58px);
  letter-spacing:-.04em; line-height:1; color:var(--navy); }
.section--navy .stat__num,.section--blue .stat__num{ color:#fff; }
.stat__num .u{ color:var(--blue); }
.section--navy .stat__num .u{ color:var(--gold); }
.stat__label{ margin-top:9px; color:var(--muted); font-size:14px; font-weight:600; }
.section--navy .stat__label,.section--blue .stat__label{ color:rgba(255,255,255,.7); }

/* ---------- Checklist ---------- */
.checklist li{ display:flex; gap:12px; align-items:flex-start; padding:7px 0; font-weight:500; color:var(--body); }
.checklist li::before{ content:""; flex:none; width:22px; height:22px; margin-top:2px; border-radius:50%;
  background:var(--green-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23178a45' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/13px no-repeat; }

/* ============================================================
   HEADER  (Divi Theme Builder → Global Header)
   ============================================================ */
.eyebar{ background:var(--footer); color:#aebbcd; font-size:13px; }
.eyebar .wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; min-height:42px; }
.eyebar a:hover{ color:#fff; }
.eyebar__left{ display:flex; gap:22px; align-items:center; flex-wrap:wrap; }
.eyebar__item{ display:inline-flex; align-items:center; gap:7px; }
.eyebar__item svg{ width:14px; height:14px; color:var(--gold); }
.eyebar__social{ display:flex; gap:14px; }
.eyebar__social a{ opacity:.78; } .eyebar__social a:hover{ opacity:1; }
.eyebar__social svg{ width:14px; height:14px; }
@media(max-width:820px){ .eyebar{ display:none; } }

.nav{ position:sticky; top:0; z-index:60; background:rgba(255,255,255,.93);
  backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav__row{ display:flex; align-items:center; gap:26px; min-height:76px; }
.nav__menu{ display:flex; align-items:center; gap:2px; margin-left:6px; }
.nav__link{ position:relative; display:inline-flex; align-items:center; gap:5px;
  font-family:var(--font-head); font-weight:600; font-size:14.5px; color:var(--navy);
  padding:9px 13px; border-radius:9px; transition:color .16s, background .16s; }
.nav__link:hover{ color:var(--blue); background:var(--blue-soft); }
.nav__link svg{ width:12px; height:12px; opacity:.55; }
.nav__right{ margin-left:auto; display:flex; align-items:center; gap:16px; }
.nav__search{ width:42px; height:42px; border-radius:50%; border:1px solid var(--line);
  background:#fff; display:grid; place-items:center; color:var(--navy); }
.nav__search:hover{ border-color:var(--blue); color:var(--blue); }
.nav__search svg{ width:17px; height:17px; }

/* Logo (real wordmark image) */
.logo{ display:inline-flex; align-items:center; line-height:0; }
.logo img{ height:30px; width:auto; display:block; }
.logo--sm img{ height:25px; }

/* Mega menu */
.has-mega{ position:static; }
.mega{ position:absolute; left:50%; transform:translateX(-50%) translateY(10px);
  top:calc(100% - 1px); width:min(940px, calc(100vw - 40px)); background:#fff;
  border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  padding:24px; opacity:0; visibility:hidden; transition:opacity .2s, transform .2s; z-index:70; }
.has-mega:hover .mega{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.mega__grid{ display:grid; grid-template-columns:1fr 1fr 1fr 1.05fr; gap:6px; }
.mega__item{ display:flex; gap:12px; align-items:flex-start; padding:11px 12px; border-radius:12px; transition:background .16s; }
.mega__item:hover{ background:var(--mist); }
.mega__item .itile{ width:40px; height:40px; border-radius:10px; }
.mega__item .itile svg{ width:19px; height:19px; }
.mega__item b{ font-family:var(--font-head); font-weight:700; font-size:14px; color:var(--navy); display:block; }
.mega__item span{ font-size:12px; color:var(--muted); line-height:1.4; display:block; margin-top:2px; }
.mega__promo{ background:var(--navy); border-radius:var(--r); padding:20px; color:#fff;
  display:flex; flex-direction:column; justify-content:flex-end; gap:4px; }
.mega__promo .eyebrow{ color:var(--gold); } .mega__promo .eyebrow::before{ color:#fff; }
.mega__promo h4{ color:#fff; font-size:18px; margin:8px 0 12px; }

.burger{ display:none; width:46px; height:46px; border-radius:11px; border:1px solid var(--line);
  background:#fff; flex-direction:column; align-items:center; justify-content:center; gap:4px; }
.burger span{ width:20px; height:2px; background:var(--navy); border-radius:2px; }
@media(max-width:1120px){ .nav__menu{ display:none; } .burger{ display:flex; } }
@media(max-width:520px){ .nav__search{ display:none; } }

/* Mobile drawer */
.drawer{ position:fixed; inset:0; z-index:200; visibility:hidden; }
.drawer.open{ visibility:visible; }
.drawer__sc{ position:absolute; inset:0; background:rgba(12,26,53,.5); opacity:0; transition:opacity .25s; }
.drawer.open .drawer__sc{ opacity:1; }
.drawer__panel{ position:absolute; top:0; right:0; height:100%; width:min(360px,86vw); background:#fff;
  transform:translateX(100%); transition:transform .28s ease; padding:22px; overflow-y:auto; }
.drawer.open .drawer__panel{ transform:none; }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.drawer__close{ width:42px; height:42px; border-radius:50%; border:1px solid var(--line); background:#fff;
  display:grid; place-items:center; }
.drawer__link{ display:block; font-family:var(--font-head); font-weight:700; font-size:18px; color:var(--navy);
  padding:14px 4px; border-bottom:1px solid var(--line); }

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.pagehero{ position:relative; overflow:hidden; background:var(--navy); color:#c3ccda; }
.pagehero__bg{ position:absolute; inset:0; }
.pagehero__bg img{ width:100%; height:100%; object-fit:cover; opacity:.32; }
.pagehero::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,34,63,.7), rgba(20,34,63,.92)); }
.pagehero .wrap{ position:relative; z-index:2; padding-block:clamp(56px,8vw,104px); text-align:center; }
.pagehero h1{ color:#fff; margin-inline:auto; }
.pagehero .lead{ color:rgba(255,255,255,.78); margin:16px auto 0; }
.crumbs{ display:inline-flex; gap:9px; align-items:center; font-size:13.5px; color:rgba(255,255,255,.7);
  font-family:var(--font-head); font-weight:600; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14); padding:9px 18px; border-radius:var(--r-pill); margin-bottom:22px; }
.crumbs a:hover{ color:var(--gold); }
.crumbs .sep{ opacity:.5; }
.crumbs .cur{ color:var(--gold); }

/* ============================================================
   FOOTER  (Divi Theme Builder → Global Footer)
   ============================================================ */
.footer{ background:var(--footer); color:#9fadc2; padding-top:clamp(54px,7vw,86px); }
.footer h5{ color:#fff; font-family:var(--font-head); font-size:13px; letter-spacing:.1em;
  text-transform:uppercase; margin-bottom:18px; font-weight:700; }
.footer a{ color:#9fadc2; display:inline-block; padding:5px 0; transition:color .16s, transform .16s; }
.footer a:hover{ color:#fff; transform:translateX(3px); }
.footer__top{ display:grid; grid-template-columns:1.5fr 1fr 1.1fr 1.1fr 1.1fr; gap:36px;
  padding-bottom:46px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer__brand .logo{ margin-bottom:18px; }
.footer__brand p{ color:#8493aa; font-size:14.5px; max-width:32ch; }
.footer__social{ display:flex; gap:10px; margin-top:20px; }
.footer__social a{ width:38px; height:38px; border-radius:50%; border:1px solid rgba(255,255,255,.16);
  display:grid; place-items:center; padding:0; }
.footer__social a:hover{ background:var(--blue); border-color:var(--blue); transform:none; }
.footer__social svg{ width:16px; height:16px; }
.footer__loc{ font-size:14px; margin-bottom:15px; line-height:1.5; }
.footer__loc b{ color:#fff; font-family:var(--font-head); display:block; font-size:13.5px;
  margin-bottom:4px; letter-spacing:.02em; }
.footer__bottom{ display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding-block:24px; font-size:13px; color:#74839b; flex-wrap:wrap; }
.footer__bottom a:hover{ color:#fff; }
@media(max-width:920px){ .footer__top{ grid-template-columns:1fr 1fr 1fr; } }
@media(max-width:560px){ .footer__top{ grid-template-columns:1fr 1fr; gap:28px; } }

/* ---------- CTA band ---------- */
.ctaband{ position:relative; overflow:hidden; background:var(--navy); border-radius:var(--r-lg);
  padding:clamp(34px,5vw,62px); color:#c3ccda; }
.ctaband::before{ content:""; position:absolute; inset:0;
  background:radial-gradient(600px 320px at 100% 0%, rgba(39,102,224,.4), transparent 62%),
             radial-gradient(420px 280px at 0% 120%, rgba(31,158,81,.28), transparent 60%); }
.ctaband__inner{ position:relative; display:flex; align-items:center; justify-content:space-between;
  gap:30px; flex-wrap:wrap; }
.ctaband h2{ color:#fff; max-width:18ch; } .ctaband p{ color:rgba(255,255,255,.8); margin-top:10px; max-width:46ch; }

/* ---------- Accordion ---------- */
.acc{ border:1px solid var(--line); border-radius:var(--r); background:#fff; overflow:hidden; }
.acc + .acc{ margin-top:14px; }
.acc__q{ width:100%; text-align:left; display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:21px 25px; font-family:var(--font-head); font-weight:700; font-size:17px;
  color:var(--navy); background:none; border:none; }
.acc__q .pm{ flex:none; width:30px; height:30px; border-radius:50%; background:var(--blue-soft);
  display:grid; place-items:center; color:var(--blue); transition:transform .25s, background .2s, color .2s; }
.acc__q .pm svg{ width:16px; height:16px; }
.acc__a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.acc__a p{ padding:0 25px 23px; color:var(--muted); }
.acc.open .acc__q .pm{ transform:rotate(45deg); background:var(--blue); color:#fff; }

/* ---------- Form ---------- */
.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-family:var(--font-head); font-weight:700; font-size:13px; color:var(--navy); }
.field input,.field select,.field textarea{ font:inherit; font-size:15px; padding:13px 15px;
  border:1.5px solid var(--line); border-radius:11px; background:#fff; color:var(--navy);
  transition:border-color .16s, box-shadow .16s; width:100%; }
.field textarea{ resize:vertical; min-height:128px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(39,102,224,.12); }
.field input::placeholder,.field textarea::placeholder{ color:#9aa6ad; }

/* ---------- Process step ---------- */
.step{ position:relative; padding:30px 26px; background:#fff; border:1px solid var(--line);
  border-radius:var(--r-lg); transition:transform .2s, box-shadow .2s; }
.step:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.step__n{ font-family:var(--font-head); font-weight:800; font-size:15px; color:var(--blue);
  width:48px; height:48px; border-radius:13px; border:2px solid var(--blue-soft);
  display:grid; place-items:center; margin-bottom:18px; }
.step h3{ font-size:19px; margin-bottom:8px; }
.step p{ color:var(--muted); font-size:14.5px; }

/* ---------- Testimonial ---------- */
.quote{ background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:30px; }
.quote__stars{ display:flex; gap:3px; color:var(--gold); margin-bottom:15px; }
.quote__stars svg{ width:17px; height:17px; }
.quote p{ font-size:16px; color:var(--navy); line-height:1.6; }
.quote__by{ display:flex; align-items:center; gap:13px; margin-top:20px; padding-top:18px; border-top:1px solid var(--line); }
.quote__by .av{ width:46px; height:46px; border-radius:50%; background:var(--blue-soft);
  display:grid; place-items:center; color:var(--blue); font-family:var(--font-head); font-weight:800; flex:none; }
.quote__by b{ font-family:var(--font-head); color:var(--navy); display:block; font-size:14.5px; }
.quote__by span{ font-size:12.5px; color:var(--muted); }

/* ---------- Decorative dotted grid (TRoo cue) ---------- */
.dots{ background-image:radial-gradient(var(--green) 1.6px, transparent 1.6px); background-size:16px 16px;
  opacity:.5; }

/* ---------- Utilities ---------- */
.mt-1{ margin-top:10px; } .mt-2{ margin-top:20px; } .mt-3{ margin-top:32px; } .mt-4{ margin-top:44px; }
.mb-2{ margin-bottom:20px; } .mb-3{ margin-bottom:32px; }
.wrap-btns{ display:flex; gap:14px; flex-wrap:wrap; }
.flex{ display:flex; } .items-center{ align-items:center; } .between{ justify-content:space-between; }
.gap-2{ gap:16px; } .gap-3{ gap:24px; } .wrap-w{ flex-wrap:wrap; }
@media(max-width:640px){ .hide-mob{ display:none !important; } }
.fadein{ opacity:0; transform:translateY(18px); }
.fadein.in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
@media(prefers-reduced-motion:reduce){ .fadein{ opacity:1 !important; transform:none !important; } }
