*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
--blue:#0D88EF;--teal:#2BB3C1;--green:#45CE9B;
--navy:#0A0F1A;--white:#FFFFFF;--off:#F7F9FB;
--border:#E2E7ED;--border-light:rgba(192,199,213,.25);
--t1:#171B27;--t2:#3D4A5C;--t3:#7A8899;--t4:#A8B4C2;
--serif:'Cormorant Garamond',Georgia,serif;
--sans:'DM Sans',-apple-system,sans-serif;
--mono:'JetBrains Mono',monospace;
}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--sans);color:var(--t1);background:var(--white);line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:color .3s}
button{cursor:pointer;border:none;font-family:inherit}
img{max-width:100%;display:block}

/* === NAV === */
.nav{position:fixed;top:0;width:100%;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:all .35s ease;padding:1.1rem 0}
.nav.scrolled{border-bottom-color:var(--border);box-shadow:0 1px 12px rgba(0,0,0,.04);padding:.85rem 0}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between}
.nav-brand{font-size:1.35rem;font-weight:700;letter-spacing:-.03em;color:var(--t1)}
.nav-brand span{color:var(--green)}
.nav-links{display:flex;gap:2.5rem}
.nav-links a{font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--t3);transition:color .3s}
.nav-links a:hover,.nav-links a.active{color:var(--t1)}
.nav-links a.active{border-bottom:2px solid var(--blue);padding-bottom:2px}
.nav-cta{padding:.6rem 1.5rem;background:var(--navy);color:#fff;font-size:.78rem;font-weight:600;letter-spacing:.02em;transition:all .3s}
.nav-cta:hover{background:var(--blue);transform:translateY(-1px)}
.hamburger{display:none;background:none;flex-direction:column;gap:4px;padding:4px}
.hamburger span{width:20px;height:1.5px;background:var(--t1)}

/* === HERO === */
.hero{position:relative;min-height:110vh;display:flex;align-items:center;background:#F4F7FA;overflow:hidden}
.hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;transform:translate(-50%,-50%);opacity:.80;object-fit:cover;z-index:0}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(244,247,250,.82) 0%,rgba(244,247,250,.55) 45%,rgba(244,247,250,.15) 100%);z-index:1}
#particleCanvas{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-inner{position:relative;z-index:3;max-width:1200px;margin:0 auto;padding:10rem 2rem 6rem;display:grid;grid-template-columns:1fr;gap:4rem;align-items:center;width:100%}
.hero-label{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}
.hero-label::before{content:'';width:28px;height:1px;background:var(--teal)}
.hero h1{font-family:var(--serif);font-size:clamp(3rem,6vw,5.5rem);font-weight:600;line-height:1.08;letter-spacing:-.03em;margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:#1A9B7A;text-shadow:0 1px 8px rgba(255,255,255,.6)}
.hero-sub{font-size:1.1rem;color:var(--t2);line-height:1.75;margin-bottom:2.5rem;max-width:520px;font-weight:300}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3.5rem}
.btn-fill{padding:.85rem 2.25rem;background:var(--navy);color:#fff;font-weight:600;font-size:.88rem;transition:all .3s;box-shadow:0 4px 16px rgba(10,15,26,.25)}
.btn-fill:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(10,15,26,.35);background:var(--blue)}
.btn-outline{padding:.85rem 2.25rem;border:2px solid var(--navy);color:var(--navy);font-weight:600;font-size:.88rem;transition:all .3s;background:rgba(255,255,255,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.btn-outline:hover{transform:translateY(-2px);border-color:var(--teal);color:var(--teal)}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.hero-stat{border:1px solid rgba(10,15,26,.12);padding:1rem;background:rgba(255,255,255,.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.hero-stat .val{font-family:var(--mono);font-size:1.5rem;font-weight:600;display:block;margin-bottom:.25rem}
.hero-stat .lbl{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;color:var(--t3)}


/* === SHARED === */
.section{padding:7rem 0}
.alt-bg{background:var(--off)}
.dark-bg{background:var(--navy);color:#fff}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.mono-label{font-family:var(--mono);font-size:.65rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);font-weight:500;margin-bottom:.75rem}
.section-title{font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:600;line-height:1.15;letter-spacing:-.02em;margin-bottom:.75rem}
.section-sub{font-size:1rem;color:var(--t2);max-width:520px;line-height:1.7;font-weight:300}
.reveal{opacity:0;transform:translateY(24px);transition:all .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:none}

/* === SERVICES === */
.svc-featured{display:grid;grid-template-columns:1fr 260px;background:var(--white);border-left:3px solid var(--blue);position:relative;overflow:hidden;margin-bottom:1.5rem;transition:all .5s cubic-bezier(.25,.8,.25,1)}
.svc-featured:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.08)}
.svc-featured:hover .svc-featured-img{transform:scale(1.06)}
.svc-featured:hover .svc-num{opacity:.12;color:var(--teal);transform:translateY(-3px)}
.svc-featured-content{padding:2.75rem;position:relative}
.svc-featured-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.svc-featured .svc-num{font-size:8rem;top:-.2rem}
.svc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1.25rem}
.svc-card{background:var(--white);border-left:2px solid var(--teal);position:relative;overflow:hidden;transition:all .5s cubic-bezier(.25,.8,.25,1);grid-column:span 2}
.svc-card:nth-child(4){grid-column:span 3}
.svc-card:nth-child(5){grid-column:span 3}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 20px 60px rgba(0,0,0,.09);border-left-color:var(--green);border-left-width:3px}
.svc-card:hover .svc-card-img{transform:scale(1.08);filter:brightness(1.04)}
.svc-card:hover .svc-num{opacity:.14;color:var(--teal);transform:translateY(-3px)}
.svc-card:hover .svc-title{color:var(--blue)}
.svc-card-img{width:calc(100% - 1.5rem);height:120px;object-fit:cover;display:block;margin:.75rem auto 0;border-radius:6px;transition:all .5s ease}
.svc-card-body{padding:1rem 1.5rem 1.5rem;position:relative;overflow:hidden}
.svc-num{font-family:var(--serif);font-size:6.5rem;line-height:1;position:absolute;top:-.2rem;right:.5rem;opacity:.07;pointer-events:none;user-select:none;color:var(--t1);transition:all .5s ease}
.svc-title{font-family:var(--serif);font-size:1.6rem;margin-bottom:.5rem;transition:color .4s ease}
.svc-featured .svc-title{font-size:2.2rem}
.svc-desc{font-size:.88rem;color:var(--t2);line-height:1.65}
.svc-icon{margin-top:auto;padding-top:1rem;color:var(--teal);opacity:.5}

/* === PROCESS === */
.proc-header{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:3rem}
.proc-aside{max-width:340px;font-size:.92rem;color:var(--t2);border-left:2px solid var(--blue);padding-left:1.25rem;line-height:1.7;font-weight:300}
.proc-steps-wrap{position:relative;padding-left:32px}
/* Vertical timeline line */
.proc-steps-wrap::before{content:'';position:absolute;left:8px;top:2.5rem;bottom:5.5rem;width:2px;background:linear-gradient(180deg,var(--teal),var(--green));opacity:.3}
.proc-step{display:flex;gap:2.5rem;padding:2rem 0;border-top:1px solid var(--border-light);align-items:flex-start;transition:all .3s;position:relative}
.proc-step:last-child{border-bottom:1px solid var(--border-light)}
.proc-step:hover{padding-left:.75rem}
/* Timeline dot on the left */
.proc-step::before{content:'';position:absolute;left:-28px;top:2.4rem;width:10px;height:10px;border-radius:50%;background:var(--teal);opacity:.4;transition:all .4s;z-index:1}
.proc-step:hover::before{opacity:.8;transform:scale(1.3);background:var(--blue)}
/* Arrow chevron between steps */
.proc-step:not(:last-child)::after{content:'';position:absolute;left:-26px;bottom:-6px;width:6px;height:6px;border-right:2px solid var(--green);border-bottom:2px solid var(--green);transform:rotate(45deg);opacity:.4;transition:opacity .4s}
.proc-step:hover::after{opacity:.7}
.proc-num{font-family:var(--serif);font-size:3.5rem;font-weight:600;color:var(--border);line-height:1;min-width:60px;transition:color .4s}
.proc-step:hover .proc-num{color:rgba(13,136,239,.25)}
.proc-body{display:grid;grid-template-columns:1fr 2fr;gap:1.5rem;flex:1}
.proc-label{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.35rem}
.proc-title{font-size:1.15rem;font-weight:600}
.proc-desc{font-size:.88rem;color:var(--t2);line-height:1.7;max-width:480px}

/* === CASES === */
.cases-list{display:flex;flex-direction:column;gap:1.75rem;margin-top:2.5rem}
.case-card{display:flex;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04);transition:all .5s}
.case-card:hover{box-shadow:0 16px 48px rgba(0,0,0,.08)}
.case-card:nth-child(even){flex-direction:row-reverse}
.case-metric{width:33%;padding:3rem;display:flex;flex-direction:column;justify-content:center;color:#fff}
.case-metric.blue{background:var(--blue)}
.case-metric.teal{background:var(--teal)}
.case-metric.green{background:var(--green);color:var(--navy)}
.case-metric.dark{background:var(--navy)}
.case-metric .big{font-family:var(--mono);font-size:4rem;font-weight:700;line-height:1}
.case-metric .big-label{display:block;font-family:var(--sans);font-size:.75rem;font-weight:400;letter-spacing:.04em;opacity:.7;margin-top:.5rem;text-transform:uppercase}
.case-metric .tag{margin-top:1.5rem;display:inline-block;padding:.2rem .6rem;font-family:var(--mono);font-size:.55rem;text-transform:uppercase;letter-spacing:.08em;background:rgba(255,255,255,.2);width:fit-content}
.case-body{width:67%;padding:3rem;display:flex;flex-direction:column;justify-content:center;background:var(--white)}
.case-card:nth-child(even) .case-body{text-align:right}
.case-h{font-family:var(--serif);font-size:1.75rem;margin-bottom:.75rem}
.case-p{font-size:.88rem;color:var(--t2);line-height:1.7;margin-bottom:1rem}
.case-sub{font-family:var(--mono);font-size:.68rem;color:var(--t3);text-transform:uppercase;letter-spacing:.05em}

/* === STACK === */
.stack-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:2.5rem;margin-top:3rem}
.stack-cat h4{font-family:var(--serif);font-size:1.1rem;font-style:italic;padding-bottom:.5rem;border-bottom:1px solid var(--border-light);margin-bottom:.75rem}
.stack-item{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;color:var(--t3);padding:.35rem 0}

