/* ═══════════════════════════════════════════════════════════
   PRIME COMMUNICATION MEDIA — Shared Legal Pages Stylesheet
   Used by: privacy-policy.html, terms-and-conditions.html,
            copyright-policy.html
   Header / Footer synced with events_page.html design system
═══════════════════════════════════════════════════════════ */

/* ── CSS CUSTOM PROPERTIES ── */
:root {
  --gold:             #c9a84c;
  --gold-light:       #e8c96a;
  --gold-dim:         rgba(201,168,76,0.12);
  --transition-speed: 0.4s;
}

/* Dark theme (default) */
[data-theme="dark"] {
  --ink:            #0a0a0f;
  --ink-mid:        #13131c;
  --ink-soft:       #1e1e2e;
  --bg-primary:     #0a0a0f;
  --bg-secondary:   #13131c;
  --bg-tertiary:    #1e1e2e;
  --text-primary:   #fdfaf4;
  --text-secondary: #f5f0e8;
  --text-muted:     #d4c9b0;
  --border-color:   rgba(201,168,76,0.2);
  --nav-bg:         rgb(201 168 77);
  --footer-bg:      #13131c;
  --input-bg:       rgba(201,168,76,0.04);
  --noise-opacity:  0.3;
  --amber:          rgba(201,138,76,0.1);
  --amber-border:   rgba(201,138,76,0.4);
  --red:            rgba(201,60,50,0.1);
  --red-border:     rgba(201,80,60,0.4);
}

[data-theme="light"] {
  --ink:            #f8f5ef;
  --ink-mid:        #ede8df;
  --ink-soft:       #e4ddd1;
  --bg-primary:     #f8f5ef;
  --bg-secondary:   #ede8df;
  --bg-tertiary:    #e4ddd1;
  --text-primary:   #1a1510;
  --text-secondary: #2a2420;
  --text-muted:     #4a4038;
  --border-color:   rgba(139,90,28,0.25);
  --nav-bg:         rgb(201 168 77);
  --footer-bg:      #ede8df;
  --input-bg:       rgba(139,90,28,0.06);
  --noise-opacity:  0.12;
  --amber:          rgba(201,138,76,0.1);
  --amber-border:   rgba(201,138,76,0.4);
  --red:            rgba(201,60,50,0.1);
  --red-border:     rgba(201,80,60,0.4);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
img  { max-width: 100%; display: block; }
a    { color: var(--gold); text-decoration: none; }

/* ── BODY ── */
body {
  background: var(--bg-primary);
  color: var(--text-secondary);
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  line-height: 1.8;
  min-height: 100vh;
  overflow-x: hidden;
  transition: background var(--transition-speed), color var(--transition-speed);
}

body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 1000;
  opacity: var(--noise-opacity);
  transition: opacity var(--transition-speed);
}

/* ══════════════════════════════════════
   HEADER — events_page.html style
══════════════════════════════════════ */
header#mainHeader {
  top: 0; left: 0; right: 0; z-index: 500;
  background: var(--nav-bg);
  transition: background var(--transition-speed), box-shadow var(--transition-speed);
}
header#mainHeader.scrolled {
  background: var(--nav-bg);
  box-shadow: 0 1px 0 rgba(201,168,76,0.2);
  backdrop-filter: blur(20px);
}
header#mainHeader nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 60px;
  transition: padding var(--transition-speed);
}
header#mainHeader.scrolled nav { padding: 14px 60px; }

.nav-logo { display: flex; align-items: center; text-decoration: none; flex-shrink: 0; }
.nav-logo img { height: 100px; width: auto; object-fit: contain; transition: height var(--transition-speed); }
header#mainHeader.scrolled .nav-logo img { height: 100px; }

.nav-logo-fallback {
  font-family: 'Playfair Display', serif; font-size: 1.15rem;
  font-weight: 900; color: var(--gold); letter-spacing: 0.15em;
}

