/* ═══════════════════════════════════════════════
   LUMIÈRE — Design System · Cinematic Dark
   UI/UX: Modern · Minimal · Immersive
═══════════════════════════════════════════════ */

/* ─── Design Tokens ─── */
:root {
  --c-bg:       #080808;
  --c-surface:  #111111;
  --c-elevated: #1a1a1a;
  --c-border:   rgba(255,255,255,0.06);

  --c-gold:     #c9a96e;
  --c-gold-lt:  #e8d5b0;
  --c-gold-gl:  rgba(201,169,110,0.12);

  --c-text:     #f5f0e8;
  --c-text-2:   #888888;
  --c-text-3:   #444444;

  --f-display:  'Cormorant Garamond', Georgia, serif;
  --f-body:     'Inter', system-ui, sans-serif;

  --ease-out:   cubic-bezier(0.25,0.46,0.45,0.94);
  --ease-in-out:cubic-bezier(0.76,0,0.24,1);
}

/* ─── Reset ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--c-bg);
  color:var(--c-text);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  cursor:none;
}
img,video,canvas{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
ul{list-style:none}
input,textarea,select,button{font-family:inherit;font-size:inherit}
button{border:none;background:none;cursor:pointer}

/* ─── Scrollbar ─── */
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--c-bg)}
::-webkit-scrollbar-thumb{background:var(--c-gold);border-radius:2px}

/* ═══════════════════════════════
   PRELOADER
═══════════════════════════════ */
#preloader{
  position:fixed;inset:0;
  background:var(--c-bg);
  z-index:9999;
  display:flex;align-items:center;justify-content:center;
}
.preloader-inner{
  display:flex;flex-direction:column;align-items:center;gap:2rem;
}
.film-strip{display:flex;gap:5px}
.film-frame{
  width:38px;height:54px;
  border:1px solid var(--c-gold);
  border-radius:2px;
  opacity:0;
  animation:frameIn 0.35s ease forwards;
}
.film-frame:nth-child(1){animation-delay:0.0s}
.film-frame:nth-child(2){animation-delay:0.1s}
.film-frame:nth-child(3){animation-delay:0.2s}
.film-frame:nth-child(4){animation-delay:0.3s}
.film-frame:nth-child(5){animation-delay:0.4s}
@keyframes frameIn{
  to{opacity:1;background:linear-gradient(135deg,transparent 30%,rgba(201,169,110,0.08) 100%)}
}
.preloader-brand{
  font-family:var(--f-display);
  font-size:2rem;font-weight:300;
  letter-spacing:0.55em;
  color:var(--c-gold);
}
.preloader-bar{
  width:180px;height:1px;
  background:var(--c-elevated);
  overflow:hidden;
}
.preloader-fill{
  height:100%;width:0;
  background:var(--c-gold);
  animation:fillBar 2s var(--ease-out) forwards;
}
@keyframes fillBar{to{width:100%}}

/* ═══════════════════════════════
   CURSOR
═══════════════════════════════ */
#cursor-ring{
  position:fixed;
  width:36px;height:36px;
  border:1px solid var(--c-gold);
  border-radius:50%;
  pointer-events:none;
  z-index:9998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,background .3s,border-color .3s,opacity .3s;
  mix-blend-mode:difference;
}
#cursor-dot{
  position:fixed;
  width:6px;height:6px;
  background:var(--c-gold);
  border-radius:50%;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .15s;
}
body.cursor-on #cursor-ring{
  width:64px;height:64px;
  background:var(--c-gold-gl);
  border-color:transparent;
}
@media(hover:none){#cursor-ring,#cursor-dot{display:none}body{cursor:auto}}

/* ═══════════════════════════════
   NAVBAR
═══════════════════════════════ */
#navbar{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.75rem 3rem;
  transition:padding .4s var(--ease-out),background .4s,backdrop-filter .4s;
}
#navbar.stuck{
  padding:1.1rem 3rem;
  background:rgba(8,8,8,0.9);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--c-border);
}
.nav-logo{
  font-family:var(--f-display);
  font-size:1.4rem;font-weight:300;
  letter-spacing:0.35em;
  color:var(--c-gold);
}
.nav-links{
  display:flex;gap:2.5rem;
}
.nav-links a{
  font-size:0.82rem;font-weight:400;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--c-text-2);
  position:relative;
  transition:color .2s;
}
.nav-links a::after{
  content:'';
  position:absolute;bottom:-4px;left:0;
  width:0;height:1px;
  background:var(--c-gold);
  transition:width .35s var(--ease-out);
}
.nav-links a:hover{color:var(--c-text)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  font-size:0.78rem;font-weight:500;
  letter-spacing:0.15em;text-transform:uppercase;
  border:1px solid var(--c-gold);
  padding:.6rem 1.5rem;
  color:var(--c-gold);
  border-radius:3px;
  transition:background .3s,color .3s;
}
.nav-cta:hover{background:var(--c-gold);color:var(--c-bg)}

