/* ═══════════════════════════════════════════════
   KODA CREATIVE — Dramatic Redesign
   Sistine · Mineral · Biophilic · Kinetic
═══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,300;1,400;1,600&family=Inter:wght@300;400;500&display=swap');

:root {
  --void:    #04040a;
  --black:   #080810;
  --coal:    #0e0e18;
  --gold:    #c9a96e;
  --gold2:   #e8c87a;
  --ember:   #8b4513;
  --copper:  #b87333;
  --white:   #f0ede6;
  --cream:   #d4c9b0;
  --smoke:   rgba(4,4,10,0.82);
  --mute:    #444455;
  --font-d:  'Cormorant Garamond', Georgia, serif;
  --font-b:  'Inter', system-ui, sans-serif;
  --ease:    cubic-bezier(0.16, 1, 0.3, 1);
}

/* ── Reset ──────────────────────────────────── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background: var(--void);
  color: var(--white);
  font-family: var(--font-b);
  font-weight:300;
  line-height: 1.7;
  overflow-x: hidden;
  cursor: none;
}
a { color:inherit; text-decoration:none; }
img { display:block; max-width:100%; }
button { cursor:none; border:none; background:none; color:inherit; font:inherit; }

/* ── Custom Cursor ──────────────────────────── */
#cursor {
  position: fixed; z-index:9999;
  width: 8px; height: 8px;
  background: var(--gold);
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%,-50%);
  transition: width .25s var(--ease), height .25s var(--ease), background .25s, opacity .3s;
  mix-blend-mode: screen;
}
#cursor-ring {
  position: fixed; z-index:9998;
  width: 40px; height: 40px;
  border: 1px solid rgba(201,169,110,.3);
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%,-50%);
  transition: width .3s var(--ease), height .3s var(--ease), border-color .3s;
}
body.cursor-hover #cursor      { width:16px; height:16px; background:var(--gold2); }
body.cursor-hover #cursor-ring { width:56px; height:56px; border-color:var(--gold); }

/* ── Particle Canvas ────────────────────────── */
#particle-canvas {
  position: fixed; inset:0; z-index:0;
  pointer-events: none;
  opacity: 1;
}

/* ── Nav ────────────────────────────────────── */
#navbar {
  position:fixed; top:0; left:0; right:0;
  display:flex; align-items:center; justify-content:space-between;
  padding: 0 60px;
  height: 76px;
  z-index: 100;
  transition: background .5s, border-color .5s;
}
#navbar.scrolled {
  background: rgba(4,4,10,.92);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(201,169,110,.08);
}
.nav-logo {
  font-family: var(--font-d);
  font-size: 17px; font-weight:600; letter-spacing:5px; text-transform:uppercase;
  display: flex; align-items:center; gap:14px;
}
.logo-mark {
  width: 34px; height: 34px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display:flex; align-items:center; justify-content:center;
  font-size: 13px; color: var(--gold);
  font-family: var(--font-d); font-weight:700; letter-spacing:0;
  transition: background .3s;
  position:relative; overflow:hidden;
}
.logo-mark::after {
  content:'';
  position:absolute; inset:0;
  background: var(--gold); border-radius:50%;
  transform:scale(0); transform-origin:center;
  transition:transform .4s var(--ease);
}
.nav-logo:hover .logo-mark { color:var(--void); }
.nav-logo:hover .logo-mark::after { transform:scale(1); }
.logo-mark span { position:relative; z-index:1; }
.nav-links { display:flex; gap:48px; list-style:none; }
.nav-links a {
  font-size: 10px; letter-spacing:2.5px; text-transform:uppercase;
  color: rgba(240,237,230,.4); font-weight:400;
  transition: color .3s;
  position:relative; padding-bottom:3px;
}
.nav-links a::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:1px; background:var(--gold);
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-links a:hover, .nav-links a.active { color:var(--white); }
.nav-links a:hover::after, .nav-links a.active::after { transform:scaleX(1); }
.nav-cta {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  padding: 10px 22px;
  border: 1px solid rgba(201,169,110,.3);
  color: var(--gold);
  transition: all .3s;
}
.nav-cta:hover { background:var(--gold); border-color:var(--gold); color:var(--void); }
.hamburger { display:none; flex-direction:column; gap:5px; }
.hamburger span { display:block; width:22px; height:1px; background:var(--white); transition:all .3s; }

