/*
Theme Name: HumAnIzing
Theme URI: https://humanizing.apollo-dev.co.uk
Author: Apollo Internet Media
Author URI: https://apollo-media.com
Description: Strategy & Execution consulting — single page theme with ACF
Version: 1.0.0
License: Proprietary
Text Domain: humanizing
*/

:root{--ink:#020817;--oxblood:#9B1B30;--oxblood-hover:#7a1526;--white:#FFFFFF;--parchment:#F5F0E8;--border:#E0DDD6;--border-light:#EBE8E2;--caption:#4B5563;--font-heading:'PT Serif',Georgia,serif;--font-body:'Work Sans',-apple-system,sans-serif;--h1:54px;--h1-lh:64px;--h2:40px;--h2-lh:48px;--h3:28px;--h3-lh:36px;--h4:22px;--h4-lh:30px;--body:18px;--body-lh:28px;--caption-size:14px;--button:16px;--button-lh:24px}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);font-size:var(--body);line-height:var(--body-lh);color:var(--ink);background:var(--white);overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:400}
a{color:inherit;text-decoration:none}
.container{max-width:100%;margin:0 auto;padding:0 10vw}
section{padding:52px 0}
.btn-primary{display:inline-block;font-family:var(--font-body);font-size:var(--button);font-weight:500;line-height:var(--button-lh);color:var(--white);background:var(--oxblood);padding:14px 32px;border:none;border-radius:4px;cursor:pointer;transition:all .35s cubic-bezier(.16,1,.3,1)}
.btn-primary:hover{background:var(--oxblood-hover);transform:translateY(-2px);box-shadow:0 8px 32px rgba(155,27,48,.2)}
.btn-sm{font-size:14px;padding:10px 24px}
.oxlink{color:var(--oxblood);font-weight:500;transition:opacity .3s}.oxlink:hover{opacity:.7}
.desktop-only{display:block}.mobile-only{display:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.95);backdrop-filter:blur(24px);border-bottom:1px solid var(--border-light);transition:all .5s cubic-bezier(.16,1,.3,1)}
.nav.scrolled{box-shadow:0 1px 16px rgba(2,8,23,0.05)}
.nav-inner{max-width:100%;margin:0 auto;padding:0 10vw;height:68px;display:flex;align-items:center;justify-content:space-between;transition:height .5s cubic-bezier(.16,1,.3,1)}
.nav.scrolled .nav-inner{height:56px}
.nav-left{display:flex;align-items:center;gap:10px}
.nav-mark{display:flex;align-items:center;height:22px}.nav-mark img{height:22px;width:auto;border-radius:3px}
.nav-logo{font-family:var(--font-heading);font-size:22px;font-weight:400;color:var(--ink);cursor:pointer}
.nav-logo .letter{display:inline-block;transition:transform .3s cubic-bezier(.34,1.56,.64,1),color .3s ease}
.nav-logo .letter-cap{color:var(--oxblood)}.nav-logo:hover .letter-cap{transform:translateY(-2px)}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-link{font-family:var(--font-body);font-size:13px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);opacity:.55;transition:opacity .3s ease;position:relative;white-space:nowrap}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--ink);transition:width .3s cubic-bezier(.16,1,.3,1)}
.nav-link:hover{opacity:1}.nav-link:hover::after{width:100%}
.nav-cta{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--white);background:var(--oxblood);padding:9px 22px;border-radius:4px;transition:all .35s cubic-bezier(.16,1,.3,1);white-space:nowrap}
.nav-cta:hover{background:var(--oxblood-hover);transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all .3s ease;transform-origin:center}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.nav-toggle.open span:nth-child(2){opacity:0}.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* HERO */
.hero{height:100vh;min-height:520px;max-height:800px;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(to right,var(--ink) 50%,var(--parchment) 50%);padding-top:68px}
.hero-container{max-width:100%;margin:0 auto;padding:0 10vw;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:stretch;position:relative;z-index:2;padding-top:48px}
.hero-left{display:flex;flex-direction:column;gap:12px;justify-content:flex-start;align-items:flex-end;text-align:right}
.hero-phrase{font-family:var(--font-heading);font-size:clamp(36px,4.8vw,62px);line-height:1.15;font-weight:400;color:var(--white);opacity:0;transform:translateY(8px)}
.hero.final .hero-phrase{opacity:1;transform:translateY(0)}
.hero.animating .hero-phrase:nth-child(1){animation:fu 1.2s cubic-bezier(.16,1,.3,1) 1.6s forwards}
.hero.animating .hero-phrase:nth-child(2){animation:fu 1.2s cubic-bezier(.16,1,.3,1) 2.6s forwards}
.hero.animating .hero-phrase:nth-child(3){animation:fu 1.2s cubic-bezier(.16,1,.3,1) 3.6s forwards}
.hero-right{display:flex;flex-direction:column;justify-content:flex-start;padding-top:clamp(35px,calc(3.5vw + 6px),52px)}
.hero-thesis{font-family:var(--font-heading);font-size:clamp(26px,2.9vw,42px);line-height:1.95;color:var(--ink);opacity:0;transform:translateY(8px)}
.hero.final .hero-thesis{opacity:1;transform:translateY(0)}
.hero.animating .hero-thesis{animation:fu 1.4s cubic-bezier(.16,1,.3,1) 4.6s forwards}
.hero-cta{margin-top:120px;align-self:flex-end;opacity:0;transform:translateY(8px)}
.hero.final .hero-cta{opacity:1;transform:translateY(0)}
.hero.animating .hero-cta{animation:fu 1s cubic-bezier(.16,1,.3,1) 5.2s forwards}
@keyframes fu{to{opacity:1;transform:translateY(0)}}
@media(min-width:1200px) and (max-width:1599px){
  .nav-inner{padding:0 7vw}
  .hero-container{padding:0 7vw;gap:72px}
  .hero-phrase{font-size:clamp(34px,3.8vw,50px)}
  .hero-thesis{font-size:clamp(24px,2.3vw,34px)}
  .hero-right{padding-top:clamp(28px,2.6vw,40px)}
  .hero-cta{margin-top:100px;margin-right:65px}
}

