/* ── TOKENS ─────────────────────────────────── */
:root {
  --black:      #080807;
  --dark:       #0D0D0B;
  --dark2:      #141412;
  --dark3:      #1C1C19;
  --gold:       #C8A96E;
  --gold-l:     #E2C99A;
  --gold-d:     #9A7A42;
  --gold-glow:  rgba(200,169,110,0.15);
  --cream:      #FAF8F4;
  --warm:       #F0EBE2;
  --white:      #FFFFFF;
  --muted:      rgba(255,255,255,0.45);
  --muted2:     rgba(255,255,255,0.25);
  --border:     rgba(200,169,110,0.12);
  --border-s:   rgba(200,169,110,0.25);
  --tr:         all 0.45s cubic-bezier(0.4,0,0.2,1);
}

/* ── RESET ──────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px;cursor:none}
body{font-family:'Montserrat',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:none;font-family:inherit;border:none;background:none}
input,textarea,select{font-family:inherit}

/* ── CUSTOM 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 0.3s,height 0.3s,opacity 0.3s;mix-blend-mode:difference}
.cursor-follower{position:fixed;width:36px;height:36px;border:1px solid var(--gold);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform 0.15s ease,width 0.3s,height 0.3s,opacity 0.3s;opacity:0.5}
.cursor.expand{width:48px;height:48px;opacity:0.3}
.cursor-follower.expand{width:60px;height:60px;opacity:0.2}
@media(max-width:900px){.cursor,.cursor-follower{display:none}*{cursor:auto}button{cursor:pointer}}

/* ── UTILITY ────────────────────────────────── */
.container{max-width:1360px;margin:0 auto;padding:0 5%}
.label{font-size:10px;letter-spacing:5px;text-transform:uppercase;font-weight:600;color:var(--gold);display:block;margin-bottom:20px}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.8s cubic-bezier(0.4,0,0.2,1),transform 0.8s cubic-bezier(0.4,0,0.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity 0.8s cubic-bezier(0.4,0,0.2,1),transform 0.8s cubic-bezier(0.4,0,0.2,1)}
.reveal-left.in{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity 0.8s cubic-bezier(0.4,0,0.2,1),transform 0.8s cubic-bezier(0.4,0,0.2,1)}
.reveal-right.in{opacity:1;transform:none}
.d1{transition-delay:0.1s}.d2{transition-delay:0.2s}.d3{transition-delay:0.3s}.d4{transition-delay:0.4s}.d5{transition-delay:0.5s}

/* ── BUTTONS ────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;transition:var(--tr);white-space:nowrap;position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;inset:0;transform:translateX(-100%);transition:transform 0.4s ease}
.btn:hover::before{transform:translateX(0)}
.btn-gold{background:var(--gold);color:var(--black)}
.btn-gold::before{background:var(--gold-l)}
.btn-gold:hover{color:var(--black)}
.btn-outline{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.2)}
.btn-outline::before{background:rgba(255,255,255,0.05)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn svg{width:16px;height:16px;flex-shrink:0;transition:transform 0.3s ease;position:relative;z-index:1}
.btn:hover svg{transform:translateX(4px)}
.btn span{position:relative;z-index:1}

/* ── PRELOADER ──────────────────────────────── */
.preloader{position:fixed;inset:0;background:var(--black);z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;transition:opacity 0.8s ease,visibility 0.8s ease}
.preloader.hidden{opacity:0;visibility:hidden}
.pre-logo{font-family:'Playfair Display',serif;font-size:48px;font-weight:400;color:var(--white);letter-spacing:8px;opacity:0;animation:pre-in 0.8s ease 0.3s forwards}
.pre-logo span{color:var(--gold)}
.pre-bar{width:200px;height:1px;background:rgba(255,255,255,0.1);overflow:hidden}
.pre-fill{height:100%;background:var(--gold);animation:pre-load 1.8s ease forwards}
@keyframes pre-in{to{opacity:1}}
@keyframes pre-load{from{width:0}to{width:100%}}

