/* ============================================================
   Mary Ramirez — Portfolio
   Built on the EdPlus at ASU Design System
   Fonts: Neue Haas Grotesk Display + Text (local, in /assets/fonts)
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face { font-family:"Neue Haas Grotesk Display"; font-weight:300; font-style:normal;
  src:url("assets/fonts/NeueHaasDisplayLight.ttf") format("truetype"); font-display:swap; }
@font-face { font-family:"Neue Haas Grotesk Display"; font-weight:500; font-style:normal;
  src:url("assets/fonts/NeueHaasDisplayMediu.ttf") format("truetype"); font-display:swap; }
@font-face { font-family:"Neue Haas Grotesk Display"; font-weight:700; font-style:normal;
  src:url("assets/fonts/NeueHaasDisplayBold.ttf") format("truetype"); font-display:swap; }

@font-face { font-family:"Neue Haas Grotesk Text"; font-weight:400; font-style:normal;
  src:url("assets/fonts/NHaasGroteskTXPro-55Rg.otf") format("opentype"); font-display:swap; }
@font-face { font-family:"Neue Haas Grotesk Text"; font-weight:500; font-style:normal;
  src:url("assets/fonts/NHaasGroteskTXPro-65Md.otf") format("opentype"); font-display:swap; }
@font-face { font-family:"Neue Haas Grotesk Text"; font-weight:700; font-style:normal;
  src:url("assets/fonts/NHaasGroteskTXPro-75Bd.otf") format("opentype"); font-display:swap; }

/* ---------- Design tokens (EdPlus @ ASU) ---------- */
:root {
  --asu-maroon:#8C1D40; --asu-maroon-deep:#6E1632; --asu-maroon-light:#AC3B5F;
  --asu-gold:#FFC627; --asu-gold-deep:#E6B11C; --asu-gold-light:#FFE6A0;
  --asu-pink:#FFB6CD; --asu-green:#005C32; --asu-blue:#00A3E0; --asu-blue-light:#BBEDFF;

  /* company-accent (used as thin lines / dots only) */
  --gh-accent:#3FB950; --tw-accent:#1D9BF0;

  --neutral-0:#FFFFFF; --neutral-50:#FAFAFA; --neutral-75:#F0F0F0; --neutral-100:#EFEFEF;
  --neutral-150:#EBEBEB; --neutral-200:#DCDCDC; --neutral-300:#BDBDBD; --neutral-400:#747474;
  --neutral-500:#6F6F6F; --neutral-600:#4E4E4E; --neutral-700:#444444; --neutral-800:#222222;
  --neutral-900:#191919; --neutral-1000:#000000;

  --fg-1:var(--neutral-900); --fg-2:var(--neutral-800); --fg-3:var(--neutral-500);
  --ink-dark:#0E0E0E; --surface-dark:#202020; --surface-dark-2:#262626;

  --font-display:"Neue Haas Grotesk Display","Helvetica Neue",Arial,sans-serif;
  --font-text:"Neue Haas Grotesk Text","Helvetica Neue",Arial,sans-serif;

  --tracking-tight:-0.02em; --tracking-eyebrow:0.15em;

  --shadow-card:0 5px 20px rgba(0,0,0,.10),0 0 3px rgba(0,0,0,.18);
  --shadow-soft:0 2px 8px rgba(0,0,0,.08);
  --shadow-lift:0 18px 48px rgba(0,0,0,.16);
  --shadow-inset:inset 0 2px 25px 8px rgba(0,0,0,.12);

  --radius-xs:4px; --radius-sm:8px; --radius-md:12px; --radius-pill:999px;

  --gutter:clamp(20px, 6vw, 116px);
  --maxw:1200px;
}

