/* ============================================================
   ELC  |  Environmental Logistics & Consulting
   Shared stylesheet  ·  Inter  ·  green / blue / teal system
   ============================================================ */
:root{
  --bg:#EEF3F1;--cream:#F7FBF9;--ink:#0B2129;--deep:#0E3A44;
  --green:#15784E;--green-br:#1E9A63;--blue:#1C6A92;--blue-br:#2E86B8;
  --teal:#1A8C86;--aqua:#3FBFA0;--aqua-soft:#A6DDCF;--blue-soft:#A9D3E6;
  --line:rgba(11,33,41,.14);
  --bg-shape-opacity:.40; /* Change this once to control all homepage background shape opacity */
  --grad:linear-gradient(135deg,var(--green) 0%,var(--teal) 100%);
  --grad-soft:linear-gradient(135deg,rgba(21,120,78,.08),rgba(26,140,134,.08));
  --elc-gradient:linear-gradient(135deg,#0B66C9 0%,#0AA5D8 32%,#22CFA6 68%,#C7D931 100%);
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--teal);color:var(--cream)}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px}
h1,h2,h3,h4{font-family:var(--sans);font-weight:800;line-height:1.05;letter-spacing:-.02em}
.skip{position:absolute;left:-999px}.skip:focus{left:16px;top:16px;background:#fff;padding:10px 16px;border-radius:8px;z-index:2000}

/* kicker — pill bubble matching the 01/02/03/04 number badges */
.kick{display:inline-flex;align-items:center;gap:0;font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:var(--grad);padding:.75em 1.1em;border-radius:100px;margin-bottom:22px;line-height:1}
.kick::before{display:none}
.faq .kick{background:rgba(63,191,160,.22);color:var(--aqua-soft)}
.faq.sec .kick{background:rgba(63,191,160,.22);color:var(--aqua-soft)}

/* buttons */
.btn{font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:.55em;padding:1.02em 1.7em;border-radius:100px;cursor:pointer;border:2px solid transparent;transition:.3s}
.btn .a{transition:transform .3s}.btn:hover .a{transform:translateX(4px)}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 12px 26px -18px rgba(21,120,78,.65)}.btn-grad:hover{background:linear-gradient(135deg,var(--green-br) 0%,var(--teal) 100%);transform:translateY(-2px);box-shadow:0 16px 34px -18px rgba(14,58,68,.7)}
.btn-out{background:transparent;border-color:var(--ink);color:var(--ink)}.btn-out:hover{background:var(--ink);color:var(--cream)}
.btn-light{background:#fff;color:var(--ink)}.btn-light:hover{background:var(--ink);color:#fff}

/* header */
header{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:900;
  padding:20px 0;
  transition:.4s;
  background:rgba(238,243,241,.82);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(11,33,41,.10);
}

header::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  pointer-events:none;
}

