*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0d0c0e;--ink2:#3a3840;--ink3:#7a7886;
  --gold:#b8975a;--gold-dark:#8a6b35;--gold-l:#e8d9b8;--gold-p:#f7f2e8;
  --white:#fdfcf9;--dark:#0a0909;
  --border:rgba(184,151,90,0.18);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--white);color:var(--ink);overflow-x:hidden;cursor:none}

/* CURSOR */
.cursor{position:fixed;width:8px;height:8px;background:var(--gold);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s}
.cursor-ring{position:fixed;width:32px;height:32px;border:1px solid rgba(184,151,90,.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .15s ease}
.cursor-ring.hovered{width:48px;height:48px;border-color:var(--gold)}
body:not(:hover) .cursor,.body:not(:hover) .cursor-ring{opacity:0}

/* NAV — solid white, constrained, never transparent */
nav{position:fixed;top:0;left:0;right:0;z-index:500;background:#fdfcf9;border-bottom:1px solid rgba(184,151,90,0.18);transition:box-shadow .3s}
nav.scrolled{box-shadow:0 2px 20px rgba(13,12,14,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 3rem;max-width:1400px;margin:0 auto}
.nav-logo{font-family:var(--serif);font-size:20px;font-weight:400;letter-spacing:.14em;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:2px}
.nav-logo .dot{color:var(--gold-dark)}
/* SVG logo mark in nav */
.nav-logo svg{width:22px;height:22px;margin-right:8px;flex-shrink:0}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2);text-decoration:none;position:relative;transition:color .2s;padding-bottom:3px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--gold-dark);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--gold-dark)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:9px 22px;border:1px solid var(--gold-dark);color:var(--gold-dark);background:transparent;cursor:none;transition:all .28s;font-family:var(--sans);text-decoration:none;position:relative;overflow:hidden}
.nav-cta::before{content:'';position:absolute;inset:0;background:var(--gold-dark);transform:scaleX(0);transform-origin:right;transition:transform .3s;z-index:-1}
.nav-cta:hover{color:var(--white)}
.nav-cta:hover::before{transform:scaleX(1);transform-origin:left}
/* hamburger mobile */
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:none;background:none;border:none;padding:4px}
.nav-burger span{display:block;width:22px;height:1px;background:var(--ink);transition:all .3s}
.nav-mobile{display:none;flex-direction:column;background:#fdfcf9;border-top:1px solid var(--border);padding:1.5rem 3rem;gap:1.25rem}
.nav-mobile.open{display:flex}
.nav-mobile a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2);text-decoration:none;transition:color .2s}
.nav-mobile a:hover,.nav-mobile a.active{color:var(--gold-dark)}

/* BUTTONS */
.btn-gold{padding:14px 40px;background:var(--gold);color:var(--ink);font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;border:none;cursor:none;transition:all .25s;text-decoration:none;display:inline-block;position:relative;overflow:hidden}
.btn-gold::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.18);transform:translateX(-110%);transition:transform .32s}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(184,151,90,.32)}
.btn-gold:hover::after{transform:translateX(0)}
.btn-outline-dark{padding:14px 40px;background:transparent;color:var(--ink2);font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;border:1px solid rgba(13,12,14,.2);cursor:none;transition:all .25s;text-decoration:none;display:inline-block}
.btn-outline-dark:hover{border-color:var(--gold-dark);color:var(--gold-dark);transform:translateY(-2px)}
.btn-outline-light{padding:14px 40px;background:transparent;color:rgba(253,252,249,.6);font-family:var(--sans);font-size:11px;letter-spacing:.14em;text-transform:uppercase;border:1px solid rgba(253,252,249,.2);cursor:none;transition:all .25s;text-decoration:none;display:inline-block}
.btn-outline-light:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}

/* SECTION PRIMITIVES */
.section-tag{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:1.25rem;display:flex;align-items:center;gap:1rem}
.section-tag::before{content:'';display:block;width:24px;height:1px;background:var(--gold-dark);flex-shrink:0}
.section-h2{font-family:var(--serif);font-size:clamp(32px,4vw,56px);font-weight:300;line-height:1.1;color:var(--ink);margin-bottom:1.25rem}
.section-h2 em{font-style:italic;color:var(--gold-dark)}
.section-sub{font-size:15px;font-weight:300;color:var(--ink3);line-height:1.85;max-width:500px}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .75s ease,transform .75s ease}
.reveal-left.in{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .75s ease,transform .75s ease}
.reveal-right.in{opacity:1;transform:translateX(0)}
.stagger-1{transition-delay:.1s}
.stagger-2{transition-delay:.2s}
.stagger-3{transition-delay:.3s}
.stagger-4{transition-delay:.4s}
.stagger-5{transition-delay:.5s}
.stagger-6{transition-delay:.6s}

