/* ============================================================
   AFLATAME ENTERPRISES LTD. — landing site
   Palette derived from the logo: forest green / leaf green,
   with royal blue + ember red strictly as accents.
   Display: Fraunces (organic optical serif) · Body: Plus Jakarta Sans
   ============================================================ */

@font-face{
  font-family:'Plus Jakarta Sans';
  src:url('/fonts/PlusJakartaSans.woff2') format('woff2');
  font-weight:200 800; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'Fraunces';
  src:url('/fonts/Fraunces.woff2') format('woff2');
  font-weight:300 900; font-style:normal; font-display:swap;
}

:root{
  /* greens */
  --forest:#0D5C3A; --forest-600:#0B4E31; --pine:#06291B; --pine-2:#0A3A26;
  --leaf:#1E9E57; --leaf-soft:#5FC98C; --leaf-glow:#8FE0B3;
  /* accents (used sparingly) */
  --royal:#0066CC; --sky:#3E92F0; --ember:#E63946; --ember-soft:#F0808A;
  /* neutrals */
  --ink:#11221A; --slate:#52635A; --muted:#80908650; --line:#E4EBE3;
  --paper:#F4F7F1; --cream:#FBFCF9; --mist:#E8F1E9; --panel:#FFFFFF; --white:#FFFFFF;
  /* type */
  --sans:'Plus Jakarta Sans',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --display:'Fraunces','Iowan Old Style',Georgia,'Times New Roman',serif;
  /* scale */
  --s-eyebrow:clamp(.72rem,.69rem + .12vw,.8rem);
  --s-small:clamp(.84rem,.81rem + .14vw,.93rem);
  --s-body:clamp(1rem,.97rem + .16vw,1.075rem);
  --s-lead:clamp(1.1rem,1.02rem + .4vw,1.3rem);
  --s-h3:clamp(1.2rem,1.08rem + .5vw,1.45rem);
  --s-h2:clamp(1.95rem,1.5rem + 2.2vw,3.05rem);
  --s-h1:clamp(2.7rem,1.9rem + 4.6vw,5.2rem);
  /* layout */
  --maxw:1180px; --gut:clamp(1.25rem,5vw,4rem);
  --r:20px; --r-sm:13px; --r-lg:30px; --pill:999px;
  --sh-1:0 1px 2px rgba(13,40,28,.05),0 6px 18px rgba(13,40,28,.05);
  --sh-2:0 14px 40px -16px rgba(11,78,49,.22);
  --sh-3:0 36px 70px -28px rgba(6,41,27,.42);
  --nav-h:74px;
}

/* reset */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-padding-top:calc(var(--nav-h) + 18px)}
body{
  font-family:var(--sans); font-size:var(--s-body); line-height:1.62;
  color:var(--ink); background:var(--paper); overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-optical-sizing:auto;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit;color:inherit}
h1,h2,h3,h4{font-family:var(--display);font-weight:560;line-height:1.04;letter-spacing:-.018em;font-optical-sizing:auto}
::selection{background:var(--leaf-soft);color:var(--pine)}
:focus-visible{outline:3px solid var(--leaf);outline-offset:3px;border-radius:6px}

/* ---------- primitives ---------- */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(4.5rem,9vh,8rem);position:relative}
.section--tint{background:var(--cream)}
.section--mist{background:linear-gradient(180deg,var(--mist),var(--cream))}
.section--dark{background:var(--pine);color:#DCEAE0}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:var(--s-eyebrow);font-weight:700;letter-spacing:.19em;text-transform:uppercase;
  color:var(--forest);
}
.section--dark .eyebrow{color:var(--leaf-soft)}
.eyebrow__tick{width:26px;height:7px;border-radius:9px;flex:none;
  background:linear-gradient(90deg,var(--leaf) 0 40%,var(--ember) 40% 75%,var(--royal) 75% 100%)}

