/* ===== DDK Studios — shared stylesheet ===== */

:root {
  --color-bg: #ffffff;
  --color-surface: #f7f8fa;
  --color-ink: #0f1b2d;
  --color-ink-soft: #2a3a55;
  --color-muted: #5a6b85;
  --color-accent: #b08a4a;
  --color-accent-dark: #8e6c33;
  --color-line: #e3e6ec;
  --max-w: 1140px;
  --radius: 6px;
  --shadow-sm: 0 1px 2px rgba(15,27,45,0.06), 0 1px 3px rgba(15,27,45,0.04);
  --shadow-md: 0 8px 24px rgba(15,27,45,0.08);
  --transition: 200ms ease;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--color-ink);
  background: var(--color-bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 {
  font-family: 'Playfair Display', Georgia, serif;
  color: var(--color-ink);
  line-height: 1.2;
  margin: 0 0 0.6em;
  font-weight: 700;
}
h1 { font-size: clamp(2.2rem, 4.5vw, 3.6rem); letter-spacing: -0.01em; }
h2 { font-size: clamp(1.8rem, 3vw, 2.4rem); letter-spacing: -0.005em; }
h3 { font-size: 1.2rem; font-family: 'Inter', sans-serif; font-weight: 600; }
p  { margin: 0 0 1em; color: var(--color-ink-soft); }
a  { color: var(--color-accent-dark); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--color-accent); }
img { max-width: 100%; display: block; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }

.eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
  margin-bottom: 1rem;
}

.btn {
  display: inline-block;
  padding: 0.85rem 1.6rem;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all var(--transition);
  text-decoration: none;
}
.btn-primary { background: var(--color-ink); color: #fff; }
.btn-primary:hover { background: var(--color-ink-soft); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn-ghost { background: transparent; color: var(--color-ink); border-color: var(--color-line); }
.btn-ghost:hover { border-color: var(--color-ink); color: var(--color-ink); }

/* ===== Navigation ===== */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--color-line);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.5rem;
  max-width: var(--max-w);
  margin: 0 auto;
}
.brand { display: flex; align-items: center; line-height: 0; }
.brand svg { display: block; height: 22px; width: auto; max-width: 70vw; }
@media (max-width: 480px) { .brand svg { height: 16px; } }

.nav-links {
  display: flex;
  gap: 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-links a {
  color: var(--color-ink-soft);
  font-weight: 500;
  font-size: 0.95rem;
  position: relative;
  padding: 0.25rem 0;
}
.nav-links a:hover { color: var(--color-ink); }
.nav-links a.active {
  color: var(--color-ink);
}
.nav-links a.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -6px;
  height: 2px;
  background: var(--color-accent);
}
.nav-cta { display: none; }
@media (min-width: 768px) { .nav-cta { display: inline-block; } }

.nav-toggle {
  display: none;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 0.4rem;
}
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-ink);
  margin: 5px 0;
  transition: var(--transition);
}
@media (max-width: 720px) {
  .nav-links { display: none; }
  .nav-toggle { display: block; }
  .nav.open .nav-links {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    padding: 1rem 1.5rem 1.5rem;
    border-bottom: 1px solid var(--color-line);
    gap: 1rem;
  }
}

/* ===== Hero ===== */
.hero {
  position: relative;
  padding: 6rem 0 5rem;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(176,138,74,0.08), transparent 60%),
    linear-gradient(180deg, #fbfbfc 0%, #ffffff 100%);
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 900px) { .hero-grid { grid-template-columns: 1.1fr 0.9fr; } }
.hero h1 { margin-bottom: 1.2rem; }
.hero-lede {
  font-size: 1.15rem;
  color: var(--color-muted);
  max-width: 38em;
  margin-bottom: 2rem;
}
.hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }

.hero-card {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: 10px;
  padding: 2rem;
  box-shadow: var(--shadow-md);
  position: relative;
}
.hero-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: 11px;
  padding: 1px;
  background: linear-gradient(135deg, rgba(176,138,74,0.4), rgba(15,27,45,0.1));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}
