/* ============================================================
   SANWIZ LAB — Design System v4 (Green on White)
   White backgrounds + subtle green gradients.
   Green-teal palette inspired by the Sanwiz logo.
   Font: Montserrat (Google Fonts, free)
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  /* Sanwiz LEAF green scale — matches the actual logo gradient */
  --sw-50:  #F4FAEC;
  --sw-100: #E7F3D5;
  --sw-150: #D5E9AC;
  --sw-200: #BCDB7E;
  --sw-300: #A1CC52;
  --sw-400: #8BBE3A;
  --sw-500: #7AB73E;   /* secondary leaf */
  --sw-600: #689F2D;   /* PRIMARY brand leaf green */
  --sw-700: #527E22;   /* deep leaf */
  --sw-800: #3F6118;   /* darkest */

  /* Neutrals — charcoal gray (matches sanwiz wordmark) */
  --ink-900:#2A2A2A;   /* display / strong headings */
  --ink-800:#3A3A3A;   /* primary text (was 4A) — darkened for AA contrast */
  --ink-700:#4F4F4F;   /* secondary text */
  --ink-500:#6B6B6B;   /* body muted (WCAG AA 6.05:1 on white) */
  --ink-400:#6B6B6B;   /* muted — collapsed to ink-500 for contrast compliance */
  --ink-300:#9A9A9A;   /* very low-contrast — large text or hairlines only */
  --ink-200:#D5D5D5;

  /* Subtle surface tints (leaf-tinted) */
  --tint-50: #FBFCF5;
  --tint-100:#F6F9E8;
  --tint-200:#EEF3D8;

  /* Neutral lines / borders */
  --line-100:#EFEFEF;
  --line-200:#E3E3E3;
  --line-300:#CFCFCF;

  /* Subtle accents (leaf shades) */
  --accent-deep:#3F6118;
  --accent-fresh:#7AB73E;

  /* Semantic */
  --ok:#1F9168;
  --warn:#B07A2D;
  --danger:#D9534F;
  --rose-soft:#FBE5E2;

  --bg:#FFFFFF;

  /* ★ Sanwiz BRAND GRADIENT — matches the actual leaf logo */
  --grad-start:#B5D14F;   /* top of leaf — bright lime */
  --grad-mid:  #8BBE3A;   /* mid leaf */
  --grad-end:  #689F2D;   /* deep leaf green */
  --brand-grad:        linear-gradient(135deg, var(--grad-start) 0%, var(--grad-mid) 55%, var(--grad-end) 100%);
  --brand-grad-soft:   linear-gradient(135deg, color-mix(in srgb, var(--grad-start) 22%, white), color-mix(in srgb, var(--grad-end) 22%, white));
  --brand-grad-radial: radial-gradient(circle at 30% 30%, var(--grad-start), var(--grad-mid) 50%, var(--grad-end) 100%);

  /* Aliases for back-compat */
  --teal:var(--sw-600);
  --teal-dark:var(--sw-800);
  --teal-soft:var(--sw-100);
  --teal-100:var(--sw-300);
  --ink:var(--ink-800);
  --muted:var(--ink-400);
  --line:var(--line-200);
  --line-2:var(--line-300);

  /* Radii */
  --r-xs:8px;
  --r-sm:12px;
  --r:18px;
  --r-md:22px;
  --r-lg:28px;
  --r-pill:999px;

  /* Shadows — calibrated for white surface */
  --shadow-xs:0 1px 2px rgba(12,42,34,.05);
  --shadow-sm:0 2px 6px rgba(12,42,34,.04), 0 10px 28px rgba(12,42,34,.06);
  --shadow:0 6px 18px rgba(12,42,34,.06), 0 24px 60px rgba(12,42,34,.08);
  --shadow-lg:0 14px 40px rgba(12,42,34,.10), 0 50px 110px rgba(12,42,34,.12);
  --shadow-ring:0 0 0 4px var(--sw-150);
  --shadow-green:0 8px 24px rgba(104,159,45,.22);

  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);

  /* Fluid container — scales smoothly from 1200px to 1440px as viewport
     grows past 1400px (common when browser zoom < 100% on big monitors).
     No step jumps → pages look identical across all zoom levels. */
  --maxw:min(1440px, max(1200px, 82vw));
  --ff:'Montserrat',system-ui,-apple-system,sans-serif;

  /* Sticky / scroll offsets — single source of truth so all pages use the same value */
  --header-h:78px;
  --sticky-offset:96px;   /* header-h + 18px breathing room */

  /* Semantic colors for callout panels */
  --amber-soft:#FFF7E8;
  --amber-border:#F5D58A;
  --amber-text:#8A5A12;
  --danger:#D14343;
  --danger-soft:#FDECEC;
  --success:#2F7D32;
  --success-soft:#E7F5E8;

  /* Spacing scale (8px-based, with 4px sub-steps) */
  --sp-1:4px;
  --sp-2:8px;
  --sp-3:12px;
  --sp-4:16px;
  --sp-5:20px;
  --sp-6:24px;
  --sp-7:32px;
  --sp-8:40px;
  --sp-9:48px;
  --sp-10:56px;
  --sp-11:64px;
  --sp-12:80px;
  --sp-13:96px;

  /* Type scale — Major Third (1.25 ratio), 16px base */
  --fs-xs:.75rem;    /* 12px — micro labels, captions */
  --fs-sm:.8125rem;  /* 13px — small UI, footnotes */
  --fs-base:.875rem; /* 14px — secondary body, helper text */
  --fs-md:.9375rem;  /* 15px — chip/badge labels */
  --fs-body:1rem;    /* 16px — body text */
  --fs-lg:1.0625rem; /* 17px — lead paragraphs */
  --fs-xl:1.1875rem; /* 19px — large body */
  --fs-2xl:1.4375rem;/* 23px — sub-titles */
  --fs-3xl:1.75rem;  /* 28px — section titles */
  --fs-4xl:2.25rem;  /* 36px — page title */
  --fs-5xl:3.4rem;   /* 54px — hero h1 max */

  /* Line-heights paired with type sizes */
  --lh-tight:1.15;
  --lh-snug:1.35;
  --lh-normal:1.55;
  --lh-relaxed:1.7;

  /* Reading column max-width for long-form content */
  --prose-max:68ch;
}

