/* ============ RESET & BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
:root{
  --black:#0a0a0a;
  --pitch:#000000;
  --ink:#111111;
  --paper:#f5f3ef;
  --white:#ffffff;
  --blue:#2F4FFF;
  --blue-deep:#1a33d9;
  --blue-soft:#6d84ff;
  --grey:#8a8a8a;
  --grey-dim:#4a4a4a;
  --border:rgba(255,255,255,.08);
  --ease:cubic-bezier(.77,0,.175,1);
  --ease-out:cubic-bezier(.19,1,.22,1);
  --f-display:"Space Grotesk",sans-serif;
  --f-serif:"Instrument Serif",serif;
}

body{
  font-family:var(--f-display);
  background:var(--black);
  color:var(--paper);
  overflow-x:hidden;
  line-height:1.5;
  cursor:none;
}
a{color:inherit;text-decoration:none;cursor:none}
button{font:inherit;cursor:none;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
em{font-family:var(--f-serif);font-style:italic;font-weight:400}

.container{max-width:1440px;margin:0 auto;padding:0 40px;position:relative;z-index:2}
@media (max-width:768px){.container{padding:0 24px}}

/* ============ CURSOR ============ */
.cursor{
  position:fixed;top:0;left:0;width:40px;height:40px;
  border:1px solid rgba(255,255,255,.4);border-radius:50%;
  pointer-events:none;z-index:9999;mix-blend-mode:difference;
  transform:translate(-50%,-50%);
  transition:width .3s var(--ease),height .3s var(--ease),border-color .3s var(--ease);
}
.cursor-dot{
  position:fixed;top:0;left:0;width:6px;height:6px;
  background:var(--blue);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .1s linear;
}
.cursor.hover{width:80px;height:80px;border-color:var(--blue);background:rgba(47,79,255,.1)}
@media (hover:none){.cursor,.cursor-dot{display:none}body,a,button{cursor:auto}}

/* ============ LOADER ============ */
.loader{
  position:fixed;inset:0;background:var(--pitch);z-index:10000;
  display:flex;align-items:center;justify-content:center;
  transition:transform 1s var(--ease-out);
}
.loader.done{transform:translateY(-100%)}
.loader-content{text-align:center;width:min(400px,80vw)}
.loader-logo{font-size:48px;font-weight:700;letter-spacing:-.04em;margin-bottom:32px}
.loader-logo .dot{color:var(--blue)}
.loader-bar{height:1px;width:100%;background:rgba(255,255,255,.1);overflow:hidden;margin-bottom:16px}
.loader-bar span{display:block;height:100%;background:var(--paper);width:0;transition:width .1s linear}
.loader-count{font-size:12px;color:var(--grey);font-variant-numeric:tabular-nums}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 40px;
  transition:background .4s var(--ease),padding .4s var(--ease),backdrop-filter .4s var(--ease);
}
.nav.scrolled{
  background:rgba(10,10,10,.7);backdrop-filter:blur(20px);
  padding:14px 40px;border-bottom:1px solid var(--border);
}
.nav-logo{display:block;height:40px;transition:transform .3s var(--ease)}
.nav-logo img{height:100%;width:auto}
.nav-logo:hover{transform:scale(1.05)}

.nav-links{list-style:none;display:flex;gap:8px}
.nav-links a{
  position:relative;display:block;padding:10px 16px;font-size:14px;font-weight:500;
  letter-spacing:.01em;color:var(--paper);overflow:hidden;border-radius:999px;
  transition:color .3s var(--ease);
}
.nav-links a::before{
  content:"";position:absolute;inset:0;background:var(--paper);
  transform:translateY(100%);transition:transform .4s var(--ease);border-radius:999px;
}
.nav-links a:hover::before{transform:translateY(0)}
.nav-links a:hover{color:var(--black)}

.nav-cta{
  display:flex;align-items:center;gap:8px;
  padding:12px 20px;border:1px solid var(--border);border-radius:999px;
  font-size:13px;font-weight:500;
  background:var(--paper);color:var(--black);
  transition:transform .3s var(--ease),background .3s var(--ease);
}
.nav-cta svg{width:14px;height:14px;transition:transform .3s var(--ease)}
.nav-cta:hover{background:var(--blue);color:var(--paper)}
.nav-cta:hover svg{transform:translate(2px,-2px)}

