*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#ffffff;
  --off:#f8f7f5;
  --black:#0c0c0c;
  --grey:#f0efed;
  --border:#e8e6e2;
  --muted:#9a9890;
}
html{scroll-behavior:smooth}
body{
  background:var(--white);
  color:var(--black);
  font-family:'DM Sans',sans-serif;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ── CURSOR ── */
#c1,#c2{display:none}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 5vw;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
}
.logo{
  font-family:'Cormorant Garamond',serif;
  font-size:1.45rem;font-weight:600;
  color:var(--black);text-decoration:none;
  letter-spacing:-.01em;display:flex;align-items:center;gap:10px;
}
.logo i{font-style:italic;font-weight:300}
/* Sigil */
.sigil-wrap{position:relative;width:38px;height:38px;flex-shrink:0}
.sigil-ring{position:absolute;inset:0;border:1.5px solid rgba(12,12,12,.22);border-radius:50%}
.sigil-core{position:absolute;inset:9px;background:var(--black);border-radius:50%}
.sigil-spin{position:absolute;inset:-3px;width:44px;height:44px;animation:rot 16s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{
  font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--black);text-decoration:none;
  opacity:.35;transition:opacity .2s;
}
.nav-links a:hover{opacity:1}
.nav-btn{
  background:var(--black);color:var(--white);
  padding:12px 28px;border-radius:100px;
  font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;
  transition:background .2s,transform .2s;
  white-space:nowrap;
}
.nav-btn:hover{background:#222;transform:translateY(-1px)}

/* ── HERO ── */
#hero{
  min-height:100vh;
  background:var(--white);
  display:grid;
  grid-template-rows:1fr auto;
  padding:130px 5vw 0;
  position:relative;
  overflow:hidden;
}
/* Subtle geometric line art - purely decorative, no colour wash */
.hero-geo{
  position:absolute;
  right:-80px;top:50%;
  transform:translateY(-55%);
  width:min(620px,70vw);
  opacity:.04;
  pointer-events:none;
}
.hero-eyebrow{
  font-size:.68rem;font-weight:500;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:24px;
  opacity:0;animation:up .7s .15s forwards;
}
h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(4.5rem,11vw,12.5rem);
  font-weight:600;line-height:.9;
  letter-spacing:-.03em;
  max-width:900px;
  opacity:0;animation:up .9s .3s forwards;
}
h1 i{font-style:italic;font-weight:300}
h1 .stroke{
  -webkit-text-stroke:1.5px var(--black);
  color:transparent;
}
.hero-bottom{
  display:flex;align-items:flex-end;justify-content:space-between;
  padding:32px 0 60px;
  border-top:1px solid var(--border);
  margin-top:48px;
  flex-wrap:wrap;gap:24px;
  opacity:0;animation:up .8s .6s forwards;
}
.hero-desc{
  font-size:1rem;max-width:380px;
  line-height:1.75;color:var(--muted);font-weight:300;
}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.btn-blk{
  background:var(--black);color:var(--white);
  padding:15px 36px;border-radius:100px;
  font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;transition:transform .2s,box-shadow .2s;
}
.btn-blk:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(12,12,12,.16)}
.btn-ring{
  border:1.5px solid rgba(12,12,12,.2);color:var(--black);
  padding:14px 32px;border-radius:100px;
  font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  text-decoration:none;transition:border-color .2s,transform .2s;
}
.btn-ring:hover{border-color:var(--black);transform:translateY(-2px)}

/* ── FLOATING HERO CARDS ── */
.hero-cards{
  position:absolute;right:5vw;top:50%;
  transform:translateY(-50%);
  display:flex;flex-direction:column;gap:14px;
  opacity:0;animation:up .8s .85s forwards;
}
.hc{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px 22px;
  min-width:190px;
  box-shadow:0 4px 24px rgba(12,12,12,.06),0 1px 3px rgba(12,12,12,.04);
}
.hc:nth-child(1){animation:floatA 6s ease-in-out infinite 1s}
.hc:nth-child(2){animation:floatB 7.5s ease-in-out infinite .5s;margin-left:22px}
.hc:nth-child(3){animation:floatC 5.5s ease-in-out infinite 1.5s}
@keyframes floatA{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-14px) rotate(1deg)}}
@keyframes floatB{0%,100%{transform:translateY(0) rotate(2deg)}50%{transform:translateY(-10px) rotate(-1deg)}}
@keyframes floatC{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-18px) rotate(2deg)}}
.hc-ico{font-size:1.3rem;margin-bottom:8px}
.hc-lbl{font-size:.6rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.hc-val{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;line-height:1;color:var(--black)}
.hc-sub{font-size:.68rem;color:var(--muted);margin-top:3px}

/* ── TICKER ── */
.ticker{
  overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:12px 0;
  background:var(--black);
}
.ticker-t{display:flex;width:max-content;animation:tk 28s linear infinite}
.ticker-t:hover{animation-play-state:paused}
.tk-i{
  font-size:.68rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;white-space:nowrap;
  padding:0 26px;color:rgba(255,255,255,.35);
}
.tk-i.on{color:rgba(255,255,255,.85)}

/* ── SECTIONS ── */
section{padding:110px 5vw;background:var(--white)}
.s-label{
  font-size:.64rem;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--muted);
  margin-bottom:16px;
  display:flex;align-items:center;gap:10px;
}
.s-label::before{content:'';width:18px;height:1px;background:var(--muted)}
h2.disp{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,6.5vw,7rem);
  font-weight:600;line-height:.92;letter-spacing:-.03em;
}
h2.disp i{font-style:italic;font-weight:300}
h2.disp .sk{-webkit-text-stroke:1.5px var(--black);color:transparent}

