/* ============ TOKENS ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:#F5F2EA;
  --cream-deep:#EEE8D9;
  --white:#FFFFFF;
  --navy:#0C1426;
  --navy-soft:#1F2A44;
  --terra:#FF5C38;
  --terra-deep:#E04A28;
  --yellow:#FFD93D;
  --gold:#D4AF6A;
  --text:#0C1426;
  --text-dim:#6B6F78;
  --text-faint:#A1A4AB;
  --line:rgba(12,20,38,.09);
  --line-strong:rgba(12,20,38,.18);
  --serif:'Instrument Serif',Georgia,serif;
  --sans:'Geist','Inter',system-ui,sans-serif;
  --mono:'Geist Mono',ui-monospace,monospace;
  --ease:cubic-bezier(.22,.6,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --container:1440px;
}
html{scroll-behavior:smooth;background:var(--cream);color:var(--text);font-family:var(--sans);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{overflow-x:hidden;line-height:1.55;font-weight:400}
::selection{background:var(--terra);color:var(--white)}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
ul,ol{list-style:none}

/* ============ TYPE ============ */
.mono{font-family:var(--mono);font-weight:400;letter-spacing:.01em}
.label{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim);display:inline-flex;align-items:center;gap:10px}
.label::before{content:"";width:7px;height:7px;background:var(--terra);border-radius:50%;display:inline-block}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--terra);display:inline-block;font-weight:500}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-.02em;line-height:.98;color:var(--text)}
h1{font-size:clamp(58px,9.8vw,184px);letter-spacing:-.035em;line-height:.94}
h2{font-size:clamp(42px,6vw,108px);letter-spacing:-.028em;line-height:.98}
h3{font-size:clamp(22px,1.8vw,30px);line-height:1.15;letter-spacing:-.01em}
h4{font-size:18px;line-height:1.25;letter-spacing:-.005em;font-family:var(--sans);font-weight:500}
.italic{font-style:italic;color:var(--terra)}
.italic-gold{font-style:italic;color:var(--gold)}

/* ============ LAYOUT ============ */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(24px,4vw,56px)}
section{padding:clamp(100px,14vh,180px) 0;position:relative}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:48px;margin-bottom:clamp(60px,8vw,90px);flex-wrap:wrap}
.section-head-left{max-width:780px}
.section-head .num{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.2em}

.bg-white{background:var(--white)}
.bg-cream{background:var(--cream)}
.bg-navy{background:var(--navy);color:var(--cream)}
.bg-navy h1,.bg-navy h2,.bg-navy h3,.bg-navy h4{color:var(--cream)}
.bg-navy .label{color:rgba(245,242,234,.65)}
.bg-navy .eyebrow{color:var(--yellow)}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:12px;padding:18px 28px;font-size:14.5px;font-weight:500;border-radius:999px;transition:all .35s var(--ease);border:1.5px solid transparent;font-family:var(--sans);cursor:pointer}
.btn .arrow{transition:transform .35s var(--ease);display:inline-block}
.btn:hover .arrow{transform:translateX(5px)}
.btn-primary{background:var(--terra);color:var(--white);border-color:var(--terra)}
.btn-primary:hover{background:var(--navy);border-color:var(--navy);color:var(--white)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:var(--white)}
.btn-yellow{background:var(--yellow);color:var(--navy);border-color:var(--yellow)}
.btn-yellow:hover{background:var(--navy);color:var(--yellow);border-color:var(--navy)}
.bg-navy .btn-ghost{color:var(--cream);border-color:rgba(245,242,234,.3)}
.bg-navy .btn-ghost:hover{background:var(--cream);color:var(--navy);border-color:var(--cream)}

.link-arrow{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);padding-bottom:6px;border-bottom:1.5px solid var(--terra);transition:all .35s var(--ease);font-weight:500}
.link-arrow:hover{gap:20px;color:var(--navy);border-color:var(--navy)}