/* ═══════════════════════════════
   BUTTONS
═══════════════════════════════ */
.btn-primary{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--c-gold);color:var(--c-bg);
  font-size:0.82rem;font-weight:500;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:.95rem 2.4rem;
  border-radius:3px;
  transition:background .3s,transform .3s,box-shadow .3s;
  border:none;cursor:pointer;
}
.btn-primary:hover{
  background:var(--c-gold-lt);
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(201,169,110,0.22);
}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.5rem;
  color:var(--c-text-2);
  font-size:0.82rem;font-weight:400;
  letter-spacing:0.1em;text-transform:uppercase;
  padding:.95rem 1.5rem;
  transition:color .25s;
}
.btn-ghost:hover{color:var(--c-text)}
.btn-outline{
  display:inline-flex;align-items:center;gap:.75rem;
  border:1px solid var(--c-border);
  color:var(--c-text);
  font-size:0.82rem;font-weight:400;
  letter-spacing:0.12em;text-transform:uppercase;
  padding:.95rem 2.4rem;
  border-radius:3px;
  transition:border-color .3s,color .3s;
}
.btn-outline:hover{border-color:var(--c-gold);color:var(--c-gold)}

/* ═══════════════════════════════
   SHARED SECTION PARTS
═══════════════════════════════ */
.sec-num{
  display:block;
  font-family:var(--f-display);
  font-size:0.82rem;font-weight:300;
  letter-spacing:0.35em;
  color:var(--c-gold);
  margin-bottom:1rem;
}
.sec-title{
  font-family:var(--f-display);
  font-size:clamp(3rem,6vw,5.5rem);
  font-weight:300;
  line-height:1.0;
  letter-spacing:-0.02em;
  margin-bottom:1.5rem;
}
.sec-desc{
  font-size:1rem;color:var(--c-text-2);
  line-height:1.8;max-width:42ch;
}
/* Reveal animation wrapper: words will be set by JS */
.reveal{overflow:visible}
.reveal .word{
  display:inline-block;
  transform:translateY(80px);
  opacity:0;
}
.grain-overlay{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:1;
}

/* ═══════════════════════════════
   HERO
═══════════════════════════════ */
#hero{
  position:relative;
  height:100vh;min-height:600px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