/* ── SERVICES ── */
#services{background:var(--white)}
.svc-head{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.svc-head p{font-size:.96rem;line-height:1.8;color:var(--muted);max-width:340px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);border-left:1px solid var(--border)}
.sc{
  padding:40px 32px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
  transition:background .35s;cursor:none;
}
.sc::after{
  content:'';position:absolute;inset:0;
  background:var(--black);
  transform:translateY(100%);
  transition:transform .45s cubic-bezier(.77,0,.18,1);
  z-index:0;
}
.sc:hover::after{transform:translateY(0)}
.sc>*{position:relative;z-index:1}
.sc:hover .sc-num,.sc:hover .sc-title,.sc:hover .sc-body{color:var(--white)}
.sc-num{font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:20px;display:block;transition:color .35s}
.sc-ico{font-size:1.8rem;margin-bottom:14px;display:block}
.sc-title{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;margin-bottom:10px;transition:color .35s}
.sc-body{font-size:.84rem;line-height:1.7;color:var(--muted);transition:color .35s}

/* ── DARK STRIP ── */
#strip{
  background:var(--black);
  padding:90px 5vw;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.strip-l h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,6vw,6rem);
  font-weight:600;line-height:.95;letter-spacing:-.03em;
  color:var(--white);
  margin-bottom:24px;
}
.strip-l h2 i{font-style:italic;font-weight:300}
.strip-l h2 .sk2{-webkit-text-stroke:1px rgba(255,255,255,.35);color:transparent}
.strip-l p{font-size:.96rem;line-height:1.8;color:rgba(255,255,255,.4);max-width:380px;font-weight:300}
.strip-r{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,.08)}
.sbox{
  background:var(--black);padding:40px 32px;
  transition:background .3s;
}
.sbox:hover{background:#161616}
.sbox-val{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,5.5vw,5rem);
  font-weight:600;line-height:1;letter-spacing:-.03em;
  color:var(--white);
}
.sbox-lbl{font-size:.66rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:8px}

/* ── FLOATING VISUAL ── */
#about{background:var(--off)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-l h2{margin-bottom:20px}
.about-l p{font-size:.96rem;line-height:1.8;color:var(--muted);max-width:400px;margin-bottom:32px;font-weight:300}
/* floating blobs */
.blob-scene{position:relative;height:460px}
.blob{
  position:absolute;border-radius:24px;
  display:flex;align-items:center;justify-content:center;
  font-size:2.5rem;
  box-shadow:0 12px 40px rgba(12,12,12,.08);
  overflow:hidden;
}
.blob::before{content:'';position:absolute;inset:0;border-radius:24px}
.b1{width:210px;height:270px;top:0;left:20px;background:var(--grey);animation:bA 7s ease-in-out infinite}
.b2{width:170px;height:190px;top:20px;right:20px;background:var(--white);border:1px solid var(--border);animation:bB 8.5s ease-in-out infinite .6s}
.b3{width:240px;height:190px;bottom:30px;left:0;background:var(--black);animation:bC 6.5s ease-in-out infinite 1.2s}
.b3 .bi{filter:grayscale(1) invert(1)}
.b4{width:155px;height:170px;bottom:10px;right:30px;background:var(--grey);animation:bD 9s ease-in-out infinite 2s}
.bi{font-size:2.5rem}
.b-tag{
  position:absolute;bottom:12px;left:12px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(10px);
  border-radius:10px;
  padding:6px 12px;
  font-size:.6rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:var(--black);
}
.b3 .b-tag{background:rgba(255,255,255,.12);color:rgba(255,255,255,.7)}
@keyframes bA{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-16px) rotate(1.5deg)}}
@keyframes bB{0%,100%{transform:translateY(0) rotate(2.5deg)}50%{transform:translateY(-12px) rotate(-1deg)}}
@keyframes bC{0%,100%{transform:translateY(0) rotate(1deg)}50%{transform:translateY(-20px) rotate(-2deg)}}
@keyframes bD{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(1.5deg)}}