/* MARQUEE */
.marquee-wrap{background:var(--gold-p);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:.85rem 0;overflow:hidden}
.marquee-track{display:flex;animation:marquee 30s linear infinite;width:max-content}
.marquee-track:hover{animation-play-state:paused}
.marquee-item{display:flex;align-items:center;gap:2.5rem;padding:0 2.5rem;white-space:nowrap}
.m-tag{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3)}
.m-dot{width:3px;height:3px;background:var(--gold);border-radius:50%;flex-shrink:0}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SERVICE CARDS */
.service-card{background:var(--white);padding:2.25rem;position:relative;overflow:hidden;transition:background .4s,transform .3s;cursor:none}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .5s;transform-origin:left}
.service-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(184,151,90,.1) 0%,transparent 58%);opacity:0;transition:opacity .4s}
.service-card:hover{background:var(--gold-p)}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover::after{opacity:1}
.service-num{font-family:var(--serif);font-size:12px;color:var(--gold-dark);letter-spacing:.12em;margin-bottom:1.25rem;display:block;transition:letter-spacing .35s}
.service-card:hover .service-num{letter-spacing:.24em}
.service-card h3{font-family:var(--serif);font-size:21px;font-weight:400;margin-bottom:.6rem;color:var(--ink);transition:transform .3s}
.service-card:hover h3{transform:translateX(5px)}
.service-card p{font-size:13px;font-weight:300;color:var(--ink3);line-height:1.7}

/* PAGE HERO SHARED */
.page-hero{padding:9rem 3rem 5rem;position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background:var(--dark);z-index:0}
.page-hero-grid{position:absolute;inset:0;z-index:1;background-image:linear-gradient(rgba(184,151,90,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(184,151,90,.045) 1px,transparent 1px);background-size:64px 64px;animation:gin 2s ease forwards;opacity:0}
@keyframes gin{to{opacity:1}}
.page-hero-orb{position:absolute;z-index:1;border-radius:50%;animation:orb 9s ease-in-out infinite}
@keyframes orb{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.page-hero-content{position:relative;z-index:2;max-width:900px}
.page-hero h1{font-family:var(--serif);font-size:clamp(44px,6vw,82px);font-weight:300;color:var(--white);line-height:1.06;margin-bottom:1.25rem;opacity:0;animation:fup .9s ease .35s forwards}
.page-hero h1 em{font-style:italic;color:var(--gold)}
.page-hero .hero-sub{font-size:16px;font-weight:300;color:rgba(253,252,249,.42);line-height:1.8;max-width:520px;opacity:0;animation:fup .8s ease .6s forwards}
@keyframes fup{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* FOOTER */
.site-footer{background:var(--dark);padding:4rem 3rem 2.5rem}
.footer-logo-row{display:flex;align-items:center;gap:10px;text-decoration:none;margin-bottom:.6rem}
.footer-logo-row svg{width:20px;height:20px}
.footer-logo-text{font-family:var(--serif);font-size:19px;letter-spacing:.13em;color:var(--white)}
.footer-logo-text span{color:var(--gold)}
.footer-tagline{font-size:11px;color:rgba(253,252,249,.28);letter-spacing:.08em;margin-bottom:2.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(184,151,90,.1)}
.footer-col h4{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem}
.footer-col a{display:block;font-size:13px;font-weight:300;color:rgba(253,252,249,.38);text-decoration:none;margin-bottom:.55rem;transition:color .2s;transition:padding-left .2s,color .2s}
.footer-col a:hover{color:var(--gold);padding-left:4px}
.footer-bottom{padding-top:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:11px;color:rgba(253,252,249,.18);letter-spacing:.05em}
.footer-langs{display:flex;gap:1.25rem}
.footer-langs span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(253,252,249,.22)}

/* SEO LANGS */
.seo-langs{background:var(--dark);border-top:1px solid rgba(184,151,90,.07);padding:2.5rem 3rem;display:grid;grid-template-columns:repeat(3,1fr);gap:3rem}
.seo-lang-label{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(184,151,90,.45);margin-bottom:.6rem}
.seo-lang-text{font-size:11.5px;color:rgba(253,252,249,.22);line-height:1.7;font-weight:300}
.seo-lang-text strong{color:rgba(253,252,249,.35);font-weight:400}

/* PAGE TRANSITIONS */
.page-transition{position:fixed;inset:0;background:var(--ink);z-index:9000;transform:scaleY(0);transform-origin:bottom;pointer-events:none}
.page-transition.out{animation:wipe-out .55s cubic-bezier(.77,0,.18,1) forwards}
.page-transition.in{animation:wipe-in .55s cubic-bezier(.77,0,.18,1) forwards}
@keyframes wipe-out{from{transform:scaleY(1);transform-origin:top}to{transform:scaleY(0);transform-origin:top}}
@keyframes wipe-in{from{transform:scaleY(0);transform-origin:bottom}to{transform:scaleY(1);transform-origin:bottom}}

/* COUNTER ANIMATION */
.counter{display:inline-block}

/* RESPONSIVE */
@media(max-width:1024px){
  .nav-inner{padding:.9rem 1.75rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .seo-langs{grid-template-columns:1fr;padding:2rem 1.75rem}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .page-hero{padding:7rem 1.5rem 3.5rem}
  .site-footer{padding:2.5rem 1.5rem 2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .seo-langs{grid-template-columns:1fr}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
}
