/*
Theme Name: Impact Medical
Theme URI: https://impact-medical.ca
Author: Impact Medical
Author URI: https://impact-medical.ca
Description: Pine-teal + a single "vital signs" mint accent. Archivo (display) / IBM Plex Sans (body) / IBM Plex Mono (data).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: Proprietary
Text Domain: impact-medical
*/

/* =========================================================
   Impact Medical — WordPress Theme
   Pine-teal + a single "vital signs" mint accent
   Archivo (display) / IBM Plex Sans (body) / IBM Plex Mono (data)
   ========================================================= */

:root{
  --ink:#0C3B3F; --ink-700:#124A4F; --ink-600:#1A5B60;
  --mint:#12C9A0; --mint-600:#0FB48F; --mint-200:#BDEEE2;
  --paper:#F2F7F5; --paper-2:#E9F1EF; --card:#FFFFFF;
  --text:#15302F; --muted:#557572; --line:#D8E6E2;
  --shadow:0 18px 40px -22px rgba(12,59,63,.45);
  --shadow-sm:0 8px 22px -16px rgba(12,59,63,.5);
  --radius:16px; --radius-sm:11px; --wrap:1640px;
  --pad-sec:clamp(4rem,7vw,6.5rem);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{ margin:0; font-family:"IBM Plex Sans",system-ui,sans-serif; color:var(--text);
  background:var(--paper); line-height:1.65; font-size:1.0625rem; -webkit-font-smoothing:antialiased; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
.wrap{ width:min(var(--wrap),94%); margin-inline:auto; }

.eyebrow{ font-family:"IBM Plex Mono",monospace; text-transform:uppercase; letter-spacing:.2em;
  font-size:.72rem; color:var(--mint-600); margin:0 0 1rem; font-weight:500; }
.section{ padding-block:var(--pad-sec); }
.section__title{ font-family:"Archivo",sans-serif; font-weight:800; letter-spacing:-.02em;
  line-height:1.06; font-size:clamp(1.85rem,3.6vw,2.85rem); margin:0 0 1.1rem; color:var(--ink); }

.skip-link{ position:absolute; left:1rem; top:-3rem; background:var(--ink); color:#fff;
  padding:.6rem 1rem; border-radius:8px; z-index:200; transition:top .2s; }
.skip-link:focus{ top:1rem; }

/* ---------- Buttons ---------- */
.btn{ --bg:var(--ink); --fg:#fff; display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family:"Archivo",sans-serif; font-weight:700; font-size:.95rem; letter-spacing:.01em;
  padding:.85rem 1.4rem; border-radius:999px; border:1.5px solid transparent;
  background:var(--bg); color:var(--fg); cursor:pointer;
  transition:transform .18s ease, box-shadow .25s ease, background .2s ease, color .2s ease; }
.btn:hover{ transform:translateY(-2px); }
.btn:focus-visible{ outline:3px solid var(--mint); outline-offset:3px; }
.btn--accent{ --bg:var(--mint); --fg:#04332a; box-shadow:0 12px 26px -14px rgba(18,201,160,.9); }
.btn--accent:hover{ background:var(--mint-600); }
.btn--dark{ --bg:var(--ink); --fg:#fff; }
.btn--dark:hover{ background:var(--ink-700); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--ink); background:#fff; }
.btn--lg{ padding:1.05rem 2rem; font-size:1.05rem; }
.btn--block{ width:100%; }

/* ---------- Topbar ---------- */
.topbar{ background:var(--ink); color:#cfeae3; font-family:"IBM Plex Mono",monospace; font-size:.78rem; letter-spacing:.02em; }
.topbar__inner{ display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:.55rem 0; flex-wrap:wrap; }
.topbar__note{ display:inline-flex; align-items:center; gap:.55rem; }
.topbar .dot{ width:7px; height:7px; border-radius:50%; background:var(--mint); animation:pulse 2.4s infinite; }
.topbar__contacts{ display:flex; gap:1.4rem; }
.topbar__contacts a:hover{ color:#fff; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(18,201,160,.55); } 70%{ box-shadow:0 0 0 7px rgba(18,201,160,0); } 100%{ box-shadow:0 0 0 0 rgba(18,201,160,0); } }

/* ---------- Header ---------- */
.header{ position:sticky; top:0; z-index:100;
  background:linear-gradient(180deg,#0A3438 0%,var(--ink) 55%,var(--ink-700) 100%);
  border-bottom:1px solid rgba(18,201,160,.16);
  box-shadow:0 12px 34px -26px rgba(0,0,0,.9);
  transition:background .25s, box-shadow .25s, border-color .25s; }
.header.is-stuck{ background:linear-gradient(180deg,#06292c 0%,#0A3438 100%);
  border-bottom-color:rgba(18,201,160,.32); box-shadow:0 16px 40px -24px rgba(0,0,0,.95); }
.header__inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.65rem 0; }
.brand{ display:inline-flex; align-items:center; }
.brand__logo{ height:46px; width:auto; filter:drop-shadow(0 3px 10px rgba(18,201,160,.35)); transition:transform .25s; }
.brand:hover .brand__logo{ transform:translateY(-1px) scale(1.02); }
.brand__fallback{ font-family:"Archivo"; font-weight:900; font-size:1.35rem; color:#fff; align-items:center; gap:.35rem; letter-spacing:-.01em; }
.brand__plus{ color:var(--mint); }
.nav{ display:flex; align-items:center; gap:1.5rem; }
.nav > a{ font-family:"Archivo",sans-serif; font-weight:600; font-size:.93rem; color:#d7efe9; position:relative; padding:.25rem 0; transition:color .2s; }
.nav > a:not(.nav__cta):hover{ color:#fff; }
.nav > a:not(.nav__cta)::after{ content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--mint); transition:width .25s; }
.nav > a:not(.nav__cta):hover::after,
.nav > a.is-active:not(.nav__cta)::after{ width:100%; }
.nav > a.is-active:not(.nav__cta){ color:#fff; }
.nav__cta{ margin-left:.3rem; }

.menu-toggle{ display:none; flex-direction:column; gap:5px; width:44px; height:40px; background:none; border:0; cursor:pointer; padding:8px; }
.menu-toggle span{ height:2px; background:#eafff8; border-radius:2px; transition:transform .25s, opacity .2s; }
.menu-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero (home) ---------- */
.hero{ position:relative; overflow:hidden; isolation:isolate; color:#fff;
  min-height:clamp(560px,80vh,780px); display:flex; align-items:center;
  padding-block:clamp(3.5rem,6vw,5.5rem); }
.hero__bg{ position:absolute; inset:0; z-index:-2; transform:scale(1.08);
  background:url("images/stockroom.png") center/cover no-repeat;
  animation:kenburns 24s ease-in-out infinite alternate; }
.hero::after{ content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(95deg,rgba(4,33,36,.97) 0%,rgba(7,44,47,.92) 38%,rgba(7,44,47,.55) 72%,rgba(7,44,47,.22) 100%); }
.hero__ecg{ position:absolute; inset:auto 0 14% 0; width:100%; height:150px; opacity:.38; z-index:-1; pointer-events:none; }
.ecg-line{ fill:none; stroke:var(--mint); stroke-width:2.2; stroke-linejoin:round; stroke-linecap:round;
  stroke-dasharray:1; stroke-dashoffset:1; animation:draw 3.2s ease forwards .2s; }
@keyframes draw{ to{ stroke-dashoffset:0; } }
.hero__inner{ position:relative; max-width:780px; }
.hero .eyebrow{ color:var(--mint); }
.hero__title{ font-family:"Archivo"; font-weight:900; letter-spacing:-.035em; line-height:.98;
  font-size:clamp(2.6rem,6.6vw,5.6rem); margin:0 0 1.3rem; color:#fff; text-wrap:balance; }
.hero__title em{ font-style:normal; color:var(--mint); }
.hero__lead{ font-size:clamp(1.05rem,1.5vw,1.32rem); color:#d3e9e3; max-width:50ch; margin:0 0 2.2rem; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-bottom:2.4rem; }
.hero .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.45); background:rgba(255,255,255,.06); }
.hero .btn--ghost:hover{ color:#fff; border-color:#fff; background:rgba(255,255,255,.16); }
.hero__points{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:.7rem; }
.hero__points li{ display:inline-flex; align-items:center; gap:.55rem; font-size:.92rem; color:#eafff8;
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.18); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  padding:.55rem .95rem; border-radius:999px; }
.check{ flex:0 0 auto; width:20px; height:20px; border-radius:6px; background:var(--mint); color:#04332a;
  font-family:"Archivo"; font-weight:800; display:grid; place-items:center; font-size:.95rem; }
.hero__stat{ position:absolute; z-index:1; right:clamp(1rem,5vw,4.5rem); bottom:clamp(1.5rem,5vh,3.25rem);
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.22);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); border-radius:var(--radius);
  padding:1.2rem 1.5rem; display:flex; align-items:center; gap:.85rem; box-shadow:var(--shadow); }
.hero__stat-num{ font-family:"Archivo"; font-weight:900; font-size:3.1rem; color:var(--mint); line-height:1; }
.hero__stat-label{ font-family:"IBM Plex Mono",monospace; font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; color:#d3e9e3; }

/* ---------- Page hero (inner pages) ---------- */
.page-hero{ position:relative; overflow:hidden; background:radial-gradient(120% 120% at 90% -10%,var(--ink-600),var(--ink) 60%); color:#fff; }
.page-hero__ecg{ position:absolute; inset:auto 0 0 0; width:100%; height:120px; opacity:.28; pointer-events:none; }
.page-hero__ecg .ecg-line{ stroke:var(--mint); }
.page-hero__inner{ position:relative; padding-block:clamp(3.2rem,6vw,5rem); }
.page-hero .eyebrow{ color:var(--mint); }
.page-hero__title{ font-family:"Archivo"; font-weight:900; letter-spacing:-.025em; line-height:1.04;
  font-size:clamp(2rem,4.6vw,3.4rem); margin:0 0 .8rem; max-width:20ch; }
.page-hero__sub{ margin:0; color:#cfe7e1; font-size:1.12rem; max-width:54ch; }

/* ---------- Trust strip ---------- */
.trust{ background:var(--ink); color:#dff3ee; }
.trust__grid{ display:grid; grid-template-columns:repeat(3,1fr); }
.trust__item{ padding:2.3rem clamp(1rem,3vw,2.2rem); border-left:1px solid rgba(255,255,255,.1); }
.trust__item:first-child{ border-left:0; padding-left:0; }
.trust__key{ display:block; font-family:"IBM Plex Mono",monospace; font-size:.78rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--mint); margin-bottom:.5rem; }
.trust__item p{ margin:0; color:#cfe7e1; font-size:.98rem; }

/* ---------- About ---------- */
.about__inner{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.about__media{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); background:#fff; }
.about__media img{ width:100%; }
.about__copy p{ color:var(--muted); margin:0 0 1.3rem; max-width:54ch; }
.about__cards{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:1.6rem 0 1.8rem; }
.mini{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); padding:1.2rem; }
.mini h3{ font-family:"Archivo"; font-size:1.05rem; margin:0 0 .4rem; color:var(--ink); }
.mini p{ margin:0; font-size:.92rem; color:var(--muted); }

/* ---------- Features ---------- */
.section__head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; margin-bottom:2.6rem; flex-wrap:wrap; }
.section__head .section__title{ margin-bottom:0; max-width:18ch; }
.section__head-note{ color:var(--muted); max-width:34ch; margin:0; }
.feature-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.1rem; }
.feature{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.6rem; }
.feature__k{ font-family:"IBM Plex Mono",monospace; font-size:.8rem; color:var(--mint-600); letter-spacing:.1em; }
.feature h3{ font-family:"Archivo"; font-size:1.15rem; color:var(--ink); margin:.6rem 0 .5rem; }
.feature p{ margin:0; color:var(--muted); font-size:.95rem; }

/* ---------- Stats ---------- */
.stats{ background:var(--ink); color:#fff; }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; padding-block:clamp(2.6rem,5vw,3.6rem); }
.stat{ text-align:center; padding:1rem; border-left:1px solid rgba(255,255,255,.1); }
.stat:first-child{ border-left:0; }
.stat__num{ display:block; font-family:"Archivo"; font-weight:900; font-size:clamp(1.8rem,3.5vw,2.6rem); color:var(--mint); line-height:1; }
.stat__label{ display:block; margin-top:.5rem; font-family:"IBM Plex Mono",monospace; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:#bcd9d2; }

/* ---------- Products ---------- */
.products{ background:linear-gradient(180deg,var(--paper) 0%,#fff 100%); }
.cat-grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:1rem; }
.cat{ position:relative; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm);
  padding:1.1rem 1.1rem 1.2rem; display:flex; flex-direction:column; gap:.7rem;
  transition:transform .2s, box-shadow .25s, border-color .2s; }
.cat:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--mint-200); }
.cat:focus-visible{ outline:3px solid var(--mint); outline-offset:2px; }
.cat__img{ aspect-ratio:1/1; display:grid; place-items:center; background:var(--paper); border-radius:10px; overflow:hidden; }
.cat__img img{ width:82%; height:82%; object-fit:contain; transition:transform .3s; }
.cat:hover .cat__img img{ transform:scale(1.06); }
.cat__name{ font-family:"Archivo"; font-weight:700; font-size:.95rem; color:var(--ink); line-height:1.2; }
.cat__go{ font-family:"IBM Plex Mono",monospace; font-size:.7rem; letter-spacing:.08em; text-transform:uppercase; color:var(--mint-600); display:inline-flex; align-items:center; gap:.3rem; margin-top:auto; }
.cat__go::after{ content:"\2192"; transition:transform .2s; }
.cat:hover .cat__go::after{ transform:translateX(4px); }

/* ---------- Product category cards (products page) ---------- */
.pgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.pcard{ position:relative; display:flex; flex-direction:column; background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .3s ease, border-color .25s; }
.pcard:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--mint-200); }
.pcard:focus-visible{ outline:3px solid var(--mint); outline-offset:3px; }
.pcard__media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--paper-2); }
.pcard__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.pcard:hover .pcard__media img{ transform:scale(1.09); }
.pcard__media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(8,41,44,.45) 100%); opacity:.55; transition:opacity .35s; }
.pcard:hover .pcard__media::after{ opacity:.85; }
.pcard__media::before{ content:""; position:absolute; top:-60%; left:-120%; width:55%; height:220%; z-index:2;
  background:linear-gradient(115deg,transparent,rgba(255,255,255,.4),transparent); transform:rotate(8deg);
  transition:left .7s ease; pointer-events:none; }
.pcard:hover .pcard__media::before{ left:150%; }
.pcard__num{ position:absolute; top:.85rem; left:.85rem; z-index:3; font-family:"IBM Plex Mono",monospace;
  font-size:.72rem; letter-spacing:.05em; color:#eafff8; background:rgba(8,41,44,.7);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); padding:.28rem .55rem; border-radius:999px; }
.pcard__body{ display:flex; flex-direction:column; flex:1; padding:1.15rem 1.25rem 1.3rem; gap:.45rem; }
.pcard__name{ font-family:"Archivo"; font-weight:800; font-size:1.14rem; color:var(--ink); line-height:1.2; letter-spacing:-.01em; }
.pcard__desc{ margin:0; font-size:.9rem; color:var(--muted); line-height:1.5; }
.pcard__go{ margin-top:auto; padding-top:.8rem; font-family:"IBM Plex Mono",monospace; font-size:.73rem;
  letter-spacing:.08em; text-transform:uppercase; color:var(--mint-600); display:inline-flex; align-items:center; gap:.4rem; }
.pcard__go::after{ content:"\2192"; transition:transform .2s; }
.pcard:hover .pcard__go::after{ transform:translateX(4px); }

/* ---------- Page-hero extras ---------- */
.page-hero__actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-top:2rem; }
.page-hero .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.45); background:rgba(255,255,255,.06); }
.page-hero .btn--ghost:hover{ color:#fff; border-color:#fff; background:rgba(255,255,255,.16); }
.page-hero .hero__points{ margin-top:1.9rem; }

/* ---------- Steps ---------- */
.steps{ background:linear-gradient(180deg,#fff 0%,var(--paper) 100%); }
.steps__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; counter-reset:step; }
.step{ position:relative; overflow:hidden; background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius); padding:1.9rem 1.7rem; transition:transform .25s, box-shadow .3s, border-color .25s; }
.step:hover{ transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--mint-200); }
.step__num{ display:inline-grid; place-items:center; width:46px; height:46px; border-radius:12px;
  background:var(--mint-200); color:var(--ink); font-family:"Archivo"; font-weight:900; font-size:1.3rem; }
.step h3{ font-family:"Archivo"; font-size:1.18rem; color:var(--ink); margin:1rem 0 .45rem; letter-spacing:-.01em; }
.step p{ margin:0; color:var(--muted); font-size:.95rem; }
.step::after{ content:""; position:absolute; right:-30px; top:-30px; width:90px; height:90px; border-radius:50%;
  background:radial-gradient(circle,rgba(18,201,160,.16),transparent 70%); }

/* ---------- Showcase (home featured categories) ---------- */
.showcase{ background:linear-gradient(180deg,#fff 0%,var(--paper) 100%); }
.show-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.3rem; }
.show-card{ position:relative; display:block; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); background:#fff; box-shadow:var(--shadow-sm);
  transition:transform .25s ease, box-shadow .3s ease, border-color .25s; }
.show-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--mint-200); }
.show-card:focus-visible{ outline:3px solid var(--mint); outline-offset:3px; }
.show-card__media{ position:relative; aspect-ratio:5/4; overflow:hidden; background:var(--paper-2); }
.show-card__media img{ width:100%; height:100%; object-fit:cover;
  transition:transform .7s cubic-bezier(.2,.7,.2,1); transform-origin:center; }
.show-card:hover .show-card__media img{ transform:scale(1.12); }
.show-card__media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(8,41,44,.82) 100%); transition:opacity .4s; }
.show-card__media::before{ content:""; position:absolute; top:-60%; left:-120%; width:60%; height:220%; z-index:2;
  background:linear-gradient(115deg,transparent,rgba(255,255,255,.42),transparent); transform:rotate(8deg);
  transition:left .7s ease; pointer-events:none; }
