/* ═══════════════════════════════════════════════════════════════
   KNIGHT'S PATH — Shared Stylesheet
   ═══════════════════════════════════════════════════════════════ */

/* ── Fonts ─────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Cinzel:wght@400;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --gold:        #c9a84c;
  --gold-light:  #e8c97a;
  --gold-dim:    rgba(201,168,76,.12);
  --gold-mid:    rgba(201,168,76,.35);
  --blood:       #8b1a1a;
  --parchment:   #f0e8d0;
  --dark:        #0a0805;
  --dark-mid:    #100d08;
  --dark-warm:   #130f09;
  --dark-card:   #0d0a07;
  --text-light:  #d4c9a8;
  --text-dim:    #bfb08a;
  --nav-h:       72px;
  --max-w:       1200px;
  --ease:        cubic-bezier(.25,.46,.45,.94);
}

/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:17px; -webkit-text-size-adjust:100%; overflow-x:hidden; }
body { font-family:'Crimson Pro',serif; background:var(--dark); color:var(--text-light); overflow-x:hidden; cursor:none; line-height:1.72; }
img, video { max-width:100%; display:block; }
a { text-decoration:none; color:inherit; }
button { cursor:pointer; font-family:inherit; }
ul { list-style:none; }

/* ── Custom Cursor ──────────────────────────────────────────── */
.cursor {
  position:fixed; width:10px; height:10px; background:var(--gold); border-radius:50%;
  pointer-events:none; z-index:9999; transform:translate(-50%,-50%);
  transition:width .2s, height .2s; mix-blend-mode:difference;
}
.cursor-ring {
  position:fixed; width:34px; height:34px; border:1px solid rgba(201,168,76,.6); border-radius:50%;
  pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:width .2s, height .2s;
}

/* ── Navigation ─────────────────────────────────────────────── */
#mainNav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 64px; height:var(--nav-h);
  transition:background .4s var(--ease), box-shadow .4s;
}
#mainNav.scrolled {
  background:rgba(10,8,5,.97); backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(201,168,76,.08);
}
.nav-logo img { height:34px; filter:drop-shadow(0 0 8px rgba(201,168,76,.3)); transition:filter .3s; }
.nav-logo:hover img { filter:drop-shadow(0 0 14px rgba(201,168,76,.55)); }

.nav-links { display:flex; gap:32px; align-items:center; }
.nav-links a {
  font-family:'Cinzel',serif; font-size:13px; letter-spacing:.16em;
  color:var(--text-dim); text-transform:uppercase; white-space:nowrap;
  position:relative; padding-bottom:2px; transition:color .3s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-2px; left:0; right:0;
  height:1px; background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-links a:hover { color:var(--gold); }
.nav-links a:hover::after { transform:scaleX(1); }
.nav-links a.active { color:var(--gold); }
.nav-links a.active::after { transform:scaleX(1); }

.nav-cta {
  font-family:'Cinzel',serif; font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  border:1px solid var(--gold); color:var(--gold); padding:11px 26px;
  position:relative; overflow:hidden; transition:color .3s; white-space:nowrap;
}
.nav-cta::before {
  content:''; position:absolute; inset:0; background:var(--gold);
  transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease); z-index:-1;
}
.nav-cta:hover { color:var(--dark); }
.nav-cta:hover::before { transform:scaleX(1); }

/* Hamburger */
.nav-hamburger {
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:40px; height:40px; background:none; border:none; z-index:1100; padding:6px;
}
.nav-hamburger span { display:block; width:22px; height:1.5px; background:var(--gold); transition:all .35s var(--ease); }
.nav-hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* Mobile nav drawer */
.nav-backdrop {
  display:none; position:fixed; inset:0; background:rgba(5,4,3,.75);
  z-index:1040; opacity:0; transition:opacity .4s;
  pointer-events:none;
}
.nav-backdrop.open { opacity:1; pointer-events:auto; }

.nav-mobile-menu {
  display:none; position:fixed; top:0; right:-100%; width:min(320px,90vw); height:100dvh;
  background:var(--dark-warm); border-left:1px solid var(--gold-dim);
  z-index:1050; flex-direction:column; padding:calc(var(--nav-h) + 24px) 36px 48px;
  gap:4px; transition:right .4s var(--ease); overflow-y:auto;
}
.nav-mobile-menu.open { right:0; }
.nav-mobile-menu a {
  font-family:'Cinzel',serif; font-size:16px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--text-dim); padding:16px 0; border-bottom:1px solid rgba(201,168,76,.07);
  transition:color .3s;
}
.nav-mobile-menu a:hover, .nav-mobile-menu a.active { color:var(--gold); }
.nav-mobile-menu .mobile-cta {
  margin-top:28px; font-family:'Cinzel',serif; font-size:13px; letter-spacing:.2em;
  text-transform:uppercase; border:1px solid var(--gold); color:var(--gold);
  padding:15px 24px; text-align:center; transition:all .3s; display:block;
}
.nav-mobile-menu .mobile-cta:hover { background:var(--gold); color:var(--dark); }