.stat {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid var(--color-line);
}
.stat:last-child { border-bottom: 0; padding-bottom: 0; }
.stat:first-child { padding-top: 0; }
.stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 2rem;
  color: var(--color-ink);
  line-height: 1;
}
.stat-label { font-size: 0.9rem; color: var(--color-muted); align-self: center; }

/* ===== Hero image (cinematic image at top of detail pages) ===== */
.hero-image {
  width: 100%;
  line-height: 0;
  overflow: hidden;
  position: relative;
}
.hero-image img,
.hero-image svg {
  width: 100%;
  height: auto;
  display: block;
  max-height: 62vh;
  object-fit: cover;
}
.hero-image::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 80px;
  background: linear-gradient(180deg, transparent 0%, var(--color-bg) 100%);
  pointer-events: none;
}

/* ===== Inner page header (lighter than hero) ===== */
.page-header {
  padding: 5rem 0 3rem;
  background: linear-gradient(180deg, #fbfbfc 0%, #ffffff 100%);
  border-bottom: 1px solid var(--color-line);
  text-align: center;
}
.hero-image + .page-header {
  padding-top: 2.5rem;
  border-top: 0;
}
.page-header h1 {
  font-size: clamp(2rem, 3.6vw, 3rem);
  margin-bottom: 0.6rem;
}
.page-header p {
  color: var(--color-muted);
  font-size: 1.1rem;
  max-width: 38em;
  margin: 0 auto;
}

/* ===== Section common ===== */
section { padding: 5rem 0; }
.section-head {
  max-width: 720px;
  margin: 0 auto 3rem;
  text-align: center;
}
.section-head p { color: var(--color-muted); font-size: 1.05rem; }

/* ===== About ===== */
.about-section { background: var(--color-surface); }
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;
}
@media (min-width: 900px) { .about-grid { grid-template-columns: 1fr 1fr; } }
.values {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-top: 1.5rem;
}
.value {
  background: #fff;
  padding: 1.25rem;
  border-radius: var(--radius);
  border: 1px solid var(--color-line);
}
.value h4 {
  font-family: 'Inter', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  margin: 0 0 0.35rem;
  color: var(--color-ink);
}
.value p { margin: 0; font-size: 0.9rem; color: var(--color-muted); }
.about-single {
  max-width: 720px;
  margin: 0 auto;
}
.about-single h3 {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

/* ===== Services ===== */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.75rem;
}
@media (min-width: 720px) {
  .services-grid {
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
  }
}
.service {
  display: block;
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: 10px;
  padding: 3rem 2.5rem;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  color: inherit;
  min-height: 280px;
}
.service h3 {
  font-size: 1.55rem;
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
}
.service-icon {
  width: 56px;
  height: 56px;
}
.service-icon svg { width: 28px; height: 28px; }
.service:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: rgba(176,138,74,0.4);
  color: inherit;
}
.service-icon {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  background: linear-gradient(135deg, #0f1b2d, #2a3a55);
  color: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
}
.service-icon svg { width: 22px; height: 22px; }
.service h3 { margin-bottom: 0.6rem; color: var(--color-ink); }
.service p { margin: 0 0 1rem; font-size: 0.95rem; color: var(--color-muted); }
.service-link {
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--color-accent-dark);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.service:hover .service-link { color: var(--color-accent); }
.service-link::after {
  content: "→";
  transition: transform var(--transition);
}
.service:hover .service-link::after { transform: translateX(3px); }

/* --- Themed service cards: photo background + darkening overlay --- */
.service--hunting,
.service--events,
.service--podcast,
.service--product {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-color: rgba(255, 255, 255, 0.12);
  color: #f8f4ec;
}
.service--hunting::before,
.service--events::before,
.service--podcast::before,
.service--product::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  transition: opacity var(--transition);
}
.service--hunting > *,
.service--events > *,
.service--podcast > *,
.service--product > * {
  position: relative;
  z-index: 1;
}
.service--hunting:hover::before,
.service--events:hover::before,
.service--podcast:hover::before,
.service--product:hover::before {
  opacity: 0.85;
}

