/* CSS Document */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafaf8;--off:#f2f0ec;--white:#fff;
  --ink:#0f0f0f;--mid:#666;--soft:#aaa;--line:#e5e2db;
  --purple:#8b7bb8;--purple-dark:#6b5b9e;--purple-pale:#f0ecfa;--purple-mid:rgba(139,123,184,0.22);
  --charcoal:#1e1b2e;--charcoal2:#2d2840;
  --serif:'Cormorant Garamond',serif;--sans:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);font-size:15px;line-height:1.7;font-weight:300;overflow-x:hidden;cursor:none}
#cur-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(139,123,184,0.6);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s;mix-blend-mode:multiply}
#cur-dot{position:fixed;width:6px;height:6px;background:var(--purple);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}




.r{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s ease}
.r.v{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}
.sec-label{display:flex;align-items:center;gap:12px;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--soft);margin-bottom:18px;font-weight:500}
.sec-label::before{content:'';width:28px;height:1px;background:var(--purple);flex-shrink:0}
.sec-label.lgt{color:rgba(255,255,255,0.4)}
.sec-label.lgt::before{background:var(--purple)}

/* ── HERO ── */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 60px);border-bottom:1px solid rgba(255,255,255,0.06)}
.hero-l{background:var(--charcoal);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:56px 56px 64px}
.hero-l-glow{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.18) 0%,transparent 65%);top:-120px;right:-160px;pointer-events:none;will-change:transform}
.hero-eyebrow{display:flex;align-items:center;gap:10px;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:24px;position:relative;z-index:3}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--purple);flex-shrink:0}
.hero h1{font-family:var(--serif);font-size:clamp(54px,6.5vw,86px);line-height:0.97;font-weight:600;color:#fff;letter-spacing:-0.02em;margin-bottom:22px;position:relative;z-index:3}
.hero h1 .ghost{color:rgba(255,255,255,0.18);font-style:italic;font-weight:300;display:block}
.hero h1 .accent{color:var(--purple);display:block}
.hero-sub{font-size:15px;color:rgba(255,255,255,0.45);max-width:420px;line-height:1.85;font-weight:300;margin-bottom:36px;position:relative;z-index:3}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px;position:relative;z-index:3}
.btn-fill{background:var(--white);color:var(--ink);font-size:11px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;padding:13px 28px;border:none;cursor:none;transition:all .22s;text-decoration:none;display:inline-block}
.btn-fill:hover{background:var(--purple);color:#fff}
.hero-pills{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:3;border-top:1px solid rgba(255,255,255,0.08);padding-top:28px;justify-content:space-between;width:100%}
.hero-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--purple);border-radius:40px;padding:10px 18px;flex:1;text-align:center;box-shadow:0 4px 20px rgba(139,123,184,0.3)}
.pill-val{font-family:var(--serif);font-size:17px;font-weight:600;color:#fff;line-height:1;letter-spacing:-0.01em}
.pill-lbl{font-size:8px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-top:2px;font-weight:500}
.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:10}
.scroll-hint span{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.3)}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--purple-mid),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.4}50%{opacity:1}}
/* right panel — interactive selector */
.hero-r{background:var(--off);position:relative;overflow:hidden;padding:56px 48px;display:flex;flex-direction:column;justify-content:center}
.hero-r-orb{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.12) 0%,transparent 65%);top:-80px;right:-80px;pointer-events:none;will-change:transform}
.hero-r-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);margin-bottom:24px;display:flex;align-items:center;gap:10px;position:relative;z-index:3}
.hero-r-label::before{content:'';width:24px;height:1px;background:var(--purple);flex-shrink:0}
.claim-list{list-style:none;position:relative;z-index:3}
.claim-item{border-bottom:1px solid var(--line)}
.claim-item:first-child{border-top:1px solid var(--line)}
.claim-link{display:flex;align-items:center;justify-content:space-between;padding:18px 0;text-decoration:none;color:var(--ink);transition:all .2s;gap:16px}
.claim-link:hover{padding-left:8px}
.claim-link:hover .claim-name{color:var(--purple)}
.claim-link:hover .claim-arr{transform:translateX(4px);color:var(--purple)}
.claim-name{font-family:var(--serif);font-size:21px;font-weight:400;letter-spacing:-0.005em;line-height:1.1}
.claim-sub{font-size:11px;color:var(--soft);font-weight:300;margin-top:2px}
.claim-arr{font-size:18px;color:var(--soft);transition:transform .22s,color .22s;flex-shrink:0}

