/* ══════════════════════════════════════════
   SUNAMI GROUP — STYLESHEET
   Pattern system: full-bleed, half-coverage,
   corner treatment, stripe accent
   ══════════════════════════════════════════ */

/* ─────────── LENIS SMOOTH SCROLL ─────────── */
html.lenis, html.lenis body {
  height: auto;
}
.lenis-smooth {
  scroll-behavior: auto !important;
}
.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}
.lenis-stopped {
  overflow: hidden;
}
.lenis-scrolling iframe {
  pointer-events: none;
}

:root{
    --black:#050505;
    --white:#ffffff;
    --gray:#8892b0;
    --blue:#1C3654;
    --card:#0c0c0c;
    --border:rgba(255,255,255,.12);
    
    /* SVG chevron shading variables mapped to the original blue color scheme */
    --color-shade-1:#1C3654;
    --color-shade-2:#18304a;
    --color-shade-3:#142536;
    --dot-color:#1C3654;
    --bg-glow:rgba(28,54,84,.25);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    background:var(--black);
    color:var(--white);
    font-family:'Inter',sans-serif;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}

/* ─────────── TYPOGRAPHY ─────────── */
h1{font-size:120px;font-weight:900;line-height:.88;letter-spacing:-.04em;text-transform:uppercase}
h2{font-size:48px;font-weight:900;line-height:.92;letter-spacing:-.02em;text-transform:uppercase}
h3{font-size:18px;font-weight:700;line-height:1.3;text-transform:uppercase}
p{font-size:16px;line-height:1.6;color:var(--gray)}
strong{color:var(--white)}
em{font-style:italic}

/* ─────────── SQUARE PERIOD ─────────── */
.dot{display:inline-block;width:.2em;height:.2em;background:var(--blue);vertical-align:baseline;margin-left:.06em;position:relative}
.dot.sm{width:.25em;height:.25em}
.dot.md{width:.18em;height:.18em}
.dot.blue{background:var(--blue)}

/* ─────────── LABELS ─────────── */
.label{font-size:14px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:2px;display:block;margin-bottom:8px}

/* ─────────── BUTTONS ─────────── */
.btn{display:inline-block;padding:14px 28px;font-size:14px;font-weight:700;text-decoration:none;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .3s ease}
.btn.filled{background:var(--blue);color:var(--white);border:2px solid var(--blue)}
.btn.filled:hover{filter:brightness(1.15);transform:translateY(-2px)}
.btn.outline{background:transparent;color:var(--white);border:2px solid rgba(255,255,255,.3)}
.btn.outline:hover{border-color:var(--white);transform:translateY(-2px)}
.btn.outline.white{border-color:var(--white)}
.btn.full{width:100%;text-align:center;font-size:16px}
.btn.full:hover{filter:brightness(1.15)}

/* ─────────── NAVBAR ─────────── */
#navbar{position:fixed;top:0;left:0;right:0;z-index:999;display:flex;justify-content:space-between;align-items:center;padding:20px 5%;background:rgba(5,5,5,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:background .3s}
.logo{font-size:28px;font-weight:900;letter-spacing:1px;color:var(--white)}
.logo .dot{background:var(--blue)}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-right a{color:var(--white);text-decoration:none;font-size:15px;font-weight:400;opacity:.85;transition:opacity .2s}
.nav-right a:hover{opacity:1}
.sep{color:var(--gray);font-size:12px;opacity:.4}
.nav-cta{border:2px solid var(--blue);padding:8px 20px !important;font-weight:700 !important;opacity:1 !important;transition:all .3s !important}
.nav-cta:hover{background:var(--blue) !important}

/* Hamburger toggle — hidden on desktop, shown ≤768px */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;background:none;border:none;cursor:pointer;padding:9px;z-index:1001}
.nav-toggle span{display:block;width:100%;height:2px;background:var(--white);border-radius:2px;transition:transform .3s ease,opacity .25s ease}

