@font-face { font-family: 'Oswald'; font-style: normal; font-weight: 400; font-display: block; src: url('/fonts/oswald-400.woff2') format('woff2'); }
@font-face { font-family: 'Oswald'; font-style: normal; font-weight: 500; font-display: block; src: url('/fonts/oswald-500.woff2') format('woff2'); }
@font-face { font-family: 'Oswald'; font-style: normal; font-weight: 600; font-display: block; src: url('/fonts/oswald-600.woff2') format('woff2'); }
@font-face { font-family: 'Oswald'; font-style: normal; font-weight: 700; font-display: block; src: url('/fonts/oswald-700.woff2') format('woff2'); }
@font-face { font-family: 'Hanken Grotesk'; font-style: normal; font-weight: 300; font-display: block; src: url('/fonts/hanken-300.woff2') format('woff2'); }
@font-face { font-family: 'Hanken Grotesk'; font-style: normal; font-weight: 400; font-display: block; src: url('/fonts/hanken-400.woff2') format('woff2'); }
@font-face { font-family: 'Hanken Grotesk'; font-style: normal; font-weight: 500; font-display: block; src: url('/fonts/hanken-500.woff2') format('woff2'); }
@font-face { font-family: 'Hanken Grotesk'; font-style: normal; font-weight: 600; font-display: block; src: url('/fonts/hanken-600.woff2') format('woff2'); }
@font-face { font-family: 'Hanken Grotesk'; font-style: normal; font-weight: 700; font-display: block; src: url('/fonts/hanken-700.woff2') format('woff2'); }

:root {
  --red: #E8473F;
  --red-dark: #C73B34;
  --red-pale: #FDF0EF;
  --cream: #F5F1E6;
  --cream-dark: #EDE8D8;
  --white: #FFFFFF;
  --ink: #18120F;
  --ink-mid: #4A3B34;
  --ink-muted: #8A7570;
  --line: #ECDDD8;
  --line-input: #E4D9D4;
  --placeholder: #C0AEAA;
  --accent: var(--red);
  --display: 'Oswald', 'Arial Narrow', sans-serif;
  --sans: 'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --r-lg: 20px;
  --r-md: 12px;
  --r-sm: 10px;
  --r-pill: 999px;
  --shadow-soft: 0 10px 30px rgba(24, 18, 15, 0.06);
  --track-eyebrow: 0.16em;
  --track-label: 0.08em;
  --fs-h1: 36px;
  --fs-h2: 17px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --dur-fast: 200ms;
  --dur-med: 450ms;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--cream); color: var(--ink); font-family: var(--sans); }
a { color: inherit; }
img { max-width: 100%; }
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 40px; }

/* LAYOUT UTILITIES */
.row { display: flex; gap: 14px; flex-wrap: wrap; }
.row-center { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.row-between { display: flex; align-items: baseline; justify-content: space-between; flex-wrap: wrap; gap: 16px; }
.row-align-center { display: flex; align-items: center; flex-wrap: wrap; }
.stack { display: flex; flex-direction: column; }
.gap-8 { gap: 8px; }
.gap-10 { gap: 10px; }
.gap-14 { gap: 14px; }
.gap-18 { gap: 18px; }
.gap-20 { gap: 20px; }
.text-center { text-align: center; }
.text-left { text-align: left; }
.grid { display: grid; gap: 20px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-span-2 { grid-column: span 2; }
.mt-8 { margin-top: 8px; }
.mt-10 { margin-top: 10px; }
.mt-12 { margin-top: 12px; }
.mt-14 { margin-top: 14px; }
.mt-16 { margin-top: 16px; }
.mt-18 { margin-top: 18px; }
.mt-20 { margin-top: 20px; }
.mt-24 { margin-top: 24px; }
.mt-28 { margin-top: 28px; }
.mt-32 { margin-top: 32px; }
.mt-0 { margin-top: 0; }
.full-w { width: 100%; }
.center-btn { justify-content: center; }
.no-underline { text-decoration: none; }
.inline-block { display: inline-block; }

@media (max-width: 900px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-span-2 { grid-column: span 1; }
}
@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .wrap, .section { padding-left: 24px; padding-right: 24px; }
}

.eyebrow { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; color: var(--red); display: inline-flex; align-items: center; gap: 9px; }
.eyebrow::before { content: ''; width: 16px; height: 1.5px; background: var(--red); display: inline-block; }
.h1 { font-family: var(--display); font-weight: 700; text-transform: uppercase; line-height: 0.96; letter-spacing: 0.01em; color: var(--ink); margin: 18px 0 0; font-size: clamp(34px, 5.2vw, 64px); }
.h2 { font-family: var(--display); font-weight: 700; text-transform: uppercase; line-height: 1.02; color: var(--ink); margin: 14px 0 0; font-size: clamp(26px, 3.4vw, 42px); }
.h3 { font-family: var(--display); font-weight: 700; text-transform: uppercase; color: var(--ink); margin: 0; font-size: clamp(18px, 1.8vw, 22px); }
.em { color: var(--red); }
.body-light { font-size: 18px; font-weight: 300; line-height: 1.7; color: var(--ink-mid); margin: 26px 0 0; max-width: 62ch; }
.small-muted { font-size: 13px; color: var(--ink-muted); }

/* SCROLL REVEAL */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity var(--dur-med) var(--ease), transform var(--dur-med) var(--ease); }
.reveal.is-visible { opacity: 1; transform: translateY(0); }
.reveal-stagger > * { opacity: 0; transform: translateY(24px); transition: opacity var(--dur-med) var(--ease), transform var(--dur-med) var(--ease); }
.reveal-stagger.is-visible > * { opacity: 1; transform: translateY(0); }
.reveal-stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.is-visible > *:nth-child(2) { transition-delay: 80ms; }
.reveal-stagger.is-visible > *:nth-child(3) { transition-delay: 160ms; }
.reveal-stagger.is-visible > *:nth-child(4) { transition-delay: 240ms; }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal-stagger > * { opacity: 1; transform: none; transition: none; }
}