.nav-burger{display:none;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);
  flex-direction:column;align-items:center;justify-content:center;gap:5px}
.nav-burger span{display:block;width:18px;height:1px;background:var(--paper);transition:transform .3s}
.nav-burger.open span:first-child{transform:translateY(3px) rotate(45deg)}
.nav-burger.open span:last-child{transform:translateY(-3px) rotate(-45deg)}

.menu-overlay{
  position:fixed;inset:0;background:var(--pitch);z-index:999;
  opacity:0;pointer-events:none;transition:opacity .5s var(--ease);
  display:flex;align-items:center;justify-content:center;
}
.menu-overlay.open{opacity:1;pointer-events:auto}
.menu-overlay-inner{text-align:center}
.menu-overlay ul{list-style:none}
.menu-overlay ul li a{font-size:48px;font-weight:600;letter-spacing:-.03em;display:block;padding:12px 0}
.menu-overlay-footer{margin-top:40px;display:flex;flex-direction:column;gap:8px;color:var(--grey);font-size:14px}

@media (max-width:900px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .nav{padding:16px 24px}
}

/* ============ HERO ============ */
.hero{
  min-height:100vh;position:relative;
  display:flex;align-items:center;
  padding:140px 40px 80px;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:1;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;animation:float 20s ease-in-out infinite}
.blob-1{width:600px;height:600px;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);top:-200px;left:-100px}
.blob-2{width:500px;height:500px;background:radial-gradient(circle,#6d84ff 0%,transparent 70%);bottom:-150px;right:-100px;animation-delay:-5s}
.blob-3{width:400px;height:400px;background:radial-gradient(circle,#8b5cf6 0%,transparent 70%);top:40%;right:30%;animation-delay:-10s;opacity:.3}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(50px,-30px) scale(1.1)}
  66%{transform:translate(-30px,40px) scale(.95)}
}
.grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse at center,black 30%,transparent 80%);
}

.hero-content{position:relative;z-index:3;max-width:1360px;margin:0 auto;width:100%}
.hero-meta{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 16px;border:1px solid var(--border);border-radius:999px;
  font-size:12px;color:var(--grey);letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:48px;backdrop-filter:blur(10px);
}
.pulse-dot{width:8px;height:8px;background:var(--blue);border-radius:50%;animation:pulse 1.8s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(47,79,255,.7)}50%{box-shadow:0 0 0 8px rgba(47,79,255,0)}}

.hero-title{
  font-size:clamp(56px,11vw,180px);
  font-weight:600;letter-spacing:-.045em;line-height:.92;
  margin-bottom:40px;
}
.hero-title .line{display:block;overflow:hidden}
.hero-title .reveal{display:inline-block;transform:translateY(105%);animation:reveal 1.2s var(--ease-out) forwards;animation-delay:1.8s}
.hero-title .line:nth-child(2) .reveal{animation-delay:2s}
@keyframes reveal{to{transform:translateY(0)}}

.hero-sub{
  font-size:clamp(16px,1.3vw,20px);color:var(--grey);
  max-width:540px;margin-bottom:48px;line-height:1.6;
  opacity:0;animation:fadeUp 1s var(--ease-out) forwards;animation-delay:2.4s;
}
.reveal-up{opacity:0;animation:fadeUp 1s var(--ease-out) forwards}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fadeUp 1s var(--ease-out) forwards;animation-delay:2.6s}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:18px 28px;border-radius:999px;
  font-size:15px;font-weight:500;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease);
  position:relative;overflow:hidden;
}
.btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;transition:transform .3s var(--ease)}
.btn-primary{background:var(--paper);color:var(--black)}
.btn-primary:hover{background:var(--blue);color:var(--paper)}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-ghost{border:1px solid rgba(255,255,255,.15);color:var(--paper)}
.btn-ghost:hover{background:var(--paper);color:var(--black);border-color:var(--paper)}