/* ── Hero ───────────────────────────────────── */
#hero {
  position:relative;
  height: 100vh; min-height:640px;
  display:flex; align-items:flex-end;
  padding: 0 60px 80px;
  overflow:hidden;
  z-index:1;
}

/* Draping dark mineral BG — no image, paint it with CSS */
.hero-stage {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 100% 70% at 65% 30%, rgba(139,69,19,.07) 0%, transparent 55%),
    radial-gradient(ellipse 80% 100% at 85% 60%, rgba(70,40,10,.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 20% 80%, rgba(201,169,110,.04) 0%, transparent 50%),
    linear-gradient(170deg, rgba(20,16,8,.95) 0%, var(--void) 100%);
}

/* Sfumato curtain layers */
.curtain-l {
  position:absolute; top:0; left:0; bottom:0;
  width:30%;
  background: linear-gradient(to right, rgba(4,4,10,.98) 0%, rgba(4,4,10,.6) 60%, transparent 100%);
  pointer-events:none; z-index:2;
}
.curtain-b {
  position:absolute; bottom:0; left:0; right:0;
  height:40%;
  background: linear-gradient(to top, rgba(4,4,10,.98) 0%, rgba(4,4,10,.5) 60%, transparent 100%);
  pointer-events:none; z-index:2;
}
.curtain-t {
  position:absolute; top:0; left:0; right:0;
  height:20%;
  background: linear-gradient(to bottom, rgba(4,4,10,.9) 0%, transparent 100%);
  pointer-events:none; z-index:2;
}

/* Hero background image (when present) */
.hero-bg-img {
  position:absolute; inset:0;
  background-size:cover; background-position:center 30%;
  z-index:1;
  opacity:.22;
  filter: saturate(.3) brightness(.6);
}

.hero-content {
  position:relative; z-index:5;
  max-width:720px;
}
.hero-eyebrow {
  font-size:9px; letter-spacing:5px; text-transform:uppercase;
  color: var(--gold); opacity:.7;
  margin-bottom:28px;
  opacity:0; transform:translateY(12px);
  animation:fadeUp .9s var(--ease) .5s forwards;
}
.hero-title {
  font-family: var(--font-d);
  font-size: clamp(52px, 7.5vw, 112px);
  font-weight:300; line-height:.9;
  letter-spacing:-3px;
  color: var(--white);
  opacity:0; transform:translateY(28px);
  animation:fadeUp 1.2s var(--ease) .7s forwards;
}
.hero-title em {
  font-style:italic; color:var(--gold);
  display:block;
}
.hero-rule {
  width:60px; height:1px;
  background:linear-gradient(to right, var(--gold), transparent);
  margin: 36px 0;
  opacity:0; animation:fadeIn 1s ease 1.3s forwards;
}
.hero-sub {
  font-size:12px; letter-spacing:1.5px; line-height:2.2;
  color: rgba(240,237,230,.35);
  opacity:0; transform:translateY(12px);
  animation:fadeUp .9s var(--ease) 1s forwards;
  max-width:380px;
}
.hero-actions {
  margin-top:48px; display:flex; gap:24px; align-items:center;
  opacity:0; animation:fadeUp .8s var(--ease) 1.3s forwards;
}
.btn-p {
  display:inline-flex; align-items:center; gap:12px;
  padding: 15px 40px;
  background:var(--gold); color:var(--void);
  font-size:10px; letter-spacing:3px; text-transform:uppercase; font-weight:500;
  transition:background .3s, gap .3s;
}
.btn-p:hover { background:var(--gold2); gap:20px; }
.btn-g {
  font-size:10px; letter-spacing:2.5px; text-transform:uppercase;
  color:rgba(240,237,230,.35);
  border-bottom:1px solid rgba(240,237,230,.12);
  padding-bottom:2px;
  display:inline-flex; align-items:center; gap:10px;
  transition:color .3s, border-color .3s, gap .3s;
}
.btn-g:hover { color:var(--white); border-color:rgba(240,237,230,.4); gap:16px; }