/* ============ NAV ============ */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:18px 0;backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);background:rgba(245,242,234,.82);border-bottom:1px solid var(--line);transition:all .4s var(--ease)}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:40px;max-width:var(--container);margin:0 auto;padding:0 clamp(24px,4vw,56px)}
.brand{display:flex;align-items:center;gap:14px;font-family:var(--serif);font-size:24px;letter-spacing:-.01em;color:var(--navy)}
.brand .mark{width:34px;height:34px;color:var(--navy);transition:transform .5s var(--ease)}
.brand:hover .mark{transform:rotate(-6deg)}
.brand .mark svg{width:100%;height:100%;overflow:visible}
.brand-text em{font-style:italic;color:var(--gold);margin-left:4px;font-size:.95em}

.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:14px;color:var(--navy);position:relative;padding:6px 0;transition:color .3s var(--ease)}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--terra);transform-origin:right;transform:scaleX(0);transition:transform .45s var(--ease-out)}
.nav-links a:hover{color:var(--terra)}
.nav-links a:hover::after{transform-origin:left;transform:scaleX(1)}

.nav-cta{display:flex;align-items:center;gap:10px;padding:11px 20px;background:var(--terra);border:1.5px solid var(--terra);color:var(--white);font-size:13px;border-radius:999px;font-weight:500;transition:all .3s var(--ease)}
.nav-cta:hover{background:var(--navy);border-color:var(--navy)}
.nav-cta .dot{width:7px;height:7px;background:var(--yellow);border-radius:50%;animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}

/* ============ HERO ============ */
.hero{padding:calc(100px + 120px) 0 clamp(60px,10vh,120px);min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden}
.hero-blob{position:absolute;top:-18%;right:-14%;width:780px;height:780px;background:var(--terra);border-radius:50%;filter:blur(80px);opacity:.22;z-index:0;pointer-events:none;animation:blob 20s ease-in-out infinite alternate}
.hero-blob-2{position:absolute;bottom:-10%;left:-10%;width:520px;height:520px;background:var(--yellow);border-radius:50%;filter:blur(90px);opacity:.2;z-index:0;pointer-events:none;animation:blob 24s ease-in-out infinite alternate-reverse}
@keyframes blob{0%{transform:translate(0,0) scale(1)}100%{transform:translate(40px,30px) scale(1.1)}}

.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:88px 88px;mask-image:radial-gradient(ellipse at 30% 50%,#000 15%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at 30% 50%,#000 15%,transparent 75%);opacity:.5;pointer-events:none;z-index:0}

.hero-inner{position:relative;z-index:2;width:100%}
.hero-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:clamp(50px,8vh,100px);flex-wrap:wrap;gap:24px}
.hero-status{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;color:var(--navy);letter-spacing:.2em;text-transform:uppercase;font-weight:500}
.hero-status .dot{width:8px;height:8px;background:var(--terra);border-radius:50%;box-shadow:0 0 0 4px rgba(255,92,56,.18);animation:pulse 2.2s ease-in-out infinite}
.hero-coord{font-family:var(--mono);font-size:11px;color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;display:flex;gap:24px}
.hero-coord span::before{content:"▸ ";color:var(--terra);font-size:8px;vertical-align:middle}

.hero h1{margin:0 0 clamp(40px,6vh,56px) 0;max-width:1240px}
.hero h1 .reveal{display:block;overflow:hidden;padding-bottom:.05em}
.hero h1 .reveal > span{display:inline-block;transform:translateY(110%);opacity:0;animation:rise 1.2s var(--ease-out) forwards}
.hero h1 .reveal:nth-child(1) > span{animation-delay:.15s}
.hero h1 .reveal:nth-child(2) > span{animation-delay:.3s}
.hero h1 .reveal:nth-child(3) > span{animation-delay:.45s}
@keyframes rise{to{transform:translateY(0);opacity:1}}

.hero-meta{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(32px,6vw,80px);align-items:end;margin-top:clamp(40px,6vh,64px);padding-top:36px;border-top:1.5px solid var(--line);opacity:0;animation:fade 1s var(--ease-out) .8s forwards}
@keyframes fade{to{opacity:1}}
.hero-lead{font-size:clamp(18px,1.3vw,22px);color:var(--navy);line-height:1.45;max-width:48ch;font-weight:400}
.hero-lead strong{color:var(--terra);font-weight:500}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;justify-content:flex-end}