.nav-links { display: flex; gap: 36px; list-style: none; }
.nav-links a {
  font-family: 'Montserrat', sans-serif; font-size: 0.7rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: #fff; text-decoration: none;
  position: relative; transition: color 0.3s;
}
.nav-links a.active { color: #000; }
.nav-links a::after {
  content: ''; position: absolute;
  bottom: -4px; left: 0; right: 100%;
  height: 1px; background: #000; transition: right 0.35s;
}
.nav-links a:hover::after, .nav-links a.active::after { right: 0; }
.nav-links a:hover { color: #000; }

.nav-right { display: flex; align-items: center; gap: 16px; }

.theme-toggle {
  background: none; border: 1px solid #000;
  width: 44px; height: 24px; border-radius: 12px;
  cursor: pointer; position: relative;
  transition: border-color 0.3s, background 0.3s; flex-shrink: 0;
}
.theme-toggle-knob {
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background: #000; transition: transform 0.3s;
  display: flex; align-items: center; justify-content: center; font-size: 9px;
}
[data-theme="light"] .theme-toggle-knob { transform: translateX(20px); }

.nav-toggle {
  display: none; background: none; border: none;
  color: #000; font-size: 1.4rem; cursor: pointer; padding: 4px;
}

/* Mobile nav */
.mobile-nav-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,0.7); z-index: 700;
  opacity: 0; transition: opacity 0.3s;
}
.mobile-nav-overlay.open { opacity: 1; }

.mobile-nav-drawer {
  position: fixed; top: 0; right: -100%;
  width: min(320px,85vw); height: 100%;
  background: #13131c;
  border-left: 1px solid rgba(201,168,76,0.2);
  z-index: 710; transition: right 0.35s;
  padding: 80px 36px 40px;
  display: flex; flex-direction: column;
}
.mobile-nav-drawer.open { right: 0; }

.mobile-nav-header {
  display: flex; align-items: center; justify-content: space-between;
  position: absolute; top: 20px; left: 20px; right: 20px;
}
.mobile-theme-toggle-wrap { display: flex; align-items: center; gap: 10px; }
.mobile-theme-label {
  font-family: 'Montserrat', sans-serif; font-size: .65rem;
  letter-spacing: .2em; text-transform: uppercase; color: var(--text-muted);
}
.mobile-nav-close { background: none; border: none; color: #d4c9b0; font-size: 1.5rem; cursor: pointer; }

.mobile-nav-links { list-style: none; display: flex; flex-direction: column; gap: 4px; margin-top: 20px; }
.mobile-nav-links a {
  font-family: 'Montserrat', sans-serif; font-size: 0.75rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: #d4c9b0; text-decoration: none;
  padding: 14px 0; border-bottom: 1px solid rgba(201,168,76,0.2);
  display: block; transition: color 0.3s, padding-left 0.3s;
}
.mobile-nav-links a:hover { color: var(--gold); padding-left: 8px; }
.mobile-nav-links a.active { color: var(--gold); }

/* ══════════════════════════════════════
   LEGAL NAV
══════════════════════════════════════ */
.legal-nav {
  border-bottom: 1px solid var(--border-color);
  padding: 0 clamp(1rem,4vw,5rem);
  display: flex; background: var(--bg-secondary);
  overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none;
  position: sticky; top: 0; z-index: 190;
  transition: background var(--transition-speed);
}
.legal-nav::-webkit-scrollbar { display: none; }
.legal-nav a {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(0.56rem,1.4vw,0.62rem);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-muted); text-decoration: none;
  padding: 0.85rem clamp(0.75rem,2vw,1.5rem);
  border-bottom: 2px solid transparent;
  white-space: nowrap; transition: all 0.2s; flex-shrink: 0;
}
.legal-nav a:hover { color: var(--gold); }
.legal-nav a.active { color: var(--gold); border-bottom-color: var(--gold); }

/* ══════════════════════════════════════
   GOLD DIVIDER
══════════════════════════════════════ */
.gold-divider {
  height: 1px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
  opacity: 0.35;
}