.btn { display: inline-flex; align-items: center; gap: 9px; background: var(--red); color: #fff; font-size: 16px; font-weight: 500; text-decoration: none; padding: 15px 26px; border-radius: 10px; border: none; cursor: pointer; white-space: nowrap; transition: background .2s, transform .15s; font-family: var(--sans); }
.btn:hover { background: var(--red-dark); transform: translateY(-1px); }
.btn-outline { display: inline-flex; align-items: center; gap: 9px; background: transparent; color: var(--ink); font-size: 16px; font-weight: 500; text-decoration: none; padding: 14px 24px; border-radius: 10px; border: 1.5px solid var(--line-input); cursor: pointer; white-space: nowrap; font-family: var(--sans); }
.btn-outline:hover { border-color: var(--red); color: var(--red); }
.btn-white { display: inline-flex; align-items: center; gap: 9px; background: #fff; color: var(--ink); font-size: 16px; font-weight: 500; text-decoration: none; padding: 16px 26px; border-radius: 10px; white-space: nowrap; }

.card { background: #fff; border: 1px solid var(--line); border-radius: 20px; }
.pill { border-radius: 100px; padding: 9px 20px; font-size: 14px; font-weight: 500; cursor: pointer; border: 1.5px solid var(--line-input); background: transparent; color: var(--ink-mid); font-family: var(--sans); }
.pill.active { background: var(--red); color: #fff; border-color: var(--red); }

input, select, textarea {
  box-sizing: border-box; padding: 13px 16px; border: 1.5px solid var(--line-input); border-radius: 10px;
  font-family: var(--sans); font-size: 15px; background: var(--cream); color: var(--ink); outline: none; width: 100%;
}
input:focus, select:focus, textarea:focus { border-color: var(--red); background: #fff; }
label.field-label { font-size: 11px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-muted); display: block; margin-bottom: 7px; }

/* NAV */
.site-header { position: sticky; top: 0; z-index: 50; background: rgba(245,241,230,0.88); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.site-nav { max-width: 1200px; margin: 0 auto; padding: 0 40px; height: 72px; display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.site-nav .logo { height: 34px; }
.site-logo { text-decoration: none; display: inline-flex; align-items: center; }
.site-logo-img { height: 30px; width: auto; display: block; }
.nav-links { display: flex; align-items: center; gap: 34px; }
.nav-links a { text-decoration: none; font-size: 15px; font-weight: 500; letter-spacing: 0.01em; color: var(--ink-mid); transition: color .2s; }
.nav-links a:hover, .nav-links a.active { color: var(--red); }

@media (max-width: 760px) {
  .site-nav { padding: 0 20px; gap: 16px; }
  .nav-links { display: none; }
  .site-nav .btn { padding: 11px 16px; font-size: 14px; }
}

/* FOOTER */
.site-footer { background: #18120F; color: #fff; }
.site-footer .footer-wrap { padding: 64px 40px 0; }
.site-footer .top { display: flex; justify-content: space-between; align-items: flex-end; gap: 48px; flex-wrap: wrap; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.site-footer a { color: rgba(255,255,255,0.78); text-decoration: none; transition: color .2s; }
.site-footer a:hover { color: var(--red); }
.site-footer .col-label { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; color: rgba(255,255,255,0.4); margin-bottom: 4px; }
.site-footer .footer-logo-img { height: 56px; width: auto; display: block; margin-bottom: 22px; }
.site-footer .tagline { max-width: 420px; font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 32px; line-height: 1.18; color: var(--cream); margin-top: 0; }
.site-footer .tagline .em { color: var(--red); }
.site-footer .cols { display: flex; gap: 56px; }
.site-footer .col-links { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; font-size: 14px; }
.site-footer .bottom { display: flex; justify-content: space-between; align-items: center; padding: 22px 0; font-size: 13px; color: rgba(255,255,255,0.45); flex-wrap: wrap; gap: 10px; }
.site-footer .admin-link { color: rgba(255,255,255,0.3); font-size: 12px; }
.wa-float { position: fixed; right: 26px; bottom: 26px; z-index: 90; display: inline-flex; align-items: center; gap: 11px; background: var(--red); color: #fff; font-size: 15px; font-weight: 600; text-decoration: none; padding: 14px 20px 14px 16px; border-radius: 100px; box-shadow: 0 10px 28px rgba(232,71,63,0.38); transition: transform .15s ease, box-shadow .15s ease; }
.wa-float .wa-icon { flex-shrink: 0; }
.wa-float:hover { transform: translateY(-2px); box-shadow: 0 14px 32px rgba(232,71,63,0.45); }

@media (max-width: 640px) {
  .site-footer .footer-wrap { padding: 48px 24px 0; }
  .site-footer .cols { gap: 32px; }
  .site-footer .bottom { justify-content: flex-start; }
  .wa-float span.wa-label { display: none; }
  .wa-float { padding: 14px; }
}

.section { max-width: 1200px; margin: 0 auto; padding: 84px 40px; }
.section-tight { padding-top: 0; }
.about-quote { font-style: italic; color: var(--red); border-left: 3px solid var(--red); padding-left: 20px; font-size: 20px; text-transform: none; max-width: 680px; }
.section-narrow { max-width: 1080px; margin: 0 auto; padding: 60px 40px; }
.band-red { background: var(--red); color: #fff; }
.band-red .eyebrow { color: rgba(255,255,255,0.85); }
.band-red .eyebrow::before { background: rgba(255,255,255,0.85); }
.band-red .cat { color: rgba(255,255,255,0.85); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.16em; }
.band-red .h1, .band-red .h2, .band-red .h3 { color: #fff; }
.band-red .body-light { color: rgba(255,255,255,0.85); }
.band-red .small-muted { color: rgba(255,255,255,0.75); }
.band-red .em { color: #fff; text-decoration: underline; text-decoration-color: rgba(255,255,255,0.5); text-decoration-thickness: 2px; text-underline-offset: 3px; }
.band-dark { background: #18120F; color: #fff; }
.band-cream-dark { background: #EFEADC; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }

/* HERO */
.hero { padding: 64px 40px 40px; display: flex; gap: 48px; align-items: center; flex-wrap: wrap; }
.hero-copy { flex: 1; min-width: 320px; }
.hero-visual { flex: 1; min-width: 320px; position: relative; }
.hero-title { font-size: clamp(38px, 6.4vw, 80px); }
.hero-visual { position: relative; }
.hero-visual::before { content: ''; position: absolute; top: -40px; right: -40px; width: 260px; height: 260px; background: radial-gradient(circle, rgba(232,71,63,0.16), transparent 70%); z-index: 0; pointer-events: none; }
.hero-media { height: 380px; background: var(--cream-dark); display: flex; align-items: center; justify-content: center; color: var(--placeholder); font-family: var(--display); text-transform: uppercase; position: relative; z-index: 1; box-shadow: var(--shadow-soft); }
.hero-price-card { position: absolute; bottom: -20px; left: 24px; padding: 14px 22px; box-shadow: 0 16px 36px rgba(26,20,16,0.14); z-index: 2; }
.hero-price-card .h3 { font-size: 22px; }

/* CATEGORY PILL STRIP */
.pill-strip-wrap { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); overflow: hidden; }
.pill-strip { display: flex; gap: 14px; padding: 18px 0; width: max-content; }
.pill-strip-track { display: flex; gap: 14px; flex-shrink: 0; animation: pill-scroll 28s linear infinite; }
.pill-static { display: inline-flex; align-items: center; gap: 9px; border-radius: 100px; padding: 11px 22px; font-size: 14px; font-weight: 500; white-space: nowrap; border: 1.5px solid var(--line-input); color: var(--ink-mid); }
.pill-static .dot { width: 9px; height: 9px; background: url('/img/planyetredplus.png') center/contain no-repeat; display: inline-block; }

@keyframes pill-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(calc(-100% - 14px)); }
}

@media (prefers-reduced-motion: reduce) {
  .pill-strip-track { animation: none; }
}

@media (max-width: 760px) {
  .pill-strip { padding: 16px 0; }
}

/* STATS ROW */
.stats-row { padding: 72px 40px; }
.stat-item { text-align: center; }
.stat-num { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 44px; line-height: 1; color: var(--ink); }
.stat-num .star { color: var(--red); font-size: 28px; margin-left: 2px; }
.stat-label { font-size: 15px; color: var(--ink-muted); margin-top: 8px; }

@media (max-width: 760px) {
  .stats-row { padding: 48px 24px; }
}

/* STAT / STEP BLOCKS */
.steps-band { padding: 72px 40px; }
.steps-heading { text-align: center; margin-bottom: 48px; }
.steps-heading .eyebrow { display: block; text-align: center; }
.steps-heading .h2 { font-size: clamp(28px, 4.2vw, 46px); }
.step-num { font-family: var(--display); font-weight: 700; color: var(--red); text-transform: uppercase; font-size: 32px; line-height: 1; }
.stat-block { text-align: left; display: flex; flex-direction: column; align-items: flex-start; gap: 14px; background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 32px; }
.stat-block .h2, .stat-block .h3 { color: var(--red); }
.stat-block .step-label { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 20px; letter-spacing: 0.01em; color: var(--ink); }
.stat-block .step-desc { font-size: 15px; color: var(--ink-muted); line-height: 1.6; max-width: 260px; }
.steps-band .grid-3 { row-gap: 24px; }

@media (max-width: 760px) {
  .steps-band { padding: 48px 24px; }
}

/* CTA BAND */
.cta-row { display: flex; align-items: center; justify-content: space-between; gap: 40px; flex-wrap: wrap; }
.cta-row .eyebrow { color: rgba(255,255,255,0.85); }
.cta-row .h2 { color: #fff; font-size: clamp(32px, 5.2vw, 60px); margin-top: 10px; max-width: 640px; }
.cta-row .body-light { color: rgba(255,255,255,0.85); margin-top: 18px; max-width: 460px; }
.cta-copy { flex: 1; min-width: 280px; }
.cta-buttons { display: flex; flex-direction: column; gap: 14px; min-width: 220px; }
.cta-buttons .btn-outline { border-color: rgba(255,255,255,0.4); color: #fff; }

@media (max-width: 760px) {
  .cta-row { align-items: flex-start; }
  .cta-buttons { width: 100%; }
}

@media (max-width: 640px) {
  .hero { padding: 40px 24px 56px; text-align: left; }
  .hero-media { height: 260px; }
  .hero-price-card { position: static; margin-top: 16px; display: inline-block; }
}

/* ABOUT PAGE */
.about-hero-icon { width: 20px; height: 20px; }
.about-hero-row { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; }
.about-hero-intro { max-width: 600px; margin-top: 0; }
.about-meta-cols { display: flex; gap: 36px; flex-shrink: 0; }
.about-meta-label { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-muted); }
.about-meta-value { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 16px; margin-top: 6px; color: var(--ink); }

.collage-band { max-width: 1200px; margin: 0 auto; padding: 0 40px 84px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px; }
.collage-band__hero { border-radius: var(--r-lg); aspect-ratio: 4 / 3; background-size: cover; background-position: center; background-color: var(--cream-dark); }
.collage-band__tiles { display: grid; grid-template-rows: 1fr 1fr; gap: 20px; }
.collage-tile { border-radius: var(--r-lg); background: var(--red); display: flex; align-items: center; justify-content: center; }
.collage-tile svg { width: 60%; height: 60%; }

.belief-band { background: var(--ink); color: #fff; padding: 84px 40px; }
.belief-band__inner { max-width: 1200px; margin: 0 auto; }
.belief-band .eyebrow { color: rgba(255,255,255,0.85); }
.belief-heading { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(28px, 4.2vw, 46px); line-height: 1.1; max-width: 820px; margin: 14px 0 0; }
.belief-heading em { color: var(--red); font-style: normal; }
.belief-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
.belief-card { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.14); border-radius: var(--r-lg); padding: 28px; }
.belief-card h3 { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 17px; margin: 0 0 10px; }
.belief-card p { color: rgba(255,255,255,0.68); font-size: 14px; line-height: 1.6; margin: 0; }

.studio-note { max-width: 1200px; margin: 0 auto; padding: 84px 40px; display: grid; grid-template-columns: 0.6fr 1.4fr; gap: 48px; }
.studio-note__quote { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(22px, 3vw, 32px); line-height: 1.3; color: var(--ink); margin: 0; }
.studio-note__sig { display: flex; align-items: center; gap: 12px; margin-top: 24px; font-size: 14px; color: var(--ink-muted); }
.studio-note__sig img { height: 22px; width: 22px; }

@media (max-width: 900px) {
  .about-hero-row { align-items: flex-start; }
  .collage-band { grid-template-columns: 1fr; }
  .belief-cards { grid-template-columns: 1fr; }
  .studio-note { grid-template-columns: 1fr; gap: 20px; }
}

@media (max-width: 640px) {
  .about-meta-cols { gap: 24px; }
  .belief-band { padding: 48px 24px; }
  .studio-note { padding: 48px 24px; }
}

.exp-card { display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); border-radius: 20px; overflow: hidden; text-decoration: none; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.exp-card:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(26,20,16,0.10); border-color: var(--red); }
.exp-card .art { width: 100%; aspect-ratio: 1 / 1; background-size: cover; background-position: center; background-color: var(--cream-dark); display: flex; align-items: center; justify-content: center; color: var(--placeholder); font-family: var(--display); text-transform: uppercase; letter-spacing: 0.05em; font-size: 13px; transition: filter .2s ease; }
.exp-card:hover .art { filter: brightness(1.04); }
.exp-card .body { padding: 22px 24px 26px; display: flex; flex-direction: column; flex: 1; }
.exp-card .cat { font-size: 10px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink-muted); }
.exp-card h3 { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 24px; line-height: 1.05; color: var(--ink); margin: 9px 0 9px; }
.exp-card p { font-size: 14px; color: var(--ink-muted); line-height: 1.55; margin: 0 0 20px; flex: 1; }
.exp-card .foot { display: flex; align-items: center; justify-content: space-between; border-top: 1px solid var(--line); padding-top: 16px; }
.exp-card .foot .cta-link { color: var(--red); font-weight: 500; }
.badge-off { font-size: 9.5px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: #fff; background: var(--red); border-radius: 100px; padding: 2px 7px; }
.strike { font-size: 13px; color: var(--ink-muted); text-decoration: line-through; }

.tier-btn { display: flex; align-items: center; justify-content: space-between; gap: 14px; width: 100%; box-sizing: border-box; padding: 14px 16px; border-radius: 12px; cursor: pointer; background: #fff; border: 1.5px solid var(--line-input); text-align: left; font-family: var(--sans); transition: border-color .15s ease, background .15s ease; }
.tier-btn:hover { border-color: var(--red); }
.tier-btn.active { border-color: var(--red); background: var(--red-pale); }

/* DETAIL PAGE */
.detail-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 48px; }
.detail-media { aspect-ratio: 1 / 1; background-size: cover; background-position: center; background-color: var(--cream-dark); display: flex; align-items: center; justify-content: center; color: var(--placeholder); font-family: var(--display); text-transform: uppercase; position: relative; overflow: hidden; }

/* IMAGE CAROUSEL — used inside .detail-media and .bk-rail-media */
.img-carousel-track { display: flex; width: 100%; height: 100%; transition: transform .4s ease; }
.img-carousel-slide { flex: 0 0 100%; height: 100%; background-size: cover; background-position: center; }
.img-carousel-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,0.85); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 18px; line-height: 1; color: var(--ink); z-index: 2; transition: background .15s ease; }
.img-carousel-arrow:hover { background: #fff; }
.img-carousel-prev { left: 12px; }
.img-carousel-next { right: 12px; }
.img-carousel-dots { position: absolute; bottom: 12px; left: 0; right: 0; display: flex; justify-content: center; gap: 6px; z-index: 2; }
.img-carousel-dot { width: 7px; height: 7px; border-radius: 4px; background: rgba(255,255,255,0.6); border: none; padding: 0; cursor: pointer; transition: width .15s ease, background .15s ease; }
.img-carousel-dot.active { background: #fff; width: 18px; }
.includes-list { margin: 14px 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 10px; }
.includes-list li { display: flex; gap: 10px; font-size: 15px; color: var(--ink-mid); align-items: flex-start; }
.includes-list li .tick { width: 14px; height: 14px; flex-shrink: 0; margin-top: 3px; }
.perks-row { display: flex; gap: 20px; margin-top: 32px; flex-wrap: wrap; }
.perks-row > div { flex: 1; min-width: 160px; }
.perk-item { display: flex; align-items: center; gap: 8px; }
.perk-icon { width: 13px; height: 13px; flex-shrink: 0; }
.booking-card { padding: 28px; position: sticky; top: 90px; }

@media (max-width: 900px) {
  .detail-grid { grid-template-columns: 1fr; gap: 32px; }
  .booking-card { position: static; }
}

/* FAQ */
.faq-item { padding: 0; margin-bottom: 12px; overflow: hidden; }
.faq-q { width: 100%; text-align: left; background: none; border: none; padding: 18px 22px; font-size: 15px; font-weight: 600; cursor: pointer; font-family: var(--sans); color: var(--ink); display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.faq-q:hover { color: var(--red); }
.faq-a { display: none; padding: 0 22px 18px; color: var(--ink-mid); font-size: 14px; line-height: 1.6; }

/* FORMS / BOOK / CONTACT */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.checkbox-row { display: flex; align-items: center; gap: 8px; font-size: 14px; color: var(--ink-mid); }
.checkbox-row input { width: auto; }
.addon-pill { display: flex; align-items: center; justify-content: space-between; width: 100%; text-align: left; gap: 16px; }
.addon-pill > span:first-child { display: flex; align-items: center; gap: 10px; }
.addon-pill input[type="checkbox"] { width: 17px; height: 17px; flex-shrink: 0; accent-color: var(--red); margin: 0; }
.book-layout { padding: 64px 40px 80px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; align-items: flex-start; }
.book-panel { padding: 32px; }
.book-panel-title { font-size: 30px; margin-bottom: 8px; }
.book-rail { padding: 26px; position: sticky; top: 90px; }
.step-actions { display: flex; gap: 12px; margin-top: 20px; }
.step-warn { color: var(--red); display: none; margin-top: 12px; }
.success-icon { font-size: 48px; color: var(--red); }
.contact-split { display: grid; grid-template-columns: 1fr 1fr; min-height: calc(100vh - 73px); }
.contact-split-left { background: var(--red); color: #fff; padding: 64px 56px; display: flex; flex-direction: column; justify-content: space-between; gap: 48px; }
.contact-split-left .eyebrow { color: rgba(255,255,255,0.85); }
.contact-split-left .h1 { color: #fff; }
.contact-split-left .body-light { color: rgba(255,255,255,0.85); margin-top: 16px; max-width: 460px; }
.contact-split-info { display: flex; flex-direction: column; gap: 6px; color: rgba(255,255,255,0.85); font-size: 15px; }
.contact-split-link { color: inherit; text-decoration: none; display: inline-flex; align-items: center; gap: 9px; }
.contact-split-link:hover { text-decoration: underline; }
.contact-split-icon { flex-shrink: 0; }
.contact-split-right { background: #fff; padding: 64px 56px; display: flex; flex-direction: column; justify-content: center; }
.contact-split-right form { width: 100%; max-width: 480px; margin: 0 auto; }

@media (max-width: 900px) {
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .grid-span-2 { grid-column: span 1; }
  .book-layout { grid-template-columns: 1fr; padding-left: 24px; padding-right: 24px; }
  .book-rail { position: static; }
  .contact-split { grid-template-columns: 1fr; min-height: auto; }
  .contact-split-left, .contact-split-right { padding: 40px 24px; }
}

/* ADMIN LOGIN */
.login-shell { display: grid; grid-template-columns: 1fr 1fr; min-height: 100vh; }
.login-panel { display: flex; flex-direction: column; justify-content: space-between; padding: 56px; }
.login-brand { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 24px; }
.login-brand .sub { opacity: 0.7; font-size: 14px; text-transform: none; font-weight: 400; }
.login-title { color: #fff; font-size: 40px; }
.login-copy { opacity: 0.85; max-width: 420px; margin-top: 16px; }
.login-foot { opacity: 0.6; font-size: 13px; }
.login-form-wrap { display: flex; align-items: center; justify-content: center; background: var(--cream); padding: 40px 24px; }
.login-form { width: 100%; max-width: 380px; }
.login-form-title { font-size: 28px; }
.login-error { background: #FDE8E6; color: var(--red-dark); padding: 12px 16px; border-radius: 10px; margin-top: 18px; font-size: 14px; }

@media (max-width: 760px) {
  .login-shell { grid-template-columns: 1fr; min-height: auto; }
  .login-panel { padding: 40px 24px; }
}

.admin-shell { display: flex; height: 100vh; overflow: hidden; background: var(--cream); }
.admin-sidebar { width: 256px; flex-shrink: 0; background: var(--red); display: flex; flex-direction: column; padding: 26px 18px 18px; color: #fff; }
.admin-brand { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 20px; }
.admin-sidebar nav { display: flex; flex-direction: column; gap: 4px; margin-top: 34px; flex: 1; }
.admin-sidebar nav a { display: flex; align-items: center; gap: 11px; padding: 11px 12px; border-radius: 10px; color: rgba(255,255,255,0.82); text-decoration: none; font-size: 14px; font-weight: 500; transition: background .15s ease, color .15s ease; }
.admin-sidebar nav a.active, .admin-sidebar nav a:hover { background: rgba(255,255,255,0.16); color: #fff; }
.admin-logout-form { margin-top: auto; }
.admin-logout-btn { width: 100%; justify-content: center; border-color: rgba(255,255,255,0.3); color: #fff; }
.admin-main { flex: 1; overflow-y: auto; min-width: 0; }
.admin-header { position: sticky; top: 0; z-index: 5; background: rgba(245,241,230,0.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); padding: 22px 40px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.admin-header-title { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: 32px; line-height: 1.05; margin-top: 4px; }
.admin-search-form { flex: 1; max-width: 360px; }
.admin-search-form input { width: 100%; border: 1px solid var(--line); background: #fff; border-radius: 999px; padding: 11px 18px; font-size: 14px; font-family: var(--sans); }
.admin-search-form input:focus { outline: none; border-color: var(--red); }
.admin-header-actions { display: flex; align-items: center; gap: 18px; }
.admin-new-enquiry-btn { white-space: nowrap; }
.search-result-row { display: flex; align-items: center; gap: 14px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 12px; text-decoration: none; color: var(--ink); background: #fff; }
.search-result-row:hover { border-color: var(--red); }
.search-result-kind { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-muted); font-weight: 600; }
.admin-content { padding: 32px 40px 56px; }
.metric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-bottom: 24px; }
.metric-card { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 22px 22px 20px; transition: box-shadow .15s ease; }
.metric-card:hover { box-shadow: 0 10px 26px rgba(26,20,16,0.08); }
.metric-card .label { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-muted); font-weight: 600; }
.metric-card .value { font-family: var(--display); font-weight: 700; font-size: 36px; line-height: 1.05; margin: 12px 0 6px; color: var(--ink); }
.catalog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.catalog-card { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 24px; display: flex; flex-direction: column; }
.catalog-card.add-card { border: 1.5px dashed var(--line-input); align-items: center; justify-content: center; }
.catalog-card .lv { display: flex; align-items: center; justify-content: space-between; padding: 8px 0; }
.catalog-actions { display: flex; gap: 8px; margin-top: 14px; }
.catalog-actions .btn-outline { flex: 1; justify-content: center; }
.catalog-edit-panel { display: none; margin-top: 16px; border-top: 1px solid var(--line); padding-top: 16px; }
.toggle-vis { font-size: 11px; font-weight: 600; padding: 5px 11px; border-radius: 100px; cursor: pointer; white-space: nowrap; }
.toggle-vis.shown { background: var(--red-pale); color: var(--red); }
.toggle-vis.hidden { background: var(--line); color: var(--ink-muted); }
.admin-table-wrap { overflow-x: auto; border-radius: 16px; }
table.admin-table { width: 100%; border-collapse: collapse; background: #fff; border-radius: 16px; overflow: hidden; min-width: 560px; }
table.admin-table th, table.admin-table td { text-align: left; padding: 12px 16px; font-size: 13.5px; border-bottom: 1px solid var(--line); }
table.admin-table th { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); }
table.admin-table tbody tr:hover { background: var(--red-pale); }
table.admin-table select { width: auto; padding: 7px 10px; font-size: 13px; }
.status-chip { padding: 4px 11px; border-radius: 100px; font-size: 11.5px; font-weight: 600; white-space: nowrap; }
.status-New { background: var(--red-pale); color: var(--red); }
.status-Confirmed { background: #E6F4EA; color: #1E7A40; }
.status-Completed { background: #E6E9F4; color: #33408C; }
.status-Quoted { background: #E3EEFB; color: #225C9E; }
.status-Inconversation { background: #FDF3E1; color: #9A6A12; }
.status-Enquiry { background: #FDF3E1; color: #9A6A12; }
.status-Contacted, .status-Cancelled, .status-Closed { background: var(--line); color: var(--ink-muted); }

/* Dashboard */
.dashboard-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 18px; align-items: flex-start; }
.card-callout { background: var(--red); border-radius: 20px; padding: 24px; }
.card-quoted { background: var(--red); border-radius: 20px; padding: 24px; }
.avatar-circle { width: 38px; height: 38px; border-radius: 50%; background: var(--red-pale); color: var(--red); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 13px; flex-shrink: 0; }
.avatar-circle-sm { width: 30px; height: 30px; font-size: 11px; }
.client-cell { display: flex; align-items: center; gap: 10px; }
.recent-enquiry-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--line); text-decoration: none; color: var(--ink); }
.recent-enquiry-row:last-child { border-bottom: none; }
.recent-enquiry-info { flex: 1; min-width: 0; }
.recent-enquiry-amount { font-weight: 600; white-space: nowrap; }
.up-next-row { display: flex; align-items: center; gap: 14px; text-decoration: none; color: var(--ink); }
.up-next-date { width: 44px; height: 44px; border-radius: 12px; background: var(--red-pale); color: var(--red); display: flex; flex-direction: column; align-items: center; justify-content: center; font-weight: 700; font-size: 16px; line-height: 1.1; flex-shrink: 0; }
.up-next-date span { font-size: 9px; font-weight: 700; letter-spacing: 0.05em; }

/* Filter pills */
.filter-pill-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 18px; }
.filter-pill { padding: 9px 18px; border-radius: 100px; background: #fff; border: 1px solid var(--line); color: var(--ink-muted); font-size: 13px; font-weight: 600; text-decoration: none; white-space: nowrap; }
.filter-pill.active { background: var(--red); border-color: var(--red); color: #fff; }

/* Enquiry detail */
.enquiry-detail-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 24px; align-items: flex-start; }
.timeline { position: relative; }
.timeline-item { display: flex; gap: 14px; padding-bottom: 18px; position: relative; }
.timeline-item:not(:last-child)::before { content: ''; position: absolute; left: 4px; top: 14px; bottom: 0; width: 1px; background: var(--line); }
.timeline-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--red); margin-top: 5px; flex-shrink: 0; }
.status-pill-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.status-pill-option { padding: 10px 18px; border-radius: 100px; border: 1px solid var(--line); font-size: 13px; font-weight: 600; cursor: pointer; color: var(--ink-muted); transition: background .15s ease, border-color .15s ease, color .15s ease; }
.status-pill-option:hover { border-color: var(--red); color: var(--red); }
.status-pill-option input { display: none; }
.status-pill-option.active { background: var(--red-pale); border-color: var(--red); color: var(--red); }

/* Calendar */
.cal-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.cal-month-nav { display: flex; align-items: center; gap: 12px; }
.cal-nav-btn { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--line); background: #fff; display: flex; align-items: center; justify-content: center; text-decoration: none; color: var(--ink); font-size: 16px; }
.cal-nav-btn:hover { border-color: var(--red); color: var(--red); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); background: var(--line); border: 1px solid var(--line); border-radius: 16px; overflow: hidden; gap: 1px; }
.cal-dow { background: #fff; padding: 10px 12px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-muted); font-weight: 600; }
.cal-cell { background: #fff; min-height: 96px; padding: 8px; display: flex; flex-direction: column; gap: 4px; }
.cal-cell-empty { background: var(--cream); }
.cal-day-num { font-size: 13px; font-weight: 600; color: var(--ink-muted); }
.cal-today { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: 50%; background: var(--red); color: #fff; }
.cal-event { display: block; font-size: 11px; font-weight: 600; padding: 3px 7px; border-radius: 6px; border-left: 3px solid transparent; text-decoration: none; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cal-event-order { background: #E6F4EA; border-left-color: #1E7A40; }
.cal-event-enquiry { background: #FDF3E1; border-left-color: #9A6A12; }
.cal-legend { display: flex; gap: 16px; }
.cal-legend-item { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ink-muted); font-weight: 600; }
.cal-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.cal-dot-order { background: #1E7A40; }
.cal-dot-enquiry { background: #9A6A12; }

@media (max-width: 900px) {
  .catalog-grid, .metric-grid { grid-template-columns: 1fr 1fr; }
  .dashboard-grid, .enquiry-detail-grid { grid-template-columns: 1fr; }
}

@media (max-width: 760px) {
  .cal-grid { grid-template-columns: repeat(7, minmax(80px, 1fr)); overflow-x: auto; }
}

@media (max-width: 760px) {
  .admin-shell { flex-direction: column; height: auto; min-height: 100vh; overflow: visible; }
  .admin-sidebar { width: 100%; flex-direction: row; align-items: center; padding: 14px 18px; }
  .admin-sidebar nav { flex-direction: row; margin-top: 0; overflow-x: auto; flex: 1; margin-left: 18px; }
  .admin-logout-form { margin-top: 0; margin-left: 12px; }
  .admin-logout-btn { width: auto; padding: 9px 14px; font-size: 13px; }
  .admin-header { padding: 16px 20px; }
  .admin-content { padding: 20px 20px 40px; }
  .metric-grid, .catalog-grid { grid-template-columns: 1fr; }
}
