/* ─── RESET ─────────────────────────────────────────────── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --bg:      #080808;
  --bg2:     #101010;
  --bg3:     #181818;
  --gold:    #C9A84C;
  --gold-lt: #E4C96E;
  --gold-dk: #896E28;
  --text:    #F0EDE6;
  --muted:   #8A877F;
  --dim:     #444440;
  --border:  rgba(201,168,76,.14);
  --bh:      rgba(201,168,76,.40);
  --serif:   'Cormorant Garamond', serif;
  --sans:    'Inter', sans-serif;
  --ease:    cubic-bezier(.4,0,.2,1);
}
body { background:var(--bg); color:var(--text); font-family:var(--sans); font-weight:300; line-height:1.7; overflow-x:hidden; }
img { display:block; width:100%; }
a { text-decoration:none; color:inherit; }
button { font-family:inherit; }

/* ─── CUSTOM LOGO ─────────────────────────────────────────── */
.custom-logo-link { display:block; }
.custom-logo, .custom-logo-link img { height:38px !important; width:auto !important; display:block; }

/* ─── CURSOR ──────────────────────────────────────────────── */
body { cursor:none; }
.cur, .cur-ring {
  position:fixed; border-radius:50%; pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  transition-property:width,height,background,border-color;
  transition-duration:.28s; transition-timing-function:var(--ease);
}
.cur      { width:8px; height:8px; background:var(--gold); mix-blend-mode:difference; }
.cur-ring { width:36px; height:36px; border:1px solid rgba(201,168,76,.55); }
.cur.h    { width:18px; height:18px; }
.cur-ring.h { width:54px; height:54px; border-color:var(--gold); }
@media (hover:none) { .cur,.cur-ring{display:none} body{cursor:auto} }

/* ─── PRELOADER ───────────────────────────────────────────── */
#loader {
  position:fixed; inset:0; background:#000; z-index:99999;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  transition:opacity .9s ease, visibility .9s ease;
}
#loader.out { opacity:0; visibility:hidden; pointer-events:none; }
.ld-logo-wrap { opacity:0; animation:fdU .9s ease .2s both; }
.ld-logo-wrap img, .ld-logo-wrap .custom-logo { height:60px !important; width:auto !important; }
.ld-bar {
  width:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin-top:1.4rem; animation:barW 1.4s ease .4s both;
}
.ld-sub {
  font-size:.6rem; letter-spacing:.55em; text-transform:uppercase;
  color:var(--muted); margin-top:.9rem; opacity:0; animation:fdU .7s ease 1.1s both;
}
@keyframes fdU { from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:none} }
@keyframes barW { from{width:0} to{width:180px} }

/* ─── NAV ─────────────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  padding:1.6rem 5%; display:flex; align-items:center; justify-content:space-between;
  transition:padding .5s var(--ease), background .5s, border-color .5s;
  border-bottom:1px solid transparent;
}
nav.scrolled {
  background:rgba(8,8,8,.92); backdrop-filter:blur(18px);
  padding:1rem 5%; border-color:var(--border);
}
.n-logo { display:flex; align-items:center; }
.n-logo img { height:38px; width:auto; display:block; }
.n-links { display:flex; list-style:none; gap:2.2rem; align-items:center; }
.n-links a { font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); position:relative; transition:color .3s; }
.n-links a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:1px; background:var(--gold); transition:width .3s var(--ease); }
.n-links a:hover { color:var(--gold); }
.n-links a:hover::after { width:100%; }
.n-cta { color:var(--gold) !important; border:1px solid var(--gold) !important; padding:.55rem 1.4rem !important; transition:background .3s, color .3s !important; }
.n-cta::after { display:none !important; }
.n-cta:hover { background:var(--gold) !important; color:#000 !important; }
.burger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.burger span { display:block; width:24px; height:1.5px; background:var(--text); transition:.3s; }
.burger.on span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.burger.on span:nth-child(2) { opacity:0; }
.burger.on span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }
.m-nav {
  position:fixed; inset:0; background:rgba(5,5,5,.97); backdrop-filter:blur(20px);
  z-index:899; flex-direction:column; align-items:center; justify-content:center; gap:2.5rem;
  display:none; opacity:0; transition:opacity .4s;
}
.m-nav.on { display:flex; opacity:1; }
.m-nav a { font-family:var(--serif); font-size:clamp(2rem,7vw,3.2rem); font-weight:300; color:var(--text); transition:color .3s; }
.m-nav a:hover { color:var(--gold); }
@media(max-width:768px){ .n-links{display:none} .burger{display:flex} }

/* ─── SHARED ──────────────────────────────────────────────── */
section { padding:7rem 5%; }
.tag { display:inline-flex; align-items:center; gap:.9rem; font-size:.62rem; letter-spacing:.5em; text-transform:uppercase; color:var(--gold); margin-bottom:.9rem; }
.tag::before { content:''; width:28px; height:1px; background:var(--gold); }
.h2 { font-family:var(--serif); font-size:clamp(2.4rem,5vw,4rem); font-weight:300; line-height:1.12; color:var(--text); margin-bottom:1.4rem; }
.h2 em { font-style:italic; color:var(--gold); }