/* ══════════════════════════════════════
   HERO
══════════════════════════════════════ */
.hero {
  position: relative;
  padding: clamp(3rem,8vw,9rem) clamp(1rem,4vw,5rem) clamp(2.5rem,5vw,5rem);
  border-bottom: 1px solid var(--border-color);
  overflow: hidden; background: var(--bg-primary);
  transition: background var(--transition-speed);
}
.hero::after {
  position: absolute; right: -2rem; top: 50%;
  transform: translateY(-50%);
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(4rem,12vw,14rem); font-weight: 300;
  letter-spacing: -0.02em; color: rgba(201,168,76,0.04);
  pointer-events: none; white-space: nowrap; line-height: 1;
}

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 0.75rem;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(0.58rem,1.4vw,0.65rem);
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.25rem;
}
.hero-eyebrow::before {
  content: ''; display: block; width: 1.5rem; height: 1px; background: var(--gold);
}

.hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2.2rem,6vw,5.5rem); font-weight: 900;
  line-height: 1.08; color: var(--text-primary);
  letter-spacing: -0.01em; max-width: 700px;
}
.hero h1 em { font-style: italic; color: var(--gold-light); }

.hero-meta { display: flex; gap: clamp(1rem,3vw,2.5rem); margin-top: 2rem; flex-wrap: wrap; }
.hero-meta-item {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(0.58rem,1.4vw,0.65rem);
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-muted);
}
.hero-meta-item strong {
  display: block; color: var(--text-secondary); font-weight: 400;
  letter-spacing: 0.1em; margin-top: 0.2rem;
  font-size: clamp(0.62rem,1.5vw,0.72rem);
}

/* ══════════════════════════════════════
   PAGE LAYOUT
══════════════════════════════════════ */
.page-wrap {
  display: grid; grid-template-columns: 260px 1fr;
  max-width: 1200px; margin: 0 auto;
  padding: 0 clamp(1rem,4vw,5rem); gap: 4rem; align-items: start;
  background: var(--bg-primary); transition: background var(--transition-speed);
}

/* ══════════════════════════════════════
   SIDEBAR
══════════════════════════════════════ */
.sidebar { position: sticky; top: calc(40px + 1rem); padding: 3rem 0; }

.sidebar-title {
  font-family: 'Montserrat', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold); margin-bottom: 1.5rem;
}

.toc { list-style: none; border-left: 1px solid var(--border-color); padding-left: 1.25rem; }
.toc li { margin-bottom: 0.75rem; }
.toc a {
  font-family: 'Montserrat', sans-serif; font-size: 0.68rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text-muted); text-decoration: none; transition: color 0.2s; display: block; line-height: 1.4;
}
.toc a:hover, .toc a.active { color: var(--gold); }

.sidebar-contact, .sidebar-warning, .sidebar-publications {
  margin-top: 2.5rem; padding: 1.5rem; border: 1px solid var(--border-color); background: var(--gold-dim);
}
.sidebar-contact p {
  font-family: 'Montserrat', sans-serif; font-size: 0.68rem;
  letter-spacing: 0.08em; color: var(--text-muted); line-height: 1.7;
}
.sidebar-warning { border-color: var(--amber-border); background: var(--amber); }
.sidebar-warning strong {
  display: block; color: #c98a4c; font-size: 0.6rem;
  letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 0.5rem;
}
.sidebar-warning p {
  font-family: 'Montserrat', sans-serif; font-size: 0.68rem;
  letter-spacing: 0.08em; color: var(--text-muted); line-height: 1.7;
}

.sidebar-pub-title {
  font-family: 'Montserrat', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-bottom: 1rem;
}
.pub-list { list-style: none; }
.pub-list li {
  font-family: 'Montserrat', sans-serif; font-size: 0.7rem; letter-spacing: 0.08em;
  color: var(--text-muted); padding: 0.4rem 0; border-bottom: 1px solid rgba(201,168,76,0.1);
  display: flex; align-items: center; gap: 0.5rem;
}
.pub-list li:last-child { border-bottom: none; }
.pub-list li span { color: var(--gold); font-size: 0.65rem; }

