/* Europe Wedding — Immersive Sales Deck */

:root {
  --avorio: #f2ede3;
  --avorio-chiaro: #f8f5f1;
  --verde: #1d331f;
  --grigio-scuro: #161616;
  --bronzo: #7a5c3a;
  --oro: #bb9a56;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Inter', system-ui, sans-serif;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-cinema: cubic-bezier(0.65, 0, 0.35, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; background: #000; color: var(--avorio); font-family: var(--sans); }

#deck { width: 100vw; height: 100vh; position: relative; cursor: none; }
#deck.show-cursor { cursor: default; }

/* TOPBAR — auto-hide */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 24px 40px;
  background: linear-gradient(180deg, rgba(0,0,0,0.45) 0%, transparent 100%);
  opacity: 0; pointer-events: none;
  transition: opacity 400ms var(--ease);
}
#deck.show-cursor .topbar { opacity: 1; pointer-events: auto; }
.brand { font-family: var(--serif); font-size: 16px; letter-spacing: 0.5em; font-weight: 400; color: var(--avorio); }
.controls { display: flex; align-items: center; gap: 14px; }
.ctrl-btn {
  background: rgba(0,0,0,0.4); backdrop-filter: blur(10px);
  border: 1px solid rgba(187,154,86,0.6); border-radius: 4px;
  padding: 8px 16px; font-family: var(--sans); font-size: 12px;
  color: var(--avorio); cursor: pointer; letter-spacing: 0.15em;
  transition: all 250ms var(--ease);
}
.ctrl-btn:hover { background: var(--oro); color: var(--verde); border-color: var(--oro); }
.slide-counter { font-family: var(--serif); font-size: 14px; color: var(--oro); letter-spacing: 0.1em; opacity: 0.8; }

/* STAGE */
#slide-stage { width: 100vw; height: 100vh; position: relative; overflow: hidden; background: #000; }
.slide {
  position: absolute; inset: 0;
  opacity: 0; pointer-events: none;
  transition: opacity 900ms var(--ease-cinema);
  display: flex; flex-direction: column;
}
.slide.active { opacity: 1; pointer-events: auto; }

/* Ken Burns subtle zoom on active photo backgrounds */
@keyframes kenBurns {
  from { transform: scale(1.0); }
  to { transform: scale(1.08); }
}
.slide.active .hero-img,
.slide.active .stmt-img {
  animation: kenBurns 20s var(--ease-cinema) forwards;
}

/* Fade-in text animation when slide goes active */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.slide.active .hero-text,
.slide.active .stmt-text,
.slide.active .numbers-grid,
.slide.active .cs-copy,
.slide.active .dd-copy,
.slide.active .menu-grid,
.slide.active .steps,
.slide.active .macro-timeline {
  animation: fadeUp 1.2s var(--ease-cinema) both;
}

/* ===== HERO ===== */
.slide.kind-hero { padding: 0; }
.slide.kind-hero .hero-img {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  filter: brightness(0.55);
}
.slide.kind-hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 0%, rgba(0,0,0,0.5) 100%);
  z-index: 1;
}
.slide.kind-hero .hero-text {
  position: relative; z-index: 2; text-align: center;
  margin: auto; padding: 0 60px;
}
.slide.kind-hero .hero-brand {
  font-family: var(--serif); font-size: 96px; font-weight: 300;
  letter-spacing: 0.22em; margin-bottom: 48px; color: var(--avorio);
  text-shadow: 0 2px 40px rgba(0,0,0,0.5);
}
.slide.kind-hero .hero-tagline {
  font-family: var(--serif); font-size: 42px; font-style: italic; font-weight: 300;
  letter-spacing: 0.08em; color: var(--oro);
  text-shadow: 0 2px 30px rgba(0,0,0,0.6);
}
.slide.kind-hero .hero-tagline::before, .slide.kind-hero .hero-tagline::after {
  content: '·'; margin: 0 30px; color: var(--bronzo);
}