.show-card:hover .show-card__media::before{ left:140%; }
.show-card__body{ position:absolute; left:0; right:0; bottom:0; padding:1.2rem 1.3rem; z-index:3;
  display:flex; align-items:flex-end; justify-content:space-between; gap:.6rem;
  transition:transform .35s ease; }
.show-card:hover .show-card__body{ transform:translateY(-3px); }
.show-card__name{ font-family:"Archivo"; font-weight:800; font-size:1.22rem; color:#fff; line-height:1.15; letter-spacing:-.01em;
  text-shadow:0 2px 12px rgba(0,0,0,.4); }
.show-card__go{ flex:0 0 auto; width:34px; height:34px; border-radius:50%; background:var(--mint); color:#04332a;
  display:grid; place-items:center; font-weight:800; transition:transform .25s, background .2s; }
.show-card:hover .show-card__go{ transform:translateX(2px) scale(1.08); }
.show-cta{ text-align:center; margin-top:2.4rem; }

/* ---------- CTA band ---------- */
.cta-band{ position:relative; overflow:hidden; color:#fff;
  background:
    radial-gradient(120% 140% at 0% 0%,rgba(18,74,79,.94),rgba(12,59,63,.97) 55%),
    url("images/stockroom.png") center/cover no-repeat;
  background-color:var(--ink); }