.head{max-width:42rem}
.head--center{margin-inline:auto;text-align:center}
.head__title{font-size:var(--s-h2);margin-top:.7rem}
.head__lead{font-size:var(--s-lead);color:var(--slate);margin-top:1.1rem;line-height:1.5}
.section--dark .head__lead{color:#B7CcBe}
em.hl{font-style:italic;color:var(--leaf);font-weight:500}
.section--dark em.hl{color:var(--leaf-glow)}

/* buttons */
.btn{
  --bg:var(--forest);--fg:#fff;--bd:transparent;
  display:inline-flex;align-items:center;gap:.6em;
  padding:.92em 1.45em;border-radius:var(--pill);border:1.5px solid var(--bd);
  background:var(--bg);color:var(--fg);font-weight:650;font-size:var(--s-small);
  letter-spacing:.005em;cursor:pointer;transition:transform .25s cubic-bezier(.2,.7,.2,1),
  box-shadow .25s ease,background .25s ease,color .2s ease;white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.btn:active{transform:translateY(0)}
.btn__arrow{transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.btn:hover .btn__arrow{transform:translate(3px,-1px)}
.btn--primary{--bg:var(--forest);--fg:#fff}
.btn--primary:hover{--bg:#0a6b41}
.btn--ghost{--bg:transparent;--fg:var(--forest);--bd:#cbd9cb}
.btn--ghost:hover{--bd:var(--forest);box-shadow:none}
.btn--light{--bg:var(--leaf-glow);--fg:var(--pine)}
.btn--light:hover{--bg:#aeedc8}
.btn--ondark-ghost{--bg:transparent;--fg:#eafff2;--bd:#3a6b50}
.btn--ondark-ghost:hover{--bd:var(--leaf-soft);box-shadow:none}

/* ---------- top hairline + nav ---------- */
.topline{height:4px;width:100%;position:fixed;top:0;left:0;z-index:60;
  background:linear-gradient(90deg,var(--leaf) 0 40%,var(--ember) 40% 75%,var(--royal) 75% 100%)}
.nav{position:fixed;top:4px;left:0;right:0;z-index:50;
  backdrop-filter:saturate(140%) blur(14px);-webkit-backdrop-filter:saturate(140%) blur(14px);
  background:rgba(244,247,241,.82);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;gap:1.4rem;height:var(--nav-h)}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:800}
.brand__mark{width:40px;height:40px;flex:none}
.brand__name{font-family:var(--display);font-weight:600;font-size:1.18rem;letter-spacing:-.02em;color:var(--forest)}
.brand__name small{display:block;font-family:var(--sans);font-weight:600;font-size:.56rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--slate);margin-top:-2px}
.nav__spacer{flex:1}
.nav__links{display:flex;align-items:center;gap:.4rem;list-style:none}
.nav__link{padding:.5rem .8rem;border-radius:var(--pill);font-size:.92rem;font-weight:550;color:var(--ink);
  position:relative;transition:color .2s,background .2s}
.nav__link:hover{color:var(--forest);background:rgba(30,158,87,.09)}
.nav__cta{margin-left:.4rem}
.nav__link--cta{display:none}
.nav__toggle,.nav__check{display:none}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:calc(var(--nav-h) + clamp(2.5rem,7vh,5.5rem));
  padding-bottom:clamp(3rem,7vh,6rem);overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55}
.blob--1{width:540px;height:540px;top:-160px;right:-120px;
  background:radial-gradient(circle,rgba(95,201,140,.55),transparent 70%)}
.blob--2{width:460px;height:460px;bottom:-200px;left:-160px;
  background:radial-gradient(circle,rgba(62,146,240,.28),transparent 70%)}
.hero__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;
  gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero__title{font-size:var(--s-h1);font-weight:550;margin-top:1.3rem}
.hero__lead{font-size:var(--s-lead);color:var(--slate);max-width:34rem;margin-top:1.5rem;line-height:1.5}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero__meta{display:flex;flex-wrap:wrap;gap:.5rem 1.1rem;margin-top:2.2rem;
  font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--slate);text-transform:uppercase}
.hero__meta span{display:inline-flex;align-items:center;gap:.5rem}
.hero__meta span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--leaf)}

/* hero art — the closing-the-loop ring */
.hero__art{position:relative;display:grid;place-items:center;min-height:380px}
.ring{width:min(440px,86%);aspect-ratio:1;position:relative;display:grid;place-items:center}
.ring svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.ring__track{fill:none;stroke:#dfe9df;stroke-width:9}
.ring__arc{fill:none;stroke-width:11;stroke-linecap:round;
  stroke-dasharray:var(--len) 1005;stroke-dashoffset:var(--len);
  animation:draw 1.15s var(--d,0s) cubic-bezier(.45,0,.2,1) forwards}
.ring__arc--g{stroke:var(--leaf)}.ring__arc--r{stroke:var(--ember)}.ring__arc--b{stroke:var(--royal)}
.ring__spin{animation:spin 46s linear infinite;transform-origin:center}
.ring__dot{fill:#cfe2d4}
.ring__logo{width:46%;aspect-ratio:1;border-radius:50%;background:#fff;display:grid;place-items:center;
  box-shadow:0 22px 50px -18px rgba(6,41,27,.45),inset 0 0 0 1px rgba(13,92,58,.06);
  animation:pop 1s .25s cubic-bezier(.2,.9,.25,1.2) both}
.ring__logo img{width:74%}
.chip{position:absolute;display:inline-flex;align-items:center;gap:.5rem;background:#fff;
  border:1px solid var(--line);border-radius:var(--pill);padding:.5rem .85rem;font-size:.78rem;
  font-weight:650;box-shadow:var(--sh-1);white-space:nowrap;animation:rise .8s both}
.chip i{width:9px;height:9px;border-radius:50%;display:block}
.chip--a{top:11%;left:-6%;animation-delay:.7s}.chip--a i{background:var(--ember)}
.chip--b{top:46%;left:-12%;animation-delay:.95s}.chip--b i{background:var(--royal)}
.chip--c{bottom:12%;right:-7%;animation-delay:1.15s}.chip--c i{background:var(--leaf)}

/* ---------- stats strip ---------- */
.stats{background:linear-gradient(120deg,var(--forest),#0a4a30 55%,var(--pine));color:#eafff3;position:relative;overflow:hidden}
.stats::after{content:"";position:absolute;right:-80px;top:-120px;width:360px;height:360px;border-radius:50%;
  border:28px solid rgba(255,255,255,.05)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.12);
  border-radius:var(--r);overflow:hidden}
.stat{background:transparent;padding:clamp(1.4rem,3vw,2.3rem)}
.stat__num{font-family:var(--display);font-weight:580;font-size:clamp(2.1rem,1.4rem + 2.6vw,3.4rem);
  line-height:1;letter-spacing:-.02em;color:#fff}
.stat__num b{color:var(--leaf-soft);font-weight:580}
.stat__label{margin-top:.6rem;font-size:.86rem;color:#bfe0cc;line-height:1.35;max-width:14rem}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.4rem);margin-top:clamp(2.2rem,4vw,3.4rem)}
.svc{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:1.8rem 1.6rem 1.7rem;overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;transform:scaleX(0);transform-origin:left;
  transition:transform .4s cubic-bezier(.2,.7,.2,1);background:var(--accent,var(--leaf))}
.svc:hover{transform:translateY(-7px);box-shadow:var(--sh-3);border-color:transparent}
.svc:hover::before{transform:scaleX(1)}
.svc__icon{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;margin-bottom:1.15rem;
  background:color-mix(in srgb,var(--accent,var(--leaf)) 13%,#fff);color:var(--accent,var(--leaf))}
.svc__icon svg{width:27px;height:27px}
.svc__title{font-size:var(--s-h3);margin-bottom:.5rem;letter-spacing:-.01em}
.svc__text{font-size:.95rem;color:var(--slate);line-height:1.55}
.svc--a{--accent:var(--leaf)}.svc--b{--accent:var(--royal)}.svc--c{--accent:var(--forest)}.svc--d{--accent:var(--ember)}

/* ---------- process / loop ---------- */
.flow{margin-top:clamp(2.4rem,4vw,3.6rem);position:relative}
.flow__line{position:absolute;top:34px;left:7%;right:7%;height:3px;z-index:0;
  background:linear-gradient(90deg,var(--leaf) 0 40%,var(--ember) 40% 75%,var(--royal) 75% 100%);opacity:.5;border-radius:3px}
.flow__steps{display:grid;grid-template-columns:repeat(5,1fr);gap:1.2rem;position:relative;z-index:1}
.step{text-align:left}
.step__num{width:68px;height:68px;border-radius:50%;background:var(--cream);border:2px solid var(--line);
  display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--forest);
  margin-bottom:1.1rem;position:relative;transition:transform .3s,border-color .3s,box-shadow .3s}
.step__num::after{content:"";position:absolute;inset:-2px;border-radius:50%;border:2px solid transparent}
.step:hover .step__num{transform:translateY(-4px);border-color:var(--leaf);box-shadow:var(--sh-2)}
.step__icon{position:absolute;bottom:-9px;right:-9px;width:30px;height:30px;border-radius:50%;background:var(--forest);
  color:#fff;display:grid;place-items:center}
.step__icon svg{width:16px;height:16px}
.step__title{font-family:var(--sans);font-weight:700;font-size:1.02rem;letter-spacing:.01em;margin-bottom:.4rem}
.step__text{font-size:.88rem;color:var(--slate);line-height:1.5}
.flow__loop{display:inline-flex;align-items:center;gap:.6rem;margin-top:2.4rem;font-weight:650;font-size:.88rem;
  color:var(--forest);background:#fff;border:1px solid var(--line);padding:.6rem 1.05rem;border-radius:var(--pill)}
.flow__loop svg{width:18px;height:18px;animation:spin 14s linear infinite}

/* ---------- impact ---------- */
.impact__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.impact__quote{font-family:var(--display);font-weight:480;font-size:clamp(1.5rem,1.1rem + 1.7vw,2.3rem);
  line-height:1.22;letter-spacing:-.015em;color:var(--ink)}
.impact__quote b{color:var(--leaf);font-weight:560}
.impact__points{margin-top:2rem;display:grid;gap:1.2rem}
.point{display:flex;gap:1rem;align-items:flex-start}
.point__icon{width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;
  background:var(--mist);color:var(--forest)}
.point__icon svg{width:21px;height:21px}
.point h4{font-family:var(--sans);font-weight:700;font-size:1rem;margin-bottom:.2rem}
.point p{font-size:.9rem;color:var(--slate);line-height:1.5}
.impact__panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--sh-1)}
.impact__panel h4{font-family:var(--sans);font-weight:700;font-size:.82rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--slate);margin-bottom:1.5rem}
.bar{margin-bottom:1.35rem}
.bar:last-child{margin-bottom:0}
.bar__meta{display:flex;justify-content:space-between;font-size:.9rem;font-weight:600;margin-bottom:.5rem}
.bar__meta b{font-family:var(--display);font-weight:560}
.bar__track{height:11px;border-radius:9px;background:var(--mist);overflow:hidden}
.bar__fill{height:100%;border-radius:9px;width:var(--w,0%);transform-origin:left;
  transition:transform 1.1s cubic-bezier(.3,.8,.3,1)}
.bar--a .bar__fill{background:linear-gradient(90deg,var(--leaf),var(--leaf-soft))}
.bar--b .bar__fill{background:linear-gradient(90deg,var(--royal),var(--sky))}
.bar--c .bar__fill{background:linear-gradient(90deg,var(--slate),#9aa89f)}
.impact__note{margin-top:1.4rem;font-size:.74rem;color:var(--slate);opacity:.8}

/* ---------- about ---------- */
.about__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.about__body p{color:var(--slate);font-size:var(--s-lead);line-height:1.55;margin-top:1.1rem;max-width:38rem}
.creed{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:2rem}
.creed__pill{display:inline-flex;align-items:center;gap:.55rem;padding:.55rem 1.05rem;border-radius:var(--pill);
  font-weight:650;font-size:.9rem;background:#fff;border:1px solid var(--line)}
.creed__pill i{width:10px;height:10px;border-radius:50%;display:block}
.creed__pill--1 i{background:var(--leaf)}.creed__pill--2 i{background:var(--royal)}
.creed__pill--3 i{background:var(--ember)}.creed__pill--4 i{background:var(--forest)}
.about__mark{position:relative;display:grid;place-items:center}
.about__mark .disc{width:min(360px,82%);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#fff,var(--mist));display:grid;place-items:center;
  box-shadow:var(--sh-2),inset 0 0 0 1px rgba(13,92,58,.06)}
.about__mark .disc img{width:62%}
.about__mark .ring2{position:absolute;width:min(360px,82%);aspect-ratio:1}
.about__mark .ring2 circle{fill:none;stroke-width:6;stroke-linecap:round}

/* ---------- CTA ---------- */
.cta{position:relative;overflow:hidden}
.cta__panel{position:relative;background:linear-gradient(135deg,var(--forest),var(--pine));color:#eafff3;
  border-radius:var(--r-lg);padding:clamp(2.6rem,6vw,5rem);overflow:hidden}
.cta__panel::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;right:-160px;top:-220px;
  border:36px solid rgba(255,255,255,.06)}
.cta__panel::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;left:-140px;bottom:-200px;
  background:radial-gradient(circle,rgba(95,201,140,.25),transparent 70%)}
.cta__inner{position:relative;z-index:1;max-width:40rem}
.cta__title{font-size:var(--s-h2);color:#fff}
.cta__title em.hl{color:var(--leaf-glow)}
.cta__text{margin-top:1.1rem;color:#c3ddcc;font-size:var(--s-lead);line-height:1.5}
.cta__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.1rem}

/* ---------- contact ---------- */
.contact__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem)}
.contact__details{display:grid;gap:1.3rem;align-content:start}
.cdetail{display:flex;gap:1rem;align-items:flex-start}
.cdetail__icon{width:44px;height:44px;border-radius:12px;flex:none;display:grid;place-items:center;
  background:var(--mist);color:var(--forest)}
.cdetail__icon svg{width:21px;height:21px}
.cdetail h4{font-family:var(--sans);font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--slate);margin-bottom:.25rem}
.cdetail p,.cdetail a{font-size:1.02rem;font-weight:550;color:var(--ink)}
.cdetail a:hover{color:var(--forest);text-decoration:underline;text-underline-offset:3px}
.contact__form{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--sh-1)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.05rem;display:block}
.field span{display:block;font-size:.8rem;font-weight:650;color:var(--slate);margin-bottom:.4rem}
.input,.textarea{width:100%;padding:.8rem .95rem;border:1.5px solid var(--line);border-radius:12px;
  background:var(--cream);font-size:.96rem;transition:border-color .2s,box-shadow .2s,background .2s}
.input:focus,.textarea:focus{outline:none;border-color:var(--leaf);background:#fff;
  box-shadow:0 0 0 4px rgba(30,158,87,.12)}
.textarea{resize:vertical;min-height:120px}
.contact__form .btn{width:100%;justify-content:center;margin-top:.3rem}

/* ---------- footer ---------- */
.footer{background:var(--pine);color:#a9c4b3;padding-top:clamp(3.5rem,7vw,5.5rem);padding-bottom:2rem}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:clamp(1.6rem,4vw,3rem);
  padding-bottom:clamp(2.4rem,4vw,3.4rem);border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand .brand__name{color:#fff}
.footer__brand .brand__name small{color:#86a795}
.footer__badge{width:46px;height:46px;border-radius:50%;background:#fff;display:grid;place-items:center;flex:none}
.footer__badge img{width:74%}
.footer__blurb{margin-top:1.1rem;font-size:.93rem;line-height:1.55;max-width:22rem;color:#9bb8a8}
.footer__creed{display:flex;gap:.45rem;margin-top:1.3rem;font-size:.7rem;font-weight:700;letter-spacing:.13em;
  text-transform:uppercase;color:#7fa08e;flex-wrap:wrap}
.footer__creed b{color:var(--leaf-soft);font-weight:700}
.fcol__title{font-family:var(--sans);font-weight:700;font-size:.76rem;letter-spacing:.13em;text-transform:uppercase;
  color:#cfe2d6;margin-bottom:1.1rem}
.fcol ul{list-style:none;display:grid;gap:.7rem}
.flink{font-size:.93rem;color:#a9c4b3;transition:color .2s}
.flink:hover{color:#fff}
.social{display:flex;gap:.6rem;margin-top:1.2rem}
.social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.07);color:#cfe2d6;transition:background .2s,transform .2s}
.social a:hover{background:var(--leaf);color:#fff;transform:translateY(-2px)}
.social svg{width:18px;height:18px}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-top:1.6rem;font-size:.82rem;color:#86a795}
.footer__bottom .tri{display:inline-block;width:64px;height:5px;border-radius:6px;vertical-align:middle;margin-right:.6rem;
  background:linear-gradient(90deg,var(--leaf) 0 40%,var(--ember) 40% 75%,var(--royal) 75% 100%)}

/* ---------- reveal + motion ---------- */
@media (prefers-reduced-motion:no-preference){
  html{scroll-behavior:smooth}
  html.js .reveal{opacity:0;transform:translateY(22px);
    transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
  html.js .reveal.in{opacity:1;transform:none}
  html.js .reveal[data-d="1"]{transition-delay:.08s}
  html.js .reveal[data-d="2"]{transition-delay:.16s}
  html.js .reveal[data-d="3"]{transition-delay:.24s}
  html.js .reveal[data-d="4"]{transition-delay:.32s}
}
@media (prefers-reduced-motion:reduce){
  .ring__arc{animation:none;stroke-dashoffset:0}
  .ring__logo,.chip{animation:none}
  .ring__spin,.flow__loop svg{animation:none}
  .bar__fill{transition:none}
}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pop{from{opacity:0;transform:scale(.82)}to{opacity:1;transform:scale(1)}}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .footer__top{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1 / -1}
}
@media (max-width:900px){
  .hero__grid{grid-template-columns:1fr;gap:2.5rem}
  .hero__art{order:-1;min-height:300px}
  .ring{width:min(360px,72%)}
  .chip{display:none}
  .impact__grid,.about__grid,.contact__grid{grid-template-columns:1fr}
  .about__mark{order:-1}
  .svc-grid{grid-template-columns:1fr 1fr}
  .stats__grid{grid-template-columns:1fr 1fr}
  .flow__line{display:none}
  .flow__steps{grid-template-columns:1fr;gap:0}
  .step{display:grid;grid-template-columns:68px 1fr;gap:1.1rem;align-items:start;
    padding-bottom:1.6rem;position:relative}
  .step__num{margin-bottom:0}
  .step:not(:last-child)::before{content:"";position:absolute;left:33px;top:68px;bottom:-2px;width:2px;
    background:var(--line)}
  .step__body{padding-top:.6rem}
}
@media (max-width:680px){
  /* mobile nav */
  .nav__links{position:fixed;inset:calc(var(--nav-h) + 4px) 0 auto 0;flex-direction:column;align-items:stretch;
    gap:.2rem;background:rgba(244,247,241,.98);backdrop-filter:blur(14px);padding:1rem var(--gut) 1.6rem;
    border-bottom:1px solid var(--line);box-shadow:var(--sh-2);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
  .nav__check:checked ~ .nav__links{transform:none;opacity:1;pointer-events:auto}
  .nav__link{padding:.85rem .6rem;font-size:1.02rem;border-bottom:1px solid var(--line)}
  .nav__link--cta{display:block;border-bottom:none;margin-top:.6rem}
  .nav__cta{display:none}
  .nav__links .btn{justify-content:center}
  .nav__toggle{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;cursor:pointer;
    border:1px solid var(--line);background:#fff}
  .nav__toggle span,.nav__toggle span::before,.nav__toggle span::after{content:"";display:block;width:18px;height:2px;
    background:var(--ink);border-radius:2px;position:relative;transition:transform .25s,opacity .2s}
  .nav__toggle span::before{position:absolute;top:-6px}.nav__toggle span::after{position:absolute;top:6px}
  .nav__check:checked ~ .nav__toggle span{background:transparent}
  .nav__check:checked ~ .nav__toggle span::before{transform:translateY(6px) rotate(45deg)}
  .nav__check:checked ~ .nav__toggle span::after{transform:translateY(-6px) rotate(-45deg)}
  .svc-grid,.stats__grid{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;align-items:flex-start}
  .hero__cta .btn{flex:1 1 auto;justify-content:center}
}