/* ===== NUMBERS ===== */
.slide.kind-numbers {
  background: radial-gradient(ellipse at center, #1a1a1a 0%, #0a0a0a 100%);
  align-items: center; justify-content: center;
}
.slide.kind-numbers .numbers-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 100px;
  max-width: 1500px; padding: 0 60px;
}
.slide.kind-numbers .num-cell { text-align: center; }
.slide.kind-numbers .num-val {
  font-family: var(--serif); font-size: 120px; font-weight: 300; color: var(--oro);
  line-height: 1; letter-spacing: -0.03em;
}
.slide.kind-numbers .num-lbl {
  font-family: var(--sans); font-size: 13px; letter-spacing: 0.35em;
  text-transform: uppercase; margin-top: 28px; color: var(--avorio);
  opacity: 0.75;
}

/* ===== STATEMENT ===== */
.slide.kind-statement { padding: 0; }
.slide.kind-statement .stmt-img {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  filter: brightness(0.4) saturate(0.9);
}
.slide.kind-statement::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,0.7) 100%);
  z-index: 1;
}
.slide.kind-statement .stmt-text {
  position: relative; z-index: 2; align-self: center; margin-top: auto;
  margin-bottom: 18vh; text-align: center; width: 100%; padding: 0 60px;
}
.slide.kind-statement h1 {
  font-family: var(--serif); font-size: 104px; font-weight: 300;
  letter-spacing: 0.005em; line-height: 1.05; color: var(--avorio);
  text-shadow: 0 2px 40px rgba(0,0,0,0.5);
}

/* ===== CASE STUDY ===== */
.slide.kind-case_study { background: #0a0a0a; padding: 0; }
.slide.kind-case_study .cs-grid {
  display: grid; grid-template-columns: 6fr 4fr; height: 100%;
}
.slide.kind-case_study .cs-images {
  display: grid; grid-template-columns: 2fr 1fr; grid-template-rows: repeat(3, 1fr);
  gap: 6px; padding: 6px;
}
.slide.kind-case_study .cs-img {
  background-size: cover; background-position: center;
  transition: transform 1.5s var(--ease-cinema);
}
.slide.kind-case_study .cs-img:nth-child(1) { grid-row: 1/3; }
.slide.kind-case_study.active .cs-img:nth-child(1) { transform: scale(1.04); }
.slide.kind-case_study .cs-copy {
  padding: 120px 70px; color: var(--avorio);
  display: flex; flex-direction: column; justify-content: center;
  background: linear-gradient(180deg, #0a0a0a 0%, #161616 100%);
}
.slide.kind-case_study .cs-eyebrow {
  font-size: 11px; letter-spacing: 0.45em; text-transform: uppercase; color: var(--oro);
  margin-bottom: 28px;
}
.slide.kind-case_study .cs-title {
  font-family: var(--serif); font-size: 72px; font-weight: 300; line-height: 1.0;
  margin-bottom: 18px;
}
.slide.kind-case_study .cs-subtitle {
  font-family: var(--serif); font-style: italic; font-size: 24px;
  color: var(--oro); margin-bottom: 40px;
}
.slide.kind-case_study .cs-line { height: 1px; background: var(--oro); width: 80px; margin-bottom: 40px; opacity: 0.6; }
.slide.kind-case_study .cs-body {
  font-size: 17px; line-height: 1.85; color: var(--avorio); opacity: 0.85; max-width: 480px;
}

/* ===== MENU INTERATTIVO ===== */
.slide.kind-menu {
  background: radial-gradient(ellipse at center, #1d331f 0%, #0c1a0d 100%);
  align-items: center; justify-content: center; padding: 100px 60px;
}
.slide.kind-menu .menu-heading {
  text-align: center; margin-bottom: 64px;
}
.slide.kind-menu h2 {
  font-family: var(--serif); font-size: 72px; font-weight: 300; color: var(--avorio);
  letter-spacing: -0.01em; line-height: 1.0;
}
.slide.kind-menu h2 em { color: var(--oro); font-style: italic; }
.slide.kind-menu .menu-sub {
  font-family: var(--serif); font-style: italic; font-size: 20px;
  color: var(--oro); margin-top: 18px; opacity: 0.85;
}
.slide.kind-menu .menu-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px;
  max-width: 1500px; width: 100%;
}
.slide.kind-menu .menu-card {
  position: relative; aspect-ratio: 3/4; cursor: pointer; overflow: hidden;
  transition: transform 600ms var(--ease-cinema), box-shadow 600ms var(--ease-cinema);
  border-radius: 2px;
}
.slide.kind-menu .menu-card::after {
  content: ''; position: absolute; inset: 0; border: 1px solid transparent;
  transition: border-color 400ms var(--ease);
  pointer-events: none;
}
.slide.kind-menu .menu-card:hover { transform: translateY(-12px) scale(1.02); box-shadow: 0 40px 80px -20px rgba(0,0,0,0.6); }
.slide.kind-menu .menu-card:hover::after { border-color: var(--oro); }
.slide.kind-menu .menu-card .mc-img {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  filter: grayscale(40%) brightness(0.55);
  transition: filter 800ms var(--ease-cinema), transform 800ms var(--ease-cinema);
}
.slide.kind-menu .menu-card:hover .mc-img { filter: grayscale(0) brightness(0.85); transform: scale(1.05); }
.slide.kind-menu .menu-card .mc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(12,26,13,0.92) 100%);
}
.slide.kind-menu .menu-card .mc-label {
  position: absolute; bottom: 32px; left: 28px; right: 28px; z-index: 2;
  font-family: var(--serif); font-size: 26px; color: var(--avorio); line-height: 1.15;
}
.slide.kind-menu .menu-card .mc-arrow {
  position: absolute; top: 24px; right: 28px; color: var(--oro);
  font-size: 22px; opacity: 0; transition: opacity 400ms var(--ease), transform 400ms var(--ease);
}
.slide.kind-menu .menu-card:hover .mc-arrow { opacity: 1; transform: translateX(6px); }