/* scroll reveal */
.rv,.rl,.rr { opacity:0; transition:opacity .85s var(--ease), transform .85s var(--ease); }
.rv  { transform:translateY(38px); }
.rl  { transform:translateX(-38px); }
.rr  { transform:translateX(38px); }
.rv.in,.rl.in,.rr.in { opacity:1; transform:none; }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s}
.d4{transition-delay:.4s} .d5{transition-delay:.5s} .d6{transition-delay:.6s}

/* ─── HERO ────────────────────────────────────────────────── */
#hero { position:relative; min-height:100vh; display:flex; align-items:center; padding:0 5%; overflow:hidden; }
.h-bg {
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 70% 60% at 72% 48%, rgba(201,168,76,.055) 0%, transparent 65%),
    radial-gradient(ellipse 40% 50% at 10% 80%, rgba(201,168,76,.025) 0%, transparent 50%),
    linear-gradient(170deg,#050505 0%,#0a0a0a 55%,#060606 100%);
}
.h-grain {
  position:absolute; inset:0; z-index:1; opacity:.038; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='256' height='256'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px; animation:grain .45s steps(1) infinite;
}
.h-scan { position:absolute; inset:0; z-index:1; pointer-events:none; background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.025) 2px,rgba(0,0,0,.025) 4px); }
@keyframes grain {
  0%{transform:translate(0,0)}    10%{transform:translate(-2px,-1px)}
  20%{transform:translate(2px,1px)} 30%{transform:translate(-1px,2px)}
  40%{transform:translate(1px,-2px)} 50%{transform:translate(-2px,2px)}
  60%{transform:translate(2px,-1px)} 70%{transform:translate(-1px,-2px)}
  80%{transform:translate(1px,2px)} 90%{transform:translate(2px,1px)}
  100%{transform:translate(0,0)}
}
.h-content { position:relative; z-index:2; max-width:860px; }
.h-eyebrow { display:flex; align-items:center; gap:1rem; font-size:.62rem; letter-spacing:.5em; text-transform:uppercase; color:var(--gold); margin-bottom:2rem; opacity:0; animation:fdU .9s ease .25s both; }
.h-eyebrow::before { content:''; width:36px; height:1px; background:var(--gold); }
.h-title { font-family:var(--serif); font-size:clamp(3.6rem,9.5vw,8.5rem); font-weight:300; line-height:.98; color:var(--text); margin-bottom:2rem; opacity:0; animation:fdU 1.1s ease .45s both; }
.h-title em { font-style:italic; color:var(--gold); }
.h-desc { font-size:.97rem; line-height:1.85; color:var(--muted); max-width:460px; margin-bottom:3rem; opacity:0; animation:fdU .9s ease .8s both; }
.h-btns { display:flex; gap:1.4rem; align-items:center; flex-wrap:wrap; opacity:0; animation:fdU .9s ease 1s both; }
.btn-g { display:inline-flex; align-items:center; gap:.7rem; padding:.95rem 2.4rem; background:var(--gold); color:#000; font-size:.72rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; position:relative; overflow:hidden; transition:color .3s; }
.btn-g::before { content:''; position:absolute; inset:0; background:var(--gold-lt); transform:translateX(-100%); transition:transform .4s var(--ease); }
.btn-g:hover::before { transform:translateX(0); }
.btn-g span { position:relative; z-index:1; }
.btn-o { display:inline-flex; align-items:center; gap:.9rem; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--muted); transition:color .3s; }
.btn-o:hover { color:var(--text); }
.play-circle { width:46px; height:46px; border:1px solid rgba(240,237,230,.22); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.9rem; transition:border-color .3s, color .3s; }
.btn-o:hover .play-circle { border-color:var(--gold); color:var(--gold); }
.h-scroll { position:absolute; bottom:2.8rem; left:5%; z-index:2; display:flex; align-items:center; gap:1rem; opacity:0; animation:fdU .9s ease 1.4s both; }
.h-scroll-line { width:48px; height:1px; background:var(--dim); overflow:hidden; position:relative; }
.h-scroll-line::after { content:''; position:absolute; inset:0; background:var(--gold); animation:scanL 2s ease infinite; }
@keyframes scanL { 0%{transform:translateX(-100%)} 50%{transform:translateX(0)} 100%{transform:translateX(100%)} }
.h-scroll span { font-size:.58rem; letter-spacing:.42em; text-transform:uppercase; color:var(--dim); }
.h-side { position:absolute; right:1.8rem; top:50%; transform:translateY(-50%) rotate(90deg); font-size:.56rem; letter-spacing:.42em; text-transform:uppercase; color:var(--dim); z-index:2; opacity:0; animation:fdI .8s ease 1.5s both; }
@keyframes fdI { to{opacity:1} }