/* ── PROCESS ── */
#process{background:var(--white)}
.proc-head{margin-bottom:60px}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--border);border-left:1px solid var(--border)}
.pcard{
  padding:44px 30px;
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:background .3s;cursor:none;
  position:relative;overflow:hidden;
}
.pcard:hover{background:var(--black)}
.pcard:hover .pc-n,.pcard:hover .pc-h3,.pcard:hover .pc-p{color:var(--white)}
.pc-n{font-family:'Cormorant Garamond',serif;font-size:4.5rem;font-weight:300;color:rgba(12,12,12,.06);line-height:1;margin-bottom:20px;transition:color .3s}
.pcard:hover .pc-n{color:rgba(255,255,255,.07)}
.pc-h3{font-family:'Cormorant Garamond',serif;font-size:1.3rem;font-weight:600;margin-bottom:10px;transition:color .3s}
.pc-p{font-size:.83rem;line-height:1.7;color:var(--muted);transition:color .3s}

/* ── TESTIMONIAL / STATEMENT ── */
#statement{background:var(--off);text-align:center;padding:100px 5vw}
.stmt h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.5rem,6vw,6.5rem);
  font-weight:600;line-height:.95;letter-spacing:-.03em;
  max-width:860px;margin:0 auto;
}
.stmt h2 i{font-style:italic;font-weight:300}
.stmt h2 .sk{-webkit-text-stroke:1.5px var(--black);color:transparent}
.stmt p{font-size:.98rem;color:var(--muted);max-width:520px;margin:28px auto 0;line-height:1.8;font-weight:300}
.pill-row{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:36px}
.pill{
  border:1px solid var(--border);
  padding:9px 20px;border-radius:100px;
  font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  transition:background .2s,border-color .2s,color .2s;cursor:none;
}
.pill:hover{background:var(--black);color:var(--white);border-color:var(--black)}

/* ── CTA ── */
#cta{
  background:var(--black);
  padding:120px 5vw;
  text-align:center;
  position:relative;overflow:hidden;
}
/* Subtle grid lines only — no colour blobs */
.cta-grid{
  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:80px 80px;
  pointer-events:none;
}
#cta h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,9vw,9.5rem);
  font-weight:600;line-height:.9;letter-spacing:-.03em;
  color:var(--white);max-width:900px;margin:0 auto;
  position:relative;z-index:1;
}
#cta h2 i{font-style:italic;font-weight:300}
#cta h2 .sk{-webkit-text-stroke:1px rgba(255,255,255,.25);color:transparent}
#cta p{
  font-size:.98rem;color:rgba(255,255,255,.35);
  max-width:400px;margin:28px auto 44px;
  line-height:1.8;font-weight:300;
  position:relative;z-index:1;
}
.btn-wht{
  background:var(--white);color:var(--black);
  padding:17px 50px;border-radius:100px;
  font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;display:inline-block;
  transition:transform .2s,box-shadow .2s;
  position:relative;z-index:1;
}
.btn-wht:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(255,255,255,.12)}