/* === ABOUT === */
.about-quote{font-family:var(--serif);font-size:clamp(2.5rem,5vw,4rem);font-weight:600;line-height:1.2;letter-spacing:-.02em;text-align:center;max-width:800px;margin:0 auto 4rem;font-style:italic}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-bottom:3rem}
.about-role{font-family:var(--mono);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--teal);margin-bottom:.75rem}
.about-bio{font-size:1.05rem;color:var(--t2);line-height:1.8;font-weight:300}
.about-col:nth-child(2){border-left:1px solid var(--border);padding-left:3rem}
.about-diffs{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}
.about-diff{padding:.5rem 1.25rem;border:1px solid var(--border);font-size:.78rem;font-weight:500;color:var(--t2);transition:all .3s}
.about-diff:hover{border-color:var(--green);color:var(--green)}

/* === SECTORS === */
.sector-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border-light);margin-top:3rem}
.sector-cell{padding:2.25rem;border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light);transition:background .3s}
.sector-cell:nth-child(4n){border-right:none}
.sector-cell:nth-child(n+5){border-bottom:none}
.sector-cell:hover{background:var(--off)}
.sector-icon{margin-bottom:1rem;transition:transform .4s ease}
.sector-icon svg{display:block}
.sector-cell:hover .sector-icon{transform:translateY(-2px)}
.sector-name{font-family:var(--serif);font-size:1.3rem;margin-bottom:.35rem}
.sector-desc{font-family:var(--mono);font-size:.55rem;text-transform:uppercase;color:var(--t3);letter-spacing:.05em;line-height:1.5}

