/* =========================================================
   HOMEPAGE — Yvonne Spencer / LeadHER CRE
   ========================================================= */

/* ---------- HERO ---------- */
.hero{ position:relative; background:var(--navy); color:var(--cream); overflow:hidden; min-height:92vh; display:flex; flex-direction:column; }
.hero-bg{ position:absolute; inset:0; opacity:.6; }
.hero-glow{
  position:absolute; right:-12%; top:-14%; width:62vw; height:62vw; max-width:840px; max-height:840px;
  background:radial-gradient(circle at 60% 40%, rgba(181,136,75,.20), rgba(90,43,77,.10) 42%, transparent 66%);
  pointer-events:none;
}
.hero-inner{ position:relative; flex:1; display:grid; grid-template-columns:1.18fr .9fr; gap:clamp(32px,5vw,72px); align-items:center; padding-top:clamp(40px,7vw,72px); padding-bottom:clamp(60px,7vw,90px); }
.hero-copy h1{ font-size:clamp(40px,6.1vw,82px); color:var(--cream); margin:24px 0 0; letter-spacing:-.015em; }
.hero-copy h1 .amber{ color:var(--bronze-lt); font-style:italic; font-weight:500; }
.hero-sub{ color:var(--cream-dim); font-size:clamp(16px,1.45vw,20px); line-height:1.62; max-width:50ch; margin-top:28px; }
.hero-cta{ display:flex; gap:16px; flex-wrap:wrap; margin-top:36px; }
.hero-micro{ list-style:none; margin:48px 0 0; padding:30px 0 0; border-top:1px solid var(--line-dk); display:flex; gap:clamp(24px,4vw,52px); flex-wrap:wrap; }
.hero-micro li{ display:flex; flex-direction:column; gap:5px; }
.hero-micro strong{ font-family:var(--serif); font-size:26px; font-weight:600; color:var(--cream); }
.hero-micro span{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--cream-faint); }

.hero-portrait{ position:relative; justify-self:end; width:100%; max-width:440px; }
.portrait-frame{ position:relative; border:1px solid var(--line-dk); padding:14px; background:rgba(255,255,255,.02); }
.portrait-frame::before{ content:""; position:absolute; inset:14px; border:1px solid rgba(203,168,103,.4); pointer-events:none; z-index:2; }
.portrait-frame img{ width:100%; aspect-ratio:1/1.08; object-fit:cover; object-position:50% 24%; filter:grayscale(.12) contrast(1.02); }
.portrait-tag{ position:absolute; left:14px; right:14px; bottom:14px; background:rgba(12,34,51,.86); backdrop-filter:blur(6px); padding:16px 18px; display:flex; flex-direction:column; gap:4px; z-index:3; border-top:2px solid var(--bronze); }
.pt-name{ font-family:var(--serif); font-size:19px; color:var(--cream); font-weight:600; }
.pt-role{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--bronze-lt); }
.portrait-coord{ position:absolute; top:-14px; left:-14px; font-family:var(--mono); font-size:10px; letter-spacing:.1em; color:var(--cream-faint); writing-mode:vertical-rl; transform:rotate(180deg); }

.hero-scroll{ position:relative; align-self:center; margin-bottom:26px; font-family:var(--mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--cream-faint); display:flex; flex-direction:column; align-items:center; gap:10px; }
.hero-scroll span{ width:1px; height:34px; background:linear-gradient(var(--bronze-lt), transparent); animation:scrollpulse 2s var(--ease) infinite; }
@keyframes scrollpulse{ 0%{ transform:scaleY(.3); transform-origin:top; opacity:.4;} 50%{ transform:scaleY(1); opacity:1;} 100%{ transform:scaleY(.3); transform-origin:bottom; opacity:.4;} }

@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; gap:44px; }
  .hero-portrait{ justify-self:start; max-width:360px; order:2; }
  .hero-scroll{ display:none; }
}

/* ---------- PROOF STRIP ---------- */
.proof{ background:var(--cream); border-bottom:1px solid var(--line-soft); }
.proof-inner{ display:flex; align-items:center; gap:clamp(20px,3vw,44px); padding-block:24px; flex-wrap:wrap; }
.proof-lead{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--bronze-dk); white-space:nowrap; }
.proof-list{ display:flex; gap:clamp(20px,3.4vw,48px); list-style:none; margin:0; padding:0; flex-wrap:wrap; align-items:center; }
.proof-list li{ font-family:var(--serif); font-size:clamp(16px,1.7vw,21px); font-weight:500; color:var(--navy); position:relative; }
.proof-list li:not(:last-child)::after{ content:"·"; position:absolute; right:-26px; color:var(--bronze); }