.hero-scroll {
  position:absolute; right:60px; bottom:60px; z-index:5;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  cursor:none;
  opacity:0; animation:fadeIn 1s ease 1.8s forwards;
}
.scroll-track {
  width:1px; height:72px;
  background:linear-gradient(to bottom, transparent, var(--gold) 50%, transparent);
  animation:scrollDrop 2.4s ease-in-out infinite;
}
.hero-scroll span {
  font-size:8px; letter-spacing:4px; text-transform:uppercase;
  color:rgba(240,237,230,.2); writing-mode:vertical-rl;
}
@keyframes scrollDrop { 0%,100%{opacity:.4;transform:scaleY(.8)} 50%{opacity:1;transform:scaleY(1)} }

/* ── Services Strip ─────────────────────────── */
#services {
  position:relative; z-index:1;
  display:grid; grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(201,169,110,.07);
}
.svc {
  padding:56px 44px;
  border-right:1px solid rgba(201,169,110,.07);
  position:relative; overflow:hidden;
  transition:background .5s;
}
.svc::before {
  content:'';
  position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(to right, var(--gold), transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.svc:hover { background:rgba(201,169,110,.025); }
.svc:hover::before { transform:scaleX(1); }
.svc-n {
  font-family:var(--font-d); font-size:52px; font-weight:300;
  color:rgba(201,169,110,.1); line-height:1; margin-bottom:24px;
  transition:color .4s;
}
.svc:hover .svc-n { color:rgba(201,169,110,.2); }
.svc-t {
  font-family:var(--font-d); font-size:20px; font-weight:600;
  color:var(--white); margin-bottom:12px; letter-spacing:.5px;
}
.svc-d { font-size:12px; color:rgba(240,237,230,.3); line-height:1.9; }

/* ── Section Shared ─────────────────────────── */
.sec-label {
  font-size:9px; letter-spacing:4px; text-transform:uppercase; color:var(--gold);
  margin-bottom:14px;
}
.sec-title {
  font-family:var(--font-d); font-weight:300; line-height:.9;
  font-size:clamp(38px,5vw,68px); letter-spacing:-1.5px;
}

/* ── Timeline ───────────────────────────────── */
#timeline {
  padding:120px 60px;
  position:relative; z-index:1;
}
.tl-spine {
  position:absolute;
  left:300px; top:120px; bottom:120px;
  width:1px;
  background:linear-gradient(to bottom,
    transparent, rgba(201,169,110,.15) 8%,
    rgba(201,169,110,.15) 92%, transparent);
}
.tl-header {
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:80px;
}
.tl-item {
  display:grid; grid-template-columns:240px 1fr;
  gap:0 60px;
  margin-bottom:60px;
  position:relative;
  opacity:0; transform:translateY(36px);
  transition:opacity .85s var(--ease), transform .85s var(--ease);
}
.tl-item.visible { opacity:1; transform:none; }
.tl-meta { text-align:right; padding-top:8px; }
.tl-year {
  font-family:var(--font-d); font-size:40px; font-weight:300;
  color:rgba(240,237,230,.1); line-height:1;
  transition:color .4s;
}
.tl-item:hover .tl-year { color:rgba(240,237,230,.2); }
.tl-loc {
  font-size:9px; letter-spacing:2.5px; text-transform:uppercase;
  color:rgba(240,237,230,.2); margin-top:6px;
}
/* Jewel dot */
.tl-item::after {
  content:''; position:absolute;
  left:calc(240px + 60px - 5px); top:16px;
  width:10px; height:10px; border-radius:50%;
  background:var(--accent, var(--gold));
  box-shadow: 0 0 0 3px rgba(4,4,10,1), 0 0 0 4px var(--accent, var(--gold));
  transition:transform .4s var(--ease), box-shadow .4s;
}
.tl-item:hover::after {
  transform:scale(1.5);
  box-shadow:0 0 0 3px rgba(4,4,10,1), 0 0 0 4px var(--accent,var(--gold)), 0 0 16px rgba(201,169,110,.3);
}

.tl-card {
  background:rgba(255,255,255,.018);
  border:1px solid rgba(255,255,255,.05);
  overflow:hidden;
  transition:border-color .4s, background .4s;
  position:relative;
}
.tl-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:var(--accent, var(--gold));
  transform:scaleY(0); transform-origin:top;
  transition:transform .45s var(--ease);
}
.tl-item:hover .tl-card { border-color:rgba(255,255,255,.1); background:rgba(255,255,255,.03); }
.tl-item:hover .tl-card::before { transform:scaleY(1); }