.cta-band__inner{ position:relative; display:flex; align-items:center; justify-content:space-between; gap:2rem; padding-block:clamp(3rem,6vw,4.5rem); flex-wrap:wrap; }
.cta-band__title{ font-family:"Archivo"; font-weight:800; font-size:clamp(1.7rem,3.4vw,2.6rem); letter-spacing:-.02em; margin:0 0 .5rem; }
.cta-band__inner p{ margin:0; color:#cfe7e1; max-width:46ch; }

/* ---------- Contact ---------- */
.contact__inner{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.contact__copy p{ color:var(--muted); max-width:42ch; }
.contact__details{ list-style:none; margin:2rem 0 0; padding:0; display:grid; gap:1.3rem; }
.contact__details li{ display:grid; gap:.2rem; }
.contact__label{ font-family:"IBM Plex Mono",monospace; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--mint-600); }
.contact__details a:hover{ color:var(--mint-600); }
.form{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,3vw,2.2rem); box-shadow:var(--shadow); }
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-weight:600; font-size:.9rem; margin-bottom:.4rem; color:var(--ink); }
.field input,.field textarea,.field select{ width:100%; font:inherit; color:var(--text); background:var(--paper);
  border:1.5px solid var(--line); border-radius:10px; padding:.75rem .85rem; transition:border-color .2s, background .2s; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--mint); background:#fff; }