/* ---------- RESET ---------- */
*{box-sizing:border-box;margin:0;padding:0}
*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scrollbar-gutter:stable}
body{
  font-family:var(--ff);color:var(--ink-800);background:#fff;
  font-size:16px;line-height:1.7;font-weight:400;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  letter-spacing:-0.005em;
  /* Subtle page-wide gradient — white with faint lime hint */
  background:radial-gradient(ellipse 100% 60% at 50% 0%, #FBFCF5, #FFFFFF 70%);
  background-attachment:fixed;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul,ol{list-style:none}
h1,h2,h3,h4,h5{
  font-family:var(--ff);font-weight:700;line-height:1.15;color:var(--ink-900);
  letter-spacing:-0.022em;
}
:focus-visible{outline:3px solid var(--sw-400);outline-offset:3px;border-radius:6px}

/* Skip link — hidden until focused */
.skip-link{
  position:absolute;left:-9999px;top:8px;padding:10px 18px;
  background:var(--sw-700);color:#fff;border-radius:8px;font-weight:600;
  font-size:.9rem;text-decoration:none;z-index:9999;transition:left .15s ease;
}
.skip-link:focus{left:12px;outline:3px solid var(--sw-300);outline-offset:2px}

/* Loading placeholder — shown while JS is rendering content. */
.ph-loading:empty{
  min-height:18rem;
  background:linear-gradient(90deg,var(--sw-50) 0%,#fff 50%,var(--sw-50) 100%);
  background-size:200% 100%;
  border-radius:var(--r);
  animation:ph-shimmer 1.6s linear infinite;
}
@keyframes ph-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
@media(prefers-reduced-motion:reduce){
  .ph-loading:empty{animation:none}
}

/* ---------- Inline button spinner ---------- */
.spinner{
  display:inline-block;width:.95em;height:.95em;
  border:2px solid currentColor;border-right-color:transparent;
  border-radius:50%;animation:spin .7s linear infinite;
  vertical-align:-2px;margin-right:.4em;
}
@keyframes spin{to{transform:rotate(360deg)}}
.btn[aria-busy="true"]{pointer-events:none;opacity:.85}
@media(prefers-reduced-motion:reduce){
  .spinner{animation-duration:1.4s}
}

/* ---------- Field help text ---------- */
.field-help{
  color:var(--ink-400);font-size:.78rem;line-height:1.4;
  margin-top:6px;font-weight:400;
}

/* ---------- Form success state ----------
   When .form-card has .is-success, hide title/sub/form entirely so the
   success panel sits as the only content in the card. */
.form-card.is-success > .form-title,
.form-card.is-success > .form-sub,
.form-card.is-success > #contact-form{display:none!important}

.form-success{
  background:var(--success-soft);border:1px solid #B7DDB8;
  border-radius:var(--r);padding:32px 30px;
  display:flex;gap:20px;align-items:flex-start;
  /* Even though the card already has padding, give the panel a little extra
     breathing room so it doesn't sit flush with the card's inner edge. */
  margin:8px 0;
  animation:fadeUp .35s var(--ease);
}
/* HTML 'hidden' attribute must beat the display:flex above — otherwise the
   success panel shows before the user submits the form. */
.form-success[hidden]{display:none!important}
.form-success .fs-ic{
  flex:none;width:48px;height:48px;border-radius:50%;
  background:var(--success);color:#fff;display:grid;place-items:center;
  box-shadow:0 4px 14px -4px rgba(31,128,55,.45);
}
.form-success .fs-ic svg{width:24px;height:24px}
.form-success h3{font-size:1.15rem;margin-bottom:8px;color:var(--ink-900);letter-spacing:-.018em}
.form-success p{color:var(--ink-700);font-size:.96rem;line-height:1.6;margin-bottom:18px}
.form-success .fs-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
@media(max-width:680px){
  .form-success{padding:24px 20px;gap:14px;flex-direction:column}
  .form-success .fs-ic{width:44px;height:44px}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Anchored sections — offset for sticky header (78px) */
.lab-cat-block, [id^="cat-"]{scroll-margin-top:var(--sticky-offset)}

/* Form validation states */
.field input.invalid,.field textarea.invalid{border-color:var(--danger);background:var(--danger-soft)}
.field input.invalid:focus,.field textarea.invalid:focus{outline-color:var(--danger);box-shadow:0 0 0 3px rgba(209,67,67,.18)}
.field-error{
  color:var(--danger);font-size:.82rem;line-height:1.4;margin-top:6px;
  min-height:1.1em;font-weight:500;
}
.form-msg.err{color:var(--danger)}
.form-msg.ok{color:var(--success)}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:80px 0}
.section-tight{padding:56px 0}
.section-tint{background:var(--tint-100)}
.section-white{background:#fff}
.section-grad{background:linear-gradient(180deg,#fff 0%,var(--tint-100) 100%)}
.section-grad-reverse{background:linear-gradient(180deg,var(--tint-100) 0%,#fff 100%)}
/* back-compat aliases */
.section-cream-2{background:var(--tint-100)}
.center{text-align:center}
.eyebrow{
  display:inline-block;font-family:var(--ff);font-weight:700;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sw-700);background:var(--sw-100);
  padding:7px 16px;border-radius:var(--r-pill);margin-bottom:18px;
  border:1px solid var(--sw-200);
}
.section-title{font-size:clamp(1.95rem,3.8vw,3rem);letter-spacing:-0.03em;line-height:1.08;font-weight:700;color:var(--ink-900)}
.section-title em{font-style:normal;color:var(--sw-600)}
.section-lead{color:var(--ink-400);max-width:640px;margin:20px auto 0;font-size:1.06rem;line-height:1.65}
.head-block{margin-bottom:48px}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--ff);font-weight:600;font-size:.94rem;
  padding:13px 26px;border-radius:var(--r-pill);
  transition:transform .22s var(--ease), background .2s var(--ease), color .2s var(--ease), box-shadow .25s var(--ease), border-color .2s var(--ease);
  white-space:nowrap;letter-spacing:.002em;line-height:1;
}
.btn svg{width:17px;height:17px;flex:none}
.btn:active{transform:translateY(1px)}
/* Primary (gradient) — .btn-primary and .btn-teal are aliases */
.btn-primary,.btn-teal{background:var(--brand-grad);background-size:140% 140%;background-position:0% 50%;color:#fff;box-shadow:var(--shadow-green)}
.btn-primary:hover,.btn-teal:hover{background-position:100% 50%;transform:translateY(-2px);box-shadow:0 12px 30px rgba(104,159,45,.32)}
.btn-ghost{background:#fff;color:var(--ink-900);border:1.5px solid var(--line-300)}
.btn-ghost:hover{border-color:var(--sw-600);color:var(--sw-700);transform:translateY(-1px);box-shadow:var(--shadow-xs)}
.btn-outline-teal{background:transparent;color:var(--sw-700);border:1.5px solid var(--sw-400)}
.btn-outline-teal:hover{background:var(--sw-600);color:#fff;border-color:var(--sw-600);transform:translateY(-1px)}
.btn-light{background:#fff;color:var(--sw-700);border:1.5px solid var(--sw-200)}
.btn-light:hover{background:var(--sw-50);transform:translateY(-1px)}
.btn-link{display:inline-flex;align-items:center;gap:7px;color:var(--sw-700);font-weight:600;font-size:.93rem}
.btn-link svg{transition:transform .25s var(--ease)}
.btn-link:hover svg{transform:translateX(4px)}
.btn-sm{padding:9px 18px;font-size:.85rem}
.btn-lg{padding:16px 32px;font-size:1rem}
.btn-block{width:100%}

/* ---------- HEADER ---------- */
.site-header{
  position:sticky;top:0;z-index:200;background:rgba(255,255,255,.85);
  backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid rgba(220,232,226,.6);
  transition:box-shadow .3s var(--ease), background .3s var(--ease);
}
.site-header.scrolled{box-shadow:var(--shadow-sm);background:rgba(255,255,255,.96)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--ff);font-weight:700;font-size:1.15rem;color:var(--ink-900);letter-spacing:-0.022em;transition:opacity .2s}
.brand:hover{opacity:.85}
.brand .logo-mark{width:38px;height:38px;flex:none}
.brand .sw-logo{height:36px;width:auto;flex:none;display:block}
.brand .b-text{display:flex;flex-direction:column;line-height:1.05}
.brand small{font-size:.6rem;font-weight:600;letter-spacing:.18em;color:var(--sw-700);text-transform:uppercase;margin-top:2px}

.nav-links{display:flex;align-items:center;gap:2px}
.nav-links>li>a,.nav-links>li>.nav-trigger{
  display:flex;align-items:center;gap:5px;padding:10px 14px;border-radius:var(--r-pill);
  font-weight:500;font-size:.92rem;color:var(--ink-800);
  transition:background .18s var(--ease), color .18s var(--ease);
}
.nav-links>li>a:hover,.nav-links>li>.nav-trigger:hover{background:var(--sw-50);color:var(--sw-700)}
.nav-links a.active{color:var(--sw-700);font-weight:600;position:relative}
.nav-links a.active::after{content:"";position:absolute;left:14px;right:14px;bottom:6px;height:2px;background:var(--sw-600);border-radius:1px}
.nav-cta{display:flex;align-items:center;gap:10px}

/* dropdown */
.has-dropdown{position:relative}
.nav-trigger svg{width:13px;height:13px;transition:transform .25s var(--ease)}
.has-dropdown:hover .nav-trigger svg{transform:rotate(180deg)}
.dropdown{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(10px);
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r);
  box-shadow:var(--shadow-lg);padding:18px;width:640px;
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
  opacity:0;visibility:hidden;transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s;
}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{display:flex;gap:14px;padding:13px;border-radius:13px;transition:background .15s}
.dropdown a:hover{background:var(--sw-50)}
.dropdown .di{width:42px;height:42px;flex:none;border-radius:12px;background:var(--sw-100);display:grid;place-items:center;transition:background .2s}
.dropdown a:hover .di{background:var(--sw-150)}
.dropdown .di svg{width:22px;height:22px;color:var(--sw-700)}
.dropdown .dt strong{display:block;font-family:var(--ff);font-weight:600;font-size:.94rem;color:var(--ink-900)}
.dropdown .dt span{font-size:.78rem;color:var(--ink-400);line-height:1.5;display:block;margin-top:3px}
.dropdown-foot{grid-column:1/-1;border-top:1px solid var(--line-200);margin-top:8px;padding-top:12px}
.dropdown-foot a{justify-content:center;gap:7px;color:var(--sw-700);font-weight:600;font-size:.88rem;white-space:nowrap}
.dropdown-foot a svg{width:14px;height:14px;flex:none;transition:transform .25s var(--ease)}
.dropdown-foot a:hover svg{transform:translateX(4px)}

/* hamburger */
.burger{display:none;flex-direction:column;gap:5px;padding:8px;border-radius:8px}
.burger span{width:22px;height:2px;background:var(--ink-900);border-radius:2px;transition:transform .3s var(--ease), opacity .2s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- HERO BASE — shared by .hero, .page-hero, .guide-hero, .detail-hero -----
   UX-tuned: tighter vertical rhythm, smaller display type, content-driven height.
   Home (.hero) gets a separate min-height override below since stats grid needs space. */
.hero,.page-hero,.guide-hero,.detail-hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(circle at 85% -10%, var(--sw-100), transparent 55%),
    radial-gradient(circle at 10% 110%, var(--sw-50), transparent 60%),
    #fff;
  padding:64px 0 72px;
  min-height:40vh;
  min-height:40dvh;
  display:flex;
  align-items:center;
}
.hero>.container,.page-hero>.container,.guide-hero>.container,.detail-hero>.container{
  width:100%;
}
/* Home hero still needs more vertical room for the 2-col stats grid */
.hero{padding:72px 0 80px;min-height:54vh;min-height:54dvh}
.hero::before,.page-hero::before,.guide-hero::before,.detail-hero::before{
  content:"";position:absolute;top:-25%;right:-15%;width:680px;height:680px;
  background:radial-gradient(circle at center,rgba(181,209,79,.14),transparent 65%);
  border-radius:50%;pointer-events:none;
}
.hero::after,.page-hero::after,.guide-hero::after,.detail-hero::after{
  content:"";position:absolute;bottom:-30%;left:-18%;width:560px;height:560px;
  background:radial-gradient(circle at center,rgba(139,190,58,.10),transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero-grid{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.hero-tag{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--ff);
  font-weight:600;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--sw-800);background:#fff;border:1px solid var(--line-200);
  padding:9px 18px;border-radius:var(--r-pill);margin-bottom:24px;box-shadow:var(--shadow-xs);
}
.hero-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--sw-500);box-shadow:0 0 0 4px var(--sw-150);animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px var(--sw-150)}50%{box-shadow:0 0 0 8px rgba(181,209,79,.22)}}
.hero h1{font-size:clamp(2.5rem,5.6vw,4.3rem);letter-spacing:-0.04em;line-height:1.03;color:var(--ink-900);font-weight:700}
.hero h1 em{font-style:normal;color:var(--sw-600);position:relative;display:inline-block}
.hero h1 em::after{
  content:"";position:absolute;left:-2px;right:-2px;bottom:.08em;height:.22em;
  background:linear-gradient(120deg,var(--sw-100) 30%,var(--sw-200));z-index:-1;border-radius:6px;
}
.hero p.lead{color:var(--ink-500);font-size:1.16rem;margin:28px 0 32px;max-width:540px;line-height:1.65}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:18px;margin-top:38px;flex-wrap:wrap}
.hero-trust .ht-stars{display:flex;gap:2px}
.hero-trust .ht-stars svg{width:18px;height:18px;color:var(--sw-500)}
.hero-avatars{display:flex;align-items:center}
.hero-avatars .av{
  width:38px;height:38px;border-radius:50%;
  background:var(--brand-grad);
  border:2.5px solid #fff;margin-left:-10px;
  font-weight:700;color:#fff;font-size:.74rem;display:grid;place-items:center;
  box-shadow:0 2px 6px rgba(104,159,45,.15);
}
.hero-avatars .av:first-child{margin-left:0}
.hero-trust .ht-text{font-size:.9rem;color:var(--ink-500);line-height:1.45}
.hero-trust .ht-text b{color:var(--ink-900)}

/* hero visual cards */
.hero-visual{position:relative;display:flex;flex-direction:column;gap:16px}
.hv-card{
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r-md);
  padding:24px 26px;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.hv-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.hv-card .hvc-top{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.hv-card .hvc-ic{width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,var(--sw-200),var(--sw-100));display:grid;place-items:center;flex:none}
.hv-card .hvc-ic svg{width:25px;height:25px;color:var(--sw-700)}
.hv-card h4{font-size:1.04rem;letter-spacing:-0.015em;margin-bottom:2px;color:var(--ink-900)}
.hv-card .hvc-partner{font-size:.76rem;color:var(--sw-700);font-weight:600;letter-spacing:.02em}
.hv-card p{font-size:.86rem;color:var(--ink-500);line-height:1.55}
.hv-card .hvc-row{display:flex;gap:18px;font-size:.76rem;color:var(--ink-400);margin-top:14px;flex-wrap:wrap;padding-top:14px;border-top:1px dashed var(--line-200)}
.hv-card .hvc-row span{display:inline-flex;align-items:center;gap:5px}
.hv-card .hvc-row svg{width:13px;height:13px;color:var(--sw-700)}
.hv-card:nth-child(2){margin-left:36px}
.hv-card:nth-child(2) .hvc-ic{background:linear-gradient(135deg,var(--sw-300),var(--sw-200))}
.hv-card:nth-child(2) .hvc-ic svg{color:var(--sw-800)}

/* ---------- TRUST STRIP ---------- */
.trust-strip{padding:34px 0 56px;background:#fff;border-top:1px solid var(--line-100)}
.trust-strip .ts-label{text-align:center;font-size:.74rem;font-weight:600;color:var(--ink-400);letter-spacing:.18em;text-transform:uppercase;margin-bottom:26px}
.trust-strip .ts-grid{display:flex;gap:54px;align-items:center;justify-content:center;flex-wrap:wrap}
.trust-strip img{height:32px;width:auto;filter:opacity(.92);transition:filter .25s var(--ease), transform .25s var(--ease)}
.trust-strip img:hover{filter:grayscale(0) opacity(1)}

/* ---------- STATS ---------- */
.stat-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.stat{background:#fff;border:1px solid var(--line-200);border-radius:var(--r);padding:28px 18px;text-align:center;transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .25s}
.stat:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--sw-300)}
.stat .si{width:44px;height:44px;border-radius:12px;background:var(--sw-100);margin:0 auto 14px;display:grid;place-items:center;transition:background .25s var(--ease)}
.stat:hover .si{background:var(--sw-150)}
.stat .si svg{width:22px;height:22px;color:var(--sw-700)}
.stat .sv{font-family:var(--ff);font-weight:700;font-size:2rem;color:var(--ink-900);letter-spacing:-0.03em;line-height:1}
.stat .sl{font-size:.78rem;color:var(--ink-400);margin-top:8px;line-height:1.4}

/* ---------- CARDS ---------- */
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

.icon-badge{
  width:56px;height:56px;border-radius:15px;
  background:var(--brand-grad-soft);
  display:grid;place-items:center;flex:none;
  transition:transform .3s var(--ease);
}
.icon-badge svg{width:28px;height:28px;color:var(--sw-700)}
.icon-badge img.cat-ic-img{width:42px;height:42px;object-fit:contain;display:block}
.dropdown .di img.cat-ic-img{width:30px;height:30px;object-fit:contain;display:block}
.ci-card .icon-badge img.cat-ic-img{width:32px;height:32px}
.stat .si img.cat-ic-img{width:30px;height:30px;object-fit:contain;display:block}
.feature:hover .icon-badge,.cat-card:hover .icon-badge,.test-card:hover .icon-badge{transform:scale(1.06) rotate(-3deg)}

.feature{background:#fff;border:1px solid var(--line-200);border-radius:var(--r);padding:32px;transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .25s var(--ease)}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--sw-200)}
.feature h3{font-size:1.12rem;margin:20px 0 10px;letter-spacing:-0.018em}
.feature p{color:var(--ink-400);font-size:.93rem;line-height:1.65}

.cat-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line-200);border-radius:var(--r);padding:30px;transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .25s;height:100%;position:relative;overflow:hidden}
.cat-card::before{content:"";position:absolute;inset:auto -30% -30% auto;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,var(--sw-100),transparent 70%);opacity:0;transition:opacity .35s var(--ease)}
.cat-card:hover::before{opacity:1}
.cat-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--sw-300)}
.cat-card h3{font-size:1.18rem;margin:20px 0 10px;letter-spacing:-0.018em;position:relative}
.cat-card p{color:var(--ink-400);font-size:.92rem;flex:1;line-height:1.6;position:relative}
.cat-card .cc-link{display:inline-flex;align-items:center;gap:7px;margin-top:22px;color:var(--sw-700);font-weight:600;font-size:.88rem;position:relative}
.cat-card .cc-link svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.cat-card:hover .cc-link svg{transform:translateX(5px)}