/* ===== CASE CHOOSER ===== */
.slide.kind-case_chooser {
  background: radial-gradient(ellipse at center, #1a1a1a 0%, #0a0a0a 100%);
  align-items: center; justify-content: center; padding: 100px 60px;
}
.slide.kind-case_chooser .menu-heading { text-align: center; margin-bottom: 64px; }
.slide.kind-case_chooser h2 {
  font-family: var(--serif); font-size: 56px; font-weight: 300; color: var(--avorio);
  line-height: 1.1; letter-spacing: -0.01em;
}
.slide.kind-case_chooser .menu-sub {
  font-family: var(--serif); font-style: italic; font-size: 22px;
  color: var(--oro); margin-top: 20px;
}
.case-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
  max-width: 1400px; width: 100%;
}
.case-card {
  position: relative; aspect-ratio: 4/5; cursor: pointer; overflow: hidden;
  transition: transform 700ms var(--ease-cinema), box-shadow 700ms var(--ease-cinema);
  border-radius: 2px;
}
.case-card::after {
  content: ''; position: absolute; inset: 0; border: 1px solid transparent;
  transition: border-color 400ms var(--ease); pointer-events: none;
}
.case-card:hover { transform: translateY(-14px); box-shadow: 0 50px 100px -20px rgba(0,0,0,0.8); }
.case-card:hover::after { border-color: var(--oro); }
.case-card .mc-img {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  filter: grayscale(20%) brightness(0.55);
  transition: filter 800ms var(--ease-cinema), transform 800ms var(--ease-cinema);
  background-color: var(--bronzo);
  background-image: linear-gradient(135deg, var(--bronzo) 0%, var(--verde) 100%);
}
.case-card:hover .mc-img { filter: grayscale(0) brightness(0.85); transform: scale(1.04); }
.case-card .mc-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,10,10,0.95) 100%);
}
.case-card .cc-id {
  position: absolute; top: 24px; left: 28px;
  font-family: var(--serif); font-size: 16px; letter-spacing: 0.25em;
  color: var(--oro); z-index: 2;
}
.case-card .cc-label {
  position: absolute; bottom: 36px; left: 32px; right: 32px; z-index: 2;
  font-family: var(--serif); font-size: 22px; color: var(--avorio); line-height: 1.25;
}