/* ─── TICKER ──────────────────────────────────────────────── */
.ticker { background:var(--gold); padding:1.1rem 0; overflow:hidden; }
.ticker-track { display:flex; animation:ticker 22s linear infinite; white-space:nowrap; }
.ticker-item { font-size:.62rem; font-weight:600; letter-spacing:.3em; text-transform:uppercase; color:#000; padding:0 3rem; display:flex; align-items:center; gap:3rem; }
.ticker-dot { width:4px; height:4px; background:rgba(0,0,0,.28); border-radius:50%; }
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ─── ABOUT ───────────────────────────────────────────────── */
#about { background:var(--bg2); position:relative; overflow:hidden; }
#about::before { content:'ABOUT'; position:absolute; left:-1%; top:50%; transform:translateY(-50%); font-family:var(--serif); font-size:clamp(7rem,16vw,14rem); font-weight:600; color:rgba(255,255,255,.012); letter-spacing:.1em; pointer-events:none; white-space:nowrap; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; position:relative; z-index:1; }
@media(max-width:900px){ .about-grid{ grid-template-columns:1fr; gap:3rem } }
.about-text p { color:var(--muted); margin-bottom:1.4rem; font-size:.94rem; line-height:1.9; }
.about-text p strong { color:var(--text); font-weight:500; }
.about-quote { font-family:var(--serif); font-size:clamp(1.25rem,2.8vw,1.7rem); font-weight:300; font-style:italic; color:var(--gold); line-height:1.45; border-left:2px solid var(--gold); padding-left:1.4rem; margin:2.2rem 0; }
.divider { width:55px; height:1px; background:var(--gold); margin:2rem 0; }
.stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:2px; }
.stat { background:var(--bg3); padding:2.4rem 2rem; border:1px solid var(--border); transition:border-color .3s, background .3s; }
.stat:hover { border-color:var(--bh); background:rgba(201,168,76,.03); }
.stat-n { font-family:var(--serif); font-size:clamp(2.8rem,5.5vw,4.2rem); font-weight:300; color:var(--gold); line-height:1; margin-bottom:.4rem; }
.stat-l { font-size:.67rem; letter-spacing:.3em; text-transform:uppercase; color:var(--muted); }