/* Hunting — warm sunset over giraffe + acacia */
.service--hunting { background-image: url(hunting.jpg); }
.service--hunting::before {
  background: linear-gradient(180deg, rgba(26, 18, 8, 0.45) 0%, rgba(10, 5, 2, 0.88) 100%);
}
.service--hunting h3 { color: #f8f4ec; }
.service--hunting p { color: #e0d4be; }
.service--hunting .service-icon {
  background: linear-gradient(135deg, #d97732, #e8a553);
  color: #1a1208;
}
.service--hunting .service-link { color: #f1b870; }
.service--hunting:hover { color: #f8f4ec; }

/* Events — auditorium silhouettes, cool blue */
.service--events { background-image: url(events.jpg); }
.service--events::before {
  background: linear-gradient(180deg, rgba(8, 25, 42, 0.48) 0%, rgba(4, 14, 26, 0.88) 100%);
}
.service--events h3 { color: #f8fcff; }
.service--events p { color: #cfe0ee; }
.service--events .service-icon {
  background: linear-gradient(135deg, #0c2841, #0d9488);
  color: #ffffff;
}
.service--events .service-link { color: #2dd4bf; }
.service--events:hover { color: #f8fcff; }

/* Podcast — studio with mics, warm */
.service--podcast { background-image: url(podcast.jpg); }
.service--podcast::before {
  background: linear-gradient(180deg, rgba(20, 14, 8, 0.5) 0%, rgba(8, 5, 2, 0.88) 100%);
}
.service--podcast h3 { color: #f8f4ec; }
.service--podcast p { color: #d4c8b4; }
.service--podcast .service-icon {
  background: linear-gradient(135deg, #b08a4a, #d4af74);
  color: #1a1208;
}
.service--podcast .service-link { color: #d4af74; }
.service--podcast:hover { color: #f8f4ec; }

/* Product — moody watch on black */
.service--product { background-image: url(product.jpg); }
.service--product::before {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.82) 100%);
}
.service--product h3 { color: #ffffff; }
.service--product p { color: #c8c8c8; }
.service--product .service-icon {
  background: linear-gradient(135deg, #d4b074, #b59455);
  color: #050505;
}
.service--product .service-link { color: #d4b074; }
.service--product:hover { color: #ffffff; }

/* --- Services dropdown in nav --- */
.has-dropdown { position: relative; }
.has-dropdown > a::after {
  content: "";
  display: inline-block;
  margin-left: 0.45em;
  width: 6px;
  height: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
  transition: transform var(--transition);
  vertical-align: middle;
}
.has-dropdown:hover > a::after,
.has-dropdown:focus-within > a::after {
  transform: rotate(-135deg) translateY(0);
}
.dropdown {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: var(--color-bg);
  border: 1px solid var(--color-line);
  border-radius: 10px;
  padding: 0.5rem;
  min-width: 240px;
  list-style: none;
  margin: 0;
  box-shadow: var(--shadow-md);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition), transform var(--transition), visibility var(--transition);
  z-index: 60;
}
.has-dropdown:hover > .dropdown,
.has-dropdown:focus-within > .dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(4px);
}
.dropdown li { list-style: none; }
.dropdown a {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.55rem 0.75rem;
  border-radius: 6px;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--color-ink-soft);
}
.dropdown a:hover {
  background: var(--color-surface);
  color: var(--color-ink);
}
.dropdown a::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 2px;
  flex-shrink: 0;
}
.dropdown a.dot-hunting::before { background: #e8a553; }
.dropdown a.dot-podcast::before { background: #b08a4a; }
.dropdown a.dot-events::before { background: #0d9488; }
.dropdown a.dot-product::before { background: #d4b074; }

@media (max-width: 720px) {
  .nav.open .has-dropdown > a::after { display: none; }
  .nav.open .dropdown {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    background: transparent;
    box-shadow: none;
    border: 0;
    padding: 0.35rem 0 0.35rem 1.25rem;
    min-width: 0;
    margin-top: 0.4rem;
  }
  .nav.open .dropdown a {
    padding: 0.45rem 0;
    color: var(--color-muted);
  }
}

/* ===== Service detail ===== */
.detail-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
@media (min-width: 900px) { .detail-grid { grid-template-columns: 1.2fr 0.8fr; } }
.detail-grid h2 { margin-top: 0; }
.detail-grid h3 { margin-top: 2rem; }
.included {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 10px;
  padding: 1.75rem 1.5rem;
}
.included h4 {
  font-family: 'Inter', sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent-dark);
  margin: 0 0 1rem;
}
.included ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.included li {
  padding: 0.65rem 0 0.65rem 1.5rem;
  border-bottom: 1px solid var(--color-line);
  position: relative;
  font-size: 0.95rem;
  color: var(--color-ink-soft);
}
.included li:last-child { border-bottom: 0; }
.included li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1.05rem;
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: var(--color-accent);
}

.process {
  margin-top: 3.5rem;
  background: var(--color-surface);
  padding: 3.5rem 0;
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.process-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
  margin-top: 2rem;
}
.process-step {
  background: #fff;
  border: 1px solid var(--color-line);
  border-radius: var(--radius);
  padding: 1.5rem 1.5rem 1.5rem 1.5rem;
}
.process-num {
  font-family: 'Playfair Display', serif;
  font-size: 1.6rem;
  color: var(--color-accent);
  display: block;
  margin-bottom: 0.3rem;
}
.process-step h4 {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  margin: 0 0 0.35rem;
  font-weight: 600;
}
.process-step p { margin: 0; font-size: 0.92rem; color: var(--color-muted); }

/* ===== CTA strip ===== */
.cta {
  background: var(--color-ink);
  color: #e6ebf3;
  padding: 4.5rem 0;
  text-align: center;
}
.cta h2 { color: #fff; }
.cta p { color: #b9c3d4; max-width: 38em; margin: 0 auto 2rem; }
.cta .btn-primary { background: var(--color-accent); color: var(--color-ink); }
.cta .btn-primary:hover { background: #c79c5a; color: var(--color-ink); }

/* ===== Contact ===== */
.contact-section {
  background: var(--color-ink);
  color: #e6ebf3;
  padding: 5rem 0;
}
.contact-section h2, .contact-section .eyebrow { color: #fff; }
.contact-section .eyebrow { color: var(--color-accent); }
.contact-section p { color: #b9c3d4; }

.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
@media (min-width: 900px) { .contact-grid { grid-template-columns: 0.9fr 1.1fr; } }
.contact-info dl { margin: 1.5rem 0 0; }
.contact-info dt {
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-top: 1.25rem;
  margin-bottom: 0.25rem;
}
.contact-info dd { margin: 0; color: #e6ebf3; }
.contact-info dd a { color: #e6ebf3; }
.contact-info dd a:hover { color: var(--color-accent); }

form {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 2rem;
  border-radius: 10px;
}
.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
@media (min-width: 600px) {
  .form-row.two { grid-template-columns: 1fr 1fr; }
}
label {
  display: block;
  font-size: 0.85rem;
  font-weight: 500;
  color: #b9c3d4;
  margin-bottom: 0.4rem;
}
input, textarea, select {
  width: 100%;
  padding: 0.75rem 0.9rem;
  background: rgba(255,255,255,0.06);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 0.95rem;
  transition: border-color var(--transition), background var(--transition);
}
input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--color-accent);
  background: rgba(255,255,255,0.09);
}
textarea { resize: vertical; min-height: 130px; }
.form-submit {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-top: 0.5rem;
}
.form-submit .btn-primary { background: var(--color-accent); color: var(--color-ink); }
.form-submit .btn-primary:hover { background: #c79c5a; color: var(--color-ink); }
.form-status { font-size: 0.9rem; color: var(--color-accent); min-height: 1.2em; }
.form-status.error { color: #ff9a9a; }

/* ===== Footer ===== */
footer {
  background: #0a1422;
  color: #8a97ad;
  padding: 2rem 0;
  font-size: 0.9rem;
  text-align: center;
}
footer a { color: #b9c3d4; }

/* ===== Reveal on scroll ===== */
.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 600ms ease, transform 600ms ease;
}
.reveal.visible { opacity: 1; transform: none; }


/* ============================================================ */
/* ===== PAGE-SPECIFIC THEMES (override CSS variables) ========= */
/* ============================================================ */

/* --- Hunting Film: dark, sunset, golden hour --- */
body.theme-hunting {
  --color-bg: #1a1208;
  --color-surface: #251a0e;
  --color-ink: #f5e6d0;
  --color-ink-soft: #d4c4a8;
  --color-muted: #a89880;
  --color-accent: #e8a553;
  --color-accent-dark: #c98538;
  --color-line: rgba(245, 230, 208, 0.14);
}
body.theme-hunting .nav {
  background: rgba(26, 18, 8, 0.92);
  border-bottom-color: rgba(245, 230, 208, 0.1);
}
body.theme-hunting .nav-toggle span { background: var(--color-ink); }
body.theme-hunting .brand svg text { fill: #f5e6d0 !important; }
body.theme-hunting .brand svg line { stroke: #e8a553 !important; }
body.theme-hunting .brand svg text + text { fill: #e8a553 !important; }
body.theme-hunting .nav-links a { color: var(--color-ink-soft); }
body.theme-hunting .nav-links a:hover,
body.theme-hunting .nav-links a.active { color: var(--color-ink); }
body.theme-hunting .hero,
body.theme-hunting .page-header {
  background:
    radial-gradient(1200px 600px at 75% 25%, rgba(232, 165, 83, 0.25), transparent 60%),
    radial-gradient(900px 500px at 10% 90%, rgba(217, 119, 50, 0.18), transparent 55%),
    linear-gradient(180deg, #2a1c10 0%, #1a1208 100%);
  border-bottom-color: rgba(245, 230, 208, 0.1);
}
body.theme-hunting .hero-card {
  background: rgba(245, 230, 208, 0.05);
  border-color: rgba(245, 230, 208, 0.16);
}
body.theme-hunting .stat { border-bottom-color: rgba(245, 230, 208, 0.12); }
body.theme-hunting .stat-num { color: var(--color-ink); }
body.theme-hunting .included {
  background: rgba(245, 230, 208, 0.05);
  border-color: rgba(245, 230, 208, 0.14);
}
body.theme-hunting .included li { border-bottom-color: rgba(245, 230, 208, 0.1); color: var(--color-ink-soft); }
body.theme-hunting .process {
  background: #221610;
  border-top-color: rgba(245, 230, 208, 0.08);
  border-bottom-color: rgba(245, 230, 208, 0.08);
}
body.theme-hunting .process-step {
  background: rgba(245, 230, 208, 0.05);
  border-color: rgba(245, 230, 208, 0.14);
}
body.theme-hunting .cta { background: #120a04; }
body.theme-hunting .cta h2 { color: var(--color-ink); }
body.theme-hunting .cta p { color: var(--color-ink-soft); }
body.theme-hunting footer { background: #0d0703; color: #a89880; }
body.theme-hunting .btn-primary { background: var(--color-accent); color: #1a1208; }
body.theme-hunting .btn-primary:hover { background: #f0b870; color: #1a1208; }
body.theme-hunting .btn-ghost { color: var(--color-ink); border-color: rgba(245, 230, 208, 0.2); }
body.theme-hunting .btn-ghost:hover { border-color: var(--color-accent); color: var(--color-accent); }


/* --- Events / Conventions / Conferences: vibrant blue --- */
body.theme-events {
  --color-bg: #f4f8fc;
  --color-surface: #e6eff8;
  --color-ink: #0c2841;
  --color-ink-soft: #1e4366;
  --color-muted: #4e6c8a;
  --color-accent: #0d9488;
  --color-accent-dark: #0a766a;
  --color-line: #cfdfee;
}
body.theme-events .hero,
body.theme-events .page-header {
  background:
    radial-gradient(1000px 600px at 80% 0%, rgba(13, 148, 136, 0.18), transparent 60%),
    radial-gradient(900px 500px at 0% 100%, rgba(59, 130, 246, 0.15), transparent 55%),
    linear-gradient(180deg, #e8f1f9 0%, #f4f8fc 100%);
  border-bottom-color: var(--color-line);
}
body.theme-events .cta {
  background: linear-gradient(135deg, #0c2841 0%, #0a766a 100%);
}
body.theme-events footer { background: #08192a; color: #b9d1e6; }
body.theme-events .nav { background: rgba(244, 248, 252, 0.92); }
body.theme-events .service:hover { border-color: rgba(13, 148, 136, 0.5); }
body.theme-events .service-icon { background: linear-gradient(135deg, #0c2841, #0d9488); }


/* --- Product Photography & Advertisements: black, moody, contrasty --- */
body.theme-product {
  --color-bg: #050505;
  --color-surface: #0e0e0e;
  --color-ink: #ffffff;
  --color-ink-soft: #d4d4d4;
  --color-muted: #888888;
  --color-accent: #d4b074;
  --color-accent-dark: #b59455;
  --color-line: rgba(255, 255, 255, 0.08);
}
body.theme-product .nav {
  background: rgba(5, 5, 5, 0.9);
  border-bottom-color: rgba(255, 255, 255, 0.06);
}
body.theme-product .nav-toggle span { background: #ffffff; }
body.theme-product .brand svg text { fill: #ffffff !important; }
body.theme-product .brand svg line { stroke: #d4b074 !important; }
body.theme-product .brand svg text + text { fill: #d4b074 !important; }
body.theme-product .nav-links a { color: #b8b8b8; }
body.theme-product .nav-links a:hover,
body.theme-product .nav-links a.active { color: #ffffff; }
body.theme-product .hero,
body.theme-product .page-header {
  background:
    radial-gradient(900px 500px at 85% 25%, rgba(212, 176, 116, 0.08), transparent 60%),
    linear-gradient(180deg, #0a0a0a 0%, #050505 100%);
  border-bottom-color: rgba(255, 255, 255, 0.06);
}
body.theme-product .hero h1,
body.theme-product .page-header h1 { color: #ffffff; }
body.theme-product .included {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.08);
}
body.theme-product .included li { border-bottom-color: rgba(255, 255, 255, 0.06); color: var(--color-ink-soft); }
body.theme-product .process {
  background: #0a0a0a;
  border-top-color: rgba(255, 255, 255, 0.06);
  border-bottom-color: rgba(255, 255, 255, 0.06);
}
body.theme-product .process-step {
  background: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.08);
}
body.theme-product .cta { background: #000000; }
body.theme-product .cta h2 { color: #ffffff; }
body.theme-product .cta p { color: #b0b0b0; }
body.theme-product footer { background: #000000; color: #888888; }
body.theme-product .btn-primary { background: #ffffff; color: #050505; }
body.theme-product .btn-primary:hover { background: #d4b074; color: #050505; }
body.theme-product .btn-ghost { color: #ffffff; border-color: rgba(255, 255, 255, 0.18); }
body.theme-product .btn-ghost:hover { border-color: #ffffff; color: #ffffff; }