header.sc{
  background:rgba(238,243,241,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:13px 0;
  border-bottom:1px solid rgba(11,33,41,.12);
}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand .mk{width:44px;height:44px;border-radius:50%;overflow:hidden;flex:none;background:#fff;box-shadow:0 0 0 1px var(--line)}
.brand .mk img{width:100%;height:100%;object-fit:cover;display:block}
.brand .txt{display:flex;flex-direction:column;line-height:1.15}
.brand .nm{font-weight:800;font-size:1.18rem;letter-spacing:-.01em}
.brand .sb{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(11,33,41,.55);font-weight:600;margin-top:3px}
.nl{display:flex;gap:2px;align-items:center}
.nl a{font-weight:500;font-size:.93rem;padding:.55em .9em;border-radius:9px;transition:.3s}
.nl a:hover,.nl a.active{color:var(--teal)}
.nl .btn{margin-left:12px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}.burger span{width:25px;height:2.5px;background:var(--ink);border-radius:2px}

/* hero — base (used by all pages) */
.hero{padding:160px 0 88px;position:relative;overflow:hidden}
.hero .wrap{position:relative;z-index:1}
.hero-topo{position:absolute;top:-150px;right:-170px;width:680px;height:680px;color:var(--green);opacity:.13;z-index:0;pointer-events:none}
/* default amp colour — overridden for hero-home below */
.hero h1 .amp{color:var(--teal)}
.hero h1{font-size:clamp(2.9rem,8vw,6.4rem);letter-spacing:-.04em;font-weight:800;margin:0;max-width:15ch}
.hero h1 .g{color:var(--green)}.hero h1 .b{color:var(--blue)}
.hero .lead{font-size:1.18rem;color:rgba(11,33,41,.72);max-width:560px;margin:26px 0 34px;line-height:1.6}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap}
.hero-visual{display:grid;grid-template-columns:1.9fr 1fr;gap:18px;margin-top:56px}
.hv-img{border-radius:18px;overflow:hidden;position:relative}
.hv-img img{width:100%;height:380px;object-fit:cover}
.hv-img .cap{position:absolute;left:18px;bottom:16px;background:rgba(11,33,41,.78);color:var(--cream);font-size:.78rem;font-weight:500;padding:7px 14px;border-radius:100px;backdrop-filter:blur(6px)}
.hv-stats{
  background:var(--deep);
  color:var(--cream);
  border-radius:18px;
  padding:24px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:14px;
  box-shadow:inset 0 0 0 1px rgba(166,221,207,.08);
}

.hv-stats .stat{
  position:relative;
  padding:0;
  border-bottom:none;
}

.hv-stats .stat.featured{
  position:relative;
  background:linear-gradient(135deg,rgba(63,191,160,.14),rgba(46,134,184,.08));
  border:1px solid rgba(166,221,207,.22);
  border-radius:16px;
  padding:24px;
  overflow:hidden;
}

.hv-stats .stat.featured::after{
  display:none;
}

.hv-stats .stat.featured > *{
  position:relative;
  z-index:1;
}

.hv-stats .stat-label{
  font-size:.7rem;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:rgba(247,251,249,.78);
  font-weight:700;
  margin-bottom:8px;
  line-height:1.2;
}

.hv-stats .v{
  font-weight:800;
  font-size:2rem;
  line-height:1;
  letter-spacing:-.03em;
  background:linear-gradient(120deg,#ffffff,var(--aqua-soft));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

.hv-stats .stat.featured .v{
  font-size:3.75rem;
  background:linear-gradient(120deg,#ffffff,var(--aqua-soft));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  filter:drop-shadow(0 8px 18px rgba(11,33,41,.20));
}

.hv-stats .k{
  font-size:.85rem;
  color:rgba(247,251,249,.72);
  margin-top:8px;
  line-height:1.45;
}

.hv-stats .stat-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.hv-stats .stat.compact{
  background:rgba(247,251,249,.045);
  border:1px solid rgba(247,251,249,.10);
  border-radius:14px;
  padding:16px;
}

.hv-stats .stat.compact .k{
  font-size:.82rem;
  line-height:1.35;
  color:rgba(247,251,249,.76);
}
.hero-band{margin-top:30px;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);padding:18px 0;display:flex;gap:34px;flex-wrap:wrap;font-weight:700;font-size:1.02rem;letter-spacing:-.01em}
.hero-band span{color:var(--teal)}

/* ---- Homepage hero redesign ---- */
.hero.hero-home{padding:150px 0 88px;isolation:isolate}
.hero-inner{position:relative;z-index:3}

/* Background tree / leaf graphics — decorative only, behind content */
.hero-tree,.hero-leaf-svg{position:absolute;height:auto;pointer-events:none;z-index:1;color:#2f9f73}
.hero-tree{right:-145px;top:50%;transform:translateY(-47%);width:min(36vw,560px);opacity:.25}
.hero-tree-secondary{left:-62px;top:340px;width:min(20vw,280px);opacity:var(--bg-shape-opacity);transform:none}
.hero-leaf-svg-left{left:-34px;top:128px;width:min(18vw,230px);opacity:.25}
.hero-leaf-svg-right{right:19%;top:102px;width:min(11vw,150px);opacity:.25}

.hero-shape,.hero-leaf{position:absolute;display:block;pointer-events:none;z-index:1}
.hero-shape{border-radius:999px;background:linear-gradient(135deg,rgba(21,120,78,.14),rgba(63,191,160,.08) 55%,rgba(28,106,146,.06));filter:blur(.3px)}
.hero-shape-a{width:310px;height:310px;left:-145px;top:120px;opacity:.25}
.hero-shape-b{width:180px;height:180px;right:23%;top:128px;opacity:.25}
.hero-shape-c{width:420px;height:420px;right:-215px;bottom:-160px;opacity:.25}
.hero-shape-d{width:120px;height:120px;left:17%;bottom:248px;opacity:.25}
.hero-leaf{width:150px;height:78px;border-radius:100% 0 100% 0;background:linear-gradient(135deg,rgba(21,120,78,.16),rgba(63,191,160,.08));transform:rotate(-18deg);opacity:.25}
.hero-leaf-a{left:8%;top:345px;opacity:.25}
.hero-leaf-b{right:31%;bottom:315px;width:112px;height:58px;transform:rotate(22deg);opacity:.25}
.hero-leaf-c{left:24%;top:208px;width:86px;height:44px;transform:rotate(-42deg);opacity:.25}

/* Lockup: larger ELC mark on the left, controlled 3-line company name on the right */
.hero-lockup{
  display:grid;
  grid-template-columns:minmax(370px, 450px) minmax(0, 1fr);
  align-items:center;
  gap:clamp(28px,3.2vw,50px);
  margin-bottom:28px;
}

.hero-mark-wrap{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  min-width:0;
  overflow:visible;
}

.hero-mark{
  display:block;
  width:clamp(380px,29vw,470px);
  height:auto;
  max-width:none;
  min-height:0;
  object-fit:unset;
  object-position:initial;
  transform:translateX(-8px);
  flex:none;
}

/* Title — controlled 3-line lockup */
.hero-title{
  margin:0;
  color:var(--ink);
  font-size:clamp(2.65rem,3.55vw,4.15rem);
  line-height:.88;
  letter-spacing:-.055em;
  font-weight:900;
  max-width:9.4ch;
  align-self:center;
}

/* Gradient ampersand — overrides .hero h1 .amp */
.hero.hero-home .gradient-text,
.hero.hero-home .hero-title .amp{
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
  display:inline-block;
}

.hero.hero-home .lead{font-size:1.18rem;color:rgba(11,33,41,.72);max-width:700px;margin:20px 0 34px;line-height:1.58}

/* Responsive */
@media(max-width:1180px){
  .hero-lockup{grid-template-columns:minmax(330px,390px) minmax(0,1fr);gap:clamp(24px,2.8vw,42px)}
  .hero-mark{width:clamp(330px,27vw,400px);transform:translateX(-6px)}
  .hero-title{font-size:clamp(2.35rem,3.15vw,3.55rem);max-width:9.4ch}
  .hero-tree{right:-160px;width:min(42vw,500px)}
  .hero-tree-secondary{left:-78px;top:356px;width:min(22vw,250px)}
  .hero-shape-b{right:14%;top:110px}
}

@media(max-width:860px){
  .hero.hero-home{padding:128px 0 72px}
  .hero-lockup{grid-template-columns:1fr;align-items:start;gap:18px}
  .hero-mark-wrap{align-items:flex-start}
  .hero-mark{width:min(340px,78vw);height:auto;min-height:0;transform:none}
  .hero-title{font-size:clamp(2.55rem,12vw,4.5rem);max-width:none;line-height:.92}
  .hero.hero-home .lead{font-size:1.02rem;max-width:100%}
  .hero-tree{width:min(72vw,430px);right:-140px;top:150px;transform:none;opacity:.25}
  .hero-tree-secondary{left:-72px;top:420px;width:min(34vw,190px);opacity:.25}
  .hero-leaf-svg-left{left:-52px;top:148px;width:min(34vw,180px);opacity:.25}
  .hero-leaf-svg-right{right:8%;top:116px;width:min(18vw,95px);opacity:.25}
  .hero-shape-a{left:-180px;top:130px}
  .hero-shape-b{right:-80px;top:88px}
  .hero-shape-d{left:10%;bottom:238px}
  .hero-leaf-a{left:auto;right:12%;top:390px}
  .hero-leaf-b{display:none}
}

@media(max-width:560px){
  .hero.hero-home{padding:118px 0 60px}
  .hero-mark{width:min(275px,78vw);transform:none}
  .hero-title{font-size:clamp(2.15rem,12vw,3.55rem);line-height:.95}
  .hero-tree{width:280px;right:-120px;top:160px;opacity:.25}
  .hero-tree-secondary{left:-68px;top:442px;width:120px}
  .hero-leaf-svg-left{left:-44px;top:166px;width:130px}
  .hero-leaf-svg-right{display:none}
  .hero-shape-c{width:280px;height:280px;right:-170px;bottom:-80px}
  .hero-shape-d{left:8%;bottom:208px;width:84px;height:84px}
  .hero-leaf-c{display:none}
}

/* inner page hero */
.page-hero{padding:148px 0 56px}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,4rem);letter-spacing:-.03em;margin:0;max-width:20ch}
.page-hero .lead{font-size:1.15rem;color:rgba(11,33,41,.7);max-width:640px;margin-top:20px;line-height:1.6}
.page-hero .crumbs{font-size:.82rem;color:rgba(11,33,41,.5);margin-bottom:18px;font-weight:500}
.page-hero .crumbs a:hover{color:var(--teal)}



/* Homepage services section side decorations */
#services-overview{
  position:relative;
  isolation:isolate;
  overflow:visible;
  padding-top:1px;
}

#services-overview .wrap{
  position:relative;
  z-index:2;
}

.services-tree,
.services-leaf-svg{
  position:absolute;
  height:auto;
  pointer-events:none;
  z-index:1;
  color:#2f9f73;
  opacity:var(--bg-shape-opacity);
}

.services-tree-left{
  left:-78px;
  top:104px;
  width:min(18vw,240px);
}

.services-tree-right{
  right:-126px;
  top:138px;
  width:min(24vw,320px);
}

.services-leaf-svg-left{
  left:-26px;
  top:18px;
  width:min(13vw,170px);
}

.services-leaf-svg-right{
  right:8%;
  bottom:34px;
  width:min(10vw,128px);
}

.services-shape,
.services-leaf{
  position:absolute;
  display:block;
  pointer-events:none;
  z-index:1;
}

.services-shape{
  border-radius:999px;
  background:linear-gradient(135deg,rgba(21,120,78,.14),rgba(63,191,160,.08) 55%,rgba(28,106,146,.06));
  filter:blur(.3px);
  opacity:var(--bg-shape-opacity);
}

.services-shape-a{
  width:230px;
  height:230px;
  left:-112px;
  top:240px;
}

.services-shape-b{
  width:150px;
  height:150px;
  right:14%;
  top:38px;
}

.services-shape-c{
  width:220px;
  height:220px;
  right:-96px;
  bottom:26px;
}

.services-leaf{
  width:124px;
  height:64px;
  border-radius:100% 0 100% 0;
  background:linear-gradient(135deg,rgba(21,120,78,.16),rgba(63,191,160,.08));
  transform:rotate(-18deg);
  opacity:var(--bg-shape-opacity);
}

.services-leaf-a{
  left:7%;
  top:84px;
}