/* ---------- Reset / base ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; font-family:var(--font-text); color:var(--fg-1);
  background:var(--neutral-0); line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }
h1,h2,h3,h4,p{ margin:0; }
::selection{ background:var(--asu-gold); color:var(--neutral-900); }

/* ---------- Type helpers ---------- */
.eyebrow{
  font-family:var(--font-display); font-weight:300; font-size:clamp(12px,1.1vw,14px);
  letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; color:var(--fg-3);
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{
  content:""; width:28px; height:2px; background:currentColor; opacity:.55; display:inline-block;
}
.display{
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  line-height:.98;
}
.h2{
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  font-size:clamp(30px,4.4vw,56px); line-height:1.05;
}
.lead{
  font-size:clamp(17px,1.5vw,21px); line-height:1.5; color:var(--fg-2);
}

/* ---------- Layout ---------- */
.section{ padding:clamp(72px,10vw,140px) var(--gutter); position:relative; }
.wrap{ max-width:var(--maxw); margin:0 auto; }
.section-head{ max-width:760px; margin-bottom:clamp(40px,5vw,64px); }
.section-head .eyebrow{ margin-bottom:20px; }
.section-head p{ margin-top:20px; }

/* Deep-dive link (Work intro → CSI 0→1 page) */
.deepdive-link{
  display:flex; align-items:center; gap:18px; flex-wrap:wrap; max-width:760px; margin-top:30px;
  padding:20px 24px; border:2px solid var(--neutral-150); border-left:4px solid var(--asu-gold);
  background:var(--neutral-50); border-radius:var(--radius-sm);
  transition:border-color .2s ease, background .2s ease, transform .2s ease;
}
.deepdive-link:hover{ border-color:var(--asu-gold); background:#fff; transform:translateY(-2px); box-shadow:var(--shadow-soft); }
.deepdive-link .dd-tag{
  font-family:var(--font-display); font-weight:700; font-size:12px; letter-spacing:var(--tracking-eyebrow);
  text-transform:uppercase; color:var(--asu-maroon); white-space:nowrap;
}
.deepdive-link .dd-text{ flex:1; min-width:220px; font-size:16px; line-height:1.45; color:var(--fg-2); }
.deepdive-link .dd-text strong{ color:var(--neutral-900); font-weight:700; }
.deepdive-link .dd-arrow{ font-family:var(--font-display); font-weight:700; font-size:22px; color:var(--asu-maroon); transition:transform .2s ease; }
.deepdive-link:hover .dd-arrow{ transform:translateX(4px); }

/* Maroon-section variant (ASU "Senior Manager of AI") */
.deepdive-link--maroon{
  max-width:none; margin-top:clamp(36px,4vw,52px);
  background:#fff; border-color:rgba(255,255,255,.18); border-left-color:var(--asu-gold);
}
.deepdive-link--maroon:hover{ border-color:var(--asu-gold); background:rgba(255,255,255,.10); box-shadow:none; }
.deepdive-link--maroon .dd-tag{ color:var(--neutral-1000); }
.deepdive-link--maroon .dd-text{ color:var(--neutral-1000); }
.deepdive-link--maroon .dd-text strong{ color:var(--neutral-1000); }
.deepdive-link--maroon .dd-arrow{ color:var(--neutral-1000); }

/* ===========================================================
   HEADER
   =========================================================== */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease, color .35s ease;
  color:#fff;
}
.site-header.scrolled{
  background:rgba(255,255,255,.92); backdrop-filter:saturate(140%) blur(10px);
  box-shadow:0 1px 0 var(--neutral-150); color:var(--fg-1); padding:12px var(--gutter);
}
.brandmark{
  font-family:var(--font-display); font-weight:700; font-size:18px; letter-spacing:var(--tracking-tight);
  display:flex; align-items:center; gap:10px;
}
.brandmark .dot{ width:10px; height:10px; background:var(--asu-gold); border-radius:50%; flex:none; }
.site-nav{ display:flex; align-items:center; gap:8px; }
.site-nav a{
  font-weight:500; font-size:15px; letter-spacing:-0.01em; padding:8px 14px; border-radius:var(--radius-xs);
  opacity:.92; transition:opacity .2s, background .2s;
}
.site-nav a:hover{ opacity:1; }
.site-nav .nav-cta{
  background:var(--asu-gold); color:var(--neutral-900); font-weight:700; opacity:1;
}
.site-nav .nav-cta:hover{ background:var(--asu-gold-deep); }
.scrolled .site-nav a:not(.nav-cta){ color:var(--fg-1); }
.scrolled .site-nav a:not(.nav-cta):hover{ background:var(--neutral-75); }
.nav-toggle{ display:none; }

/* ===========================================================
   HERO
   =========================================================== */
.hero{
  position:relative; background:var(--neutral-900); color:#fff;
  min-height:100svh; display:flex; align-items:center;
  padding:clamp(120px,16vh,200px) var(--gutter) clamp(72px,10vh,120px);
  overflow:hidden;
}
.hero::before{ /* warm gold glow, top-left */
  content:""; position:absolute; width:90vmax; height:90vmax; left:-30vmax; top:-40vmax;
  background:radial-gradient(circle at center, rgba(255,198,39,.42), transparent 60%);
  pointer-events:none;
}
.hero::after{ /* gold glow, behind portrait */
  content:""; position:absolute; width:60vmax; height:60vmax; right:-22vmax; bottom:-26vmax;
  background:radial-gradient(circle at center, rgba(255,198,39,.16), transparent 62%);
  pointer-events:none;
}
.hero-inner{
  position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; width:100%;
  display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,72px); align-items:center;
}
.hero .eyebrow{ color:#fff; }
.hero h1{
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  font-size:clamp(40px,6.6vw,92px); line-height:.96; margin:22px 0 26px; max-width:14ch;
}
.hero h1 .accent{ color:var(--asu-gold); }
.hero-sub{ font-size:clamp(17px,1.55vw,22px); line-height:1.5; color:#dcdcdc; max-width:46ch; margin-bottom:38px; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; }

.btn{
  display:inline-flex; align-items:center; gap:10px; padding:15px 26px; border-radius:var(--radius-xs);
  font-family:var(--font-text); font-weight:700; font-size:16px; letter-spacing:-0.01em;
  border:1px solid transparent; cursor:pointer; transition:transform .15s ease, background .2s, color .2s, border-color .2s;
}
.btn:active{ transform:scale(.98); }
.btn-gold{ background:var(--asu-gold); color:var(--neutral-900); }
.btn-gold:hover{ background:var(--asu-gold-deep); }
.btn-maroon{ background:var(--asu-maroon); color:#fff; }
.btn-maroon:hover{ background:var(--asu-maroon-deep); }
.btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.45); }
.btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.08); }
.btn-ghost-dark{ background:transparent; color:var(--fg-1); border-color:var(--neutral-300); }
.btn-ghost-dark:hover{ border-color:var(--neutral-900); background:var(--neutral-75); }
.btn .arrow{ transition:transform .2s; }
.btn:hover .arrow{ transform:translateX(3px); }