/* ── Footer ─────────────────────────────────────────────────── */
footer {
  padding:72px 64px; background:var(--dark);
  border-top:1px solid rgba(201,168,76,.12);
}
.footer-inner {
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:40px;
}
.footer-logo img { height:34px; opacity:.85; filter:drop-shadow(0 0 6px rgba(201,168,76,.2)); }
.footer-links {
  display:flex; gap:36px; justify-content:center;
}
.footer-links a {
  font-family:'Cinzel',serif; font-size:13px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--text-dim); transition:color .3s;
}
.footer-links a:hover { color:var(--gold); }
.footer-right { text-align:right; }
.footer-copy { font-size:14px; color:rgba(191,176,138,.72); font-style:italic; }
.footer-pages { display:flex; gap:22px; justify-content:flex-end; margin-bottom:14px; }
.footer-pages a { font-family:'Cinzel',serif; font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--text-dim); transition:color .3s; }
.footer-pages a:hover { color:var(--gold); }

/* ── Noise Texture ──────────────────────────────────────────── */
body::after {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:9997; opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%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)'/%3E%3C/svg%3E");
}

/* ── Shared Components ──────────────────────────────────────── */
.section-label {
  font-family:'Cinzel',serif; font-size:13px; letter-spacing:.36em; color:var(--gold);
  text-transform:uppercase; display:flex; align-items:center; gap:14px; margin-bottom:18px;
}
.section-label::before { content:''; width:36px; height:1px; background:var(--gold); flex-shrink:0; }
.section-label.ctr { justify-content:center; }
.section-label.ctr::before,
.section-label.ctr::after { content:''; width:36px; height:1px; background:var(--gold); flex-shrink:0; }

.ornament { display:flex; align-items:center; gap:16px; justify-content:center; margin-bottom:48px; }
.ornament::before, .ornament::after { content:''; flex:1; max-width:80px; height:1px; background:rgba(201,168,76,.28); }
.ornament span { color:var(--gold); font-size:15px; }

/* Buttons */
.btn-primary {
  display:inline-block; font-family:'Cinzel',serif; font-size:13px; letter-spacing:.24em;
  text-transform:uppercase; background:var(--gold); color:var(--dark); padding:16px 42px;
  font-weight:700; transition:all .3s var(--ease); white-space:nowrap;
}
.btn-primary:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 8px 30px rgba(201,168,76,.35); }

.btn-secondary {
  display:inline-block; font-family:'Cinzel',serif; font-size:13px; letter-spacing:.24em;
  text-transform:uppercase; border:1px solid rgba(201,168,76,.4); color:var(--text-light);
  padding:16px 42px; transition:all .3s var(--ease); white-space:nowrap;
}
.btn-secondary:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }

.btn-group { display:flex; gap:16px; flex-wrap:wrap; }

/* Corner frame */
.frame-box { position:relative; padding:12px; border:1px solid rgba(201,168,76,.16); }
.frame-box::before { content:''; position:absolute; top:-1px; right:-1px; width:26px; height:26px; border-top:2px solid var(--gold); border-right:2px solid var(--gold); }
.frame-box::after  { content:''; position:absolute; bottom:-1px; left:-1px; width:26px; height:26px; border-bottom:2px solid var(--gold); border-left:2px solid var(--gold); }
.frame-box img { width:100%; }

/* Tag pills */
.tag { font-family:'Cinzel',serif; font-size:11px; letter-spacing:.24em; text-transform:uppercase; border:1px solid rgba(201,168,76,.18); color:var(--text-dim); padding:8px 16px; transition:all .3s; }
.tag:hover { border-color:var(--gold); color:var(--gold); }

/* ── Animations ─────────────────────────────────────────────── */
@keyframes fade-in  { from{opacity:0}              to{opacity:1} }
@keyframes fade-up  { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes fade-dn  { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:translateY(0)} }
@keyframes scroll-a { 0%,100%{opacity:.3} 50%{opacity:1} }
@keyframes pulse-ring { 0%{box-shadow:0 0 0 0 rgba(201,168,76,.3)} 70%{box-shadow:0 0 0 12px rgba(201,168,76,0)} 100%{box-shadow:0 0 0 0 rgba(201,168,76,0)} }