.services-leaf-b{
  right:26%;
  bottom:54px;
  width:92px;
  height:48px;
  transform:rotate(24deg);
}

@media (max-width: 1100px){
  .services-tree-right{
    right:-88px;
    width:min(22vw,260px);
  }

  .services-tree-left{
    left:-62px;
    width:min(16vw,190px);
  }
}

@media (max-width: 900px){
  .services-tree-right,
  .services-tree-left,
  .services-leaf-svg-right{
    display:none;
  }

  .services-shape-b{
    right:-40px;
    top:34px;
  }
}

@media (max-width: 640px){
  .services-tree,
  .services-leaf-svg,
  .services-shape,
  .services-leaf{
    display:none;
  }
}

/* section shell */
.sec{padding:104px 0}
#services-overview{
  padding-top:1px;
}
.sec-head{max-width:740px;margin-bottom:44px}
.sec-head h2{font-size:clamp(2.2rem,5vw,3.6rem);margin:0;letter-spacing:-.03em}
.sec-head p{font-size:1.1rem;color:rgba(11,33,41,.66);margin-top:18px;line-height:1.6}
/* centered variant for FAQ teaser on homepage */
.sec-head.center{max-width:100%;text-align:center}
.sec-head.center h2{color:var(--cream)}
/* FAQ page: full dark section including page-hero area */
.faq-page-hero{background:var(--deep);color:var(--cream);padding:148px 0 0}
.faq-page-hero h1{font-size:clamp(2.4rem,5.5vw,4rem);letter-spacing:-.03em;margin:0;max-width:20ch;color:var(--cream)}
.faq-page-hero .lead{font-size:1.15rem;color:rgba(247,251,249,.7);max-width:640px;margin-top:20px;line-height:1.6}
.faq-page-hero .crumbs{font-size:.82rem;color:rgba(247,251,249,.5);margin-bottom:18px;font-weight:500}
.faq-page-hero .crumbs a:hover{color:var(--aqua-soft)}
.faq-page-hero .kick{background:rgba(63,191,160,.22);color:var(--aqua-soft)}

/* unified work section (services page) */
.work{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.seg{display:inline-flex;background:var(--bg);border:2px solid var(--ink);border-radius:100px;padding:5px;gap:4px;margin-bottom:40px}
.seg-btn{font-family:var(--sans);font-weight:600;font-size:.94rem;letter-spacing:-.01em;padding:.72em 1.5em;border:none;background:none;border-radius:100px;cursor:pointer;color:var(--ink);transition:.3s}
.seg-btn.on{background:var(--grad);color:#fff}
.seg-btn:not(.on):hover{color:var(--teal)}
.work-view{animation:fadeSw .45s ease}
.work-view.hide{display:none}
@keyframes fadeSw{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.svc-wrap{display:grid;grid-template-columns:.92fr 1.08fr;gap:30px;align-items:stretch}
.svc-tabs{display:flex;flex-direction:column;gap:12px}
.svc-tab{display:flex;align-items:center;gap:18px;text-align:left;width:100%;background:var(--bg);border:2px solid var(--line);border-radius:14px;padding:20px 24px;cursor:pointer;transition:.3s;font-family:var(--sans)}
.svc-tab:hover{border-color:var(--ink)}
.svc-tab.on{border-color:transparent;background:var(--grad);color:#fff}
.svc-tab .no{font-weight:800;font-size:1.7rem;line-height:1;letter-spacing:-.02em;color:var(--blue);transition:.3s;flex:none}
.svc-tab.on .no{color:rgba(255,255,255,.85)}
.tabtext{display:flex;flex-direction:column;gap:5px}
.svc-tab .tt{font-weight:700;font-size:1.24rem;letter-spacing:-.02em;line-height:1.1}
.svc-tab .tg{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:rgba(11,33,41,.5);line-height:1.2}
.svc-tab.on .tg{color:rgba(255,255,255,.78)}
.svc-tab .arr{margin-left:auto;opacity:0;transform:translateX(-6px);transition:.3s;font-size:1.25rem;flex:none}
.svc-tab.on .arr{opacity:1;transform:none}
.svc-panel{border:2px solid var(--ink);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;background:var(--bg)}
.svc-photo{height:236px;overflow:hidden;position:relative}
.svc-photo img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.3,1)}
.svc-panel:hover .svc-photo img{transform:scale(1.05)}
.svc-photo .badge{position:absolute;top:16px;left:16px;background:var(--deep);color:var(--cream);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 12px;border-radius:100px}
.svc-content{padding:34px;flex:1;display:flex;flex-direction:column}
.svc-content h3{font-size:1.85rem;margin-bottom:14px;letter-spacing:-.02em}
.svc-content .desc{color:rgba(11,33,41,.76);font-size:1.02rem;margin-bottom:22px;line-height:1.6}
.svc-points{list-style:none;display:grid;gap:12px;margin-bottom:28px}
.svc-points li{display:flex;gap:12px;font-size:.97rem;color:var(--ink);line-height:1.45}
.svc-points .dot{width:22px;height:22px;border-radius:6px;background:var(--aqua-soft);color:var(--green);flex:none;display:grid;place-items:center;margin-top:1px}
.svc-points .dot svg{width:13px;height:13px}
.svc-content .btn{align-self:flex-start;margin-top:auto}

/* process timeline */
.proc-panel{background:var(--ink);color:var(--cream);border-radius:20px;padding:48px 44px}
.proc-panel .lead-line{color:rgba(247,251,249,.62);font-size:1.05rem;margin-bottom:40px;max-width:560px}
.tl-track{display:flex;position:relative;margin-bottom:40px;flex-wrap:wrap}
.tl-track::before{content:"";position:absolute;top:26px;left:5%;right:5%;height:2px;background:rgba(247,251,249,.2)}
.tl-prog{position:absolute;top:26px;left:5%;height:2px;background:var(--aqua);width:0;transition:width .5s ease;z-index:1}
.tl-node{flex:1;min-width:110px;text-align:center;position:relative;z-index:2;cursor:pointer}
.tl-node .dot{width:54px;height:54px;border-radius:50%;background:var(--ink);border:2px solid rgba(247,251,249,.3);display:grid;place-items:center;margin:0 auto 14px;font-weight:800;font-size:1.05rem;letter-spacing:-.02em;transition:.35s;color:rgba(247,251,249,.6)}
.tl-node.act .dot{background:var(--grad);border-color:transparent;color:#fff;transform:scale(1.08)}
.tl-node .nlab{font-size:.82rem;color:rgba(247,251,249,.6);transition:.3s;font-weight:500;padding:0 8px}
.tl-node.act .nlab{color:var(--cream);font-weight:600}
.tl-detail{background:rgba(247,251,249,.05);border:1px solid rgba(247,251,249,.14);border-radius:14px;padding:34px;display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;min-height:148px}
.tl-detail .big{font-weight:800;font-size:3.8rem;line-height:1;letter-spacing:-.03em;background:linear-gradient(120deg,var(--aqua),var(--blue-soft));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.tl-detail h3{font-size:1.5rem;margin-bottom:10px;letter-spacing:-.02em}
.tl-detail p{color:rgba(247,251,249,.72);font-size:1.02rem;line-height:1.55}
.tl-detail .dur{display:inline-block;margin-top:14px;font-weight:600;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;color:var(--aqua-soft);border:1px solid rgba(247,251,249,.2);border-radius:100px;padding:.4em .9em}

/* sectors / cards (also used for home services overview) */
.sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.sector{border:2px solid var(--ink);border-radius:16px;overflow:hidden;background:var(--bg);transition:.4s;display:flex;flex-direction:column}
.sector:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(11,33,41,.5)}
.sector .pic{height:200px;overflow:hidden;position:relative}
.sector .pic img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.3,1)}
.sector:hover .pic img{transform:scale(1.07)}
.sector .pic .n{position:absolute;top:14px;left:14px;width:40px;height:40px;border-radius:10px;background:var(--grad);color:#fff;font-weight:800;display:grid;place-items:center;letter-spacing:-.02em}
.sector .bd{padding:24px;display:flex;flex-direction:column;flex:1}
.sector .tag{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--blue);margin-bottom:8px}
.sector h3{font-size:1.3rem;margin-bottom:10px;letter-spacing:-.02em}
.sector p{color:rgba(11,33,41,.68);font-size:.94rem;line-height:1.55}
.sector .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-weight:600;font-size:.9rem;color:var(--teal)}
.sector .more .a{transition:transform .3s}.sector:hover .more .a{transform:translateX(4px)}