/* Mobile TOC accordion */
.toc-accordion { display: none; margin: 1.5rem 0 0; }
.toc-toggle {
  width: 100%; background: var(--gold-dim); border: 1px solid var(--border-color);
  color: var(--gold); font-family: 'Montserrat', sans-serif; font-size: 0.68rem;
  letter-spacing: 0.2em; text-transform: uppercase; padding: 0.9rem 1.25rem;
  display: flex; align-items: center; justify-content: space-between; cursor: pointer; transition: background 0.2s;
}
.toc-toggle:hover { background: rgba(201,168,76,0.2); }
.toc-toggle-icon { width: 16px; height: 16px; position: relative; flex-shrink: 0; }
.toc-toggle-icon::before, .toc-toggle-icon::after { content: ''; position: absolute; background: var(--gold); transition: transform 0.3s; }
.toc-toggle-icon::before { width: 10px; height: 1px; top: 7px; left: 3px; }
.toc-toggle-icon::after  { width: 1px; height: 10px; top: 3px; left: 7px; }
.toc-toggle.open .toc-toggle-icon::after { transform: rotate(90deg); opacity: 0; }

.toc-panel {
  max-height: 0; overflow: hidden; transition: max-height 0.4s ease;
  border: 1px solid var(--border-color); border-top: none; background: var(--bg-secondary);
}
.toc-panel.open { max-height: 1000px; }
.toc-panel ul { list-style: none; padding: 0.75rem 0; }
.toc-panel ul li a {
  display: block; padding: 0.6rem 1.25rem; font-family: 'Montserrat', sans-serif;
  font-size: 0.66rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-muted); text-decoration: none;
  border-bottom: 1px solid rgba(201,168,76,0.05); transition: color 0.2s, padding-left 0.2s;
}
.toc-panel ul li a:hover { color: var(--gold); padding-left: 1.6rem; }
.toc-panel ul li:last-child a { border-bottom: none; }

/* ══════════════════════════════════════
   MAIN CONTENT
══════════════════════════════════════ */
.content { padding: 3rem 0 5rem; }

.policy-section {
  margin-bottom: 3.5rem; padding-bottom: 3.5rem;
  border-bottom: 1px solid var(--border-color);
  opacity: 0; transform: translateY(24px);
  animation: fadeUp 0.6s ease forwards;
}
.policy-section:last-child { border-bottom: none; }
.policy-section:nth-child(1)  { animation-delay: 0.06s; }
.policy-section:nth-child(2)  { animation-delay: 0.12s; }
.policy-section:nth-child(3)  { animation-delay: 0.18s; }
.policy-section:nth-child(4)  { animation-delay: 0.24s; }
.policy-section:nth-child(5)  { animation-delay: 0.30s; }
.policy-section:nth-child(6)  { animation-delay: 0.36s; }
.policy-section:nth-child(7)  { animation-delay: 0.42s; }
.policy-section:nth-child(8)  { animation-delay: 0.48s; }
.policy-section:nth-child(9)  { animation-delay: 0.54s; }
.policy-section:nth-child(10) { animation-delay: 0.60s; }
.policy-section:nth-child(11) { animation-delay: 0.66s; }
.policy-section:nth-child(12) { animation-delay: 0.72s; }
.policy-section:nth-child(13) { animation-delay: 0.78s; }

@keyframes fadeUp { to { opacity: 1; transform: none; } }

.section-number {
  font-family: 'Montserrat', sans-serif; font-size: 0.6rem;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 0.75rem; display: flex; align-items: center; gap: 0.6rem;
}
.section-number::after { content: ''; flex: 1; max-width: 40px; height: 1px; background: var(--gold); opacity: 0.5; }

.policy-section h2 {
  font-family: 'Playfair Display', serif; font-size: clamp(1.5rem,3.5vw,2.2rem);
  font-weight: 700; color: var(--text-primary); line-height: 1.2;
  margin-bottom: 1.25rem; letter-spacing: -0.01em;
}
.policy-section h2 em { font-style: italic; color: var(--gold-light); }

.policy-section h3 {
  font-family: 'Montserrat', sans-serif; font-size: clamp(0.64rem,1.5vw,0.72rem);
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-light);
  margin: 1.5rem 0 0.75rem; font-weight: 400;
}