#hero-canvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  z-index:0;
}
.hero-vignette{
  position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse at center, transparent 35%, rgba(8,8,8,0.75) 100%);
}
.hero-content{
  position:relative;z-index:2;
  text-align:center;
  padding:0 2rem;
}
.hero-eyebrow{
  display:flex;align-items:center;justify-content:center;
  gap:1.25rem;
  font-size:0.78rem;font-weight:400;
  letter-spacing:0.3em;text-transform:uppercase;
  color:var(--c-gold);
  margin-bottom:2rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .9s var(--ease-out) .4s forwards;
}
.eyebrow-line{
  width:36px;height:1px;
  background:var(--c-gold);
  flex-shrink:0;
}
.hero-title{
  font-family:var(--f-display);
  font-size:clamp(4.5rem,12vw,11rem);
  font-weight:300;
  line-height:.9;
  letter-spacing:-0.03em;
  margin-bottom:2rem;
}
.hero-title .hl{
  display:block;
  opacity:0;transform:translateY(60px);
}
.hero-title .hl:nth-child(1){animation:heroSlide 1.2s var(--ease-out) .6s forwards}
.hero-title .hl:nth-child(2){animation:heroSlide 1.2s var(--ease-out) .8s forwards;font-style:italic;color:var(--c-gold)}
.hero-title .hl:nth-child(3){animation:heroSlide 1.2s var(--ease-out) 1.0s forwards}
@keyframes heroSlide{to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

.hero-sub{
  font-size:1.05rem;letter-spacing:.1em;
  color:var(--c-text-2);
  margin-bottom:2.75rem;
  opacity:0;animation:fadeUp .9s var(--ease-out) 1.2s forwards;
}
.hero-btns{
  display:flex;align-items:center;justify-content:center;gap:1.5rem;
  opacity:0;animation:fadeUp .9s var(--ease-out) 1.4s forwards;
}

.hero-scroll{
  position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);
  z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--c-text-3);
  opacity:0;animation:fadeUp .9s var(--ease-out) 2s forwards;
}
.scroll-bar{
  width:1px;height:56px;
  background:linear-gradient(to bottom,var(--c-gold),transparent);
  animation:scrollPulse 2.2s ease infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.35;transform:scaleY(1)}
  50%{opacity:1;transform:scaleY(1.12)}
}

.hero-stats{
  position:absolute;bottom:3rem;right:3.5rem;
  z-index:2;
  display:flex;flex-direction:column;gap:1.75rem;
  text-align:right;
  opacity:0;animation:fadeUp .9s var(--ease-out) 1.7s forwards;
}
.stat-num{
  display:block;
  font-family:var(--f-display);
  font-size:2.4rem;font-weight:300;
  color:var(--c-gold);
  line-height:1;
}
.stat-num::after{content:'+'}
.stat-lbl{
  font-size:.72rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--c-text-3);
}

/* ═══════════════════════════════
   MARQUEE
═══════════════════════════════ */
.marquee-banner{
  overflow:hidden;
  padding:1.25rem 0;
  background:var(--c-gold);
  white-space:nowrap;
  user-select:none;
}
.marquee-track{
  display:inline-block;
  animation:marqueeRoll 22s linear infinite;
}
.marquee-track span{
  font-size:.82rem;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-bg);
  padding:0 1.25rem;
}
.marquee-track .sep{padding:0 .4rem}
@keyframes marqueeRoll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ═══════════════════════════════
   REEL
═══════════════════════════════ */
#reel{
  padding:10rem 3rem;
}
.reel-wrap{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1fr 2fr;
  gap:6rem;align-items:center;
}
.reel-desc{
  color:var(--c-text-2);
  line-height:1.85;
  max-width:32ch;
  margin-top:.5rem;
}
.reel-player{
  position:relative;
  aspect-ratio:16/9;
  border-radius:8px;
  overflow:hidden;
  cursor:pointer;
}
.reel-thumb{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
}
.reel-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0d0820 0%,#1a0f30 30%,#0d1520 60%,#201505 100%);
}
.play-circle{
  position:relative;z-index:2;
  width:80px;height:80px;
  border:2px solid var(--c-gold);
  border-radius:50%;
  background:rgba(201,169,110,.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--c-gold);
  transition:background .3s,transform .3s,box-shadow .3s;
  cursor:pointer;
}
.play-circle:hover{
  background:var(--c-gold);color:var(--c-bg);
  transform:scale(1.1);
  box-shadow:0 0 50px rgba(201,169,110,.35);
}
.play-circle svg{width:28px;height:28px;margin-left:4px}
.reel-duration{
  position:absolute;bottom:1.5rem;right:1.5rem;z-index:2;
  font-size:.72rem;letter-spacing:.12em;color:var(--c-text-2);
}
.reel-embed{
  position:absolute;inset:0;
}
.reel-embed iframe{width:100%;height:100%}
.hidden{display:none!important}