/* ---------- POSITIONING ---------- */
.positioning{ background:var(--paper); }
.pos-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(36px,6vw,90px); align-items:start; }
.pos-left h2{ font-size:clamp(34px,4.8vw,62px); color:var(--navy); margin-top:20px; }
.pos-left h2 .serif-i{ color:var(--bronze-dk); }
.pos-body{ color:#46505b; margin:24px 0 30px; font-size:16.5px; }
@media (max-width:820px){ .pos-grid{ grid-template-columns:1fr; gap:28px; } }

/* ---------- SERVICES ---------- */
.services{ background:var(--cream); }
.svc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border-top:1px solid var(--line); border-left:1px solid var(--line); }
.svc-card{ border-radius:0; border-top:0; border-left:0; border-right:1px solid var(--line); border-bottom:1px solid var(--line); background:transparent; padding:40px 34px 34px; min-height:300px; display:flex; flex-direction:column; position:relative; }
.svc-card:hover{ transform:none; box-shadow:none; background:var(--paper); border-color:var(--line); }
.svc-card .idx{ position:absolute; top:34px; right:34px; }
.svc-icon{ color:var(--bronze-dk); width:46px; height:46px; margin-bottom:auto; }
.svc-icon svg{ width:46px; height:46px; }
.svc-card h3{ font-size:24px; color:var(--navy); margin:30px 0 12px; line-height:1.1; }
.svc-card p{ color:#525c66; font-size:15.5px; line-height:1.55; }
.svc-go{ position:absolute; bottom:34px; right:34px; font-size:18px; color:var(--bronze-dk); opacity:0; transform:translateX(-6px); transition:.35s var(--ease); }
.svc-card:hover .svc-go{ opacity:1; transform:translateX(0); }
.svc-card--cta{ background:var(--navy); color:var(--cream); }
.svc-card--cta:hover{ background:var(--navy-700); }
.svc-card--cta h3{ color:var(--cream); margin-top:auto; }
.svc-card--cta p{ color:var(--cream-dim); margin-bottom:20px; }
@media (max-width:880px){ .svc-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .svc-grid{ grid-template-columns:1fr; } .svc-card{ min-height:0; } }

/* ---------- LEADHER FEATURE ---------- */
.leadher-feature{ position:relative; background:var(--navy); color:var(--cream); overflow:hidden; }
.lh-bg{ position:absolute; inset:0; opacity:.5; }
.lh-grid{ position:relative; display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(36px,5vw,80px); align-items:center; }
.lh-media{ position:relative; }
.lh-img{ aspect-ratio:4/5; border:1px solid var(--line-dk); }
.lh-img img{ filter:grayscale(.2) contrast(1.03); object-position:50% 28%; }
.lh-badge{ position:absolute; right:-18px; bottom:34px; background:var(--navy); border:1px solid var(--line-dk); padding:22px 28px; display:flex; flex-direction:column; align-items:center; gap:10px; box-shadow:0 20px 40px -20px rgba(0,0,0,.7); text-align:center; min-width:200px; background-image:linear-gradient(rgba(203,168,103,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(203,168,103,.07) 1px,transparent 1px); background-size:48px 48px; }
.lh-badge-logo{ font-family:var(--serif); font-size:32px; color:var(--cream); font-weight:700; line-height:1; letter-spacing:-.01em; }
.lh-badge-logo .her{ font-style:italic; color:var(--bronze-lt); font-family:var(--serif); }
.lh-badge-logo .tm{ font-size:13px; vertical-align:super; color:var(--bronze-lt); }
.lh-badge-rule{ font-family:var(--mono); font-size:9px; letter-spacing:.22em; text-transform:uppercase; color:var(--bronze-lt); display:flex; align-items:center; gap:10px; white-space:nowrap; }
.lh-badge-rule::before,.lh-badge-rule::after{ content:""; display:block; width:20px; height:1px; background:var(--bronze-lt); opacity:.7; }
.lh-copy h2{ font-size:clamp(30px,3.8vw,50px); color:var(--cream); margin:22px 0 0; max-width:18ch; }
.lh-lede{ color:var(--cream-dim); font-size:clamp(16px,1.4vw,19px); line-height:1.62; margin-top:24px; max-width:52ch; }
.lh-points{ list-style:none; margin:30px 0; padding:0; display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line-dk); }
.lh-points li{ padding:15px 0; border-bottom:1px solid var(--line-dk); font-size:16.5px; color:var(--cream); display:flex; align-items:baseline; gap:16px; }
.lh-points li span{ font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--bronze-lt); min-width:34px; }
.lh-cta{ display:flex; align-items:center; gap:26px; flex-wrap:wrap; margin-top:34px; }
@media (max-width:820px){ .lh-grid{ grid-template-columns:1fr; gap:40px; } .lh-media{ max-width:380px; } .lh-badge{ right:auto; left:34px; } }