.hero-badge{position:absolute;right:clamp(24px,4vw,56px);top:50%;transform:translateY(-50%) rotate(8deg);background:var(--yellow);color:var(--navy);padding:20px 24px;border-radius:999px;font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;z-index:3;box-shadow:0 20px 40px rgba(12,20,38,.08);animation:wiggle 4s ease-in-out infinite;display:flex;align-items:center;gap:10px}
.hero-badge::before{content:"★";color:var(--terra);font-size:14px;letter-spacing:0}
@keyframes wiggle{0%,100%{transform:translateY(-50%) rotate(8deg)}50%{transform:translateY(-50%) rotate(12deg)}}

.hero-scroll{position:absolute;bottom:32px;left:clamp(24px,4vw,56px);font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-dim);display:flex;align-items:center;gap:14px;z-index:2}
.hero-scroll .line{width:60px;height:1px;background:linear-gradient(to right,var(--text-dim),transparent);position:relative;overflow:hidden}
.hero-scroll .line::after{content:"";position:absolute;inset:0;background:var(--terra);animation:scrollDot 2.4s ease-in-out infinite}
@keyframes scrollDot{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ============ TRUST ============ */
.trust{padding:clamp(32px,5vh,52px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:var(--cream);position:relative}
.trust-label{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:0 clamp(24px,4vw,56px);color:var(--text-dim);font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase}
.trust-label .hl{flex:1;height:1px;background:var(--line)}
.trust-track{display:flex;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 8%,#000 92%,transparent 100%)}
.trust-marquee{display:flex;align-items:center;gap:80px;padding-right:80px;animation:marquee 38s linear infinite;white-space:nowrap;flex-shrink:0}
.trust-item{font-family:var(--serif);font-size:clamp(28px,3.2vw,48px);color:var(--navy);font-style:italic;letter-spacing:-.02em;display:flex;align-items:center;gap:80px;white-space:nowrap;transition:color .4s}
.trust-item:hover{color:var(--terra)}
.trust-item::after{content:"…";color:var(--terra);font-size:14px;font-style:normal}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-100%)}}

/* ============ CONSTAT ============ */
.constat{background:var(--cream);text-align:center;padding:clamp(120px,16vh,200px) 0}
.constat-inner{max-width:1100px;margin:0 auto;position:relative}
.constat .eyebrow{margin-bottom:32px}
.constat h2{margin-bottom:48px;font-size:clamp(40px,6vw,112px)}
.constat-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.constat-sticker{position:absolute;right:5%;top:-10px;background:var(--terra);color:var(--white);padding:14px 18px;border-radius:999px;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;transform:rotate(-8deg);box-shadow:0 14px 30px rgba(255,92,56,.3)}

/* ============ PILLARS ============ */
.pillars{background:var(--white);position:relative}
.pillar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}
.pillar{background:var(--cream);padding:40px 32px 32px;border-radius:20px;position:relative;transition:all .45s var(--ease);overflow:hidden;min-height:320px;display:flex;flex-direction:column;border:1.5px solid transparent}
.pillar:hover{background:var(--white);border-color:var(--terra);transform:translateY(-6px);box-shadow:0 30px 60px rgba(255,92,56,.12)}
.pillar-badge{width:44px;height:44px;background:var(--yellow);border-radius:12px;display:grid;place-items:center;font-family:var(--mono);font-size:13px;font-weight:500;color:var(--navy);margin-bottom:44px;letter-spacing:.05em}
.pillar:nth-child(2) .pillar-badge{background:var(--terra);color:var(--white)}
.pillar:nth-child(3) .pillar-badge{background:var(--navy);color:var(--yellow)}
.pillar:nth-child(4) .pillar-badge{background:var(--gold);color:var(--white)}
.pillar h3{margin-bottom:12px;font-family:var(--sans);font-weight:500;font-size:22px;letter-spacing:-.01em}
.pillar p{color:var(--text-dim);font-size:15px;line-height:1.5;font-weight:400;margin-bottom:28px}
.pillar .link-arrow{margin-top:auto;font-size:11px;border-color:var(--line-strong);color:var(--navy)}
.pillar:hover .link-arrow{color:var(--terra);border-color:var(--terra)}