.tl-img-wrap {
  position:relative; overflow:hidden; height:200px;
}
.tl-img-wrap img {
  width:100%; height:100%; object-fit:cover;
  filter:saturate(.5) brightness(.55);
  transition:filter .6s var(--ease), transform .8s var(--ease);
}
.tl-item:hover .tl-img-wrap img {
  filter:saturate(.9) brightness(.75);
  transform:scale(1.04);
}
/* Gradient overlay on image */
.tl-img-wrap::after {
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(to bottom, transparent 30%, rgba(4,4,10,.92) 100%);
}
.tl-body { padding:28px 36px 32px; }
.tl-tag {
  display:inline-block;
  font-size:8px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--accent, var(--gold)); border:1px solid var(--accent, var(--gold));
  padding:3px 10px; margin-bottom:14px; opacity:.7;
}
.tl-name {
  font-family:var(--font-d); font-size:26px; font-weight:600;
  color:var(--white); line-height:1.1; margin-bottom:12px;
}
.tl-desc { font-size:13px; color:rgba(240,237,230,.38); line-height:1.85; margin-bottom:20px; }
.tl-link {
  font-size:9px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--accent, var(--gold));
  display:inline-flex; align-items:center; gap:8px;
  transition:gap .3s, opacity .3s;
}
.tl-link:hover { gap:14px; opacity:.8; }

/* ── Contact ────────────────────────────────── */
#contact {
  position:relative; z-index:1;
  padding:120px 60px;
  background:var(--coal);
  border-top:1px solid rgba(201,169,110,.06);
}
.contact-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start;
}
.contact-promise {
  font-family:var(--font-d); font-weight:300;
  font-size:clamp(32px,4vw,54px); line-height:1.15;
  margin-top:16px; margin-bottom:40px;
}
.contact-promise em { color:var(--gold); font-style:italic; }
.contact-detail {
  display:flex; align-items:center; gap:14px;
  font-size:12px; color:rgba(240,237,230,.35);
  margin-bottom:14px;
}
.contact-detail-icon { color:var(--gold); }
.response-box {
  margin-top:36px; padding:22px 28px;
  border:1px solid rgba(201,169,110,.15);
  background:rgba(201,169,110,.03);
  display:flex; gap:16px; align-items:flex-start;
}
.response-icon { font-size:18px; margin-top:2px; }
.response-txt { font-size:12px; color:rgba(240,237,230,.4); line-height:1.7; }
.response-txt strong { color:var(--gold); }

