/* ============================================================
   ZainSEO — zainulabidin.ca
   Typography: Garet (brand font) — Heavy for display, Book for body
   Palette: deep brand blue (panels) · orange (CTAs) · cream (results)
   ============================================================ */

/* ---- Fonts (self-hosted) ----
   Rubik (open source, OFL) does all headings, numbers and UI chrome —
   weights capped at 500/600 (nothing heavier on the site). Garet, the brand
   font, is reserved for reading text (body paragraphs) at Book 400. */
@font-face{
  font-family:"Garet";
  src:url("fonts/Garet-Book.woff2") format("woff2"),
      url("fonts/Garet-Book.woff") format("woff");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Rubik";
  src:url("fonts/Rubik-500.woff2") format("woff2");
  font-weight:500;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Rubik";
  src:url("fonts/Rubik-600.woff2") format("woff2");
  font-weight:600;font-style:normal;font-display:swap;
}

/* ---- Tokens ---- */
:root{
  --ink:#13283D;           /* deep navy — headings/text, warmer than pure black */
  --muted:#5A6675;
  --orange:#EF4E28;        /* brand orange: accents, badges, highlights */
  --orange-deep:#D23E1B;   /* CTA backgrounds + small orange text (AA on white) */
  --blue:#57A2D8;          /* brand blue: bright accent, CTA band, glow */
  --blue-deep:#1F6FA8;     /* accessible blue for text links */
  --navy:#0B2F52;          /* deep brand blue — feature panels, footer, heroes */
  --navy-2:#0F3D69;        /* lighter navy for gradients */
  --cream:#F6F6DD;         /* result cards — matches brand case-study graphics */
  --soft:#EEF4FA;          /* tinted-blue section background */
  --line:#E2E8F0;
  --dark:var(--navy);      /* all "dark" surfaces are now deep brand blue */
  --green:#1E8E3E;--green-bg:#E9F6EC;
  --amber:#8A5A00;--amber-bg:#FFF4DC;
  --badge-blue:#155E96;--badge-blue-bg:#E8F1F9;

  --font-display:"Rubik","Garet",system-ui,-apple-system,sans-serif;
  --font-ui:"Rubik","Garet",system-ui,-apple-system,sans-serif;
  --font-body:"Garet",system-ui,-apple-system,"Segoe UI",sans-serif;

  --r-sm:10px;--r-md:16px;--r-lg:24px;--r-pill:999px;
  --shadow-sm:0 1px 2px rgba(11,47,82,.06),0 4px 14px rgba(11,47,82,.06);
  --shadow-md:0 8px 18px rgba(11,47,82,.10),0 20px 44px rgba(11,47,82,.12);

  --ease-out:cubic-bezier(.22,1,.36,1);
}

/* ---- Base ---- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-ui);
  font-size:1.0625rem;line-height:1.7;
  background:#fff;color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-synthesis:none; /* never fake-bold; only real font weights render */
}
/* Reading text stays in the brand font, Garet */
p,.lead,blockquote,.system-item span{font-family:var(--font-body)}
strong,b{font-weight:600}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.container{width:min(1140px,100% - 40px);margin-inline:auto}

:focus-visible{outline:3px solid var(--blue-deep);outline-offset:3px;border-radius:4px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 18px;border-radius:0 0 var(--r-sm) 0;z-index:100}
.skip-link:focus{left:0}

h1,h2,h3,p{margin-top:0}
h1,h2,h3{text-wrap:balance}
h1{
  font-family:var(--font-display);
  font-size:clamp(2.35rem,4.4vw,3.85rem);
  font-weight:500;line-height:1.08;letter-spacing:-.022em;
  margin:18px 0 22px;
}
/* Highlighted hero word — orange brush underline */
.hl{position:relative;white-space:nowrap;color:var(--orange-deep)}
.hl::after{
  content:"";position:absolute;left:-2px;right:-2px;bottom:.04em;height:.34em;
  background:rgba(239,78,40,.18);border-radius:3px;z-index:-1;
}
h2{font-family:var(--font-display);font-size:clamp(1.75rem,3vw,2.35rem);font-weight:600;line-height:1.12;letter-spacing:-.02em;margin-bottom:14px}
h3{font-family:var(--font-display);font-size:1.25rem;font-weight:600;line-height:1.3;letter-spacing:-.012em;margin-bottom:10px}
.lead{font-size:clamp(1.0625rem,1.6vw,1.1875rem);line-height:1.75;color:var(--muted);max-width:62ch}
p{text-wrap:pretty}