/* ============ SERVICES ============ */
.services{background:var(--cream)}
.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.service-card{position:relative;padding:clamp(36px,4vw,60px);min-height:480px;display:flex;flex-direction:column;overflow:hidden;border-radius:24px;transition:transform .5s var(--ease)}
.service-card:hover{transform:translateY(-4px)}
.service-card.ia{background:var(--navy);color:var(--cream)}
.service-card.ia h3{color:var(--cream)}
.service-card.ia .eyebrow{color:var(--yellow)}
.service-card.seo{background:var(--terra);color:var(--white)}
.service-card.seo h3{color:var(--white)}
.service-card.seo .eyebrow{color:var(--yellow)}

.service-card::before{content:"";position:absolute;top:-60px;right:-60px;width:260px;height:260px;border-radius:50%;opacity:.18;transition:all .5s var(--ease)}
.service-card.ia::before{background:var(--terra)}
.service-card.seo::before{background:var(--yellow)}
.service-card:hover::before{transform:scale(1.15)}

.service-card .eyebrow{margin-bottom:40px;position:relative;z-index:1}
.service-card h3{font-family:var(--serif);font-size:clamp(34px,3.8vw,60px);font-weight:400;line-height:.98;letter-spacing:-.025em;margin-bottom:28px;max-width:11ch;position:relative;z-index:1}
.service-card h3 em{font-style:italic;color:var(--yellow)}
.service-card .service-desc{font-size:16px;line-height:1.5;opacity:.82;margin-bottom:32px;max-width:42ch;position:relative;z-index:1}
.service-list{margin:0 0 40px;padding-top:24px;border-top:1px solid rgba(245,242,234,.15);position:relative;z-index:1}
.service-card.seo .service-list{border-color:rgba(255,255,255,.22)}
.service-list li{padding:14px 0;border-bottom:1px solid rgba(245,242,234,.1);font-size:15px;display:flex;align-items:center;gap:14px;transition:transform .3s}
.service-card.seo .service-list li{border-color:rgba(255,255,255,.15)}
.service-list li:hover{transform:translateX(6px)}
.service-list li::before{content:"→";font-family:var(--mono);font-size:14px;opacity:.7}
.service-card .btn{margin-top:auto;align-self:flex-start;position:relative;z-index:1}
.service-card.ia .btn{background:var(--yellow);color:var(--navy);border-color:var(--yellow)}
.service-card.ia .btn:hover{background:transparent;color:var(--yellow)}
.service-card.seo .btn{background:var(--white);color:var(--terra);border-color:var(--white)}
.service-card.seo .btn:hover{background:transparent;color:var(--white)}

/* ============ PACKS ============ */
.packs{background:var(--white)}
.packs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.pack{position:relative;background:var(--cream);padding:40px 36px 32px;display:flex;flex-direction:column;transition:all .5s var(--ease);overflow:hidden;border-radius:20px;border:1.5px solid transparent}
.pack:hover{border-color:var(--navy);transform:translateY(-6px);box-shadow:0 30px 60px rgba(12,20,38,.1)}
.pack.featured{background:var(--navy);color:var(--cream);border-color:var(--terra)}
.pack.featured h3{color:var(--cream)}
.pack.featured:hover{border-color:var(--yellow);box-shadow:0 30px 60px rgba(255,92,56,.3)}
.pack-tag{position:absolute;top:-1px;right:24px;background:var(--terra);color:var(--white);padding:7px 16px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border-radius:0 0 10px 10px}
.pack-name{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-dim);margin-bottom:28px;font-weight:500}
.pack.featured .pack-name{color:var(--yellow)}
.pack-price{font-family:var(--serif);font-size:clamp(42px,4.4vw,64px);color:var(--navy);line-height:1;margin-bottom:10px;letter-spacing:-.02em}
.pack.featured .pack-price{color:var(--cream)}
.pack-price-sub{font-family:var(--mono);font-size:11px;color:var(--text-faint);letter-spacing:.15em;text-transform:uppercase;margin-bottom:28px;min-height:14px}
.pack.featured .pack-price-sub{color:rgba(245,242,234,.6)}
.pack-desc{color:var(--text-dim);font-size:14.5px;line-height:1.5;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid var(--line);min-height:52px}
.pack.featured .pack-desc{color:rgba(245,242,234,.75);border-color:rgba(245,242,234,.15)}
.pack-features{margin-bottom:36px;flex:1}
.pack-features li{padding:10px 0;font-size:14px;display:flex;align-items:flex-start;gap:12px;font-weight:400}
.pack-features li::before{content:"";flex-shrink:0;margin-top:7px;width:7px;height:7px;background:var(--terra);display:inline-block;border-radius:50%}
.pack.featured .pack-features li::before{background:var(--yellow)}
.pack .btn{width:100%;justify-content:center}