/* ── NAV ────────────────────────────────────── */
nav{position:fixed;top:0;left:0;right:0;z-index:800;padding:28px 5%;display:flex;align-items:center;justify-content:space-between;transition:var(--tr)}
nav.scrolled{background:rgba(8,8,7,0.95);backdrop-filter:blur(20px);padding:18px 5%;border-bottom:1px solid var(--border)}
.nav-logo{font-family:'Playfair Display',serif;font-size:22px;font-weight:400;letter-spacing:4px;color:var(--white)}
.nav-logo span{color:var(--gold)}
.nav-links{display:flex;align-items:center;gap:40px;list-style:none}
.nav-links a{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);transition:color 0.2s;font-weight:500}
.nav-links a:hover{color:var(--white)}
.nav-cta{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600;border:1px solid var(--border-s);padding:10px 24px;transition:var(--tr)}
.nav-cta:hover{background:var(--gold);color:var(--black);border-color:var(--gold)}
.hamburger{display:none;flex-direction:column;gap:6px;padding:4px}
.hamburger span{width:24px;height:1px;background:var(--white);display:block;transition:var(--tr)}
.mobile-menu{display:none;position:fixed;inset:0;background:var(--dark);z-index:799;flex-direction:column;align-items:center;justify-content:center;gap:40px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:'Playfair Display',serif;font-size:32px;line-height:1.2;color:var(--white);font-weight:400;transition:color 0.2s}
.mobile-menu a:hover{color:var(--gold)}

/* ── HERO ───────────────────────────────────── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:120px 5% 80px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(200,169,110,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(200,169,110,0.03) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%)}
.hero-glow{position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(200,169,110,0.06) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);animation:glow-pulse 6s ease-in-out infinite}
@keyframes glow-pulse{0%,100%{opacity:0.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}}
.hero-content{position:relative;z-index:2;max-width:900px}
.hero-badge{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--border-s);padding:8px 20px;margin-bottom:40px;opacity:0;animation:fade-up 0.8s ease 2.2s forwards}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:dot-pulse 2s ease-in-out infinite}
@keyframes dot-pulse{0%,100%{opacity:1}50%{opacity:0.3}}
.hero-badge span{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);font-weight:500}
.hero-h1{font-family:'Playfair Display',serif;font-size:clamp(38px,7vw,96px);font-weight:400;line-height:1.08;letter-spacing:-2px;color:var(--white);margin-bottom:28px;opacity:0;animation:fade-up 0.8s ease 2.4s forwards}
.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-h1 .line{display:block;overflow:hidden}
.hero-sub{font-size:clamp(14px,1.5vw,17px);line-height:1.8;color:var(--muted);max-width:520px;margin-bottom:48px;font-weight:300;letter-spacing:0.3px;opacity:0;animation:fade-up 0.8s ease 2.6s forwards}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fade-up 0.8s ease 2.8s forwards}
.hero-meta{position:absolute;bottom:48px;left:5%;right:5%;display:flex;align-items:center;justify-content:space-between;z-index:2;opacity:0;animation:fade-up 0.8s ease 3s forwards}
.hero-loc{display:flex;align-items:center;gap:8px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2)}
.hero-loc svg{flex-shrink:0}
.hero-scroll{display:flex;align-items:center;gap:12px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2)}
.scroll-line{width:60px;height:1px;background:linear-gradient(to right,var(--gold),transparent);animation:scroll-anim 2s ease-in-out infinite}
@keyframes scroll-anim{0%,100%{opacity:0.4;transform:scaleX(1)}50%{opacity:1;transform:scaleX(0.6)}}
@keyframes fade-up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── MARQUEE ─────────────────────────────────── */
.marquee{background:var(--dark2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:18px 0;overflow:hidden}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:marquee 30s linear infinite}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{display:inline-flex;align-items:center;gap:20px;padding:0 24px;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.2);font-weight:500}
.marquee-dot{color:var(--gold);font-size:8px}

/* ── WORK ───────────────────────────────────── */
#work{padding:120px 0 0;background:var(--black)}
.work-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:56px;flex-wrap:wrap;gap:32px}
.work-head-left h2{font-family:'Playfair Display',serif;font-size:clamp(36px,5vw,60px);font-weight:400;color:var(--white);line-height:1.1;letter-spacing:-1px}
.work-head-left h2 em{font-style:italic;color:var(--gold)}
.work-head-right{font-size:13px;color:var(--muted);max-width:400px;line-height:1.8;font-weight:300}
.work-grid{display:flex;flex-direction:column;gap:2px}

