*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden;scroll-behavior:auto}
body{font-family:var(--ui,'Manrope',sans-serif);font-weight:300;overflow-x:hidden;cursor:none;background:var(--bg,#080808);color:#fff}
@media(pointer:coarse){body{cursor:auto}}

/* ─ FONTS (preloaded by each page) ─ */
:root{
  --font:'Cormorant Garamond',Georgia,serif;
  --ui:'Manrope',sans-serif;
  --gold:#c8a45e;
  --white:#fff;
}

/* ─ CURSOR ─ */
.cur-h,.cur-v{position:fixed;z-index:9999;pointer-events:none;top:0;left:0;transform:translate(-50%,-50%)}
.cur-h{width:20px;height:1px;background:var(--accent,.8)}
.cur-v{width:1px;height:20px;background:var(--accent,.8)}
.cur-sq{position:fixed;z-index:10000;width:4px;height:4px;pointer-events:none;top:0;left:0;transform:translate(-50%,-50%);background:var(--accent)}
@media(pointer:coarse){.cur-h,.cur-v,.cur-sq{display:none!important}}

/* ─ NAV ─ */
#co-nav{position:fixed;inset:0 0 auto;z-index:800;padding:1.4rem 3rem;display:flex;justify-content:space-between;align-items:center;transition:all .4s}
#co-nav.solid{background:var(--nav-bg,rgba(8,8,8,.94));backdrop-filter:blur(20px);border-bottom:1px solid var(--line,rgba(255,255,255,.07))}
.nav-back{display:flex;align-items:center;gap:.8rem;text-decoration:none;color:rgba(255,255,255,.4);font-family:var(--ui);font-size:.6rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;transition:color .2s}
.nav-back:hover{color:var(--accent)}
.nav-back svg{width:14px;opacity:.5;transition:opacity .2s;flex-shrink:0}
.nav-back:hover svg{opacity:1}
.nav-co{text-align:right}
.nav-co-name{font-family:var(--ui);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.nav-co-tag{font-family:var(--ui);font-size:.58rem;letter-spacing:.14em;color:rgba(255,255,255,.2);text-transform:uppercase;margin-top:.2rem}

/* ─ HERO ─ */
#hero{position:relative;height:100vh;min-height:640px;overflow:hidden;display:flex;align-items:flex-end}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.65)}
.hero-bg{position:absolute;inset:0;background:var(--bg);z-index:0}
.hero-vignette{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse 80% 90% at 50% 60%,transparent 20%,var(--bg) 100%)}
.hero-body{position:relative;z-index:3;padding:0 6vw 8vh}
.hero-num{font-family:var(--ui);font-size:.6rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);opacity:.6;margin-bottom:1.2rem}
.hero-title{font-family:var(--font);font-size:clamp(11vw,15vw,18rem);font-weight:700;line-height:.86;text-transform:uppercase;letter-spacing:.02em}
.hero-sub{font-family:var(--ui);font-size:.9rem;font-weight:300;line-height:1.8;color:rgba(255,255,255,.38);margin-top:1.5rem;max-width:460px}
.hero-scroll{position:absolute;right:3rem;bottom:2rem;z-index:4;display:flex;align-items:center;gap:.8rem;font-family:var(--ui);font-size:.55rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.18)}
.hero-scroll-line{display:block;width:36px;height:1px;background:linear-gradient(to right,var(--accent),transparent)}

/* ─ CONTENT WRAPPER ─ */
.co-content{position:relative;background:var(--bg);padding:7rem 6vw}

/* ─ SECTION ─ */
.sec{max-width:1240px;margin:0 auto}
.sec-divider{border:none;border-top:1px solid var(--line,rgba(255,255,255,.07));max-width:1240px;margin:0 auto}
.eyebrow{font-family:var(--ui);font-size:.58rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);opacity:.6;margin-bottom:2rem}

/* ─ ABOUT ─ */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:7rem;align-items:start;margin-bottom:7rem}
.about-title{font-family:var(--font);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:700;text-transform:uppercase;line-height:.9;margin-bottom:2.5rem}
.about-italic{font-style:italic;font-weight:300;color:rgba(255,255,255,.28)}
.about-desc{font-size:.88rem;font-weight:300;line-height:1.95;color:rgba(255,255,255,.42)}
.about-desc+.about-desc{margin-top:1.2rem}

/* ─ STATS ─ */
.stats-col{display:flex;flex-direction:column;gap:3.5rem;padding-top:2rem}
.stat-n{font-family:var(--font);font-size:clamp(3rem,7vw,5.5rem);font-weight:700;color:var(--accent);line-height:1}
.stat-l{font-family:var(--ui);font-size:.55rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-top:.5rem}

/* ─ SERVICES ─ */
.srv-label{font-family:var(--ui);font-size:.58rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.2);padding-bottom:1.8rem;border-bottom:1px solid var(--line,rgba(255,255,255,.07));margin-bottom:0}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line,rgba(255,255,255,.07))}
.srv-item{background:var(--bg);padding:2.8rem 2.2rem;transition:background .3s}
.srv-item:hover{background:var(--accent-bg)}
.srv-num{font-family:var(--ui);font-size:.52rem;font-weight:500;letter-spacing:.2em;color:var(--accent);opacity:.5;margin-bottom:1.4rem}
.srv-name{font-family:var(--font);font-size:1.5rem;font-weight:600;line-height:1.1;margin-bottom:.9rem}
.srv-desc{font-size:.76rem;font-weight:300;line-height:1.75;color:rgba(255,255,255,.3)}

/* ─ CTA ─ */
.cta-row{display:flex;align-items:center;justify-content:space-between;padding:5rem 0;border-top:1px solid var(--line,rgba(255,255,255,.07));margin-top:5rem}
.cta-title{font-family:var(--font);font-size:clamp(2rem,4vw,3.2rem);font-weight:700;text-transform:uppercase}
.cta-btns{display:flex;gap:1.2rem}
.btn{font-family:var(--ui);font-size:.62rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;padding:.9rem 2rem;transition:all .2s;cursor:none}
.btn-primary{background:var(--accent);color:var(--bg)}
.btn-primary:hover{opacity:.85}
.btn-secondary{border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.45)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}

/* ─ FOOTER ─ */
.co-footer{text-align:center;padding:3rem;border-top:1px solid rgba(255,255,255,.04);font-family:var(--ui);font-size:.55rem;color:rgba(255,255,255,.12);letter-spacing:.15em;text-transform:uppercase}

/* ─ REVEAL ─ */
.rv{opacity:0;transform:translateY(32px);transition:opacity .8s,transform .8s}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.12s}.rv.d2{transition-delay:.22s}.rv.d3{transition-delay:.32s}

/* ─ LOADING ─ */
#page-loader{position:fixed;inset:0;background:var(--bg,#080808);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s}
#page-loader.out{opacity:0;pointer-events:none}
.loader-logo{font-family:var(--ui);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.2);animation:pulse 1.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.2}50%{opacity:.6}}

/* ─ RESPONSIVE ─ */
@media(max-width:1024px){.srv-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:860px){
  #co-nav{padding:1.2rem 1.5rem}
  .about-grid{grid-template-columns:1fr;gap:4rem}
  .srv-grid{grid-template-columns:1fr}
  .cta-row{flex-direction:column;gap:2rem;align-items:flex-start}
  .hero-title{font-size:17vw}
  .co-content{padding:5rem 1.5rem}
}
