/* ============================================================
   MARIGOLD — Home Cleaning theme
   Style: "Warm Hearth Botanical" — cream paper + deep forest
   green dark sections, coral CTA, gold accent word.
   Fonts: Fraunces (display serif) + Inter (body).
   Vanilla CSS, no frameworks. All tokens as vars below.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --paper:#FCF8F2;      /* page background, warm near-white */
  --cream:#F4EBDB;      /* alt section background */
  --cream-2:#EFE3D0;    /* deeper cream */
  --card:#FFFFFF;
  --ink:#1B2A22;        /* headings */
  --body:#4B584F;       /* body text */
  --muted:#808C83;      /* meta / small */
  --forest:#103B2F;     /* dark sections + brand */
  --forest-2:#0C2E25;   /* darkest (topbar) */
  --forest-soft:#1A4D3D;/* cards/hover on dark */
  --coral:#ED7A55;      /* primary CTA */
  --coral-d:#E4663C;    /* CTA hover */
  --gold:#DDA23E;       /* accent word, stars, code */
  --gold-soft:#EFC988;
  --on-forest:#EAF1EC;  /* text on dark */
  --on-forest-mut:#A9C2B6;
  --line:rgba(27,42,34,.12);
  --line-2:rgba(27,42,34,.08);
  --line-d:rgba(255,255,255,.14);
  --tint:#E6EFE7;       /* light green pill bg */
  --ring:rgba(237,122,85,.40);

  --sh-1:0 2px 10px rgba(16,40,30,.05);
  --sh-2:0 16px 44px -18px rgba(16,40,30,.24);
  --sh-3:0 34px 80px -34px rgba(16,40,30,.50);

  --r:18px;
  --r-s:12px;
  --r-l:28px;
  --r-xl:36px;

  --disp:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;

  --wrap:1200px;
  --gut:clamp(20px,5vw,40px);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:clip}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
h1,h2,h3,h4{
  font-family:var(--disp);
  color:var(--ink);
  font-weight:500;
  font-optical-sizing:auto;
  line-height:1.08;
  letter-spacing:-.01em;
  margin:0 0 .5em;
}
h1{font-size:clamp(2.5rem,6vw,4.4rem)}
h2{font-size:clamp(2rem,4.2vw,3.1rem)}
h3{font-size:1.35rem;line-height:1.18}
p{margin:0 0 1rem}
em{font-style:italic}
::selection{background:var(--coral);color:#fff}
:focus-visible{outline:3px solid var(--ring);outline-offset:3px;border-radius:6px}

.skip{position:absolute;left:-9999px;top:0;background:var(--forest);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;z-index:200}
.skip:focus{left:0}

/* ---------- Layout ---------- */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 var(--gut)}
.section{padding:clamp(64px,9vw,118px) 0}
.section--cream{background:var(--cream)}
.section--ink{background:var(--forest);color:var(--on-forest);position:relative;overflow:hidden}
.section--ink h1,.section--ink h2,.section--ink h3,.section--ink h4{color:#fff}
.section--tight{padding:clamp(48px,6vw,80px) 0}
.mt-1{margin-top:1rem}.mt-2{margin-top:1.6rem}.mt-3{margin-top:2.4rem}

/* aggregate glow on dark sections */
.section--ink::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(60% 90% at 88% -10%,rgba(221,162,62,.16),transparent 60%),
    radial-gradient(50% 80% at 6% 110%,rgba(237,122,85,.14),transparent 60%);
}
.section--ink>*{position:relative;z-index:1}

/* ---------- Section heads ---------- */
.sec-head{max-width:660px;margin-bottom:clamp(34px,5vw,56px)}
.sec-head--center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head--row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;max-width:none}
.sec-head h2{margin:.15em 0 0}
.sec-head .lead{margin-top:.8rem}
.lead{font-size:1.12rem;color:var(--body)}
.section--ink .lead,.section--ink p{color:var(--on-forest-mut)}