/* ── CONTACT ── */
#contact{background:var(--white)}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:80px;margin-top:60px}
.c-left p{font-size:.96rem;line-height:1.8;color:var(--muted);max-width:360px;margin-top:18px;margin-bottom:36px;font-weight:300}
.c-facts{display:flex;flex-direction:column}
.cf{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border)}
.cfk{font-size:.62rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.cfv{font-size:.86rem;color:var(--black);font-weight:400}
/* Form */
.cform{border:1px solid var(--border);border-radius:20px;overflow:hidden}
.fg{display:flex;flex-direction:column;padding:18px 22px;border-bottom:1px solid var(--border);transition:background .2s}
.fg:focus-within{background:var(--off)}
.frow{display:grid;grid-template-columns:1fr 1fr}
.frow .fg{border-right:1px solid var(--border)}
.frow .fg:last-child{border-right:none}
.fg.full{border-right:none}
label{font-size:.58rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
input,textarea,select{
  background:transparent;border:none;
  color:var(--black);font-family:'DM Sans',sans-serif;
  font-size:.92rem;font-weight:300;outline:none;width:100%;
}
input::placeholder,textarea::placeholder{color:rgba(12,12,12,.2)}
textarea{min-height:96px;resize:none}
select option{background:var(--white)}
.fsub{
  background:var(--black);color:var(--white);
  padding:20px;width:100%;border:none;
  font-family:'DM Sans',sans-serif;
  font-size:.75rem;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  cursor:none;transition:background .2s;
  border-radius:0 0 18px 18px;
}
.fsub:hover{background:#222}

/* ── FOOTER ── */
footer{
  background:var(--off);
  border-top:1px solid var(--border);
  padding:52px 5vw 36px;
}
.ft{display:flex;justify-content:space-between;flex-wrap:wrap;gap:36px;margin-bottom:44px;padding-bottom:40px;border-bottom:1px solid var(--border)}
.fb .logo{display:block;margin-bottom:10px}
.fb p{font-size:.83rem;color:var(--muted);max-width:220px;line-height:1.7;font-weight:300}
.fc h4{font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.fc ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.fc ul a{font-size:.86rem;color:var(--muted);text-decoration:none;transition:color .2s;font-weight:300}
.fc ul a:hover{color:var(--black)}
.fb2{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fb2 p{font-size:.68rem;color:rgba(12,12,12,.25);letter-spacing:.04em}

/* ── REVEAL ── */
.rev{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.25,.46,.45,.94),transform .85s cubic-bezier(.25,.46,.45,.94)}
.rev.in{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.38s}

/* ── KEYFRAMES ── */
@keyframes up{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes tk{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── MOBILE ── */
@media(max-width:860px){
  .hero-cards{display:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .strip-r{grid-template-columns:1fr 1fr}
  #strip{grid-template-columns:1fr;gap:40px}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:1fr 1fr}
  .svc-head{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .frow .fg{border-right:none}
  .blob-scene{height:300px}
  .b1{width:150px;height:200px}
  .b2{width:130px;height:150px;right:0}
  .b3{width:180px;height:150px;bottom:0}
  .b4{width:110px;height:130px;right:10px}
  .nav-links{display:none}
}

/* ============ MULTI-PAGE ADDITIONS ============ */
.nav-links a.active{opacity:1}
.page-hero{padding:170px 5vw 80px;background:var(--white);position:relative;overflow:hidden}
.page-hero .s-label{justify-content:flex-start}
.breadcrumb{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.breadcrumb a{color:var(--muted);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--black)}
.breadcrumb span{margin:0 8px;opacity:.5}
.prose{max-width:760px}
.prose p{font-size:1rem;line-height:1.85;color:var(--muted);margin-bottom:22px;font-weight:300}
.prose h3{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;margin:44px 0 16px;letter-spacing:-.02em}
.prose ul{list-style:none;margin:22px 0}
.prose ul li{font-size:.96rem;line-height:1.8;color:var(--muted);padding-left:26px;position:relative;margin-bottom:10px}
.prose ul li::before{content:'';position:absolute;left:0;top:13px;width:10px;height:1px;background:var(--black)}
.svc-detail-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:70px;align-items:start;margin-top:20px}
.svc-aside{border:1px solid var(--border);border-radius:18px;padding:30px;position:sticky;top:110px}
.svc-aside h4{font-size:.64rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.svc-aside ul{list-style:none}
.svc-aside ul li{padding:11px 0;border-bottom:1px solid var(--border);font-size:.85rem}
.svc-aside ul li:last-child{border-bottom:none}
.svc-aside ul li a{color:var(--black);text-decoration:none;display:flex;justify-content:space-between;opacity:.6;transition:opacity .2s}
.svc-aside ul li a:hover,.svc-aside ul li a.active{opacity:1}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:30px}
.bcard{border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:transform .3s,box-shadow .3s;text-decoration:none;color:var(--black);display:block}
.bcard:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(12,12,12,.08)}
.bcard-top{height:160px;background:var(--grey);display:flex;align-items:center;justify-content:center;font-size:2.5rem}
.bcard-body{padding:26px 24px}
.bcard-cat{font-size:.6rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:block}
.bcard h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:600;line-height:1.15;margin-bottom:10px}
.bcard p{font-size:.84rem;line-height:1.65;color:var(--muted)}
.bcard-meta{font-size:.7rem;color:var(--muted);margin-top:16px;letter-spacing:.04em}
@media(max-width:880px){.svc-detail-grid{grid-template-columns:1fr}.svc-aside{position:static}.blog-grid{grid-template-columns:1fr}.nav-links{display:none}}