/* TRANSITION */
.transition-section{padding:48px 10vw 64px;text-align:center;background:var(--white)}
.ts-line{font-family:var(--font-heading);font-size:22px;line-height:34px;color:var(--caption);margin:0 auto 8px;white-space:nowrap;opacity:0;transform:translateY(10px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.ts-red{font-family:var(--font-heading);font-size:26px;line-height:36px;color:var(--oxblood);max-width:560px;margin:0 auto 16px;opacity:0;transform:translateY(10px);transition:all .7s cubic-bezier(.16,1,.3,1) .15s}
.ts-bold{font-family:var(--font-heading);font-size:22px;line-height:34px;color:var(--caption);max-width:560px;margin:0 auto;font-weight:400;opacity:0;transform:translateY(10px);transition:all .7s cubic-bezier(.16,1,.3,1) .3s}
.ts-line.in-view,.ts-red.in-view,.ts-bold.in-view{opacity:1;transform:translateY(0)}

/* RELEVANCE — card layout with arrows */
.relevance-grid{max-width:100%;margin:0 auto;padding:36px 10vw 44px;background:var(--white)}
.rg-labels{display:grid;grid-template-columns:1fr 40px 1fr;gap:0 16px;margin-bottom:20px}
.rg-h-left,.rg-h-right{font-family:var(--font-heading);font-size:calc(var(--h3) * 1.1);line-height:calc(var(--h3-lh) * 1.1);font-weight:700;padding-bottom:18px;opacity:0;transform:translateY(12px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.rg-h-left.in-view,.rg-h-right.in-view{opacity:1;transform:translateY(0)}
.rg-h-spacer{width:40px}
.rg-rows{display:flex;flex-direction:column;gap:14px}
.rg-row{display:grid;grid-template-columns:1fr 40px 1fr;align-items:stretch;gap:0 16px;opacity:0;transform:translateY(8px);transition:all .5s cubic-bezier(.16,1,.3,1)}
.rg-row.in-view{opacity:1;transform:translateY(0)}
.rg-left{background:var(--white);border:1px solid var(--border);border-radius:8px;padding:22px 28px;display:flex;align-items:flex-start}
.rg-left p{font-family:var(--font-body);font-size:16px;color:#4A4540;line-height:1.55;font-weight:400;margin:0}
.rg-arrow{display:flex;align-items:center;justify-content:center}
.rg-arrow svg{width:28px;height:12px;display:block}
.rg-right{background:#E8DFD0;border:1px solid #DDD5C5;border-radius:8px;padding:22px 28px;display:flex;align-items:flex-start}
.rg-right p{font-family:var(--font-body);font-size:16px;color:var(--ink);line-height:1.55;font-weight:400;margin:0}

/* DIAGRAM — two-column layout */
.diagram-section{padding:56px 0 60px;background:var(--parchment)}
.diagram-layout{display:grid;grid-template-columns:1fr 1fr;gap:0 40px;align-items:center;padding:0}
.diagram-text-col{display:flex;flex-direction:column;justify-content:center}
.diagram-title{font-family:var(--font-heading);font-size:var(--h2);line-height:var(--h2-lh);font-weight:400;margin-bottom:16px;text-align:left}
.diagram-intro{font-family:var(--font-heading);font-size:20px;line-height:32px;color:var(--ink);margin-bottom:0;text-align:left;max-width:100%;opacity:0;transform:translateY(10px);transition:all .8s ease .2s}
.diagram-section.in-view .diagram-intro{opacity:1;transform:translateY(0)}
.diagram-sub{font-family:var(--font-heading);font-size:17.1px;line-height:28.5px;color:var(--ink);margin-top:8px;text-align:left;opacity:0;transform:translateY(10px);transition:all .8s ease .8s}
.diagram-section.in-view .diagram-sub{opacity:1;transform:translateY(0)}
.diagram-visual-col{display:flex;flex-direction:column;align-items:center}
.diagram-system-label{font-family:var(--font-body);font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--caption);text-align:center;margin-bottom:16px;opacity:0;transform:translateY(10px);transition:all .8s ease .1s}
.diagram-section.in-view .diagram-system-label{opacity:1;transform:translateY(0)}
.diagram-closing{font-family:var(--font-heading);font-size:20px;line-height:32px;color:var(--oxblood);font-style:italic;margin-top:12px;text-align:center;opacity:0;transform:translateY(10px);transition:all .8s ease .6s}
.diagram-section.in-view .diagram-closing{opacity:1;transform:translateY(0)}
.diagram-container{max-width:100%;width:100%;margin:0 auto;transform:none}
.diagram-svg{width:100%;height:auto;overflow:visible}
.pill-track{stroke:#C8C3BB;stroke-width:3;fill:none;opacity:0;transition:opacity .8s ease .4s}
.diagram-section.in-view .pill-track{opacity:1}
.pill-pulse{stroke:var(--oxblood);stroke-width:3.5;fill:none;stroke-linecap:round;stroke-dasharray:180 1340;stroke-dashoffset:1520;opacity:0}
.diagram-section.in-view .pill-pulse{opacity:.6;animation:pillCW 7s linear 1.4s infinite}
@keyframes pillCW{from{stroke-dashoffset:1520}to{stroke-dashoffset:0}}
.pill-ghost{stroke:var(--oxblood);stroke-width:3;fill:none;stroke-linecap:round;stroke-dasharray:80 1440;stroke-dashoffset:1520;opacity:0}
.diagram-section.in-view .pill-ghost{opacity:.2;animation:pillCW 7s linear 3.5s infinite}
.diagram-arrow{fill:#000;opacity:0;transition:opacity .5s ease}
.diagram-section.in-view .diagram-arrow{opacity:1}
.diagram-node rect{stroke-width:1.6}
.diagram-node text{font-weight:600}
.diagram-svg text{font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.diagram-section.in-view .da1{transition-delay:.5s}.diagram-section.in-view .da2{transition-delay:.65s}.diagram-section.in-view .da3{transition-delay:.8s}.diagram-section.in-view .da4{transition-delay:.95s}.diagram-section.in-view .da5{transition-delay:1.1s}.diagram-section.in-view .da6{transition-delay:1.25s}
.diagram-node{opacity:0;transition:opacity .6s ease}
.diagram-section.in-view .diagram-node{opacity:1}
.diagram-section.in-view .dn1{transition-delay:.15s}.diagram-section.in-view .dn2{transition-delay:.3s}.diagram-section.in-view .dn3{transition-delay:.45s}.diagram-section.in-view .dn4{transition-delay:.6s}.diagram-section.in-view .dn5{transition-delay:.75s}.diagram-section.in-view .dn6{transition-delay:.9s}
.diagram-center{opacity:0;transition:opacity .8s ease 1s}
.diagram-section.in-view .diagram-center{opacity:1}
.diagram-annotation{opacity:0;transition:opacity .8s ease 1.3s}
.diagram-section.in-view .diagram-annotation{opacity:1}

/* CASE STUDIES */
.case-studies{padding:52px 0;background:var(--white)}
.section-heading{font-size:var(--h2);line-height:var(--h2-lh);margin-bottom:24px;position:relative;display:inline-block;opacity:0;transform:translateY(12px);transition:all .8s cubic-bezier(.16,1,.3,1)}
.section-heading.in-view{opacity:1;transform:translateY(0)}
.section-heading::after{content:'';position:absolute;bottom:-8px;left:0;width:0;height:2px;background:var(--oxblood);transition:width .8s cubic-bezier(.16,1,.3,1) .3s}
.section-heading.in-view::after{width:36px}
.case-intro{font-size:var(--body);line-height:var(--body-lh);color:var(--caption);margin-bottom:12px;max-width:720px}
.case-intro-flow{font-size:17px;line-height:26px;color:var(--ink);margin-bottom:10px;font-weight:600;letter-spacing:.02em;white-space:nowrap}
.case-intro-sub{font-size:15px;color:var(--caption);margin-bottom:28px;font-style:italic}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.case-card{background:var(--parchment);border-radius:12px;padding:26px 26px 22px;cursor:pointer;position:relative;overflow:hidden;opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease,box-shadow .3s ease;display:flex;flex-direction:column;border:1px solid var(--border-light)}
.case-card.in-view{opacity:1;transform:translateY(0)}
.case-card:hover{box-shadow:0 8px 32px rgba(2,8,23,.06);border-color:var(--border);transform:translateY(-3px)}
.case-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--oxblood);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.case-card:hover::before{transform:scaleX(1)}
.card-metric{font-family:var(--font-heading);font-size:30px;line-height:36px;font-weight:770;color:var(--oxblood);margin-bottom:8px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.card-headline{font-family:var(--font-heading);font-size:16px;line-height:24px;font-weight:400;margin-bottom:10px}
.card-context{font-family:var(--font-body);font-size:13px;line-height:20px;color:#5C6370;margin-bottom:14px;flex:1}
.card-link{font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--oxblood);margin-top:auto;transition:opacity .3s ease}
.card-link:hover{opacity:.7}
.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.card-pill{font-family:var(--font-body);font-size:10px;font-weight:500;letter-spacing:.03em;color:var(--oxblood);background:transparent;border:1px solid var(--oxblood);padding:3px 10px;border-radius:100px;white-space:nowrap}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(2,8,23,.55);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s;padding:40px}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-panel{background:var(--white);border-radius:16px;max-width:680px;width:100%;max-height:85vh;overflow-y:auto;padding:44px;position:relative;transform:translateY(24px) scale(.97);opacity:0;transition:all .45s cubic-bezier(.16,1,.3,1) .05s;box-shadow:0 32px 64px rgba(2,8,23,.18)}
.modal-overlay.open .modal-panel{transform:translateY(0) scale(1);opacity:1}
.modal-close{position:absolute;top:18px;right:18px;width:34px;height:34px;background:none;border:1px solid var(--border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:var(--ink);font-size:15px}
.modal-close:hover{background:var(--ink);border-color:var(--ink);color:var(--white)}
.modal-metric{font-family:var(--font-heading);font-size:var(--h2);line-height:var(--h2-lh);color:var(--oxblood);margin-bottom:6px}
.modal-title{font-family:var(--font-heading);font-size:var(--h3);line-height:var(--h3-lh);margin-bottom:20px}
.modal-divider{border:none;border-top:1px solid var(--border);margin:0 0 20px 0}
.modal-label{font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.modal-body{margin-bottom:18px}.modal-body p{margin-bottom:10px;max-width:100%;font-size:16px;line-height:26px}.modal-body p:last-child{margin-bottom:0}
.modal-body ul{list-style:none;padding:0;margin:0}.modal-body li{position:relative;padding:5px 0 5px 18px;font-size:16px;line-height:26px}.modal-body li::before{content:'\00b7';position:absolute;left:0;top:5px;color:var(--oxblood);font-size:22px;line-height:26px}
.modal-context-label{font-family:var(--font-body);font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.modal-context-body{margin-bottom:18px}.modal-context-body p{margin-bottom:10px;max-width:100%;font-size:16px;line-height:26px;color:var(--caption);font-style:italic}.modal-context-body p:last-child{margin-bottom:0}
.modal-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.modal-tag{font-size:12px;font-weight:500;padding:5px 14px;border:1px solid var(--border);border-radius:100px;color:var(--caption)}

/* HOW I WORK */
.how-i-work{padding:48px 0;background:var(--parchment)}
.how-layout{display:grid;grid-template-columns:220px 1fr 1.2fr 1fr;gap:0;align-items:stretch}
.how-layout-heading{padding-right:32px;display:flex;align-items:flex-start}
.how-col{padding:0 28px;border-left:3px solid var(--oxblood);display:flex;flex-direction:column}
.how-col-title{font-family:var(--font-heading);font-size:var(--h4);line-height:var(--h4-lh);font-weight:700;margin-bottom:10px;opacity:0;transform:translateY(10px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.how-col-title.in-view{opacity:1;transform:translateY(0)}
.how-col-body{font-size:16px;line-height:26px;color:var(--caption);opacity:0;transform:translateY(10px);transition:all .7s cubic-bezier(.16,1,.3,1) .1s}
.how-col-body.in-view{opacity:1;transform:translateY(0)}

/* IDEAS */
.ideas-section{padding:48px 0;background:var(--white)}
.ideas-intro{font-size:var(--body);line-height:var(--body-lh);color:var(--caption);margin-bottom:6px}
.ideas-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px}
.ideas-link{font-family:var(--font-body);font-size:15px;font-weight:500;color:var(--oxblood);transition:opacity .3s}.ideas-link:hover{opacity:.7}
.ideas-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.idea-item{background:var(--parchment);border-radius:12px;padding:0;cursor:pointer;position:relative;overflow:hidden;opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease,box-shadow .3s ease;display:flex;flex-direction:column;border:1px solid var(--border-light)}
.idea-item.in-view{opacity:1;transform:translateY(0)}
.idea-item:hover{box-shadow:0 8px 32px rgba(2,8,23,.06);border-color:var(--border);transform:translateY(-3px)}
.idea-item::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--oxblood);transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.idea-item:hover::before{transform:scaleX(1)}
a.idea-item{color:inherit;text-decoration:none;display:flex;flex-direction:column}
.idea-thumb{width:100%;aspect-ratio:3/2;height:auto;object-fit:cover;display:block;border-radius:12px 12px 0 0}
.idea-thumb-placeholder{width:100%;aspect-ratio:3/2;background:var(--parchment);border-bottom:1px solid var(--border-light)}
.idea-content{padding:22px 24px 24px}
.idea-title{font-family:var(--font-heading);font-size:20px;line-height:28px;font-weight:700;margin-bottom:8px;transition:color .3s ease}
.idea-item:hover .idea-title{color:var(--oxblood)}
.idea-excerpt{font-size:15px;line-height:24px;color:var(--caption)}
.idea-excerpt:empty{display:none}

/* ABOUT */
.about{padding:48px 0;background:var(--parchment);overflow:hidden}
.about-inner{display:grid;grid-template-columns:160px 1fr 220px;gap:0 36px;align-items:start}
.about-heading{padding-top:4px}
.about-image{position:relative;opacity:0;transition:opacity 1s cubic-bezier(.16,1,.3,1) .2s}
.about-image.in-view{opacity:1}
.about-image::before{content:'';position:absolute;bottom:-25px;right:-5px;width:2px;height:95px;background:var(--oxblood);pointer-events:none}
.about-image::after{content:'';position:absolute;bottom:-5px;right:-25px;width:95px;height:2px;background:var(--oxblood);pointer-events:none}
.about-portrait{width:100%;display:block;border-radius:12px;box-shadow:0 8px 28px rgba(200,185,165,.3);filter:grayscale(8%) contrast(.97) brightness(1.02)}
.about-text{padding-top:8px;opacity:0;transform:translateY(12px);transition:all .8s cubic-bezier(.16,1,.3,1)}
.about-text.in-view{opacity:1;transform:translateY(0)}
.about-text p{margin-bottom:14px;font-size:16px;line-height:26px;max-width:100%}.about-text p:last-of-type{margin-bottom:0}
.about-exp{font-size:14px;color:var(--caption);margin-top:20px;font-style:italic}
.about-linkedin{margin-top:16px}.about-linkedin .oxlink{font-size:16px;font-weight:600}

/* WORKING TOGETHER */
.work-together{padding:48px 0 84px;text-align:center;background:var(--white)}
.work-together-inner{opacity:0;transform:translateY(20px);transition:all 1s cubic-bezier(.16,1,.3,1);max-width:600px;margin:0 auto}
.work-together-inner.in-view{opacity:1;transform:translateY(0)}
.wt-heading{font-size:var(--h2);line-height:var(--h2-lh);margin-bottom:12px}
.wt-subline{font-size:var(--body);line-height:var(--body-lh);color:#374151;margin-bottom:24px}
.wt-list{list-style:none;text-align:left;margin-bottom:42px;padding:0}
.wt-list li{padding:4px 0 4px 28px;position:relative;font-size:16px;line-height:24px;color:var(--ink)}
.wt-list li::before{content:'\2713';position:absolute;left:0;top:4px;color:var(--oxblood);font-size:17px;font-weight:720;line-height:24px}
.contact-form{display:none;text-align:left;margin-top:28px;padding-top:28px;border-top:1px solid var(--border)}
.contact-form.open{display:block}
.cf-field{margin-bottom:16px}
.cf-label{display:block;font-size:13px;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--caption);margin-bottom:6px}
.cf-input,.cf-textarea{width:100%;padding:10px 14px;font-family:var(--font-body);font-size:15px;border:1px solid var(--border);border-radius:4px;background:var(--white);transition:border-color .3s}
.cf-input:focus,.cf-textarea:focus{outline:none;border-color:var(--oxblood)}
.cf-textarea{min-height:80px;resize:vertical}
.cf-note{font-size:14px;color:var(--caption);margin-bottom:16px;font-style:italic}
.cf-submit{display:inline-block;font-family:var(--font-body);font-size:var(--button);font-weight:500;color:var(--white);background:var(--oxblood);padding:12px 28px;border:none;border-radius:4px;cursor:pointer;transition:all .3s}
.cf-submit:hover{background:var(--oxblood-hover)}
/* WPForms overrides — match original .cf-* styles exactly */
#contactForm .wpforms-container,#contactForm .wpforms-form{margin:0!important;padding:0!important;max-width:none!important}
#contactForm .wpforms-field{margin-bottom:16px!important;padding:0!important}
#contactForm .wpforms-field-label{display:block!important;font-family:var(--font-body)!important;font-size:13px!important;font-weight:500!important;letter-spacing:.03em!important;text-transform:uppercase!important;color:var(--caption)!important;margin-bottom:6px!important;padding:0!important}
#contactForm .wpforms-field-sublabel{display:none!important}
#contactForm .wpforms-field input[type="text"],#contactForm .wpforms-field input[type="email"]{width:100%!important;padding:10px 14px!important;font-family:var(--font-body)!important;font-size:15px!important;line-height:1.4!important;border:1px solid var(--border)!important;border-radius:4px!important;background:var(--white)!important;transition:border-color .3s!important;box-shadow:none!important;-webkit-appearance:none!important;height:auto!important}
#contactForm .wpforms-field input:focus,#contactForm .wpforms-field textarea:focus{border-color:var(--oxblood)!important;outline:none!important;box-shadow:none!important}
#contactForm .wpforms-field textarea{width:100%!important;padding:10px 14px!important;font-family:var(--font-body)!important;font-size:15px!important;line-height:1.4!important;border:1px solid var(--border)!important;border-radius:4px!important;background:var(--white)!important;min-height:80px!important;resize:vertical!important;box-shadow:none!important;-webkit-appearance:none!important;height:auto!important}
#contactForm .wpforms-field-description{font-size:14px!important;color:var(--caption)!important;font-style:italic!important;margin-top:4px!important}
#contactForm .wpforms-submit-container{padding:0!important;margin:0!important;text-align:left!important}
#contactForm .wpforms-submit-container button,#contactForm .wpforms-submit{display:inline-block!important;font-family:var(--font-body)!important;font-size:var(--button)!important;font-weight:500!important;color:var(--white)!important;background:var(--oxblood)!important;padding:12px 28px!important;border:none!important;border-radius:4px!important;cursor:pointer!important;transition:all .3s!important;box-shadow:none!important;text-transform:none!important;letter-spacing:0!important;line-height:1.4!important;width:auto!important}
#contactForm .wpforms-submit-container button:hover,#contactForm .wpforms-submit:hover{background:var(--oxblood-hover)!important}
#contactForm .wpforms-confirmation-container-full{font-family:var(--font-body)!important;font-size:14px!important;color:var(--caption)!important;font-style:italic!important}
#contactForm .wpforms-required-label{color:var(--oxblood)!important}
#contactForm .wpforms-field-medium{max-width:100%!important}

/* FOOTER */
.footer{background:var(--ink);color:rgba(255,255,255,.9);padding:56px 0}
.footer-grid{display:grid;grid-template-columns:1.2fr auto auto;gap:64px;align-items:start}
.footer-brand{display:flex;flex-direction:column;gap:12px}
.footer-logo{font-family:var(--font-heading);font-size:22px;font-weight:400;color:var(--white)}.footer-logo .lc{color:var(--oxblood)}
.footer-tagline{font-size:16px;line-height:25px;color:rgba(255,255,255,.85);max-width:420px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:15px;font-weight:500;color:rgba(255,255,255,.85);transition:all .3s ease}
.footer-links a:hover{font-size:16px;color:rgba(255,255,255,.95)}
.footer-bottom{margin-top:40px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:13px;color:rgba(255,255,255,.6);font-weight:400}
.footer-legal-link{color:rgba(255,255,255,.6);text-decoration:none;transition:color .3s}.footer-legal-link:hover{color:rgba(255,255,255,.9)}

/* LEGAL PAGES */
.legal-content h2{font-family:var(--font-heading);font-size:var(--h4);line-height:var(--h4-lh);font-weight:700;color:var(--ink);margin:28px 0 10px}
.legal-content p{margin-bottom:14px}
.legal-content a{color:var(--oxblood);text-decoration:none;transition:opacity .3s}.legal-content a:hover{opacity:.7}

/* MOBILE MENU */
.mobile-menu{position:fixed;inset:0;background:var(--white);z-index:999;padding:90px 48px 48px;display:flex;flex-direction:column;gap:24px;opacity:0;pointer-events:none;transition:opacity .3s ease}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu a{font-family:var(--font-heading);font-size:var(--h3);line-height:var(--h3-lh);color:var(--ink);opacity:0;transform:translateX(-16px);transition:all .4s cubic-bezier(.16,1,.3,1)}
.mobile-menu.open a{opacity:1;transform:translateX(0)}
.mobile-menu.open a:nth-child(1){transition-delay:.05s}.mobile-menu.open a:nth-child(2){transition-delay:.1s}.mobile-menu.open a:nth-child(3){transition-delay:.15s}
.mobile-menu a.mm-cta{color:var(--oxblood);font-weight:700}

/* TABLET */
@media(max-width:1199px){
  :root{--h1:44px;--h1-lh:54px;--h2:34px;--h2-lh:42px;--h3:24px;--h3-lh:32px;--body:17px;--body-lh:26px}
  .container{padding:0 6vw}.nav-inner{padding:0 6vw}.hero-container{padding:0 6vw;gap:40px}
  .relevance-grid{padding:36px 6vw 40px}.rg-labels{gap:0 12px}.rg-row{gap:0 12px}.rg-labels,.rg-row{grid-template-columns:1fr 36px 1fr}
  .diagram-layout{grid-template-columns:1fr 1fr;gap:0 24px}
  .transition-section{padding:40px 6vw}
  .how-layout{grid-template-columns:1fr;gap:0}.how-layout-heading{grid-column:1;margin-bottom:20px;padding-right:0}
  .how-col{padding:20px 0;border-left:none;border-top:2px solid var(--oxblood)}
  .how-col:nth-child(2){border-top:none;padding-top:0}
  .about-inner{gap:0 24px;grid-template-columns:140px 1fr 180px}
  .footer-grid{gap:40px}.case-grid{gap:16px}
}

/* MOBILE */
@media(max-width:767px){
  :root{--h1:36px;--h1-lh:46px;--h2:28px;--h2-lh:36px;--h3:22px;--h3-lh:30px;--body:16px;--body-lh:24px;--caption-size:13px;--button:15px}
  .container{padding:0 24px}.nav-inner{padding:0 24px;height:56px}.nav.scrolled .nav-inner{height:50px}
  .nav-links{display:none}.nav-toggle{display:flex}
  .nav-mark{height:18px}.nav-mark img{height:18px;border-radius:2px}
  section{padding:36px 0}
  .desktop-only{display:none}.mobile-only{display:block}
  .hero{min-height:100vh;max-height:none;height:100vh;padding:0;background:none;display:flex;flex-direction:column}
  .hero-container{display:flex;flex-direction:column;flex:1;gap:0;padding:0}
  .hero-left{gap:4px;background:var(--ink);padding:24px 24px;text-align:center;align-items:center;flex:1;display:flex;flex-direction:column;justify-content:center}
  .hero-phrase{font-size:clamp(32px,9vw,42px);color:var(--white)}
  .hero-right{background:var(--parchment);padding:16px 24px 24px;text-align:center;align-items:center;flex:1;display:flex;flex-direction:column;justify-content:center}
  .hero-thesis{font-size:clamp(20px,5vw,28px);line-height:1.1;color:var(--ink);margin:0 auto;position:relative;top:-12px}
  .hero-cta{margin-top:28px;align-self:center}.hero-cta .btn-sm{padding:16px 40px;font-size:15px}
  .transition-section{padding:20px 24px 22px}
  .ts-line{font-size:18px;line-height:24px;white-space:normal;margin-bottom:4px}.ts-red{font-size:21px;line-height:27px;margin-bottom:8px}.ts-bold{font-size:18px;line-height:24px}
  .relevance-grid{display:none}
  .diagram-layout{grid-template-columns:1fr;gap:14px 0}
  .diagram-text-col{align-items:center}
  .diagram-title{font-size:var(--h3);text-align:center;margin-bottom:10px}
  .diagram-intro{font-size:18px;line-height:27px;max-width:100%;text-align:center;margin-bottom:6px}
  .diagram-sub{font-size:16px;text-align:center}
  .diagram-container{max-width:100%;padding:0;transform:none;margin:2px 0 4px}
  .diagram-section{padding:32px 0 36px}
  .diagram-closing{font-size:18px;margin-top:12px}
  .diagram-system-label{margin-top:6px;margin-bottom:10px}
  .case-grid{grid-template-columns:1fr;gap:20px}
  .case-card{aspect-ratio:auto;min-height:auto}
  .card-metric{font-size:32px;line-height:38px;border-bottom-color:var(--border-light)}
  .case-intro-flow{white-space:normal;font-size:14px}
  .case-studies{padding:36px 0}
  .how-layout{grid-template-columns:1fr;gap:0}.how-layout-heading{margin-bottom:20px;padding-right:0}
  .how-col{padding:14px 0;border-left:none;border-top:2px solid var(--oxblood)}
  .how-col:nth-child(2){border-top:none;padding-top:0}
  .how-col-body{font-size:14px;line-height:22px;opacity:.7}
  .how-i-work{padding:36px 0}
  .ideas-list{grid-template-columns:1fr;gap:16px}
  .idea-title{font-size:19px;line-height:26px}
  .idea-excerpt{font-size:14px;line-height:22px}
  .idea-content{padding:18px 20px 20px}
  .ideas-section{padding:36px 0}
  .about-inner{grid-template-columns:1fr;gap:16px}
  .about-heading{order:1}
  .about-image{order:2;max-width:200px;margin:0 auto 24px}
  .about-text{order:3}
  .about{padding:36px 0}
  .work-together{padding:40px 0 80px}
  .wt-list{margin-bottom:36px}
  .footer{padding:64px 0 40px}
  .mobile-menu{padding:72px 24px 48px}
  .modal-overlay{padding:12px}.modal-panel{padding:28px 20px;border-radius:12px}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-links{gap:20px}
  .footer-links a{font-size:16px;padding:4px 0;display:inline-block}
  .footer-tagline{font-size:15px;color:rgba(255,255,255,.8)}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
}