@media(max-width:768px){
    .nav-toggle{display:flex}
    .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
    .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
    .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
    .nav-right{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:rgba(5,5,5,.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:8px 5% 22px;max-height:0;overflow:hidden;opacity:0;pointer-events:none;transition:max-height .35s ease,opacity .25s ease}
    #navbar.nav-open .nav-right{max-height:85vh !important;opacity:1 !important;pointer-events:auto !important}
    .nav-right a{width:100%;padding:15px 2px;font-size:18px;border-bottom:1px solid var(--border)}
    .nav-right .sep{display:none}
    .nav-cta{margin-top:14px;text-align:center;border:2px solid var(--blue) !important;border-radius:6px;padding:14px 20px !important}
    .nav-cta:last-child{border-bottom:2px solid var(--blue)}
}


/* ══════════════════════════════════════════
   PATTERN SYSTEM — .pat is the unified class
   for all chevron geometric backgrounds.
   Each variation is positioned differently.
   ══════════════════════════════════════════ */

.pat, .draw-ribbon {
    will-change: transform, opacity;
    transform-style: preserve-3d;
    backface-visibility: hidden;
}

/* HERO — original zigzag ribbons on the right side */
.hero-chevron-wrap{
    position:absolute;
    top:-10vh;right:-10vw;bottom:0;
    width:60vw;
    z-index:1;
    pointer-events:none;
}
.pat-hero{
    width:140%;height:120%;
    display:block;
    opacity:.9;
}

/* RESULTS STRIP — full-bleed behind stats */
.pat-results-strip{
    position:absolute;inset:0;
    width:100%;height:100%;
    z-index:0;
}

/* CORNER TREATMENT — right side, top */
.pat-corner-right{
    position:absolute;top:0;right:0;
    width:250px;height:100%;
    z-index:0;pointer-events:none;
    opacity:.85;
}

/* CORNER TREATMENT — left side, top */
.pat-corner-left{
    position:absolute;top:0;left:0;
    width:200px;height:60%;
    z-index:0;pointer-events:none;
    opacity:.7;
}

/* ABOUT — half-coverage, fills right column */
.pat-about{
    position:absolute;top:-10vh;left:-30%;
    width:180%;height:120%;
}

/* CTA BANNER — full-bleed */
.pat-cta{
    position:absolute;inset:0;
    width:100%;height:100%;
    z-index:0;
}

/* CONTACT — fills right column */
.pat-contact{
    position:absolute;
    inset:0;
    width:100%;height:100%;
    z-index:0;
}

/* FOOTER — stripe accent, bottom-right */
.pat-footer{
    position:absolute;bottom:0;right:0;
    width:180px;height:80px;
    z-index:1;
}


/* ══════════ 1 · HERO ══════════ */
#hero {
    position:relative;
    min-height:100vh;
    display:flex;
    align-items:center;
    overflow:hidden !important;
}
.pin-spacer {
    overflow: visible !important;
}

/* ─────────── TYPEWRITER ─────────── */
.type-header {
    display: inline-block;
}
.cursor {
    position: absolute;
    display: inline-block;
    width: 6px;
    background-color: var(--blue);
    margin-left: 4px;
    pointer-events: none;
    z-index: 5;
}
.cursor.blink {
    animation: blink-anim 0.8s step-end infinite;
}
@keyframes blink-anim {
    50% { opacity: 0; }
}
.hero-content{
    position:relative;z-index:2;
    padding:0 5%;
    width:100%;            /* full width so text can overlap chevrons */
    padding-top:0;
}
#hero h1{
    font-size:120px;
    line-height:.9;
    max-width:none;        /* let "MANAGED." extend into chevron area */
}
.hero-sub{margin:24px 0 36px;font-size:18px;color:var(--gray);line-height:1.7;max-width:450px}
.btn-row{display:flex;gap:16px;flex-wrap:wrap}


/* ══════════ 2 · SERVICES ══════════ */
#services {
    z-index: 100; /* Protects against GSAP pin-spacer escalation */
}
.sec{padding:100px 0;position:relative;overflow:hidden}
.wrap{max-width:1300px;margin:0 auto;padding:0 5%;position:relative;z-index:2}
.sub{margin-top:12px;margin-bottom:48px;max-width:700px}

.sec-header{text-align:center;display:flex;flex-direction:column;align-items:center}
.sec-header .sub{text-align:center}

.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.card{background:transparent;border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:16px 20px 20px 20px;position:relative;transition:border-color .3s,transform .3s,box-shadow .3s;overflow:hidden;}

.card-num {
    font-size: 80px;
    font-weight: 900;
    color: var(--blue);
    line-height: 1;
    margin-bottom: 6px;
    letter-spacing: -2px;
}
.card h3 {
    margin-bottom: 4px;
    font-size: 20px;
}
.card p {
    font-size: 13px;
    line-height: 1.5;
}

.card:hover{border-color:rgba(255,255,255,0.3);transform:translateY(-4px)}