.field textarea{ resize:vertical; }
.field select{ appearance:none; -webkit-appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23667' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right .9rem center; padding-right:2.4rem; }
.field.invalid input,.field.invalid textarea,.field.invalid select{ border-color:#d8584f; background-color:#fff6f5; }
.field__error{ display:block; color:#c14a42; font-size:.8rem; margin-top:.35rem; min-height:1em; }
.form__status{ margin:.9rem 0 0; font-size:.92rem; font-weight:600; min-height:1.2em; }
.form__status.ok{ color:var(--mint-600); }

/* ---------- Portfolio: breadcrumb ---------- */
.crumb{ display:flex; align-items:center; gap:.55rem; margin-bottom:1.1rem;
  font-family:"IBM Plex Mono",monospace; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; }
.crumb a{ color:#9fc4bc; }
.crumb a:hover{ color:var(--mint); }
.crumb__sep{ color:rgba(255,255,255,.3); }
.crumb__here{ color:var(--mint); }

/* ---------- Portfolio: filter bar ---------- */
.portfolio{ background:linear-gradient(180deg,var(--paper) 0%,#fff 100%); }
.filterbar{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1.2rem;
  padding-bottom:1.6rem; margin-bottom:2.2rem; border-bottom:1px solid var(--line); }
.filterbar__pills{ display:flex; flex-wrap:wrap; gap:.6rem; }
.pill{ font:inherit; cursor:pointer; border:1px solid var(--line); background:#fff; color:var(--muted);
  padding:.5rem 1.1rem; border-radius:999px; font-size:.78rem; font-weight:600; letter-spacing:.02em;
  text-transform:uppercase; transition:background .2s, color .2s, border-color .2s; }
.pill:hover{ border-color:var(--mint-200); color:var(--ink); }
.pill.is-active{ background:var(--ink); color:#fff; border-color:var(--ink); }
.pill:focus-visible{ outline:3px solid var(--mint); outline-offset:2px; }
.filterbar__count{ margin:0; font-family:"IBM Plex Mono",monospace; font-size:.74rem; letter-spacing:.06em;
  text-transform:uppercase; color:var(--muted); }
.filterbar__count span{ color:var(--mint-600); font-weight:500; }

/* ---------- Portfolio: bento grid ---------- */
.bento{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.bento__card{ position:relative; display:flex; flex-direction:column; background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  box-shadow:var(--shadow-sm); transition:transform .25s ease, box-shadow .3s ease, border-color .25s; }
.bento__card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--mint-200); }
.bento__card:focus-visible{ outline:3px solid var(--mint); outline-offset:3px; }
.bento__card--feature{ grid-column:span 2; grid-row:span 2; }
.bento__media{ position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--paper-2); flex:0 0 auto; }
.bento__card--feature .bento__media{ aspect-ratio:16/10; }
.bento__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.2,.7,.2,1); }
.bento__card:hover .bento__media img{ transform:scale(1.07); }
.bento__media::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(8,41,44,.4) 100%); opacity:.5; transition:opacity .35s; }
.bento__card:hover .bento__media::after{ opacity:.85; }
.bento__body{ display:flex; flex-direction:column; flex:1; padding:1.15rem 1.25rem 1.3rem; gap:.4rem; }
.bento__tag{ align-self:flex-start; font-family:"IBM Plex Mono",monospace; font-size:.64rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--mint-600); background:var(--mint-200); padding:.22rem .55rem; border-radius:999px; margin-bottom:.25rem; }
.bento__name{ font-family:"Archivo"; font-weight:800; color:var(--ink); line-height:1.18; letter-spacing:-.01em; font-size:1.14rem; }
.bento__card--feature .bento__name{ font-size:1.5rem; }
.bento__desc{ margin:0; font-size:.9rem; color:var(--muted); line-height:1.5; }
.bento__go{ margin-top:auto; padding-top:.8rem; font-family:"IBM Plex Mono",monospace; font-size:.73rem;
  letter-spacing:.08em; text-transform:uppercase; color:var(--mint-600); display:inline-flex; align-items:center; gap:.4rem; }