/* Kicker — the brand "EY" eyebrow. Used on page heroes only. */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.8125rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--orange-deep);margin-bottom:10px;
}
.kicker::before{content:"";width:22px;height:3px;background:var(--orange);border-radius:2px}
.page-hero .kicker,.dark-section .kicker{color:#FF9D80}
.page-hero .kicker::before,.dark-section .kicker::before{background:var(--orange)}

/* ---- Header ---- */
header.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.header-inner{min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand-logo{display:block;width:178px;height:auto;border-radius:var(--r-sm)}
nav.primary-nav{display:flex;gap:2px;align-items:center}
.nav-link{
  position:relative;padding:10px 14px;font-weight:600;font-size:.9375rem;color:var(--muted);
  border-radius:var(--r-pill);transition:color .18s var(--ease-out);
}
.nav-link::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2.5px;
  background:var(--orange);border-radius:2px;
  transform:scaleX(0);transform-origin:left;transition:transform .22s var(--ease-out);
}
.nav-link:hover{color:var(--ink)}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}
.nav-link.active{color:var(--ink)}
.menu-btn{display:none;border:1px solid var(--line);background:#fff;border-radius:var(--r-sm);padding:9px 12px;font-size:1.1rem;line-height:1}
.mobile-nav{display:none}

/* ---- Buttons ---- */
.primary-btn,.secondary-btn,.ghost-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:0;border-radius:var(--r-pill);padding:13px 24px;
  font-family:var(--font-ui);font-weight:600;font-size:1rem;line-height:1.2;
  transition:transform .18s var(--ease-out),box-shadow .18s var(--ease-out),background .18s var(--ease-out);
}
.primary-btn{background:var(--orange-deep);color:#fff;box-shadow:0 8px 20px rgba(210,62,27,.25)}
.primary-btn:hover{background:#BE3614;transform:translateY(-1px);box-shadow:0 10px 24px rgba(210,62,27,.3)}
.secondary-btn{background:#fff;color:var(--ink);border:1.5px solid #C9CED6}
.secondary-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.header-cta{padding:11px 20px;font-size:.9375rem}

/* ---- Sections ---- */
section{padding:clamp(64px,9vw,104px) 0}
.section-head{max-width:680px;margin-bottom:clamp(36px,5vw,56px)}
.section-head.center{text-align:center;margin-inline:auto}
.section-copy{font-size:1.0625rem;line-height:1.75;color:var(--muted)}
.soft-section{background:var(--soft)}
.dark-section{
  color:#fff;
  background:
    radial-gradient(760px 380px at 88% -10%,rgba(87,162,216,.30),transparent 56%),
    linear-gradient(160deg,var(--navy-2) 0%,var(--navy) 70%);
}
.dark-section h2{color:#fff}
.dark-section .section-copy{color:rgba(255,255,255,.72)}

/* ---- Hero (home) ---- */
.hero{
  padding:clamp(64px,8vw,96px) 0;
  background:
    radial-gradient(820px 460px at 90% -8%,rgba(87,162,216,.30),transparent 58%),
    radial-gradient(620px 380px at -5% 8%,rgba(239,78,40,.08),transparent 52%),
    linear-gradient(180deg,#fff 0%,#EBF3FB 100%);
  overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,64px);align-items:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  padding:8px 16px;border:1px solid var(--line);border-radius:var(--r-pill);
  background:#fff;font-size:.875rem;font-weight:600;color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--orange)}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}

.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:40px}
.stat{display:flex;flex-direction:column;justify-content:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:16px 20px;box-shadow:var(--shadow-sm)}
.stat{transition:border-color .18s var(--ease-out),transform .18s var(--ease-out)}
.stat:hover{border-color:var(--blue);transform:translateY(-2px)}
.stat strong{display:block;font-family:var(--font-display);font-weight:600;font-size:1.9rem;line-height:1.05;letter-spacing:-.02em;margin-bottom:4px;color:var(--ink)}
.stat:hover strong{color:var(--orange-deep)}
.stat span{font-size:.8125rem;color:var(--muted);font-weight:600;line-height:1.4}

/* hero system card */
.system-card{
  position:relative;color:#fff;border-radius:var(--r-lg);
  padding:clamp(24px,3vw,34px);box-shadow:0 24px 60px rgba(11,47,82,.28);
  background:
    radial-gradient(420px 220px at 100% 0%,rgba(87,162,216,.45),transparent 60%),
    linear-gradient(155deg,var(--navy-2) 0%,var(--navy) 70%);
  border:1px solid rgba(255,255,255,.08);
}
.system-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.system-head .sys-label{color:var(--blue);font-weight:600;font-size:.875rem;letter-spacing:.06em;text-transform:uppercase}
.system-head h3{margin:8px 0 0;font-size:clamp(1.45rem,2.2vw,1.8rem);color:#fff}
.system-arrow{font-size:1.9rem;color:var(--orange);line-height:1}
.system-list{display:grid;gap:10px;margin-top:24px}
.system-item{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);border-radius:var(--r-md);padding:14px 16px}
.system-item .dot{width:10px;height:10px;border-radius:50%;margin-top:8px;background:var(--blue)}
.system-item:nth-child(2) .dot{background:var(--orange)}
.system-item:nth-child(3) .dot{background:#7BC47F}
.system-item:nth-child(4) .dot{background:#F2C14E}
.system-item strong{display:block;margin-bottom:2px}
.system-item span{color:rgba(255,255,255,.72);font-size:.9375rem;line-height:1.55}

/* ---- Result cards (the brand's signature cream artifact) ---- */
.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px}
.result-grid--two{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.result-grid--two{grid-template-columns:1fr}}
.result-card{
  background:var(--cream);border:1px solid #DEDEC2;border-radius:var(--r-lg);
  padding:clamp(24px,3vw,32px);
  transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out);
}
.result-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.result-card .label{font-size:.75rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;text-align:center;color:var(--orange-deep)}
.result-card .client{text-align:center;font-size:1.25rem;font-weight:600;margin-top:10px;line-height:1.3}
.metric{
  text-align:center;font-family:var(--font-display);font-weight:600;
  font-size:clamp(3.6rem,6.4vw,5.2rem);line-height:.95;letter-spacing:-.03em;
  margin-top:20px;color:var(--ink);
}
.metric-label{text-align:center;font-family:var(--font-display);font-size:clamp(1.3rem,2.4vw,1.7rem);font-weight:600;letter-spacing:-.02em;line-height:1.12;margin-top:8px}
.result-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;border-top:1px solid #CFCFAE;margin-top:22px;padding-top:22px}
.result-stats div{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  background:rgba(255,255,255,.6);border:1px solid #CFCFAE;border-radius:var(--r-sm);
  padding:12px 6px;text-align:center;min-height:62px;
}
.result-stats b{font-family:var(--font-display);font-weight:600;font-size:1.15rem;line-height:1;letter-spacing:-.01em;color:var(--ink)}
.result-stats span{font-size:.7rem;font-weight:600;color:#454A50;line-height:1.2;text-transform:uppercase;letter-spacing:.03em}
.result-note{color:#41464D;line-height:1.65;font-size:.9375rem;margin:16px 0 0}

/* ---- Services (dark index list) ---- */
.service-list{border-top:1px solid rgba(255,255,255,.14)}
.service-row{
  display:grid;grid-template-columns:1fr auto;gap:18px;align-items:baseline;
  padding:20px 6px;border-bottom:1px solid rgba(255,255,255,.14);
  transition:background .18s var(--ease-out),padding-left .18s var(--ease-out);
}
.service-row:hover{background:rgba(255,255,255,.04);padding-left:14px}
.service-row .service-name{font-weight:600;font-size:clamp(1.1rem,1.8vw,1.3rem);color:#fff}
.service-row .service-desc{color:rgba(255,255,255,.6);font-size:.9375rem;text-align:right}
.service-cols{columns:2;column-gap:48px}
.service-cols .service-row{break-inside:avoid}

/* ---- Page hero (inner pages) ---- */
.page-hero{
  padding:clamp(56px,7vw,84px) 0;
  background:
    radial-gradient(760px 420px at 92% -25%,rgba(87,162,216,.42),transparent 58%),
    radial-gradient(560px 320px at 0% 120%,rgba(239,78,40,.14),transparent 55%),
    linear-gradient(150deg,var(--navy-2) 0%,var(--navy) 72%);
  color:#fff;
}
.page-hero h1{color:#fff;font-size:clamp(2.25rem,4.4vw,3.5rem);margin-bottom:16px}
.page-hero .lead{color:rgba(255,255,255,.75)}

/* ---- About ---- */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:start}
.dark-card{
  color:#fff;border-radius:var(--r-lg);padding:clamp(24px,3vw,32px);
  background:
    radial-gradient(380px 200px at 100% 0%,rgba(87,162,216,.38),transparent 62%),
    linear-gradient(155deg,var(--navy-2) 0%,var(--navy) 72%);
  border:1px solid rgba(255,255,255,.08);
}
.dark-card h3{color:#fff}
.dark-card p{color:rgba(255,255,255,.78);line-height:1.8}
.profile-photo-wrap{display:flex;justify-content:center;margin-bottom:22px}
.profile-photo-frame{
  width:208px;height:208px;padding:7px;border-radius:var(--r-lg);
  background:linear-gradient(150deg,var(--blue) 0%,rgba(87,162,216,.25) 60%,rgba(239,78,40,.5) 100%);
}
.profile-photo{width:100%;height:100%;object-fit:cover;border-radius:calc(var(--r-lg) - 7px);display:block}
.about-contact-panel{margin-top:26px;border-top:1px solid rgba(255,255,255,.14);padding-top:22px}
.about-contact-title{font-weight:600;font-size:.875rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.about-contact-grid{display:grid;gap:10px}
.about-contact-item{display:flex;align-items:center;gap:12px;color:#fff;font-weight:600;padding:4px 0;text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:5px;transition:text-decoration-color .18s}
.about-contact-item:hover{text-decoration-color:var(--orange)}
.about-contact-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-sm);background:rgba(255,255,255,.1);font-size:.9rem;font-style:normal}

.white-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,3vw,30px)}
.specialties{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pill-box{display:flex;align-items:center;gap:10px;background:var(--soft);border-radius:var(--r-sm);padding:13px 15px;font-weight:600;font-size:.9375rem}
.pill-box::before{content:"✓";color:var(--green);font-weight:600}
.education-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.education-item{border:1px solid var(--line);border-radius:var(--r-sm);padding:14px 16px;font-weight:600;font-size:.9375rem;line-height:1.5}
.tools{display:flex;flex-wrap:wrap;gap:9px}
.tool{border:1px solid var(--line);background:var(--soft);border-radius:var(--r-pill);padding:8px 14px;font-size:.875rem;font-weight:600}

/* ---- Case studies ---- */
.filters{display:flex;gap:9px;flex-wrap:wrap;margin-top:26px}
.filter-btn{
  border:1.5px solid rgba(255,255,255,.3);border-radius:var(--r-pill);
  background:transparent;color:#fff;padding:9px 18px;font-weight:600;font-size:.9375rem;
  transition:background .18s,color .18s,border-color .18s;
}
.filter-btn:hover{border-color:#fff}
.filter-btn.active{background:#fff;color:var(--ink);border-color:#fff}
.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(310px,1fr));gap:18px;align-items:start}
.case-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:24px;
  display:flex;flex-direction:column;
  transition:transform .2s var(--ease-out),box-shadow .2s var(--ease-out);
}
.case-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.case-top{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.case-category{font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.case-card h3{font-size:1.2rem;margin-bottom:0}
.badge{display:inline-flex;border-radius:var(--r-pill);padding:6px 12px;font-size:.75rem;font-weight:600;white-space:nowrap}
.badge.ranked{background:var(--green-bg);color:var(--green)}
.badge.completed{background:var(--badge-blue-bg);color:var(--badge-blue)}
.badge.progress{background:var(--amber-bg);color:var(--amber)}
.case-service{background:var(--soft);border-radius:var(--r-sm);padding:12px 14px;font-weight:600;font-size:.9375rem;margin:16px 0}
.case-card p{color:var(--muted);line-height:1.65;font-size:.9688rem}
.case-card ul{padding:0;margin:16px 0 0;list-style:none}
.case-card li{position:relative;padding-left:24px;margin:8px 0;color:#33383F;font-size:.9063rem;font-weight:600;line-height:1.45}
.case-card li::before{content:"✓";position:absolute;left:0;font-weight:600;color:var(--green)}

/* ---- Reviews ---- */
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:20px;align-items:start}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:clamp(22px,3vw,28px);display:flex;flex-direction:column}
.stars{letter-spacing:4px;font-size:1.05rem;margin-bottom:16px;color:#E8A100}
.review-card blockquote{margin:0;color:#2C313A;line-height:1.8;font-size:1.0313rem}
.review-meta{margin-top:20px;padding-top:16px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:4px 12px}
.review-name{font-weight:600;font-size:1.0625rem}
.review-business{color:var(--muted);font-weight:600;font-size:.9375rem}
.review-business::before{content:"·";margin-right:12px;color:#C3C8CF}
.review-category{margin-left:auto;border-radius:var(--r-pill);background:var(--soft);padding:6px 12px;font-size:.75rem;font-weight:600;color:var(--muted)}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:24px;align-items:start}
.calendly-box{background:#fff;border-radius:var(--r-md);margin-top:22px;overflow:hidden}
form.inquiry{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(24px,3vw,32px)}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:grid;gap:7px;font-size:.9063rem;font-weight:600;color:#33383F}
input,select,textarea{
  width:100%;border:1.5px solid #D4D8DE;background:#fff;border-radius:var(--r-sm);
  padding:12px 14px;outline:none;color:var(--ink);
  transition:border-color .15s,box-shadow .15s;
}
input::placeholder,textarea::placeholder{color:#707883}
input:focus,select:focus,textarea:focus{border-color:var(--blue-deep);box-shadow:0 0 0 3px rgba(31,111,168,.15)}
textarea{min-height:140px;resize:vertical}
.full{grid-column:1/-1}
.contact-list{display:grid;gap:12px;margin-top:24px}
.contact-list a{display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:600;text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:5px}
.contact-list a:hover{text-decoration-color:var(--orange)}

/* ---- CTA band ---- */
.cta-band{background:var(--blue);color:var(--ink)}
.cta-band .container{display:grid;grid-template-columns:1fr auto;gap:28px;align-items:center}
.cta-band h2{margin-bottom:6px;color:#0E2A40}
.cta-band p{margin:0;color:#173E5C;font-weight:600}

/* ---- Footer ---- */
footer.site-footer{
  background:
    radial-gradient(720px 320px at 95% 0%,rgba(87,162,216,.30),transparent 60%),
    linear-gradient(160deg,var(--navy-2) 0%,var(--navy) 75%);
  color:#fff;padding:clamp(44px,6vw,60px) 0 22px;
  border-top:4px solid var(--blue);
}
.footer-main{display:grid;grid-template-columns:1.2fr 1fr .9fr 1.1fr;gap:38px;align-items:start}
.footer-logo{display:block;width:165px;height:auto;border-radius:var(--r-sm)}
.footer-tagline{margin-top:14px;color:rgba(255,255,255,.6);font-size:.9375rem;line-height:1.6;max-width:30ch}
.footer-heading{font-weight:600;font-size:.8125rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:16px}
.footer-link{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.85);font-weight:600;padding:5px 0;font-size:.9375rem;transition:color .15s}
.footer-link:hover{color:#fff}
.footer-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:rgba(255,255,255,.1);font-size:.8rem;font-style:normal}
.footer-call-button{
  display:inline-flex;align-items:center;gap:8px;margin-top:2px;
  background:var(--orange-deep);color:#fff;font-weight:600;
  border-radius:var(--r-pill);padding:13px 24px;
  transition:background .18s,transform .18s var(--ease-out);
}
.footer-call-button:hover{background:#BE3614;transform:translateY(-1px)}
.footer-bottom{
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  margin-top:clamp(34px,5vw,48px);padding-top:20px;
  border-top:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.55);font-size:.875rem;
}

/* ---- Reveal motion (enhances visible-by-default content) ---- */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:1;transform:none;transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
  .js .reveal:not(.in){opacity:0;transform:translateY(14px)}
}

/* ---- Responsive ---- */
@media(max-width:1000px){
  .hero-grid,.about-grid,.contact-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .footer-main{grid-template-columns:1fr 1fr}
  .service-cols{columns:1}
  .cta-band .container{grid-template-columns:1fr}
}
@media(max-width:760px){
  nav.primary-nav,.header-cta{display:none}
  .menu-btn{display:inline-flex}
  .mobile-nav{display:none;border-top:1px solid var(--line);background:#fff}
  .mobile-nav.open{display:grid;gap:6px;padding:14px 20px 18px}
  .mobile-nav .nav-link{background:var(--soft);border-radius:var(--r-sm);text-align:left;padding:13px 16px}
  .mobile-nav .nav-link::after{display:none}
  .mobile-nav .nav-link.active{background:var(--ink);color:#fff}
  .brand-logo{width:150px}
  section{padding:clamp(52px,8vw,72px) 0}
  .field-grid,.specialties,.education-grid{grid-template-columns:1fr}
  .result-stats{grid-template-columns:repeat(3,1fr)}
  .service-row{grid-template-columns:1fr}
  .service-row .service-desc{text-align:left}
  .review-category{margin-left:0}
}
@media(max-width:480px){
  .stats{grid-template-columns:1fr 1fr}
  .result-stats{grid-template-columns:1fr 1fr}
  .footer-main{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition-duration:.01ms!important;animation-duration:.01ms!important}
}

/* ---- Print ---- */
@media print{
  header.site-header,.menu-btn,.footer-call-button,.actions{display:none}
  body{font-size:11pt}
}