/* CONTINUE BUTTON IN 5A */
.menu-continue { margin-top: 56px; text-align: center; }
.continue-btn {
  background: transparent; color: var(--oro);
  border: 1px solid var(--oro); padding: 14px 36px;
  font-family: var(--sans); font-size: 13px; letter-spacing: 0.2em;
  text-transform: uppercase; cursor: pointer;
  transition: all 300ms var(--ease);
}
.continue-btn:hover { background: var(--oro); color: var(--verde); }

/* ===== DEEP DIVE — fullscreen photos + overlay text ===== */
.slide.kind-deep_dive { padding: 0; background: #0a0a0a; }
.slide.kind-deep_dive .dd-grid { display: block; position: relative; height: 100%; width: 100%; }
.slide.kind-deep_dive .dd-photos {
  position: absolute; inset: 0;
  display: grid; gap: 4px; padding: 4px;
}
.slide.kind-deep_dive .dd-photos.cnt-1 { grid-template-columns: 1fr; }
.slide.kind-deep_dive .dd-photos.cnt-2 { grid-template-columns: 1fr 1fr; }
.slide.kind-deep_dive .dd-photos.cnt-3 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.slide.kind-deep_dive .dd-photos.cnt-3 .dd-img:nth-child(1) { grid-column: 1/3; }
.slide.kind-deep_dive .dd-photos.cnt-4 { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; }
.slide.kind-deep_dive .dd-photos.cnt-5 {
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 2fr 1fr;
  grid-template-areas:
    "a b c"
    "a d e";
}
.slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(1) { grid-area: a; }
.slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(2) { grid-area: b; }
.slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(3) { grid-area: c; }
.slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(4) { grid-area: d; }
.slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(5) { grid-area: e; }
.slide.kind-deep_dive .dd-img {
  background-size: cover; background-position: center;
  transition: transform 1.6s var(--ease-cinema);
}
.slide.kind-deep_dive .dd-video {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.slide.kind-deep_dive.active .dd-img:nth-child(1) { transform: scale(1.03); }
.slide.kind-deep_dive .dd-copy {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 3;
  padding: 80px 80px 70px;
  display: flex; flex-direction: column; justify-content: flex-end;
  background: linear-gradient(180deg, transparent 0%, rgba(10,10,10,0.55) 35%, rgba(10,10,10,0.92) 100%);
  color: var(--avorio); max-width: 100%;
}
.slide.kind-deep_dive .dd-copy h1,
.slide.kind-deep_dive .dd-copy .dd-eyebrow,
.slide.kind-deep_dive .dd-copy .dd-line,
.slide.kind-deep_dive .dd-copy .dd-body { max-width: 760px; }
.slide.kind-deep_dive .dd-eyebrow {
  font-size: 11px; letter-spacing: 0.45em; text-transform: uppercase; color: var(--oro);
  margin-bottom: 26px;
}
.slide.kind-deep_dive h1 {
  font-family: var(--serif); font-size: 64px; font-weight: 300; line-height: 1.0;
  margin-bottom: 26px; color: var(--avorio);
}
.slide.kind-deep_dive h1 em { font-style: italic; color: var(--oro); }
.slide.kind-deep_dive .dd-line { height: 1px; background: var(--oro); width: 70px; margin-bottom: 32px; opacity: 0.5; }
.slide.kind-deep_dive .dd-body {
  font-size: 17px; line-height: 1.85; color: var(--avorio); opacity: 0.82; max-width: 500px;
}

/* ===== CLOSING ===== */
.slide.kind-closing {
  background: radial-gradient(ellipse at center, #1d331f 0%, #0c1a0d 100%);
  color: var(--avorio); padding: 120px 60px;
  align-items: center; justify-content: center;
}
.slide.kind-closing h2 {
  font-family: var(--serif); font-size: 72px; font-weight: 300; text-align: center;
  margin-bottom: 100px; color: var(--avorio);
}
.slide.kind-closing h2 em { color: var(--oro); font-style: italic; }
.slide.kind-closing .steps {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px; max-width: 1500px;
  margin: 0 auto 100px; width: 100%;
}
.slide.kind-closing .step { text-align: center; }
.slide.kind-closing .step-n {
  font-family: var(--serif); font-size: 120px; color: var(--oro); font-weight: 300;
  line-height: 1; margin-bottom: 28px;
}
.slide.kind-closing .step-label {
  font-family: var(--serif); font-size: 32px; margin-bottom: 16px; color: var(--avorio);
}
.slide.kind-closing .step-detail { font-size: 14px; opacity: 0.75; line-height: 1.7; max-width: 280px; margin: 0 auto; }
.slide.kind-closing .macro-timeline {
  font-family: var(--serif); font-style: italic; font-size: 24px;
  text-align: center; max-width: 950px; margin: 0 auto;
  line-height: 1.65; color: var(--avorio); opacity: 0.85;
}

/* ===== NAV BUTTONS — auto-hide ===== */
.navbtns {
  position: fixed; bottom: 32px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 14px; z-index: 100;
  opacity: 0; pointer-events: none;
  transition: opacity 400ms var(--ease);
}
#deck.show-cursor .navbtns { opacity: 1; pointer-events: auto; }
.navbtns button {
  width: 52px; height: 52px; border-radius: 50%;
  border: 1px solid rgba(187,154,86,0.5);
  background: rgba(0,0,0,0.4); backdrop-filter: blur(10px);
  color: var(--oro); font-size: 22px; cursor: pointer;
  transition: all 250ms var(--ease);
}
.navbtns button:hover { background: var(--oro); color: var(--verde); transform: translateY(-3px); }
.navbtns #menu-back { width: auto; padding: 0 24px; border-radius: 26px; font-size: 12px; letter-spacing: 0.15em; }
.hidden { display: none !important; }

/* ===== OVERLAY: TOC ===== */
#toc-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(10,10,10,0.92); backdrop-filter: blur(20px);
  display: none; align-items: center; justify-content: center;
  padding: 60px;
}
#toc-overlay.show { display: flex; animation: fadeIn 400ms var(--ease); }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
#toc-overlay .toc-inner { max-width: 1200px; width: 100%; }
#toc-overlay .toc-title {
  font-family: var(--serif); font-size: 14px; letter-spacing: 0.5em;
  text-transform: uppercase; color: var(--oro); text-align: center; margin-bottom: 50px;
}
#toc-overlay .toc-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px;
}
#toc-overlay .toc-col h3 {
  font-family: var(--serif); font-size: 12px; letter-spacing: 0.3em;
  text-transform: uppercase; color: var(--bronzo); margin-bottom: 18px;
  border-bottom: 1px solid rgba(187,154,86,0.2); padding-bottom: 12px;
}
#toc-overlay .toc-item {
  display: flex; align-items: baseline; gap: 14px; padding: 10px 0; cursor: pointer;
  color: var(--avorio); transition: color 200ms var(--ease); font-family: var(--sans);
}
#toc-overlay .toc-item:hover { color: var(--oro); }
#toc-overlay .toc-item.active { color: var(--oro); }
#toc-overlay .toc-item .toc-id {
  font-family: var(--serif); font-size: 13px; color: var(--oro); min-width: 44px; opacity: 0.8;
}
#toc-overlay .toc-item .toc-label { font-size: 15px; }
#toc-overlay .toc-item.visited .toc-label::after { content: ' ✓'; color: var(--oro); opacity: 0.7; }
#toc-overlay .toc-close {
  position: absolute; top: 30px; right: 30px;
  background: transparent; border: 1px solid var(--bronzo); color: var(--oro);
  width: 44px; height: 44px; border-radius: 50%; font-size: 22px; cursor: pointer;
}