.hero-scroll{
  position:absolute;bottom:40px;left:40px;
  display:flex;align-items:center;gap:16px;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--grey);
  opacity:0;animation:fadeUp 1s var(--ease-out) forwards;animation-delay:3s;
}
.scroll-line{width:60px;height:1px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.scroll-line::after{
  content:"";position:absolute;inset:0;background:var(--paper);
  animation:scrollLine 2.5s var(--ease) infinite;
}
@keyframes scrollLine{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* Orbiting cards */
.hero-orbit{position:absolute;inset:0;z-index:2;pointer-events:none}
.orbit-card{
  position:absolute;padding:16px 20px;
  background:rgba(15,15,15,.7);backdrop-filter:blur(20px);
  border:1px solid var(--border);border-radius:16px;
  opacity:0;animation:fadeUp 1.2s var(--ease-out) forwards;
  min-width:180px;
}
.orbit-1{top:18%;right:8%;animation-delay:2.8s;transform:rotate(-4deg)}
.orbit-2{bottom:28%;right:4%;animation-delay:3s;transform:rotate(3deg)}
.orbit-3{top:50%;right:20%;animation-delay:3.2s;transform:rotate(-2deg)}
.orbit-label{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--grey);margin-bottom:10px}
.orbit-swatch{height:56px;background:linear-gradient(135deg,var(--blue),#6d84ff,#a78bfa);border-radius:8px}
.orbit-code{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--blue-soft)}
.orbit-code i{color:#ff79c6;font-style:normal}
.orbit-code span{display:block}
.orbit-ring{width:56px;height:56px;border-radius:50%;position:relative;background:radial-gradient(circle,var(--blue) 0%,transparent 70%)}
.orbit-ring span{position:absolute;inset:0;border:1px solid var(--blue);border-radius:50%;animation:expand 2s ease-out infinite}
@keyframes expand{0%{transform:scale(.5);opacity:1}100%{transform:scale(1.4);opacity:0}}

@media (max-width:900px){.hero-orbit{display:none}.hero{padding:120px 24px 60px}.hero-scroll{left:24px}}

/* ============ MARQUEE ============ */
.marquee{
  padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;background:var(--pitch);
}
.marquee-track{
  display:flex;gap:48px;width:max-content;
  animation:slide 40s linear infinite;
  font-family:var(--f-serif);font-size:clamp(36px,5vw,72px);font-style:italic;
}
.marquee-track .sep{color:var(--blue)}
@keyframes slide{to{transform:translateX(-50%)}}

/* ============ SECTION COMMON ============ */
.section-head{margin-bottom:64px}
.section-head.split{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.section-kicker{
  display:inline-block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--grey);margin-bottom:20px;
}
.section-title{font-size:clamp(40px,6vw,88px);font-weight:600;letter-spacing:-.035em;line-height:1}
.section-cta{font-size:14px;padding:14px 22px;border:1px solid var(--border);border-radius:999px;transition:background .3s,color .3s}
.section-cta:hover{background:var(--paper);color:var(--black)}

/* ============ INTRO ============ */
.intro{padding:160px 40px 120px;background:var(--pitch);position:relative}
.intro-statement{
  font-size:clamp(36px,5.5vw,88px);font-weight:500;letter-spacing:-.035em;
  line-height:1.05;margin-bottom:100px;max-width:1200px;
}
.intro-statement .reveal-line{display:block;overflow:hidden}
.intro-statement .reveal-line em{color:var(--blue-soft)}
.intro-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  padding-top:60px;border-top:1px solid var(--border);
}
.intro-copy{font-size:18px;line-height:1.7;color:var(--grey);max-width:480px}
.intro-stats{display:flex;justify-content:space-between;gap:20px}
.stat{display:flex;flex-direction:column;align-items:flex-start}
.stat-num{font-size:clamp(48px,5vw,80px);font-weight:600;font-variant-numeric:tabular-nums;color:var(--paper);letter-spacing:-.03em;line-height:1;display:inline-block}
.stat-plus{font-size:clamp(48px,5vw,80px);font-weight:600;color:var(--blue);line-height:1;display:inline-block;margin-left:2px}
.stat-label{font-size:12px;color:var(--grey);text-transform:uppercase;letter-spacing:.15em;margin-top:12px}

@media (max-width:900px){.intro-grid{grid-template-columns:1fr;gap:40px}.intro-stats{flex-direction:column;gap:40px}.intro{padding:80px 24px}}

/* ============ WORK ============ */
.work{padding:160px 40px;position:relative;background:var(--black)}
.work-list{display:flex;flex-direction:column;position:relative}

.work-item{
  display:grid;grid-template-columns:120px 1fr auto 80px;gap:40px;align-items:center;
  padding:40px 0;border-top:1px solid var(--border);
  transition:padding .4s var(--ease),background .4s var(--ease);
  cursor:none;position:relative;
}
.work-item:last-of-type{border-bottom:1px solid var(--border)}
.work-item::before{
  content:"";position:absolute;inset:0;background:var(--pitch);
  transform:scaleY(0);transform-origin:bottom;transition:transform .5s var(--ease-out);z-index:0;
}
.work-item:hover::before{transform:scaleY(1);transform-origin:top}
.work-item:hover{padding:40px 24px}
.work-item > *{position:relative;z-index:1}

.work-meta{display:flex;flex-direction:column;gap:4px}
.work-num{font-size:12px;color:var(--grey);letter-spacing:.1em}
.work-year{font-size:12px;color:var(--grey-dim)}

.work-title{
  font-size:clamp(32px,4vw,64px);font-weight:500;letter-spacing:-.03em;
  transition:transform .5s var(--ease),color .3s;
}
.work-item:hover .work-title{transform:translateX(10px);color:var(--blue-soft)}
.work-item:hover .work-title::after{content:" ↗";color:var(--blue)}

.work-tags{display:flex;gap:8px;flex-wrap:wrap}
.work-tags span{
  padding:6px 12px;border:1px solid var(--border);border-radius:999px;
  font-size:11px;letter-spacing:.05em;color:var(--grey);
  transition:border-color .3s,color .3s;
}
.work-item:hover .work-tags span{border-color:var(--border);color:var(--paper)}
.work-arrow{font-size:24px;color:var(--grey);transition:transform .5s var(--ease),color .3s}
.work-item:hover .work-arrow{transform:translate(8px,-8px);color:var(--blue)}

/* Floating preview */
.work-preview{
  position:fixed;top:0;left:0;width:380px;height:260px;
  pointer-events:none;z-index:500;
  opacity:0;transition:opacity .3s;
}
.work-preview.visible{opacity:1}
.work-preview-inner{position:relative;width:100%;height:100%;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.preview{position:absolute;inset:0;opacity:0;transition:opacity .3s}
.preview.active{opacity:1}
.preview-1{background:linear-gradient(135deg,#1a1a1a 0%,#2a0a0a 100%);}
.preview-1::after{content:"MAISON NOIR";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#d4a574;font-family:var(--f-serif);font-size:42px;letter-spacing:.2em;font-style:italic}
.preview-2{background:linear-gradient(135deg,#f0ebe0 0%,#d9cfbf 100%);}
.preview-2::after{content:"ATELIER & CO.";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#1a1a1a;font-weight:700;font-size:28px;letter-spacing:.1em}
.preview-3{background:linear-gradient(135deg,#0a2540 0%,#062647 100%);}
.preview-3::after{content:"NORTH CURRENT";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#d4af37;font-weight:500;font-size:26px;letter-spacing:.25em}
.preview-4{background:linear-gradient(135deg,#3d2817 0%,#6b4423 100%);}
.preview-4::after{content:"KINDRED";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#f5e6d3;font-family:var(--f-serif);font-size:52px;font-style:italic}
.preview-5{background:linear-gradient(135deg,#f5f5f0 0%,#e8e5dc 100%);}
.preview-5::after{content:"STUDIO MERIDIAN";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#000;font-weight:300;font-size:22px;letter-spacing:.3em}
.preview-6{background:linear-gradient(135deg,#1e3a2a 0%,#0f2819 100%);}
.preview-6::after{content:"HALCYON";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#d4af37;font-family:var(--f-serif);font-size:48px;letter-spacing:.15em;font-style:italic}

@media (max-width:900px){
  .work{padding:80px 24px}
  .work-item{grid-template-columns:40px 1fr auto;gap:16px}
  .work-tags{display:none}
  .work-preview{display:none}
}

/* ============ SERVICES ============ */
.services{padding:160px 40px;background:var(--pitch);position:relative;overflow:hidden}
.services::before{
  content:"";position:absolute;top:0;right:0;width:600px;height:600px;
  background:radial-gradient(circle,rgba(47,79,255,.15) 0%,transparent 70%);
  filter:blur(60px);
}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;position:relative;z-index:1}

.service-card{perspective:1000px;min-height:380px}
.service-card-inner{position:relative;width:100%;height:100%;min-height:380px;transition:transform .8s var(--ease);transform-style:preserve-3d}
.service-card:hover .service-card-inner{transform:rotateY(180deg)}

.service-front,.service-back{
  position:absolute;inset:0;padding:48px;border-radius:24px;
  border:1px solid var(--border);backface-visibility:hidden;
  display:flex;flex-direction:column;
}
.service-front{background:linear-gradient(180deg,rgba(20,20,20,.8) 0%,rgba(10,10,10,.9) 100%);backdrop-filter:blur(20px)}
.service-card.featured .service-front{background:linear-gradient(180deg,var(--blue) 0%,var(--blue-deep) 100%);border-color:var(--blue-soft)}
.service-back{background:linear-gradient(180deg,var(--paper) 0%,#e0ddd6 100%);color:var(--black);transform:rotateY(180deg)}

.service-num{
  display:inline-block;font-size:11px;letter-spacing:.15em;color:var(--grey);
  padding:6px 12px;border:1px solid var(--border);border-radius:999px;
  width:fit-content;margin-bottom:auto;
}
.service-card.featured .service-num{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.service-front h3{font-size:clamp(28px,3vw,44px);font-weight:500;letter-spacing:-.02em;margin:24px 0 16px}
.service-front p{color:var(--grey);line-height:1.6;font-size:16px;max-width:360px}
.service-card.featured .service-front p{color:rgba(255,255,255,.85)}
.service-more{margin-top:32px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey)}
.service-card.featured .service-more{color:rgba(255,255,255,.7)}

.service-back ul{list-style:none;margin:auto 0;display:flex;flex-direction:column;gap:14px}
.service-back li{font-size:18px;padding-bottom:12px;border-bottom:1px solid rgba(0,0,0,.1);display:flex;align-items:center;gap:12px}
.service-back li::before{content:"→";color:var(--blue)}
.service-price{padding-top:24px;border-top:1px solid rgba(0,0,0,.15);font-family:var(--f-serif);font-style:italic;font-size:28px}

@media (max-width:900px){
  .services{padding:80px 24px}
  .services-grid{grid-template-columns:1fr}
  .service-card{min-height:340px}
  .service-front,.service-back{padding:32px}
}

/* ============ PROCESS ============ */
.process{padding:160px 40px;background:var(--black)}
.process-steps{display:flex;flex-direction:column}
.process-step{
  display:grid;grid-template-columns:120px 1fr;gap:60px;
  padding:60px 0;border-top:1px solid var(--border);position:relative;
  transition:padding .3s var(--ease);
}
.process-step:last-child{border-bottom:1px solid var(--border)}
.process-step:hover{padding:60px 40px 60px 20px;background:linear-gradient(90deg,rgba(47,79,255,.05),transparent)}
.process-num{font-family:var(--f-serif);font-style:italic;font-size:80px;color:var(--blue);line-height:1}
.process-body h3{font-size:clamp(28px,3vw,42px);font-weight:500;letter-spacing:-.02em;margin-bottom:16px}
.process-body p{color:var(--grey);font-size:18px;line-height:1.7;max-width:640px}

@media (max-width:900px){
  .process{padding:80px 24px}
  .process-step{grid-template-columns:1fr;gap:20px;padding:40px 0}
  .process-num{font-size:60px}
}

/* ============ TESTIMONIAL ============ */
.testimonial{
  padding:160px 40px;background:var(--paper);color:var(--black);
  position:relative;overflow:hidden;
}
.testimonial::before{
  content:"";position:absolute;top:-100px;right:-100px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(47,79,255,.1),transparent 70%);
}
.quote-mark{
  font-family:var(--f-serif);font-size:clamp(200px,24vw,400px);line-height:.6;color:var(--blue);
  position:absolute;top:60px;left:40px;font-style:italic;opacity:.4;
}
.testimonial-quote{
  font-family:var(--f-serif);font-size:clamp(32px,4.5vw,64px);line-height:1.2;font-style:italic;font-weight:400;
  max-width:1100px;position:relative;z-index:1;margin:80px auto 60px;
}
.testimonial-quote .highlight{background:linear-gradient(180deg,transparent 50%,rgba(47,79,255,.25) 50%);padding:0 4px}
.testimonial-meta{display:flex;align-items:center;gap:16px;position:relative;z-index:1;max-width:1100px;margin:0 auto}
.testimonial-avatar{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-deep));
  display:flex;align-items:center;justify-content:center;color:white;
  font-weight:600;font-size:14px;letter-spacing:.08em;
}
.testimonial-name{font-weight:600;font-size:16px}
.testimonial-role{font-size:14px;color:var(--grey)}

@media (max-width:900px){.testimonial{padding:80px 24px}}

/* ============ CONTACT ============ */
.contact{padding:160px 40px;background:var(--pitch);position:relative;overflow:hidden}
.contact::before{
  content:"";position:absolute;bottom:-200px;left:50%;transform:translateX(-50%);
  width:1000px;height:1000px;border-radius:50%;
  background:radial-gradient(circle,rgba(47,79,255,.15),transparent 60%);filter:blur(80px);
}
.contact-inner{max-width:840px;margin:0 auto;position:relative;z-index:1;text-align:center}
.contact-title{
  font-size:clamp(48px,8vw,128px);font-weight:600;letter-spacing:-.045em;line-height:.95;
  margin:12px 0 32px;
}
.contact-title span{display:block}
.contact-sub{font-size:18px;color:var(--grey);max-width:560px;margin:0 auto 60px;line-height:1.6}

.contact-form{display:flex;flex-direction:column;gap:20px;text-align:left;margin-bottom:60px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-form label{display:flex;flex-direction:column;gap:8px}
.contact-form label > span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey)}
.contact-form input,.contact-form select,.contact-form textarea{
  padding:18px 20px;background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:12px;color:var(--paper);font-family:inherit;font-size:15px;
  transition:border-color .3s,background .3s;
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{
  outline:none;border-color:var(--blue);background:rgba(47,79,255,.05);
}
.contact-form select option{background:var(--pitch)}

.budget-pills{display:flex;gap:10px;flex-wrap:wrap}
.budget-pills input{display:none}
.budget-pills label{
  padding:12px 20px;border:1px solid var(--border);border-radius:999px;
  font-size:14px;transition:all .3s;cursor:none;display:inline-block;
}
.budget-pills input:checked + label{background:var(--blue);border-color:var(--blue);color:white}

.contact-form .btn{justify-content:center;padding:22px;font-size:16px}
.form-sent{display:none;padding:16px;background:rgba(47,79,255,.1);border:1px solid var(--blue);border-radius:12px;text-align:center;color:var(--blue-soft)}
.form-sent.show{display:block}

.contact-divider{display:flex;align-items:center;gap:20px;margin:40px 0;color:var(--grey);font-size:12px;letter-spacing:.15em;text-transform:uppercase}
.contact-divider::before,.contact-divider::after{content:"";flex:1;height:1px;background:var(--border)}

.contact-direct{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.direct-card{
  padding:28px 20px;border:1px solid var(--border);border-radius:16px;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  transition:background .3s,border-color .3s,transform .3s;
}
.direct-card:hover{background:var(--ink);border-color:var(--blue);transform:translateY(-4px)}
.direct-label{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--grey)}
.direct-value{font-size:16px;font-weight:500}

@media (max-width:900px){
  .contact{padding:80px 24px}
  .form-row{grid-template-columns:1fr}
  .contact-direct{grid-template-columns:1fr}
}

/* ============ FOOTER ============ */
.footer{padding:100px 40px 40px;background:var(--black);border-top:1px solid var(--border)}
.footer-top{display:grid;grid-template-columns:1fr 2fr;gap:60px;margin-bottom:80px}
.footer-logo{height:60px}
.footer-logo img{height:100%;width:auto}
.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.footer-links h4{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--grey);margin-bottom:20px;font-weight:500}
.footer-links div a{display:block;padding:6px 0;font-size:14px;color:var(--paper);transition:color .3s}
.footer-links div a:hover{color:var(--blue-soft)}
.footer-big{
  font-size:clamp(80px,24vw,400px);font-weight:700;letter-spacing:-.06em;line-height:.8;
  text-align:center;background:linear-gradient(180deg,var(--paper) 0%,rgba(245,243,239,.05) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  padding:40px 0;
}
.footer-big .dot{color:var(--blue);-webkit-text-fill-color:var(--blue)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:30px;border-top:1px solid var(--border);font-size:12px;color:var(--grey)}

@media (max-width:900px){
  .footer{padding:60px 24px 30px}
  .footer-top,.footer-links{grid-template-columns:1fr;gap:40px}
  .footer-bottom{flex-direction:column;gap:10px;text-align:center}
}

/* ============ REVEAL ANIMATIONS (scroll) ============ */
.fade-in{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.fade-in.in-view{opacity:1;transform:translateY(0)}