/* ============ PORTFOLIO ============ */
.portfolio{background:var(--cream)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.case{background:var(--white);padding:32px 28px 28px;position:relative;transition:all .5s var(--ease);overflow:hidden;display:flex;flex-direction:column;min-height:340px;border-radius:18px;border:1.5px solid transparent}
.case:hover{border-color:var(--terra);transform:translateY(-6px);box-shadow:0 24px 50px rgba(12,20,38,.08)}
.case-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;font-family:var(--mono);font-size:10px;color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;font-weight:500}
.case-header .sector{color:var(--terra)}
.case-figure{font-family:var(--serif);font-size:clamp(64px,7vw,104px);font-style:italic;color:var(--navy);line-height:.9;letter-spacing:-.03em;margin-bottom:20px;transition:color .5s}
.case:hover .case-figure{color:var(--terra)}
.case-figure .unit{font-size:.35em;color:var(--text-dim);font-style:normal;font-family:var(--mono);vertical-align:super;margin-left:6px;letter-spacing:.05em;text-transform:uppercase;font-weight:500}
.case h3{margin-bottom:auto;font-family:var(--sans);font-weight:500;font-size:17px;letter-spacing:-.01em;line-height:1.35;padding-bottom:20px}
.case-cta{padding-top:18px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--navy);font-weight:500;transition:color .3s}
.case:hover .case-cta{color:var(--terra)}
.case-cta .arrow{transition:transform .3s}
.case:hover .case-cta .arrow{transform:translateX(5px)}

.portfolio-cta{padding:60px 0 0;text-align:center}

/* ============ TESTIMONIALS ============ */
.testi{background:var(--white);position:relative;overflow:hidden}
.testi-main{display:grid;grid-template-columns:1fr 1.8fr;gap:60px;align-items:start}
.testi-lead-block{position:sticky;top:140px}
.testi-rating{display:flex;align-items:center;gap:18px;margin-top:32px;padding-top:28px;border-top:1.5px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--text-dim);font-weight:500}
.testi-rating .stars{color:var(--terra);letter-spacing:3px;font-size:14px}
.testi-rating .num{font-family:var(--serif);font-size:36px;color:var(--navy);line-height:1;font-style:italic}
.testi-rating small{color:var(--text-faint);letter-spacing:.15em}

.testi-grid{display:grid;grid-template-columns:1fr;gap:18px}
.testi-card{background:var(--cream);padding:36px;transition:all .4s var(--ease);position:relative;overflow:hidden;border-radius:18px;border:1.5px solid transparent}
.testi-card:hover{background:var(--white);border-color:var(--terra);transform:translateY(-3px);box-shadow:0 20px 40px rgba(12,20,38,.08)}
.testi-card .quote{font-family:var(--serif);font-size:64px;color:var(--terra);line-height:.5;margin-bottom:12px;font-style:italic}
.testi-card p{font-size:18px;line-height:1.5;color:var(--navy);margin-bottom:28px;font-weight:400}
.testi-author{display:flex;align-items:center;gap:14px;padding-top:24px;border-top:1px solid var(--line)}
.testi-author .avatar{width:44px;height:44px;border-radius:50%;background:var(--terra);color:var(--white);display:grid;place-items:center;font-family:var(--serif);font-size:16px;font-style:italic;flex-shrink:0}
.testi-card:nth-child(2) .avatar{background:var(--yellow);color:var(--navy)}
.testi-card:nth-child(3) .avatar{background:var(--navy);color:var(--yellow)}
.testi-author-name{font-size:15px;color:var(--navy);font-weight:500}
.testi-author-role{font-size:12px;color:var(--text-dim);margin-top:2px;font-family:var(--mono);letter-spacing:.05em}