/* ─── FILM STRIP ──────────────────────────────────────────── */
.strip { display:flex; overflow:hidden; background:#000; height:28px; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.strip-hole { flex:none; width:18px; height:100%; border-right:1px solid #1a1a1a; display:flex; align-items:center; justify-content:center; }
.strip-hole::after { content:''; width:8px; height:12px; border:1px solid #2a2a2a; border-radius:1px; background:#050505; }

/* ─── REEL ────────────────────────────────────────────────── */
#reel { padding:0; background:#000; }
.reel-wrap { position:relative; height:min(55vw,600px); min-height:300px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.reel-bg { position:absolute; inset:0; background:linear-gradient(135deg,#0a0500,#160c00 35%,#0a0a09 65%,#050508 100%); }
.reel-grid { position:absolute; inset:0; background:repeating-linear-gradient(90deg,transparent,transparent calc(100%/8 - 1px),rgba(255,255,255,.018) calc(100%/8 - 1px),rgba(255,255,255,.018) calc(100%/8)); }
.reel-overlay { position:absolute; inset:0; background:rgba(0,0,0,.48); }
.reel-cta { position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; gap:1.5rem; }
.reel-btn { width:88px; height:88px; border:1.5px solid rgba(201,168,76,.55); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); font-size:1.7rem; position:relative; transition:all .4s; cursor:pointer; background:none; }
.reel-btn::before { content:''; position:absolute; inset:-12px; border-radius:50%; border:1px solid rgba(201,168,76,.2); animation:pulse 2.2s ease infinite; }
@keyframes pulse { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.35);opacity:0} }
.reel-btn:hover { background:var(--gold); border-color:var(--gold); color:#000; transform:scale(1.04); }
.reel-label { font-size:.62rem; letter-spacing:.42em; text-transform:uppercase; color:rgba(240,237,230,.5); }

/* Showreel modal */
.reel-modal { position:fixed; inset:0; background:rgba(0,0,0,.95); z-index:9000; display:flex; align-items:center; justify-content:center; }
.reel-modal-inner { position:relative; width:90%; max-width:1100px; }
.reel-modal-close { position:absolute; top:-3rem; right:0; background:none; border:none; color:var(--text); font-size:2rem; cursor:pointer; line-height:1; }
.reel-embed { position:relative; padding-bottom:56.25%; height:0; }
.reel-embed iframe { position:absolute; inset:0; width:100%; height:100%; }

/* ─── SERVICES ────────────────────────────────────────────── */
#services { position:relative; }
.svc-head { max-width:680px; margin-bottom:4rem; }
.svc-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); }
@media(max-width:900px){ .svc-grid{ grid-template-columns:repeat(2,1fr) } }
@media(max-width:580px){ .svc-grid{ grid-template-columns:1fr } }
.svc-card { background:var(--bg); padding:2.8rem 2.4rem; position:relative; overflow:hidden; transition:background .4s; }
.svc-card::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(201,168,76,.06) 0%,transparent 55%); opacity:0; transition:opacity .4s; }
.svc-card::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--gold); transition:width .4s var(--ease); }
.svc-card:hover { background:var(--bg3); }
.svc-card:hover::before { opacity:1; }
.svc-card:hover::after { width:100%; }
.svc-num { font-family:var(--serif); font-size:3.8rem; font-weight:300; line-height:1; color:rgba(255,255,255,.04); position:absolute; top:1.4rem; right:2rem; transition:color .3s; }
.svc-card:hover .svc-num { color:rgba(201,168,76,.07); }
.svc-icon { width:48px; height:48px; color:var(--gold); opacity:.8; margin-bottom:1.8rem; transition:opacity .3s, transform .3s; }
.svc-card:hover .svc-icon { opacity:1; transform:scale(1.08); }
.svc-title { font-family:var(--serif); font-size:1.55rem; font-weight:400; color:var(--text); margin-bottom:.9rem; }
.svc-desc  { font-size:.86rem; color:var(--muted); line-height:1.8; }