/* ── WHY ────────────────────────────────────── */
#why{padding:120px 0;background:var(--dark2);position:relative;overflow:hidden}
#why::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
#why::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.why-inner{max-width:1360px;margin:0 auto;padding:0 5%}
.why-top{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;margin-bottom:80px}
.why-top h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,56px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-1px}
.why-top h2 em{font-style:italic;color:var(--gold)}
.why-top p{font-size:15px;line-height:1.9;color:var(--muted);font-weight:300}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}
.why-card{background:var(--dark2);padding:40px 32px;transition:var(--tr);position:relative;overflow:hidden}
.why-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 0.4s ease}
.why-card:hover{background:var(--dark3)}
.why-card:hover::before{transform:scaleX(1)}
.why-num{font-family:'Playfair Display',serif;font-size:48px;font-weight:300;color:var(--gold-glow);line-height:1;margin-bottom:24px}
.why-card h3{font-size:13px;line-height:1.4;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--white);margin-bottom:14px}
.why-card p{font-size:13px;line-height:1.8;color:var(--muted);font-weight:300}

/* ── SERVICES ─────────────────────────────────── */
#services{padding:120px 0;background:var(--black)}
.services-inner{max-width:1360px;margin:0 auto;padding:0 5%}
.services-head{max-width:600px;margin-bottom:80px}
.services-head h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,56px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-1px;margin-top:12px}
.services-head h2 em{font-style:italic;color:var(--gold)}
.services-list{display:flex;flex-direction:column;gap:0}
.svc-item{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:48px;padding:40px 0;border-bottom:1px solid var(--border);transition:var(--tr);cursor:none}
.svc-item:first-child{border-top:1px solid var(--border)}
.svc-item:hover{padding-left:20px}
.svc-item:hover .svc-arrow{opacity:1;transform:translateX(0)}
.svc-num{font-family:'Playfair Display',serif;font-size:13px;color:var(--muted2);font-weight:300;letter-spacing:2px}
.svc-content h3{font-family:'Playfair Display',serif;font-size:clamp(20px,2.5vw,30px);line-height:1.2;color:var(--white);font-weight:400;margin-bottom:8px;transition:color 0.2s}
.svc-item:hover .svc-content h3{color:var(--gold)}
.svc-content p{font-size:13px;color:var(--muted);font-weight:300;line-height:1.8;max-width:500px}
.svc-price{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600;white-space:nowrap;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.svc-arrow{opacity:0;transform:translateX(-10px);transition:var(--tr)}
.svc-arrow svg{width:20px;height:20px;stroke:var(--gold)}

/* ── PROCESS ──────────────────────────────────── */
#process{padding:120px 0;background:var(--dark2);position:relative}
.process-inner{max-width:1360px;margin:0 auto;padding:0 5%}
.process-head{text-align:center;max-width:600px;margin:0 auto 80px}
.process-head h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,56px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-1px;margin-top:12px}
.process-head h2 em{font-style:italic;color:var(--gold)}
.process-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
.process-grid::before{content:'';position:absolute;top:40px;left:10%;right:10%;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent)}
.process-step{padding:0 24px;text-align:center;position:relative}
.process-num{width:80px;height:80px;border:1px solid var(--border-s);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 32px;font-family:'Playfair Display',serif;font-size:20px;color:var(--gold);background:var(--dark2);position:relative;z-index:1;transition:var(--tr)}
.process-step:hover .process-num{background:var(--gold);color:var(--black);border-color:var(--gold)}
.process-step h3{font-size:13px;line-height:1.4;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--white);margin-bottom:12px}
.process-step p{font-size:13px;line-height:1.8;color:var(--muted);font-weight:300}

/* ── TESTIMONIALS ─────────────────────────────── */
#testimonials{padding:120px 0;background:var(--black)}
.testi-inner{max-width:1360px;margin:0 auto;padding:0 5%}
.testi-head{text-align:center;max-width:500px;margin:0 auto 80px}
.testi-head h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,56px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-1px;margin-top:12px}
.testi-head h2 em{font-style:italic;color:var(--gold)}
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--border)}
.testi-card{background:var(--dark2);padding:56px 48px;transition:var(--tr)}
.testi-card:hover{background:var(--dark3)}
.testi-quote{font-family:'Playfair Display',serif;font-size:64px;color:var(--gold);line-height:0.8;margin-bottom:12px;opacity:0.3}
.testi-text{font-size:15px;line-height:1.9;color:rgba(255,255,255,0.7);font-style:italic;font-weight:300;margin-bottom:36px}
.testi-stars{color:var(--gold);letter-spacing:4px;font-size:12px;margin-bottom:24px}
.testi-author{display:flex;align-items:center;gap:16px}
.testi-av{width:48px;height:48px;border-radius:50%;background:var(--gold-d);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:18px;color:var(--white);flex-shrink:0}
.testi-name{font-size:13px;font-weight:700;color:var(--white);letter-spacing:0.5px}
.testi-role{font-size:11px;color:var(--muted2);margin-top:3px;letter-spacing:1px}