/* ═══════════════════════════════
   WORK — HORIZONTAL SCROLL
═══════════════════════════════ */
#work{
  padding-top:10rem;
}
.work-head{
  max-width:1400px;margin:0 auto;
  padding:0 3rem 3rem;
}
.work-hint{
  font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--c-text-3);
  margin-top:.5rem;
}
.portfolio-pin-wrap{
  overflow:hidden;
  position:relative;
}
.portfolio-track{
  display:flex;gap:2rem;
  padding:0 3rem 4rem;
  width:max-content;
  will-change:transform;
}
.p-card{
  width:380px;flex-shrink:0;
  cursor:pointer;
  transform-style:preserve-3d;
}
.p-card.p-wide{width:560px}
.p-media{
  position:relative;
  aspect-ratio:4/5;
  border-radius:6px;
  overflow:hidden;
  transition:transform .5s var(--ease-out);
}
.p-card.p-wide .p-media{aspect-ratio:16/9}
.p-card:hover .p-media{transform:scale(1.02)}
.p-reveal{
  position:absolute;inset:0;z-index:2;
  background:rgba(8,8,8,.6);
  display:flex;align-items:center;justify-content:center;
  opacity:0;
  transition:opacity .35s;
}
.p-card:hover .p-reveal{opacity:1}
.p-reveal span{
  font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-gold);
  border-bottom:1px solid var(--c-gold);
  padding-bottom:3px;
}
.p-meta{padding:1.25rem 0}
.p-cat{
  display:block;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:.4rem;
}
.p-name{
  font-family:var(--f-display);
  font-size:1.5rem;font-weight:300;
  color:var(--c-text);margin-bottom:.3rem;
}
.p-loc{font-size:.78rem;color:var(--c-text-3)}
.work-footer{
  padding:0 3rem 10rem;
  text-align:center;
}

/* ═══════════════════════════════
   ABOUT
═══════════════════════════════ */
#about{
  padding:10rem 3rem;
  background:var(--c-surface);
}
.about-wrap{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:8rem;align-items:center;
}
.about-visual{position:relative}
.about-frame{
  aspect-ratio:3/4;
  border-radius:10px;
  overflow:hidden;
  position:relative;
  background:var(--c-elevated);
}
.about-frame-bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#0d0820 0%,#1a1535 40%,#0d2010 100%);
  z-index:0;
}
#about-canvas{
  position:absolute;inset:0;
  width:100%!important;height:100%!important;
  z-index:1;
}
.about-chip{
  position:absolute;bottom:-2rem;right:-2rem;
  background:var(--c-elevated);
  border:1px solid var(--c-border);
  border-radius:8px;
  padding:1.25rem 1.5rem;
  backdrop-filter:blur(10px);
  z-index:2;
}
.chip-icon{font-size:1.6rem;display:block;margin-bottom:.4rem}
.chip-label{
  display:block;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:.2rem;
}
.chip-sub{font-size:.82rem;color:var(--c-text-2)}
.about-body{
  font-size:1.02rem;color:var(--c-text-2);
  line-height:1.9;margin-bottom:1.5rem;
}
.about-sig{
  font-family:var(--f-display);
  font-size:2.4rem;font-weight:300;font-style:italic;
  color:var(--c-gold);
  margin-bottom:2.5rem;
}