/* ===== SPEAKER PANE ===== */
#speaker-pane, #filter-pane {
  position: fixed; right: 0; top: 0; bottom: 0; width: 440px;
  background: rgba(10,10,10,0.95); backdrop-filter: blur(20px); color: var(--avorio);
  border-left: 1px solid var(--bronzo); z-index: 210; overflow-y: auto;
  font-family: var(--sans);
  transform: translateX(100%); transition: transform 500ms var(--ease-cinema);
}
#speaker-pane:not(.hidden), #filter-pane:not(.hidden) { transform: translateX(0); }
.sp-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 28px 30px; border-bottom: 1px solid rgba(187,154,86,0.2);
  font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--oro);
}
.sp-head button {
  background: transparent; border: none; color: var(--avorio); font-size: 28px; cursor: pointer; line-height: 1;
}
.sp-body { padding: 30px; font-size: 15px; line-height: 1.75; color: var(--avorio); opacity: 0.9; }
.sp-body label { display: block; margin-bottom: 16px; cursor: pointer; }
.sp-body input { margin-right: 12px; accent-color: var(--oro); }

/* ===== PHOTO FALLBACK ===== */
.dd-img, .cs-img, .mc-img, .hero-img, .stmt-img {
  background-color: var(--bronzo);
  background-image: linear-gradient(135deg, var(--bronzo) 0%, var(--verde) 100%);
}