/* ── ABOUT ────────────────────────────────────── */
#about{padding:120px 0;background:var(--dark2);position:relative;overflow:hidden}
.about-inner{max-width:1360px;margin:0 auto;padding:0 5%;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-left{position:relative}
.about-img-wrap{position:relative}
.about-img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:grayscale(20%)}
.about-img-border{position:absolute;top:24px;left:24px;right:-24px;bottom:-24px;border:1px solid var(--border-s);pointer-events:none}
.about-float{position:absolute;bottom:-32px;right:-32px;background:var(--black);border:1px solid var(--border);padding:28px 32px;text-align:center}
.about-float-num{font-family:'Playfair Display',serif;font-size:48px;color:var(--gold);line-height:1;font-weight:400}
.about-float-text{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);margin-top:8px}
.about-right h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4vw,52px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-1px;margin:12px 0 32px}
.about-right h2 em{font-style:italic;color:var(--gold)}
.about-right p{font-size:14px;line-height:1.9;color:var(--muted);margin-bottom:20px;font-weight:300}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;padding-top:48px;border-top:1px solid var(--border)}
.about-stat-num{font-family:'Playfair Display',serif;font-size:36px;color:var(--gold);font-weight:400;line-height:1}
.about-stat-text{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);margin-top:8px}

/* ── CTA BAND ─────────────────────────────────── */
.cta-band{padding:120px 5%;background:var(--black);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'YK';font-family:'Playfair Display',serif;font-size:400px;font-weight:400;color:rgba(200,169,110,0.03);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;white-space:nowrap;letter-spacing:-20px}
.cta-band-inner{position:relative;z-index:1}
.cta-band h2{font-family:'Playfair Display',serif;font-size:clamp(40px,6vw,80px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-2px;margin:12px 0 24px}
.cta-band h2 em{font-style:italic;color:var(--gold)}
.cta-band p{font-size:15px;color:var(--muted);margin-bottom:48px;font-weight:300;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.8}
.cta-band .label{text-align:center}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ── CONTACT ──────────────────────────────────── */
#contact{padding:120px 0;background:var(--dark2)}
.contact-inner{max-width:1360px;margin:0 auto;padding:0 5%;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-left h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4vw,52px);color:var(--white);font-weight:400;line-height:1.1;letter-spacing:-1px;margin:12px 0 24px}
.contact-left h2 em{font-style:italic;color:var(--gold)}
.contact-left p{font-size:14px;line-height:1.9;color:var(--muted);margin-bottom:48px;font-weight:300}
.contact-items{display:flex;flex-direction:column;gap:24px}
.c-item{display:flex;align-items:center;gap:20px;padding-bottom:24px;border-bottom:1px solid var(--border)}
.c-item:last-child{border-bottom:none}
.c-icon{font-size:20px;width:48px;text-align:center;flex-shrink:0}
.c-lbl{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted2);font-weight:600;margin-bottom:4px}
.c-val{font-size:14px;line-height:1.4;color:var(--white);font-weight:400;transition:color 0.2s}
.c-val:hover{color:var(--gold)}
.form-wrap{background:var(--dark3);border:1px solid var(--border);padding:56px 48px}
.form-title{font-family:'Playfair Display',serif;font-size:28px;line-height:1.2;color:var(--white);font-weight:400;margin-bottom:8px}
.form-sub{font-size:12px;color:var(--muted2);margin-bottom:40px;letter-spacing:0.5px}
.fg{margin-bottom:24px}
.fg label{display:block;font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted2);margin-bottom:12px;font-weight:600}
.fg input,.fg select,.fg textarea{width:100%;padding:14px 18px;background:rgba(255,255,255,0.04);border:1px solid var(--border);color:var(--white);font-size:13px;font-family:'Montserrat',sans-serif;font-weight:300;outline:none;transition:border-color 0.2s;-webkit-appearance:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,0.2)}
.fg select{cursor:none;color:rgba(255,255,255,0.5)}
.fg select option{background:var(--dark3)}
.fg textarea{min-height:120px;resize:vertical}
.btn-submit{width:100%;padding:18px;background:var(--gold);color:var(--black);font-size:11px;font-weight:700;font-family:'Montserrat',sans-serif;letter-spacing:2.5px;text-transform:uppercase;cursor:none;transition:var(--tr);border:none}
.btn-submit:hover{background:var(--gold-l)}
.form-success{display:none;text-align:center;padding:40px;color:var(--gold)}
.form-success svg{margin:0 auto 16px}
.form-success h4{font-family:'Playfair Display',serif;font-size:22px;line-height:1.2;margin-bottom:8px}
.form-success p{font-size:13px;line-height:1.7;color:var(--muted)}