.testi-more{margin-top:32px;display:flex;justify-content:flex-start}

/* ============ PROCESS ============ */
.process{background:var(--cream)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}
.step{padding:36px 28px 32px;position:relative;transition:all .4s var(--ease);min-height:280px;display:flex;flex-direction:column;background:var(--white);border-radius:18px;border:1.5px solid transparent}
.step:hover{border-color:var(--terra);transform:translateY(-6px);box-shadow:0 24px 50px rgba(12,20,38,.1)}
.step-num{width:42px;height:42px;background:var(--yellow);border-radius:10px;display:grid;place-items:center;font-family:var(--mono);font-size:13px;color:var(--navy);font-weight:500;margin-bottom:40px;letter-spacing:.02em}
.step:nth-child(2) .step-num{background:var(--terra);color:var(--white)}
.step:nth-child(3) .step-num{background:var(--navy);color:var(--yellow)}
.step:nth-child(4) .step-num{background:var(--gold);color:var(--white)}
.step-title{font-family:var(--serif);font-size:clamp(26px,2.6vw,36px);color:var(--navy);line-height:.98;letter-spacing:-.02em;margin-bottom:12px}
.step-title em{color:var(--terra);font-style:italic}
.step p{color:var(--text-dim);font-size:14px;line-height:1.55;margin-top:auto}

.process-cta{padding:60px 0 0;text-align:center}

/* ============ FAQ ============ */
.faq{background:var(--white)}
.faq-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:60px;align-items:start;margin-top:32px;max-width:1180px;margin-left:auto;margin-right:auto}
.faq-head{position:sticky;top:140px}
.faq-head h2{margin-top:20px}
.faq-list{border-top:1.5px solid var(--navy)}
.faq-list details{border-bottom:1px solid var(--line);padding:0;cursor:pointer;transition:all .3s}
.faq-list summary{list-style:none;padding:28px 0;font-family:var(--serif);font-size:clamp(20px,1.6vw,26px);color:var(--navy);letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:center;gap:24px;cursor:pointer;transition:color .3s;line-height:1.2}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary:hover{color:var(--terra)}
.faq-list summary .plus{width:28px;height:28px;border-radius:50%;background:var(--cream);position:relative;flex-shrink:0;transition:all .4s var(--ease)}
.faq-list summary:hover .plus{background:var(--terra)}
.faq-list summary:hover .plus::before,.faq-list summary:hover .plus::after{background:var(--white)}
.faq-list summary .plus::before,.faq-list summary .plus::after{content:"";position:absolute;left:50%;top:50%;background:var(--navy);transition:all .4s var(--ease)}
.faq-list summary .plus::before{width:12px;height:1.5px;transform:translate(-50%,-50%)}
.faq-list summary .plus::after{width:1.5px;height:12px;transform:translate(-50%,-50%)}
.faq-list details[open] summary .plus{background:var(--terra)}
.faq-list details[open] summary .plus::before{background:var(--white)}
.faq-list details[open] summary .plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-list details[open] summary{color:var(--terra)}
.faq-list details p{color:var(--text-dim);font-size:15.5px;line-height:1.7;padding:0 0 32px;max-width:64ch;font-weight:400}