/* about */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}
.about-media{display:grid;grid-template-columns:1fr 1fr;gap:14px;position:sticky;top:120px}
.about-media .m{border-radius:14px;overflow:hidden}
.about-media .m img{width:100%;height:100%;object-fit:cover;min-height:200px}
.about-media .tall{grid-row:span 2}
.about-txt h2{font-size:clamp(2.1rem,4.4vw,3.2rem);margin:0 0 22px;letter-spacing:-.03em}
.about-txt p{font-size:1.05rem;color:rgba(11,33,41,.76);margin-bottom:18px;line-height:1.7;max-width:56ch}
.about-txt p:first-child{font-size:1.22rem;line-height:1.6;color:var(--ink);font-weight:500}
/* closing credential strip (replaces the old pull-quote) */
.about-strip{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:34px;background:var(--line);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.about-strip .it{background:var(--cream);padding:22px 24px}
.about-strip .n{font-weight:800;font-size:1.7rem;letter-spacing:-.03em;color:var(--green);line-height:1}
.about-strip .l{font-size:.82rem;color:rgba(11,33,41,.6);margin-top:7px;line-height:1.4}

/* risk */
.risk{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.risk-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:38px;align-items:start}
.check-list{display:grid;gap:10px}
.ck-item{display:flex;align-items:center;gap:15px;padding:16px 20px;border:2px solid var(--line);border-radius:12px;cursor:pointer;background:var(--bg);transition:.25s;user-select:none;font-family:var(--sans)}
.ck-item:hover{border-color:var(--ink)}
.ck-item.on{border-color:var(--teal);background:#fff}
.ck-box{width:26px;height:26px;border:2px solid var(--line);border-radius:7px;flex:none;display:grid;place-items:center;transition:.25s}
.ck-item.on .ck-box{background:var(--teal);border-color:var(--teal)}
.ck-box svg{width:15px;height:15px;color:var(--cream);opacity:0;transition:.2s}
.ck-item.on .ck-box svg{opacity:1}
.ck-item .t{font-weight:500;font-size:.98rem}
.risk-panel{
  position:sticky;
  top:104px;
  background:var(--deep);
  color:var(--cream);
  border-radius:16px;
  padding:34px;
  box-shadow:inset 0 0 0 1px rgba(166,221,207,.08);
}

.risk-panel-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:26px;
}

.risk-panel .pk{
  font-size:.72rem;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--aqua-soft);
  font-weight:700;
}

.risk-status-pill{
  font-size:.62rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(247,251,249,.72);
  border:1px solid rgba(247,251,249,.14);
  background:rgba(247,251,249,.05);
  padding:.45em .75em;
  border-radius:999px;
  font-weight:700;
}

.risk-meter{
  margin-bottom:24px;
}

.gauge{
  margin:0;
  display:flex;
  align-items:flex-end;
  gap:6px;
  height:86px;
  padding:0 0 4px;
}

.gauge .bar{
  flex:1;
  background:rgba(247,251,249,.13);
  border-radius:5px 5px 2px 2px;
  transition:.4s;
}

.gauge .bar.lit{
  background:linear-gradient(180deg,var(--aqua),var(--teal));
  box-shadow:0 0 18px rgba(63,191,160,.18);
}

.risk-scale{
  display:flex;
  justify-content:space-between;
  gap:10px;
  border-top:1px solid rgba(247,251,249,.13);
  padding-top:9px;
  margin-top:8px;
  color:rgba(247,251,249,.44);
  font-size:.68rem;
  letter-spacing:.09em;
  text-transform:uppercase;
  font-weight:700;
}

.risk-result{
  margin-top:8px;
}

.risk-eyebrow{
  color:rgba(166,221,207,.72);
  font-size:.68rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:8px;
}

.risk-level{
  font-weight:800;
  font-size:2.65rem;
  line-height:1;
  letter-spacing:-.035em;
  margin:0;
}

.risk-count{
  color:rgba(247,251,249,.62);
  font-size:.92rem;
  margin-top:8px;
}

.risk-rec{
  margin:22px 0 24px;
  padding:0;
  background:none;
  border:none;
  border-radius:0;
  font-size:.97rem;
  color:rgba(247,251,249,.84);
  line-height:1.62;
  max-width:36ch;
}

.risk-panel .btn{
  width:100%;
  justify-content:center;
}

.risk-panel .note{
  font-size:.78rem;
  color:rgba(247,251,249,.45);
  margin-top:14px;
  text-align:center;
}

/* faq (dark) */
.faq{background:var(--deep);color:var(--cream)}
.faq .sec-head h2{color:var(--cream)}
.acc{max-width:840px;margin:0 auto;display:grid;gap:12px}
.acc-item{border:1px solid rgba(247,251,249,.15);border-radius:14px;background:rgba(247,251,249,.04);transition:border-color .3s,background .3s}
.acc-item:hover{background:rgba(247,251,249,.07);border-color:rgba(166,221,207,.4)}
.acc-item.open{background:rgba(247,251,249,.08);border-color:rgba(166,221,207,.55)}
.acc-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 26px;display:flex;justify-content:space-between;gap:18px;align-items:center;font-family:var(--sans);font-weight:700;font-size:1.12rem;letter-spacing:-.02em;color:var(--cream);transition:.3s}
.acc-q:hover{color:var(--aqua-soft)}.acc-q .pm{color:var(--aqua-soft);font-size:1.6rem;transition:.4s;flex:none;line-height:1;font-weight:400}
.acc-item.open .pm{transform:rotate(45deg)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.4,0,.2,1)}
.acc-ai{padding:0 26px 24px;color:rgba(247,251,249,.82);font-size:1rem;line-height:1.65}.acc-ai strong{color:var(--aqua-soft)}
.acc-ai .def{margin-top:12px;padding:14px 16px;background:rgba(247,251,249,.08);border-radius:9px;border-left:3px solid var(--aqua-soft);font-size:.93rem}
.faq .btn{margin-top:34px;display:flex;width:max-content;margin-left:auto;margin-right:auto}