/* ── FOOTER ───────────────────────────────────── */
footer{background:var(--black);padding:64px 0 48px;border-top:1px solid var(--border)}
.footer-inner{max-width:1360px;margin:0 auto;padding:0 5%}
.footer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:48px;flex-wrap:wrap;gap:32px}
.footer-logo{font-family:'Playfair Display',serif;font-size:28px;letter-spacing:4px;color:var(--white)}
.footer-logo span{color:var(--gold)}
.footer-links{display:flex;gap:32px;list-style:none;flex-wrap:wrap}
.footer-links a{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted2);transition:color 0.2s;font-weight:500}
.footer-links a:hover{color:var(--white)}
.footer-socials{display:flex;gap:12px}
.f-soc{width:40px;height:40px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted2);transition:var(--tr)}
.f-soc:hover{border-color:var(--gold);color:var(--gold)}
.footer-bottom{border-top:1px solid var(--border);padding-top:32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-bottom p{font-size:11px;color:var(--muted2);letter-spacing:0.5px}
.footer-bottom a{color:var(--gold)}
.footer-legal{display:flex;gap:16px;align-items:center}
.footer-legal a{font-size:11px;color:var(--muted2);letter-spacing:0.5px;transition:color 0.2s}
.footer-legal a:hover{color:var(--white)}
.footer-legal span{color:var(--border-s)}

/* ── COOKIE BANNER ──────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:8000;background:var(--dark2);border-top:1px solid var(--border);padding:20px 5%;transform:translateY(100%);transition:transform 0.4s ease}
.cookie-banner.show{transform:translateY(0)}
.cookie-inner{max-width:1360px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cookie-text p{font-size:12px;color:var(--muted);line-height:1.6;font-weight:300}
.cookie-text a{color:var(--gold);text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
.cookie-decline{padding:10px 24px;background:transparent;border:1px solid var(--border);color:var(--muted);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;cursor:none;font-family:'Montserrat',sans-serif;transition:var(--tr)}
.cookie-decline:hover{border-color:var(--white);color:var(--white)}
.cookie-accept{padding:10px 24px;background:var(--gold);border:none;color:var(--black);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;cursor:none;font-family:'Montserrat',sans-serif;font-weight:700;transition:var(--tr)}
.cookie-accept:hover{background:var(--gold-l)}

/* ── FLOATING WA ─────────────────────────────── */
.wa-float{position:fixed;bottom:40px;right:40px;z-index:700;background:#25D366;color:var(--white);display:flex;align-items:center;gap:10px;padding:14px 24px;border-radius:0;box-shadow:0 8px 40px rgba(37,211,102,0.25);transition:var(--tr);font-size:11px;font-weight:600;letter-spacing:1px;text-decoration:none;cursor:none}
.wa-float::before{content:'';position:absolute;inset:0;background:#25D366;animation:wa-pulse 2.5s ease-out infinite;z-index:-1}
@keyframes wa-pulse{0%{transform:scale(1);opacity:0.5}70%{transform:scale(1.4);opacity:0}100%{transform:scale(1.4);opacity:0}}
.wa-float:hover{background:#1aad53;transform:translateY(-3px)}

/* ── BACK TO TOP ─────────────────────────────── */
.back-to-top{position:fixed;bottom:40px;left:40px;z-index:700;width:48px;height:48px;background:transparent;border:1px solid var(--border);color:var(--muted);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:var(--tr);cursor:none}
.back-to-top.show{opacity:1;pointer-events:auto}
.back-to-top:hover{border-color:var(--gold);color:var(--gold)}



/* ── PREMIUM CASE STUDY BREAKDOWN ───────────── */
.case-breakdown{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  margin-top:36px;
  border:1px solid rgba(200,169,110,0.16);
  background:rgba(200,169,110,0.16);
}
.case-breakdown-light{border-color:rgba(10,10,8,0.10);background:rgba(10,10,8,0.10)}
.case-breakdown-dark{border-color:var(--border);background:var(--border)}
.case-block{padding:28px 24px;background:rgba(255,255,255,0.42)}
.case-breakdown-dark .case-block{background:var(--dark3)}
.case-block span{display:block;font-size:9px;letter-spacing:2.4px;text-transform:uppercase;font-weight:700;color:var(--gold);margin-bottom:14px}
.case-block p{font-size:13px;line-height:1.8;font-weight:300;color:#5d574d}
.case-breakdown-dark .case-block p{color:var(--muted)}

/* ── CLIENT FIT SECTION ─────────────────────── */
#fit{padding:110px 0;background:var(--black);position:relative;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.fit-inner{max-width:1360px;margin:0 auto;padding:0 5%;display:grid;grid-template-columns:0.95fr 1.05fr;gap:80px;align-items:center}
.fit-copy h2{font-family:'Playfair Display',serif;font-size:clamp(36px,4.5vw,60px);font-weight:400;line-height:1.08;letter-spacing:-1px;color:var(--white)}
.fit-copy h2 em{font-style:italic;color:var(--gold)}
.fit-list{display:flex;flex-direction:column;border-top:1px solid var(--border)}
.fit-item{display:grid;grid-template-columns:72px 1fr;gap:24px;padding:28px 0;border-bottom:1px solid var(--border)}
.fit-item span{font-family:'Playfair Display',serif;color:var(--gold);font-size:22px;line-height:1}
.fit-item p{font-size:15px;line-height:1.8;color:rgba(255,255,255,0.62);font-weight:300}

/* ── MOBILE ───────────────────────────────────── */
@media(max-width:1100px){
  .case-breakdown{grid-template-columns:repeat(2,1fr)}
  .fit-inner{grid-template-columns:1fr;gap:48px}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(3,1fr);gap:40px}
  .process-grid::before{display:none}
  .about-inner,.contact-inner{grid-template-columns:1fr;gap:64px}
  .about-float{right:0;bottom:-16px}
  .about-img-border{display:none}
}
@media(max-width:860px){
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  .testi-grid{grid-template-columns:1fr}
  .why-top{grid-template-columns:1fr}
  .footer-top{flex-direction:column;align-items:flex-start}
  .work-head{flex-direction:column}
}
@media(max-width:600px){
  .case-breakdown{grid-template-columns:1fr}
  .case-block{padding:24px 20px}
  #fit{padding:80px 0}
  .fit-item{grid-template-columns:1fr;gap:8px}
  .why-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr;gap:40px}
  .hero-meta{display:none}
  .about-stats{grid-template-columns:1fr 1fr}
  .form-wrap{padding:36px 24px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .wa-float span{display:none}
  .wa-float{padding:14px;bottom:24px;right:24px}
  .back-to-top{bottom:24px;left:24px}

  /* ── Section vertical padding ── */
  #why,#services,#process,#testimonials,#about,#contact{padding-top:80px;padding-bottom:80px}
  #work{padding-top:80px}
  .cta-band{padding-top:80px;padding-bottom:80px}

  /* ── Sub-section head margins ── */
  .services-head{margin-bottom:48px}
  .process-head{margin:0 auto 48px}
  .testi-head{margin:0 auto 48px}
  .why-top{margin-bottom:48px}

  /* ── Services: fix broken 3-column grid ── */
  .svc-item{grid-template-columns:1fr;gap:12px;padding:28px 0}
  .svc-item:hover{padding-left:0}
  .svc-price{align-items:flex-start}
  .svc-arrow{display:none}

  /* ── Testimonial card padding ── */
  .testi-card{padding:40px 28px}

  /* ── Hero badge: prevent overflow on narrow screens ── */
  .hero-badge{max-width:100%}
  .hero-badge span{white-space:normal}

  /* ── Footer legal: allow wrap ── */
  .footer-legal{flex-wrap:wrap;gap:12px}

  /* ── Why cards ── */
  .why-card{padding:32px 24px}

  /* ── Portfolio work inner ── */
  .pw-browser{margin-bottom:24px}
  .pw-info{padding-top:20px}

  /* ── About float ── */
  .about-float{padding:20px 24px;bottom:-12px}
  .about-float-num{font-size:36px}
}

/* ── PORTFOLIO WORK ─────────────────────────── */
.pw-project { background: var(--cream); }
.pw-project-dark { background: var(--dark2); }

.pw-inner {
  max-width: 1360px;
  margin: 0 auto;
  padding: 60px 5%;
}

/* Browser frame */
.pw-browser {
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 40px 100px rgba(0,0,0,0.2);
  margin-bottom: 40px;
  border: 1px solid rgba(0,0,0,0.08);
}
.pw-browser-dark {
  box-shadow: 0 40px 100px rgba(0,0,0,0.5);
  border-color: rgba(200,169,110,0.1);
}

/* Browser bar */
.pw-browser-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: #E8E4DE;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.pw-bar-dark {
  background: #1A1A17;
  border-bottom-color: rgba(200,169,110,0.1);
}
.pw-dots {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}
.pw-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(0,0,0,0.15);
  display: block;
}
.pw-dots span:nth-child(1) { background: #FF5F57; }
.pw-dots span:nth-child(2) { background: #FFBD2E; }
.pw-dots span:nth-child(3) { background: #28C840; }
.pw-url {
  flex: 1;
  text-align: center;
  font-size: 11px;
  color: rgba(0,0,0,0.4);
  letter-spacing: 0.3px;
  background: rgba(255,255,255,0.6);
  padding: 5px 16px;
  border-radius: 6px;
  font-family: 'Montserrat', sans-serif;
}
.pw-url-dark {
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.3);
}
.pw-open {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(0,0,0,0.3);
  transition: color 0.2s;
  flex-shrink: 0;
}
.pw-open:hover { color: var(--gold-d); }
.pw-open-dark { color: rgba(255,255,255,0.25); }
.pw-open-dark:hover { color: var(--gold); }

/* Screenshot */
.pw-screen {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/9;
  background: var(--warm);
}
.pw-browser-dark .pw-screen {
  aspect-ratio: 4/3;
  background: var(--dark3);
}
.pw-screen img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform 0.8s cubic-bezier(0.4,0,0.2,1);
}
.pw-browser:hover .pw-screen img {
  transform: scale(1.02);
}
.pw-overlay {
  position: absolute;
  inset: 0;
  background: rgba(8,8,7,0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  opacity: 0;
  transition: var(--tr);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--white);
}
.pw-browser:hover .pw-overlay { opacity: 1; }
.pw-overlay svg { flex-shrink: 0; }

/* Info bar */
.pw-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding-top: 32px;
  border-top: 1px solid rgba(10,10,8,0.08);
  flex-wrap: wrap;
}
.pw-info-dark {
  border-color: var(--border);
}
.pw-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}
.pw-tags span {
  font-size: 9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  padding: 4px 10px;
  border: 1px solid rgba(200,169,110,0.25);
  color: #8A8578;
}
.pw-tags-dark span {
  color: var(--gold);
  border-color: var(--border-s);
}
.pw-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.2;
  font-weight: 400;
  color: var(--dark);
  letter-spacing: -0.5px;
  margin-bottom: 6px;
}
.pw-title-dark { color: var(--white); }
.pw-location {
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #8A8578;
  font-weight: 500;
}
.pw-location-dark { color: var(--muted2); }

/* Stats */
.pw-stats {
  display: flex;
  gap: 40px;
  flex-shrink: 0;
}
.pw-stat { text-align: center; }
.pw-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--gold);
  line-height: 1;
}
.pw-stat-num span { font-size: 0.6em; vertical-align: super; }
.pw-stat-label {
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #8A8578;
  margin-top: 6px;
  font-weight: 500;
}
.pw-stat-label-dark { color: var(--muted2); }

/* Mobile */
@media(max-width:768px) {
  .pw-info { flex-direction: column; align-items: flex-start; }
  .pw-stats { gap: 24px; }
  .pw-inner { padding: 56px 5%; }
}
@media(max-width:480px) {
  .pw-stats { flex-wrap: wrap; gap: 16px; }
  .pw-browser-bar { padding: 10px 12px; }
  .pw-url { display: none; }
  .pw-inner { padding-top: 40px; padding-bottom: 40px; }
}