/* ===== HINT BAR (subtle) ===== */
.hint {
  position: fixed; bottom: 20px; left: 24px; z-index: 50;
  font-family: var(--sans); font-size: 11px; letter-spacing: 0.2em;
  color: var(--oro); opacity: 0; transition: opacity 400ms var(--ease);
  text-transform: uppercase;
}
#deck.show-cursor .hint { opacity: 0.5; }

/* ===== PRINT ===== */
@media print {
  .topbar, .navbtns, #speaker-pane, #filter-pane, #toc-overlay, .hint { display: none !important; }
  .slide { opacity: 1 !important; position: relative; page-break-after: always; height: 100vh; }
  #deck { cursor: default; }
}

/* ===== TABLET ===== */
@media (max-width: 1024px) {
  .slide { padding: 70px 40px 80px; }
  .slide.kind-hero .hero-brand { font-size: 64px; }
  .slide.kind-hero .hero-tagline { font-size: 32px; }
  .slide.kind-numbers .numbers-grid { gap: 60px; }
  .slide.kind-numbers .num-val { font-size: 88px; }
  .slide.kind-statement h1 { font-size: 72px; }
  .slide.kind-menu .menu-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
  .case-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
  #speaker-pane, #filter-pane { width: 360px; }
}

/* ===== MOBILE ===== */
@media (max-width: 640px) {
  #deck { cursor: default !important; }
  .slide { padding: 70px 20px 80px; }
  .topbar { padding: 14px 16px; opacity: 1 !important; pointer-events: auto !important; background: rgba(0,0,0,0.55); }
  .brand { font-size: 12px; letter-spacing: 0.3em; }
  .controls { gap: 6px; }
  .ctrl-btn { padding: 6px 10px; font-size: 11px; letter-spacing: 0.1em; }
  .slide-counter { font-size: 12px; }
  .navbtns { opacity: 1 !important; pointer-events: auto !important; bottom: 18px; gap: 12px; }
  .navbtns button { width: 44px; height: 44px; font-size: 18px; }
  .navbtns #menu-back { padding: 0 14px; font-size: 11px; }
  .hint { display: none !important; }

  /* HERO */
  .slide.kind-hero .hero-text { padding: 0 24px; }
  .slide.kind-hero .hero-brand { font-size: 36px; margin-bottom: 24px; letter-spacing: 0.15em; }
  .slide.kind-hero .hero-tagline { font-size: 20px; }
  .slide.kind-hero .hero-tagline::before, .slide.kind-hero .hero-tagline::after { margin: 0 14px; }

  /* NUMBERS */
  .slide.kind-numbers .numbers-grid { grid-template-columns: repeat(2, 1fr); gap: 40px 30px; padding: 0 24px; }
  .slide.kind-numbers .num-val { font-size: 58px; }
  .slide.kind-numbers .num-lbl { font-size: 10px; letter-spacing: 0.25em; margin-top: 14px; }

  /* STATEMENT */
  .slide.kind-statement .stmt-text { margin-bottom: 12vh; padding: 0 24px; }
  .slide.kind-statement h1 { font-size: 42px; line-height: 1.1; }

  /* CASE STUDY */
  .slide.kind-case_study .cs-grid { grid-template-columns: 1fr; grid-template-rows: 45% 55%; }
  .slide.kind-case_study .cs-images { grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; gap: 3px; padding: 3px; }
  .slide.kind-case_study .cs-images .cs-img:nth-child(1) { grid-row: 1/3; }
  .slide.kind-case_study .cs-images .cs-img:nth-child(4),
  .slide.kind-case_study .cs-images .cs-img:nth-child(5) { display: none; }
  .slide.kind-case_study .cs-copy { padding: 30px 24px; }
  .slide.kind-case_study .cs-eyebrow { font-size: 9px; letter-spacing: 0.3em; margin-bottom: 14px; }
  .slide.kind-case_study .cs-title { font-size: 36px; margin-bottom: 10px; }
  .slide.kind-case_study .cs-subtitle { font-size: 16px; margin-bottom: 20px; }
  .slide.kind-case_study .cs-line { margin-bottom: 20px; }
  .slide.kind-case_study .cs-body { font-size: 14px; line-height: 1.65; }

  /* CASE CHOOSER */
  .slide.kind-case_chooser { padding: 80px 20px; }
  .slide.kind-case_chooser h2 { font-size: 28px; }
  .slide.kind-case_chooser .menu-sub { font-size: 16px; }
  .slide.kind-case_chooser .menu-heading { margin-bottom: 32px; }
  .case-grid { grid-template-columns: 1fr; gap: 18px; }
  .case-card { aspect-ratio: 16/9; }
  .case-card .cc-id { font-size: 12px; }
  .case-card .cc-label { font-size: 18px; bottom: 20px; left: 20px; right: 20px; }

  /* MENU 5A */
  .slide.kind-menu { padding: 80px 20px; }
  .slide.kind-menu h2 { font-size: 32px; }
  .slide.kind-menu .menu-sub { font-size: 16px; }
  .slide.kind-menu .menu-heading { margin-bottom: 28px; }
  .slide.kind-menu .menu-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .slide.kind-menu .menu-card .mc-label { font-size: 16px; bottom: 16px; left: 16px; right: 16px; }
  .slide.kind-menu .menu-card .mc-arrow { display: none; }

  /* DEEP DIVE */
  .slide.kind-deep_dive .dd-grid { grid-template-columns: 1fr; grid-template-rows: 40% 60%; }
  .slide.kind-deep_dive .dd-photos.cnt-5 { grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; }
  .slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(1) { grid-row: 1/3; }
  .slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(4),
  .slide.kind-deep_dive .dd-photos.cnt-5 .dd-img:nth-child(5) { display: none; }
  .slide.kind-deep_dive .dd-copy { padding: 26px 22px; }
  .slide.kind-deep_dive .dd-eyebrow { font-size: 9px; letter-spacing: 0.3em; margin-bottom: 12px; }
  .slide.kind-deep_dive h1 { font-size: 34px; margin-bottom: 14px; }
  .slide.kind-deep_dive .dd-line { margin-bottom: 16px; }
  .slide.kind-deep_dive .dd-body { font-size: 14px; line-height: 1.65; }

  /* CLOSING */
  .slide.kind-closing { padding: 80px 20px; }
  .slide.kind-closing h2 { font-size: 32px; margin-bottom: 36px; }
  .slide.kind-closing .steps { grid-template-columns: 1fr; gap: 28px; margin-bottom: 36px; }
  .slide.kind-closing .step-n { font-size: 60px; margin-bottom: 10px; }
  .slide.kind-closing .step-label { font-size: 22px; margin-bottom: 8px; }
  .slide.kind-closing .step-detail { font-size: 13px; }
  .slide.kind-closing .macro-timeline { font-size: 16px; line-height: 1.55; }

  /* TOC OVERLAY */
  #toc-overlay { padding: 24px 16px; }
  #toc-overlay .toc-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  #toc-overlay .toc-col h3 { font-size: 10px; }
  #toc-overlay .toc-item .toc-label { font-size: 13px; }
  #toc-overlay .toc-close { top: 16px; right: 16px; width: 38px; height: 38px; }

  /* SPEAKER + FILTER */
  #speaker-pane, #filter-pane { width: 100vw; }
  .sp-body { padding: 22px; font-size: 14px; }
}

/* ===== TOUCH SWIPE HINT ===== */
@media (hover: none) and (pointer: coarse) {
  .case-card:hover { transform: none; box-shadow: none; }
  .slide.kind-menu .menu-card:hover { transform: none; box-shadow: none; }
}