/* === CTA / CONTACT === */
.cta{padding:7rem 2rem;background:var(--navy)}
.cta-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:start}
.cta-left h2{font-family:var(--serif);font-size:clamp(2.8rem,5vw,4.2rem);color:#fff;margin-bottom:1rem;line-height:1.1}
.cta-left-sub{color:rgba(255,255,255,.45);font-size:1rem;font-weight:300;line-height:1.75;margin-bottom:2.5rem;max-width:380px}
.cta-info{display:flex;flex-direction:column;gap:1.25rem}
.cta-info-row{display:flex;align-items:center;gap:.75rem}
.cta-info-icon{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cta-info-icon svg{opacity:.5}
.cta-info-text{font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.5}
.cta-info-text a{color:var(--green);transition:opacity .3s}
.cta-info-text a:hover{opacity:.7}
/* Form */
.cta-form{display:flex;flex-direction:column;gap:1.25rem}
.cta-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.cta-field{display:flex;flex-direction:column;gap:.4rem}
.cta-field label{font-family:var(--mono);font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.cta-field input,.cta-field select,.cta-field textarea{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:#fff;font-family:var(--sans);font-size:.88rem;padding:.8rem 1rem;transition:all .3s;outline:none;-webkit-appearance:none;appearance:none;border-radius:0}
.cta-field input::placeholder,.cta-field textarea::placeholder{color:rgba(255,255,255,.2)}
.cta-field input:focus,.cta-field select:focus,.cta-field textarea:focus{border-color:var(--teal);background:rgba(255,255,255,.06)}
.cta-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='rgba(255,255,255,0.3)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.cta-field select option{background:var(--navy);color:#fff}
.cta-field textarea{resize:vertical;min-height:100px}
.cta-submit{padding:1rem 2.5rem;background:var(--green);color:var(--navy);font-weight:700;font-size:.88rem;letter-spacing:.03em;transition:all .3s;display:inline-block;width:fit-content;border:none;cursor:pointer;font-family:var(--sans)}
.cta-submit:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(69,206,155,.25)}
.cta-note{font-family:var(--mono);font-size:.55rem;color:rgba(255,255,255,.2);letter-spacing:.05em}

/* === FOOTER === */
.footer{background:var(--navy);border-top:1px solid rgba(255,255,255,.06);padding:4rem 0 2rem;color:rgba(255,255,255,.5)}
.footer-grid{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand{font-size:1.35rem;font-weight:700;color:#fff;margin-bottom:1rem}
.footer-brand span{color:var(--green)}
.footer-desc{font-size:.85rem;line-height:1.7;max-width:260px}
.footer h5{font-family:var(--serif);font-size:1.1rem;font-style:italic;color:rgba(255,255,255,.7);margin-bottom:1.25rem}
.footer a{display:block;font-size:.85rem;margin-bottom:.6rem;transition:color .3s}
.footer a:hover{color:var(--green)}
.footer-bottom{max-width:1200px;margin:0 auto;padding:2rem 2rem 0;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.2)}

/* === MOBILE MENU === */
.mob-menu{position:fixed;inset:0;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .3s}
.mob-menu.open{opacity:1;pointer-events:all}
.mob-menu a{font-family:var(--serif);font-size:1.75rem;color:var(--t1);font-weight:600}
.mob-close{position:absolute;top:1.5rem;right:2rem;background:none;font-size:2rem;color:var(--t1)}

/* === RESPONSIVE === */
@media(max-width:1024px){
.hero-inner{grid-template-columns:1fr}
.svc-grid{grid-template-columns:1fr 1fr}.svc-card{grid-column:span 1}.svc-card:nth-child(4),.svc-card:nth-child(5){grid-column:span 1}.svc-featured{grid-template-columns:1fr}.svc-featured-img{height:180px}
.proc-header{flex-direction:column}.proc-body{grid-template-columns:1fr}
.case-metric{width:35%}.case-body{width:65%}
.stack-grid{grid-template-columns:repeat(3,1fr)}
.about-grid{grid-template-columns:1fr}.about-col:nth-child(2){border-left:none;padding-left:0;border-top:1px solid var(--border);padding-top:2rem}
.sector-grid{grid-template-columns:repeat(2,1fr)}.sector-cell:nth-child(2n){border-right:none}.sector-cell:nth-child(n+7){border-bottom:none}
.footer-grid{grid-template-columns:1fr 1fr}
.cta-grid{grid-template-columns:1fr;gap:3rem}
}
@media(max-width:768px){
.nav-links,.nav-cta{display:none}.hamburger{display:flex}
.hero h1{font-size:2.6rem}.hero-stats{grid-template-columns:1fr 1fr}.hero-inner{padding-top:7rem;padding-bottom:4rem}
.svc-grid{grid-template-columns:1fr}.svc-card,.svc-card:nth-child(4),.svc-card:nth-child(5){grid-column:span 1}.svc-card-img{height:140px}
.proc-step{flex-direction:column;gap:1rem}.proc-num{font-size:2.5rem}.proc-steps-wrap{padding-left:0}.proc-steps-wrap::before{display:none}.proc-step::before,.proc-step::after{display:none!important}.proc-body{grid-template-columns:1fr}
.case-card,.case-card:nth-child(even){flex-direction:column}.case-metric,.case-body{width:100%}
.stack-grid{grid-template-columns:1fr 1fr}
.sector-grid{grid-template-columns:1fr 1fr}
.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;gap:.75rem;text-align:center}
.cta-form-row{grid-template-columns:1fr}
}