/* ── WHAT WE DO ── */
.what{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line)}
.what-l{padding:80px 56px;background:var(--white);display:flex;flex-direction:column;justify-content:center}
.what-l h2{font-family:var(--serif);font-size:clamp(40px,4.5vw,56px);font-weight:600;line-height:1.06;letter-spacing:-0.01em;margin-bottom:22px}
.what-l h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.what-l p{font-size:15px;color:var(--mid);line-height:1.9;font-weight:300;margin-bottom:16px}
.what-l p strong{color:var(--ink);font-weight:600}
.what-r{padding:80px 56px;background:var(--charcoal);display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.what-r-glow{position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.14) 0%,transparent 65%);top:-100px;right:-80px;pointer-events:none}
.what-r h3{font-family:var(--serif);font-size:28px;font-weight:600;color:#fff;margin-bottom:24px;letter-spacing:-0.01em;position:relative;z-index:1}
.what-r h3 em{font-style:italic;font-weight:300;color:rgba(255,255,255,0.4)}
/* flip cards */
.flip-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;position:relative;z-index:1}
.flip-card{height:130px;perspective:800px;cursor:none}
.flip-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s cubic-bezier(0.22,1,0.36,1)}
.flip-card:hover .flip-inner{transform:rotateY(180deg)}
.flip-front,.flip-back{position:absolute;inset:0;backface-visibility:hidden;border-radius:16px;padding:20px}
.flip-front{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);display:flex;flex-direction:column;gap:8px}
.flip-front svg{width:18px;height:18px;stroke:var(--purple);fill:none;stroke-width:1.5;flex-shrink:0}
.flip-front-title{font-size:13px;font-weight:600;color:#fff;line-height:1.2}
.flip-back{background:var(--purple);border:1px solid var(--purple);transform:rotateY(180deg);display:flex;align-items:center;justify-content:center}
.flip-back-text{font-size:12px;color:#fff;line-height:1.7;font-weight:300;text-align:center}

/* ── ASSESSMENT TYPES ── */
.assess{background:var(--charcoal);border-bottom:1px solid rgba(255,255,255,0.07)}
.assess-header{padding:72px 56px 52px;border-bottom:1px solid rgba(255,255,255,0.07);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
.assess-header h2{font-family:var(--serif);font-size:clamp(40px,4vw,54px);font-weight:600;line-height:1.06;letter-spacing:-0.01em;color:#fff}
.assess-header h2 em{font-style:italic;font-weight:300;color:rgba(255,255,255,0.3)}
.assess-header p{font-size:15px;color:rgba(255,255,255,0.45);line-height:1.85;font-weight:300}
.assess-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:32px 40px 48px}
.assess-card{padding:36px 32px;border-radius:20px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);cursor:none;transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,background .3s;position:relative;overflow:hidden}
.assess-card:hover{background:var(--purple);transform:translateY(-8px) scale(1.02);box-shadow:0 28px 56px rgba(0,0,0,0.5)}
.assess-card:hover .ac-icon{background:rgba(255,255,255,0.2);border-color:rgba(255,255,255,0.4)}
.assess-card:hover .ac-icon svg{stroke:#fff}
.assess-card:hover .ac-tag{color:rgba(255,255,255,0.6)}
.assess-card:hover .ac-title{color:#fff}
.assess-card:hover .ac-body{color:rgba(255,255,255,0.7)}
.ac-icon{width:42px;height:42px;border-radius:50%;background:rgba(139,123,184,0.2);border:1.5px solid rgba(139,123,184,0.3);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:all .3s}
.ac-icon svg{width:17px;height:17px;stroke:var(--purple);fill:none;stroke-width:1.5;transition:stroke .25s}
.ac-tag{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--purple);font-weight:600;margin-bottom:8px;transition:color .2s}
.ac-title{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1.1;color:#fff;margin-bottom:8px;letter-spacing:-0.01em}
.ac-body{font-size:13px;color:rgba(255,255,255,0.42);line-height:1.75;font-weight:300;transition:color .2s}

/* ── WHO WE WORK WITH ── */
.who{border-bottom:1px solid var(--line);background:var(--off)}
.who-header{padding:72px 56px 52px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
.who-header h2{font-family:var(--serif);font-size:clamp(40px,4vw,54px);font-weight:600;line-height:1.06;letter-spacing:-0.01em}
.who-header h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.who-header p{font-size:15px;color:var(--mid);line-height:1.85;font-weight:300}
.who-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:32px 40px 48px}
.who-card{padding:36px 28px;border-radius:20px;background:var(--white);border:1px solid var(--line);cursor:none;transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,background .3s;position:relative;overflow:hidden}
.who-card:hover{background:var(--purple);transform:translateY(-8px) scale(1.03);box-shadow:0 24px 48px rgba(139,123,184,0.25),0 0 0 1.5px rgba(139,123,184,0.4)}
.who-card:hover .wc-icon{background:rgba(255,255,255,0.2);border-color:rgba(255,255,255,0.4)}
.who-card:hover .wc-icon svg{stroke:#fff}
.who-card:hover .wc-title{color:#fff}
.who-card:hover .wc-body{color:rgba(255,255,255,0.7)}
.wc-icon{width:42px;height:42px;border-radius:50%;background:var(--purple-pale);border:1.5px solid rgba(139,123,184,0.25);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:all .3s}
.wc-icon svg{width:17px;height:17px;stroke:var(--purple);fill:none;stroke-width:1.5;transition:stroke .25s}
.wc-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:6px;transition:color .2s}
.wc-body{font-size:13px;color:var(--mid);line-height:1.75;font-weight:300;transition:color .2s}

/* ── PROCESS ── */
.process{border-bottom:1px solid var(--line);background:var(--bg)}
.proc-header{padding:72px 56px 52px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
.proc-header h2{font-family:var(--serif);font-size:clamp(40px,4vw,54px);font-weight:600;line-height:1.06;letter-spacing:-0.01em}
.proc-header h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.proc-header p{font-size:15px;color:var(--mid);line-height:1.85;font-weight:300}
.proc-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center;padding:32px 40px 48px}
.step-arrow{display:flex;align-items:center;justify-content:center;padding:0 8px;color:rgba(139,123,184,0.4);font-size:22px;flex-shrink:0;margin-top:-20px}
.step{padding:34px 28px;border-radius:20px;background:var(--white);border:1px solid var(--line);cursor:none;position:relative;transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,background .3s}
.step:hover{background:var(--purple-pale);transform:translateY(-8px) scale(1.02);box-shadow:0 24px 48px rgba(139,123,184,0.18),0 0 0 1.5px rgba(139,123,184,0.35)}
.step-num{font-family:var(--serif);font-size:48px;font-weight:600;color:rgba(139,123,184,0.18);line-height:1;margin-bottom:10px;letter-spacing:-0.02em;transition:color .3s}
.step:hover .step-num{color:rgba(139,123,184,0.45)}
.step-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.step-body{font-size:12px;color:var(--mid);line-height:1.75;font-weight:300}

/* ── QUOTE ── */
.quote{background:var(--charcoal);padding:80px 64px;display:flex;align-items:flex-start;gap:48px;position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,0.07)}
.q-glow{position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.14) 0%,transparent 65%);top:-200px;right:-80px;pointer-events:none;will-change:transform}
.q-bar{width:3px;background:var(--purple);flex-shrink:0;align-self:stretch;opacity:0.5;border-radius:2px}
.quote blockquote{font-family:var(--serif);font-size:clamp(28px,3vw,42px);font-weight:300;color:#fff;line-height:1.3;font-style:italic;position:relative;z-index:1}
.quote blockquote strong{font-weight:600;font-style:normal;color:#c4b8e0}
.q-sub{margin-top:18px;font-size:11px;color:rgba(255,255,255,0.35);letter-spacing:.14em;text-transform:uppercase;position:relative;z-index:1}

/* ── CTA ── */
.cta{position:relative;padding:100px 56px;overflow:hidden;background:var(--charcoal);border-bottom:1px solid rgba(255,255,255,0.07)}
.cta-wash{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 20% 50%,rgba(139,123,184,0.12) 0%,transparent 70%)}
.cta-inner{position:relative;z-index:3;max-width:520px}
.cta-inner h2{font-family:var(--serif);font-size:clamp(44px,5vw,60px);font-weight:600;line-height:1;letter-spacing:-0.02em;color:#fff;margin-bottom:16px}
.cta-inner h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.cta-inner p{font-size:15px;color:rgba(255,255,255,0.4);line-height:1.85;font-weight:300;max-width:400px;margin-bottom:32px}
.cta-contacts{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.cta-contact{display:flex;align-items:center;gap:12px;font-size:13px;color:rgba(255,255,255,0.55);text-decoration:none;transition:color .2s}
.cta-contact:hover{color:#fff}
.cta-contact svg{width:16px;height:16px;stroke:var(--purple);fill:none;stroke-width:1.5;flex-shrink:0}
.btn-cta{background:var(--white);color:var(--ink);font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;padding:14px 32px;border:none;cursor:none;transition:all .22s;text-decoration:none;display:inline-block}
.btn-cta:hover{background:var(--purple);color:#fff}

/* SERVICES STRIP */
.svc-strip{border-bottom:1px solid var(--line);background:var(--white);overflow:hidden}
.strip-header{padding:48px 56px 32px;display:flex;align-items:flex-end;justify-content:space-between}
.strip-header h2{font-family:var(--serif);font-size:clamp(28px,3vw,38px);font-weight:600;line-height:1.07;letter-spacing:-0.01em}
.strip-header h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.strip-header-r{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}
.strip-grid{display:grid;grid-template-columns:repeat(5,1fr);width:100%;border-top:1px solid var(--line)}
.strip-chip{padding:36px 28px 32px;border-right:1px solid var(--line);text-decoration:none;color:inherit;background:var(--white);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background .28s,transform .35s cubic-bezier(0.22,1,0.36,1);cursor:none}
.strip-chip:last-child{border-right:none}
.strip-chip:hover{background:var(--purple);transform:translateY(-6px);box-shadow:0 20px 48px rgba(139,123,184,0.3);z-index:2}
.strip-chip::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--purple);transform:scaleX(0);transform-origin:left;transition:transform .32s}
.strip-chip:hover::before{transform:scaleX(1)}
.strip-chip:hover .chip-tag{color:rgba(255,255,255,0.55)}
.strip-chip:hover .chip-title{color:#fff}
.strip-chip:hover .chip-body{color:rgba(255,255,255,0.6)}
.strip-chip:hover .chip-arr{color:#fff;transform:translateX(3px)}
.strip-chip:hover .chip-icon{background:rgba(255,255,255,0.2);border-color:rgba(255,255,255,0.4)}
.strip-chip:hover .chip-icon svg{stroke:#fff}
.chip-icon{width:36px;height:36px;border-radius:50%;background:var(--purple-pale);border:1.5px solid rgba(139,123,184,0.25);display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:all .25s;flex-shrink:0}
.chip-icon svg{width:14px;height:14px;stroke:var(--purple);fill:none;stroke-width:1.5;transition:stroke .2s}
.chip-tag{font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:var(--purple);font-weight:600;margin-bottom:5px;transition:color .2s}
.chip-title{font-family:var(--serif);font-size:19px;font-weight:600;line-height:1.15;color:var(--ink);margin-bottom:6px;letter-spacing:-0.01em;transition:color .2s}
.chip-body{font-size:11px;color:var(--mid);line-height:1.65;font-weight:300;flex:1;transition:color .2s}
.chip-arr{font-size:12px;color:var(--soft);transition:transform .22s,color .22s;margin-top:14px;align-self:flex-start}

footer{padding:28px 48px;display:flex;align-items:center;justify-content:space-between;background:var(--charcoal);border-top:1px solid rgba(255,255,255,0.07)}
.f-logo{font-family:var(--serif);font-size:14px;color:rgba(255,255,255,0.4)}
.f-logo i{font-style:italic;color:var(--purple)}
.f-links{display:flex;gap:28px;list-style:none}
.f-links a{font-size:10px;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,0.3);text-decoration:none;transition:color .2s}
.f-links a:hover{color:var(--purple)}
.f-copy{font-size:10px;color:rgba(255,255,255,0.2)}