.bento__go::after{ content:"\2192"; transition:transform .2s; }
.bento__card:hover .bento__go::after{ transform:translateX(4px); }

/* ---------- Portfolio: procurement promo ---------- */
.promo{ position:relative; overflow:hidden; display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(1.5rem,4vw,3rem);
  align-items:center; margin-top:2.4rem; padding:clamp(1.8rem,4vw,3rem);
  border-radius:var(--radius); color:#fff;
  background:radial-gradient(120% 130% at 0% 0%,var(--ink-600),var(--ink) 60%); }
.promo__title{ font-family:"Archivo"; font-weight:800; letter-spacing:-.02em; line-height:1.1;
  font-size:clamp(1.5rem,3vw,2.1rem); margin:0 0 .8rem; }
.promo__copy p{ margin:0 0 1.6rem; color:#cfe7e1; max-width:48ch; }
.promo__actions{ display:flex; flex-wrap:wrap; gap:.9rem; }
.promo__ghost{ color:#fff; border-color:rgba(255,255,255,.45); background:rgba(255,255,255,.06); }
.promo__ghost:hover{ color:#fff; border-color:#fff; background:rgba(255,255,255,.16); }
.promo__media{ position:relative; }
.promo__media img{ width:100%; height:100%; object-fit:cover; border-radius:var(--radius-sm);
  box-shadow:var(--shadow); border:1px solid rgba(255,255,255,.18); }

/* ---------- Portfolio: assurance banner ---------- */
.assure{ background:var(--paper-2); border-block:1px solid var(--line); padding-block:clamp(2rem,4vw,3rem); }
.assure__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; }
.assure__item{ display:flex; align-items:flex-start; gap:1rem; }
.assure__icon{ flex:0 0 auto; width:38px; height:38px; border-radius:11px; display:grid; place-items:center;
  background:var(--mint-200); color:var(--ink); font-size:.85rem; }
.assure__item h4{ font-family:"IBM Plex Mono",monospace; font-size:.74rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink); margin:.15rem 0 .35rem; }
.assure__item p{ margin:0; font-size:.92rem; color:var(--muted); line-height:1.5; }

/* ---------- Prose (privacy) ---------- */
.prose{ max-width:760px; }
.prose__updated{ font-family:"IBM Plex Mono",monospace; font-size:.8rem; color:var(--muted); margin:0 0 2rem; }
.prose h2{ font-family:"Archivo"; font-weight:800; color:var(--ink); font-size:1.4rem; margin:2rem 0 .6rem; letter-spacing:-.01em; }
.prose p{ color:var(--muted); margin:0 0 1rem; }
.prose a{ color:var(--mint-600); text-decoration:underline; }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:#bcd9d2; }
.footer__inner{ display:grid; grid-template-columns:1.6fr 1fr 1.2fr; gap:2.5rem; padding-block:clamp(3rem,5vw,4rem) 2rem; }
.wordmark{ font-family:"Archivo"; font-weight:900; font-size:1.5rem; color:#fff; letter-spacing:-.01em; display:inline-flex; align-items:center; gap:.4rem; }
.wordmark__plus{ color:var(--mint); }
.footer__brand p{ margin:.9rem 0 0; max-width:38ch; color:#9fc4bc; font-size:.95rem; }
.footer__heading{ display:block; font-family:"IBM Plex Mono",monospace; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--mint); margin-bottom:1rem; }
.footer__nav,.footer__contact{ display:grid; gap:.55rem; align-content:start; }
.footer__nav a:hover,.footer__contact a:hover{ color:#fff; }
.footer__bottom{ display:flex; justify-content:space-between; gap:1rem; padding-block:1.4rem; border-top:1px solid rgba(255,255,255,.1); font-family:"IBM Plex Mono",monospace; font-size:.74rem; color:#84aaa2; flex-wrap:wrap; }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }
.show-grid .show-card:nth-child(1){ transition-delay:.00s; }
.show-grid .show-card:nth-child(2){ transition-delay:.08s; }
.show-grid .show-card:nth-child(3){ transition-delay:.16s; }
.show-grid .show-card:nth-child(4){ transition-delay:.24s; }
.show-grid .show-card:nth-child(5){ transition-delay:.32s; }
.show-grid .show-card:nth-child(6){ transition-delay:.40s; }

/* ---------- Ken Burns ---------- */
@keyframes kenburns{ 0%{ transform:scale(1) translate3d(0,0,0); } 100%{ transform:scale(1.09) translate3d(-1.5%,-1.5%,0); } }
.hero__figure img{ animation:kenburns 16s ease-in-out infinite alternate; }
.about__media{ overflow:hidden; }
.about__media img{ animation:kenburns 20s ease-in-out infinite alternate; transition:transform .6s ease; }

/* ---------- Responsive ---------- */
@media (max-width:1280px){ .pgrid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:1000px){ .cat-grid{ grid-template-columns:repeat(4,1fr); } .show-grid{ grid-template-columns:repeat(2,1fr); } .pgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:860px){
  .menu-toggle{ display:flex; }
  .nav{ position:fixed; inset:0 0 0 auto; width:min(320px,82%); background:#fff; flex-direction:column;
    align-items:stretch; gap:.4rem; padding:6.75rem 1.4rem 2rem; transform:translateX(100%);
    transition:transform .3s ease; box-shadow:-20px 0 50px -30px rgba(0,0,0,.5); overflow-y:auto; }
  .nav.open{ transform:none; }
  .nav > a{ padding:.7rem .2rem; border-bottom:1px solid var(--line); color:var(--ink); }
  .nav > a:not(.nav__cta):hover{ color:var(--ink-600); }
  .nav > a.is-active:not(.nav__cta){ color:var(--mint-600); }
  .nav > a:not(.nav__cta)::after{ display:none; }
  .nav__cta{ margin-top:.6rem; }
  .hero{ min-height:auto; }
  .hero__lead{ max-width:none; }
  .about__inner,.contact__inner{ grid-template-columns:1fr; }
  .feature-grid{ grid-template-columns:1fr; }
  .trust__grid{ grid-template-columns:1fr; }
  .trust__item{ border-left:0; border-top:1px solid rgba(255,255,255,.1); padding:1.6rem 0; }
  .trust__item:first-child{ border-top:0; }
  .stats__grid{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(3){ border-left:0; }
  .steps__grid{ grid-template-columns:1fr; }
  .footer__inner{ grid-template-columns:1fr; gap:2rem; }
  .bento{ grid-template-columns:repeat(2,1fr); }
  .bento__card--feature{ grid-column:span 2; grid-row:auto; }
  .promo{ grid-template-columns:1fr; }
  .promo__media{ order:-1; }
  .assure__grid{ grid-template-columns:1fr; gap:1.4rem; }
}
@media (max-width:620px){
  .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .show-grid{ grid-template-columns:1fr; }
  .pgrid{ grid-template-columns:1fr; }
  .bento{ grid-template-columns:1fr; }
  .bento__card--feature{ grid-column:auto; }
  .filterbar{ flex-direction:column; align-items:flex-start; }
  .topbar__contacts{ display:none; }
  .hero__stat{ display:none; }
  .about__cards{ grid-template-columns:1fr; }
  .stats__grid{ grid-template-columns:1fr; }
  .stat{ border-left:0; }
}
@media (prefers-reduced-motion:reduce){
  .ecg-line{ animation:none; stroke-dashoffset:0; }
  .topbar .dot{ animation:none; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .btn:hover,.cat:hover,.show-card:hover,.pcard:hover,.step:hover,.bento__card:hover{ transform:none; }
  .hero__bg,.about__media img{ animation:none; transform:none; }
  .show-card:hover .show-card__media img,.pcard:hover .pcard__media img,.bento__card:hover .bento__media img{ transform:none; }
}
