/* ============================================================
   CABANA — Pool Service Theme (HTML draft)
   Demo business: Pebble & Palm Pool Co. — Phoenix, AZ
   Palette: navy ink / ice blue / sun yellow / pool cyan / coral
   Fonts: Baloo 2 (display) + Plus Jakarta Sans (body)
   Vanilla CSS — no frameworks. Class names map 1:1 to the
   future WordPress theme.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:#0A1C2E;          /* deepest navy — header, dark bands, footer */
  --ink-2:#0F2740;        /* panel navy */
  --ink-3:#143352;        /* raised navy */
  --paper:#FFFFFF;
  --ice:#EAF6FC;          /* light section background */
  --ice-2:#D9EEF9;        /* chips, icon bubbles */
  --sun:#FFC93C;          /* primary CTA yellow */
  --sun-2:#F4B71B;        /* CTA hover */
  --cyan:#1FB8DE;         /* pool cyan */
  --cyan-2:#0E8FB8;       /* deep cyan — text on light */
  --cyan-3:#7FD9F0;       /* cyan on dark */
  --coral:#FF6157;        /* pins, BEFORE tags — tiny doses */
  --text:#33475C;         /* body on light */
  --mut:#5E7286;          /* muted on light */
  --mut-d:#9FB6C8;        /* muted on dark */
  --line:#DBEAF3;         /* borders on light */
  --line-d:rgba(255,255,255,.14);
  --ph-bg:#F2F9FD;        /* placeholder bg light */
  --ph-bg-d:#11293F;      /* placeholder bg dark */
  --disp:'Baloo 2','Plus Jakarta Sans',system-ui,sans-serif;
  --body:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  --r:22px;
  --r-sm:14px;
  --e:cubic-bezier(.2,.7,.2,1);
  --shadow:0 18px 50px rgba(10,28,46,.12);
  --shadow-sm:0 8px 24px rgba(10,28,46,.08);
  --sun-glow:0 12px 28px rgba(255,201,60,.38);
  --cyan-glow:0 12px 28px rgba(31,184,222,.35);
  --wrap:1200px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--text);
  font:400 1rem/1.68 var(--body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
svg{display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
input,select,textarea{font:inherit}
ul,ol{margin:0;padding:0}
ul{list-style:none}
h1,h2,h3,h4,h5{margin:0;font-family:var(--disp);color:var(--ink);font-weight:700;line-height:1.15}
p{margin:0}
::selection{background:var(--cyan);color:#fff}
.skip{
  position:absolute;left:-999px;top:0;z-index:100;background:var(--sun);color:var(--ink);
  padding:.8em 1.2em;border-radius:0 0 12px 0;font-weight:800;
}
.skip:focus{left:0}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.sec{position:relative;padding:clamp(3.6rem,8vw,6.2rem) 0}
.sec--ice{background:var(--ice)}
.sec--dark{background:var(--ink);color:#fff}
.sec--tight{padding:clamp(2.2rem,5vw,3.4rem) 0}
.has-wave-b{padding-bottom:clamp(5.4rem,12vw,9rem)}
.has-wave-t{padding-top:clamp(5.4rem,12vw,9rem)}
.sec--dark>.wrap{position:relative;z-index:1}

/* bubble glows on dark sections */
.sec--dark::before,.page-hero::before,.info-card::before,.site-foot::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 12% 18%,rgba(31,184,222,.16),transparent 28%),
    radial-gradient(circle at 86% 80%,rgba(255,201,60,.08),transparent 30%),
    radial-gradient(circle at 82% 8%,rgba(31,184,222,.10),transparent 24%);
}

/* ---------- Waves ---------- */
.wave{
  position:absolute;left:0;right:0;bottom:-1px;width:100%;
  height:clamp(30px,6vw,66px);pointer-events:none;z-index:2;
}
.wave--top{bottom:auto;top:-1px;transform:scaleY(-1)}
.wave--paper path{fill:var(--paper)}
.wave--ice path{fill:var(--ice)}
.wave--ink path{fill:var(--ink)}

/* ---------- Type ---------- */
.h1{font:800 clamp(2.7rem,6.4vw,4.6rem)/1.05 var(--disp);letter-spacing:-.01em;color:var(--ink)}
.h2{font:700 clamp(1.95rem,4.2vw,2.9rem)/1.12 var(--disp);color:var(--ink)}
.h3{font:700 clamp(1.3rem,2.4vw,1.6rem)/1.2 var(--disp);color:var(--ink)}
.sec--dark .h1,.sec--dark .h2,.sec--dark .h3,.page-hero .h1,.cta-band .h2{color:#fff}
.lead{font-size:1.06rem;line-height:1.75;color:var(--mut)}
.sec--dark .lead,.page-hero .lead,.cta-band .lead{color:#D5E7F2}
.muted{color:var(--mut)}
.center{text-align:center}
.gap-lead{margin-top:.95rem}
.mt-1{margin-top:1rem}
.mt-2{margin-top:1.8rem}

/* yellow highlighter accent on light headings */
.mark{
  background:linear-gradient(transparent 60%,rgba(255,201,60,.6) 60%,rgba(255,201,60,.6) 92%,transparent 92%);
  padding:0 .08em;
}
/* sun word on dark headings */
.hl{color:var(--sun)}

/* pill eyebrow */
.kicker{
  display:inline-flex;align-items:center;gap:.55em;
  background:var(--ice-2);color:var(--cyan-2);
  font:800 .7rem/1 var(--body);letter-spacing:.18em;text-transform:uppercase;
  padding:.68em 1.15em;border-radius:99px;margin-bottom:1rem;
}
.kicker--dark{background:rgba(31,184,222,.14);color:var(--cyan-3)}
.kicker--sun{background:rgba(255,201,60,.16);color:var(--sun)}

.sec-head{max-width:660px;margin-bottom:2.5rem}
.sec-head--c{margin-inline:auto;text-align:center}
.sec-head--row{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:1.5rem;flex-wrap:wrap;margin-bottom:2.5rem;
}
.sec-head--row .sec-head{margin-bottom:0}
.sec-sub{margin-top:.8rem}

.arrow-link{
  display:inline-flex;align-items:center;gap:.45em;
  font:800 .93rem var(--body);color:var(--cyan-2);
}
.sec--dark .arrow-link{color:var(--cyan-3)}
.arrow-link .b-arr{transition:transform .25s var(--e)}
.arrow-link:hover .b-arr{transform:translateX(4px)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font:800 .95rem/1 var(--body);
  padding:1em 1.75em;border-radius:99px;border:2px solid transparent;
  transition:transform .22s var(--e),box-shadow .22s var(--e),background .22s var(--e),color .22s var(--e),border-color .22s var(--e);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn--sun{background:var(--sun);color:var(--ink);box-shadow:var(--sun-glow)}
.btn--sun:hover{background:var(--sun-2)}
.btn--cyan{background:var(--cyan);color:#fff;box-shadow:var(--cyan-glow)}
.btn--cyan:hover{background:var(--cyan-2)}
.btn--ink{background:var(--ink);color:#fff}
.btn--ink:hover{background:var(--ink-3)}
.btn--ghost{border-color:rgba(255,255,255,.45);color:#fff;background:transparent}
.btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.btn--ghost-ink{border-color:var(--ink);color:var(--ink);background:transparent}
.btn--ghost-ink:hover{background:var(--ink);color:#fff}
.btn--sm{padding:.72em 1.25em;font-size:.85rem}
.btn--lg{padding:1.1em 2.1em;font-size:1.02rem}
.btn--full{width:100%}
.btn .b-arr{transition:transform .25s var(--e)}
.btn:hover .b-arr{transform:translateX(4px)}

/* ---------- Topbar ---------- */
.topbar{
  background:#071423;color:#C9DEEC;text-align:center;
  font:700 .78rem/1.4 var(--body);letter-spacing:.04em;
  padding:.62em 1rem;position:relative;z-index:51;
}
.topbar p{display:inline}
.tb-flash{color:var(--sun)}
.tb-dot{opacity:.45;margin:0 .55em}
.topbar a{color:#fff;text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:3px}
.topbar a:hover{text-decoration-color:var(--sun)}

/* ---------- Header ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:var(--ink);
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:box-shadow .3s var(--e);
}
.site-head.is-scrolled{box-shadow:0 12px 32px rgba(5,14,24,.5)}
.head-in{display:flex;align-items:center;justify-content:space-between;gap:1.6rem;min-height:76px}

.brand{display:inline-flex;align-items:center;gap:.7rem;color:#fff}
.brand-mark{
  width:42px;height:42px;flex:none;border-radius:14px;
  background:linear-gradient(135deg,var(--cyan),#36CFF0);
  display:grid;place-items:center;color:#fff;
  box-shadow:0 6px 16px rgba(31,184,222,.35);
}
.brand-mark svg{width:22px;height:22px}
.brand-txt{display:flex;flex-direction:column;line-height:1.05}
.brand-txt b{font:700 1.22rem var(--disp);letter-spacing:.01em}
.brand-txt small{font:800 .56rem var(--body);letter-spacing:.34em;text-transform:uppercase;color:var(--cyan-3);margin-top:.18em}

.nav{display:flex;align-items:center;gap:1.55rem}
.nav-item{
  position:relative;color:#D7E9F4;font:700 .92rem var(--body);
  padding:.6em 0;display:inline-flex;align-items:center;gap:.4em;
}
.nav-item::after{
  content:"";position:absolute;left:0;right:0;bottom:.1em;height:3px;border-radius:3px;
  background:var(--sun);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--e);
}
.nav-item:hover{color:#fff}
.nav-item:hover::after{transform:scaleX(1)}
.caret{
  width:8px;height:8px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;
  transform:rotate(45deg) translateY(-2px);opacity:.7;
}
.has-sub{position:relative}
.sub{
  position:absolute;top:100%;left:-1.1rem;min-width:320px;
  background:#fff;border-radius:18px;box-shadow:var(--shadow);
  padding:.65rem;opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity .25s var(--e),transform .25s var(--e),visibility .25s;
}
.has-sub:hover .sub,.has-sub:focus-within .sub{opacity:1;visibility:visible;transform:translateY(4px)}
.sub a{display:block;padding:.72rem .95rem;border-radius:12px}
.sub a:hover{background:var(--ice)}
.sub strong{display:block;font:700 .95rem var(--body);color:var(--ink)}
.sub span{display:block;font-size:.8rem;color:var(--mut);margin-top:.1em}
.sub-all{font:800 .85rem var(--body);color:var(--cyan-2)}
.sub-all:hover{background:var(--ice)}

.head-cta{display:flex;align-items:center;gap:.7rem}

.burger{
  display:none;width:46px;height:46px;border:0;background:transparent;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.burger span{
  width:24px;height:2.5px;border-radius:3px;background:#fff;
  transition:transform .3s var(--e),opacity .3s var(--e);
}
.burger.is-open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Mobile menu ---------- */
.m-menu{
  position:fixed;inset:0;z-index:49;overflow:auto;
  background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);
  padding:7.2rem 1.6rem 2.6rem;
  opacity:0;visibility:hidden;transition:opacity .3s var(--e),visibility .3s;
}
.m-menu.is-open{opacity:1;visibility:visible}
body.menu-open{overflow:hidden}
.m-nav{display:flex;flex-direction:column;max-width:560px;margin:0 auto}
.m-link{
  font:700 1.5rem var(--disp);color:#fff;padding:.5em 0;
  border-bottom:1px solid rgba(255,255,255,.09);
  display:flex;align-items:center;justify-content:space-between;
}
.m-sub{
  font:600 1rem var(--body);color:#B9D2E2;padding:.55em 0 .55em 1.15em;
  display:block;
}
.m-sub:hover{color:#fff}
.m-subwrap{
  max-height:0;overflow:hidden;transition:max-height .4s var(--e);
  border-bottom:1px solid rgba(255,255,255,.09);
}
.m-subwrap.is-open{max-height:420px}
.m-caret{
  width:10px;height:10px;flex:none;margin-left:.6em;
  border-right:2.5px solid var(--cyan-3);border-bottom:2.5px solid var(--cyan-3);
  transform:rotate(45deg);transition:transform .3s var(--e);
}
.m-toggle.is-open .m-caret{transform:rotate(225deg)}
/* mobile CTA: flex-centered, body font (Verdara v1.1.5 lesson) */
.m-menu .btn{
  display:flex;justify-content:center;text-align:center;
  font:800 .9rem var(--body);letter-spacing:.04em;
  margin-top:1.4rem;width:100%;
}
.m-meta{text-align:center;color:var(--mut-d);font-size:.85rem;margin-top:1.1rem}
.m-meta a{color:#fff;font-weight:700}

/* ---------- Placeholder image system ----------
   Swap for a real image:
   <div class="ph ph--16x9 has-image"><img class="ph-img" src="..." alt="..."></div> */
.ph{
  position:relative;overflow:hidden;border-radius:var(--r);
  background:
    repeating-linear-gradient(-45deg,transparent 0 12px,rgba(14,143,184,.05) 12px 13px),
    var(--ph-bg);
  border:1.5px dashed #B5DCEE;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:1.4rem;gap:.55rem;
}
.sec--dark .ph,.hero .ph,.page-hero .ph,.cta-band .ph,.site-foot .ph{
  background:
    repeating-linear-gradient(-45deg,transparent 0 12px,rgba(127,217,240,.06) 12px 13px),
    var(--ph-bg-d);
  border-color:#2A4A66;
}
.ph-tag{
  font:800 .58rem var(--body);letter-spacing:.26em;text-transform:uppercase;
  color:var(--cyan-2);border:1px solid currentColor;padding:.5em 1em;border-radius:99px;
}
.ph-dim{font:800 .7rem var(--body);letter-spacing:.2em;color:var(--mut)}
.ph-prompt{font-size:.8rem;line-height:1.55;color:var(--mut);max-width:46ch}
.sec--dark .ph-tag,.hero .ph-tag,.page-hero .ph-tag,.cta-band .ph-tag{color:var(--cyan-3)}
.sec--dark .ph-dim,.hero .ph-dim,.page-hero .ph-dim,.cta-band .ph-dim,
.sec--dark .ph-prompt,.hero .ph-prompt,.page-hero .ph-prompt,.cta-band .ph-prompt{color:var(--mut-d)}

.ph--21x9{aspect-ratio:21/9}
.ph--16x9{aspect-ratio:16/9}
.ph--3x2{aspect-ratio:3/2}
.ph--4x3{aspect-ratio:4/3}
.ph--1x1{aspect-ratio:1/1}
.ph--3x4{aspect-ratio:3/4}
.ph--map{aspect-ratio:5/4}
.ph--fill{position:absolute;inset:0;height:100%;border:0;border-radius:0}

.ph.has-image{padding:0;border:0}
.ph.has-image > :not(.ph-img){display:none}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

/* ---------- Hero (homepage) ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .ph{justify-content:flex-end;align-items:flex-start;text-align:left;padding:2rem}
.hero-veil{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(6,16,28,.66) 0%,rgba(6,16,28,.32) 42%,rgba(8,21,36,.82) 100%);
}
.hero-in{
  position:relative;z-index:2;
  min-height:min(86vh,840px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:1.35rem;
  padding:clamp(5rem,10vw,7.5rem) 0 clamp(7rem,14vw,10rem);
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.6em;
  background:rgba(10,28,46,.45);border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:#EAF6FC;font:800 .7rem/1 var(--body);letter-spacing:.22em;text-transform:uppercase;
  padding:.78em 1.4em;border-radius:99px;
}
.live-dot{
  width:8px;height:8px;border-radius:50%;background:var(--sun);
  box-shadow:0 0 0 0 rgba(255,201,60,.65);animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,201,60,.65)}
  70%{box-shadow:0 0 0 9px rgba(255,201,60,0)}
  100%{box-shadow:0 0 0 0 rgba(255,201,60,0)}
}
.hero-h{font:800 clamp(2.75rem,6.6vw,4.8rem)/1.06 var(--disp);color:#fff;max-width:18ch;letter-spacing:-.01em}
.hero-sub{max-width:60ch;color:#DCEBF5;font-size:1.08rem;line-height:1.72}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}

.hero-stats{
  display:flex;flex-wrap:wrap;justify-content:center;
  background:rgba(13,33,53,.52);border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-radius:22px;padding:1.15rem .6rem;margin-top:1.5rem;
}
.stat{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.3rem 2.2rem}
.hero-stats .stat + .stat{border-left:1px solid rgba(255,255,255,.16)}
.stat-n{font:700 1.95rem/1 var(--disp);color:var(--sun)}
.stat-n .star{font-size:.85em}
.stat-l{font:800 .63rem var(--body);letter-spacing:.18em;text-transform:uppercase;color:#B9D2E2}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  position:relative;background:var(--ink);color:#fff;overflow:hidden;
  padding:clamp(4.2rem,8vw,6.4rem) 0 clamp(6rem,12vw,8.6rem);
  text-align:center;
}
.page-hero>.wrap{position:relative;z-index:1}
.crumbs{
  display:flex;justify-content:center;flex-wrap:wrap;gap:.55em;
  font:800 .72rem var(--body);letter-spacing:.18em;text-transform:uppercase;
  color:#8FB6CD;margin-bottom:1.15rem;
}
.crumbs a{color:#C9DEEC}
.crumbs a:hover{color:var(--sun)}
.crumb-sep{opacity:.5}
.page-hero .h1{max-width:20ch;margin-inline:auto}
.page-hero .lead{max-width:64ch;margin:1.1rem auto 0}
.page-hero .hero-cta{margin-top:1.6rem}

/* ---------- Trust strip ---------- */
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.t-item{display:flex;align-items:center;gap:.9rem}
.t-ico{
  width:52px;height:52px;flex:none;border-radius:50%;
  background:var(--ice);color:var(--cyan-2);display:grid;place-items:center;
}
.t-ico svg{width:24px;height:24px}
.t-item b{display:block;font:700 .98rem var(--body);color:var(--ink)}
.t-item span{display:block;font-size:.82rem;color:var(--mut)}

/* ---------- Grids ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2.2rem,5vw,4.4rem);align-items:center}
.split--form{display:grid;grid-template-columns:1.25fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.split--swap > :first-child{order:2}
/* button rows inside split copy blocks sit left, not centered */
.split .hero-cta{justify-content:flex-start;margin-top:1.5rem}
.split .stat-band{grid-template-columns:1fr 1fr}
.center .chip-row{justify-content:center}

/* ---------- Service cards ---------- */
.svc-card{
  position:relative;display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--e),box-shadow .3s var(--e);
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.svc-card .ph{border-radius:0;border:0;border-bottom:1px solid var(--line)}
.svc-card .ph-img{transition:transform .5s var(--e)}
.svc-card:hover .ph-img{transform:scale(1.045)}
.svc-body{padding:0 1.6rem 1.7rem;display:flex;flex-direction:column;flex:1}
.svc-ico{
  width:56px;height:56px;border-radius:18px;margin-top:-28px;
  position:relative;z-index:2;
  background:var(--sun);color:var(--ink);display:grid;place-items:center;
  box-shadow:var(--sun-glow);
}
/* text-only service cards (no photo): icon sits inside normally */
.svc-card .svc-body:first-child{padding-top:1.6rem}
.svc-card .svc-body:first-child .svc-ico{margin-top:0}
.svc-ico svg{width:26px;height:26px}
.svc-card h3{font-size:1.32rem;margin:.9rem 0 .45rem}
.svc-card p{font-size:.92rem;color:var(--mut);flex:1}
.svc-card .arrow-link{margin-top:1rem}
.svc-from{
  font:800 .72rem var(--body);letter-spacing:.14em;text-transform:uppercase;
  color:var(--cyan-2);margin-top:.9rem;
}

/* ---------- Steps ---------- */
.steps{counter-reset:step}
.step{position:relative;text-align:center;padding:0 .6rem}
.step-n{
  width:86px;height:86px;margin:0 auto 1.15rem;border-radius:50%;
  background:var(--ice);border:2px dashed #A9D8EC;color:var(--cyan-2);
  font:700 2rem/1 var(--disp);display:grid;place-items:center;
  position:relative;z-index:1;
}
.step::before{
  content:"";position:absolute;top:43px;left:calc(50% + 58px);
  width:calc(100% - 116px);border-top:2px dashed #B5DCEE;
}
.step:last-child::before{display:none}
.step h3{font-size:1.22rem;margin-bottom:.45rem}
.step p{font-size:.92rem;color:var(--mut);max-width:30ch;margin-inline:auto}
.sec--dark .step-n{background:rgba(31,184,222,.12);border-color:rgba(127,217,240,.4);color:var(--cyan-3)}
.sec--dark .step p{color:var(--mut-d)}
.sec--dark .step::before{border-color:rgba(127,217,240,.3)}

/* ---------- Ticks (hanging indent — Verdara lesson) ---------- */
.ticks{display:grid;gap:.85rem;margin:1.4rem 0}
.ticks li{position:relative;padding-left:2.35rem;line-height:1.62}
.ticks li::before{
  content:"";position:absolute;left:0;top:.1em;width:1.55rem;height:1.55rem;border-radius:50%;
  background:var(--cyan) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/56% no-repeat;
}
.ticks strong{color:var(--ink)}
.sec--dark .ticks li::before,.plan--featured .ticks li::before,.info-card .ticks li::before{
  background:var(--sun) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230A1C2E' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/56% no-repeat;
}
.sec--dark .ticks strong,.plan--featured .ticks strong{color:#fff}
.ticks--sm{gap:.55rem;font-size:.93rem}

/* ---------- Service report mockup (pure HTML, no image) ---------- */
.report-card{
  background:#fff;color:var(--text);border-radius:26px;box-shadow:var(--shadow);
  padding:1.5rem;max-width:460px;margin-inline:auto;
  transform:rotate(-1.6deg);transition:transform .35s var(--e);
}
.report-card:hover{transform:rotate(0deg)}
.rep-head{
  display:flex;align-items:center;gap:.85rem;
  border-bottom:1px solid var(--line);padding-bottom:1rem;margin-bottom:1rem;
}
.rep-head b{display:block;font:700 1rem var(--body);color:var(--ink)}
.rep-head span{display:block;font-size:.78rem;color:var(--mut)}
.rep-bubble{
  background:var(--ice);border-radius:18px 18px 18px 6px;
  padding:1rem 1.15rem;font-size:.93rem;line-height:1.6;margin-bottom:.8rem;
}
.rep-bubble b{color:var(--ink)}
.rep-chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:.85rem}
.rep-chip{
  font:800 .72rem var(--body);background:#fff;border:1.5px solid var(--line);
  color:var(--cyan-2);padding:.5em .85em;border-radius:99px;
}
.rep-shots{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.rep-shots .ph{border-radius:14px}
.rep-time{font-size:.72rem;color:var(--mut);text-align:right;margin-top:.7rem}

/* avatar bubbles */
.ava{
  width:46px;height:46px;flex:none;border-radius:50%;
  display:grid;place-items:center;font:800 .92rem var(--body);
}
.ava--c{background:var(--ice-2);color:var(--cyan-2)}
.ava--s{background:rgba(255,201,60,.25);color:#8A6400}
.ava--r{background:rgba(255,97,87,.16);color:#C2362D}
.ava--lg{width:64px;height:64px;font-size:1.15rem}

/* ---------- Work gallery (Before Us, After Us) ---------- */
.work-grid{display:grid;grid-template-columns:1.55fr 1fr 1fr;gap:1.1rem;grid-auto-flow:dense}
.work-tile{position:relative;border-radius:18px;overflow:hidden;margin:0;display:block}
.work-tile .ph{height:100%;border-radius:18px}
.work-tall{grid-row:span 2}
.work-tile .ph--16x9,.work-tile .ph--4x3,.work-tile .ph--3x2{height:100%}
.work-cap{
  position:absolute;left:.85rem;bottom:.85rem;right:.85rem;z-index:3;
  background:rgba(10,28,46,.78);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  border-radius:12px;padding:.6rem .85rem;
  display:flex;flex-direction:column;gap:.15rem;text-align:left;
}
.work-cap b{font:700 .9rem var(--body);color:#fff}
.work-cap span{font:700 .7rem var(--body);letter-spacing:.12em;text-transform:uppercase;color:var(--cyan-3)}

/* tap-to-flip before/after */
.flip{position:relative;border-radius:18px;overflow:hidden;cursor:pointer}
.flip .ph{border-radius:18px;height:100%}
.flip-after{position:absolute;inset:0;opacity:0;transition:opacity .45s var(--e);z-index:1}
.flip.is-after .flip-after{opacity:1}
.flip-tag{
  position:absolute;top:.85rem;left:.85rem;z-index:3;
  font:800 .64rem var(--body);letter-spacing:.18em;text-transform:uppercase;
  padding:.55em 1em;border-radius:99px;background:var(--coral);color:#fff;
  transition:opacity .3s var(--e);
}
.flip-tag--after{background:var(--cyan);opacity:0}
.flip.is-after .flip-tag{opacity:0}
.flip.is-after .flip-tag--after{opacity:1}
.flip-btn{
  position:absolute;right:.85rem;bottom:.85rem;z-index:3;
  font:800 .72rem var(--body);letter-spacing:.12em;text-transform:uppercase;
  background:var(--sun);color:var(--ink);border:0;border-radius:99px;
  padding:.75em 1.15em;box-shadow:var(--sun-glow);
  transition:transform .22s var(--e);
}
.flip-btn:hover{transform:translateY(-2px)}
.flip-wrap{display:flex;flex-direction:column;gap:.8rem}
.flip-cap{display:flex;justify-content:space-between;gap:.8rem;align-items:baseline;padding:0 .2rem}
.flip-cap b{font:700 .95rem var(--body);color:var(--ink)}
.flip-cap span{font-size:.8rem;color:var(--mut)}
.flip-cap a:hover{color:var(--cyan-2)}

/* projects page cards */
.proj-card{display:flex;flex-direction:column;gap:.75rem;margin:0}
.proj-card>a{display:block;border-radius:18px;overflow:hidden}
.proj-card .ph-img{transition:transform .5s var(--e)}
.proj-card:hover .ph-img{transform:scale(1.04)}
.proj-cap{display:flex;flex-direction:column;gap:.15rem;padding:0 .2rem}
.proj-cap b{font:700 1.02rem var(--body);color:var(--ink)}
.proj-cap span{font-size:.82rem;color:var(--mut)}
.proj-chip{
  align-self:flex-start;font:800 .66rem var(--body);letter-spacing:.14em;text-transform:uppercase;
  background:var(--ice-2);color:var(--cyan-2);padding:.5em .9em;border-radius:99px;margin-bottom:.25rem;
}

/* filter chips */
.filter-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:2.2rem}
.filt{
  font:800 .8rem var(--body);padding:.65em 1.2em;border-radius:99px;
  border:1.5px solid var(--line);background:#fff;color:var(--mut);
  transition:all .22s var(--e);
}
.filt:hover{border-color:var(--cyan);color:var(--cyan-2)}
.filt.is-on{background:var(--ink);border-color:var(--ink);color:#fff}
.is-hidden{display:none !important}

/* ---------- Plans / pricing ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch}
.plan{
  position:relative;display:flex;flex-direction:column;gap:1rem;
  background:#fff;border:1px solid var(--line);border-radius:26px;
  padding:2.2rem 1.9rem 1.9rem;
}
.plan-name{
  font:800 .74rem var(--body);letter-spacing:.18em;text-transform:uppercase;color:var(--cyan-2);
}
.plan-price{font:700 2.7rem/1 var(--disp);color:var(--ink)}
.plan-price small{font:600 .58rem var(--body);letter-spacing:.18em;text-transform:uppercase;color:var(--mut)}
.plan-desc{font-size:.92rem;color:var(--mut)}
.plan .ticks{margin:.4rem 0;flex:1;font-size:.93rem;gap:.6rem}
.plan--featured{
  background:var(--ink);border-color:var(--ink);color:#D5E7F2;
  box-shadow:var(--shadow);transform:scale(1.045);
}
.plan--featured .plan-name{color:var(--cyan-3)}
.plan--featured .plan-price{color:#fff}
.plan--featured .plan-price small{color:var(--mut-d)}
.plan--featured .plan-desc{color:var(--mut-d)}
.plan-badge{
  position:absolute;top:-15px;left:50%;transform:translateX(-50%);
  background:var(--sun);color:var(--ink);
  font:800 .64rem var(--body);letter-spacing:.18em;text-transform:uppercase;
  padding:.65em 1.2em;border-radius:99px;box-shadow:var(--sun-glow);white-space:nowrap;
}
.plan-note{text-align:center;font-size:.85rem;color:var(--mut);margin-top:1.6rem}

/* ---------- Reviews ---------- */
.review-card{
  display:flex;flex-direction:column;gap:1rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.9rem;
}
.stars{color:var(--sun);letter-spacing:.18em;font-size:1.02rem}
.review-q{line-height:1.72;flex:1}
.review-meta{display:flex;align-items:center;gap:.9rem}
.review-meta b{display:block;font:700 .95rem var(--body);color:var(--ink)}
.review-meta span{display:block;font-size:.8rem;color:var(--mut)}
.g-chip{
  display:inline-flex;align-items:center;gap:.6em;
  background:#fff;border:1px solid var(--line);border-radius:99px;
  padding:.75em 1.3em;font:700 .88rem var(--body);color:var(--ink);
}

/* ---------- Areas ---------- */
.towns{display:grid;grid-template-columns:1fr 1fr;gap:.6rem 1rem;margin:1.4rem 0}
.town{display:flex;align-items:center;gap:.55em;font:700 .95rem var(--body);color:var(--ink)}
.town:hover{color:var(--cyan-2)}
.pin{width:16px;height:16px;flex:none;color:var(--coral)}
.map-card{position:relative}
.map-chip{
  position:absolute;top:1rem;left:1rem;z-index:3;
  font:800 .66rem var(--body);letter-spacing:.16em;text-transform:uppercase;
  background:rgba(10,28,46,.8);color:#fff;backdrop-filter:blur(4px);
  padding:.6em 1em;border-radius:99px;
}
.area-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--e),box-shadow .3s var(--e);
}
.area-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.area-card .ph{border-radius:0;border:0;border-bottom:1px solid var(--line)}
.area-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.area-body h3{font-size:1.3rem;display:flex;align-items:center;gap:.4em}
.area-body p{font-size:.9rem;color:var(--mut);flex:1}
.area-stat{
  font:800 .7rem var(--body);letter-spacing:.14em;text-transform:uppercase;color:var(--cyan-2);
}
.chip-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.2rem}
.a-chip{
  font:700 .85rem var(--body);background:#fff;border:1.5px solid var(--line);color:var(--ink);
  padding:.6em 1.15em;border-radius:99px;transition:all .22s var(--e);
}
.a-chip:hover{border-color:var(--cyan);color:var(--cyan-2);transform:translateY(-2px)}
.sec--dark .a-chip{background:transparent;border-color:rgba(255,255,255,.25);color:#fff}
.sec--dark .a-chip:hover{border-color:var(--sun);color:var(--sun)}

/* ---------- Forms ---------- */
.form-card{
  background:#fff;border:1px solid var(--line);border-radius:26px;
  padding:clamp(1.5rem,3.5vw,2.3rem);box-shadow:var(--shadow-sm);
}
.f-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.05rem}
.f-field{display:flex;flex-direction:column;gap:.4rem}
.f-field--full{grid-column:1/-1}
.f-field label{font:700 .82rem var(--body);color:var(--ink)}
.f-field input,.f-field select,.f-field textarea{
  width:100%;font:500 .95rem var(--body);color:var(--ink);
  background:#F7FBFD;border:1.5px solid var(--line);border-radius:13px;
  padding:.85em 1em;transition:border-color .2s,box-shadow .2s;
}
.f-field textarea{min-height:130px;resize:vertical}
.f-field input:focus,.f-field select:focus,.f-field textarea:focus{
  outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(31,184,222,.16);
}
.form-note{
  background:#E8F8EE;border:1px solid #BFE8CD;color:#1E7A43;
  padding:1rem 1.2rem;border-radius:14px;font-weight:600;font-size:.93rem;margin-top:1.1rem;
}
.form-note[hidden]{display:none}
.form-micro{font-size:.78rem;color:var(--mut);margin-top:.9rem}
.form--inline{display:grid;grid-template-columns:1fr auto;gap:.7rem;align-items:stretch}
.form--inline input{
  width:100%;font:500 .95rem var(--body);color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:99px;
  padding:.9em 1.3em;
}
.form--inline input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(31,184,222,.16)}
.sec--dark .form--inline input,.cta-band .form--inline input{
  background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.25);color:#fff;
}

/* ---------- Info card (contact sidebar) ---------- */
.info-card{
  position:relative;overflow:hidden;
  background:var(--ink);color:#C9DEEC;border-radius:26px;
  padding:clamp(1.6rem,3.5vw,2.2rem);display:flex;flex-direction:column;gap:1.25rem;
}
.info-card>*{position:relative;z-index:1}
.info-card h3{color:#fff;font-size:1.45rem}
.info-row{display:flex;gap:.95rem;align-items:flex-start}
.info-ico{
  width:46px;height:46px;flex:none;border-radius:14px;
  background:rgba(31,184,222,.16);color:var(--cyan-3);display:grid;place-items:center;
}
.info-ico svg{width:22px;height:22px}
.info-row b{display:block;font:700 .95rem var(--body);color:#fff;margin-bottom:.15em}
.info-row p,.info-row a{font-size:.92rem;color:#B9D2E2;line-height:1.6}
.info-row a:hover{color:var(--sun)}
.hours{width:100%;font-size:.92rem}
.hours div{display:flex;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px dashed rgba(255,255,255,.16)}
.hours div:last-child{border-bottom:0}
.hours b{color:#fff;font-weight:700}

/* ---------- FAQ accordions ---------- */
.acc{
  background:#fff;border:1px solid var(--line);border-radius:16px;
  margin-bottom:.85rem;overflow:hidden;transition:box-shadow .25s var(--e),border-color .25s var(--e);
}
.acc summary{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.15rem 1.35rem;cursor:pointer;list-style:none;
  font:700 1.02rem var(--body);color:var(--ink);
}
.acc summary::-webkit-details-marker{display:none}
.acc-ico{
  flex:none;width:30px;height:30px;border-radius:50%;
  background:var(--cyan);color:#fff;display:grid;place-items:center;
  font:800 1.05rem/1 var(--body);transition:transform .3s var(--e);
}
.acc[open]{border-color:#A9D8EC;box-shadow:var(--shadow-sm)}
.acc[open] .acc-ico{transform:rotate(45deg)}
.acc-body{padding:0 1.35rem 1.3rem;color:var(--mut);line-height:1.72;max-width:78ch}
.acc-body a{color:var(--cyan-2);font-weight:700}
.faq-group{margin-bottom:2.6rem}
.faq-group h2{font-size:1.55rem;margin-bottom:1.1rem;display:flex;align-items:center;gap:.5em}

/* ---------- Blog ---------- */
.post-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  transition:transform .3s var(--e),box-shadow .3s var(--e);
}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card .ph{border-radius:0;border:0;border-bottom:1px solid var(--line)}
.post-card .ph-img{transition:transform .5s var(--e)}
.post-card:hover .ph-img{transform:scale(1.04)}
.post-body{padding:1.3rem 1.45rem 1.6rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.post-meta{font:800 .72rem var(--body);letter-spacing:.13em;text-transform:uppercase;color:var(--mut)}
.post-meta .cat{color:var(--cyan-2)}
.post-t{font:700 1.28rem/1.28 var(--disp);color:var(--ink)}
.post-card:hover .post-t{color:var(--cyan-2)}
.post-card p{font-size:.92rem;color:var(--mut);flex:1}

/* featured blog card (collapses @860 — Verdara lesson class) */
.card--featured{
  display:grid;grid-template-columns:1.2fr 1fr;
  background:#fff;border:1px solid var(--line);border-radius:26px;overflow:hidden;
  box-shadow:var(--shadow-sm);margin-bottom:2.4rem;
}
.card--featured .ph{border-radius:0;border:0;border-right:1px solid var(--line);height:100%}
.feat-body{padding:clamp(1.6rem,4vw,2.6rem);display:flex;flex-direction:column;gap:.8rem;justify-content:center}
.feat-body .post-t{font-size:clamp(1.5rem,2.8vw,2.1rem)}
.feat-body p{color:var(--mut)}

/* article (blog single) */
.article{max-width:760px;margin-inline:auto;font-size:1.04rem}
.article>p{margin:1.15em 0}
.article h2{font-size:1.75rem;margin:1.7em 0 .55em}
.article h3{font-size:1.3rem;margin:1.5em 0 .5em}
.article .ph{margin:2em 0}
.article .ticks{margin:1.3em 0}
.article blockquote{
  margin:1.7em 0;padding:1.25rem 1.5rem;
  background:var(--ice);border-left:5px solid var(--sun);border-radius:0 16px 16px 0;
  font:600 1.1rem/1.6 var(--body);color:var(--ink);
}
.callout{
  display:flex;gap:1rem;align-items:flex-start;
  background:var(--ice);border:1px solid #BBDDEE;border-radius:18px;
  padding:1.25rem 1.4rem;margin:1.7em 0;
}
.callout-ico{
  width:42px;height:42px;flex:none;border-radius:13px;
  background:var(--sun);color:var(--ink);display:grid;place-items:center;
}
.callout-ico svg{width:22px;height:22px}
.callout b{color:var(--ink)}
.callout p{font-size:.95rem;margin:.2em 0 0}
.article-meta{
  display:flex;justify-content:center;flex-wrap:wrap;gap:.6em 1.4em;
  font:800 .74rem var(--body);letter-spacing:.14em;text-transform:uppercase;color:#8FB6CD;
}
.article-meta .cat{color:var(--sun)}
.author-box{
  display:flex;gap:1.1rem;align-items:center;
  border:1px solid var(--line);border-radius:20px;padding:1.3rem 1.5rem;margin-top:2.6rem;
}
.author-box b{display:block;font:700 1.02rem var(--body);color:var(--ink)}
.author-box p{font-size:.88rem;color:var(--mut);margin-top:.15em}
.tag-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2rem}
.tag{
  font:800 .76rem var(--body);background:var(--ice);color:var(--cyan-2);
  padding:.55em 1em;border-radius:99px;
}
.tag:hover{background:var(--ice-2)}

/* newsletter band */
.newsletter{
  background:var(--ink);color:#fff;border-radius:26px;overflow:hidden;position:relative;
  padding:clamp(2rem,5vw,3rem);display:grid;grid-template-columns:1.2fr 1fr;
  gap:2rem;align-items:center;
}
.newsletter::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 88% 20%,rgba(31,184,222,.18),transparent 34%),
             radial-gradient(circle at 8% 90%,rgba(255,201,60,.1),transparent 30%);
}
.newsletter>*{position:relative;z-index:1}
.newsletter h2{color:#fff;font-size:clamp(1.5rem,3vw,2.1rem)}
.newsletter p{color:var(--mut-d);margin-top:.5rem;font-size:.95rem}
.newsletter .form-micro{color:var(--mut-d)}

/* ---------- Mini CTA (sun banner) ---------- */
.mini-cta{
  position:relative;overflow:hidden;
  background:var(--sun);border-radius:26px;
  padding:clamp(1.8rem,4vw,2.6rem) clamp(1.6rem,4vw,2.8rem);
  display:flex;align-items:center;justify-content:space-between;gap:1.6rem;flex-wrap:wrap;
  box-shadow:var(--sun-glow);
}
.mini-cta::before{
  content:"";position:absolute;right:-70px;top:-70px;width:230px;height:230px;border-radius:50%;
  background:rgba(255,255,255,.28);pointer-events:none;
}
.mini-cta::after{
  content:"";position:absolute;right:60px;bottom:-90px;width:180px;height:180px;border-radius:50%;
  background:rgba(10,28,46,.06);pointer-events:none;
}
.mini-cta>*{position:relative;z-index:1}
.mini-cta h3{font-size:clamp(1.35rem,2.6vw,1.8rem);max-width:26ch}
.mini-cta p{color:#5B4A12;font-weight:600;font-size:.95rem;margin-top:.3rem}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--ink);color:#fff;text-align:center;overflow:hidden}
.cta-bg{position:absolute;inset:0;z-index:0}
.cta-bg .ph{justify-content:flex-end;align-items:flex-start;text-align:left;padding:2rem}
.cta-veil{position:absolute;inset:0;z-index:1;background:rgba(7,19,33,.78);pointer-events:none}
.cta-band>.wrap{position:relative;z-index:2;padding-top:clamp(4.6rem,10vw,7.4rem);padding-bottom:clamp(4.6rem,10vw,7.4rem)}
.cta-band .h2{font-size:clamp(2.1rem,4.6vw,3.3rem);max-width:22ch;margin-inline:auto}
.cta-band .lead{max-width:56ch;margin:1rem auto 0}
.cta-actions{display:flex;gap:.95rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}
.cta-micro{margin-top:1.2rem;font:700 .8rem var(--body);letter-spacing:.06em;color:#9FB6C8}

/* ---------- Spec table (chemistry) ---------- */
.spec-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:18px;background:#fff}
.spec{width:100%;border-collapse:collapse;min-width:560px;font-size:.95rem}
.spec th{
  font:800 .72rem var(--body);letter-spacing:.15em;text-transform:uppercase;
  color:var(--cyan-2);text-align:left;padding:1rem 1.25rem;
  background:var(--ice);border-bottom:1px solid var(--line);white-space:nowrap;
}
.spec td{padding:.95rem 1.25rem;border-bottom:1px solid var(--line);vertical-align:top}
.spec tr:last-child td{border-bottom:0}
.spec td b{color:var(--ink)}
.spec td small{color:var(--mut)}

/* ---------- About page bits ---------- */
.stat-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;text-align:center}
.stat-band .stat{padding:.4rem 1rem}
.stat-band .stat-n{color:var(--ink);font-size:2.7rem}
.sec--dark .stat-band .stat-n,.stat-band--dark .stat-n{color:var(--sun)}
.stat-band .stat-l{color:var(--mut)}
.sec--dark .stat-band .stat-l{color:#B9D2E2}

.value-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.9rem;
  display:flex;flex-direction:column;gap:.7rem;
}
.v-ico{
  width:54px;height:54px;border-radius:16px;
  background:var(--ice);color:var(--cyan-2);display:grid;place-items:center;
}
.v-ico svg{width:26px;height:26px}
.value-card h3{font-size:1.25rem}
.value-card p{font-size:.92rem;color:var(--mut)}

.team-card{text-align:center}
.team-card .ph{aspect-ratio:3/4}
.team-card h3{font-size:1.2rem;margin-top:1rem}
.team-card .role{font:800 .72rem var(--body);letter-spacing:.16em;text-transform:uppercase;color:var(--cyan-2);margin-top:.25rem}
.team-card p{font-size:.88rem;color:var(--mut);margin-top:.5rem}

.timeline{border-left:2px dashed #A9D8EC;margin-left:.5rem;padding-left:1.8rem;display:grid;gap:1.6rem}
.tl-item{position:relative}
.tl-item::before{
  content:"";position:absolute;left:calc(-1.8rem - 8px);top:.4em;
  width:13px;height:13px;border-radius:50%;background:var(--sun);
  box-shadow:0 0 0 4px #fff,0 0 0 5.5px #A9D8EC;
}
.sec--ice .tl-item::before{box-shadow:0 0 0 4px var(--ice),0 0 0 5.5px #A9D8EC}
.tl-year{font:800 .76rem var(--body);letter-spacing:.16em;color:var(--cyan-2);text-transform:uppercase}
.tl-item h3{font-size:1.18rem;margin:.25rem 0 .3rem}
.tl-item p{font-size:.93rem;color:var(--mut);max-width:56ch}

.collage{position:relative}
.collage-pop{
  position:absolute;right:-1rem;bottom:-1.6rem;width:42%;
  border-radius:18px;overflow:hidden;box-shadow:var(--shadow);
  border:6px solid #fff;
}
.sec--ice .collage-pop{border-color:var(--ice)}
.collage-pop .ph{border-radius:12px}
.collage-chip{
  position:absolute;top:1rem;left:1rem;z-index:3;
  font:800 .66rem var(--body);letter-spacing:.16em;text-transform:uppercase;
  background:var(--sun);color:var(--ink);padding:.65em 1.05em;border-radius:99px;
  box-shadow:var(--sun-glow);
}

/* meta chips (project single) */
.meta-row{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:1.4rem}
.meta-chip{
  display:inline-flex;flex-direction:column;gap:.1rem;text-align:left;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:14px;padding:.7rem 1.1rem;
}
.meta-chip span{font:800 .6rem var(--body);letter-spacing:.18em;text-transform:uppercase;color:#8FB6CD}
.meta-chip b{font:700 .95rem var(--body);color:#fff}

.gal-2{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.gal-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}

/* ---------- Footer ---------- */
.site-foot{
  position:relative;background:var(--ink);color:#B9D2E2;overflow:hidden;
  padding-top:clamp(3.6rem,7vw,5.4rem);
}
.site-foot>.wrap{position:relative;z-index:1}
.foot-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.35fr;gap:2.4rem;
  padding-bottom:2.8rem;
}
.f-col h4{font:700 1.08rem var(--disp);color:#fff;margin-bottom:1.05rem}
.f-col nav{display:grid;gap:.55rem}
.f-col nav a{color:#B9D2E2;font-size:.93rem;width:fit-content}
.f-col nav a:hover{color:var(--sun)}
.f-brand p{font-size:.93rem;line-height:1.7;margin:1.05rem 0 1.25rem;max-width:36ch}
.f-soc{display:flex;gap:.6rem}
.f-soc a{
  width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(255,255,255,.22);
  display:grid;place-items:center;color:#fff;font:800 .72rem var(--body);
  transition:all .22s var(--e);
}
.f-soc a:hover{background:var(--sun);border-color:var(--sun);color:var(--ink);transform:translateY(-3px)}
.f-contact p{font-size:.93rem;line-height:1.65;margin-bottom:.95rem}
.f-contact a{color:#fff;font-weight:700}
.f-contact a:hover{color:var(--sun)}
.f-chip{
  display:inline-block;font:800 .68rem var(--body);letter-spacing:.15em;text-transform:uppercase;
  background:rgba(31,184,222,.13);color:var(--cyan-3);border:1px solid rgba(31,184,222,.32);
  padding:.65em 1.05em;border-radius:99px;
}
.foot-base{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.1);
  padding:1.5rem 0 2rem;font-size:.82rem;color:#8FA9BD;
}

/* ---------- To top ---------- */
.to-top{
  position:fixed;right:1.2rem;bottom:1.2rem;z-index:60;
  width:50px;height:50px;border-radius:50%;border:0;
  background:var(--cyan);color:#fff;display:grid;place-items:center;
  box-shadow:var(--cyan-glow);
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity .3s var(--e),transform .3s var(--e),visibility .3s,background .2s;
}
.to-top svg{width:20px;height:20px}
.to-top:hover{background:var(--cyan-2)}
.to-top.is-show{opacity:1;visibility:visible;transform:translateY(0)}

/* ---------- Reveal animations ---------- */
.js .rev{opacity:0;transform:translateY(24px);transition:opacity .75s var(--e),transform .75s var(--e)}
.js .rev.in{opacity:1;transform:none}
.js .rev.d1{transition-delay:.1s}
.js .rev.d2{transition-delay:.2s}
.js .rev.d3{transition-delay:.3s}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .js .rev{opacity:1;transform:none;transition:none}
  .live-dot{animation:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1180px){
  .btn--phone{display:none}
}
@media (max-width:1020px){
  .nav{display:none}
  .head-cta .btn--sun{display:none}
  .burger{display:flex}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .trust-row{grid-template-columns:repeat(2,1fr)}
  .step::before{display:none}
  .plans{grid-template-columns:1fr;max-width:520px;margin-inline:auto}
  .plan--featured{transform:scale(1)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stat-band{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:980px){
  .split{grid-template-columns:1fr}
  .split--form{grid-template-columns:1fr}
  .split--swap > :first-child{order:0}
  .work-grid{grid-template-columns:1fr 1fr}
  .work-tall{grid-row:auto}
  .newsletter{grid-template-columns:1fr}
}
@media (max-width:860px){
  .card--featured{grid-template-columns:1fr}
  .card--featured .ph{border-right:0;border-bottom:1px solid var(--line)}
}
@media (max-width:700px){
  .grid-3{grid-template-columns:1fr}
  .gal-3{grid-template-columns:1fr 1fr}
  .hero-stats .stat + .stat{border-left:0}
  .hero-stats{gap:.6rem 0}
  .stat{padding:.3rem 1.3rem}
  .towns{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .grid-4{grid-template-columns:1fr}
  .work-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:2rem}
  .trust-row{grid-template-columns:1fr}
  .stat-band{grid-template-columns:repeat(2,1fr)}
  .gal-2{grid-template-columns:1fr}
}
@media (max-width:560px){
  .f-grid{grid-template-columns:1fr}
}
@media (max-width:480px){
  .form--inline{grid-template-columns:1fr}
  .gal-3{grid-template-columns:1fr}
  .collage-pop{right:.4rem;bottom:-1rem}
  .hero-cta .btn,.cta-actions .btn{width:100%}
  .mini-cta .btn{width:100%}
}

/* ============================================================
   WORDPRESS THEME ADDITIONS (Cabana)
   Styles for content the WP version adds beyond the static demo:
   post/page body typography, pagination, comments, detail pages.
   ============================================================ */

/* Custom logo */
.brand-logo-img{max-height:48px;width:auto;display:block}

/* Active nav state */
.nav-item.is-active{color:#fff}
.nav-item.is-active::after{transform:scaleX(1)}

/* Long-form content typography (posts, pages, service/area detail) */
.entry-content{max-width:760px;font-size:1.03rem;line-height:1.75}
.single .entry-content,.page-template-default .entry-content{margin-inline:auto}
.split .entry-content,.split--wide .entry-content{max-width:none;margin-inline:0}
.entry-content > * + *{margin-top:1.15em}
.entry-content h2{font-size:clamp(1.4rem,3vw,1.9rem);margin-top:1.8em}
.entry-content h3{font-size:1.3rem;margin-top:1.5em}
.entry-content p{margin:0 0 0}
.entry-content a{color:var(--cyan-2);text-decoration:underline;text-underline-offset:3px}
.entry-content a:hover{color:var(--ink)}
.entry-content ul,.entry-content ol{padding-left:1.3em;display:grid;gap:.5em}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content li{padding-left:.2em}
.entry-content img{border-radius:14px}
.entry-content blockquote{margin:1.5em 0;padding:.6em 1.3em;border-left:4px solid var(--cyan);background:var(--ice);border-radius:0 12px 12px 0;font-size:1.08rem}
.entry-content code{background:var(--ice);padding:.15em .45em;border-radius:6px;font-size:.92em}
.entry-content figure{margin:1.5em 0}
.entry-tags{margin-top:1.6rem;font-size:.9rem;color:var(--mut)}
.entry-tags .tag-label{font-weight:800;color:var(--ink)}

/* Featured images on detail pages */
.post-hero-img,.page-feat-img,.proj-hero-img,.svc-detail-img,.area-detail-img{margin:0 auto 1.6rem;border-radius:var(--r);overflow:hidden}
.post-feat-img{border-radius:var(--r);display:block;width:100%}
.post-hero-img{max-width:1000px}
.post-meta--hero{margin-bottom:.7rem}

/* Wide split for detail pages */
.split--wide{display:grid;grid-template-columns:1.55fr .92fr;gap:clamp(2rem,5vw,3.5rem);align-items:start}

/* Service detail aside (sits inside the dark .info-card) */
.svc-aside{display:flex;flex-direction:column;gap:.85rem;text-align:left;position:sticky;top:96px}
.svc-aside .svc-ico{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.1);color:var(--sun)}
.svc-aside .svc-ico svg{width:24px;height:24px}
.svc-aside-price{font:800 1.5rem/1 var(--disp);color:#fff}
.svc-aside-note{color:var(--mut-d);font-size:.92rem}
.svc-aside .btn{margin:0}
.svc-aside-list{margin-top:.4rem}
.svc-aside-list li{color:#DCEBF5;font-size:.9rem}

/* Contact aside (light) */
.contact-aside{display:grid;gap:1.2rem;align-content:start}
.info-block{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.6rem 1.7rem;box-shadow:var(--shadow-sm)}
.info-block h3{font-size:1.2rem;margin-bottom:.6rem}
.info-block p{margin:.2rem 0 .9rem;color:var(--text)}
.info-block a{color:var(--cyan-2);font-weight:700}
.contact-map{border-radius:var(--r);overflow:hidden}
.form-card-title{font-size:clamp(1.4rem,3vw,1.9rem);margin-bottom:.4rem}
.form-error{background:#FDECEA;color:#B23A2F;padding:.85em 1.1em;border-radius:12px;font-weight:600;margin:0 0 1rem}

/* Before/after pair on project detail */
.ba-pair{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.6rem}
.ba-pair figure{margin:0;display:flex;flex-direction:column;gap:.5rem}
.ba-pair figcaption{font:800 .76rem var(--body);letter-spacing:.14em;text-transform:uppercase;color:var(--cyan-2)}

/* FAQ page list */
.faq-list{max-width:840px;margin-inline:auto;display:grid;gap:.7rem}
.faq-intro{max-width:760px;margin:0 auto 1.6rem}

/* Post navigation */
.post-nav{display:flex;justify-content:space-between;gap:1.2rem;margin-top:2.4rem;padding-top:1.6rem;border-top:1px solid var(--line);font-weight:700}
.post-nav a{color:var(--cyan-2)}
.post-nav a:hover{color:var(--ink)}
.post-nav-next{margin-left:auto;text-align:right}

/* Pagination */
.cabana-pagination{margin-top:2.8rem}
.cabana-pagination .nav-links{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center}
.page-numbers{display:inline-grid;place-items:center;min-width:44px;height:44px;padding:0 .7rem;border:1.5px solid var(--line);border-radius:12px;font-weight:800;color:var(--ink);background:#fff}
a.page-numbers:hover{border-color:var(--cyan);color:var(--cyan-2)}
.page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink)}
.page-numbers.dots{border-color:transparent;background:transparent}
.page-links{margin-top:1.4rem;font-weight:800}
.page-links a{margin:0 .3em;color:var(--cyan-2)}

/* Search field */
.search-field{flex:1;min-width:0;padding:.85em 1.1em;border:1.5px solid var(--line);border-radius:14px;background:#fff}
.search-field:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(31,184,222,.15)}

/* Comments */
.comments-area{max-width:760px;margin:3rem auto 0}
.comments-title{font-size:1.4rem;margin-bottom:1.2rem}
.comment-list{list-style:none;margin:0;padding:0;display:grid;gap:1.4rem}
.comment-list .children{list-style:none;margin:1.2rem 0 0 1.4rem;padding:0;display:grid;gap:1.2rem}
.comment-body{background:#fff;border:1px solid var(--line);border-radius:var(--r-sm);padding:1.2rem 1.3rem;box-shadow:var(--shadow-sm)}
.comment-author{font-weight:800}
.comment-author .says{display:none}
.comment-meta{font-size:.82rem;color:var(--mut);margin-bottom:.5rem}
.comment-respond{margin-top:2rem}
.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url],.comment-form textarea{width:100%;padding:.85em 1.1em;border:1.5px solid var(--line);border-radius:14px;background:#fff;margin-top:.3rem}
.comment-form label{font-weight:700;font-size:.9rem}
.comment-form .comment-form-comment,.comment-form p{margin-bottom:1rem}

/* Widgets (if a buyer adds the optional sidebars) */
.widget{margin-bottom:1.8rem}
.widget-title{font-size:1.05rem;margin-bottom:.8rem}

/* Responsive: collapse detail splits + before/after on small screens */
@media (max-width:860px){
  .split--wide{grid-template-columns:1fr}
  .svc-aside{position:static}
  .ba-pair{grid-template-columns:1fr}
  .post-nav{flex-direction:column}
  .post-nav-next{text-align:left;margin-left:0}
}