.test-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line-200);border-radius:var(--r);overflow:hidden;transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .25s;height:100%;position:relative}
.test-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--sw-300)}
.test-card .tc-top{padding:26px 28px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.test-card .tc-body{padding:18px 28px 0;flex:1}
.test-card h3{font-size:1.15rem;margin-bottom:6px;letter-spacing:-0.018em;color:var(--ink-900)}
.test-card .tc-tag{font-size:.76rem;color:var(--sw-700);font-weight:600;margin-bottom:12px;letter-spacing:.02em}
.test-card .tc-desc{color:var(--ink-400);font-size:.9rem;line-height:1.6}
.test-card .tc-meta{display:flex;flex-wrap:wrap;gap:8px;padding:18px 28px 0}
.test-card .tc-stat{display:flex;justify-content:space-between;font-size:.78rem;color:var(--ink-400);padding:14px 28px;margin-top:16px;border-top:1px dashed var(--line-200)}
.test-card .tc-stat b{color:var(--ink-900);font-weight:600}
.test-card .tc-foot{padding:14px 28px 26px}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:.76rem;font-weight:600;color:var(--ink-700);background:var(--sw-50);border:1px solid var(--line-200);padding:6px 12px;border-radius:var(--r-pill)}
.chip svg{width:13px;height:13px;color:var(--sw-700)}
.tag-new{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--sw-600);padding:5px 10px;border-radius:6px;box-shadow:0 2px 8px rgba(104,159,45,.28)}
.tag-soon{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--sw-800);background:var(--sw-100);padding:5px 10px;border-radius:6px;border:1px dashed var(--sw-400)}

/* ---------- FAQ ---------- */
.faq-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{background:#fff;border:1px solid var(--line-200);border-radius:var(--r);overflow:hidden;transition:border-color .2s var(--ease), box-shadow .25s var(--ease)}
.faq-item:hover{border-color:var(--sw-300)}
.faq-item.open{border-color:var(--sw-400);box-shadow:var(--shadow-sm)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:24px 28px;font-family:var(--ff);font-weight:600;font-size:1.02rem;color:var(--ink-900);text-align:left;transition:color .15s}
.faq-q:hover{color:var(--sw-700)}
.faq-q .fi{width:30px;height:30px;flex:none;border-radius:50%;background:var(--sw-50);display:grid;place-items:center;transition:background .25s var(--ease)}
.faq-q .fi svg{width:14px;height:14px;color:var(--ink-900);transition:color .25s var(--ease), transform .25s var(--ease)}
.faq-item.open .fi{background:var(--sw-600)}
.faq-item.open .fi svg{color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;opacity:0;transition:max-height .35s var(--ease), opacity .25s var(--ease) .05s, padding .35s var(--ease)}
.faq-item.open .faq-a{opacity:1}
.faq-a p{padding:0 28px 26px;color:var(--ink-500);font-size:.96rem;line-height:1.7}

/* ---------- PARTNERS ---------- */
/* Partner logo grid — uniform display regardless of source aspect ratio.
   Each cell is a fixed-height box; the logo scales to fit with `object-fit:contain`
   so wide wordmarks and square icons both read as visually equivalent. */
.partner-grid{
  display:grid;grid-template-columns:repeat(8,1fr);gap:36px 28px;align-items:center;
}
.partner-grid img{
  display:block;margin:0 auto;
  max-height:56px;
  max-width:100%;
  width:auto;height:auto;
  object-fit:contain;
  filter:opacity(.82);
  transition:filter .25s var(--ease), transform .25s var(--ease);
}
.partner-grid img:hover{filter:opacity(1);transform:translateY(-2px)}

/* ---------- CTA band — green gradient ---------- */
.cta-band{
  background:var(--brand-grad);
  border-radius:var(--r-lg);padding:68px 56px;text-align:center;color:#fff;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.14),transparent 70%);
  top:-180px;right:-140px;
}
.cta-band::after{
  content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(181,209,79,.32),transparent 70%);
  bottom:-180px;left:-100px;
}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{color:#fff;font-size:clamp(1.7rem,3vw,2.5rem);letter-spacing:-0.028em;font-weight:700}
.cta-band p{color:rgba(255,255,255,.88);margin:16px auto 30px;max-width:560px;font-size:1.04rem;line-height:1.6}
.cta-band .btn-light{background:#fff;color:var(--sw-700);border-color:#fff}
.cta-band .btn-light:hover{background:var(--sw-50);color:var(--sw-800)}
.cta-band .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.14);border-color:#fff;color:#fff}

/* ---------- FOOTER — white with green accents ---------- */
.site-footer{background:#fff;color:var(--ink-500);padding:76px 0 30px;border-top:1px solid var(--line-200);position:relative}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--sw-400),transparent);
}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:48px;padding-bottom:44px;border-bottom:1px solid var(--line-200)}
.footer-grid .brand{color:var(--ink-900)}
.footer-grid .brand small{color:var(--sw-700)}
.footer-about{margin:20px 0 22px;font-size:.93rem;max-width:320px;line-height:1.7}
.footer-col h4{color:var(--ink-900);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:20px;font-weight:700}
.footer-col a{display:block;padding:7px 0;font-size:.93rem;color:var(--ink-500);transition:color .15s, transform .2s var(--ease)}
.footer-col a:hover{color:var(--sw-700);transform:translateX(3px)}
.footer-contact li{display:flex;gap:11px;font-size:.92rem;padding:7px 0;line-height:1.55;color:var(--ink-500)}
.footer-contact svg{width:17px;height:17px;color:var(--sw-600);flex:none;margin-top:3px}
.footer-contact a:hover{color:var(--sw-700)}
.footer-social{display:flex;gap:10px;margin-top:8px}
.footer-social a{width:40px;height:40px;border-radius:50%;background:var(--sw-50);border:1px solid var(--line-200);display:grid;place-items:center;transition:background .25s var(--ease), transform .25s var(--ease), border-color .2s}
.footer-social a:hover{background:var(--sw-600);border-color:var(--sw-600);transform:translateY(-2px)}
.footer-social a:hover svg{color:#fff}
.footer-social svg{width:18px;height:18px;color:var(--sw-700);transition:color .2s}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:24px;font-size:.84rem;flex-wrap:wrap;color:var(--ink-400)}
.footer-legal-links a{color:var(--ink-700);text-decoration:none;border-bottom:1px solid transparent;transition:color .2s var(--ease), border-color .2s var(--ease)}
.footer-legal-links a:hover{color:var(--sw-700);border-bottom-color:var(--sw-300)}

/* ---------- Floating contact ---------- */
.float-contact{position:fixed;right:22px;bottom:22px;z-index:150;display:flex;flex-direction:column;gap:10px}
.float-contact a{
  width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  box-shadow:var(--shadow);transition:transform .3s var(--ease-bounce), box-shadow .3s var(--ease);
}
.float-contact a:hover{transform:scale(1.08) translateY(-3px);box-shadow:var(--shadow-lg)}
.float-contact svg{width:26px;height:26px;color:#fff}
.fc-line{background:var(--brand-grad)}
.fc-phone{background:var(--brand-grad)}

/* ---------- Page hero — extends hero base, adds center alignment ---------- */
.page-hero{text-align:center}
.page-hero>.container{position:relative}
.page-hero h1{font-size:clamp(2rem,3.8vw,3.4rem);letter-spacing:-0.032em;line-height:1.08;color:var(--ink-900);font-weight:700;max-width:18ch;margin:0 auto}
.page-hero h1 em{font-style:normal;color:var(--sw-600);position:relative;display:inline-block}
.page-hero h1 em::after{
  content:"";position:absolute;left:-2px;right:-2px;bottom:.08em;height:.22em;
  background:linear-gradient(120deg,var(--sw-100) 30%,var(--sw-200));z-index:-1;border-radius:6px;
}
.page-hero p{color:var(--ink-500);max-width:54ch;margin:16px auto 0;font-size:1.06rem;line-height:1.55}
.page-hero .hero-tag,.page-hero .eyebrow{margin-bottom:14px}
.page-hero .hero-actions{justify-content:center;margin-top:36px}
.crumb{display:flex;justify-content:center;gap:8px;font-size:.82rem;color:var(--ink-400);margin-bottom:14px}
.crumb a:hover{color:var(--sw-700)}
.crumb span{color:var(--ink-900);font-weight:500}

/* ---------- Contact — tighter section padding ---------- */
.contact-section{padding:80px 0}
.contact-grid-v2{margin-top:40px}

/* ---------- Contact — Quick contact row ---------- */
.quick-contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.quick-contact-card{
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r);
  padding:24px 22px;transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .2s;
  position:relative;overflow:hidden;display:flex;flex-direction:column;gap:14px;
}
.quick-contact-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--sw-300)}
.quick-contact-card .qc-ic{
  width:50px;height:50px;border-radius:14px;
  background:linear-gradient(135deg,var(--sw-150),var(--sw-100));
  display:grid;place-items:center;color:var(--sw-700);flex:none;
  transition:background .25s var(--ease);
}
.quick-contact-card:hover .qc-ic{background:linear-gradient(135deg,var(--sw-300),var(--sw-200))}
.quick-contact-card .qc-ic svg{width:24px;height:24px}
.quick-contact-card .qc-text{flex:1;min-width:0}
.quick-contact-card .qc-label{font-size:.72rem;font-weight:600;color:var(--ink-400);letter-spacing:.16em;text-transform:uppercase;margin-bottom:6px}
.quick-contact-card .qc-value{font-family:var(--ff);font-weight:600;font-size:1.02rem;color:var(--ink-900);letter-spacing:-0.012em;word-break:break-word;line-height:1.35}
/* Highlight the "LINE chat available every day" note on a new line in
   brand green so it reads as an extra perk, not just trailing copy. */
.quick-contact-card .qc-line-note{
  display:block;margin-top:4px;
  color:var(--sw-700);font-weight:600;font-size:.94rem;
}
.quick-contact-card .qc-sub{font-size:.8rem;color:var(--ink-400);margin-top:4px;line-height:1.45}
.quick-contact-card .qc-arrow{position:absolute;top:24px;right:22px;color:var(--ink-300);transition:transform .25s var(--ease), color .2s}
.quick-contact-card .qc-arrow svg{width:16px;height:16px}
.quick-contact-card:hover .qc-arrow{color:var(--sw-700);transform:translate(3px,-3px)}

/* ---------- Contact — Main layout (2-col) ---------- */
.contact-grid-v2{display:grid;grid-template-columns:1fr 1.18fr;gap:36px;align-items:start}
.contact-side{display:flex;flex-direction:column;gap:18px;position:sticky;top:100px}