.kicker{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--sans);font-weight:600;font-size:.74rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--forest);background:var(--tint);
  padding:.5em 1em;border-radius:999px;
}
.kicker::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}
.section--ink .kicker{color:var(--gold-soft);background:rgba(255,255,255,.07)}
.section--ink .kicker::before{background:var(--gold)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--coral);--fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;white-space:nowrap;
  font-family:var(--sans);font-weight:600;font-size:.97rem;line-height:1;
  padding:.95em 1.5em;border-radius:999px;border:1.6px solid transparent;
  background:var(--bg);color:var(--fg);cursor:pointer;
  box-shadow:0 12px 26px -12px rgba(237,122,85,.75);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease,border-color .18s ease;
}
.btn:hover{background:var(--coral-d);transform:translateY(-2px);box-shadow:0 18px 34px -14px rgba(237,122,85,.85)}
.btn .ar{transition:transform .18s ease}
.btn:hover .ar{transform:translateX(4px)}
.btn--forest{--bg:var(--forest);box-shadow:0 12px 26px -14px rgba(16,40,30,.6)}
.btn--forest:hover{--bg:var(--forest-soft);box-shadow:0 18px 34px -16px rgba(16,40,30,.7)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border-color:var(--line);box-shadow:none}
.btn--ghost:hover{--bg:var(--ink);--fg:#fff;border-color:var(--ink);transform:translateY(-2px)}
.btn--ghost-l{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.34);box-shadow:none}
.btn--ghost-l:hover{--bg:#fff;--fg:var(--forest);border-color:#fff;transform:translateY(-2px)}
.btn--block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}

.stars{color:var(--gold);letter-spacing:.12em;font-size:.95rem}

/* ---------- Topbar ---------- */
.topbar{background:var(--forest-2);color:var(--on-forest)}
.topbar-in{
  max-width:var(--wrap);margin:0 auto;padding:9px var(--gut);
  display:flex;align-items:center;justify-content:center;gap:10px;
  font-size:.84rem;text-align:center;
}
.tb-l{color:var(--on-forest-mut)}
.tb-l b{color:#fff;font-weight:600}
.tb-code{color:var(--gold);font-weight:700;letter-spacing:.04em}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:90;background:rgba(252,248,242,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line-2)}
.header-in{max-width:var(--wrap);margin:0 auto;padding:14px var(--gut);display:flex;align-items:center;gap:16px}
.logo{display:inline-flex;align-items:center;gap:11px;flex-shrink:0}
.logo-mark{
  width:42px;height:42px;border-radius:13px;flex-shrink:0;
  display:grid;place-items:center;color:#fff;
  background:linear-gradient(150deg,var(--forest),var(--forest-soft));
  box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.08),0 8px 18px -10px rgba(16,40,30,.6);
}
.logo-mark svg{width:23px;height:23px}
.logo-txt{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:var(--disp);font-weight:600;font-size:1.42rem;color:var(--ink);letter-spacing:-.01em}
.logo-sub{font-family:var(--sans);font-weight:600;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);margin-top:3px}

.nav{list-style:none;display:flex;align-items:center;gap:2px;margin:0 auto 0 8px;padding:0}
.nav>li{position:relative}
.nav>li>a{display:inline-flex;align-items:center;gap:.4em;padding:.5em .64em;font-weight:500;font-size:.92rem;color:var(--ink);border-radius:9px;white-space:nowrap;transition:color .15s ease,background .15s ease}
.nav>li>a:hover{color:var(--forest);background:var(--tint)}
.nav>li>a.is-active{color:var(--forest)}
.nav>li>a.is-active::after{content:"";position:absolute;left:.8em;right:.8em;bottom:.18em;height:2px;background:var(--coral);border-radius:2px}
.crt{font-size:.5rem;opacity:.6;transition:transform .2s ease}
.has-sub:hover .crt{transform:rotate(180deg)}
.sub{
  position:absolute;top:calc(100% + 10px);left:0;min-width:248px;list-style:none;margin:0;padding:8px;
  background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-2);
  opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s ease;z-index:50;
}
.has-sub:hover .sub{opacity:1;visibility:visible;transform:translateY(0)}
.sub li a{display:block;padding:.66em .85em;border-radius:10px;font-size:.93rem;font-weight:500;color:var(--body)}
.sub li a:hover{background:var(--tint);color:var(--forest)}

.head-r{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0}
.head-tel{display:inline-flex;align-items:center;gap:.45em;font-weight:600;font-size:1rem;color:var(--ink);white-space:nowrap}
.head-tel span{color:var(--coral)}
.head-tel:hover{color:var(--forest)}