/* portrait */
.hero-portrait{ position:relative; justify-self:center; }
.portrait-ring{
  position:relative; width:clamp(240px,30vw,400px); aspect-ratio:1; border-radius:50%;
  background:linear-gradient(160deg,#2a2a2a,#141414);
  box-shadow:var(--shadow-inset), 0 30px 70px rgba(0,0,0,.5);
  overflow:hidden; outline:1px solid rgba(255,255,255,.08);
}
.portrait-ring img{ width:100%; height:100%; object-fit:cover; object-position:center top; }
.portrait-badge{
  position:absolute; bottom:6%; left:-6%; background:var(--asu-gold); color:var(--neutral-900);
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  padding:12px 18px; border-radius:var(--radius-sm); box-shadow:var(--shadow-lift); line-height:1.05;
  font-size:clamp(13px,1.2vw,15px);
}
.portrait-badge span{ display:block; font-family:var(--font-text); font-weight:500; font-size:12px; color:var(--neutral-900); margin-top:3px; }

.scroll-cue{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:var(--asu-gold); font-size:13px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
}
.scroll-cue .line{ width:2px; height:42px; border-radius:2px; background:linear-gradient(var(--asu-gold),rgba(255,198,39,0)); animation:cuePulse 2.2s ease-in-out infinite; }
@keyframes cuePulse{ 0%,100%{ opacity:.55; transform:scaleY(.7); } 50%{ opacity:1; transform:scaleY(1); } }

/* ===========================================================
   CREDIBILITY STRIP (animated counters)
   =========================================================== */
.stats{ background:var(--neutral-50); }
.stats-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(24px,3.5vw,48px); }
.stat{ border-top:4px solid var(--asu-gold); padding-top:22px; }
.stat .num{
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  font-size:clamp(40px,5vw,64px); line-height:.95; color:var(--asu-gold-deep);
}
.stat .num .suffix{ color:var(--asu-gold-deep); }
.stat .cap{ margin-top:10px; font-size:15px; font-weight:500; color:var(--fg-2); max-width:24ch; }

/* ===========================================================
   EXPERIENCE / COMPANY SECTIONS
   =========================================================== */
.company{ position:relative; }
.company-head{
  display:flex; align-items:flex-end; justify-content:space-between; gap:32px; flex-wrap:wrap;
  padding-bottom:34px; margin-bottom:clamp(40px,5vw,60px); border-bottom:2px solid;
}
.company-id{ display:flex; flex-direction:column; gap:18px; }
.company-logo{ display:flex; align-items:center; gap:16px; }
.company-logo .mark{ width:48px; height:48px; flex:none; }
.company-logo img{ height:44px; width:auto; }
.company-wordmark{ font-family:var(--font-display); font-weight:700; font-size:clamp(28px,3.4vw,42px); letter-spacing:var(--tracking-tight); }
.company-role{ font-family:var(--font-display); font-weight:700; font-size:clamp(22px,2.6vw,32px); letter-spacing:var(--tracking-tight); line-height:1.1; }
.company-meta{ font-size:14px; letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; font-weight:500; }
.company-summary{ max-width:42ch; font-size:clamp(16px,1.5vw,19px); line-height:1.55; }