/* Office card */
.office-card,.hours-card,.social-card{
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r);padding:26px 28px;
  transition:border-color .2s, box-shadow .25s var(--ease);
}
.office-card:hover,.hours-card:hover,.social-card:hover{border-color:var(--sw-300)}
.office-head{display:flex;gap:14px;align-items:center;margin-bottom:18px}
.office-head .icon-badge{width:48px;height:48px;border-radius:13px}
.office-head .icon-badge svg{width:22px;height:22px}
.office-head h3{font-size:1.04rem;letter-spacing:-0.015em;color:var(--ink-900)}
.office-head p{color:var(--ink-400);font-size:.82rem;margin-top:2px;line-height:1.4}
.office-address{color:var(--ink-700);font-size:.93rem;line-height:1.65;margin-bottom:18px}
.office-map{border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--line-200);margin-bottom:18px;background:var(--sw-50)}
.office-map iframe{width:100%;height:220px;display:block;border:0}

/* Hours list */
.hours-list li{display:flex;justify-content:space-between;align-items:center;padding:13px 0;border-bottom:1px solid var(--line-100);font-size:.93rem}
.hours-list li:last-child{border:0;padding-bottom:0}
.hours-list li:first-child{padding-top:0}
.hours-list li b{color:var(--ink-900);font-weight:600}
.hours-list li span{color:var(--ink-500)}
.hours-list li span.closed{color:var(--danger);font-weight:600}
.hours-list li span.open{color:var(--sw-700);font-weight:600;display:inline-flex;align-items:center;gap:6px}
.hours-list li span.open::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--sw-500);box-shadow:0 0 0 3px var(--sw-150)}

/* Social card */
.social-card h3{font-size:1.04rem;margin-bottom:5px;letter-spacing:-0.015em}
.social-card p{color:var(--ink-400);font-size:.86rem;margin-bottom:16px}
.social-list{display:flex;gap:10px}
.social-list a{
  width:44px;height:44px;border-radius:50%;background:var(--sw-50);
  border:1px solid var(--line-200);display:grid;place-items:center;
  transition:background .25s var(--ease), border-color .2s, transform .25s var(--ease);
}
.social-list a:hover{background:var(--sw-600);border-color:var(--sw-600);transform:translateY(-2px)}
.social-list a:hover svg{color:#fff}
.social-list svg{width:18px;height:18px;color:var(--sw-700);transition:color .2s}

/* Form refinements */
.form-card .form-title{font-size:1.6rem;letter-spacing:-0.025em;margin-top:10px;margin-bottom:8px}
.form-card .form-sub{color:var(--ink-400);font-size:.93rem;margin-bottom:24px;line-height:1.6}
.form-card .btn svg{transition:transform .25s var(--ease)}
.form-card .btn:hover svg{transform:translateX(4px)}
.form-note code{background:var(--sw-50);color:var(--sw-800);padding:2px 7px;border-radius:5px;font-size:.86em}

/* Old back-compat (used by other pages if any) */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px}

/* Contact — Responsive */
@media(max-width:1024px){
  .quick-contact-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid-v2{grid-template-columns:1fr;gap:28px}
  .contact-side{position:static}
}
@media(max-width:680px){
  .quick-contact-grid{grid-template-columns:1fr}
  .office-map iframe{height:200px}
  .office-card,.hours-card,.social-card{padding:22px 24px}
  .quick-contact-card{padding:20px 22px}
  .quick-contact-card .qc-arrow{display:none}
}
.contact-info{display:flex;flex-direction:column;gap:14px}
.ci-card{display:flex;gap:18px;background:#fff;border:1px solid var(--line-200);border-radius:var(--r);padding:24px 26px;transition:border-color .2s, box-shadow .25s var(--ease), transform .25s var(--ease)}
.ci-card:hover{border-color:var(--sw-300);transform:translateX(3px);box-shadow:var(--shadow-xs)}
.ci-card .icon-badge{width:48px;height:48px}
.ci-card .icon-badge svg{width:22px;height:22px}
.ci-card h4{font-size:.96rem;margin-bottom:5px;letter-spacing:-0.01em}
.ci-card p,.ci-card a{color:var(--ink-400);font-size:.93rem;line-height:1.55}
.ci-card a:hover{color:var(--sw-700)}
.form-card{background:#fff;border:1px solid var(--line-200);border-radius:var(--r-lg);padding:42px;box-shadow:var(--shadow-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:20px}
.field label{display:block;font-family:var(--ff);font-weight:600;font-size:.81rem;color:var(--ink-900);margin-bottom:8px}
.field input,.field textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--line-300);border-radius:var(--r-sm);
  font-family:inherit;font-size:.94rem;color:var(--ink-900);background:var(--sw-50);
  transition:border-color .2s, background .2s, box-shadow .25s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-300)}
.field input:focus,.field textarea:focus{outline:0;border-color:var(--sw-600);background:#fff;box-shadow:var(--shadow-ring)}
.field textarea{resize:vertical;min-height:8.125rem;line-height:1.55}
.form-note{font-size:.83rem;color:var(--ink-400);margin-top:14px;text-align:center;line-height:1.55}
.form-msg{display:none;padding:16px;border-radius:12px;font-size:.93rem;margin-top:16px;font-weight:500}
.form-msg.ok{display:block;background:var(--sw-100);color:var(--sw-800);border:1px solid var(--sw-200)}
.form-msg.err{display:block;background:var(--rose-soft);color:var(--danger)}

/* ---------- Team ---------- */
.team-card{
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r-md);
  padding:38px 30px 32px;text-align:center;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), border-color .25s;
  position:relative;overflow:hidden;
}
/* No-photo team cards — tighter top padding so name sits at the top */
.team-card.no-photo{padding-top:30px}
.team-card.no-photo h3{margin-top:0}
.team-card::before{
  content:"";position:absolute;top:-40%;left:50%;transform:translateX(-50%);
  width:140%;height:200px;
  background:radial-gradient(ellipse at center, var(--sw-100) 0%, transparent 60%);
  opacity:0;transition:opacity .35s var(--ease);pointer-events:none;
}
.team-card:hover::before{opacity:.9}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--sw-300)}
.team-card>*{position:relative}

.team-avatar{
  width:108px;height:108px;border-radius:50%;margin:0 auto 22px;
  background:var(--brand-grad);
  display:grid;place-items:center;font-family:var(--ff);font-weight:700;font-size:1.85rem;color:#fff;letter-spacing:-0.025em;
  box-shadow:0 10px 28px rgba(104,159,45,.28), inset 0 -6px 18px rgba(0,0,0,.08), inset 0 3px 10px rgba(255,255,255,.30);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
  position:relative;
}
/* Team photo — round portrait when p.photo is set */
.team-photo{
  width:108px;height:108px;border-radius:50%;margin:0 auto 22px;
  object-fit:cover;display:block;
  background:var(--sw-50);
  border:3px solid #fff;
  box-shadow:0 10px 28px rgba(104,159,45,.22), 0 0 0 1px var(--line-200);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
  position:relative;
}
.team-card:hover .team-photo{
  transform:scale(1.05);
  box-shadow:0 14px 36px rgba(104,159,45,.32), 0 0 0 1px var(--sw-300);
}
.team-card:hover .team-avatar{
  transform:scale(1.06) rotate(-4deg);
  box-shadow:0 14px 36px rgba(104,159,45,.40), inset 0 -6px 18px rgba(0,0,0,.08), inset 0 3px 10px rgba(255,255,255,.30);
}
.team-avatar::after{
  content:"";position:absolute;inset:-5px;border-radius:50%;
  border:1.5px dashed var(--sw-300);opacity:0;
  transition:opacity .35s var(--ease), transform .6s var(--ease);
}
.team-card:hover .team-avatar::after{opacity:.7;transform:rotate(18deg)}

.team-card h3{font-size:1.12rem;letter-spacing:-0.018em;color:var(--ink-900);line-height:1.3}
.team-card .tc-role,
.team-card .tc-role-pill{
  display:inline-block;margin-top:12px;padding:5px 14px;
  background:var(--sw-100);color:var(--sw-700);
  border:1px solid var(--sw-200);border-radius:var(--r-pill);
  font-size:.76rem;font-weight:600;letter-spacing:.02em;
}
.team-card .tc-bio{color:var(--ink-400);font-size:.88rem;margin-top:16px;line-height:1.65}
.team-card .tc-social{display:flex;justify-content:center;gap:10px;margin-top:20px}
.team-card .tc-social a{
  width:36px;height:36px;border-radius:50%;
  background:var(--sw-50);border:1px solid var(--line-200);
  display:grid;place-items:center;
  transition:background .2s var(--ease), border-color .2s, transform .25s var(--ease);
}
.team-card .tc-social a:hover{background:var(--sw-600);border-color:var(--sw-600);transform:translateY(-2px)}
.team-card .tc-social a:hover svg{color:#fff}
.team-card .tc-social svg{width:15px;height:15px;color:var(--sw-700);transition:color .2s}

/* ---------- GUIDES — Interpretation guides + Protocols ---------- */
.guides-cat-block{margin-bottom:56px}
.guides-cat-block:last-child{margin-bottom:0}

.guide-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--line-200);
  border-radius:var(--r);padding:24px 26px;height:100%;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), border-color .25s;
  position:relative;overflow:hidden;
}
.guide-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--sw-300)}
.guide-card .gc-tag{
  display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  font-size:.7rem;font-weight:700;letter-spacing:.10em;text-transform:uppercase;
  color:var(--sw-700);background:var(--sw-50);
  padding:5px 12px 5px 8px;border-radius:var(--r-pill);border:1px solid var(--sw-200);
  margin-bottom:14px;line-height:1;
}
.guide-card .gc-tag svg{width:13px;height:13px;color:var(--sw-700)}
.guide-card .gc-tag img.cat-ic-img{width:14px;height:14px;object-fit:contain;display:block}
.guide-card h3{font-size:1.12rem;letter-spacing:-0.018em;color:var(--ink-900);line-height:1.3;margin-top:2px}
.guide-card .gc-partner{font-size:.78rem;font-weight:600;color:var(--sw-700);margin-top:6px;letter-spacing:.015em}
.guide-card .gc-desc{color:var(--ink-400);font-size:.9rem;line-height:1.6;flex:1;margin:12px 0 14px}
.guide-card .gc-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.guide-card .gc-link{display:inline-flex;align-items:center;gap:7px;color:var(--sw-700);font-weight:600;font-size:.88rem;margin-top:auto}
.guide-card .gc-link svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.guide-card:hover .gc-link svg{transform:translateX(5px)}

/* Guide hero — extends hero base */
.guide-hero{color:var(--ink-800)}
.guide-hero>.container{position:relative}
.guide-hero h1{color:var(--ink-900);font-size:clamp(2rem,3.8vw,2.9rem);letter-spacing:-0.032em;line-height:1.1;margin-top:8px}
.guide-hero .gh-tag{color:var(--ink-500);font-size:1.04rem;margin:16px 0 22px;max-width:660px;line-height:1.6}
.guide-hero .gh-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.guide-hero .gh-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- GUIDE — Accordion + Sidebar Portal ----------
   Now wrapped inside <section class="section"><div class="container">
   so we only need to define the inner grid (matches .detail-body pattern). */
.guide-layout{
  display:grid;grid-template-columns:280px 1fr;gap:26px;
  align-items:start;
}
@media(max-width:1024px){.guide-layout{grid-template-columns:1fr;gap:32px}}

/* Downloads section: comfortable green hero space above (give the hero room
   to breathe) + tight gap below (sits close to the guide content).
   We also zero out the dl-card's default margin-bottom + dl-after's section
   padding-top + guide-layout's top padding so the chain doesn't stack.
   IMPORTANT: must use .section.dl-section (specificity 0,2,0) — plain
   .dl-section (0,1,0) loses to later .section{padding:64px/68px 0}
   rules inside the responsive media queries. */
.section.dl-section{padding-top:24px;padding-bottom:0}
.dl-section .dl-card{margin-bottom:0}
.dl-section + .dl-after{padding-top:0}
.dl-section + .dl-after .guide-layout{padding-top:14px}

/* Hero keeps a generous bottom padding to preserve the green breathing room
   below the action buttons — just shy of the default 88px so the Downloads
   section reads as related, not floating in space. */
.guide-hero:has(+ .dl-section),
.detail-hero:has(+ .dl-section),
.hero:has(+ .dl-section),
.page-hero:has(+ .dl-section){padding-bottom:56px}