/* ---------- EVENT ---------- */
.event-section{ background:var(--paper); }
.event-card{ display:grid; grid-template-columns:1.1fr .9fr; background:var(--cream); border:1px solid var(--line); }
.event-left{ padding:clamp(36px,4vw,60px); border-right:1px solid var(--line); }
.event-left h2{ font-size:clamp(40px,5vw,68px); color:var(--navy); margin:20px 0; line-height:.98; }
.event-desc{ color:#525c66; font-size:16.5px; max-width:42ch; }
.event-meta{ list-style:none; margin:30px 0 34px; padding:0; display:flex; flex-direction:column; gap:0; }
.event-meta li{ display:flex; justify-content:space-between; padding:13px 0; border-top:1px solid var(--line); font-size:15px; }
.event-meta li:last-child{ border-bottom:1px solid var(--line); }
.event-meta .k{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--bronze-dk); }
.event-meta .v{ color:var(--navy); font-weight:500; }
.event-right{ background:var(--navy); color:var(--cream); padding:clamp(36px,4vw,60px); display:flex; align-items:center; }
.em-label{ font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--bronze-lt); display:block; margin-bottom:22px; }
.em-row{ display:flex; align-items:baseline; gap:18px; padding:18px 0; border-top:1px solid var(--line-dk); font-family:var(--serif); font-size:clamp(17px,1.7vw,21px); color:var(--cream); }
.em-row:last-child{ border-bottom:1px solid var(--line-dk); }
.em-n{ font-family:var(--mono); font-size:12px; color:var(--bronze-lt); letter-spacing:.1em; }
@media (max-width:820px){ .event-card{ grid-template-columns:1fr; } .event-left{ border-right:0; border-bottom:1px solid var(--line); } }

/* ---------- CASE STUDIES ---------- */
.case-section{ background:var(--cream); }
.case-grid{ display:grid; grid-template-columns:1.25fr .75fr; gap:24px; }
.case-feature{ overflow:hidden; display:flex; flex-direction:column; }
.case-img{ aspect-ratio:16/9; }
.case-img.lbl, .case-img .lbl{ font-size:12px; }
.case-body{ padding:32px 34px 36px; }
.case-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.case-card h3{ font-size:clamp(22px,2.4vw,30px); color:var(--navy); margin-bottom:12px; line-height:1.08; }
.case-card p{ color:#525c66; font-size:15.5px; line-height:1.56; }
.case-stats{ display:flex; gap:36px; margin:26px 0 0; padding-top:22px; border-top:1px solid var(--line); }
.case-stats dt{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--bronze-dk); margin-bottom:6px; }
.case-stats dd{ margin:0; font-family:var(--serif); font-size:22px; color:var(--navy); font-weight:600; }
.case-side{ display:flex; flex-direction:column; gap:24px; }
.case-side .case-card{ padding:28px 30px; flex:1; display:flex; flex-direction:column; }
.case-note{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--bronze-dk); margin-top:auto; padding-top:18px; }
.case-foot{ margin-top:40px; }
@media (max-width:820px){ .case-grid{ grid-template-columns:1fr; } }

/* ---------- INSIGHTS ---------- */
.insights{ background:var(--paper); }
.ins-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.ins-card{ display:flex; flex-direction:column; }
.ins-img{ aspect-ratio:4/3; margin-bottom:20px; transition:transform .5s var(--ease); }
.ins-card:hover .ins-img{ transform:translateY(-4px); }
.ins-cat{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--bronze-dk); }
.ins-card h3{ font-size:21px; color:var(--navy); margin:12px 0 16px; line-height:1.2; transition:color .3s; }
.ins-card:hover h3{ color:var(--bronze-dk); }
.ins-meta{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:#8a929b; margin-top:auto; }
@media (max-width:820px){ .ins-grid{ grid-template-columns:1fr; gap:36px; } }

/* ---------- CLOSING ---------- */
.closing{ position:relative; background:var(--navy); color:var(--cream); overflow:hidden; padding-block:clamp(80px,10vw,140px); }
.closing-bg{ position:absolute; inset:0; opacity:.55; }
.closing-inner{ position:relative; text-align:center; }
.closing .eyebrow{ justify-content:center; margin-bottom:26px; }
.closing h2{ font-size:clamp(34px,5.6vw,76px); color:var(--cream); line-height:1.02; }
.closing h2 .amber{ color:var(--bronze-lt); font-style:italic; font-weight:500; }
.path-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:clamp(44px,5vw,64px); max-width:980px; margin-inline:auto; }
.path-card{ border:1px solid var(--line-dk); padding:34px 28px; text-align:left; display:flex; flex-direction:column; gap:8px; transition:background .35s, transform .35s var(--ease), border-color .35s; position:relative; }
.path-card:hover{ background:rgba(203,168,103,.07); transform:translateY(-4px); border-color:var(--bronze-lt); }
.path-n{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--bronze-lt); }
.path-t{ font-family:var(--serif); font-size:24px; color:var(--cream); font-weight:600; margin-top:6px; }
.path-go{ position:absolute; top:30px; right:28px; font-size:18px; color:var(--bronze-lt); transition:transform .35s var(--ease); }
.path-card:hover .path-go{ transform:translate(4px,-4px); }
@media (max-width:760px){ .path-grid{ grid-template-columns:1fr; } }