/* ═══════════════════════════════
   SERVICES
═══════════════════════════════ */
#services{padding:10rem 3rem}
.services-head{
  max-width:1400px;margin:0 auto 4rem;
}
.services-grid{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
.svc-card{
  position:relative;
  border:1px solid var(--c-border);
  border-radius:8px;
  padding:3rem 2.5rem;
  overflow:hidden;
  transform-style:preserve-3d;
  transition:border-color .4s,transform .4s var(--ease-out);
  cursor:pointer;
}
.svc-card:hover{
  border-color:rgba(201,169,110,.3);
  transform:translateY(-8px);
}
.svc-card.svc-featured{
  border-color:rgba(201,169,110,.3);
  background:linear-gradient(135deg,rgba(201,169,110,.04) 0%,transparent 100%);
}
.svc-badge{
  position:absolute;top:1.5rem;right:1.5rem;
  background:var(--c-gold);color:var(--c-bg);
  font-size:.68rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  padding:.28rem .75rem;
  border-radius:20px;
}
.svc-num{
  font-family:var(--f-display);
  font-size:4rem;font-weight:300;font-style:italic;
  color:var(--c-gold);opacity:.35;
  line-height:1;margin-bottom:1.5rem;
}
.svc-title{
  font-family:var(--f-display);
  font-size:1.75rem;font-weight:300;
  margin-bottom:1rem;
}
.svc-desc{
  font-size:.95rem;color:var(--c-text-2);
  line-height:1.8;margin-bottom:2rem;
}
.svc-list{
  display:flex;flex-direction:column;gap:.6rem;
  margin-bottom:2rem;
}
.svc-list li{
  font-size:.9rem;color:var(--c-text-2);
  display:flex;align-items:center;gap:.75rem;
}
.svc-list li::before{
  content:'';
  width:14px;height:1px;
  background:var(--c-gold);
  flex-shrink:0;
}
.svc-price{
  font-family:var(--f-display);
  font-size:1.5rem;font-weight:300;
  margin-bottom:1.5rem;
}
.svc-cta{
  display:inline-flex;
  font-size:.78rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-gold);
  border-bottom:1px solid var(--c-gold);
  padding-bottom:2px;
  transition:gap .3s;
  gap:.4rem;
}
.svc-cta:hover{gap:.9rem}
.svc-glow{
  position:absolute;
  width:220px;height:220px;border-radius:50%;
  background:rgba(201,169,110,.04);
  filter:blur(60px);
  bottom:-60px;right:-60px;
  pointer-events:none;
}
.svc-glow-featured{
  background:rgba(201,169,110,.1);
  width:320px;height:320px;
}

/* ═══════════════════════════════
   PROCESS
═══════════════════════════════ */
#process{
  padding:10rem 3rem;
  background:var(--c-surface);
}
.process-wrap{max-width:900px;margin:0 auto}
.process-head{margin-bottom:5rem}
.timeline{
  position:relative;
  padding-left:4rem;
}
.timeline::before{
  content:'';
  position:absolute;left:.55rem;top:0;bottom:0;
  width:1px;
  background:linear-gradient(to bottom,var(--c-gold),transparent);
}
.tl-item{
  position:relative;
  padding-bottom:3.5rem;
}
.tl-item:last-child{padding-bottom:0}
.tl-dot{
  position:absolute;left:-3.6rem;top:.35rem;
  width:10px;height:10px;border-radius:50%;
  background:var(--c-gold);
  box-shadow:0 0 20px rgba(201,169,110,.5);
}
.tl-step{
  display:block;
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--c-gold);margin-bottom:.4rem;
}
.tl-content h3{
  font-family:var(--f-display);
  font-size:1.75rem;font-weight:300;
  margin-bottom:.6rem;
}
.tl-content p{
  font-size:.95rem;color:var(--c-text-2);
  line-height:1.8;max-width:48ch;
}

/* ═══════════════════════════════
   TESTIMONIALS
═══════════════════════════════ */
#testimonials{padding:10rem 3rem}
.test-wrap{
  max-width:860px;margin:0 auto;
  text-align:center;
}
.test-wrap .sec-num{text-align:left}
.test-slider{min-height:180px;position:relative}
.test-slide{
  display:none;
  animation:slideIn .5s var(--ease-out);
}
.test-slide.active{display:block}
@keyframes slideIn{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:translateY(0)}
}
.test-slide blockquote{
  font-family:var(--f-display);
  font-size:clamp(1.3rem,2.5vw,2rem);
  font-weight:300;font-style:italic;
  line-height:1.55;
  color:var(--c-text);
  margin-bottom:2rem;
  quotes:"\201C""\201D";
}
.test-slide blockquote::before{content:open-quote}
.test-slide blockquote::after{content:close-quote}
.test-slide cite{
  font-size:.82rem;letter-spacing:.12em;
  color:var(--c-gold);
}
.test-controls{
  display:flex;align-items:center;justify-content:center;
  gap:2rem;margin-top:3rem;
}
.test-btn{
  width:46px;height:46px;
  border:1px solid var(--c-border);
  border-radius:50%;
  color:var(--c-text-2);
  font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:border-color .25s,color .25s;
}
.test-btn:hover{border-color:var(--c-gold);color:var(--c-gold)}
.test-dots{display:flex;gap:.45rem;align-items:center}
.tdot{
  width:6px;height:6px;border-radius:3px;
  background:var(--c-text-3);
  cursor:pointer;
  transition:background .3s,width .3s;
}
.tdot.active{background:var(--c-gold);width:22px}