@media(max-width:1100px){
  .section.dl-section{padding-top:20px;padding-bottom:0}
  .dl-section + .dl-after .guide-layout{padding-top:10px}
  .guide-hero:has(+ .dl-section),
  .detail-hero:has(+ .dl-section){padding-bottom:44px}
}
/* Match Downloads card horizontal width to the sidebar/main below:
   .guide-layout adds 20px inset on tablet/mobile (max-width:1024), so the
   .dl-card needs the same 20px side margin to align edges. */
@media(max-width:1024px){
  .dl-section > .container > .dl-card{margin-left:20px;margin-right:20px}
}
@media(max-width:680px){
  /* Consistent ~24px breathing room on all sides of the Downloads card on
     mobile — matches the inner guide-content rhythm so all gaps feel equal. */
  .section.dl-section{padding-top:12px;padding-bottom:0}
  .dl-section + .dl-after .guide-layout{padding-top:20px}
  .guide-hero:has(+ .dl-section),
  .detail-hero:has(+ .dl-section){padding-bottom:12px}
}
.guide-sidebar{
  position:sticky;top:var(--sticky-offset);align-self:start;
  max-height:calc(100vh - 120px);overflow-y:auto;
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r);
  padding:18px;box-shadow:var(--shadow-xs);
}
.g-search{
  width:100%;padding:10px 14px;
  border:1.5px solid var(--line-300);border-radius:var(--r-sm);
  font-family:inherit;font-size:13.5px;background:var(--sw-50);
  transition:border-color .15s, background .15s, box-shadow .25s;
  margin-bottom:12px;
}
.g-search:focus{outline:0;border-color:var(--sw-600);background:#fff;box-shadow:var(--shadow-ring)}
.g-controls{display:flex;gap:6px;margin-bottom:14px}
.g-controls button{
  flex:1;padding:8px 10px;background:var(--sw-50);border:1px solid var(--line-200);
  border-radius:6px;cursor:pointer;font-family:inherit;font-size:11.5px;font-weight:600;
  color:var(--sw-700);letter-spacing:.04em;transition:background .15s, border-color .15s;
}
.g-controls button:hover{background:var(--sw-100);border-color:var(--sw-300)}
.g-nav-group-title{
  font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--ink-400);padding:14px 8px 6px;border-top:1px solid var(--line-100);margin-top:8px;
}
.g-nav-group-title:first-of-type{border-top:0;margin-top:0;padding-top:0}
.g-nav-link{
  display:block;padding:8px 12px;color:var(--ink-700);text-decoration:none;
  border-radius:6px;font-size:13px;line-height:1.4;
  border-left:3px solid transparent;cursor:pointer;
  transition:background .12s, color .12s, border-left-color .12s;
}
.g-nav-link:hover{background:var(--sw-50);color:var(--sw-700);border-left-color:var(--sw-400)}
.g-nav-link.active{background:var(--sw-100);color:var(--sw-800);border-left-color:var(--sw-600);font-weight:600}
.g-nav-link.hidden{display:none}

.guide-main{min-width:0}
.g-group-header{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
  color:var(--ink-400);margin:28px 0 14px;padding-bottom:10px;
  border-bottom:2px solid var(--line-200);
}
.g-group-header:first-of-type{margin-top:0}

