/* ===================================================================
   HANKAKA TECHNOLOGIES — shared design system (multi-page build)
   Brand: Google Blue #4285F4 (major) · Red #EA4335 (minor) · Green #34A853 (sustainability)
   Type: Inter + Inter Tight. Light & dark themes via [data-theme].
   =================================================================== */

/* ---------- Self-hosted fonts (Inter + Inter Tight, latin subset) ---------- */
@font-face{font-family:"Inter";font-style:normal;font-weight:400;font-display:swap;src:url("../fonts/inter-400.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:500;font-display:swap;src:url("../fonts/inter-500.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/inter-600.woff2") format("woff2")}
@font-face{font-family:"Inter";font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/inter-700.woff2") format("woff2")}
@font-face{font-family:"Inter Tight";font-style:normal;font-weight:600;font-display:swap;src:url("../fonts/inter-tight-600.woff2") format("woff2")}
@font-face{font-family:"Inter Tight";font-style:normal;font-weight:700;font-display:swap;src:url("../fonts/inter-tight-700.woff2") format("woff2")}
@font-face{font-family:"Inter Tight";font-style:normal;font-weight:800;font-display:swap;src:url("../fonts/inter-tight-800.woff2") format("woff2")}

/* ---------- Tokens ---------- */
:root {
  --blue-50:#e8f0fe; --blue-100:#d2e3fc; --blue-200:#aecbfa; --blue-400:#669df6;
  --blue:#4285f4; --blue-600:#1a73e8; --blue-700:#1967d2; --blue-800:#185abc; --blue-900:#174ea6;
  --red-50:#fce8e6; --red:#ea4335; --red-600:#d93025; --red-700:#c5221f;
  --green-50:#e6f4ea; --green:#34a853; --green-700:#1e8e3e; --green-800:#188038;
  --yellow:#fbbc04;

  --grad-brand: linear-gradient(135deg,#4285f4 0%,#1a73e8 100%);
  --grad-google: linear-gradient(90deg,#4285f4,#34a853 55%,#fbbc04 78%,#ea4335);
  --grad-navy: linear-gradient(160deg,#0a1730 0%,#0f2247 55%,#123163 100%);

  --bg:#ffffff; --bg-subtle:#f6f9fd; --surface:#ffffff; --surface-2:#f7f9fc;
  --text:#1f2733; --text-strong:#111722; --text-soft:#3c4250; --muted:#5f6675;
  --line:#e4e9f1; --line-strong:#d4dbe6; --link:var(--blue-700);
  --header-bg:rgba(255,255,255,.82);
  --hero-grad: radial-gradient(1200px 600px at 78% -10%, #e8f0fe 0%, rgba(232,240,254,0) 60%),
               radial-gradient(900px 500px at -5% 10%, #f0f6ff 0%, rgba(240,246,255,0) 55%);
  --map-bg:#f1f5fb; --map-dot:#d2e3fc; --grid-line:#e8eef7;

  --shadow-xs:0 1px 2px rgba(15,34,71,.06);
  --shadow-sm:0 2px 8px rgba(15,34,71,.06),0 1px 2px rgba(15,34,71,.04);
  --shadow-md:0 10px 30px rgba(15,34,71,.08),0 2px 8px rgba(15,34,71,.05);
  --shadow-lg:0 24px 60px rgba(15,34,71,.12),0 8px 20px rgba(15,34,71,.06);
  --shadow-blue:0 14px 30px rgba(26,115,232,.28);

  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;
  --container:1200px; --gutter:clamp(1.15rem,4vw,2.5rem); --section-y:clamp(3.5rem,7vw,6.5rem);
  --font-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-display:"Inter Tight",var(--font-sans);
  --ease:cubic-bezier(.4,0,.2,1); --ease-out:cubic-bezier(.16,1,.3,1);
}
[data-theme="dark"] {
  --bg:#0b1220; --bg-subtle:#0f1830; --surface:#131d33; --surface-2:#18223c;
  --text:#e7ecf4; --text-strong:#f4f7fb; --text-soft:#c4ccda; --muted:#93a0b5;
  --line:#243149; --line-strong:#2e3d59; --link:var(--blue-400);
  --header-bg:rgba(11,18,32,.72);
  --hero-grad: radial-gradient(1200px 600px at 80% -10%, rgba(26,115,232,.18) 0%, transparent 60%),
               radial-gradient(900px 520px at -5% 8%, rgba(52,168,83,.10) 0%, transparent 55%);
  --map-bg:#0e1932; --map-dot:#243a63; --grid-line:#16223c;
  --shadow-xs:0 1px 2px rgba(0,0,0,.4); --shadow-sm:0 2px 10px rgba(0,0,0,.4);
  --shadow-md:0 12px 32px rgba(0,0,0,.5); --shadow-lg:0 26px 64px rgba(0,0,0,.6);
  --shadow-blue:0 14px 34px rgba(26,115,232,.4);
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:var(--font-sans);font-size:1.0625rem;line-height:1.7;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;transition:background-color .4s var(--ease),color .4s var(--ease)}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:var(--link);text-decoration:none;transition:color .18s var(--ease)}
a:hover{color:var(--blue-800)}
ul,ol{padding:0;list-style:none}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;background:none;border:none}
::selection{background:var(--blue-200);color:#08111f}
:focus-visible{outline:3px solid var(--blue-600);outline-offset:2px;border-radius:4px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display);color:var(--text-strong);line-height:1.12;letter-spacing:-.02em;font-weight:700;text-wrap:balance}
h1{font-size:clamp(2.3rem,1.4rem + 4vw,3.7rem);letter-spacing:-.03em}
h2{font-size:clamp(1.85rem,1.2rem + 2.4vw,2.65rem)}
h3{font-size:clamp(1.3rem,1.05rem + 1vw,1.6rem);letter-spacing:-.015em}
h4{font-size:1.15rem;letter-spacing:-.01em}
p{color:var(--text-soft)}p+p{margin-top:1rem}
strong,b{font-weight:600;color:var(--text)}
.lead{font-size:clamp(1.08rem,1rem + .5vw,1.3rem);line-height:1.6;color:var(--text-soft)}
.overline{display:inline-flex;align-items:center;gap:.55rem;font-size:.8rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-700)}
.overline::before{content:none}
.overline--center{justify-content:center}
.overline--light{color:var(--blue-200)}
.overline--light::before{background:linear-gradient(90deg,var(--blue-400),var(--green))}
[data-theme="dark"] .overline{color:var(--blue-400)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:820px}
.section{padding-block:var(--section-y)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.section--subtle{background:var(--bg-subtle)}
.section--tint{background:radial-gradient(700px 380px at 90% 0%, color-mix(in srgb,var(--blue-50) 60%, transparent), transparent 60%),var(--bg-subtle)}
.section-head{max-width:760px;margin-bottom:clamp(2rem,4vw,3.25rem)}
.section-head--center{margin-inline:auto;text-align:center}
.section-head .overline{margin-bottom:1rem}.section-head p{margin-top:1rem}
.grid{display:grid;gap:clamp(1.1rem,2.4vw,1.7rem)}
.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Buttons ---------- */
.btn{--py:.82rem;--px:1.5rem;display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:var(--py) var(--px);font-size:.98rem;font-weight:600;line-height:1.1;border-radius:var(--r-pill);border:1.5px solid transparent;white-space:nowrap;text-align:center;transition:transform .2s var(--ease-out),box-shadow .2s var(--ease),background-color .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease)}
.btn svg{width:1.15em;height:1.15em;transition:transform .25s var(--ease-out)}
.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}
.btn--lg{--py:1rem;--px:1.9rem;font-size:1.05rem}.btn--sm{--py:.6rem;--px:1.1rem;font-size:.9rem}.btn--block{width:100%}
.btn--primary{background:var(--blue-700);color:#fff;box-shadow:var(--shadow-blue)}
.btn--primary:hover{background:var(--blue-800);color:#fff;box-shadow:0 18px 38px rgba(26,115,232,.36)}
.btn--primary:hover svg{transform:translateX(3px)}
.btn--ghost{background:var(--surface);color:var(--blue-800);border-color:var(--line-strong);box-shadow:var(--shadow-xs)}
.btn--ghost:hover{border-color:var(--blue-200);color:var(--blue-800);background:color-mix(in srgb,var(--blue-50) 60%,var(--surface))}
[data-theme="dark"] .btn--ghost{color:var(--blue-400)}[data-theme="dark"] .btn--ghost:hover{background:var(--surface-2)}
.btn--outline-white{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.4)}
.btn--outline-white:hover{background:#fff;color:var(--blue-900);border-color:#fff}
.btn--green{background:var(--green-700);color:#fff;box-shadow:0 14px 30px rgba(30,142,62,.28)}
.btn--green:hover{background:var(--green-800);color:#fff}
.btn--text{padding-inline:0;color:var(--link);font-weight:600}
.btn--text:hover svg{transform:translateX(4px)}

/* ---------- Pills ---------- */
.pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;font-size:.8rem;font-weight:600;letter-spacing:.02em;border-radius:var(--r-pill);background:var(--blue-50);color:var(--blue-800);border:1px solid var(--blue-100)}
[data-theme="dark"] .pill{background:rgba(66,133,244,.14);color:var(--blue-200);border-color:rgba(66,133,244,.3)}
.pill--green{background:var(--green-50);color:var(--green-800);border-color:#ceead6}
[data-theme="dark"] .pill--green{background:rgba(52,168,83,.16);color:#7fd79b;border-color:rgba(52,168,83,.34)}
.pill--ghost{background:transparent;color:var(--muted);border-color:var(--line)}
.pill .dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.pill--live .dot{background:var(--green);box-shadow:0 0 0 0 rgba(52,168,83,.6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,168,83,.55)}70%{box-shadow:0 0 0 7px rgba(52,168,83,0)}100%{box-shadow:0 0 0 0 rgba(52,168,83,0)}}

/* ---------- Skip link ---------- */
.skip-link{position:absolute;left:1rem;top:-60px;z-index:300;background:var(--blue-700);color:#fff;padding:.65rem 1.1rem;border-radius:var(--r-sm);transition:top .2s var(--ease)}
.skip-link:focus{top:1rem;color:#fff}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:var(--header-bg);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid transparent;transition:border-color .25s var(--ease),box-shadow .25s var(--ease),background-color .4s var(--ease)}
.site-header.is-scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;gap:1.25rem;height:72px}
.brand{display:inline-flex;align-items:center;gap:.65rem;flex-shrink:0}
.brand__logo{width:40px;height:40px;flex-shrink:0}
.brand__lockup{height:46px;width:auto;display:block;border-radius:6px}
.site-footer .brand__lockup{background:#fff;padding:8px 12px;border-radius:10px}
[data-theme="dark"] .site-header .brand__lockup{background:#fff;padding:6px 10px;border-radius:9px}
@media (max-width:480px){.brand__lockup{height:40px}}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--font-display);font-weight:800;font-size:1.28rem;letter-spacing:-.02em;color:var(--text-strong)}
.brand__tag{font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-700);margin-top:3px}
[data-theme="dark"] .brand__tag{color:var(--blue-400)}
.nav__links{display:flex;align-items:center;gap:.1rem;margin-left:auto}
.nav__link{position:relative;padding:.5rem .6rem;font-size:.92rem;font-weight:500;color:var(--text-soft);border-radius:var(--r-sm);white-space:nowrap}
.nav__link:hover{color:var(--blue-800);background:color-mix(in srgb,var(--blue-50) 70%,transparent)}
[data-theme="dark"] .nav__link:hover{color:var(--blue-200);background:rgba(66,133,244,.12)}
.nav__link.is-active{color:var(--blue-800)}[data-theme="dark"] .nav__link.is-active{color:var(--blue-200)}
.nav__link.is-active::after{content:"";position:absolute;left:.6rem;right:.6rem;bottom:.1rem;height:2px;border-radius:2px;background:var(--grad-brand)}
.nav__tools{display:flex;align-items:center;gap:.5rem;margin-left:.6rem}
.theme-toggle{display:grid;place-items:center;width:42px;height:42px;border-radius:var(--r-pill);border:1.5px solid var(--line-strong);color:var(--text-soft);background:var(--surface);transition:border-color .2s,color .2s,background-color .2s,transform .2s var(--ease-out)}
.theme-toggle:hover{color:var(--blue-700);border-color:var(--blue-200);transform:translateY(-1px)}
.theme-toggle svg{width:20px;height:20px}.theme-toggle .moon{display:none}
[data-theme="dark"] .theme-toggle .sun{display:none}[data-theme="dark"] .theme-toggle .moon{display:block}
.nav__toggle{display:none;width:44px;height:44px;border-radius:var(--r-sm);color:var(--text)}
.nav__toggle:hover{background:color-mix(in srgb,var(--blue-50) 70%,transparent)}
.nav__toggle svg{width:26px;height:26px;margin-inline:auto}
.nav__toggle .icon-close{display:none}
.nav__toggle[aria-expanded="true"] .icon-open{display:none}
.nav__toggle[aria-expanded="true"] .icon-close{display:block}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--hero-grad),var(--bg);overflow:hidden;padding-block:clamp(2.6rem,6vw,5rem) clamp(3rem,7vw,5.5rem)}
.hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:radial-gradient(900px 520px at 80% 12%,#000,transparent 72%);mask-image:radial-gradient(900px 520px at 80% 12%,#000,transparent 72%);opacity:.6;pointer-events:none}
.hero>.container{position:relative;z-index:1}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero__content{max-width:620px}.hero h1{margin-block:1.1rem}
.hero__sub{font-size:clamp(1.05rem,1rem + .45vw,1.22rem);color:var(--text-soft)}
.hero__actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.9rem}
.hero__trust{display:flex;flex-wrap:wrap;align-items:center;gap:1rem 1.5rem;margin-top:2.3rem;padding-top:1.5rem;border-top:1px solid var(--line)}
.hero__trust-item{display:flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:500;color:var(--muted)}
.hero__trust-item svg{width:1.2rem;height:1.2rem;color:var(--green-700);flex-shrink:0}
[data-theme="dark"] .hero__trust-item svg{color:#5bc77d}
.hero__art{position:relative}

/* ---------- Connectivity card ---------- */
.connect-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);padding:1.4rem;overflow:hidden}
.connect-card__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.connect-card__title{font-size:.92rem;font-weight:600;color:var(--text)}
.connect-map{width:100%;height:auto;border-radius:var(--r-md)}
.map-bg{fill:var(--map-bg)}.map-dot-fill{fill:var(--map-dot)}.map-label{fill:var(--text)}.map-sub{fill:var(--muted)}
.connect-card__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.7rem;margin-top:1.1rem}
.mini-stat{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);padding:.75rem .85rem}
.mini-stat__num{font-family:var(--font-display);font-weight:800;font-size:1.4rem;color:var(--blue-700);line-height:1;letter-spacing:-.02em}
[data-theme="dark"] .mini-stat__num{color:var(--blue-400)}
.mini-stat__label{font-size:.74rem;color:var(--muted);margin-top:.3rem}
.float-badge{position:absolute;display:inline-flex;align-items:center;gap:.5rem;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-md);border-radius:var(--r-pill);padding:.5rem .9rem;font-size:.82rem;font-weight:600;color:var(--text)}
.float-badge svg{width:1.1rem;height:1.1rem}
.float-badge--tr{top:-.6rem;right:1rem;color:var(--green-700)}
.float-badge--bl{bottom:2.4rem;left:-.8rem;color:var(--blue-700)}
[data-theme="dark"] .float-badge--tr{color:#5bc77d}[data-theme="dark"] .float-badge--bl{color:var(--blue-400)}

/* ---------- Clients strip ---------- */
.clients{border-block:1px solid var(--line);background:var(--surface)}
.clients__label{text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1.4rem}
.clients__row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.7rem 1rem}
.client-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1rem;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--surface-2);font-size:.86rem;font-weight:600;color:var(--text-soft)}
.client-chip svg{width:1.05rem;height:1.05rem;color:var(--blue-600)}