.policy-section p {
  font-size: clamp(0.9rem,1.8vw,1rem); line-height: 1.9;
  color: var(--text-muted); margin-bottom: 1rem; letter-spacing: 0.02em; font-weight: 300;
}

.policy-section ul { list-style: none; margin: 1rem 0 1.5rem; }
.policy-section ul li {
  font-size: clamp(0.88rem,1.7vw,0.95rem); line-height: 1.8;
  color: var(--text-muted); padding: 0.5rem 0 0.5rem 1.5rem;
  border-bottom: 1px solid rgba(201,168,76,0.07);
  position: relative; letter-spacing: 0.02em; font-weight: 300;
}
.policy-section ul li::before { content: '✦'; position: absolute; left: 0; color: var(--gold); font-size: 0.5rem; top: 0.75rem; }

/* ══════════════════════════════════════
   CALLOUT BOXES
══════════════════════════════════════ */
.highlight-box { background: var(--gold-dim); border-left: 3px solid var(--gold); padding: 1.25rem 1.5rem; margin: 1.5rem 0; }
.highlight-box p { font-size: clamp(0.88rem,1.7vw,0.95rem); color: var(--text-muted); margin: 0; }

.warning-box { background: var(--amber); border-left: 3px solid #c98a4c; padding: 1.25rem 1.5rem; margin: 1.5rem 0; }
.warning-box p { font-size: clamp(0.88rem,1.7vw,0.95rem); color: var(--text-muted); margin: 0; }

.prohibited-box { background: var(--red); border-left: 3px solid var(--red-border); padding: 1.25rem 1.5rem; margin: 1.5rem 0; }
.prohibited-box p { font-size: clamp(0.88rem,1.7vw,0.95rem); color: var(--text-muted); margin: 0 0 0.5rem; }
.prohibited-box p:last-child { margin: 0; }

/* ══════════════════════════════════════
   INFO GRID
══════════════════════════════════════ */
.info-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,190px),1fr));
  gap: 1px; background: var(--border-color); border: 1px solid var(--border-color); margin: 1.5rem 0;
}
.info-cell { background: var(--bg-secondary); padding: 1.25rem 1.5rem; transition: background var(--transition-speed); }
.info-cell-label { font-family: 'Montserrat', sans-serif; font-size: 0.6rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.4rem; }
.info-cell-value { font-size: clamp(0.85rem,1.7vw,0.92rem); color: var(--text-muted); line-height: 1.6; }

/* ══════════════════════════════════════
   PUBLICATION CARDS
══════════════════════════════════════ */
.pub-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,160px),1fr));
  gap: 1px; background: var(--border-color); border: 1px solid var(--border-color); margin: 1.75rem 0;
}
.pub-card { background: var(--bg-secondary); padding: 1.5rem 1.25rem; transition: background var(--transition-speed); }
.pub-card-icon { font-size: 1.4rem; margin-bottom: 0.75rem; display: block; }
.pub-card-name { font-family: 'Playfair Display', serif; font-size: clamp(0.95rem,2vw,1.1rem); font-weight: 700; color: var(--text-primary); margin-bottom: 0.3rem; line-height: 1.3; }
.pub-card-tag { font-family: 'Montserrat', sans-serif; font-size: clamp(0.54rem,1.2vw,0.6rem); letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); }