/* ASU — maroon */
.company--asu{ background:var(--asu-maroon); color:#fff; }
.company--asu .company-head{ border-color:rgba(255,255,255,.22); }
.company--asu .company-meta{ color:var(--asu-gold); }
.company--asu .company-summary{ color:#FFE6A0; }
.company--asu .company-logo img{ height:52px; }

/* GitHub — dark */
.company--gh{ background:var(--ink-dark); color:#fff; }
.company--gh .company-head{ border-color:rgba(255,255,255,.14); }
.company--gh .company-meta{ color:var(--gh-accent); }
.company--gh .company-summary{ color:#c9c9c9; }
.company--gh .company-logo .mark{ color:#fff; }

/* Twitter — light */
.company--tw{ background:var(--neutral-0); color:var(--fg-1); }
.company--tw .company-head{ border-color:var(--neutral-200); }
.company--tw .company-meta{ color:var(--tw-accent); }
.company--tw .company-summary{ color:var(--fg-2); }
.company--tw .company-logo .mark{ color:var(--tw-accent); }

/* ===========================================================
   CASE STUDY FLIP CARDS
   =========================================================== */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2vw,26px); }
.company--gh .cards{ grid-template-columns:repeat(2,1fr); }
.company--tw .cards{ grid-template-columns:repeat(2,1fr); align-items:stretch; }
.company--tw .cards .case{ grid-column:auto; }

/* Twitter companion context panel */
.tw-context{
  display:flex; flex-direction:column; justify-content:center; gap:18px;
  padding:34px 36px; border:2px solid var(--neutral-150); border-top:4px solid var(--tw-accent);
  background:var(--neutral-50);
}
.tw-context-lead{ font-family:var(--font-display); font-weight:500; font-size:clamp(19px,2vw,26px); line-height:1.2; letter-spacing:var(--tracking-tight); color:var(--neutral-900); }
.tw-context-list{ list-style:none; margin:6px 0 0; padding:0; display:flex; flex-direction:column; gap:12px; }
.tw-context-list li{ position:relative; padding-left:26px; font-size:15px; font-weight:500; color:var(--fg-2); line-height:1.4; }
.tw-context-list li::before{ content:""; position:absolute; left:0; top:.55em; width:9px; height:9px; border-radius:50%; background:var(--tw-accent); }

.case{ perspective:1600px; height:clamp(420px,46vw,500px); position:relative; z-index:1; }

/* Hover lift — same feel as the "In their words" cards: lift + soft scale.
   Higher specificity than .reveal.in so the scroll-reveal reset doesn't cancel it. */
@media (hover:hover){
  .cards .case{
    transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease;
    will-change:transform;
  }
  .cards .case:hover,
  .cards .case:focus-within,
  .reveal-ready .cards .case:hover,
  .reveal-ready .cards .case:focus-within{
    transform:scale(1.12); z-index:30;
  }
  .cards .case:hover .case-face,
  .cards .case:focus-within .case-face{
    box-shadow:var(--shadow-lift);
  }
}
@media (prefers-reduced-motion:reduce){
  .cards .case{ transition:box-shadow .2s ease; }
}
.case-inner{
  position:relative; width:100%; height:100%; transition:transform .7s cubic-bezier(.4,.05,.2,1);
  transform-style:preserve-3d; cursor:pointer;
}
.case.flipped .case-inner{ transform:rotateY(180deg); }
.case-face{
  position:absolute; inset:0; backface-visibility:hidden; -webkit-backface-visibility:hidden;
  display:flex; flex-direction:column; padding:30px; border:2px solid; overflow:hidden;
}
.case-front{ background:var(--neutral-0); border-color:var(--neutral-150); }
.case-back{ background:var(--neutral-900); color:#fff; border-color:var(--neutral-900); transform:rotateY(180deg); }

/* card surface tints per company for contrast on colored sections */
.company--asu .case-front{ background:#fff; border-color:#fff; }
.company--gh  .case-front{ background:var(--surface-dark); border-color:#333; color:#fff; }
.company--tw  .case-front{ background:#fff; border-color:var(--neutral-200); box-shadow:var(--shadow-soft); }

.case-eyebrow{ font-family:var(--font-display); font-weight:300; font-size:12px; letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; }
.company--asu .case-front .case-eyebrow{ color:var(--asu-maroon); }
.company--gh  .case-front .case-eyebrow{ color:var(--gh-accent); }
.company--tw  .case-front .case-eyebrow{ color:var(--tw-accent); }

.case-front .case-quote{
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  font-size:clamp(20px,2vw,26px); line-height:1.12; margin:18px 0 0;
}
.company--gh .case-front .case-quote{ color:#fff; }
.case-front .case-foot{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:12px; padding-top:20px; }
.case-front .case-role{ font-size:13px; font-weight:500; color:var(--fg-3); }
.company--gh .case-front .case-role{ color:#9a9a9a; }
.flip-hint{
  display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:700; letter-spacing:.04em;
  text-transform:uppercase; color:var(--fg-3);
}
.flip-hint .ico{ width:26px; height:26px; border-radius:50%; border:1.5px solid currentColor; display:grid; place-items:center; }
.company--asu .case-front .flip-hint{ color:var(--asu-maroon); }
.company--gh  .case-front .flip-hint{ color:var(--gh-accent); }
.company--tw  .case-front .flip-hint{ color:var(--tw-accent); }

/* back face */
.case-back .case-title{ font-family:var(--font-display); font-weight:700; font-size:18px; letter-spacing:var(--tracking-tight); color:var(--asu-gold); margin-bottom:14px; }
.case-back .case-body{ font-size:14px; line-height:1.5; color:#d8d8d8; overflow-y:auto; flex:1; padding-right:6px; }
.case-back .case-body p{ margin:0 0 12px; color:#d8d8d8; }
.case-back .outcome{
  margin-top:14px; padding-top:16px; border-top:1px solid rgba(255,255,255,.16);
}
.case-back .outcome .lbl{ font-size:11px; letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; color:var(--asu-gold); font-weight:500; }
.case-back .outcome .val{ font-size:15px; font-weight:500; line-height:1.4; color:#fff; margin-top:6px; }
.case-back .back-close{ margin-top:16px; align-self:flex-start; font-size:12px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--asu-gold); display:inline-flex; gap:8px; align-items:center; }

/* scrollbar for back body */
.case-back .case-body::-webkit-scrollbar{ width:5px; }
.case-back .case-body::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.25); border-radius:3px; }

/* ===========================================================
   WORKING WITH ME (toggle)
   =========================================================== */
.wwm{ background:var(--neutral-900); color:#fff; position:relative; overflow:hidden; }
.wwm::before{ /* warm gold glow, top-left (matches hero) */
  content:""; position:absolute; width:90vmax; height:90vmax; left:-40vmax; top:-55vmax;
  background:radial-gradient(circle at center, rgba(255,198,39,.20), transparent 60%); pointer-events:none;
}
.wwm::after{ /* gold glow, bottom-right (matches hero) */
  content:""; position:absolute; right:-22vmax; bottom:-26vmax; width:60vmax; height:60vmax;
  background:radial-gradient(circle at center, rgba(255,198,39,.10), transparent 62%); pointer-events:none;
}
.wwm .wrap{ position:relative; z-index:2; }
.wwm .section-head .eyebrow{ color:#fff; }

/* two-column: phone mockup + operating principles */
.wwm-grid{
  display:grid; grid-template-columns:0.92fr 1.08fr;
  gap:clamp(36px,5vw,80px); align-items:center;
}
.wwm-visual{ display:flex; justify-content:center; }
.wwm-visual img{
  width:100%; max-width:440px; height:auto;
  -webkit-mask-image:linear-gradient(to bottom, #000 56%, transparent 86%);
  mask-image:linear-gradient(to bottom, #000 56%, transparent 86%);
}
.toggle{
  display:flex; width:-moz-fit-content; width:fit-content; padding:5px; background:rgba(255,255,255,.12); border-radius:var(--radius-pill);
  margin:0 auto 44px; position:relative;
}
.toggle button{
  position:relative; z-index:2; border:0; background:transparent; cursor:pointer;
  font-family:var(--font-text); font-weight:700; font-size:15px; letter-spacing:-0.01em;
  padding:11px 26px; min-width:130px; text-align:center; border-radius:var(--radius-pill); color:#fff; transition:color .25s;
}
.toggle button[aria-selected="true"]{ color:var(--neutral-900); }
.toggle .thumb{
  position:absolute; z-index:1; top:5px; bottom:5px; left:5px; width:calc(50% - 5px);
  background:#ffc627; border-radius:var(--radius-pill); transition:transform .3s cubic-bezier(.4,.05,.2,1);
}
.toggle[data-mode="ic"] .thumb{ transform:translateX(100%); }

.wwm-panels{ position:relative; }
.wwm-panel{ display:none; }
.wwm-panel.active{ display:block; animation:fadeUp .45s ease both; }
.wwm-list{ display:grid; grid-template-columns:1fr; gap:clamp(18px,2.4vw,26px); }
.wwm-item{ display:flex; gap:18px; padding:4px 0; }
.wwm-item .idx{
  font-family:var(--font-display); font-weight:700; font-size:15px; color:#fff;
  width:34px; height:34px; border-radius:50%; border:2px solid rgba(255,255,255,.55); flex:none;
  display:grid; place-items:center; background:transparent;
}
.wwm-item p{ font-size:clamp(16px,1.5vw,18px); line-height:1.45; color:#fff; font-weight:500; }

/* ===========================================================
   TESTIMONIALS
   =========================================================== */
/* ===========================================================
   TESTIMONIALS — scatter / pile of draggable cards
   (colors unchanged: white card, maroon accent, gold mark, FAFAFA section)
   =========================================================== */
.testimonials{ background:var(--neutral-50); overflow:hidden; }
.scatter-hint{ text-align:center; color:var(--fg-3); font-size:13px; letter-spacing:.03em; margin:0 0 30px; }

/* Default (no-JS / mobile): clean readable stack */
.scatter{ max-width:560px; margin:0 auto; display:flex; flex-direction:column; gap:20px; }
.quote{
  display:flex; flex-direction:column; position:relative;
  background:#fff; border:2px solid var(--neutral-150); border-left:4px solid #ffc627;
  padding:28px 30px; box-shadow:var(--shadow-soft);
}
.quote .mark{ font-family:var(--font-display); font-weight:700; font-size:50px; line-height:.55; color:var(--asu-gold); height:26px; display:block; }
.q-body{ margin-top:6px; }
.quote blockquote{ margin:0; font-family:var(--font-display); font-weight:500; font-size:clamp(17px,1.6vw,21px); line-height:1.36; letter-spacing:var(--tracking-tight); color:var(--neutral-900); }
.quote .who{ margin-top:18px; font-size:13.5px; flex:none; }
.quote .who .name{ font-weight:700; color:#ffc627; letter-spacing:.04em; text-transform:uppercase; }
.quote .who .role{ color:var(--fg-3); margin-top:2px; }
.q-close{ display:none; }

/* JS / desktop: scattered, draggable pile */
.scatter.js{ position:relative; max-width:1040px; height:980px; display:block; touch-action:none; }
.scatter.js .quote{
  position:absolute; top:0; left:0; width:332px; height:300px; padding:26px 28px;
  box-shadow:var(--shadow-card); cursor:grab; user-select:none;
  transform:rotate(var(--r,0deg)); transform-origin:center center;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, opacity .5s ease;
  will-change:transform;
}
.scatter.js .quote:focus-visible{ outline:3px solid var(--asu-gold); outline-offset:3px; }
.scatter.js .q-body{ flex:1; overflow:hidden; -webkit-mask-image:linear-gradient(#000 70%, transparent); mask-image:linear-gradient(#000 70%, transparent); }
.scatter.js .quote .who{ margin-top:14px; }

/* entrance: fade in once ready (transform stays for rotation) */
.scatter.js.anim .quote{ opacity:0; }
.scatter.js.anim.ready .quote{ opacity:1; }
.scatter.js.anim.ready .quote:nth-child(1){ transition-delay:.05s; }
.scatter.js.anim.ready .quote:nth-child(2){ transition-delay:.13s; }
.scatter.js.anim.ready .quote:nth-child(3){ transition-delay:.21s; }
.scatter.js.anim.ready .quote:nth-child(4){ transition-delay:.29s; }
.scatter.js.anim.ready .quote:nth-child(5){ transition-delay:.37s; }
.scatter.js.anim.ready .quote:nth-child(6){ transition-delay:.45s; }
.scatter.js.anim.ready .quote:nth-child(7){ transition-delay:.53s; }
.scatter.js.anim.ready .quote:nth-child(8){ transition-delay:.61s; }

/* hover: straighten + lift */
@media (hover:hover){
  .scatter.js .quote:hover{ transform:rotate(0deg) scale(1.045); box-shadow:var(--shadow-lift); }
}
.scatter.js .quote.dragging{ transition:box-shadow .2s ease; transform:rotate(var(--r,0deg)) scale(1.05); box-shadow:var(--shadow-lift); cursor:grabbing; }

/* opened / expanded card */
.scatter-backdrop{ position:fixed; inset:0; background:rgba(20,20,20,.55); -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); z-index:200; opacity:0; transition:opacity .3s ease; }
.scatter-backdrop.show{ opacity:1; }
.scatter.js .quote.expanded{
  position:fixed; top:50%; left:50%; width:min(580px,92vw); height:auto; max-height:86vh; overflow:auto;
  padding:46px 46px 40px; z-index:210; cursor:default; border-left-width:6px;
  transform:translate(-50%,-50%) rotate(0deg) scale(1); box-shadow:0 40px 110px rgba(0,0,0,.45);
  opacity:1 !important; transition:opacity .3s ease, box-shadow .3s ease;
}
.scatter.js .quote.expanded .q-body{ overflow:visible; flex:none; -webkit-mask-image:none; mask-image:none; }
.scatter.js .quote.expanded blockquote{ font-size:clamp(21px,2.5vw,28px); line-height:1.34; }
.scatter.js .quote.expanded .mark{ font-size:64px; height:32px; }
.scatter.js .quote.expanded .who{ margin-top:24px; font-size:14px; }
.scatter.js .quote.expanded .q-close{
  display:grid; place-items:center; position:absolute; top:14px; right:14px; width:38px; height:38px;
  border:0; border-radius:50%; background:var(--neutral-75); color:var(--neutral-700);
  font-size:24px; line-height:1; cursor:pointer; transition:background .2s, color .2s;
}
.scatter.js .quote.expanded .q-close:hover{ background:#ffc627; color:var(--neutral-900); }

@media (prefers-reduced-motion:reduce){
  .scatter.js .quote{ transition:box-shadow .2s ease; }
  .scatter.js.anim .quote{ opacity:1; }
}

/* ===========================================================
   CONTACT
   =========================================================== */
.contact{ background:var(--neutral-900); color:#fff; position:relative; overflow:hidden; }
.contact::before{ /* warm gold glow, top-left (matches hero) */
  content:""; position:absolute; width:90vmax; height:90vmax; left:-30vmax; top:-40vmax;
  background:radial-gradient(circle at center, rgba(255,198,39,.42), transparent 60%); pointer-events:none;
}
.contact::after{ /* gold glow, bottom-right (matches hero) */
  content:""; position:absolute; right:-22vmax; bottom:-26vmax; width:60vmax; height:60vmax;
  background:radial-gradient(circle at center, rgba(255,198,39,.16), transparent 62%); pointer-events:none;
}
.contact .wrap{ position:relative; z-index:2; }
.contact .eyebrow{ color:#fff; }
.contact h2{ font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight); font-size:clamp(40px,7vw,88px); line-height:.96; margin:18px 0 24px; }
.contact p{ color:#fff; font-size:clamp(17px,1.7vw,22px); line-height:1.5; max-width:46ch; margin-bottom:40px; }
.contact-ctas{ display:flex; flex-wrap:wrap; gap:14px; }

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer{ background:var(--neutral-900); color:#fff; padding:64px var(--gutter) 36px; }
.footer-top{ display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; max-width:var(--maxw); margin:0 auto 40px; }
.footer-brand{ font-family:var(--font-display); font-weight:700; font-size:22px; letter-spacing:var(--tracking-tight); display:flex; align-items:center; gap:10px; }
.footer-brand .dot{ width:9px; height:9px; background:var(--asu-gold); border-radius:50%; }
.footer-brand .blurb{ display:block; font-family:var(--font-text); font-weight:400; font-size:14px; color:#bdbdbd; margin-top:14px; max-width:34ch; letter-spacing:0; }
.footer-social{ display:flex; gap:10px; }
.footer-social a{
  width:42px; height:42px; border-radius:50%; border:1px solid rgba(255,255,255,.22);
  display:grid; place-items:center; color:#fff; transition:background .2s, border-color .2s, transform .15s;
}
.footer-social a:hover{ background:var(--asu-gold); color:var(--neutral-900); border-color:var(--asu-gold); transform:translateY(-2px); }
.footer-social svg{ width:18px; height:18px; }
.footer-bottom{
  max-width:var(--maxw); margin:0 auto; padding-top:24px; border-top:1px solid #2a2a2a;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  font-size:12.5px; color:#9a9a9a; letter-spacing:.01em;
}
.footer-bottom a{ color:#bdbdbd; }
.footer-bottom a:hover{ color:var(--asu-gold); }

/* ===========================================================
   SCROLL REVEAL
   =========================================================== */
/* Progressive enhancement: content is visible by default. Only when JS adds
   .reveal-ready to <html> do we hide-then-animate. If JS fails, nothing hides. */
.reveal{ transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); will-change:opacity,transform; }
.reveal-ready .reveal{ opacity:0; transform:translateY(26px); }
.reveal-ready .reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .scroll-cue .line{ animation:none; }
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:960px){
  .hero-inner{ grid-template-columns:1fr; gap:48px; }
  .hero-portrait{ order:-1; }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .cards{ grid-template-columns:repeat(2,1fr); }
  .company--gh .cards, .company--tw .cards{ grid-template-columns:repeat(2,1fr); }
  .wwm-grid{ grid-template-columns:1fr; gap:48px; }
  .wwm-visual{ order:2; }
  .wwm-visual img{ max-width:360px; }
}
@media (max-width:640px){
  .site-nav{
    position:fixed; inset:0 0 auto 0; top:0; flex-direction:column; align-items:stretch; gap:4px;
    background:rgba(20,20,20,.97); backdrop-filter:blur(12px); padding:84px 20px 24px;
    transform:translateY(-105%); transition:transform .35s ease; height:auto;
  }
  .site-nav.open{ transform:none; }
  .site-nav a{ color:#fff !important; padding:14px 16px; font-size:17px; }
  .site-nav a:hover{ background:rgba(255,255,255,.08) !important; }
  .site-nav .nav-cta{ color:var(--neutral-900) !important; text-align:center; margin-top:8px; }
  .nav-toggle{
    display:inline-flex; flex-direction:column; gap:5px; background:transparent; border:0; cursor:pointer;
    padding:8px; z-index:120;
  }
  .nav-toggle span{ width:26px; height:2px; background:currentColor; transition:transform .3s, opacity .3s; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .cards, .company--gh .cards, .company--tw .cards{ grid-template-columns:1fr; }
  .case{ height:auto; min-height:440px; }
  .stats-grid{ grid-template-columns:1fr; }
  .company-head{ flex-direction:column; align-items:flex-start; }
}

/* ===========================================================
   CURSOR-FOLLOWING PAPER PLANE
   =========================================================== */
.cursor-plane{
  position:fixed; top:0; left:0; width:62px; height:auto; z-index:9999;
  pointer-events:none; opacity:0; transition:opacity .35s ease;
  will-change:transform; filter:drop-shadow(0 8px 16px rgba(0,0,0,.22));
}
.cursor-plane.show{ opacity:1; }
@media (hover:none),(pointer:coarse){ .cursor-plane{ display:none !important; } }
@media (prefers-reduced-motion:reduce){ .cursor-plane{ display:none !important; } }

/* ===========================================================
   SPECIALIZING IN — auto-scrolling word carousel
   =========================================================== */
.specializing{ padding-top:clamp(36px,4vw,64px); padding-bottom:clamp(36px,4vw,64px); overflow:hidden; background:#000; }
.spec-grid{
  display:grid; grid-template-columns:minmax(200px,0.85fr) 1.15fr;
  gap:clamp(24px,5vw,80px); align-items:center;
}
.spec-label{
  font-family:var(--font-display); font-weight:700; letter-spacing:var(--tracking-tight);
  font-size:clamp(22px,2.6vw,36px); line-height:1.1; color:var(--fg-1);
}
.spec-viewport{
  position:relative; height:clamp(320px,46vh,520px); overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 24%,#000 76%,transparent 100%);
  mask-image:linear-gradient(180deg,transparent 0,#000 24%,#000 76%,transparent 100%);
}
.spec-track{
  list-style:none; margin:0; padding:0; display:flex; flex-direction:column;
  animation:specScroll 24s linear infinite;
}
.spec-viewport:hover .spec-track{ animation-play-state:paused; }
.spec-track li{
  font-family:var(--font-display); font-weight:600; letter-spacing:var(--tracking-tight);
  font-size:clamp(34px,4.6vw,62px); line-height:1.18; color:#fff;
  white-space:nowrap; margin-bottom:clamp(8px,1.4vh,20px);
}
@keyframes specScroll{ from{ transform:translateY(0); } to{ transform:translateY(-50%); } }
@media (prefers-reduced-motion:reduce){ .spec-track{ animation:none; } }
@media (max-width:760px){
  .spec-grid{ grid-template-columns:1fr; gap:14px; }
  .spec-viewport{ height:clamp(180px,42vh,300px); }
}