/* ═══════════════════════════════
   CONTACT
═══════════════════════════════ */
#contact{
  padding:10rem 3rem;
  background:var(--c-surface);
}
.contact-wrap{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:8rem;align-items:start;
}
.contact-desc{
  font-size:1.02rem;color:var(--c-text-2);
  line-height:1.85;margin-bottom:2.5rem;
}
.contact-links{
  display:flex;flex-direction:column;gap:.75rem;
  margin-bottom:2.5rem;
}
.c-link{
  font-size:1rem;color:var(--c-text-2);
  transition:color .22s;
}
.c-link:hover{color:var(--c-gold)}
.contact-socials{display:flex;gap:2rem}
.soc{
  font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-text-3);
  border-bottom:1px solid transparent;
  padding-bottom:2px;
  transition:color .22s,border-color .22s;
}
.soc:hover{color:var(--c-gold);border-color:var(--c-gold)}
.contact-form{display:flex;flex-direction:column;gap:1.5rem}
.f-group{display:flex;flex-direction:column;gap:.45rem}
.f-group label{
  font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--c-text-3);
}
.f-group input,.f-group select,.f-group textarea{
  background:var(--c-elevated);
  border:1px solid var(--c-border);
  border-radius:4px;
  padding:.95rem 1.2rem;
  color:var(--c-text);
  font-size:.95rem;
  outline:none;
  resize:vertical;
  appearance:none;
  -webkit-appearance:none;
  transition:border-color .25s,background .25s;
}
.f-group input:focus,.f-group select:focus,.f-group textarea:focus{
  border-color:var(--c-gold);
  background:rgba(201,169,110,.03);
}
.f-group input::placeholder,.f-group textarea::placeholder{color:var(--c-text-3)}
.f-group select option{background:var(--c-elevated)}
.f-group input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1) opacity(.4)}
.f-submit{align-self:flex-start;margin-top:.5rem}

/* ═══════════════════════════════
   FOOTER
═══════════════════════════════ */
#footer{
  padding:4.5rem 3rem;
  border-top:1px solid var(--c-border);
  position:relative;overflow:hidden;
}
.footer-inner{
  max-width:1400px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:1.5rem;
  position:relative;z-index:1;
}
.footer-logo{
  font-family:var(--f-display);
  font-size:2.75rem;font-weight:300;
  letter-spacing:.45em;
  color:var(--c-gold);
}
.footer-line{
  font-size:.88rem;color:var(--c-text-3);
  letter-spacing:.08em;
}
.footer-nav{display:flex;gap:2.5rem}
.footer-nav a{
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--c-text-3);
  transition:color .22s;
}
.footer-nav a:hover{color:var(--c-text)}
.footer-copy{font-size:.78rem;color:var(--c-text-3)}
#footer-canvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  opacity:.25;pointer-events:none;
}

/* ═══════════════════════════════
   RESPONSIVE
═══════════════════════════════ */
@media(max-width:1100px){
  .about-wrap,.contact-wrap{grid-template-columns:1fr;gap:4rem}
  .reel-wrap{grid-template-columns:1fr;gap:3rem}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .about-chip{bottom:-1.5rem;right:.5rem}
}
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  #navbar{padding:1.25rem 1.5rem}
  #hero{padding:0 1.5rem}
  .hero-stats{display:none}
  .hero-title{font-size:clamp(3.5rem,14vw,6rem)}
  #reel,#about,#services,#process,#testimonials,#contact{padding:6rem 1.5rem}
  #work{padding-top:6rem}
  .work-head{padding:0 1.5rem 2rem}
  .portfolio-track{padding:0 1.5rem 3rem}
  .p-card{width:280px}
  .p-card.p-wide{width:380px}
  .work-footer{padding:0 1.5rem 6rem}
  .services-grid{grid-template-columns:1fr}
  .footer-nav{flex-wrap:wrap;gap:1.25rem;justify-content:center}
}