/* ─── PORTFOLIO ───────────────────────────────────────────── */
#portfolio { background:var(--bg2); }
.port-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:3rem; flex-wrap:wrap; gap:2rem; }
.port-filters { display:flex; gap:.2rem; }
.f-btn { font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); background:none; border:1px solid var(--border); padding:.48rem 1rem; cursor:pointer; transition:background .3s, color .3s, border-color .3s; }
.f-btn.on,.f-btn:hover { background:var(--gold); color:#000; border-color:var(--gold); }
.port-grid { display:grid; grid-template-columns:repeat(12,1fr); gap:1px; background:rgba(255,255,255,.04); }
.pi:nth-child(1) { grid-column:span 7; }
.pi:nth-child(2) { grid-column:span 5; }
.pi:nth-child(3) { grid-column:span 4; }
.pi:nth-child(4) { grid-column:span 4; }
.pi:nth-child(5) { grid-column:span 4; }
.pi:nth-child(6) { grid-column:span 5; }
.pi:nth-child(7) { grid-column:span 7; }
@media(max-width:900px){ .pi{ grid-column:span 6 !important } }
@media(max-width:580px){ .pi{ grid-column:span 12 !important } }
.pi { position:relative; overflow:hidden; cursor:pointer; transition:opacity .4s; }
.pi.hide { display:none; }
.pi img { width:100%; aspect-ratio:16/10; object-fit:cover; filter:grayscale(25%) brightness(.72); transition:filter .55s, transform .6s var(--ease); }
.pi:hover img { filter:grayscale(0%) brightness(.5); transform:scale(1.06); }
.pi-ov { position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end; padding:1.8rem; background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 55%); opacity:0; transition:opacity .4s; }
.pi:hover .pi-ov { opacity:1; }
.pi-cat { font-size:.58rem; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); margin-bottom:.4rem; }
.pi-name { font-family:var(--serif); font-size:1.35rem; font-weight:400; color:var(--text); }

/* ─── PROCESS ─────────────────────────────────────────────── */
#process { position:relative; }
.proc-head { max-width:680px; margin-bottom:4rem; }
.proc-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); }
@media(max-width:900px){ .proc-steps{ grid-template-columns:repeat(2,1fr) } }
@media(max-width:480px){ .proc-steps{ grid-template-columns:1fr } }
.proc-step { background:var(--bg); padding:2.5rem 2rem; position:relative; transition:background .3s; }
.proc-step::after { content:''; position:absolute; top:0; left:0; width:0; height:2px; background:var(--gold); transition:width .5s var(--ease); }
.proc-step:hover { background:var(--bg3); }
.proc-step:hover::after { width:100%; }
.proc-n { font-family:var(--serif); font-size:3rem; font-weight:300; color:rgba(201,168,76,.18); line-height:1; margin-bottom:1.4rem; }
.proc-t { font-family:var(--serif); font-size:1.35rem; color:var(--text); margin-bottom:.8rem; }
.proc-d { font-size:.85rem; color:var(--muted); line-height:1.8; }

/* ─── TEAM ────────────────────────────────────────────────── */
#team { background:var(--bg2); }
.team-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); margin-top:4rem; }
@media(max-width:900px){ .team-grid{ grid-template-columns:repeat(2,1fr) } }
@media(max-width:480px){ .team-grid{ grid-template-columns:1fr } }
.tc { background:var(--bg); overflow:hidden; }
.tc img { width:100%; aspect-ratio:3/4; object-fit:cover; filter:grayscale(80%) brightness(.7); transition:filter .5s, transform .55s var(--ease); }
.tc:hover img { filter:grayscale(0%) brightness(.78); transform:scale(1.04); }
.tc-info { padding:1.4rem; border-top:1px solid var(--border); background:var(--bg3); transition:background .3s; }
.tc:hover .tc-info { background:rgba(201,168,76,.04); }
.tc-name { font-family:var(--serif); font-size:1.25rem; font-weight:400; color:var(--text); margin-bottom:.2rem; }
.tc-role { font-size:.65rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); }
.tc-soc { display:flex; gap:.8rem; margin-top:.9rem; }
.tc-soc a { font-size:.75rem; color:var(--dim); transition:color .3s; border:1px solid var(--border); width:28px; height:28px; display:flex; align-items:center; justify-content:center; }
.tc-soc a:hover { color:var(--gold); border-color:var(--gold); }