/* ============ CTA FINAL ============ */
.cta{background:var(--navy);color:var(--white);position:relative;overflow:hidden;padding:clamp(80px,12vh,140px) 0}
.cta::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:88px 88px;pointer-events:none}
.cta-layout{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(48px,7vw,100px);align-items:start}
.cta-left .eyebrow{color:var(--yellow)}
.cta-left h2{color:var(--white);margin:28px 0 24px;font-size:clamp(40px,5vw,88px);letter-spacing:-.032em}
.cta-left h2 em{color:var(--yellow);font-style:italic}
.cta-left p{color:rgba(255,255,255,.75);font-size:clamp(15px,1.1vw,18px);max-width:44ch;line-height:1.6;margin-bottom:40px}
.cta-benefits{display:flex;flex-direction:column;gap:16px;margin-bottom:44px}
.cta-benefit{display:flex;align-items:center;gap:14px;font-size:14px;color:rgba(255,255,255,.8)}
.cta-benefit::before{content:"";width:8px;height:8px;background:var(--terra);border-radius:50%;flex-shrink:0}
.cta-meta{display:flex;gap:clamp(20px,4vw,48px);padding-top:36px;border-top:1px solid rgba(255,255,255,.15);flex-wrap:wrap;font-family:var(--mono);font-size:10px;color:rgba(255,255,255,.55);letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.cta-meta span{display:flex;align-items:center;gap:8px}
.cta-meta span::before{content:"";width:5px;height:5px;background:var(--yellow);border-radius:50%}

/* ---- AUDIT FORM CARD ---- */
.audit-card{background:var(--cream);border-radius:24px;padding:clamp(32px,4vw,52px);position:relative;z-index:2}
.audit-card-head{margin-bottom:32px;padding-bottom:28px;border-bottom:1.5px solid var(--line)}
.audit-card-head .label{margin-bottom:12px}
.audit-card-head h3{font-family:var(--sans);font-size:22px;font-weight:600;color:var(--navy);letter-spacing:-.02em}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-group label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);font-weight:500}
.form-group input,
.form-group select,
.form-group textarea{padding:14px 18px;background:var(--white);border:1.5px solid var(--line-strong);color:var(--text);font-family:var(--sans);font-size:14px;transition:border-color .3s,box-shadow .3s;outline:none;border-radius:12px;width:100%;appearance:none;-webkit-appearance:none}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{border-color:var(--terra);box-shadow:0 0 0 3px rgba(255,92,56,.1)}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--text-faint)}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B6F78' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;cursor:pointer}
.form-group textarea{resize:vertical;min-height:110px;line-height:1.55}

.audit-submit{width:100%;padding:18px 28px;background:var(--terra);color:var(--white);border:none;border-radius:999px;font-family:var(--sans);font-size:15px;font-weight:500;cursor:pointer;transition:all .35s var(--ease);display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px}
.audit-submit:hover{background:var(--navy)}
.audit-submit:disabled{opacity:.6;cursor:not-allowed}
.audit-submit .btn-arrow{transition:transform .35s var(--ease)}
.audit-submit:hover .btn-arrow{transform:translateX(5px)}
.form-note{margin-top:14px;font-family:var(--mono);font-size:10px;color:var(--text-faint);letter-spacing:.1em;text-align:center;line-height:1.5}