.card.active {
    border-color: #fff;
    box-shadow: 0 0 30px rgba(255,255,255,0.1);
    transform: translateY(-8px);
}
.card.active h3 {
    text-shadow: 0 0 15px rgba(255,255,255,0.3);
}

/* ══════════ 3 · RESULTS ══════════ */
#results{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:120px 0;background:#0a0a0a;position:relative;z-index:10;box-sizing:border-box}
.results-top{text-align:center;padding:0 5%;margin-bottom:48px}
.results-top .sub{margin:16px auto 0;max-width:640px}
.results-strip{position:relative;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stats-row{display:none;} /* fallback block */
.horizontal-track{position:relative;z-index:2;display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;max-width:1300px;margin:0 auto;padding:80px 5%;gap:20px}
.horizontal-track .stat{border-left:none;padding:0;flex-shrink:1}
.horizontal-track .track-chevron{width:80px;align-self:stretch;flex-shrink:0;display:flex;align-items:stretch;padding: 10px 0;}
.horizontal-track .track-chevron svg{width:100%;height:100%;}
.stat h2{font-size:80px;font-weight:900;line-height:1;margin-bottom:12px;color:#ffffff !important}
.stat p{font-size:14px;color:#ffffff !important;opacity:.9}
.strip-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;background:rgba(5,5,5,.4);border:2px solid var(--border);color:var(--white);font-size:28px;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s}
.strip-nav:hover{background:var(--bg-glow);border-color:var(--dot-color)}
.strip-nav.left{left:16px}
.strip-nav.right{right:16px}


/* ══════════ 4 · PHILOSOPHY ══════════ */
.belief-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:48px 0 60px;align-items:stretch}
.belief{background-color:var(--card);border:1px solid var(--border);padding:32px 28px;position:relative;transition:border-color .3s,transform .3s;
  background-image:
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue)),
    linear-gradient(var(--blue),var(--blue)),linear-gradient(var(--blue),var(--blue));
  background-size:
    24px 3px,3px 24px,
    24px 3px,3px 24px,
    24px 3px,3px 24px,
    24px 3px,3px 24px;
  background-position:
    0 0,0 0,
    100% 0,100% 0,
    0 100%,0 100%,
    100% 100%,100% 100%;
  background-repeat:no-repeat}
.belief:hover{border-color:var(--blue);transform:translateY(-3px)}
.belief h3{margin-bottom:10px}
.belief p{font-size:14px}
.why-vc{border-top:1px solid var(--border);padding-top:48px}
.why-vc h2{margin-bottom:20px}
.why-vc p{max-width:740px;margin-bottom:12px}


/* ══════════ 5 · ABOUT ══════════ */
.about-split{display:grid;grid-template-columns:1fr 1fr;min-height:80vh}
.about-text{padding:100px 5%;max-width:700px}
.about-text h1{margin-bottom:24px}
.about-intro{font-size:18px;margin-bottom:48px}
.about-text h2{margin:48px 0 20px}
.about-text p{margin-bottom:16px}
.about-geo{position:relative;overflow:hidden}


/* ══════════ 6 · PROCESS + CTA ══════════ */
.timeline{position:relative;margin-top:48px;overflow:visible}
.timeline-line{width:100%;height:180px;position:absolute;top:0;left:0;z-index:1;overflow:visible}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding-top:80px;position:relative;z-index:2}
.step{text-align:center}
.step .num{font-size:80px;font-weight:900;color:var(--blue);line-height:1;display:inline-block;margin-bottom:24px;position:relative;z-index:2;background:var(--black);padding:0 8px}
.step h3{margin-bottom:8px}
.step p{font-size:14px}
.cta-banner{position:relative;overflow:hidden;margin-top:80px;text-align:center;padding:80px 5%}
.cta-inner{position:relative;z-index:2}
.cta-inner h1{margin-bottom:32px}


/* ══════════ 7 · CASE STUDIES ══════════ */
.heading-border-wrap{position:relative;padding:16px 32px}
.heading-border-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:block}

.cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start;margin-top:48px}
.cs-card{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--blue);transition:border-color .3s}
.cs-card.open{border-color:var(--blue)}
/* Collapsed head (clickable) */
.cs-card-head{padding:36px 34px 34px;cursor:pointer;display:block;transition:background .25s}
.cs-card-head:hover{background:rgba(255,255,255,.025)}
.cs-card-head:focus-visible{outline:2px solid var(--blue);outline-offset:-2px}
.cs-num{display:block;font-size:60px;font-weight:900;color:var(--blue);line-height:1;letter-spacing:-2px;margin-bottom:6px}
.cs-title{font-size:32px;font-weight:900;text-transform:uppercase;line-height:1.04;letter-spacing:-.01em}
.cs-era{display:block;margin-top:12px;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue)}
.cs-summary{margin-top:18px;font-size:15px;line-height:1.6;color:var(--gray);min-height:48px}
.cs-stats{display:grid;grid-template-columns:1fr 1fr;gap:24px 20px;margin-top:26px}
.cs-stats strong{display:block;font-size:38px;font-weight:900;color:var(--white);line-height:1;letter-spacing:-1.5px}
.cs-stats small{display:block;margin-top:8px;font-size:12px;color:var(--gray);line-height:1.35}
.cs-toggle{display:inline-flex;align-items:center;gap:9px;margin-top:28px;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--white)}
.cs-chevron{font-size:16px;color:var(--blue);transition:transform .35s ease;line-height:1}
.cs-card.open .cs-chevron{transform:rotate(180deg)}
/* Expandable detail */
.cs-detail{max-height:0;overflow:hidden;transition:max-height .45s ease}
.cs-detail-inner{padding:6px 34px 36px;border-top:1px solid var(--border)}
.cs-block{padding-top:26px}
.cs-block h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--blue);margin-bottom:12px}
.cs-detail p{font-size:15px;line-height:1.7;color:var(--gray);margin-bottom:12px}
.cs-detail strong{color:var(--white)}
.cs-quote{font-size:19px;line-height:1.5;color:var(--white);font-style:italic;border-left:3px solid var(--blue);padding-left:20px;margin:0 0 16px}
.cs-cap{font-size:12px;color:var(--gray);margin-top:8px}
.cs-foot{font-size:14px;line-height:1.6;color:var(--gray);margin-top:24px}
/* PO growth — line chart (draws on expand) */
.cs-linechart{margin:20px 0 8px;max-width:560px}
.line-svg{width:100%;height:auto;display:block;overflow:visible}
.line-area{opacity:0;transition:opacity .8s ease .35s}
.cs-card.open .line-area{opacity:1}
.line-path{stroke-dasharray:560;stroke-dashoffset:560;transition:stroke-dashoffset 1.2s cubic-bezier(.4,0,.2,1)}
.cs-card.open .line-path{stroke-dashoffset:0}
.line-pts circle{fill:#fff;opacity:0;transition:opacity .4s ease .7s}
.line-pts circle.peak{fill:var(--blue)}
.cs-card.open .line-pts circle{opacity:1}
.line-vals text{fill:#fff;font-size:13px;font-weight:700;text-anchor:middle;opacity:0;transition:opacity .5s ease .8s}
.line-vals text.peak-val{font-size:22px;font-weight:900;fill:#fff;transition-delay:1.05s}
.cs-card.open .line-vals text{opacity:1}
.line-x text{fill:var(--gray);font-size:12px;font-weight:700;text-anchor:middle}
/* US retail footprint map (real US map + store dots that fade in on expand) */
.cs-map{margin:18px 0 4px}
.usmap{position:relative;width:100%;max-width:520px;aspect-ratio:917/577}
.usmap-img{width:100%;height:100%;display:block;object-fit:contain;opacity:.92}
.map-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:#5b9bd5;transform:translate(-50%,-50%);box-shadow:0 0 7px 1px rgba(91,155,213,.55);opacity:0;transition:opacity .55s ease .15s}
.cs-card.open .map-dot{opacity:1;animation:dotPulse 2.6s ease-in-out infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 6px 0 rgba(91,155,213,.45)}50%{box-shadow:0 0 12px 2px rgba(91,155,213,.85)}}


/* ══════════ 8 · TEAM ══════════ */
#team{position:relative;overflow:hidden}
.founder-row{display:grid;grid-template-columns:200px 1fr;gap:32px;margin:48px 0;padding-bottom:48px;border-bottom:1px solid var(--border)}
.founder-img{width:200px;height:240px;background:#0f0f0f;border:1px solid var(--border);border-radius:8px;overflow:hidden;background-repeat:no-repeat;background-position:center;background-size:80px;background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23555'%20stroke-width='1.5'%3E%3Ccircle%20cx='12'%20cy='8'%20r='4'/%3E%3Cpath%20d='M4%2020c0-4%204-6%208-6s8%202%208%206'/%3E%3C/svg%3E")}
.founder-img img{width:100%;height:100%;object-fit:cover;display:block}
.founder-info h2{font-size:48px;margin-bottom:4px}

/* ── LEADERSHIP (two-up) ── */
.leadership{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:48px 0;padding-bottom:48px;border-bottom:1px solid var(--border)}
.leader{display:grid;grid-template-columns:150px 1fr;gap:22px;align-items:start}
.leader-img{width:150px;height:188px;background:#0f0f0f;border:1px solid var(--border);border-radius:8px;overflow:hidden;background-repeat:no-repeat;background-position:center;background-size:70px;background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23555'%20stroke-width='1.5'%3E%3Ccircle%20cx='12'%20cy='8'%20r='4'/%3E%3Cpath%20d='M4%2020c0-4%204-6%208-6s8%202%208%206'/%3E%3C/svg%3E")}
.leader-img img{width:100%;height:100%;object-fit:cover;display:block}
.leader-info h2{font-size:28px;margin-bottom:4px;line-height:1.05}
.leader-info .label{margin-bottom:12px}
.leader-info p{font-size:14px;line-height:1.6;color:var(--gray)}

/* ── TEAM PHOTO GRID ── */
.team-intro{margin:52px 0 24px}
.team-intro h2{margin-bottom:10px}
.team-intro p{font-size:15px}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:56px}
.team-member{display:flex;flex-direction:column}
.team-photo{aspect-ratio:4/5;background:#0f0f0f;border:1px solid var(--border);border-radius:8px;overflow:hidden;background-repeat:no-repeat;background-position:center;background-size:76px;background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23555'%20stroke-width='1.5'%3E%3Ccircle%20cx='12'%20cy='8'%20r='4'/%3E%3Cpath%20d='M4%2020c0-4%204-6%208-6s8%202%208%206'/%3E%3C/svg%3E");transition:border-color .3s,transform .3s}
.team-member:hover .team-photo{border-color:var(--blue);transform:translateY(-4px)}
.team-photo img{width:100%;height:100%;object-fit:cover;display:block}
.team-name{font-size:17px;font-weight:700;text-transform:none;margin-top:14px}
.team-role{font-size:12px;color:var(--blue);font-weight:700;text-transform:uppercase;letter-spacing:1.5px;margin-top:3px}
.founder-info .label{margin-bottom:16px}
.founder-info p{font-size:15px;max-width:560px}
.expertise{padding-top:32px}
.expertise h2{margin-bottom:28px}
.exp-stats{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;gap:24px;padding-bottom:28px;border-bottom:1px solid var(--border);margin-bottom:28px}
.exp-stats strong{font-size:56px;font-weight:900;display:block;line-height:1}
.exp-stats span{font-size:14px;color:var(--gray)}
.vline{width:1px;height:60px;background:var(--border)}
.roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.roles-grid p{font-size:14px}
.roles-grid small{color:var(--gray);font-size:12px}


/* ══════════ 9 · FAQ ══════════ */
.faq-wrap{max-width:900px}
.faq-wrap h1{margin-bottom:48px}
.accordion{display:flex;flex-direction:column}
.acc-item{border-top:1px solid var(--border);padding:20px 0;cursor:pointer;transition:background .2s}
.acc-item:hover{background:rgba(255,255,255,.02)}
.acc-item:last-child{border-bottom:1px solid var(--border)}
.acc-q{display:flex;justify-content:space-between;align-items:center}
.acc-q strong{font-size:16px;font-weight:700}
.chevron-icon{font-size:24px;color:var(--gray);transition:transform .3s}
.acc-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.acc-item.open .acc-a{max-height:200px}
.acc-item.open .chevron-icon{transform:rotate(180deg)}
.acc-a p{padding:12px 0 4px;font-size:15px}


/* ══════════ 10 · CONTACT ══════════ */
#contact{padding:80px 0;position:relative;overflow:hidden}
.contact-split{display:grid;grid-template-columns:1fr 1fr;max-width:960px;margin:0 auto;padding:0 5%;gap:48px}
.contact-form-side{max-width:560px;position:relative;z-index:2}
.contact-form-side h1{margin-bottom:16px}
.contact-form-side>p{margin-bottom:32px;font-size:16px}
form input[type="text"],form input[type="email"],form input[type="url"],form select,form textarea{width:100%;background:rgba(255,255,255,0.03);border:1px solid var(--border);color:var(--white);padding:14px 16px;font-size:15px;font-family:'Inter',sans-serif;outline:none;border-radius:6px;transition:border-color .3s, background-color .3s}
form input[type="text"]:focus,form input[type="email"]:focus,form input[type="url"]:focus,form select:focus,form textarea:focus{border-color:var(--blue);background:rgba(255,255,255,0.06)}
form textarea{min-height:120px;resize:vertical}
#contactForm{display:flex;flex-direction:column;gap:12px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
form select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 16px center;background-size:16px;padding-right:48px}
.form-status{font-size:14px;line-height:1.5;margin-top:6px;min-height:1.3em}
.form-status.ok{color:#3ecf8e}
.form-status.err{color:#ff6b6b}
button[type="submit"]:disabled{opacity:.6;cursor:not-allowed}
.check-label{font-size:14px;margin:8px 0 0;color:var(--white)}
.check-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:16px}
.check-grid label{font-size:13px;color:var(--gray);display:flex;align-items:center;gap:6px;cursor:pointer;transition:color .2s}
.check-grid label:hover{color:var(--white)}
.check-grid input[type=checkbox]{appearance:none;-webkit-appearance:none;width:18px;height:18px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:4px;position:relative;cursor:pointer;transition:all .2s;flex-shrink:0}
.check-grid input[type=checkbox]:checked{background:var(--blue);border-color:var(--blue)}
.check-grid input[type=checkbox]:checked::after{content:"\2713";position:absolute;color:white;font-size:13px;font-weight:bold;left:3px;top:-1px}
.contact-info-side{position:relative;min-height:500px;overflow:hidden}
.info-card{position:relative;z-index:2;padding:40px 32px;max-width:320px;margin:0 auto}
.info-card h3{font-size:32px;font-weight:900;margin-bottom:4px}
.info-card>p{margin-bottom:24px;font-size:15px}
.info-card a{color:#fff;text-decoration:none;transition:color .2s,opacity .2s}
.info-card a:hover{text-decoration:underline;opacity:.85}
.socials{display:flex;gap:16px;margin-top:32px;font-size:24px;font-weight:700}
.socials span{cursor:pointer;opacity:.7;transition:opacity .2s}
.socials span:hover{opacity:1}


/* ══════════ FOOTER ══════════ */
footer{position:relative;overflow:hidden;border-top:3px solid var(--blue);padding:24px 5%}
.footer-inner{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2}
.footer-inner .logo{font-size:22px}
.footer-inner span{font-size:13px;color:var(--gray)}
.footer-socials{display:flex;gap:12px;font-size:16px}
.copy{font-size:12px;color:var(--gray)}


/* ══════════ RESPONSIVE ══════════ */
@media(max-width:1024px){
    h1{font-size:72px}h2{font-size:36px}
    #hero h1{font-size:64px}
    .card-grid,.stories-row{grid-template-columns:1fr 1fr}
    .steps{grid-template-columns:1fr 1fr}
    .stats-row{grid-template-columns:1fr 1fr}
    .about-split,.contact-split{grid-template-columns:1fr}
    .pat-corner-right,.pat-corner-left{width:150px}
    /* Results stats: wrap to 2-up so the row never overruns the viewport */
    .horizontal-track{flex-wrap:wrap;justify-content:center;gap:40px 24px;padding:60px 5%}
    .horizontal-track .track-chevron{display:none}
    .horizontal-track .stat{flex:0 0 40%;text-align:center}
    /* Case studies: shrink so side-by-side cards still fit on tablet */
    .cs-card-head{padding:30px 26px}
    .cs-num{font-size:52px}
    .cs-title{font-size:28px}
    .cs-stats strong{font-size:30px}
    .cs-detail-inner{padding:6px 26px 30px}
}
@media(max-width:640px){
    h1{font-size:44px}
    /* Hero headline had an ID-level 120px rule that escaped the responsive h1 size */
    #hero h1{font-size:40px;line-height:1.04}
    .hero-sub{font-size:16px;max-width:none}
    .card-grid,.belief-grid,.stories-row,.steps,.stats-row{grid-template-columns:1fr}
    .form-row,.check-grid{grid-template-columns:1fr}
    .exp-stats{grid-template-columns:1fr;text-align:center}
    .vline{display:none}
    .founder-row{grid-template-columns:1fr}
    .roles-grid{grid-template-columns:1fr}
    .pat-corner-right,.pat-corner-left{display:none}
    /* Results stats: single column on phones */
    .horizontal-track{gap:32px;padding:48px 5%}
    .horizontal-track .stat{flex:0 0 100%}
    .stat h2{font-size:56px}

    /* Tighten vertical rhythm on phones — sections were 100px+ top/bottom */
    .sec{padding:56px 0}
    #results{padding:56px 0;min-height:auto}
    .results-top{margin-bottom:32px}
    #contact{padding:56px 0}
    .about-text{padding:56px 5%}
    .about-split{min-height:0}
    .about-text h2{margin:32px 0 16px}
    .about-intro{margin-bottom:28px}
    .why-vc{padding-top:32px}
    .cta-banner{margin-top:48px;padding:56px 5%}
    /* Stacked steps: the horizontal connector line reads as a stray line on phones */
    .timeline-line{display:none}
    .steps{padding-top:0;gap:36px}
    .step .num{margin-bottom:12px}
    .belief-grid{margin:32px 0 40px}
    .stories-row,.timeline,.founder-row,.expertise{margin-top:32px}
    /* Case studies: tighter padding + 2x2 stats so longer figures don't cramp */
    .story.case{padding:28px 22px 24px}
    .story-stats{grid-template-columns:1fr 1fr;gap:18px 10px}
    /* Team photo grid: 2-up on phones */
    .team-grid{grid-template-columns:1fr 1fr;gap:18px;margin-bottom:40px}
    /* Case studies: single column on phones */
    .cs-grid{grid-template-columns:1fr;gap:20px;margin-top:32px}
    .cs-card-head{padding:28px 24px}
    .cs-num{font-size:52px}
    .cs-title{font-size:26px}
    .cs-summary{font-size:14px;margin-top:14px}
    .cs-stats{gap:20px 14px;margin-top:22px}
    .cs-stats strong{font-size:32px}
    .cs-detail-inner{padding:6px 24px 28px}
    .cs-quote{font-size:18px;padding-left:18px}
    .po-row{grid-template-columns:40px 1fr 64px;gap:10px}
    .founder-row{margin:32px 0;padding-bottom:32px}
    /* Leadership stacks on phones */
    .leadership{grid-template-columns:1fr;gap:28px;margin:32px 0;padding-bottom:32px}
    .leader{grid-template-columns:110px 1fr;gap:16px}
    .leader-img{width:110px;height:138px}
    .leader-info h2{font-size:24px}
    .faq-wrap h1{margin-bottom:28px}
    .sec .sub{margin-bottom:32px}
}

/* ─────────── CARD & STORY SPOTLIGHT GLOW ─────────── */
.card, .belief, .story {
    position: relative;
    overflow: hidden;
}
.card::before, .belief::before, .story::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    border-radius: inherit;
    background: radial-gradient(400px circle at var(--mouse-x, -1000px) var(--mouse-y, -1000px), var(--bg-glow), transparent 50%);
    z-index: 1;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.4s ease;
}
.card:hover::before, .belief:hover::before, .story:hover::before {
    opacity: 1;
}
.card > *, .belief > *, .story > * {
    position: relative;
    z-index: 2;
}

/* ─────────── PORTAL HUB STYLING ─────────── */
.hub-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin: 60px 0 100px;
}
.hub-card {
    min-height: 280px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background: #090909;
    border: 1px solid var(--border);
    padding: 24px;
    border-radius: 8px;
    transition: all 0.4s ease;
}
.hub-card:hover {
    transform: translateY(-8px);
    border-color: rgba(255, 255, 255, 0.2);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}
.hub-card h3 {
    font-size: 20px;
    font-weight: 900;
    margin-bottom: 8px;
    letter-spacing: -0.5px;
    display: flex;
    align-items: center;
}
.hub-card p {
    font-size: 13px;
    line-height: 1.6;
    margin-bottom: 24px;
    flex-grow: 1;
}
.hub-link {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--white);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: auto;
    transition: color 0.3s;
}
.hub-card:hover .hub-link {
    color: var(--dot-color);
}
.theme-dot-indicator {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    margin-right: 10px;
    background-color: var(--dot-color);
}
@media(max-width:1024px){
    .hub-grid { grid-template-columns: 1fr 1fr; }
}
@media(max-width:640px){
    .hub-grid { grid-template-columns: 1fr; }
}