/* ─── CONTACT ─────────────────────────────────────────────── */
#contact { background:var(--bg2); }
.ct-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; }
@media(max-width:900px){ .ct-grid{ grid-template-columns:1fr; gap:3rem } }
.ct-info-item { padding:1.4rem 0; border-bottom:1px solid var(--border); }
.ct-label { font-size:.58rem; letter-spacing:.42em; text-transform:uppercase; color:var(--gold); margin-bottom:.35rem; }
.ct-val { font-family:var(--serif); font-size:1.1rem; color:var(--text); line-height:1.5; }
.ct-val a { color:var(--text); transition:color .3s; }
.ct-val a:hover { color:var(--gold); }
.ct-form { display:flex; flex-direction:column; gap:1.4rem; }
.fg { display:flex; flex-direction:column; gap:.45rem; }
.fl { font-size:.6rem; letter-spacing:.32em; text-transform:uppercase; color:var(--muted); }
.fi,.ft { background:var(--bg3); border:1px solid var(--border); color:var(--text); padding:.95rem 1.2rem; font-family:var(--sans); font-size:.9rem; font-weight:300; outline:none; width:100%; resize:none; transition:border-color .3s, background .3s; }
.fi::placeholder,.ft::placeholder { color:var(--dim); }
.fi:focus,.ft:focus { border-color:var(--gold); background:rgba(201,168,76,.03); }
.fg-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media(max-width:480px){ .fg-row{ grid-template-columns:1fr } }
.sub-btn { display:inline-flex; align-items:center; gap:.9rem; padding:1.05rem 2.4rem; background:transparent; color:var(--gold); font-size:.7rem; font-weight:500; letter-spacing:.25em; text-transform:uppercase; border:1px solid var(--gold); cursor:pointer; position:relative; overflow:hidden; transition:color .3s; width:fit-content; }
.sub-btn::before { content:''; position:absolute; inset:0; background:var(--gold); transform:translateX(-100%); transition:transform .4s var(--ease); }
.sub-btn:hover { color:#000; }
.sub-btn:hover::before { transform:translateX(0); }
.sub-btn span { position:relative; z-index:1; }
.sub-btn:disabled { opacity:.6; cursor:default; }
#cf-msg.success { color:var(--gold); }
#cf-msg.error   { color:#e06060; }

/* ─── FOOTER ──────────────────────────────────────────────── */
footer { background:#000; padding:4rem 5%; border-top:1px solid var(--border); }
.ft-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3.5rem; }
@media(max-width:900px){ .ft-grid{ grid-template-columns:1fr 1fr } }
@media(max-width:480px){ .ft-grid{ grid-template-columns:1fr } }
.ft-brand p { font-size:.84rem; color:var(--dim); line-height:1.8; margin-top:1.2rem; max-width:250px; }
.ft-col-t { font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; color:var(--muted); margin-bottom:1.4rem; }
.ft-links { list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.ft-links a { font-size:.84rem; color:var(--dim); transition:color .3s; }
.ft-links a:hover { color:var(--gold); }
.ft-soc { display:flex; gap:.8rem; }
.ft-s { width:36px; height:36px; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--muted); font-size:.8rem; transition:all .3s; }
.ft-s:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,.05); }
.ft-bot { display:flex; align-items:center; justify-content:space-between; padding-top:1.8rem; border-top:1px solid var(--border); flex-wrap:wrap; gap:1rem; }
.ft-bot p { font-size:.72rem; color:var(--dim); }
.ft-bot a { color:var(--gold); }