/* Success state */
.audit-success{display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;min-height:300px}
.audit-success.show{display:flex}
.audit-form-content.hide{display:none}
.success-icon{width:64px;height:64px;background:var(--terra);border-radius:50%;display:grid;place-items:center;margin:0 auto 24px;animation:popIn .5s var(--ease-out) forwards}
@keyframes popIn{from{transform:scale(0)}to{transform:scale(1)}}
.success-icon svg{width:28px;height:28px;stroke:white;stroke-width:2.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.audit-success h3{font-family:var(--serif);font-size:28px;color:var(--navy);margin-bottom:12px;letter-spacing:-.02em}
.audit-success p{color:var(--text-dim);font-size:15px;line-height:1.6;max-width:34ch}
.audit-success .next-steps{margin-top:28px;display:flex;flex-direction:column;gap:10px;width:100%}
.audit-success .next-step{display:flex;align-items:center;gap:12px;background:var(--cream-deep);padding:12px 16px;border-radius:10px;font-size:13px;color:var(--navy);text-align:left}
.audit-success .next-step::before{content:attr(data-n);width:24px;height:24px;background:var(--terra);color:white;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:10px;font-weight:600;flex-shrink:0}

/* Error message */
.form-error{display:none;background:rgba(255,92,56,.1);border:1.5px solid var(--terra);color:var(--terra);padding:12px 16px;border-radius:10px;font-size:13px;margin-bottom:14px;text-align:center}
.form-error.show{display:block}

@media (max-width:1100px){
  .cta-layout{grid-template-columns:1fr}
  .audit-card{margin-top:0}
}
@media (max-width:680px){
  .form-row{grid-template-columns:1fr}
}

/* ============ FOOTER ============ */
footer{background:var(--navy);color:rgba(245,242,234,.72);padding:clamp(80px,10vh,120px) 0 32px;position:relative;overflow:hidden}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;margin-bottom:72px}
.footer-brand .mark{color:var(--cream);margin-bottom:28px;max-width:220px}
.footer-brand .mark svg{width:100%;height:auto;overflow:visible}
.footer-brand p{color:rgba(245,242,234,.72);font-size:14.5px;line-height:1.55;max-width:320px;margin-bottom:28px}
.footer-col h4{font-family:var(--mono);font-size:11px;color:var(--yellow);letter-spacing:.22em;text-transform:uppercase;margin-bottom:22px;font-weight:500}
.footer-col ul li{margin-bottom:11px;font-size:14px;color:rgba(245,242,234,.72)}
.footer-col ul a{transition:color .3s}
.footer-col ul a:hover{color:var(--yellow)}

.footer-newsletter{display:flex;gap:10px}
.footer-newsletter input{flex:1;padding:14px 18px;background:transparent;border:1.5px solid rgba(245,242,234,.22);color:var(--cream);font-family:var(--sans);font-size:13px;transition:border-color .3s;outline:none;border-radius:999px}
.footer-newsletter input:focus{border-color:var(--yellow)}
.footer-newsletter input::placeholder{color:rgba(245,242,234,.4)}
.footer-newsletter button{padding:0 22px;background:var(--yellow);color:var(--navy);font-size:13px;font-weight:500;transition:background .3s;font-family:var(--sans);border-radius:999px;cursor:pointer}
.footer-newsletter button:hover{background:var(--terra);color:var(--white)}

.footer-big{font-family:var(--serif);font-size:clamp(80px,15vw,260px);line-height:.88;letter-spacing:-.05em;color:var(--cream);margin:48px 0 40px;white-space:nowrap}
.footer-big em{color:var(--yellow);font-style:italic}

.footer-bottom{padding-top:28px;border-top:1px solid rgba(245,242,234,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;font-family:var(--mono);font-size:11px;color:rgba(245,242,234,.55);letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.footer-bottom .links{display:flex;gap:32px}
.footer-bottom .links a:hover{color:var(--yellow)}

/* ============ REVEAL ============ */
.r{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.r.in{opacity:1;transform:none}
.r-delay-1{transition-delay:.08s}
.r-delay-2{transition-delay:.16s}
.r-delay-3{transition-delay:.24s}

/* ============ RESPONSIVE ============ */
@media (max-width:1100px){
  .pillar-grid,.packs-grid,.portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr}
  .hero-meta{grid-template-columns:1fr;gap:32px}
  .hero-cta{justify-content:flex-start}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .testi-main{grid-template-columns:1fr}
  .testi-lead-block{position:static}
  .faq-grid{grid-template-columns:1fr;gap:40px}
  .faq-head{position:static}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .hero-badge{display:none}
}
@media (max-width:680px){
  .nav-links{display:none}
  .pillar-grid,.packs-grid,.portfolio-grid,.process-steps{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .hero-top{flex-direction:column;align-items:flex-start}
  .footer-big{font-size:22vw}
  .constat-sticker{display:none}
}

/* NAP footer (parite home V2) */
.footer-nap{font-style:normal;font-size:13.5px;line-height:1.65;color:rgba(245,242,234,.72);margin-bottom:18px}
.footer-nap strong{color:var(--cream);font-weight:500}