.g-accordion{
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r);
  margin-bottom:10px;overflow:hidden;scroll-margin-top:var(--sticky-offset);
  transition:border-color .2s var(--ease), box-shadow .25s var(--ease);
}
.g-accordion:hover{border-color:var(--sw-300)}
.g-accordion.open{border-color:var(--sw-400);box-shadow:var(--shadow-sm)}
.g-accordion-header{
  width:100%;padding:16px 20px;background:#fff;border:0;text-align:left;
  cursor:pointer;font-family:inherit;font-size:14.5px;font-weight:600;
  color:var(--ink-900);display:flex;align-items:center;gap:12px;letter-spacing:-0.01em;
  transition:background .12s;
}
.g-accordion-header:hover{background:var(--sw-50)}
.g-accordion-header:focus-visible{outline:2px solid var(--sw-400);outline-offset:-2px}
.g-accordion-icon{
  width:24px;height:24px;flex:none;display:grid;place-items:center;
  color:var(--ink-400);transition:transform .25s var(--ease), color .25s;
}
.g-accordion.open .g-accordion-icon{transform:rotate(180deg);color:var(--sw-700)}
.g-accordion-icon svg{width:13px;height:13px}
.g-accordion-title{flex:1;min-width:0;line-height:1.4}
.g-tag{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  padding:4px 10px;border-radius:5px;white-space:nowrap;flex:none;
}
.g-tag.interpret{background:var(--sw-100);color:var(--sw-800);border:1px solid var(--sw-200)}
.g-tag.protocol{background:var(--sw-600);color:#fff}
.g-tag.pattern{background:var(--sw-150);color:var(--sw-800);border:1px solid var(--sw-300)}
.g-tag.overview{background:var(--tint-100);color:var(--ink-700);border:1px solid var(--line-200)}

.g-accordion-body{
  display:none;padding:6px 24px 24px;border-top:1px solid var(--sw-100);background:#fcfdfb;
}
.g-accordion.open .g-accordion-body{display:block}
.g-accordion-body p{color:var(--ink-700);line-height:1.7;margin:12px 0;font-size:.94rem}
.g-accordion-body p:first-child{margin-top:14px}

.g-panel{
  border-radius:8px;padding:14px 18px;margin:14px 0;
  border:1px solid var(--line-200);border-left:4px solid;
}
.g-panel.interpret{border-left-color:var(--sw-500);background:var(--sw-50)}
.g-panel.treatment{border-left-color:var(--sw-700);background:linear-gradient(180deg,#fff,var(--sw-50))}
.g-panel.warn{border-left-color:var(--warn);background:var(--amber-soft);border-color:#f0d9b8}
.g-panel-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  margin-bottom:8px;display:inline-block;
}
.g-panel.interpret .g-panel-label{color:var(--sw-700)}
.g-panel.treatment .g-panel-label{color:var(--sw-800)}
.g-panel.warn .g-panel-label{color:var(--warn)}
.g-panel p:first-child{margin-top:4px}
.g-panel p:last-child{margin-bottom:0}

.g-keypoints{list-style:none;padding:0;margin:12px 0}
.g-keypoints li{
  position:relative;padding:9px 0 9px 24px;
  font-size:.92rem;color:var(--ink-700);line-height:1.6;
  border-bottom:1px dashed var(--line-100);
}
.g-keypoints li:last-child{border-bottom:0}
.g-keypoints li::before{
  content:"";position:absolute;left:4px;top:17px;
  width:7px;height:7px;border-radius:50%;background:var(--sw-600);
}

.g-protocol-steps{counter-reset:gstep;list-style:none;padding:0;margin:10px 0}
.g-protocol-steps li{
  counter-increment:gstep;position:relative;
  padding:12px 0 12px 40px;font-size:.93rem;color:var(--ink-700);line-height:1.6;
  border-bottom:1px dashed var(--line-100);
}
.g-protocol-steps li:last-child{border-bottom:0}
.g-protocol-steps li::before{
  content:counter(gstep);position:absolute;left:0;top:10px;
  width:28px;height:28px;border-radius:50%;background:#fff;color:var(--sw-700);
  border:1.5px solid var(--sw-300);display:grid;place-items:center;
  font-weight:700;font-size:.78rem;font-family:var(--ff);
}

/* References block — peer-reviewed citations for an interpretation
   section or protocol. Compact serif-friendly list with hanging indent. */
.g-refs{
  margin-top:18px;padding:14px 16px;
  background:#FAFCFE;border:1px solid var(--line-100);border-radius:10px;
}
.g-refs .g-panel-label{color:var(--sw-700)}
.g-refs-list{
  margin:6px 0 0;padding-left:22px;
  font-size:.82rem;line-height:1.55;color:var(--ink-700);
}
.g-refs-list li{margin:4px 0;padding-left:2px}
.g-refs-list li::marker{color:var(--ink-400);font-weight:600}
.g-refs-body{margin-top:6px;font-size:.84rem;line-height:1.55;color:var(--ink-700);white-space:pre-line}

/* Structured items list — used by CMS-edited protocols where each
   recommendation has a short label + supporting detail. */
.g-protocol-items{list-style:none;padding:0;margin:10px 0}
.g-protocol-items li{
  padding:10px 0;border-bottom:1px dashed var(--line-200);
  font-size:.94rem;line-height:1.6;color:var(--ink-700);
}
.g-protocol-items li:last-child{border-bottom:0}
.g-protocol-items li b{color:var(--ink-900);font-weight:600}
.g-protocol-items .g-protocol-detail{color:var(--ink-700)}

.g-protocol-meta{
  margin-top:14px;padding-top:12px;border-top:1px solid var(--line-100);
  font-size:.9rem;color:var(--ink-500);line-height:1.65;
}
.g-protocol-meta div{margin:3px 0}
.g-protocol-meta b{color:var(--ink-900);font-weight:600}

/* .g-disclaimer-block — deprecated. Both lab and guide pages now use the
   unified .medical-disclaimer component (see further down). Kept as a no-op
   alias in case any older content / CMS-generated HTML still references it. */
.g-disclaimer-block{display:none}

/* ---------- Guide sex tabs (Female / Male) ---------- */
.guide-sex-tabs{
  display:flex;gap:8px;margin-bottom:22px;padding:6px;
  background:var(--sw-50);border:1px solid var(--sw-200);border-radius:var(--r-pill);
  position:sticky;top:var(--header-h);z-index:5;
}
.gst-btn{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:11px 18px;border:none;cursor:pointer;
  border-radius:var(--r-pill);background:transparent;color:var(--ink-500);
  font-family:var(--ff);font-weight:600;font-size:.92rem;letter-spacing:-.01em;
  transition:background .2s var(--ease), color .2s var(--ease), box-shadow .2s var(--ease), transform .15s var(--ease);
}
.gst-btn:hover{color:var(--sw-700)}
.gst-btn .gst-ic{display:inline-flex}
.gst-btn .gst-ic svg{width:18px;height:18px}
.gst-btn.active{
  background:var(--brand-grad);color:#fff;
  box-shadow:0 6px 16px -6px rgba(104,159,45,.5);
}
.gst-btn.active:hover{color:#fff}
.g-accordion.sex-hidden,.g-nav-link.sex-hidden{display:none !important}
@media(max-width:1024px){.guide-sex-tabs{top:0}}
@media(max-width:680px){
  .gst-btn{padding:10px 12px;font-size:.86rem}
}

/* ---------- Guide reference tables ---------- */
.g-table-title{
  font-size:.82rem;font-weight:700;color:var(--sw-700);
  text-transform:uppercase;letter-spacing:.04em;
  margin:18px 0 8px 2px;
}
.g-table-wrap{
  width:100%;overflow-x:auto;margin:12px 0;
  border:1px solid var(--line-200);border-radius:var(--r);
  -webkit-overflow-scrolling:touch;
}
.g-table{
  width:100%;border-collapse:collapse;font-size:.86rem;min-width:440px;
}
.g-table th,.g-table td{
  padding:9px 13px;text-align:left;vertical-align:top;
  border-bottom:1px solid var(--line-100);line-height:1.5;
}
.g-table thead th{
  background:var(--sw-50);color:var(--sw-800);font-weight:700;
  font-size:.74rem;text-transform:uppercase;letter-spacing:.03em;
  border-bottom:2px solid var(--sw-200);white-space:nowrap;
}
.g-table tbody tr:last-child td{border-bottom:none}
.g-table tbody tr:hover{background:var(--sw-50)}
.g-table td.ga-analyte{font-weight:600;color:var(--ink-900)}
.g-table-note{
  font-size:.8rem;color:var(--ink-400);margin:6px 0 2px 2px;line-height:1.5;
}
@media(max-width:680px){
  .g-table{font-size:.8rem;min-width:420px}
  .g-table th,.g-table td{padding:7px 10px}
}

/* ---------- Expert review note (Old framing vs Current evidence) ---------- */
.g-expert{
  margin:18px 0 8px;border:1px solid var(--line-200);border-radius:var(--r);
  background:#fff;overflow:hidden;
  box-shadow:0 1px 0 rgba(15,40,21,.02);
}
.g-expert-head{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;background:var(--sw-50);
  font-size:.78rem;font-weight:700;color:var(--sw-800);
  text-transform:uppercase;letter-spacing:.05em;
  border-bottom:1px solid var(--sw-200);
}
.g-expert-ic{
  display:inline-grid;place-items:center;
  width:22px;height:22px;border-radius:50%;
  background:var(--brand-grad);color:#fff;font-size:.78rem;font-weight:700;
}
.g-expert-row{
  padding:12px 16px;border-bottom:1px dashed var(--line-100);
  display:flex;flex-direction:column;gap:6px;
}
.g-expert-row:last-child{border-bottom:none}
.g-expert-tag{
  font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  display:inline-flex;align-items:center;gap:6px;width:fit-content;
  padding:3px 10px;border-radius:var(--r-pill);
}
.g-expert-row.old{background:#fffaf2}
.g-expert-row.old .g-expert-tag{background:#fef3c7;color:#92400e}
.g-expert-row.new{background:#f4faf0}
.g-expert-row.new .g-expert-tag{background:#dcf2d0;color:var(--sw-800)}
.g-expert-row.practice{background:#f0f7fb}
.g-expert-row.practice .g-expert-tag{background:#dbeafe;color:#1e3a8a}
.g-expert-row.safety{background:#fef2f2}
.g-expert-row.safety .g-expert-tag{background:#fee2e2;color:#991b1b}
.g-expert-row p{margin:0;font-size:.92rem;line-height:1.6;color:var(--ink-800)}
.g-expert-refs{
  padding:8px 16px 10px;font-size:.78rem;color:var(--ink-400);
  background:var(--sw-50);border-top:1px solid var(--line-100);
}
@media(max-width:680px){
  .g-expert-head{padding:10px 14px;font-size:.74rem}
  .g-expert-row{padding:11px 14px}
}

/* ---------- Downloads (PDF resources) ---------- */
.dl-card{
  background:#fff;border:1px solid var(--line-200);border-radius:var(--r-lg);
  padding:22px 24px;margin-bottom:28px;
  box-shadow:0 1px 0 rgba(15,40,21,.02), 0 8px 24px -16px rgba(15,40,21,.08);
}
/* Card header — clickable button toggling collapse */
.dl-card-head{
  display:flex;align-items:center;gap:14px;
  width:100%;background:transparent;border:0;
  padding:0;margin:0;text-align:left;
  font-family:inherit;cursor:pointer;
  color:inherit;
  transition:opacity .2s var(--ease);
}
.dl-card-head:hover{opacity:.92}
.dl-card-head:focus-visible{outline:3px solid var(--sw-400);outline-offset:4px;border-radius:12px}
.dl-card-icon{
  width:42px;height:42px;border-radius:12px;flex:0 0 42px;
  display:grid;place-items:center;
  background:var(--brand-grad);color:#fff;
}
.dl-card-icon svg{width:22px;height:22px}
.dl-card-htxt{flex:1;min-width:0}
.dl-card-title{font-size:1.18rem;font-weight:700;letter-spacing:-.02em;color:var(--ink-900);margin:2px 0 4px;display:flex;align-items:center;gap:10px}
.dl-card-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:26px;height:22px;padding:0 8px;
  background:var(--sw-100);color:var(--sw-800);
  border:1px solid var(--sw-200);border-radius:999px;
  font-size:.74rem;font-weight:700;letter-spacing:.02em;
}
.dl-card-sub{font-size:.9rem;color:var(--ink-500);line-height:1.55;margin:0}
.dl-card-chev{
  flex:0 0 36px;width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--sw-50);border:1px solid var(--sw-150);color:var(--sw-700);
  transition:transform .3s var(--ease), background .2s var(--ease);
}
.dl-card-chev svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.dl-card-head:hover .dl-card-chev{background:var(--sw-100)}
/* Rotated when expanded */
.dl-card:not(.is-collapsed) .dl-card-chev svg{transform:rotate(180deg)}

/* Collapse / expand animation. Visibility transitions with a delay so that
   children are removed from the tab order only after the close animation completes. */
.dl-list{
  list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;
  overflow:hidden;
  margin-top:16px;
  opacity:1;visibility:visible;
  transition:max-height .35s var(--ease), opacity .25s var(--ease), margin-top .3s var(--ease), visibility 0s linear 0s;
}
.dl-card.is-collapsed .dl-list{
  max-height:0;
  opacity:0;margin-top:0;
  visibility:hidden;
  transition:max-height .35s var(--ease), opacity .25s var(--ease), margin-top .3s var(--ease), visibility 0s linear .35s;
}

/* ---------- ASIDE DOWNLOADS — compact version for sticky right sidebar ----------
   Reuses .dl-list/.dl-row/.dl-btn machinery but tightens padding and typography
   to fit the narrower aside column (320px) without becoming cramped. */
.aside-dl{padding:0;overflow:hidden}
.aside-dl-head{
  display:flex;align-items:center;gap:12px;width:100%;
  padding:18px 20px;border:0;background:transparent;cursor:pointer;
  text-align:left;font:inherit;color:inherit;
}
.aside-dl-head:hover{background:#fafcfc}
.aside-dl-head:focus-visible{outline:3px solid var(--sw-400);outline-offset:-3px;border-radius:var(--r)}
.aside-dl-icon{
  flex:0 0 36px;width:36px;height:36px;border-radius:10px;
  display:grid;place-items:center;
  background:var(--brand-grad);color:#fff;
}
.aside-dl-icon svg{width:18px;height:18px}
.aside-dl-htxt{flex:1;min-width:0}
.aside-dl-title{
  font-size:.97rem;font-weight:700;color:var(--ink-900);
  letter-spacing:-.018em;margin:0 0 2px;
  display:flex;align-items:center;gap:8px;
}
.aside-dl-count{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:20px;padding:0 7px;
  background:var(--sw-100);color:var(--sw-800);
  border:1px solid var(--sw-200);border-radius:999px;
  font-size:.68rem;font-weight:700;
}
.aside-dl-sub{font-size:.78rem;color:var(--ink-500);line-height:1.45;margin:0}
.aside-dl-chev{
  flex:0 0 28px;width:28px;height:28px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--sw-50);border:1px solid var(--sw-150);color:var(--sw-700);
  transition:background .2s var(--ease);
}
.aside-dl-chev svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.aside-dl-head:hover .aside-dl-chev{background:var(--sw-100)}
.aside-dl:not(.is-collapsed) .aside-dl-chev svg{transform:rotate(180deg)}

/* List collapse/expand inside aside */
.aside-dl-list{
  padding:0 16px 16px;margin:0;
  display:flex;flex-direction:column;gap:8px;
  overflow:hidden;opacity:1;visibility:visible;
  transition:max-height .35s var(--ease), opacity .25s var(--ease), padding .3s var(--ease), visibility 0s linear 0s;
}
.aside-dl.is-collapsed .aside-dl-list{
  max-height:0;
  opacity:0;padding-top:0;padding-bottom:0;
  visibility:hidden;
  transition:max-height .35s var(--ease), opacity .25s var(--ease), padding .3s var(--ease), visibility 0s linear .35s;
}

/* Compact row variant for aside */
.dl-row--compact{padding:10px 12px;gap:10px;flex-wrap:wrap}
.dl-row--compact .dl-ic{width:32px;height:32px;flex:0 0 32px;border-radius:8px}
.dl-row--compact .dl-ic svg{width:16px;height:16px}
.dl-row--compact .dl-name{font-size:.86rem;line-height:1.35;font-weight:600}
.dl-row--compact .dl-desc{font-size:.76rem;color:var(--ink-500);line-height:1.45;margin-top:2px}
.dl-row--compact .dl-meta{font-size:.66rem;margin-top:4px}
.dl-row--compact .dl-btn{
  padding:7px 12px;font-size:.74rem;width:100%;justify-content:center;margin-top:4px;
}
.dl-row--compact .dl-btn-ic svg{width:13px;height:13px}
.dl-row--compact .dl-info{min-width:0;flex:1 1 100%}
@media(prefers-reduced-motion:reduce){
  .dl-list,.dl-card-chev svg,.dl-card-chev{transition:none}
}
.dl-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border:1px solid var(--line-200);border-radius:var(--r);
  background:#fff;transition:border-color .2s var(--ease), background .2s var(--ease), transform .2s var(--ease);
}
.dl-row:hover{border-color:var(--sw-300);background:var(--sw-50);transform:translateY(-1px)}
.dl-ic{
  width:38px;height:38px;border-radius:10px;flex:0 0 38px;
  display:grid;place-items:center;
  background:var(--sw-50);color:var(--sw-700);border:1px solid var(--sw-200);
}
.dl-ic svg{width:20px;height:20px}
.dl-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.dl-name{font-weight:600;font-size:.96rem;color:var(--ink-900);letter-spacing:-.005em}
.dl-desc{font-size:.84rem;color:var(--ink-500);line-height:1.5}
.dl-meta{font-size:.76rem;color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.dl-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 16px;border-radius:var(--r-pill);
  background:var(--brand-grad);color:#fff;
  font-family:var(--ff);font-weight:600;font-size:.82rem;
  border:none;cursor:pointer;text-decoration:none;flex:0 0 auto;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), filter .2s var(--ease);
  box-shadow:0 4px 12px -4px rgba(104,159,45,.45);
}
.dl-btn:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 8px 18px -6px rgba(104,159,45,.55)}
.dl-btn:disabled,.dl-btn[aria-busy="true"]{opacity:.85;cursor:wait}
.dl-btn-ic{display:inline-flex}
.dl-btn-ic svg{width:15px;height:15px}
.dl-status{
  display:block;font-size:.78rem;line-height:1.45;margin-top:6px;
  font-weight:500;transition:opacity .2s;
}
.dl-status:empty{display:none}
.dl-status--ok{color:var(--success)}
.dl-status--err{color:var(--danger)}

/* "Coming soon" badge — shown next to filename when file isn't ready yet
   (either explicit pending:true in CMS or HEAD check returned 404) */
.dl-pending{
  display:inline-block;vertical-align:middle;
  margin-left:10px;padding:2px 9px;
  background:var(--amber-soft);color:var(--amber-text);
  border:1px solid var(--amber-border);border-radius:999px;
  font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  line-height:1.4;
}
/* Row state — subtle visual cue without making the card unusable */
.dl-row.is-pending{background:linear-gradient(0deg,rgba(255,247,232,.45),rgba(255,247,232,.45)),#fff}
.dl-row.is-pending .dl-ic{background:var(--amber-soft);border-color:var(--amber-border);color:var(--amber-text)}
.dl-row.is-pending .dl-btn{
  background:#fff;color:var(--amber-text);border:1.5px solid var(--amber-border);
  box-shadow:none;
}
.dl-row.is-pending .dl-btn:hover:not(:disabled){
  background:var(--amber-soft);transform:translateY(-1px);
  border-color:#E0B85F;
}


@media(max-width:680px){
  .dl-card{padding:18px 16px}
  .dl-row{flex-wrap:wrap;padding:12px 14px;gap:10px}
  .dl-info{flex:1 1 100%;order:2;padding-left:48px;margin-top:-30px}
  .dl-ic{order:1}
  .dl-btn{order:3;width:100%;justify-content:center}
}

@media(max-width:1024px){
  .guide-layout{grid-template-columns:1fr;gap:16px;padding:18px 20px 48px}
  .guide-sidebar{position:static;max-height:340px}
}
@media(max-width:680px){
  .g-accordion-header{padding:13px 16px;font-size:13.5px;flex-wrap:wrap}
  .g-tag{font-size:9.5px;padding:3px 8px}
  .g-accordion-body{padding:6px 16px 18px}
  .g-panel{padding:12px 14px}
}

/* ---------- Lab list ---------- */
.lab-nav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:40px}
.lab-nav a{padding:11px 22px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--line-200);font-family:var(--ff);font-weight:600;font-size:.86rem;color:var(--ink-900);transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), transform .2s var(--ease)}
.lab-nav a:hover{background:var(--sw-600);color:#fff;border-color:var(--sw-600);transform:translateY(-2px)}
.lab-cat-block{margin-bottom:56px}
.lab-cat-block:last-child{margin-bottom:0}
.lab-cat-head{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.lab-cat-head h2{font-size:1.55rem;letter-spacing:-0.025em}
.lab-cat-head p{color:var(--ink-400);font-size:.92rem;margin-top:4px;line-height:1.5}

/* Within a category block, hide the redundant per-card icon —
   category header already shows the same icon, so cards focus on test name */
.lab-cat-block .test-card .tc-top{padding:14px 28px 0;justify-content:flex-end;min-height:0}
.lab-cat-block .test-card .tc-top .icon-badge{display:none}
.lab-cat-block .test-card .tc-body{padding-top:14px}

/* ---------- Lab detail — extends hero base, with 2-col layout ---------- */
.detail-hero{color:var(--ink-800)}
.detail-hero>.container{position:relative}
.detail-hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:52px;align-items:start}
.detail-hero h1{color:var(--ink-900);font-size:clamp(2.1rem,4vw,3.2rem);letter-spacing:-0.034em;line-height:1.08}
.detail-hero .dh-tag{color:var(--ink-500);font-size:1.08rem;margin:18px 0 28px;max-width:580px;line-height:1.6}
.detail-hero .dh-cta{display:flex;gap:14px;flex-wrap:wrap}
.detail-hero .dh-cert{display:inline-flex;align-items:center;gap:11px;margin-top:28px;font-size:.86rem;color:var(--sw-700);background:#fff;padding:11px 20px;border-radius:var(--r-pill);border:1px solid var(--sw-200);box-shadow:var(--shadow-xs)}
.detail-hero .dh-cert svg{width:17px;height:17px;color:var(--sw-600)}
.partner-badge{display:inline-flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line-200);padding:10px 22px 10px 12px;border-radius:var(--r-pill);margin-top:20px;box-shadow:var(--shadow-xs)}
.partner-badge img{height:26px;width:auto}
.partner-badge .pb-text{font-size:.76rem;color:var(--ink-400);line-height:1.3}
.partner-badge b{color:var(--ink-900);font-weight:600;font-size:.92rem;display:block;letter-spacing:.005em}

/* Specbox */
.specbox{background:#fff;border:1px solid var(--line-200);border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-sm)}
.specbox h3{color:var(--ink-900);font-size:.78rem;margin-bottom:18px;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.specbox .sb-row{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--line-100)}
.specbox .sb-row:last-child{border:0}
.specbox .sb-ic{width:46px;height:46px;border-radius:13px;background:var(--sw-100);display:grid;place-items:center;flex:none}
.specbox .sb-ic svg{width:22px;height:22px;color:var(--sw-700)}
.specbox .sb-row .sb-l{font-size:.72rem;color:var(--ink-400);display:block;text-transform:uppercase;letter-spacing:.10em;font-weight:600}
.specbox .sb-row .sb-v{color:var(--ink-900);font-family:var(--ff);font-weight:600;font-size:.98rem;margin-top:3px;display:block}

.detail-body{display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:start}
.detail-main h2{font-size:1.65rem;margin:0 0 18px;letter-spacing:-0.028em}
.detail-main h3{font-size:1.18rem;margin:32px 0 12px;letter-spacing:-0.018em}
.detail-main p{color:var(--ink-500);margin-bottom:14px;line-height:1.75;font-size:.96rem}
.detail-block{padding-bottom:44px;margin-bottom:44px;border-bottom:1px solid var(--line-200)}
.detail-block:last-child{border:0;margin-bottom:0;padding-bottom:0}
.bio-box{background:linear-gradient(135deg,var(--sw-50),var(--sw-100));border:1px solid var(--sw-200);border-radius:var(--r);padding:24px 28px;font-size:.96rem;color:var(--ink-700);line-height:1.7;font-weight:500}

/* Packages */
.opt-card{
  border:1px solid var(--line-200);border-radius:var(--r);padding:26px 28px;
  margin-bottom:14px;background:#fff;
  transition:border-color .25s var(--ease), box-shadow .3s var(--ease), transform .25s var(--ease);
  position:relative;
}
.opt-card:hover{border-color:var(--sw-400);box-shadow:var(--shadow-sm);transform:translateX(4px)}
.opt-card.featured{border-color:var(--sw-600);background:linear-gradient(180deg,#fff,var(--sw-50))}
.opt-card.featured::before{
  content:"★ Most Popular";position:absolute;top:-12px;right:24px;
  font-family:var(--ff);font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:var(--sw-600);padding:5px 12px;border-radius:var(--r-pill);
}
.opt-card .oc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.opt-card h4{font-size:1.12rem;letter-spacing:-0.018em;color:var(--ink-900)}
.opt-badge{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.10em;color:var(--sw-800);background:var(--sw-100);padding:5px 11px;border-radius:6px;white-space:nowrap;border:1px solid var(--sw-200)}
.opt-card .oc-bio{font-size:.88rem;color:var(--ink-700);background:var(--sw-50);padding:14px 16px;border-radius:10px;margin-bottom:12px;line-height:1.6;border-left:3px solid var(--sw-600);font-weight:500}
.opt-card .oc-note{font-size:.9rem;color:var(--ink-400);line-height:1.65}

/* Check list */
.check-list li{display:flex;gap:13px;padding:11px 0;font-size:.94rem;color:var(--ink-700);line-height:1.65}
.check-list li svg{width:20px;height:20px;color:var(--sw-600);flex:none;margin-top:3px}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 18px}
.tag-list .tag{display:inline-block;background:#fff;color:var(--ink-700);border:1px solid var(--line-200);padding:7px 14px;border-radius:var(--r-pill);font-size:.82rem;font-weight:500;transition:background .2s, border-color .2s}
.tag-list .tag:hover{background:var(--sw-100);border-color:var(--sw-400);color:var(--sw-800)}

/* Sample reports */
.report-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.report-card{border:1px solid var(--line-200);border-radius:var(--r-sm);overflow:hidden;background:#fff;transition:transform .3s var(--ease), box-shadow .3s var(--ease);cursor:zoom-in;position:relative;padding:0;text-align:left;width:100%;font:inherit;color:inherit;display:block}
.report-card:focus-visible{outline:3px solid var(--sw-400);outline-offset:2px}
.report-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm);border-color:var(--sw-300)}
.report-card::after{
  content:"Click to enlarge";
  position:absolute;bottom:62px;right:10px;background:var(--ink-900);color:#fff;
  font-size:.7rem;padding:5px 11px 5px 26px;border-radius:var(--r-pill);
  opacity:0;transition:opacity .25s var(--ease);font-weight:600;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.4' stroke-linecap='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:8px center;background-size:12px 12px;
}
.report-card:hover::after{opacity:.9}
.report-card img{width:100%;height:280px;object-fit:cover;object-position:top;background:var(--sw-50)}
.report-card .rc-cap{padding:14px 16px;font-family:var(--ff);font-weight:600;font-size:.84rem;color:var(--ink-900);letter-spacing:-0.01em}
.report-card .rc-badge{
  position:absolute;top:10px;left:10px;
  background:rgba(255,255,255,.96);color:var(--ink-900);
  font-size:.72rem;font-weight:700;letter-spacing:.02em;
  padding:5px 11px;border-radius:var(--r-pill);
  box-shadow:var(--shadow-sm);backdrop-filter:blur(4px);
  display:flex;align-items:center;gap:5px;
}
.report-card .rc-badge::before{
  content:"";display:inline-block;width:11px;height:13px;
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232A2A2A' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 3H7a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V8l-5-5Z'/%3E%3Cpath d='M14 3v5h5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-size:contain;background-position:center;
}

/* Aside */
.detail-aside{position:sticky;top:var(--sticky-offset);display:flex;flex-direction:column;gap:18px}
.aside-card{background:#fff;border:1px solid var(--line-200);border-radius:var(--r);padding:28px}
.aside-card h3{font-size:1.1rem;margin-bottom:10px;letter-spacing:-0.018em}
.aside-card p{font-size:.9rem;color:var(--ink-400);margin-bottom:18px;line-height:1.65}
.aside-card.accent{
  background:var(--brand-grad);
  color:rgba(255,255,255,.92);border-color:var(--sw-700);
}
.aside-card.accent h3{color:#fff}
.aside-card.accent p{color:rgba(255,255,255,.85)}
.aside-card.accent .btn-teal{background:#fff;color:var(--sw-700);box-shadow:none}
.aside-card.accent .btn-teal:hover{background:var(--sw-50);color:var(--sw-800)}

/* Lightbox — multi-page sample report viewer */
.lb{position:fixed;inset:0;background:rgba(12,42,34,.94);display:none;align-items:center;justify-content:center;padding:30px;z-index:300;backdrop-filter:blur(8px)}
.lb.show{display:flex;animation:fadeIn .25s var(--ease)}
.lb .lb-img{
  max-width:min(90vw,1100px);max-height:88vh;
  border-radius:14px;box-shadow:var(--shadow-lg);background:#fff;
  cursor:zoom-in;
  transition:transform .35s var(--ease);
  transform-origin:center center;
  animation:lbImgIn .35s var(--ease);
}
.lb.zoomed .lb-img{cursor:zoom-out;transform:scale(1.7);max-height:none;max-width:none}
@keyframes lbImgIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.lb-btn{
  position:absolute;width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,.96);color:var(--ink-900);border:0;padding:0;
  display:grid;place-items:center;cursor:pointer;
  transition:background .2s, transform .25s var(--ease), box-shadow .25s;
  box-shadow:var(--shadow-sm);user-select:none;
}
.lb-btn svg{width:22px;height:22px;display:block}
.lb-btn:hover{background:#fff;box-shadow:var(--shadow)}
.lb-prev{left:32px;top:50%;transform:translateY(-50%)}
.lb-prev:hover{transform:translateY(-50%) translateX(-2px)}
.lb-next{right:32px;top:50%;transform:translateY(-50%)}
.lb-next:hover{transform:translateY(-50%) translateX(2px)}
.lb-close{top:28px;right:32px;width:46px;height:46px}
.lb-close svg{width:18px;height:18px}
.lb-counter{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:12px;
  color:#fff;font-weight:600;font-size:.88rem;letter-spacing:.06em;
  background:rgba(0,0,0,.45);padding:9px 18px;border-radius:var(--r-pill);
  font-family:var(--ff);backdrop-filter:blur(6px);
}
.lb-counter .lb-action{
  display:inline-flex;align-items:center;gap:6px;
  color:#fff;background:transparent;border:0;
  font:inherit;cursor:pointer;padding:4px 8px;border-radius:8px;
  transition:background .2s;
}
.lb-counter .lb-action:hover{background:rgba(255,255,255,.15)}
.lb-counter .lb-action svg{width:14px;height:14px}
.lb-counter .lb-sep{opacity:.4}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@media(prefers-reduced-motion:reduce){
  .lb.show,.lb .lb-img{animation:none}
  .lb .lb-img{transition:none}
}
@media(max-width:680px){
  .lb{padding:14px}
  .lb-prev{left:10px}
  .lb-next{right:10px}
  .lb-close{top:14px;right:14px}
  .lb-btn{width:44px;height:44px}
  .lb-btn svg{width:18px;height:18px}
  .lb-close svg{width:16px;height:16px}
  .lb-counter{bottom:18px;font-size:.82rem;padding:7px 14px}
}

/* ---------- Long-form prose — optimal reading width ----------
   Apply to article-like containers so paragraphs stay within
   45-75ch reading range. Headings can break out for visual rhythm. */
.prose{max-width:var(--prose-max);margin-left:auto;margin-right:auto}
.prose>p,.prose>ul,.prose>ol,.prose>blockquote{max-width:var(--prose-max)}
.prose h2,.prose h3{margin-top:1.5em}
.prose p+p{margin-top:.85em}
.prose blockquote{
  border-left:3px solid var(--sw-400);
  padding:6px 16px;margin:18px 0;
  color:var(--ink-700);font-style:italic;
}
.prose code{
  background:var(--sw-50);border:1px solid var(--sw-100);
  padding:1px 6px;border-radius:5px;font-size:.92em;
}
.prose hr{border:0;border-top:1px solid var(--line-200);margin:28px 0}

/* ---------- Misc ---------- */
.notice{background:linear-gradient(135deg,var(--sw-50),var(--sw-100));border:1px solid var(--sw-200);border-radius:var(--r);padding:26px;color:var(--ink-700);font-size:.96rem;line-height:1.65}
.notice h3{margin-bottom:10px;font-size:1.06rem;letter-spacing:-0.015em}
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.fade-up.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ----------
   Container width handled via fluid clamp at :root level (no breakpoint jumps).
   Section padding still uses media queries for vertical rhythm. */
@media(max-width:1100px){
  .section{padding:64px 0}
  .head-block{margin-bottom:40px}
}
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .detail-hero-grid{grid-template-columns:1fr;gap:38px}
  .detail-body{grid-template-columns:1fr;gap:48px}
  .detail-aside{position:static;flex-direction:row;flex-wrap:wrap}
  .detail-aside .aside-card{flex:1;min-width:260px}
  .stat-strip{grid-template-columns:repeat(3,1fr)}
  .partner-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:860px){
  .burger{display:flex}
  .nav-links{
    position:fixed;inset:78px 0 auto 0;background:#fff;flex-direction:column;
    align-items:stretch;gap:2px;padding:20px 24px 32px;border-bottom:1px solid var(--line-200);
    box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .32s var(--ease);
    max-height:calc(100vh - 78px);overflow:auto;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links>li>a,.nav-links>li>.nav-trigger{padding:14px 16px;font-size:1rem;width:100%;border-radius:10px}
  .dropdown{position:static;transform:none;width:100%;opacity:1;visibility:visible;box-shadow:none;border:0;background:transparent;grid-template-columns:1fr;padding:6px 0 6px 12px;display:none}
  .has-dropdown.open .dropdown{display:grid}
  .has-dropdown:hover .dropdown{transform:none}
  .nav-cta .btn:not(.nav-call){display:none}
  .g-2,.g-3,.g-4,.contact-grid{grid-template-columns:1fr}
  .hero h1{font-size:clamp(2.2rem,8vw,3rem)}
  .hero,.page-hero,.guide-hero,.detail-hero{padding:84px 0 88px}
  .page-hero h1{font-size:clamp(2.2rem,8vw,3rem)}
}
@media(max-width:680px){
  .section{padding:68px 0}
  .container{padding:0 20px}
  .stat-strip{grid-template-columns:repeat(2,1fr)}
  .stat .sv{font-size:1.8rem}
  .partner-grid{grid-template-columns:repeat(2,1fr);gap:22px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .cta-band{padding:48px 28px}
  .form-row{grid-template-columns:1fr}
  .form-card{padding:30px}
  .hero p.lead{font-size:1.04rem}
  .hv-card:nth-child(2){margin-left:0}
  .footer-bottom{flex-direction:column;text-align:center}
  .opt-card .oc-head{flex-direction:column}
  .opt-card{padding:22px 24px}
  .float-contact{right:14px;bottom:14px}
  .float-contact a{width:50px;height:50px}
  /* Prevent floating LINE/phone buttons from overlapping sticky CTAs */
  body{padding-bottom:80px}
  .site-footer{padding-bottom:90px}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
  .fade-up{opacity:1;transform:none}
  .ph-loading:empty,.spinner,.hero-tag .dot{animation:none!important}
  .lb.show,.lb .lb-img,.form-success{animation:none!important}
}

/* ============================================================
   PRINT STYLES — lab tests + interpretation guides
   Optimized for clinical print/PDF export. Strips chrome,
   keeps content readable, ensures tables don't break mid-row.
   ============================================================ */
@media print{
  *{background:transparent!important;color:#000!important;box-shadow:none!important;text-shadow:none!important}
  html,body{background:#fff!important;font-size:11pt;line-height:1.45}
  a,a:visited{color:#000;text-decoration:underline}
  a[href^="http"]::after{content:" (" attr(href) ")";font-size:.85em;color:#444}
  a[href^="#"]::after,a[href^="mailto"]::after,a[href^="tel"]::after{content:""}
  /* Hide chrome — NOT .contact-section (whole contact page lives inside it).
     Hide only the .form-card and the floating helpers, keep contact info. */
  .site-header,.site-footer,.float-contact,.skip-link,
  .nav-cta,.burger,.lb,.guide-sidebar,.detail-aside,
  .guide-sex-tabs,.lab-nav,.hero-actions,
  .form-card,.faq-q .fi,
  .cc-link,.tc-foot,.cta-band,.btn,.gh-cta,.dh-cta{display:none!important}
  /* Force FAQ answers open in print */
  .faq-a{max-height:none!important;opacity:1!important;overflow:visible!important}
  /* Force collapsed download cards open in print (both main-area + aside variants) */
  .dl-card.is-collapsed .dl-list,.dl-list,
  .aside-dl.is-collapsed .aside-dl-list,.aside-dl-list{
    max-height:none!important;opacity:1!important;visibility:visible!important;
    overflow:visible!important;margin-top:12pt!important;padding:0!important;
  }
  .dl-card-chev,.aside-dl-chev{display:none!important}
  /* Hide decorative blobs and gradients */
  .hero::before,.hero::after,
  .page-hero::before,.page-hero::after,
  .guide-hero::before,.guide-hero::after,
  .detail-hero::before,.detail-hero::after{display:none!important}
  /* Layout collapse */
  .hero-grid,.detail-hero-grid,.detail-body,.guide-layout{display:block!important}
  .hero,.page-hero,.guide-hero,.detail-hero{padding:0 0 12pt!important;min-height:0!important;border-bottom:1.5pt solid #000}
  .section{padding:12pt 0!important}
  .container{max-width:none!important;padding:0!important}
  /* Typography */
  h1{font-size:22pt;page-break-after:avoid;margin-bottom:6pt}
  h2{font-size:16pt;page-break-after:avoid;margin:14pt 0 4pt;border-bottom:1pt solid #999;padding-bottom:3pt}
  h3{font-size:13pt;page-break-after:avoid;margin:10pt 0 3pt}
  p,li{font-size:11pt;orphans:3;widows:3}
  /* Tables must not break */
  table{page-break-inside:auto}
  tr{page-break-inside:avoid;page-break-after:auto}
  thead{display:table-header-group}
  tfoot{display:table-footer-group}
  /* Show URLs for inline links inside articles only */
  .guide-main,.detail-main{font-size:11pt}
  /* Page breaks */
  .detail-block,.g-accordion-item{page-break-inside:avoid}
  .guide-toc{page-break-after:always}
  /* Image scaling */
  img{max-width:100%!important;page-break-inside:avoid}
}

/* ============================================================
   Visually-hidden but readable by screen readers + SEO crawlers.
   Used for static H1 fallbacks in JS-rendered pages. */
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ============================================================
   LEGAL DOCS (privacy.html, terms.html)
   ============================================================ */
.legal-doc{max-width:780px;margin:0 auto;line-height:1.72;color:var(--ink-800);font-size:1rem}
.legal-doc h2{font-size:1.18rem;font-weight:700;letter-spacing:-.015em;color:var(--ink-900);margin:36px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line-200)}
.legal-doc h2:first-of-type{margin-top:8px}
.legal-doc p,.legal-doc ul{margin:0 0 14px}
.legal-doc ul{padding-left:22px}
.legal-doc li{margin-bottom:6px}
.legal-doc a{color:var(--sw-700);text-decoration:underline;text-underline-offset:2px}
.legal-doc a:hover{color:var(--sw-800)}
.legal-meta{background:var(--sw-50);border:1px solid var(--sw-100);border-radius:10px;padding:10px 14px;font-size:.88rem;color:var(--ink-700);margin-bottom:24px}
.legal-contact{background:var(--sw-50);border-left:3px solid var(--sw-600);padding:14px 18px;border-radius:0 8px 8px 0;margin:14px 0;font-size:.94rem;line-height:1.7}
.legal-note{font-size:.88rem;color:var(--ink-500);font-style:italic;margin-top:16px}
.lang-toggle{display:inline-flex;gap:4px;padding:4px;background:var(--sw-50);border:1px solid var(--sw-100);border-radius:999px;margin-bottom:32px}
.lang-btn{padding:8px 18px;border:0;background:transparent;font-family:inherit;font-weight:600;font-size:.86rem;color:var(--ink-700);border-radius:999px;cursor:pointer;transition:background .2s var(--ease), color .2s var(--ease)}
.lang-btn.is-active{background:#fff;color:var(--sw-800);box-shadow:0 1px 2px rgba(0,0,0,.06)}
.lang-btn:hover:not(.is-active){color:var(--sw-700)}

/* ============================================================
   MEDICAL DISCLAIMER block — shown under every lab page hero
   ============================================================ */
.medical-disclaimer{
  background:#FFF8EB;border:1px solid #F4D58A;border-left:4px solid #C99B30;
  border-radius:10px;padding:14px 18px;margin:32px 0 0;
  font-size:.92rem;line-height:1.6;color:#5C4310;
  display:flex;gap:12px;align-items:flex-start;
}
.medical-disclaimer .md-ic{flex:0 0 22px;color:#C99B30;margin-top:1px}
.medical-disclaimer .md-ic svg{width:22px;height:22px}
.medical-disclaimer strong{color:#3C2C0A;font-weight:700}
.medical-disclaimer a{color:#7B5F18;text-decoration:underline;text-underline-offset:2px}
@media(max-width:680px){
  .medical-disclaimer{padding:12px 14px;font-size:.86rem}
}

/* ============================================================
   COOKIE / PDPA banner — shown once until dismissed
   ============================================================ */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:9000;
  max-width:880px;margin:0 auto;
  background:#fff;border:1px solid var(--line-200);border-radius:14px;
  box-shadow:0 16px 48px -8px rgba(15,40,21,.20), 0 2px 6px rgba(15,40,21,.08);
  padding:18px 22px;
  display:flex;gap:18px;align-items:center;
  transform:translateY(20px);opacity:0;
  transition:transform .35s var(--ease), opacity .35s var(--ease);
}
.cookie-banner.is-shown{transform:translateY(0);opacity:1}
.cookie-banner .cb-text{flex:1;font-size:.92rem;line-height:1.55;color:var(--ink-800)}
.cookie-banner .cb-text strong{color:var(--ink-900);font-weight:700}
.cookie-banner .cb-text a{color:var(--sw-700);text-decoration:underline;text-underline-offset:2px}
.cookie-banner .cb-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-banner .cb-btn{
  padding:10px 18px;border-radius:999px;border:0;
  font-family:inherit;font-weight:600;font-size:.88rem;
  cursor:pointer;transition:background .2s var(--ease), transform .2s var(--ease);
}
.cookie-banner .cb-btn-primary{background:var(--brand-grad);color:#fff}
.cookie-banner .cb-btn-primary:hover{transform:translateY(-1px);filter:brightness(1.05)}
.cookie-banner .cb-btn-ghost{background:transparent;color:var(--ink-700);border:1px solid var(--line-200)}
.cookie-banner .cb-btn-ghost:hover{background:var(--sw-50);color:var(--sw-800)}
@media(max-width:680px){
  .cookie-banner{flex-direction:column;align-items:stretch;padding:16px 18px;left:8px;right:8px;bottom:8px}
  .cookie-banner .cb-actions{justify-content:flex-end}
}

/* ============================================================
   PDPA consent checkbox on contact form
   ============================================================ */
.form-consent{
  display:flex;gap:10px;align-items:flex-start;
  padding:14px 16px;background:var(--sw-50);border:1px solid var(--sw-100);
  border-radius:10px;margin:0 0 18px;
}
.form-consent input[type="checkbox"]{
  flex:0 0 18px;width:18px;height:18px;margin-top:2px;
  accent-color:var(--sw-600);cursor:pointer;
}
.form-consent label{font-size:.88rem;line-height:1.55;color:var(--ink-800);cursor:pointer;margin:0}
.form-consent label a{color:var(--sw-700);text-decoration:underline;text-underline-offset:2px}
.form-consent.is-error{border-color:var(--danger);background:#fff5f5}