/* ---------- Cards ---------- */
.card-tile{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease),border-color .3s}
.card-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue-100)}
.icon-tile{display:grid;place-items:center;width:52px;height:52px;border-radius:var(--r-md);background:var(--blue-50);color:var(--blue-700);margin-bottom:1.1rem}
[data-theme="dark"] .icon-tile{background:rgba(66,133,244,.16);color:var(--blue-400)}
.icon-tile svg{width:26px;height:26px}
.icon-tile--green{background:var(--green-50);color:var(--green-700)}
[data-theme="dark"] .icon-tile--green{background:rgba(52,168,83,.16);color:#5bc77d}
.icon-tile--red{background:var(--red-50);color:var(--red-600)}
[data-theme="dark"] .icon-tile--red{background:rgba(234,67,53,.16);color:#f3897e}
.card-tile h3,.pillar h3{margin-bottom:.5rem}.card-tile p,.pillar p{font-size:.96rem}
.kicker{font-weight:600;color:var(--blue-800)}[data-theme="dark"] .kicker{color:var(--blue-200)}

/* ---------- Service cards ---------- */
.service-card{position:relative;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.7rem;overflow:hidden;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease),border-color .3s}
.service-card::before{content:none}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-card h3{font-size:1.22rem;margin-bottom:.55rem}
.service-card p{font-size:.96rem;flex-grow:1}.service-card .btn--text{margin-top:1.1rem;align-self:flex-start}
.service-card__flag{position:absolute;top:1.1rem;right:1.1rem}
.service-card--feature{background:var(--grad-navy);border-color:transparent;color:#fff}
.service-card--feature::before{transform:scaleX(1);background:var(--grad-google);height:5px}
.service-card--feature h3{color:#fff}.service-card--feature p{color:rgba(255,255,255,.82)}
.service-card--feature .icon-tile{background:rgba(255,255,255,.12);color:#fff}
.service-card--feature .btn--text{color:var(--blue-200)}.service-card--feature .btn--text:hover{color:#fff}

/* ---------- Split / feature list ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.feature-list{display:grid;gap:1.1rem;margin-top:1.6rem}
.feature-item{display:flex;gap:.9rem;align-items:flex-start}
.feature-item__icon{flex-shrink:0;display:grid;place-items:center;width:38px;height:38px;border-radius:10px;background:var(--blue-50);color:var(--blue-700)}
[data-theme="dark"] .feature-item__icon{background:rgba(66,133,244,.16);color:var(--blue-400)}
.feature-item__icon svg{width:20px;height:20px}
.feature-item h4{margin-bottom:.15rem}.feature-item p{font-size:.95rem;margin:0}

/* ---------- Check list ---------- */
.check-list{display:grid;gap:.7rem}
.check-list li{position:relative;padding-left:1.9rem;color:var(--text-soft)}
.check-list li::before{content:"";position:absolute;left:0;top:.28rem;width:20px;height:20px;border-radius:50%;background:var(--green-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231e8e3e' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/13px no-repeat}
[data-theme="dark"] .check-list li::before{background-color:rgba(52,168,83,.18)}
.check-list--cols{grid-template-columns:repeat(2,1fr);column-gap:1.8rem}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.stat{text-align:center}
.stat__num{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem,1.6rem + 2vw,3rem);letter-spacing:-.03em;line-height:1;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat__label{margin-top:.55rem;font-size:.92rem;color:var(--muted)}

/* ---------- Specialities / usecases ---------- */
.spec-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;height:100%;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease)}
.spec-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.spec-card .icon-tile{width:50px;height:50px}.spec-card h3{font-size:1.1rem;margin-bottom:.5rem}.spec-card p{font-size:.93rem;margin:0}
.spec-card--green{}
.usecase{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;height:100%}
.usecase__tag{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--blue-700)}
[data-theme="dark"] .usecase__tag{color:var(--blue-400)}
.usecase h3{font-size:1.1rem;margin:.6rem 0}.usecase p{font-size:.94rem;margin:0}

/* ---------- Sustainability ---------- */
.sustain{position:relative;overflow:hidden;background:linear-gradient(160deg,#0c2a1a 0%,#0f3b25 60%,#14502f 100%);color:#fff;border-radius:var(--r-xl)}
.sustain::before{content:"";position:absolute;inset:0;background:radial-gradient(480px 300px at 88% -10%,rgba(52,168,83,.55),transparent 60%),radial-gradient(420px 280px at 0% 120%,rgba(66,133,244,.3),transparent 60%);pointer-events:none}
.sustain__inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center;padding:clamp(2rem,5vw,3.5rem)}
.sustain h2{color:#fff}.sustain p{color:rgba(255,255,255,.85)}
.sustain .overline{color:#8fe3a8}.sustain .overline::before{background:linear-gradient(90deg,#34a853,#a8e6b8)}
.sustain__badge{display:grid;place-items:center;aspect-ratio:1;max-width:300px;margin-inline:auto;border-radius:50%;background:radial-gradient(circle at 50% 40%,rgba(52,168,83,.35),rgba(10,40,25,.2));border:1px solid rgba(168,230,184,.3)}
.sustain__badge svg{width:46%;height:46%;color:#a8e6b8}

/* ---------- Testimonials ---------- */
.testi-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.7rem;height:100%;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease)}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testi-card__stars{display:flex;gap:.15rem;margin-bottom:.7rem;color:var(--yellow)}
.testi-card__stars svg{width:1rem;height:1rem;fill:currentColor}
.testi-card blockquote{font-size:1rem;line-height:1.65;color:var(--text-soft);flex-grow:1}
.testi-card__service{margin-top:1rem;align-self:flex-start;font-size:.74rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--blue-700);background:var(--blue-50);border:1px solid var(--blue-100);padding:.3rem .7rem;border-radius:var(--r-pill)}
[data-theme="dark"] .testi-card__service{background:rgba(66,133,244,.14);color:var(--blue-200);border-color:rgba(66,133,244,.3)}
.testi-card__author{display:flex;align-items:center;gap:.85rem;margin-top:1.3rem;padding-top:1.3rem;border-top:1px solid var(--line)}
.avatar{position:relative;width:50px;height:50px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--grad-brand);display:grid;place-items:center}
.avatar__init{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:#fff;letter-spacing:.02em}
.avatar__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.testi-card__name{font-weight:700;color:var(--text-strong);font-size:.98rem;line-height:1.2}
.testi-card__role{font-size:.84rem;color:var(--muted);margin-top:.15rem}

/* ---------- Insights ---------- */
.insight-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease),border-color .3s}
.insight-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.insight-card__thumb{position:relative;aspect-ratio:16/9;overflow:hidden}.insight-card__thumb svg{width:100%;height:100%}
.insight-card__body{padding:1.5rem;display:flex;flex-direction:column;flex-grow:1}
.insight-card__meta{display:flex;align-items:center;gap:.6rem;font-size:.8rem;color:var(--muted);margin-bottom:.7rem}
.insight-card h3{font-size:1.12rem;line-height:1.28}.insight-card p{font-size:.92rem;margin-top:.55rem;flex-grow:1}
.insight-card .btn--text{margin-top:1rem;align-self:flex-start}

/* ---------- Locations ---------- */
.location-card{display:flex;gap:1.1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem;transition:transform .3s var(--ease-out),box-shadow .3s var(--ease)}
.location-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.location-card__flag{flex-shrink:0;width:48px;height:48px;border-radius:12px;display:grid;place-items:center;font-size:1.6rem;background:var(--surface-2);border:1px solid var(--line)}
.location-card__role{font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-700)}
[data-theme="dark"] .location-card__role{color:var(--blue-400)}
.location-card h3{font-size:1.2rem;margin:.2rem 0 .5rem}.location-card p{font-size:.94rem;margin:0}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;max-width:820px;margin-inline:auto}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq-item[open]{border-color:var(--blue-200);box-shadow:var(--shadow-sm)}
.faq-item summary{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.4rem;font-family:var(--font-display);font-weight:600;font-size:1.06rem;color:var(--text-strong);cursor:pointer;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .chev{flex-shrink:0;width:1.4rem;height:1.4rem;color:var(--blue-700);transition:transform .3s var(--ease)}
[data-theme="dark"] .faq-item summary .chev{color:var(--blue-400)}
.faq-item[open] summary .chev{transform:rotate(180deg)}
.faq-item__body{padding:0 1.4rem 1.3rem;color:var(--text-soft);font-size:.98rem}
.faq-item[open] .faq-item__body{animation:fadeIn .35s var(--ease-out)}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ---------- Forms ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(1.5rem,3vw,2.3rem);box-shadow:var(--shadow-md)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem}.field--full{grid-column:1/-1}
.field label{font-size:.86rem;font-weight:600;color:var(--text)}.field .req{color:var(--red-600)}
.field input,.field select,.field textarea{width:100%;padding:.8rem .95rem;border:1.5px solid var(--line-strong);border-radius:var(--r-md);background:var(--bg);color:var(--text);font-size:.98rem;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-600);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue-600) 16%,transparent)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235f6675' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;background-size:18px;padding-right:2.6rem}
.form-note{font-size:.84rem;color:var(--muted);margin-top:1rem}
.form-status{margin-top:1rem;padding:.85rem 1rem;border-radius:var(--r-md);font-size:.92rem;font-weight:500;display:none}
.form-status.is-visible{display:block}
.form-status--ok{background:var(--green-50);color:var(--green-800);border:1px solid #ceead6}
.form-status--err{background:var(--red-50);color:var(--red-700);border:1px solid #f6c9c4}
.recaptcha-wrap{margin-top:1.1rem;min-height:78px}
.contact-block{display:grid;gap:1.1rem}
.contact-line{display:flex;gap:.85rem;align-items:flex-start;font-size:.97rem;color:var(--text-soft)}
.contact-line svg{width:1.3rem;height:1.3rem;color:var(--blue-700);flex-shrink:0;margin-top:.15rem}
[data-theme="dark"] .contact-line svg{color:var(--blue-400)}
.contact-line strong{display:block;color:var(--text-strong)}.contact-line .placeholder{color:var(--muted);font-style:italic}
.office-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.5rem}

/* ---------- CTA band / mission ---------- */
.cta-band{position:relative;background:var(--grad-navy);color:#fff;border-radius:var(--r-xl);padding:clamp(2.3rem,5vw,3.6rem);overflow:hidden;isolation:isolate}
.cta-band::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(520px 320px at 88% -20%,rgba(66,133,244,.55),transparent 60%),radial-gradient(420px 280px at 0% 120%,rgba(52,168,83,.35),transparent 60%)}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.cta-band h2{color:#fff;max-width:24ch}.cta-band p{color:rgba(255,255,255,.82);margin-top:.75rem;max-width:52ch}
.cta-band .btn--primary{background:#fff;color:var(--blue-800);box-shadow:0 14px 30px rgba(0,0,0,.25)}
.cta-band .btn--primary:hover{background:var(--blue-50);color:var(--blue-900)}
.mission-block{position:relative;padding:clamp(1.8rem,4vw,3rem);background:var(--grad-navy);color:#fff;border-radius:var(--r-xl);overflow:hidden}
.mission-block::before{content:"\201C";position:absolute;top:-.3rem;left:1.5rem;font-family:Georgia,serif;font-size:8rem;color:rgba(255,255,255,.1);line-height:1}
.mission-block p{position:relative;font-family:var(--font-display);font-size:clamp(1.3rem,1.1rem + 1.1vw,1.8rem);line-height:1.4;color:#fff;font-weight:500;letter-spacing:-.01em}
.mission-block cite{display:block;margin-top:1.2rem;font-style:normal;font-size:.9rem;color:var(--blue-200)}

/* ---------- Page hero / breadcrumb (interior pages) ---------- */
.page-hero{position:relative;background:var(--hero-grad),var(--bg);padding-block:clamp(2.4rem,5vw,3.8rem) clamp(2.4rem,5vw,3.6rem);border-bottom:1px solid var(--line);overflow:hidden}
.page-hero__inner{max-width:780px;position:relative;z-index:1}
.page-hero--center .page-hero__inner{margin-inline:auto;text-align:center}
.page-hero h1{margin-block:1rem .9rem}.page-hero .lead{margin:0}
.breadcrumb{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.85rem;color:var(--muted);margin-bottom:1.1rem}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--blue-700)}
.breadcrumb li{display:flex;gap:.4rem;align-items:center}
.breadcrumb li:not(:last-child)::after{content:"/";color:var(--line-strong)}
.breadcrumb li[aria-current]{color:var(--text);font-weight:500}
.page-hero--center .breadcrumb{justify-content:center}

/* ---------- Service detail blocks ---------- */
.service-detail{scroll-margin-top:96px;display:grid;grid-template-columns:340px 1fr;gap:clamp(1.5rem,4vw,3.5rem);padding-block:clamp(2.5rem,5vw,4rem);align-items:start}
.service-detail+.service-detail{border-top:1px solid var(--line)}
.service-detail__aside{position:sticky;top:96px}
.service-detail__num{font-family:var(--font-display);font-weight:800;font-size:3rem;letter-spacing:-.04em;line-height:1;color:var(--blue-100)}
[data-theme="dark"] .service-detail__num{color:rgba(66,133,244,.3)}
.service-detail__icon{display:grid;place-items:center;width:60px;height:60px;border-radius:var(--r-md);background:var(--grad-brand);color:#fff;box-shadow:var(--shadow-blue);margin-block:1rem}
.service-detail__icon svg{width:30px;height:30px}
.service-detail h2{font-size:clamp(1.5rem,1.2rem + 1.2vw,1.9rem)}
.service-detail .lead{margin-block:1rem;font-size:1.08rem}
.service-detail__closing{margin-top:1.4rem;padding:1rem 1.2rem;border-left:3px solid var(--green);background:var(--green-50);border-radius:0 var(--r-md) var(--r-md) 0;font-style:italic;color:var(--green-800)}
[data-theme="dark"] .service-detail__closing{background:rgba(52,168,83,.12);color:#9fe0b3}
.included-title{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-block:1.6rem .9rem}
.audience-note{margin-top:1.4rem;font-size:.95rem;color:var(--muted)}.audience-note strong{color:var(--text)}

/* ---------- Careers roles ---------- */
.role-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.15rem 1.4rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .2s var(--ease-out)}
.role-row:hover{border-color:var(--blue-200);box-shadow:var(--shadow-sm);transform:translateX(4px)}
.role-row__main{display:flex;align-items:center;gap:1rem}
.role-row__icon{display:grid;place-items:center;width:42px;height:42px;border-radius:10px;background:var(--blue-50);color:var(--blue-700);flex-shrink:0}
[data-theme="dark"] .role-row__icon{background:rgba(66,133,244,.16);color:var(--blue-400)}
.role-row__icon svg{width:22px;height:22px}
.role-row h3{font-size:1.05rem;margin:0}.role-row p{font-size:.88rem;margin:0;color:var(--muted)}

/* ---------- Prose / articles ---------- */
.prose{max-width:740px}
.prose p{margin-bottom:1.15rem;font-size:1.075rem;line-height:1.78}
.prose h2{margin-top:2.6rem;margin-bottom:1rem;font-size:clamp(1.5rem,1.2rem + 1vw,1.9rem)}
.prose h3{margin-top:1.9rem;margin-bottom:.7rem;font-size:1.25rem}
.prose ul,.prose ol{display:grid;gap:.6rem;margin:1rem 0 1.5rem;padding-left:0}
.prose ul li{position:relative;padding-left:1.6rem;color:var(--text-soft)}
.prose ul li::before{content:"";position:absolute;left:.25rem;top:.72rem;width:6px;height:6px;border-radius:50%;background:var(--blue)}
.prose ol{counter-reset:li;padding-left:0}
.prose ol li{counter-increment:li;position:relative;padding-left:2.2rem;color:var(--text-soft)}
.prose ol li::before{content:counter(li);position:absolute;left:0;top:.1rem;width:1.5rem;height:1.5rem;display:grid;place-items:center;font-family:var(--font-display);font-size:.8rem;font-weight:700;color:#fff;background:var(--blue-700);border-radius:50%}
.prose a{text-decoration:underline;text-underline-offset:2px}
.prose blockquote{margin:1.6rem 0;padding:1rem 1.4rem;border-left:4px solid var(--blue);background:var(--surface-2);border-radius:0 var(--r-md) var(--r-md) 0;font-family:var(--font-display);font-size:1.2rem;line-height:1.5;color:var(--text)}
.prose strong{color:var(--text)}
.prose .pull{font-family:var(--font-display);font-size:1.3rem;line-height:1.45;color:var(--text-strong);font-weight:600;letter-spacing:-.01em;margin:1.8rem 0}

/* article layout */
.article-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;font-size:.85rem;color:var(--muted);margin-top:1rem}
.article-cover{aspect-ratio:21/8;border-radius:var(--r-xl);overflow:hidden;margin-bottom:clamp(1.5rem,4vw,2.5rem);box-shadow:var(--shadow-md)}
.article-cover svg{width:100%;height:100%}
.article-share{display:flex;gap:.5rem;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--line);font-size:.88rem;color:var(--muted)}
.article-share a{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--surface-2);border:1px solid var(--line);color:var(--text-soft)}
.article-share a:hover{background:var(--blue-50);color:var(--blue-700);border-color:var(--blue-200)}
.article-share svg{width:18px;height:18px}
.toc{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.3rem 1.5rem;margin-bottom:2rem}
.toc h4{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.7rem;font-family:var(--font-sans)}
.toc ul{display:grid;gap:.5rem}.toc a{font-size:.95rem;color:var(--text-soft)}.toc a:hover{color:var(--blue-700)}

/* ---------- Callout / dev note ---------- */
.callout{display:flex;gap:.9rem;padding:1.1rem 1.3rem;border-radius:var(--r-md);background:var(--blue-50);border:1px solid var(--blue-100);font-size:.95rem;color:var(--text-soft)}
[data-theme="dark"] .callout{background:rgba(66,133,244,.12);border-color:rgba(66,133,244,.3)}
.callout svg{width:1.4rem;height:1.4rem;color:var(--blue-700);flex-shrink:0}
.callout--green{background:var(--green-50);border-color:#ceead6}
[data-theme="dark"] .callout--green{background:rgba(52,168,83,.12);border-color:rgba(52,168,83,.3)}
.callout--green svg{color:var(--green-700)}
.dev-note{border:1px dashed var(--line-strong);border-radius:var(--r-md);background:color-mix(in srgb,var(--blue-50) 40%,var(--surface));padding:.9rem 1.1rem;font-size:.85rem;color:var(--muted);margin-top:1rem}
.dev-note b{color:var(--text-soft);letter-spacing:.04em;text-transform:uppercase;font-size:.74rem}
.dev-note code,.prose code,.dev-note code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:.92em;background:var(--surface-2);padding:.1rem .35rem;border-radius:5px;border:1px solid var(--line)}

/* ---------- Footer ---------- */
.site-footer{background:var(--grad-navy);color:rgba(255,255,255,.75);padding-top:clamp(3rem,6vw,4.5rem);position:relative}
.site-footer::before{content:none}
.footer-top{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:2rem;padding-bottom:2.5rem}
.footer-brand .brand__name{color:#fff}.footer-brand .brand__tag{color:var(--blue-200)}
.footer-about{margin-top:1.1rem;font-size:.92rem;max-width:34ch;color:rgba(255,255,255,.7)}
.footer-cta{margin-top:1.4rem}
.footer-col h4{color:#fff;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:1rem;font-family:var(--font-sans);font-weight:700}
.footer-col ul{display:grid;gap:.6rem}.footer-col a{color:rgba(255,255,255,.72);font-size:.92rem}.footer-col a:hover{color:#fff}
.footer-locations{display:grid;gap:.8rem}.footer-loc{display:flex;gap:.55rem;align-items:flex-start;font-size:.88rem}
.footer-loc svg{width:1.1rem;height:1.1rem;color:var(--blue-200);flex-shrink:0;margin-top:.15rem}.footer-loc strong{color:#fff;display:block;font-weight:600}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-block:1.5rem;border-top:1px solid rgba(255,255,255,.12);font-size:.85rem}
.footer-bottom a{color:rgba(255,255,255,.7)}.footer-bottom a:hover{color:#fff}
.footer-legal{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer-social{display:flex;gap:.6rem}
.footer-social a{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;transition:background-color .2s,transform .2s var(--ease-out)}
.footer-social a:hover{background:var(--blue-600);transform:translateY(-2px)}.footer-social svg{width:18px;height:18px}

/* ---------- Floating actions ---------- */
.fab{position:fixed;right:clamp(1rem,3vw,1.6rem);z-index:90;display:grid;place-items:center;border-radius:50%;box-shadow:var(--shadow-lg);transition:transform .25s var(--ease-out),opacity .25s var(--ease)}
.fab:hover{transform:translateY(-3px) scale(1.04)}
.fab-whatsapp{bottom:clamp(1rem,3vw,1.6rem);width:58px;height:58px;background:#25d366;color:#fff}
.fab-whatsapp svg{width:32px;height:32px}
.fab-whatsapp::after{content:"";position:absolute;inset:0;border-radius:50%;box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:waPulse 2.4s infinite}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.fab-top{bottom:calc(clamp(1rem,3vw,1.6rem) + 70px);width:46px;height:46px;background:var(--surface);color:var(--text);border:1px solid var(--line);opacity:0;visibility:hidden;pointer-events:none}
.fab-top svg{width:22px;height:22px}.fab-top.is-visible{opacity:1;visibility:visible;pointer-events:auto}

/* ---------- Cookie consent ---------- */
.cookie-banner{position:fixed;left:clamp(1rem,3vw,1.6rem);right:clamp(1rem,3vw,1.6rem);bottom:clamp(1rem,3vw,1.6rem);z-index:120;max-width:760px;margin-inline:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:1.2rem 1.4rem;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;transform:translateY(140%);transition:transform .45s var(--ease-out)}
.cookie-banner.is-in{transform:none}
.cookie-banner__icon{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--blue-50);color:var(--blue-700);flex-shrink:0}
[data-theme="dark"] .cookie-banner__icon{background:rgba(66,133,244,.16);color:var(--blue-400)}
.cookie-banner__icon svg{width:24px;height:24px}
.cookie-banner__text{flex:1 1 260px;font-size:.9rem;color:var(--text-soft)}
.cookie-banner__text a{text-decoration:underline}
.cookie-banner__actions{display:flex;gap:.6rem;flex-shrink:0}
@media (max-width:560px){.cookie-banner__actions{width:100%}.cookie-banner__actions .btn{flex:1}}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease-out),transform .7s var(--ease-out)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}.reveal[data-delay="4"]{transition-delay:.32s}

/* ---------- 404 ---------- */
.error-code{font-family:var(--font-display);font-weight:800;font-size:clamp(6rem,18vw,11rem);line-height:.9;letter-spacing:-.04em;background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Utilities ---------- */
.text-center{text-align:center}.mx-auto{margin-inline:auto}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.maxw-60{max-width:60ch}.full{grid-column:1/-1}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}
  .stats{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}
  .nav{gap:.8rem}.nav__links{gap:0}.nav__link{padding:.45rem .42rem;font-size:.85rem}.brand__tag{display:none}
}
@media (max-width:900px){
  .grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}
  .hero__inner{grid-template-columns:1fr}.hero__art{order:-1;max-width:480px}
  .split,.sustain__inner,.contact-grid{grid-template-columns:1fr}
  .sustain__badge{max-width:220px}
  .service-detail{grid-template-columns:1fr}.service-detail__aside{position:static;display:flex;align-items:center;gap:1rem}.service-detail__icon{margin:0}.service-detail__num{font-size:2.2rem}
}
@media (max-width:720px){
  .nav__toggle{display:grid}
  .nav__links{position:fixed;inset:72px 0 auto 0;flex-direction:column;align-items:stretch;gap:.25rem;margin:0;padding:1rem var(--gutter) 1.5rem;background:var(--bg);border-bottom:1px solid var(--line);box-shadow:var(--shadow-lg);transform:translateY(-12px);opacity:0;visibility:hidden;transition:opacity .25s var(--ease),transform .25s var(--ease-out),visibility .25s;max-height:calc(100vh - 72px);overflow-y:auto}
  .nav__links.is-open{opacity:1;visibility:visible;transform:none}
  .nav__link{padding:.85rem .8rem;font-size:1.02rem;border-radius:var(--r-md)}
  .nav__link.is-active{background:var(--blue-50)}[data-theme="dark"] .nav__link.is-active{background:rgba(66,133,244,.14)}
  .nav__link.is-active::after{content:none}
  .nav__tools{margin-left:auto}.nav__cta{margin-top:.6rem}.nav__cta .btn{width:100%}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.check-list--cols{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}
  .cta-band__inner{flex-direction:column;align-items:flex-start}
  .footer-top{grid-template-columns:1fr 1fr}.footer-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:480px){.footer-top{grid-template-columns:1fr}.stats{grid-template-columns:1fr}.float-badge{display:none}}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}}
@media print{.site-header,.site-footer,.fab,.cookie-banner,.cta-band{display:none}body{color:#000}}

/* ============================================================
   BALANCED COLOUR — brand colour highlights CTAs, icon tiles,
   section labels, pills, the green sustainability band, CTA
   glows & hero wash. Kept tasteful: no busy dividers (dash /
   footer bar / card top-bars stay off), and the loud bits are
   calmed — big numbers are solid blue (not rainbow) and large
   info boxes stay neutral with a coloured icon.
   ============================================================ */
/* big numbers -> solid brand blue (calmer than the gradient) */
.stat__num{background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:var(--blue-700);color:var(--blue-700)}
[data-theme="dark"] .stat__num{-webkit-text-fill-color:var(--blue-400);color:var(--blue-400)}
.error-code{background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:var(--blue-700);color:var(--blue-700)}
[data-theme="dark"] .error-code{-webkit-text-fill-color:var(--blue-400);color:var(--blue-400)}
/* large info boxes: neutral box, coloured icon */
.callout,[data-theme="dark"] .callout,.callout--green,[data-theme="dark"] .callout--green{background:var(--surface-2);border-color:var(--line);color:var(--text-soft)}
.callout svg{color:var(--blue-700)}[data-theme="dark"] .callout svg{color:var(--blue-400)}
.callout--green svg{color:var(--green-700)}
.service-detail__closing,[data-theme="dark"] .service-detail__closing{background:var(--surface-2);border-left-color:var(--green);color:var(--text-soft);font-style:italic}
/* language toggle button */
.lang-toggle{display:grid;place-items:center;min-width:42px;height:42px;padding:0 .55rem;border-radius:var(--r-pill);border:1.5px solid var(--line-strong);color:var(--text-soft);background:var(--surface);font-size:.82rem;font-weight:700;letter-spacing:.03em;transition:border-color .2s,color .2s,background-color .2s,transform .2s var(--ease-out)}
.lang-toggle:hover{color:var(--blue-700);border-color:var(--blue-200);transform:translateY(-1px)}
[data-theme="dark"] .lang-toggle:hover{color:var(--blue-400)}

/* ============================================================
   SUSTAINABILITY — faded green base so the lower text is legible
   ============================================================ */
.sustain{background:linear-gradient(160deg,#e9f6ee 0%,#f4faf6 65%,#ffffff 100%)}
.sustain::before{content:none}
.sustain .overline{color:var(--green-700)}
.sustain h2{color:var(--text-strong)}
.sustain p,.sustain .check-list li{color:var(--text-soft)}
.sustain__badge{background:radial-gradient(circle at 50% 40%,rgba(52,168,83,.16),rgba(52,168,83,.04));border:1px solid #c4e7cf}
.sustain__badge svg{color:var(--green-700)}
[data-theme="dark"] .sustain{background:linear-gradient(160deg,#12281d 0%,#0f1f19 100%)}
[data-theme="dark"] .sustain .overline{color:#8fe3a8}
[data-theme="dark"] .sustain h2{color:#fff}
[data-theme="dark"] .sustain p,[data-theme="dark"] .sustain .check-list li{color:rgba(255,255,255,.82)}
[data-theme="dark"] .sustain__badge{background:radial-gradient(circle at 50% 40%,rgba(52,168,83,.3),rgba(10,40,25,.15));border-color:rgba(168,230,184,.3)}
[data-theme="dark"] .sustain__badge svg{color:#a8e6b8}

/* ============================================================
   GLASSMORPHISM — frosted translucent surfaces over a faint
   ambient colour wash. Header is already glass.
   ============================================================ */
body{background:
  radial-gradient(900px 620px at 10% -8%, rgba(66,133,244,.12), transparent 60%),
  radial-gradient(820px 620px at 100% 6%, rgba(52,168,83,.09), transparent 55%),
  radial-gradient(760px 760px at 50% 112%, rgba(66,133,244,.08), transparent 60%),
  var(--bg);
  background-attachment:fixed}
[data-theme="dark"] body{background:
  radial-gradient(900px 620px at 10% -8%, rgba(66,133,244,.18), transparent 60%),
  radial-gradient(820px 620px at 100% 6%, rgba(52,168,83,.13), transparent 55%),
  radial-gradient(760px 760px at 50% 112%, rgba(66,133,244,.13), transparent 60%),
  var(--bg);
  background-attachment:fixed}
/* let the ambient wash show through the alternating sections */
.section--subtle{background-color:color-mix(in srgb, var(--bg-subtle) 55%, transparent)}
/* frosted glass cards */
.card-tile,.service-card:not(.service-card--feature),.spec-card,.usecase,.insight-card,.location-card,.testi-card,.form-card,.office-card,.faq-item,.role-row,.connect-card,.mini-stat,.cookie-banner{
  background:color-mix(in srgb, var(--surface) 72%, transparent);
  -webkit-backdrop-filter:blur(12px) saturate(150%);
  backdrop-filter:blur(12px) saturate(150%);
  border-color:color-mix(in srgb, var(--line-strong) 55%, transparent)}
[data-theme="dark"] .card-tile,[data-theme="dark"] .service-card:not(.service-card--feature),[data-theme="dark"] .spec-card,[data-theme="dark"] .usecase,[data-theme="dark"] .insight-card,[data-theme="dark"] .location-card,[data-theme="dark"] .testi-card,[data-theme="dark"] .form-card,[data-theme="dark"] .office-card,[data-theme="dark"] .faq-item,[data-theme="dark"] .role-row,[data-theme="dark"] .connect-card,[data-theme="dark"] .mini-stat,[data-theme="dark"] .cookie-banner{
  background:color-mix(in srgb, var(--surface) 58%, transparent);
  border-color:rgba(255,255,255,.10)}
@media (prefers-reduced-motion:no-preference){.card-tile,.service-card,.spec-card,.insight-card,.testi-card{will-change:auto}}