/* Form */
.form { display:flex; flex-direction:column; gap:18px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.fg { display:flex; flex-direction:column; gap:7px; }
.fl {
  font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:rgba(240,237,230,.3);
}
.fi, .fs, .ft {
  background:rgba(255,255,255,.025); border:1px solid rgba(255,255,255,.07);
  color:var(--white); padding:14px 16px;
  font:inherit; font-size:13px; outline:none;
  transition:border-color .3s, background .3s;
  cursor:none; -webkit-appearance:none;
}
.fi:focus, .fs:focus, .ft:focus {
  border-color:rgba(201,169,110,.5); background:rgba(201,169,110,.03);
}
.fi::placeholder, .ft::placeholder { color:rgba(240,237,230,.15); }
.fs option { background:var(--coal); color:var(--white); }
.ft { resize:vertical; min-height:130px; }
.upload-zone {
  border:1px dashed rgba(201,169,110,.18);
  padding:22px; text-align:center;
  transition:border-color .3s, background .3s; cursor:none;
}
.upload-zone:hover { border-color:var(--gold); background:rgba(201,169,110,.03); }
.upload-label { font-size:11px; color:rgba(240,237,230,.25); }
.upload-label span { color:var(--gold); }
.submit-btn {
  display:flex; align-items:center; justify-content:space-between;
  padding:17px 32px;
  background:var(--gold); color:var(--void);
  font-size:10px; letter-spacing:2.5px; text-transform:uppercase; font-weight:500;
  cursor:none; width:100%;
  transition:background .3s;
}
.submit-btn:hover { background:var(--gold2); }
.form-ok { display:none; padding:24px; border:1px solid var(--gold); background:rgba(201,169,110,.06); text-align:center; }
.form-ok.show { display:block; }
.form-ok h3 { font-family:var(--font-d); font-size:22px; color:var(--gold); margin-bottom:8px; }
.form-ok p { font-size:12px; color:rgba(240,237,230,.4); }

/* ── Footer ─────────────────────────────────── */
footer {
  padding:56px 60px;
  border-top:1px solid rgba(201,169,110,.07);
  display:flex; justify-content:space-between; align-items:center;
  position:relative; z-index:1;
}
.footer-brand { font-family:var(--font-d); font-size:16px; letter-spacing:5px; text-transform:uppercase; }
.footer-links { display:flex; gap:28px; }
.footer-links a {
  font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:rgba(240,237,230,.22);
  transition:color .3s;
}
.footer-links a:hover { color:var(--gold); }
.footer-copy { font-size:11px; color:var(--mute); }

/* ── Animations ─────────────────────────────── */
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { to { opacity:1; } }
.reveal {
  opacity:0; transform:translateY(28px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.visible { opacity:1; transform:none; }
.d1{transition-delay:.1s} .d2{transition-delay:.2s} .d3{transition-delay:.3s} .d4{transition-delay:.4s}

/* Mobile nav overlay */
.nav-overlay {
  display:none; position:fixed; inset:0; z-index:200;
  background:rgba(4,4,10,.97);
  flex-direction:column; align-items:center; justify-content:center; gap:36px;
}
.nav-overlay.open { display:flex; }
.nav-overlay a { font-family:var(--font-d); font-size:44px; font-weight:300; color:var(--white); transition:color .3s; }
.nav-overlay a:hover { color:var(--gold); }
.overlay-close { position:absolute; top:24px; right:24px; font-size:22px; color:var(--mute); cursor:none; }

/* ── Responsive ─────────────────────────────── */
@media(max-width:1024px) {
  #services { grid-template-columns:repeat(2,1fr); }
  #timeline { padding:80px 32px; }
  .tl-spine { left:200px; }
  .tl-item { grid-template-columns:160px 1fr; gap:0 40px; }
  .tl-item::after { left:calc(160px+40px-5px); }
  .contact-grid { grid-template-columns:1fr; gap:48px; }
  #hero,#contact,footer { padding-left:32px; padding-right:32px; }
  #navbar { padding:0 32px; }
}
@media(max-width:700px) {
  body { cursor:auto; }
  #cursor,#cursor-ring { display:none; }
  #navbar { padding:0 20px; }
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
  #hero { padding:0 20px 60px; }
  .hero-scroll { display:none; }
  #services { grid-template-columns:1fr; border-top:none; }
  #timeline { padding:60px 20px; }
  .tl-spine,.tl-item::after { display:none; }
  .tl-item { grid-template-columns:1fr; }
  .tl-meta { text-align:left; }
  #contact { padding:60px 20px; }
  .form-row { grid-template-columns:1fr; }
  footer { flex-direction:column; gap:18px; text-align:center; padding:36px 20px; }
  .tl-header { flex-direction:column; align-items:flex-start; gap:20px; }
}