/* ══════════════════════════════════════
   CONTACT CTA
══════════════════════════════════════ */
.contact-cta {
  background: linear-gradient(135deg, var(--bg-tertiary), var(--bg-secondary));
  border: 1px solid var(--border-color); padding: clamp(1.5rem,4vw,2.5rem);
  text-align: center; margin-top: 2rem; position: relative; overflow: hidden;
}
.contact-cta::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at center top, rgba(201,168,76,0.06), transparent 70%); }
.contact-cta h3 { font-family: 'Playfair Display', serif; font-size: clamp(1.4rem,3.5vw,1.8rem); font-weight: 700; color: var(--text-primary); margin-bottom: 0.6rem; position: relative; }
.contact-cta > p { font-family: 'Montserrat', sans-serif; font-size: clamp(0.65rem,1.5vw,0.75rem); color: var(--text-muted); margin-bottom: 1.5rem; letter-spacing: 0.05em; position: relative; }
.cta-links { display: flex; justify-content: center; gap: 0.75rem; flex-wrap: wrap; position: relative; }
.cta-link { display: inline-block; font-family: 'Montserrat', sans-serif; font-size: clamp(0.62rem,1.4vw,0.7rem); letter-spacing: 0.18em; text-transform: uppercase; padding: 0.75rem clamp(1rem,3vw,2rem); border: 1px solid var(--gold); color: var(--gold); transition: all 0.25s; white-space: nowrap; }
.cta-link:hover { background: var(--gold); color: var(--ink); }
.cta-link.secondary { border-color: var(--border-color); color: var(--text-muted); }
.cta-link.secondary:hover { border-color: var(--gold); color: var(--gold); background: transparent; }

/* ══════════════════════════════════════
   ENQUIRY FORM SECTION
══════════════════════════════════════ */
.enquiry-section {
  padding: clamp(3rem,6vw,5rem) clamp(1rem,4vw,5rem);
  background: var(--bg-secondary); transition: background var(--transition-speed);
}
.enquiry-inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1.1fr;
  gap: clamp(2rem,5vw,5rem); align-items: start;
}

.enquiry-text .section-label {
  font-family: 'Montserrat', sans-serif; font-size: 0.62rem;
  letter-spacing: 0.35em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 16px; position: relative; padding-left: 24px; display: inline-block;
}
.enquiry-text .section-label::before {
  content: ''; position: absolute; left: 0; top: 50%;
  width: 14px; height: 1px; background: var(--gold); transform: translateY(-50%);
}
.enquiry-text .section-title {
  font-family: 'Playfair Display', serif; font-size: clamp(1.8rem,4vw,3rem);
  font-weight: 900; line-height: 1.05; color: var(--text-primary); margin-bottom: 1rem;
}
.enquiry-text .section-title em { font-style: italic; color: var(--gold); }
.enquiry-text > p { font-size: clamp(0.9rem,1.8vw,1.1rem); line-height: 1.9; color: var(--text-muted); font-weight: 300; margin-bottom: 1rem; }

.enquiry-form-wrap {
  background: var(--bg-tertiary); border: 1px solid var(--border-color);
  padding: 40px 36px; position: relative; transition: background var(--transition-speed);
}
.enquiry-form-wrap::before {
  content: ''; position: absolute; top: -1px; left: 0; width: 60px; height: 3px; background: var(--gold);
}
.enquiry-form-title { font-family: 'Playfair Display', serif; font-size: 1.6rem; font-weight: 700; color: var(--text-primary); margin-bottom: 8px; }
.enquiry-form-title em { font-style: italic; color: var(--gold); }
.enquiry-form-sub { font-family: 'Cormorant Garamond', serif; font-size: 1rem; font-style: italic; color: var(--text-muted); margin-bottom: 28px; }