.reveal { opacity:0; transform:translateY(32px); transition:opacity .85s var(--ease), transform .85s var(--ease); }
.reveal.visible { opacity:1; transform:translateY(0); }
.d1{transition-delay:.1s} .d2{transition-delay:.22s} .d3{transition-delay:.34s} .d4{transition-delay:.46s}

/* ── Page Hero (sub-pages) ──────────────────────────────────── */
.page-hero {
  position:relative; height:min(560px,70vh); display:flex;
  align-items:flex-end; overflow:hidden;
}
.page-hero-bg {
  position:absolute; inset:0; background-size:cover; background-position:center 30%;
  transform:scale(1.04); transition:transform 8s ease;
}
.page-hero-bg.loaded { transform:scale(1); }
.page-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(10,8,5,.5) 0%,rgba(10,8,5,.2) 40%,rgba(10,8,5,.85) 80%,rgba(10,8,5,1) 100%);
}
.page-hero-content {
  position:relative; z-index:2; max-width:var(--max-w); width:100%;
  margin:0 auto; padding:0 64px 80px;
}
.page-hero-content .section-label { margin-bottom:14px; }
.page-hero-content h1 {
  font-family:'Cinzel',serif; font-size:clamp(36px,5vw,68px); font-weight:700;
  color:var(--parchment); line-height:1.1;
}
.page-hero-content p {
  font-size:19px; font-style:italic; color:var(--text-dim); margin-top:16px; max-width:560px;
}

/* ── Lightbox ────────────────────────────────────────────────── */
.lightbox {
  display:none; position:fixed; inset:0; background:rgba(5,4,3,.96);
  z-index:2000; align-items:center; justify-content:center; backdrop-filter:blur(8px);
}
.lightbox.open { display:flex; }
.lightbox-img { max-width:90vw; max-height:88vh; object-fit:contain; border:1px solid rgba(201,168,76,.2); }
.lightbox-close { position:absolute; top:24px; right:32px; font-size:22px; color:var(--gold); background:none; border:none; opacity:.8; transition:opacity .2s; }
.lightbox-close:hover { opacity:1; }
.lightbox-arrow { position:absolute; top:50%; transform:translateY(-50%); font-size:36px; color:var(--gold); background:none; border:none; padding:20px; opacity:.6; transition:opacity .2s; }
.lightbox-arrow:hover { opacity:1; }
.lb-prev { left:12px; }
.lb-next { right:12px; }

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width:1100px) {
  :root { --nav-h:60px; }
  body { cursor:auto; font-size:17px; }
  .cursor, .cursor-ring { display:none; }
  #mainNav { padding:0 24px; }
  .nav-links, .nav-cta { display:none; }
  .nav-hamburger { display:flex; }
  .nav-backdrop, .nav-mobile-menu { display:flex; }
  footer { padding:48px 24px; }
  .footer-inner { grid-template-columns:1fr; gap:28px; text-align:center; }
  .footer-links { flex-wrap:wrap; justify-content:center; gap:14px 24px; }
  .footer-right { text-align:center; }
  .footer-pages { justify-content:center; }
  .page-hero { height:min(420px,55vh); }
  .page-hero-content { padding:0 24px 56px; }
  .page-hero-content h1 { font-size:clamp(28px,8vw,44px); }
  .page-hero-content p { font-size:18px; } /* tablet: 18px */
  .section-label { font-size:12px; }
}

@media (max-width:600px) {
  body { font-size:16px; line-height:1.7; }
  /* Hamburger — minimum 44×44 touch target on phones */
  .nav-hamburger { width:44px; height:44px; }
  .btn-group { flex-direction:column; align-items:flex-start; }
  .btn-group.ctr { align-items:center; }
  .btn-primary, .btn-secondary { width:100%; max-width:300px; text-align:center; padding:16px 28px; }
  .section-label { font-size:11px; letter-spacing:.28em; }
  /* Page hero — tighter on phones */
  .page-hero { height:min(360px,54vh); }
  .page-hero-content { padding:0 18px 44px; }
  .page-hero-content h1 { font-size:clamp(24px,9vw,38px); }
  .page-hero-content p { font-size:17px; }
  .nav-mobile-menu a { font-size:16px; }
  footer { padding:48px 20px; }
  .footer-inner { gap:20px; }
  .footer-links { gap:12px 20px; }
  .footer-links a { font-size:12px; }
  .footer-pages a { font-size:12px; }
  .footer-copy { font-size:13px; }
  /* Larger lightbox touch targets */
  .lightbox-arrow { padding:28px 18px; font-size:32px; }
  .lb-prev { left:0; }
  .lb-next { right:0; }
  .lightbox-close { top:16px; right:16px; font-size:24px; padding:10px; }
}