.burger{display:none;width:46px;height:46px;border:1px solid var(--line);background:var(--card);border-radius:12px;cursor:pointer;padding:0;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.burger b{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s ease}
.burger.is-open b:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open b:nth-child(2){opacity:0}
.burger.is-open b:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Mobile menu ---------- */
.m-menu{position:fixed;inset:0 0 0 auto;width:min(380px,90vw);background:var(--paper);z-index:120;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:var(--sh-3);overflow-y:auto;visibility:hidden}
.m-menu.is-open{transform:translateX(0);visibility:visible}
.m-nav{display:flex;flex-direction:column;padding:84px 22px 14px}
.m-nav a{display:block;padding:.74em .4em;font-weight:600;font-size:1.12rem;color:var(--ink);border-bottom:1px solid var(--line-2)}
.m-nav a.m-sub{font-size:1rem;font-weight:500;color:var(--body);padding-left:1.1em}
.m-group .m-parent{display:flex;align-items:center;justify-content:space-between}
.m-group .m-parent::after{content:"⌄";font-size:1.1rem;color:var(--coral);transition:transform .25s ease;line-height:1}
.m-group.is-open .m-parent::after{transform:rotate(180deg)}
.m-subwrap{display:flex;flex-direction:column;overflow:hidden;max-height:0;transition:max-height .3s ease}
.m-group.is-open .m-subwrap{max-height:420px}
.m-foot{margin-top:auto;padding:20px 22px 28px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:14px}
.m-tel{display:inline-flex;align-items:center;gap:.5em;font-weight:700;font-size:1.15rem;color:var(--forest)}
.m-tel span{color:var(--coral)}
.m-menu .btn{display:flex;justify-content:center;text-align:center}
.m-close{position:absolute;top:14px;right:16px;width:42px;height:42px;border:none;background:var(--tint);color:var(--forest);border-radius:12px;font-size:1.7rem;line-height:1;cursor:pointer;display:grid;place-items:center;padding:0;transition:background .15s ease,color .15s ease}
.m-close:hover{background:var(--coral);color:#fff}

/* ---------- HERO (full-bleed) ---------- */
.hero{position:relative;isolation:isolate;min-height:clamp(560px,86vh,820px);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2}
.hero-bg .ph{position:absolute;inset:0;border-radius:0;aspect-ratio:auto;height:100%}
.hero-veil{position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(11,30,24,.62),rgba(11,30,24,.32) 42%,rgba(11,30,24,.72))}
.hero-in{max-width:880px;padding:clamp(80px,12vh,130px) var(--gut) clamp(40px,7vh,72px)}
.hero-pill{display:inline-flex;align-items:center;gap:.55em;font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px);padding:.55em 1.1em;border-radius:999px}
.hero-pill::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(221,162,62,.28)}
.hero h1{color:#fff;margin:.5em 0 .35em;font-size:clamp(2.7rem,6.6vw,5rem);font-weight:500;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero h1 em{color:var(--gold);font-style:italic}
.hero-sub{font-size:clamp(1.05rem,2vw,1.28rem);color:rgba(255,255,255,.92);max-width:620px;margin:0 auto 1.8em;line-height:1.55}
.hero .btn-row{justify-content:center}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:clamp(20px,5vw,54px);margin-top:clamp(34px,5vw,52px);padding-top:clamp(26px,4vw,38px);border-top:1px solid rgba(255,255,255,.18)}
.hstat{text-align:center}
.hstat-n{font-family:var(--disp);font-weight:600;font-size:clamp(1.6rem,3vw,2.2rem);color:#fff;line-height:1}
.hstat-n em{color:var(--gold);font-style:normal}
.hstat-t{font-size:.74rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:7px}

.ph--hero{background:linear-gradient(150deg,#13362b,#0b231c);border:none;color:rgba(255,255,255,.6)}
.ph--hero .ph-tag{background:rgba(255,255,255,.14);color:#fff}
.ph--hero .ph-dim{color:rgba(255,255,255,.7)}
.ph--hero .ph-prompt{color:rgba(255,255,255,.55);border-color:rgba(255,255,255,.2)}

/* ---------- Featured strip ---------- */
.featured{background:var(--paper);border-bottom:1px solid var(--line-2)}
.featured-in{max-width:var(--wrap);margin:0 auto;padding:26px var(--gut);display:flex;align-items:center;gap:clamp(18px,4vw,48px);flex-wrap:wrap;justify-content:center}
.featured-label{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600}
.featured-logos{display:flex;align-items:center;gap:clamp(18px,4vw,46px);flex-wrap:wrap;justify-content:center}
.flogo{font-family:var(--disp);font-style:italic;font-size:1.12rem;color:var(--ink);opacity:.42;transition:opacity .2s ease}
.flogo:hover{opacity:.75}

/* ---------- Grids & cards ---------- */
.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}

.card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:30px 28px;box-shadow:var(--sh-1);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;display:flex;flex-direction:column}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-2);border-color:transparent}
.card .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:var(--tint);color:var(--forest);margin-bottom:18px}
.card .ic svg{width:27px;height:27px}
.card.is-feat .ic{background:var(--coral);color:#fff}
.card h3{margin-bottom:.4em}
.card p{font-size:.98rem;margin-bottom:1.1em}
.card-link{margin-top:auto;display:inline-flex;align-items:center;gap:.45em;font-weight:600;font-size:.92rem;color:var(--coral)}
.card-link i{font-style:normal;transition:transform .18s ease}
.card-link:hover i{transform:translateX(4px)}
.card-link:hover{color:var(--coral-d)}

/* ---------- Split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,72px);align-items:center}
.split--rev .split-media{order:-1}
.split-media{position:relative}

/* numbered feature list (why us / personal) */
.feat-list{list-style:none;margin:1.6rem 0 0;padding:0;display:flex;flex-direction:column;gap:20px}
.feat-item{display:flex;gap:16px}
.feat-no{flex-shrink:0;width:38px;height:38px;border-radius:11px;background:var(--forest);color:#fff;font-family:var(--disp);font-weight:600;font-size:1.05rem;display:grid;place-items:center}
.feat-tx b{display:block;color:var(--ink);font-weight:700;font-size:1.02rem;margin-bottom:2px}
.feat-tx p{margin:0;font-size:.96rem}
.section--ink .feat-no{background:var(--coral)}
.section--ink .feat-tx b{color:#fff}

/* hanging-indent tick list */
.ticks{list-style:none;margin:1.4rem 0 0;padding:0;display:flex;flex-direction:column;gap:13px}
.ticks li{position:relative;padding-left:34px;font-size:1rem}
.ticks li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23103B2F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:13px}
.ticks li b{color:var(--ink)}
.section--ink .ticks li{color:var(--on-forest-mut)}
.section--ink .ticks li b{color:#fff}
.section--ink .ticks li::before{background-color:rgba(255,255,255,.1);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23EFC988' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E")}

.chiprow{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.5rem}
.tagchip{display:inline-flex;align-items:center;gap:.45em;font-size:.88rem;font-weight:500;color:var(--body);background:var(--card);border:1px solid var(--line);padding:.5em .9em;border-radius:999px}
.tagchip b{color:var(--forest);font-weight:700}
.section--ink .tagchip{background:rgba(255,255,255,.06);border-color:var(--line-d);color:var(--on-forest)}
.section--ink .tagchip b{color:var(--gold-soft)}

/* floating media card on images */
.frame{border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-2)}
.media-card{position:absolute;left:20px;bottom:20px;right:20px;max-width:330px;display:flex;align-items:center;gap:13px;background:var(--card);border-radius:16px;padding:14px 16px;box-shadow:var(--sh-2)}
.mc-ic{flex-shrink:0;width:40px;height:40px;border-radius:11px;background:var(--coral);color:#fff;display:grid;place-items:center;font-size:1.1rem}
.mc-l{font-weight:700;color:var(--ink);font-size:.96rem;line-height:1.2}
.mc-s{font-size:.84rem;color:var(--muted)}
.media-pill{position:absolute;top:18px;right:18px;background:rgba(252,248,242,.94);backdrop-filter:blur(6px);border-radius:14px;padding:10px 14px;box-shadow:var(--sh-2);text-align:center}
.media-pill b{display:block;font-family:var(--disp);font-weight:600;font-size:1.2rem;color:var(--ink);line-height:1}
.media-pill small{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* ---------- Before / After slider ---------- */
.ba{position:relative;aspect-ratio:4/3;border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-2);user-select:none;touch-action:pan-y;--pos:50%}
.ba-pane{position:absolute;inset:0}
.ba-pane .ph{position:absolute;inset:0;border-radius:0;aspect-ratio:auto;height:100%}
.ba-after{z-index:1}
.ba-before{z-index:2;clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba-tag{position:absolute;bottom:16px;font-size:.7rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#fff;background:rgba(11,30,24,.66);backdrop-filter:blur(4px);padding:.45em .9em;border-radius:999px;z-index:3}
.ba-tag--before{left:16px}
.ba-tag--after{right:16px}
.ba-handle{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:rgba(255,255,255,.9);transform:translateX(-1px);z-index:4;pointer-events:none}
.ba-knob{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;color:var(--forest);display:grid;place-items:center;font-size:1.1rem;font-weight:700;box-shadow:var(--sh-2)}
.ba-range{position:absolute;inset:0;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;z-index:5}
.ba-range::-webkit-slider-thumb{-webkit-appearance:none;width:54px;height:100%;cursor:ew-resize}
.ba-range::-moz-range-thumb{width:54px;height:100%;border:0;background:transparent;cursor:ew-resize}

/* ---------- Steps (how it works) ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;background:var(--forest-soft);border:1px solid var(--line-d);border-radius:var(--r);padding:30px 26px}
.step-no{font-family:var(--disp);font-weight:600;font-size:2.4rem;color:var(--gold);line-height:1;display:block;margin-bottom:14px;opacity:.92}
.step h3{font-size:1.18rem;margin-bottom:.4em}
.step p{font-size:.95rem;margin:0;color:var(--on-forest-mut)}

/* ---------- Guarantee band ---------- */
.guarantee{background:var(--coral);border-radius:var(--r-l);padding:clamp(34px,5vw,56px);display:flex;align-items:center;gap:clamp(26px,4vw,48px);color:#fff;box-shadow:var(--sh-2);position:relative;overflow:hidden}
.guarantee::after{content:"";position:absolute;right:-40px;top:-40px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.10)}
.g-seal{flex-shrink:0;width:120px;height:120px;border-radius:50%;border:3px dashed rgba(255,255,255,.6);display:grid;place-items:center;text-align:center;position:relative;z-index:1}
.g-seal b{font-family:var(--disp);font-weight:600;font-size:1.7rem;line-height:.95}
.g-seal small{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;opacity:.9}
.g-tx{position:relative;z-index:1}
.g-tx h2{color:#fff;margin-bottom:.3em}
.g-tx p{color:rgba(255,255,255,.92);margin:0;max-width:560px}

/* ---------- Pricing plans ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.plan{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r-l);padding:32px 30px;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}
.plan:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.plan.is-pop{border-color:var(--coral);box-shadow:var(--sh-2)}
.plan-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--coral);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.45em 1em;border-radius:999px}
.plan-name{font-family:var(--disp);font-weight:600;font-size:1.4rem;color:var(--ink)}
.plan-price{font-family:var(--disp);font-weight:600;font-size:2.8rem;color:var(--ink);line-height:1;margin:.25em 0 0}
.plan-price small{font-family:var(--sans);font-size:.95rem;font-weight:500;color:var(--muted)}
.plan-per{font-size:.9rem;color:var(--muted);margin-bottom:1.1em}
.plan-feats{list-style:none;margin:.4em 0 1.6em;padding:1.3em 0 0;border-top:1px solid var(--line-2);display:flex;flex-direction:column;gap:11px;flex-grow:1}
.plan-feats li{position:relative;padding-left:28px;font-size:.95rem}
.plan-feats li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:var(--tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23103B2F' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:11px}

/* ---------- Quotes / reviews ---------- */
.quote{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:28px 26px;box-shadow:var(--sh-1);display:flex;flex-direction:column;gap:14px}
.quote p{font-size:1.02rem;color:var(--ink);margin:0;line-height:1.55}
.quote-by{display:flex;align-items:center;gap:12px;margin-top:auto}
.quote-av{width:44px;height:44px;border-radius:50%;background:var(--forest);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.9rem;flex-shrink:0}
.quote-by b{display:block;color:var(--ink);font-size:.95rem}
.quote-by small{color:var(--muted);font-size:.84rem}
.section--ink .quote{background:rgba(255,255,255,.05);border-color:var(--line-d)}
.section--ink .quote p{color:#fff}
.section--ink .quote-by b{color:#fff}
.section--ink .quote-by small{color:var(--on-forest-mut)}
.section--ink .quote-av{background:var(--coral)}

/* ---------- City list ---------- */
.citylist{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.4rem}

/* ---------- Blog cards ---------- */
.post-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-1);transition:transform .2s ease,box-shadow .2s ease}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.post-card .ph{border-radius:0}
.post-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex-grow:1}
.post-meta{font-size:.8rem;color:var(--muted);letter-spacing:.02em;margin-bottom:.6em}
.post-meta b{color:var(--coral);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem}
.post-card h3{font-size:1.24rem;margin-bottom:.4em}
.post-card p{font-size:.95rem;margin-bottom:1.1em}
.post-card .card-link{padding:0 24px 24px}
.post-body .card-link{padding:0}

/* featured blog card */
.card--featured{display:grid;grid-template-columns:1.1fr 1fr;gap:0;overflow:hidden}
.card--featured .ph{height:100%;border-radius:0}
.card--featured .post-body{padding:clamp(28px,4vw,48px);justify-content:center}
.card--featured h3{font-size:clamp(1.5rem,3vw,2.1rem)}

/* ---------- Page hero (interior) ---------- */
.pagehero{background:var(--forest);color:var(--on-forest);position:relative;overflow:hidden;padding:clamp(64px,9vw,108px) 0 clamp(56px,7vw,86px)}
.pagehero::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(55% 90% at 90% -10%,rgba(221,162,62,.18),transparent 60%),radial-gradient(46% 80% at 4% 120%,rgba(237,122,85,.16),transparent 60%)}
.pagehero-in{position:relative;z-index:1;max-width:780px}
.pagehero-in.is-center{margin:0 auto;text-align:center}
.crumbs{display:flex;flex-wrap:wrap;gap:.5em;font-size:.82rem;color:var(--on-forest-mut);margin-bottom:1.1em}
.crumbs a:hover{color:#fff}
.crumbs span{opacity:.5}
.pagehero h1{color:#fff;font-size:clamp(2.4rem,5.2vw,3.7rem)}
.pagehero h1 em{color:var(--gold);font-style:italic}
.pagehero p{color:var(--on-forest-mut);font-size:1.1rem;margin:.4em 0 0;max-width:600px}
.pagehero-in.is-center p{margin-left:auto;margin-right:auto}

/* ---------- Inclusions grid ---------- */
.inc{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 28px;margin-top:1.4rem}
.inc-item{position:relative;padding-left:32px;font-size:.98rem}
.inc-item::before{content:"";position:absolute;left:0;top:1px;width:22px;height:22px;border-radius:7px;background:var(--tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23103B2F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:13px}
.inc-item b{color:var(--ink)}

/* ---------- Spec table ---------- */
.spec-wrap{overflow-x:auto;margin-top:1.4rem;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-1)}
.spec{width:100%;border-collapse:collapse;min-width:420px;background:var(--card)}
.spec th,.spec td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--line-2);font-size:.95rem}
.spec thead th{background:var(--cream);color:var(--ink);font-family:var(--sans);font-weight:700;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase}
.spec tbody tr:last-child td{border-bottom:none}
.spec td:first-child{font-weight:600;color:var(--ink)}

/* ---------- FAQ accordions ---------- */
.faq-group{margin-bottom:clamp(34px,4vw,52px)}
.faq-group>h3{font-size:1.45rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--line)}
.acc{border:1px solid var(--line);border-radius:14px;background:var(--card);margin-bottom:12px;overflow:hidden;transition:box-shadow .2s ease,border-color .2s ease}
.acc.is-open{box-shadow:var(--sh-1);border-color:transparent}
.acc-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 54px 20px 22px;position:relative;font-family:var(--disp);font-weight:500;font-size:1.1rem;color:var(--ink);line-height:1.3}
.acc-q::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--coral);transition:transform .25s ease;font-family:var(--sans);font-weight:400}
.acc.is-open .acc-q::after{transform:translateY(-50%) rotate(45deg)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.acc-a-in{padding:0 22px 22px;color:var(--body);font-size:.98rem}
.acc-a-in p{margin:0}

/* ---------- Contact ---------- */
.split--form{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,60px);align-items:start}
.form{background:var(--card);border:1px solid var(--line);border-radius:var(--r-l);padding:clamp(26px,4vw,42px);box-shadow:var(--sh-1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px;display:flex;flex-direction:column}
.field label{font-weight:600;font-size:.86rem;color:var(--ink);margin-bottom:7px}
.field input,.field select,.field textarea{font-family:inherit;font-size:1rem;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:.78em .95em;width:100%;transition:border-color .15s ease,box-shadow .15s ease}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px var(--ring)}
.field textarea{resize:vertical;min-height:120px}
.form-note{font-size:.82rem;color:var(--muted);margin-top:4px}
.form-ok{display:none;background:var(--tint);border:1px solid var(--forest);color:var(--forest);border-radius:12px;padding:16px 18px;font-weight:500;margin-bottom:18px}
.form-ok.is-show{display:block}
.form-ok b{font-weight:700}

.contact-cards{display:flex;flex-direction:column;gap:16px}
.cinfo{display:flex;gap:15px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:20px 22px}
.cinfo-ic{flex-shrink:0;width:44px;height:44px;border-radius:12px;background:var(--tint);color:var(--forest);display:grid;place-items:center}
.cinfo-ic svg{width:21px;height:21px}
.cinfo h4{font-family:var(--sans);font-weight:700;font-size:.95rem;color:var(--ink);margin:0 0 3px}
.cinfo p{margin:0;font-size:.95rem}
.cinfo a{color:var(--coral);font-weight:600}

/* sidecard / info card */
.sidecard{background:var(--forest);color:var(--on-forest);border-radius:var(--r-l);padding:30px 28px;position:relative;overflow:hidden}
.sidecard::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 90% 0,rgba(221,162,62,.2),transparent 60%)}
.sidecard>*{position:relative;z-index:1}
.sidecard h3{color:#fff}
.sidecard ul{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.sidecard li{display:flex;gap:11px;font-size:.95rem;color:var(--on-forest-mut)}
.sidecard li b{color:#fff}

/* ---------- Next band (related CTA) ---------- */
.next-band{display:flex;align-items:center;justify-content:space-between;gap:24px;background:var(--cream);border:1px solid var(--line-2);border-radius:var(--r-l);padding:clamp(26px,4vw,40px)}
.next-band h3{margin:0 0 .25em}
.next-band p{margin:0;font-size:.98rem}

/* ---------- Article (blog single) ---------- */
.article{max-width:760px;margin:0 auto;font-size:1.08rem;line-height:1.75}
.article h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:1.8em 0 .5em}
.article h3{font-size:1.32rem;margin:1.5em 0 .4em}
.article p{margin:0 0 1.2em;color:var(--body)}
.article ul,.article ol{margin:0 0 1.3em;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.article ul li{position:relative;padding-left:32px}
.article ul li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23103B2F' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:13px}
.article ol{counter-reset:ai}
.article ol li{position:relative;padding-left:38px;counter-increment:ai}
.article ol li::before{content:counter(ai);position:absolute;left:0;top:0;width:26px;height:26px;border-radius:50%;background:var(--forest);color:#fff;font-size:.82rem;font-weight:700;display:grid;place-items:center}
.article blockquote{margin:1.6em 0;padding:6px 0 6px 26px;border-left:4px solid var(--coral);font-family:var(--disp);font-style:italic;font-size:1.3rem;color:var(--ink);line-height:1.4}
.article figure{margin:1.8em 0}
.article figcaption{font-size:.85rem;color:var(--muted);text-align:center;margin-top:.7em}
.article .ph{border-radius:var(--r)}

.article-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:1.6em;color:var(--muted);font-size:.9rem}
.article-meta .quote-av{width:40px;height:40px}
.article a{color:var(--coral);font-weight:600}
.article a:hover{color:var(--coral-d)}
.article-share{display:flex;gap:12px;align-items:center;margin-top:2em;padding-top:1.6em;border-top:1px solid var(--line)}
.article-share .soc a{background:var(--tint);color:var(--forest)}
.article-share .soc a:hover{background:var(--coral);color:#fff}
.faq-wrap{max-width:820px;margin:0 auto}

/* ---------- Newsletter ---------- */
.form--inline{display:grid;grid-template-columns:1fr auto;gap:12px;max-width:520px;margin:1.4rem auto 0}
.form--inline input{font-family:inherit;font-size:1rem;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:.85em 1.2em;color:var(--ink)}
.form--inline input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px var(--ring)}
.section--ink .form--inline input{background:rgba(255,255,255,.08);border-color:var(--line-d);color:#fff}
.section--ink .form--inline input::placeholder{color:var(--on-forest-mut)}

/* ---------- Placeholders ---------- */
.ph{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:9px;aspect-ratio:16/10;background:var(--cream);border:1.5px dashed rgba(16,40,30,.3);border-radius:var(--r);padding:22px;overflow:hidden;color:var(--body)}
.ph--169{aspect-ratio:16/9}
.ph--43{aspect-ratio:4/3}
.ph--11{aspect-ratio:1/1}
.ph--portrait{aspect-ratio:4/5}
.ph--wide{aspect-ratio:16/7}
.ph--map{aspect-ratio:16/11}
.ph-tag{font-family:var(--sans);font-weight:700;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);background:var(--tint);padding:.4em .85em;border-radius:999px}
.ph-dim{font-weight:600;font-size:.8rem;color:var(--muted)}
.ph-prompt{font-size:.78rem;line-height:1.45;color:var(--muted);max-width:90%;border-top:1px dashed var(--line);padding-top:9px;margin-top:2px}
.ph.has-image{border:none;padding:0;background:none}
.ph.has-image .ph-tag,.ph.has-image .ph-dim,.ph.has-image .ph-prompt{display:none}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:inherit}

/* ---------- foot CTA ---------- */
.foot-cta{background:var(--forest);color:#fff;position:relative;overflow:hidden}
.foot-cta::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(46% 90% at 88% -20%,rgba(221,162,62,.2),transparent 60%),radial-gradient(40% 80% at 6% 120%,rgba(237,122,85,.22),transparent 60%)}
.foot-cta-in{position:relative;z-index:1;max-width:var(--wrap);margin:0 auto;padding:clamp(56px,8vw,96px) var(--gut);display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:center}
.foot-cta h2{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.foot-cta h2 em{color:var(--gold);font-style:italic}
.foot-cta p{color:var(--on-forest-mut);margin:0;max-width:520px}
.foot-cta .btn-row{justify-content:flex-end}

/* ---------- Footer ---------- */
.footer{background:var(--forest-2);color:var(--on-forest-mut)}
.foot-grid{max-width:var(--wrap);margin:0 auto;padding:clamp(54px,7vw,80px) var(--gut) 40px;display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:40px}
.foot-brand .logo{margin-bottom:16px}
.foot-brand .logo-name{color:#fff}
.foot-brand p{font-size:.95rem;max-width:330px;margin:0 0 18px}
.soc{display:flex;gap:10px}
.soc a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:var(--on-forest);transition:background .18s ease,transform .18s ease}
.soc a:hover{background:var(--coral);transform:translateY(-2px)}
.soc svg{width:18px;height:18px}
.foot-h{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.13em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.foot-l,.foot-c{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.foot-l a:hover{color:#fff}
.foot-l a,.foot-c{font-size:.94rem}
.foot-c li b{color:#fff;font-weight:600}
.foot-c a{color:var(--gold-soft)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1)}
.foot-bottom-in{max-width:var(--wrap);margin:0 auto;padding:20px var(--gut);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem;color:var(--on-forest-mut)}

/* ---------- To top ---------- */
.totop{position:fixed;right:22px;bottom:22px;width:48px;height:48px;border-radius:50%;border:none;background:var(--forest);color:#fff;font-size:1.2rem;cursor:pointer;box-shadow:var(--sh-2);opacity:0;visibility:hidden;transform:translateY(12px);transition:.25s ease;z-index:80}
.totop.is-show{opacity:1;visibility:visible;transform:translateY(0)}
.totop:hover{background:var(--coral);transform:translateY(-3px)}

/* ---------- Reveal ---------- */
.rv{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
.rv.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}*{scroll-behavior:auto!important}}

/* ---------- Utilities & extra components ---------- */
.muted{color:var(--muted)}
.center{text-align:center}
.hstat-sep{width:1px;height:36px;background:rgba(255,255,255,.22);flex-shrink:0}

/* stat band */
.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.statc{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);padding:28px 22px;text-align:center;box-shadow:var(--sh-1)}
.statc-n{font-family:var(--disp);font-weight:600;font-size:clamp(2rem,4vw,2.7rem);color:var(--ink);line-height:1}
.statc-n em{color:var(--coral);font-style:normal}
.statc-t{font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.section--ink .statc{background:rgba(255,255,255,.05);border-color:var(--line-d)}
.section--ink .statc-n{color:#fff}
.section--ink .statc-t{color:var(--on-forest-mut)}

/* team */
.role{font-size:.88rem;color:var(--coral);font-weight:600;margin:.1em 0 0}
.team-card{background:var(--card);border:1px solid var(--line-2);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-1);transition:transform .2s ease,box-shadow .2s ease}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.team-card .ph{border-radius:0}
.tc-body{padding:18px 20px 22px}
.tc-body h3{font-size:1.14rem;margin:0}

/* projects / filter */
.chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:clamp(28px,4vw,46px)}
.chip{font-family:var(--sans);font-weight:600;font-size:.9rem;color:var(--body);background:var(--card);border:1px solid var(--line);padding:.55em 1.15em;border-radius:999px;cursor:pointer;transition:.18s ease}
.chip:hover{border-color:var(--coral);color:var(--coral)}
.chip.is-on{background:var(--forest);color:#fff;border-color:var(--forest)}
.proj-card{display:flex;flex-direction:column;gap:14px}
.proj-card.is-hide{display:none}
.proj-cap{display:flex;flex-direction:column}
.proj-cap b{color:var(--ink);font-weight:700;font-size:1.05rem}
.proj-cap span{color:var(--muted);font-size:.9rem}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1320px){
  .nav{display:none}
  .burger{display:flex}
  .head-tel{display:none}
}
@media (min-width:1321px){
  .m-menu{display:none}
}
@media (max-width:1040px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .statband{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .plans{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .foot-cta-in{grid-template-columns:1fr;gap:24px}
  .foot-cta .btn-row{justify-content:flex-start}
  .foot-grid{grid-template-columns:1fr 1fr;gap:34px}
}
@media (max-width:900px){
  .split{grid-template-columns:1fr;gap:36px}
  .split--rev .split-media{order:0}
  .split--form{grid-template-columns:1fr}
  .grid--3{grid-template-columns:1fr 1fr}
  .card--featured{grid-template-columns:1fr}
  .sec-head--row{flex-direction:column;align-items:flex-start}
  .guarantee{flex-direction:column;text-align:center}
  .g-tx p{margin-inline:auto}
  .next-band{flex-direction:column;align-items:flex-start}
}
@media (max-width:680px){
  body{font-size:16px}
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .inc{grid-template-columns:1fr}
  .hero-stats{flex-wrap:wrap;gap:20px 28px}
  .form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .featured-in{flex-direction:column;gap:14px}
  .form--inline{grid-template-columns:1fr}
  .form--inline .btn{width:100%}
}
@media (max-width:480px){
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom-in{flex-direction:column;text-align:center}
  .topbar-in{font-size:.78rem}
  .tb-l{display:none}
  .hero-stats .hstat-sep{display:none}
  .ba-tag{font-size:.62rem}
}