.form-field { margin-bottom: 20px; }
.form-field label { font-family: 'Montserrat', sans-serif; font-size: 0.58rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-muted); display: block; margin-bottom: 8px; }
.form-field input,
.form-field select,
.form-field textarea {
  width: 100%; background: var(--input-bg); border: 1px solid var(--border-color);
  color: var(--text-secondary); font-family: 'Cormorant Garamond', serif; font-size: 1rem;
  padding: 12px 16px; outline: none; transition: border-color 0.3s;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { border-color: var(--gold); }
.form-field textarea { resize: vertical; min-height: 100px; }
.form-field select option { background: var(--bg-tertiary); color: var(--text-secondary); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.field-error-msg { font-family: 'Montserrat', sans-serif; font-size: 0.55rem; letter-spacing: 0.12em; color: #e74c3c; display: none; margin-top: 4px; }
.field-error-msg.show { display: block; }
.form-field input.field-error,
.form-field select.field-error,
.form-field textarea.field-error { border-color: #e74c3c; }
.form-submit { margin-top: 8px; }

.btn-primary {
  font-family: 'Montserrat', sans-serif; font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  padding: 16px 40px; background: var(--gold); color: var(--ink); border: none; font-weight: 600;
  position: relative; overflow: hidden; transition: color 0.3s; display: inline-block;
  cursor: pointer; width: 100%; text-align: center;
}
.btn-primary::before { content: ''; position: absolute; inset: 0; background: #1a1510; transform: translateX(-101%); transition: transform 0.4s; }
.btn-primary:hover { color: var(--gold); }
.btn-primary:hover::before { transform: translateX(0); }
.btn-primary span { position: relative; z-index: 1; }

.form-success { display: none; margin-top: 20px; padding: 20px 24px; border: 1px solid var(--gold); background: rgba(201,168,76,0.07); font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; font-style: italic; color: var(--text-secondary); }
.form-error-msg { display: none; margin-top: 20px; padding: 20px 24px; border: 1px solid #c0392b; background: rgba(192,57,43,0.06); font-family: 'Cormorant Garamond', serif; font-size: 1rem; color: #c0392b; }

/* ══════════════════════════════════════
   FOOTER — events_page.html style
══════════════════════════════════════ */
footer {
  background: var(--footer-bg); border-top: 1px solid var(--border-color);
  padding: 60px; transition: background var(--transition-speed);
}
.footer-inner { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1.4fr; gap: 48px; margin-bottom: 48px; }
.footer-logo-wrap { margin-bottom: 20px; }
.footer-logo-wrap img { height: 100px; width: auto; object-fit: contain; display: block; filter: drop-shadow(0 0 0 rgba(200, 190, 100, 1)); }
.footer-brand-desc { font-family: 'Cormorant Garamond', serif; font-size: 1rem; line-height: 1.8; color: var(--text-muted); font-weight: 300; }

.footer-col h4 { font-family: 'Montserrat', sans-serif; font-size: .62rem; letter-spacing: .3em; text-transform: uppercase; color: var(--gold); margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid var(--border-color); }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col ul a { font-family: 'Montserrat', sans-serif; font-size: .65rem; letter-spacing: .1em; text-transform: uppercase; color: var(--text-muted); text-decoration: none; transition: color .3s; }
.footer-col ul a:hover { color: var(--gold); }

.footer-contact-item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 16px; }
.footer-contact-icon { width: 32px; height: 32px; flex-shrink: 0; border: 1px solid var(--border-color); display: flex; align-items: center; justify-content: center; font-size: .85rem; transition: border-color .3s; }
.footer-contact-item:hover .footer-contact-icon { border-color: var(--gold); }
.footer-contact-text { display: flex; flex-direction: column; gap: 2px; }
.footer-contact-label { font-family: 'Montserrat', sans-serif; font-size: .55rem; letter-spacing: .25em; text-transform: uppercase; color: var(--gold); }
.footer-contact-value { font-size: .88rem; color: var(--text-muted); font-weight: 300; line-height: 1.5; text-decoration: none; transition: color .3s; }
.footer-contact-value:hover { color: var(--gold); }

.footer-bottom { border-top: 1px solid var(--border-color); padding-top: 28px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.footer-copy, .footer-tagline { font-family: 'Montserrat', sans-serif; font-size: .6rem; letter-spacing: .15em; text-transform: uppercase; color: var(--text-muted); }
.footer-list { font-family: 'Montserrat', sans-serif; font-size: .6rem; letter-spacing: .15em; text-transform: uppercase; display: flex; gap: 10px; flex-wrap: wrap; }
.footer-list a { color: var(--text-muted); text-decoration: none; }
.footer-list a:hover { color: var(--gold); }

/* ══════════════════════════════════════
   BACK TO TOP
══════════════════════════════════════ */
.back-to-top {
  position: fixed; bottom: 32px; right: 32px; width: 48px; height: 48px;
  background: var(--gold); border: none; cursor: pointer; z-index: 400;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; font-weight: 700; color: #0a0a0f;
  opacity: 0; transform: translateY(20px);
  transition: opacity .4s, transform .4s, background .3s;
  box-shadow: 0 4px 24px rgba(201,168,76,.3);
}
.back-to-top.visible { opacity: 1; transform: translateY(0); }
.back-to-top:hover { background: var(--gold-light); }

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 1280px) {
  header#mainHeader nav { padding: 10px 40px; }
  header#mainHeader.scrolled nav { padding: 12px 40px; }
  footer { padding: 56px 40px; }
  .footer-inner { grid-template-columns: 1.6fr 1fr 1fr 1fr 1.4fr; gap: 32px; }
}

@media (max-width: 1024px) {
  .nav-center { display: none !important; }
  .nav-toggle  { display: block !important; }
  header#mainHeader nav { padding: 0 24px; }
  header#mainHeader.scrolled nav { padding: 12px 24px; }
  .nav-logo img { height: 80px; }

  .page-wrap { grid-template-columns: 1fr; gap: 0; padding: 0 clamp(1rem,4vw,2rem); }
  .sidebar { position: static; padding: 2rem 0 0; order: -1; }
  .toc { display: none; } .sidebar-title { display: none; }
  .toc-accordion { display: block; }
  .sidebar-contact, .sidebar-warning, .sidebar-publications { margin-top: 1.5rem; }
  .content { padding: 2rem 0 4rem; }
  .policy-section { margin-bottom: 2.5rem; padding-bottom: 2.5rem; }

  .enquiry-inner { grid-template-columns: 1fr; gap: 2rem; }
  .form-row { grid-template-columns: 1fr; gap: 0; }

  footer { padding: 48px 24px; }
  .footer-inner { grid-template-columns: 1fr 1fr 1fr; gap: 32px; }
  .footer-inner > div:first-child { grid-column: span 3; }
}

@media (max-width: 768px) {
  header#mainHeader nav { padding: 0 20px; }
  .nav-logo img { height: 80px; }
  .hero::after { display: none; }
  .hero-meta { gap: 1rem 2rem; }
  .hero-meta-item { min-width: calc(50% - 0.75rem); }
  .policy-section h2 { font-size: clamp(1.3rem,5.5vw,1.8rem); }
  .enquiry-section { padding: clamp(2rem,4vw,3rem) clamp(1rem,4vw,2rem); }
  .enquiry-form-wrap { padding: 32px 24px; }
  .info-grid { grid-template-columns: 1fr; }
  .pub-grid { grid-template-columns: repeat(auto-fit,minmax(140px,1fr)); }
  .pub-card { padding: 1.25rem 1rem; }
  .contact-cta { padding: 1.5rem 1rem; }
  .cta-links { flex-direction: column; align-items: center; }
  .cta-link { width: 100%; max-width: 320px; text-align: center; }
  .back-to-top { bottom: 20px; right: 20px; width: 42px; height: 42px; }
  footer { padding: 44px 20px; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 28px; }
  .footer-inner > div:first-child { grid-column: span 2; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 8px; }
}

@media (max-width: 640px) {
  .enquiry-form-wrap { padding: 28px 18px; }
  footer { padding: 40px 16px; }
  .footer-inner { grid-template-columns: 1fr; gap: 24px; }
  .footer-inner > div:first-child { grid-column: span 1; }
  .footer-list { flex-direction: column; gap: 6px; }
}

@media (max-width: 480px) {
  header#mainHeader nav { padding: 0 16px; }
  .nav-logo img { height: 70px; }
  .enquiry-form-wrap { padding: 24px 16px; }
  .enquiry-form-title { font-size: 1.35rem; }
  .form-field input, .form-field select, .form-field textarea { font-size: 0.95rem; padding: 11px 14px; }
  .btn-primary { padding: 14px 24px; font-size: 0.65rem; }
  .pub-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 360px) {
  header#mainHeader nav { padding: 0 12px; }
  .nav-logo img { height: 60px; }
  footer { padding: 36px 12px; }
  .pub-grid { grid-template-columns: 1fr; }
  .mobile-nav-drawer { padding: 72px 24px 32px; }
}