/* cta band */
.cta{background:var(--grad);color:#fff}
.cta-inner{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.cta h2{color:#fff;font-size:clamp(1.9rem,3.8vw,2.8rem);max-width:640px;margin:0;letter-spacing:-.03em}
.cta p{color:rgba(255,255,255,.88);margin-top:12px;font-size:1.08rem;max-width:520px}

/* contact */
.contact{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px}
.contact h2{font-size:clamp(2.1rem,4.4vw,3rem);margin:0 0 20px;letter-spacing:-.03em}
.contact .intro{color:rgba(11,33,41,.7);font-size:1.07rem;margin-bottom:30px;max-width:420px;line-height:1.6}
.cinfo{display:flex;gap:16px;align-items:center;padding:18px 0;border-top:1px solid var(--line)}
.cinfo .ic{width:46px;height:46px;background:var(--grad);border-radius:11px;display:grid;place-items:center;flex:none}
.cinfo .ic svg{width:20px;height:20px;color:var(--cream)}
.cinfo .k{font-size:.7rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(11,33,41,.5);font-weight:700}
.cinfo .v{font-weight:700;font-size:1.12rem;letter-spacing:-.01em;margin-top:2px}
.fc{background:var(--deep);color:var(--cream);border-radius:16px;padding:38px}
.fc h3{font-size:1.6rem;margin-bottom:8px;letter-spacing:-.02em}.fc .fs{color:rgba(247,251,249,.6);font-size:.95rem;margin-bottom:26px}
.field{margin-bottom:16px}
.field label{font-weight:600;font-size:.8rem;display:block;margin-bottom:8px;color:var(--aqua-soft)}
.field input,.field textarea{width:100%;padding:14px 16px;border:2px solid rgba(247,251,249,.2);border-radius:10px;font-family:var(--sans);font-size:1rem;background:rgba(247,251,249,.05);color:var(--cream);transition:.3s}
.field input::placeholder,.field textarea::placeholder{color:rgba(247,251,249,.4)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--aqua);background:rgba(247,251,249,.08)}
.field textarea{min-height:104px;resize:vertical}
.field.err input,.field.err textarea{border-color:#e8775a}.errm{color:#f0a48f;font-size:.78rem;margin-top:6px;display:none}.field.err .errm{display:block}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.fc .btn{width:100%;justify-content:center;margin-top:8px}
.fsucc{display:none;text-align:center;padding:26px 8px}.fsucc.show{display:block}
.fsucc .ck2{width:62px;height:62px;border-radius:50%;background:rgba(63,191,160,.18);color:var(--aqua-soft);display:grid;place-items:center;margin:0 auto 18px}.fsucc .ck2 svg{width:30px;height:30px}.fsucc h3{margin-bottom:8px}.fsucc a{color:var(--aqua-soft);font-weight:600}.fsucc p{color:rgba(247,251,249,.7)}

/* footer */
footer{background:var(--ink);color:var(--cream);padding:64px 0 28px}
.fg{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:42px;border-bottom:1px solid rgba(247,251,249,.18)}
.fg .nm{font-weight:800;font-size:1.3rem;letter-spacing:-.02em}.fg p{color:rgba(247,251,249,.5);font-size:.94rem;margin-top:14px;max-width:290px;line-height:1.6}
.fg h4{font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:var(--aqua-soft);font-weight:700;margin-bottom:16px}
.fg a,.fg span{display:block;color:rgba(247,251,249,.7);font-size:.93rem;padding:5px 0}.fg a:hover{color:var(--cream)}
.fb{display:flex;justify-content:space-between;padding-top:24px;flex-wrap:wrap;gap:10px;color:rgba(247,251,249,.45);font-size:.84rem}

/* reveal + mobile nav */
.r{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.3,1),transform .8s cubic-bezier(.2,.7,.3,1)}.r.in{opacity:1;transform:none}.s1{transition-delay:.1s}.s2{transition-delay:.2s}
.mob{position:fixed;inset:0;z-index:1000;background:var(--cream);transform:translateX(100%);transition:.5s cubic-bezier(.2,.7,.3,1);display:flex;flex-direction:column;padding:80px 32px 40px}.mob.open{transform:none}.mob a{font-weight:800;font-size:1.8rem;letter-spacing:-.02em;padding:16px 0;border-bottom:1px solid var(--line)}.mobx{position:absolute;top:24px;right:24px;background:none;border:none;font-size:2rem;cursor:pointer;color:var(--ink)}

@media(max-width:960px){
  .nl{display:none}.burger{display:flex}
  .hero-visual,.svc-wrap,.about-grid,.contact-grid,.risk-grid,.fg{grid-template-columns:1fr}
  .hv-img img{height:300px}.sector-grid,.cards-4{grid-template-columns:1fr}.hero-topo{width:460px;height:460px;top:-90px;right:-110px}
  .risk-panel{position:static}.tl-detail{grid-template-columns:1fr}.tl-detail .big{font-size:3rem}
  .fg{grid-template-columns:1fr 1fr}.tl-node{min-width:84px}.tl-node .nlab{font-size:.72rem}
  .about-media .tall{grid-row:auto}.about-media{position:static}.proc-panel{padding:34px 22px}
  .about-strip{grid-template-columns:1fr 1fr}
  .seg{width:100%;justify-content:space-between}.seg-btn{flex:1;padding:.72em .4em;font-size:.84rem}
}
@media(min-width:600px) and (max-width:960px){.cards-4{grid-template-columns:1fr 1fr}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.r{opacity:1;transform:none}}

/* ============================================================
   New components: testimonials carousel · contact map · select
   ============================================================ */



/* Homepage testimonial preview */
.home-testimonials{
  background:var(--bg);
  border-bottom:1px solid var(--line);
}

.home-testimonials .sec-head{
  max-width:760px;
}

.home-testimonials .tcar{
  margin-left:0;
  margin-right:0;
}

.home-testimonials-action{
  margin-top:34px;
}

.home-testimonials .btn-out{
  background:transparent;
}

@media(max-width:960px){
  .home-testimonials .tcar{
    margin-left:auto;
    margin-right:auto;
  }
}

/* testimonials carousel */
.tcar{max-width:900px;margin:0 auto;position:relative}
.tcar-view{overflow:hidden}
.tcar-track{display:flex;transition:transform .7s cubic-bezier(.4,0,.2,1)}
.tslide{flex:0 0 100%;background:var(--cream);border:1px solid var(--line);border-radius:20px;padding:clamp(30px,5vw,52px)}
.tslide .qm{font-family:Georgia,"Times New Roman",serif;font-size:4rem;line-height:1;height:52px;display:block;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px;overflow:visible}
.tslide .q{font-size:clamp(1.25rem,2.5vw,1.6rem);line-height:1.5;letter-spacing:-.02em;font-weight:600;color:var(--ink)}
.tslide .who{display:flex;align-items:center;gap:16px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line)}
.tslide .who .logo{width:56px;height:56px;border-radius:12px;object-fit:contain;background:#fff;border:1px solid var(--line);padding:7px;flex:none}
.tslide .who .ph{width:56px;height:56px;border-radius:12px;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.2rem;flex:none}
.tslide .who .nm{font-weight:700;font-size:1.04rem;letter-spacing:-.01em}
.tslide .who .co{font-size:.9rem;color:rgba(11,33,41,.6);margin-top:2px}
.tcar-nav{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:30px}
.tcar-arrow{width:48px;height:48px;border-radius:50%;border:2px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:.3s}
.tcar-arrow:hover{border-color:var(--ink);background:var(--ink);color:#fff}
.tcar-arrow svg{width:20px;height:20px}
.tcar-dots{display:flex;gap:9px;align-items:center}
.tcar-dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--line);cursor:pointer;padding:0;transition:.3s}
.tcar-dots button.on{background:var(--green);width:28px;border-radius:5px}

/* contact map */
.cmap{margin-top:28px;border-radius:16px;overflow:hidden;border:1px solid var(--line);line-height:0}
.cmap iframe{width:100%;height:300px;border:0;display:block}
.cmap .lbl{background:#fff;line-height:1.4;padding:13px 18px;border-top:1px solid var(--line);display:flex;align-items:center;gap:9px;font-size:.86rem;color:rgba(11,33,41,.7);font-weight:500}
.cmap .lbl svg{width:16px;height:16px;color:var(--teal);flex:none}

/* select (service picker in the quote form) */
.field select{width:100%;padding:14px 16px;border:2px solid rgba(247,251,249,.2);border-radius:10px;font-family:var(--sans);font-size:1rem;background-color:rgba(247,251,249,.05);color:var(--cream);transition:.3s;appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23A6DDCF' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.field select:focus{outline:none;border-color:var(--aqua);background-color:rgba(247,251,249,.08)}
.field select option{color:#0B2129;background:#fff}


/* Homepage carousel captions */
.hv-carousel .cap{
  padding:7px 12px;
  font-size:.76rem;
  background:rgba(11,33,41,.78);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 12px 24px -18px rgba(0,0,0,.45);
}


@media(max-width:560px){
  .hv-stats .stat-row{
    grid-template-columns:1fr;
  }

  .hv-stats .stat.featured .v{
    font-size:3.1rem;
  }
}


/* ============================================================
   FAQ page redesign: light hero + clean dark accordion
   ============================================================ */
.faq-page-clean{
  background:var(--bg);
  color:var(--ink);
  padding-top:0;
}

.faq-page-clean .faq-page-hero{
  background:transparent;
  color:var(--ink);
  padding:148px 0 34px;
}

.faq-page-clean .faq-page-hero h1{
  color:var(--ink);
  font-size:clamp(2.4rem,5.5vw,4rem);
  letter-spacing:-.03em;
  margin:0;
  max-width:18ch;
}

.faq-page-clean .faq-page-hero .lead{
  color:rgba(11,33,41,.70);
  font-size:1.15rem;
  max-width:640px;
  margin-top:20px;
  line-height:1.6;
}

.faq-page-clean .faq-page-hero .crumbs{
  color:rgba(11,33,41,.52);
}

.faq-page-clean .faq-page-hero .crumbs a:hover{
  color:var(--teal);
}

.faq-page-clean .kick{
  background:var(--grad);
  color:#fff;
}

.faq-page-clean .faq-list-wrap{
  padding-top:34px;
  padding-bottom:104px;
}

.faq-page-clean .acc{
  max-width:760px;
  margin:0;
  display:grid;
  gap:12px;
}

.faq-page-action{
  max-width:760px;
  margin-top:34px;
  text-align:left;
}

.faq-page-clean .acc-item{
  background:var(--deep);
  border:1px solid rgba(166,221,207,.18);
  border-radius:14px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.02);
  overflow:hidden;
  transition:border-color .25s ease, transform .25s ease, background .25s ease;
}

.faq-page-clean .acc-item:hover{
  background:#103f4a;
  border-color:rgba(166,221,207,.36);
  transform:translateY(-1px);
}

.faq-page-clean .acc-item.open{
  background:var(--deep);
  border-color:rgba(166,221,207,.48);
}

.faq-page-clean .acc-q{
  color:var(--cream);
  padding:22px 26px;
}

.faq-page-clean .acc-q:hover{
  color:#fff;
}

.faq-page-clean .acc-q .pm{
  color:var(--aqua-soft);
}

.faq-page-clean .acc-ai{
  color:rgba(247,251,249,.82);
  padding:0 26px 26px;
  font-size:1rem;
  line-height:1.66;
}

/* Cleaner definition rows, no AI-card accent-block look */
.faq-page-clean .acc-ai .def{
  margin-top:14px;
  padding:0;
  background:transparent;
  border:none;
  border-radius:0;
  color:rgba(247,251,249,.78);
  font-size:.96rem;
  line-height:1.6;
}

.faq-page-clean .acc-ai .def strong{
  color:var(--aqua-soft);
  font-weight:800;
}



/* FAQ two-column layout + support card */
.faq-content-grid{
  display:grid;
  grid-template-columns:minmax(0,760px) minmax(280px,360px);
  gap:44px;
  align-items:start;
}

.faq-main{
  min-width:0;
}

.faq-page-clean .acc{
  max-width:none;
}

.faq-page-action{
  max-width:none;
}

.faq-help-card{
  position:sticky;
  top:112px;
  background:var(--deep);
  color:var(--cream);
  border-radius:18px;
  padding:30px;
  box-shadow:inset 0 0 0 1px rgba(166,221,207,.10);
}

.faq-help-card .mini-kicker{
  display:inline-flex;
  align-items:center;
  color:var(--aqua-soft);
  font-size:.66rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
  margin-bottom:16px;
}

.faq-help-card h2{
  color:var(--cream);
  font-size:clamp(1.75rem,2.4vw,2.25rem);
  letter-spacing:-.04em;
  margin:0 0 14px;
}

.faq-help-card p{
  color:rgba(247,251,249,.76);
  font-size:.98rem;
  line-height:1.62;
  margin:0 0 22px;
}

.faq-help-stats{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin:24px 0;
}

.faq-help-stats div{
  border:1px solid rgba(247,251,249,.12);
  background:rgba(247,251,249,.045);
  border-radius:14px;
  padding:15px 16px;
}

.faq-help-stats strong{
  display:block;
  font-size:1.65rem;
  line-height:1;
  letter-spacing:-.04em;
  background:linear-gradient(120deg,#ffffff,var(--aqua-soft));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

.faq-help-stats span{
  display:block;
  color:rgba(247,251,249,.68);
  font-size:.8rem;
  line-height:1.4;
  margin-top:6px;
}

.faq-help-card .btn{
  width:100%;
  justify-content:center;
}

@media(max-width:980px){
  .faq-content-grid{
    grid-template-columns:1fr;
    gap:34px;
  }

  .faq-help-card{
    position:static;
    max-width:760px;
  }

  .faq-help-stats{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:560px){
  .faq-help-card{
    padding:24px;
  }

  .faq-help-stats{
    grid-template-columns:1fr;
  }
}

@media(max-width:700px){
  .faq-page-clean .faq-page-hero{
    padding:126px 0 28px;
  }

  .faq-page-clean .faq-list-wrap{
    padding-top:24px;
  }

  .faq-page-clean .acc-q{
    padding:19px 20px;
    font-size:1rem;
  }

  .faq-page-clean .acc-ai{
    padding:0 20px 22px;
  }
}


/* Testimonials carousel polish: result chips + integrated edge controls */
.tcar{
  max-width:900px;
  margin:0 auto;
  position:relative;
  padding:0 70px;
}

.tcar-view{
  overflow:hidden;
  border-radius:20px;
}

.tslide{
  background:linear-gradient(180deg,#fff,rgba(247,251,249,.82));
  border:1px solid rgba(11,33,41,.12);
  box-shadow:0 24px 60px -42px rgba(11,33,41,.45);
}

.testimonial-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:24px;
}

.testimonial-tags span{
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.02em;
  color:var(--green);
  background:rgba(21,120,78,.08);
  border:1px solid rgba(21,120,78,.14);
  border-radius:999px;
  padding:.48em .85em;
  line-height:1.1;
}

.tslide .who{
  margin-top:28px;
}

.tcar-nav{
  margin-top:26px;
  gap:14px;
}

.tcar-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:4;
  width:52px;
  height:52px;
  background:rgba(247,251,249,.92);
  box-shadow:0 18px 34px -24px rgba(11,33,41,.55);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}

.tcar-arrow:hover{
  transform:translateY(-50%) scale(1.04);
}

#tPrev{
  left:0;
}

#tNext{
  right:0;
}

.tcar-dots{
  margin:0 auto;
}

@media(max-width:760px){
  .tcar{
    padding:0;
  }

  .tcar-arrow{
    position:static;
    transform:none;
    width:48px;
    height:48px;
  }

  .tcar-arrow:hover{
    transform:none;
  }

  .tcar-nav{
    margin-top:24px;
    gap:18px;
  }
}


/* Homepage testimonial preview alignment fix */
.home-testimonials .tcar{
  max-width:760px;
  margin-left:0;
  margin-right:0;
  padding:0;
}

.home-testimonials .tcar-view{
  border-radius:20px;
}

.home-testimonials .tcar-nav{
  justify-content:flex-start;
  margin-top:22px;
  gap:16px;
}

.home-testimonials .tcar-arrow{
  position:static;
  transform:none;
  width:44px;
  height:44px;
  box-shadow:none;
  background:#fff;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}

.home-testimonials .tcar-arrow:hover{
  transform:none;
}

.home-testimonials .tcar-dots{
  margin:0;
}

.home-testimonials-action{
  margin-top:28px;
}

@media(max-width:960px){
  .home-testimonials .tcar{
    margin-left:0;
    margin-right:0;
  }
}


/* Homepage testimonial preview size/breathing tweaks */
.home-testimonials{
  padding-top:88px;
  padding-bottom:88px;
}

.home-testimonials .sec-head{
  margin-bottom:34px;
}

.home-testimonials .tcar{
  max-width:820px;
}

.home-testimonials .tslide{
  padding:42px 48px;
}

.home-testimonials .tslide .q{
  font-size:clamp(1.12rem,1.7vw,1.35rem);
  line-height:1.55;
}

.home-testimonials-action{
  margin-top:26px;
}

@media(max-width:640px){
  .home-testimonials{
    padding-top:72px;
    padding-bottom:72px;
  }

  .home-testimonials .tslide{
    padding:32px 28px;
  }
}


/* Homepage About preview: force same background as Free Risk Check */
.home-testimonials + section{
  background:var(--cream) !important;
}


/* About page text styling */
.about-page-copy p{
  color:var(--ink);
}

.about-page-copy p:first-child{
  color:var(--ink);
}

.about-ownership-statement{
  color:var(--green) !important;
  font-weight:800 !important;
  font-size:clamp(1.22rem,1.75vw,1.55rem) !important;
  line-height:1.28 !important;
  letter-spacing:-.035em;
  margin-top:26px;
  max-width:34ch;
}

@media(max-width:700px){
  .about-ownership-statement{
    font-size:1.18rem !important;
    max-width:100%;
  }
}


/* Hero round logo replacement */
.hero-lockup{
  grid-template-columns:minmax(300px,420px) minmax(0,1fr);
  gap:clamp(34px,4vw,64px);
}

.hero-brand-logo-wrap{
  justify-content:center;
}

.hero-brand-logo{
  display:block;
  width:clamp(260px,24vw,390px);
  height:auto;
  border-radius:50%;
  filter:drop-shadow(0 24px 38px rgba(11,33,41,.14));
}

@media(max-width:1180px){
  .hero-lockup{
    grid-template-columns:minmax(260px,360px) minmax(0,1fr);
    gap:clamp(28px,3.2vw,46px);
  }

  .hero-brand-logo{
    width:clamp(240px,23vw,330px);
  }
}

@media(max-width:860px){
  .hero-brand-logo-wrap{
    justify-content:flex-start;
  }

  .hero-brand-logo{
    width:min(260px,62vw);
  }
}

@media(max-width:560px){
  .hero-brand-logo{
    width:min(220px,60vw);
  }
}


/* Match hero ampersand gradient to green button gradient */
.hero.hero-home .gradient-text,
.hero.hero-home .hero-title .amp{
  background:var(--grad);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}


/* Dark mode system */
:root{
  color-scheme:light;
}

html[data-theme="dark"]{
  color-scheme:dark;
  --bg:#071A20;
  --cream:#0B242B;
  --ink:#F4FBF8;
  --deep:#06161B;
  --line:rgba(166,221,207,.20);
  --bg-shape-opacity:.18;
  --grad:linear-gradient(135deg,#16865A 0%,#159B92 100%);
  --grad-soft:linear-gradient(135deg,rgba(63,191,160,.12),rgba(46,134,184,.10));
}

html[data-theme="dark"] body{
  background:var(--bg);
  color:var(--ink);
}

html[data-theme="dark"] header{
  background:rgba(7,26,32,.86);
  border-bottom-color:rgba(166,221,207,.14);
}

html[data-theme="dark"] header.sc{
  background:rgba(7,26,32,.94);
  border-bottom-color:rgba(166,221,207,.18);
}

html[data-theme="dark"] .brand .mk{
  background:rgba(247,251,249,.08);
  box-shadow:0 0 0 1px rgba(166,221,207,.22);
}

html[data-theme="dark"] .brand .sb,
html[data-theme="dark"] .hero .lead,
html[data-theme="dark"] .page-hero .lead,
html[data-theme="dark"] .sec-head p,
html[data-theme="dark"] .about-txt p,
html[data-theme="dark"] .sector p,
html[data-theme="dark"] .contact .intro{
  color:rgba(244,251,248,.72);
}

html[data-theme="dark"] .btn-out{
  border-color:rgba(244,251,248,.92);
  color:var(--ink);
}

html[data-theme="dark"] .btn-out:hover{
  background:var(--ink);
  color:#071A20;
}

html[data-theme="dark"] .sector,
html[data-theme="dark"] .ck-item,
html[data-theme="dark"] .svc-panel,
html[data-theme="dark"] .svc-tab,
html[data-theme="dark"] .about-strip .it,
html[data-theme="dark"] .testimonial-card,
html[data-theme="dark"] .tslide,
html[data-theme="dark"] .faq-page-clean .acc-item{
  background:#0B242B;
  border-color:rgba(166,221,207,.22);
}

html[data-theme="dark"] .sector:hover,
html[data-theme="dark"] .ck-item:hover{
  border-color:rgba(244,251,248,.72);
}

html[data-theme="dark"] .risk,
html[data-theme="dark"] .work,
html[data-theme="dark"] .home-testimonials,
html[data-theme="dark"] .faq-page-clean,
html[data-theme="dark"] .sec[style*="var(--bg)"]{
  background:#071A20 !important;
  border-color:rgba(166,221,207,.16);
}

html[data-theme="dark"] .sec,
html[data-theme="dark"] .contact,
html[data-theme="dark"] .services-overview-env{
  background:#071A20;
}

html[data-theme="dark"] .hv-stats,
html[data-theme="dark"] .risk-panel,
html[data-theme="dark"] .faq-help-card,
html[data-theme="dark"] .fc{
  background:#06161B;
  box-shadow:inset 0 0 0 1px rgba(166,221,207,.12);
}

html[data-theme="dark"] .hv-stats .stat.featured,
html[data-theme="dark"] .hv-stats .stat.compact{
  border-color:rgba(166,221,207,.18);
  background:rgba(247,251,249,.045);
}

html[data-theme="dark"] .hero-band{
  border-color:rgba(244,251,248,.78);
}

html[data-theme="dark"] .field input,
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .field select{
  background:rgba(247,251,249,.06);
  border-color:rgba(166,221,207,.24);
  color:var(--ink);
}

html[data-theme="dark"] .field input::placeholder,
html[data-theme="dark"] .field textarea::placeholder{
  color:rgba(244,251,248,.42);
}

html[data-theme="dark"] .cinfo{
  border-top-color:rgba(166,221,207,.18);
}

html[data-theme="dark"] .cinfo .k,
html[data-theme="dark"] .page-hero .crumbs,
html[data-theme="dark"] .risk-count,
html[data-theme="dark"] .risk-panel .note{
  color:rgba(244,251,248,.52);
}

html[data-theme="dark"] .hero-tree,
html[data-theme="dark"] .hero-tree-secondary,
html[data-theme="dark"] .hero-leaf-svg,
html[data-theme="dark"] .services-tree,
html[data-theme="dark"] .services-leaf-svg{
  color:#42C497;
  opacity:.16;
}

html[data-theme="dark"] .hero-shape,
html[data-theme="dark"] .services-shape,
html[data-theme="dark"] .hero-leaf,
html[data-theme="dark"] .services-leaf{
  opacity:.16;
}

html[data-theme="dark"] .tcar-arrow,
html[data-theme="dark"] .btn-light{
  background:#F4FBF8;
  color:#071A20;
}

html[data-theme="dark"] footer{
  background:#06161B;
}

/* Header dark mode toggle */
.theme-toggle{
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(11,33,41,.16);
  background:rgba(255,255,255,.45);
  color:var(--ink);
  display:inline-grid;
  place-items:center;
  cursor:pointer;
  transition:.25s ease;
  margin-left:8px;
  flex:none;
}

.theme-toggle:hover{
  transform:translateY(-1px);
  background:#fff;
}

.theme-toggle svg{
  width:18px;
  height:18px;
  display:block;
}

.theme-toggle .sun{
  display:none;
}

html[data-theme="dark"] .theme-toggle{
  border-color:rgba(166,221,207,.24);
  background:rgba(247,251,249,.08);
  color:var(--ink);
}

html[data-theme="dark"] .theme-toggle:hover{
  background:rgba(247,251,249,.14);
}

html[data-theme="dark"] .theme-toggle .moon{
  display:none;
}

html[data-theme="dark"] .theme-toggle .sun{
  display:block;
}

@media(max-width:960px){
  .theme-toggle{
    margin-left:auto;
    margin-right:10px;
  }
}


/* Mobile hero round logo layout fix */
@media(max-width:860px){
  .hero.hero-home{
    padding-top:128px;
  }

  .hero-lockup{
    grid-template-columns:1fr !important;
    justify-items:center;
    text-align:center;
    gap:18px !important;
    margin-bottom:26px;
  }

  .hero-mark-wrap,
  .hero-brand-logo-wrap{
    justify-content:center !important;
    width:100%;
  }

  .hero-brand-logo{
    width:min(250px,62vw) !important;
    max-width:250px;
    height:auto;
  }

  .hero-title{
    max-width:9.5ch !important;
    width:100%;
    justify-self:center;
    text-align:center;
    font-size:clamp(2.45rem,12.2vw,3.7rem) !important;
    line-height:.9;
    letter-spacing:-.055em;
  }

  .hero.hero-home .lead{
    text-align:left;
    margin-top:22px;
  }
}

@media(max-width:560px){
  .hero-lockup{
    gap:16px !important;
  }

  .hero-brand-logo{
    width:min(220px,60vw) !important;
    max-width:220px;
  }

  .hero-title{
    font-size:clamp(2.25rem,11.4vw,3.15rem) !important;
    max-width:9.5ch !important;
  }
}

@media(max-width:430px){
  .hero.hero-home{
    padding-top:112px;
  }

  .hero-brand-logo{
    width:min(205px,58vw) !important;
    max-width:205px;
  }

  .hero-title{
    font-size:clamp(2rem,10.8vw,2.85rem) !important;
  }
}


/* Dark mode muted text readability fix */
html[data-theme="dark"] .co,
html[data-theme="dark"] .who .co,
html[data-theme="dark"] .fb,
html[data-theme="dark"] .fb span,
html[data-theme="dark"] footer p,
html[data-theme="dark"] footer a,
html[data-theme="dark"] footer span,
html[data-theme="dark"] .brand .sb,
html[data-theme="dark"] .testimonial-tags span,
html[data-theme="dark"] .tcar-dots button,
html[data-theme="dark"] .k,
html[data-theme="dark"] .tag,
html[data-theme="dark"] .more{
  color:rgba(244,251,248,.72) !important;
}

html[data-theme="dark"] .who .nm,
html[data-theme="dark"] .nm,
html[data-theme="dark"] footer .nm{
  color:var(--ink) !important;
}

html[data-theme="dark"] .testimonial-tags span{
  background:rgba(63,191,160,.14) !important;
  border-color:rgba(166,221,207,.22) !important;
}


/* Dark mode testimonial company line fix */
html[data-theme="dark"] .tslide .who .co,
html[data-theme="dark"] .tcar .who .co,
html[data-theme="dark"] .testimonial-card .who .co{
  color:rgba(244,251,248,.72) !important;
  -webkit-text-fill-color:rgba(244,251,248,.72) !important;
  opacity:1 !important;
}

html[data-theme="dark"] .tslide .testimonial-tags span,
html[data-theme="dark"] .tcar .testimonial-tags span{
  color:rgba(166,221,207,.92) !important;
  -webkit-text-fill-color:rgba(166,221,207,.92) !important;
}


/* Contact page info cards as buttons */
.contact .wrap > .r:first-child > a{
  display:block;
  width:100%;
}

.contact .cinfo{
  display:grid !important;
  grid-template-columns:46px 1fr 34px !important;
  align-items:center !important;
  gap:16px !important;
  width:100%;
  margin:0 0 14px !important;
  padding:16px 18px !important;
  border:1px solid rgba(11,33,41,.13) !important;
  border-radius:16px !important;
  background:rgba(247,251,249,.76) !important;
  box-shadow:0 16px 38px -32px rgba(11,33,41,.42) !important;
  transition:transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease !important;
}

.contact .cinfo:hover{
  transform:translateY(-2px);
  border-color:rgba(21,120,78,.34) !important;
  background:#fff !important;
  box-shadow:0 20px 46px -32px rgba(11,33,41,.50) !important;
}

.contact .cinfo .ic{
  width:46px !important;
  height:46px !important;
  border-radius:14px !important;
  background:var(--grad) !important;
  color:#fff !important;
  box-shadow:0 12px 24px -18px rgba(21,120,78,.70) !important;
}

.contact .cinfo .k{
  margin-bottom:2px !important;
  font-size:.72rem !important;
  letter-spacing:.14em !important;
}

.contact .cinfo .v{
  font-weight:800 !important;
  font-size:1.02rem !important;
  color:var(--ink) !important;
}

.contact .wrap > .r:first-child > a .cinfo::after{
  content:"→";
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  justify-self:end;
  font-weight:800;
  color:var(--green);
  background:rgba(21,120,78,.08);
  transition:transform .25s ease, background .25s ease, color .25s ease;
}

.contact .wrap > .r:first-child > a:hover .cinfo::after{
  transform:translateX(3px);
  background:var(--grad);
  color:#fff;
}

/* Keep location aligned even though it is not a link */
.contact .wrap > .r:first-child > .cinfo::after{
  content:"";
  width:34px;
  height:34px;
}

/* Dark mode support */
html[data-theme="dark"] .contact .cinfo{
  background:rgba(247,251,249,.055) !important;
  border-color:rgba(166,221,207,.20) !important;
  box-shadow:none !important;
}

html[data-theme="dark"] .contact .cinfo:hover{
  background:rgba(247,251,249,.085) !important;
  border-color:rgba(166,221,207,.36) !important;
}

html[data-theme="dark"] .contact .cinfo .v{
  color:var(--ink) !important;
  -webkit-text-fill-color:var(--ink) !important;
}

html[data-theme="dark"] .contact .wrap > .r:first-child > a .cinfo::after{
  color:var(--aqua-soft);
  background:rgba(63,191,160,.12);
}

@media(max-width:560px){
  .contact .cinfo{
    grid-template-columns:44px 1fr 30px !important;
    gap:14px !important;
    padding:14px 15px !important;
  }

  .contact .cinfo .ic{
    width:44px !important;
    height:44px !important;
  }
}


/* Remove contact info card arrows */
.contact .wrap > .r:first-child > a .cinfo::after,
.contact .wrap > .r:first-child > .cinfo::after{
  content:none !important;
  display:none !important;
}

.contact .cinfo{
  grid-template-columns:46px 1fr !important;
}

@media(max-width:560px){
  .contact .cinfo{
    grid-template-columns:44px 1fr !important;
  }
}

