:root {
  --caliza: #e8e8e6;
  --yeso: #d8d2c6;
  --arena-profunda: #b3ab9b;
  --arcilla: #986d4f;
  --tierra-tostada: #5f452e;
  --pizarra: #3f3f3b;
  --olivo-mineral: #827d5b;
  --musgo: #6a7346;
  --bosque-seco: #424130;
  --bruma-azul: #828a91;
  --night-progress: 0;
  --glow-dim: 0;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
}

body {
  font-family: 'Outfit', sans-serif;
  color: var(--pizarra);
  background:
    radial-gradient(circle at 10% 0%, rgba(152, 109, 79, 0.22), transparent 35%),
    radial-gradient(circle at 90% 5%, rgba(130, 138, 145, 0.22), transparent 35%),
    linear-gradient(180deg, #d8bea0 0%, #d9c3aa 24%, #cdb29b 55%, #161412 100%);
  transition: color 0.2s ease;
}

body.has-landing-intro {
  overflow: hidden;
}

body.has-landing-intro .site-header,
body.has-landing-intro .story-root,
body.has-landing-intro .sim-banner {
  transform: translateY(100vh);
  opacity: 0;
  filter: none;
  will-change: transform;
  visibility: hidden;
  transition:
    transform 0.95s cubic-bezier(.2,.74,.2,1),
    opacity 0.25s ease;
  pointer-events: none;
}

body.intro-pushing .site-header,
body.intro-pushing .story-root,
body.intro-pushing .sim-banner {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
}

body.intro-pushing {
  overflow: hidden;
}

body:not(.has-landing-intro) .site-header,
body:not(.has-landing-intro) .story-root,
body:not(.has-landing-intro) .sim-banner {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: rgba(0, 0, 0, calc(var(--night-progress) * 0.62));
}

.landing-intro {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 0;
  cursor: pointer;
  background:
    linear-gradient(120deg, rgba(234, 228, 220, 0.72), rgba(184, 160, 139, 0.48) 34%, rgba(95, 82, 61, 0.34) 56%, rgba(101, 110, 88, 0.4) 78%, rgba(140, 145, 149, 0.52) 100%);
  transform: translateZ(0);
  will-change: transform;
  overflow: hidden;
}

.landing-intro::before {
  content: '';
  position: absolute;
  inset: -6%;
  z-index: 0;
  pointer-events: none;
  background:
    url('/static/logocompleto-upscaled.jpg') center center / cover no-repeat,
    linear-gradient(120deg, rgba(232, 225, 215, 0.68), rgba(177, 145, 118, 0.38) 35%, rgba(97, 74, 54, 0.28) 58%, rgba(116, 124, 90, 0.28) 76%, rgba(145, 152, 157, 0.36) 100%);
  filter: blur(34px) saturate(0.92) brightness(0.95);
  opacity: 0.96;
  transform: scale(1.08) translate3d(calc(var(--intro-mx, 0) * 10px), calc(var(--intro-my, 0) * 8px), 0);
  transition: transform 0.25s ease;
}

.landing-intro::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(17, 14, 12, 0.08), rgba(14, 13, 12, 0.14)),
    radial-gradient(circle at 18% 22%, rgba(255, 244, 230, 0.16), transparent 30%),
    radial-gradient(circle at 78% 24%, rgba(167, 182, 193, 0.14), transparent 28%),
    radial-gradient(circle at 50% 78%, rgba(206, 174, 144, 0.12), transparent 32%);
}

.intro-core {
  position: relative;
  z-index: 3;
  text-align: center;
  width: min(720px, 92vw);
  padding: 2.2rem 1.4rem;
  color: #f8f0e6;
  border: 1px solid rgba(255, 234, 212, 0.28);
  background: linear-gradient(160deg, rgba(32, 26, 23, 0.42), rgba(38, 30, 24, 0.2));
  border-radius: 24px;
  box-shadow: 0 34px 80px rgba(14, 10, 9, 0.35);
  transform: translateZ(0);
}

.intro-shell {
  position: relative;
  z-index: 3;
  width: 100%;
  display: grid;
  margin: 0 auto;
  place-items: center;
}

.intro-copy {
  position: relative;
  width: 100%;
  min-height: 100dvh;
  padding: max(1.4rem, env(safe-area-inset-top)) 1.4rem max(1.8rem, env(safe-area-inset-bottom));
  color: #f8f0e6;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 0;
  text-align: center;
  background: url('/static/intro-embedded-desktop.png') center center / cover no-repeat;
}

.intro-copy::before {
  display: none;
}

.intro-mobile-stage {
  display: none;
}

.intro-shortcuts {
  display: none;
}

.intro-shortcuts-kicker,
.intro-shortcuts h2,
.intro-shortcuts-copy {
  display: none;
}

.intro-breathing {
  display: none;
}

.intro-poster-wrap {
  display: none;
}

.intro-poster-wrap::before {
  display: none;
}

.intro-poster-wrap::after {
  display: none;
}

.intro-actions {
  display: flex;
  width: min(360px, 100%);
  justify-content: center;
  margin-top: 0;
  margin-bottom: clamp(2rem, 4vh, 3rem);
  position: relative;
  z-index: 1;
}

.intro-actions .btn {
  min-width: min(320px, 100%);
  border-color: rgba(249, 242, 232, 0.94);
  background: rgba(20, 16, 13, 0.32);
  box-shadow: 0 16px 38px rgba(12, 10, 8, 0.18);
  backdrop-filter: blur(14px);
}

.intro-actions .btn:hover,
.intro-actions .btn:focus-visible {
  background: rgba(32, 24, 19, 0.46);
}

.intro-composite-art {
  display: none;
}

.intro-logo-mark {
  display: none;
}

.intro-core h1 {
  display: none;
}

.intro-core p {
  display: none;
}

.sand-river {
  display: none;
}

body.intro-pushing .landing-intro {
  pointer-events: none;
  animation: introPushUp 0.95s cubic-bezier(.2,.74,.2,1) forwards;
}

@keyframes introPushUp {
  from { transform: translateY(0); }
  to { transform: translateY(-100%); }
}

@media (max-width: 760px) {
  .intro-copy {
    min-height: 100dvh;
    padding: max(0.75rem, env(safe-area-inset-top)) 0.9rem max(1.2rem, env(safe-area-inset-bottom));
  }

  .intro-actions {
    width: 100%;
    margin-bottom: 0.75rem;
  }

  .intro-actions .btn {
    width: 100%;
    min-width: 0;
    background: #3b2d25;
  }
}

main,
.site-header,
.sim-banner {
  position: relative;
  z-index: 2;
}

.sim-banner {
  background: var(--bosque-seco);
  color: var(--caliza);
  text-align: center;
  padding: 6px;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  backdrop-filter: blur(10px);
  background: rgba(232, 232, 230, 0.72);
  border-bottom: 1px solid rgba(63, 63, 59, 0.12);
}

.brand {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  color: var(--tierra-tostada);
  letter-spacing: 0.06em;
}

.top-nav {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.top-nav a,
.top-nav button {
  text-decoration: none;
  color: var(--pizarra);
  border: 0;
  background: none;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
}

.story-root {
  position: relative;
  overflow: clip;
}

.landing-banner {
  max-width: 1180px;
  margin: 1rem auto 0;
  padding: 1.25rem 1.5rem 0;
  display: grid;
}

.landing-banner-card {
  border-radius: 28px;
  padding: clamp(1.8rem, 4vw, 3rem);
  color: var(--caliza);
  background:
    radial-gradient(circle at 18% 35%, rgba(255, 227, 193, 0.28), transparent 30%),
    radial-gradient(circle at 82% 22%, rgba(137, 146, 154, 0.2), transparent 28%),
    linear-gradient(130deg, rgba(48, 42, 34, 0.96), rgba(97, 69, 48, 0.9));
  box-shadow: 0 26px 60px rgba(44, 34, 27, 0.22);
}

.landing-banner-hint {
  display: inline-flex;
  align-items: center;
  margin-top: 1.2rem;
  border-radius: 999px;
  padding: 0.55rem 0.9rem;
  border: 1px solid rgba(248, 233, 214, 0.2);
  background: rgba(255, 248, 240, 0.08);
  color: rgba(247, 239, 228, 0.92);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.landing-banner-card h1 {
  margin: 0;
  max-width: 12ch;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.8rem, 8vw, 5.6rem);
  line-height: 0.92;
}

.landing-banner-card p:last-child {
  max-width: 42ch;
  margin: 0.9rem 0 0;
  font-size: 1.04rem;
  color: rgba(247, 239, 228, 0.84);
}

.ambient-lights {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.light-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(18px);
  opacity: calc((1 - var(--night-progress)) * (1 - var(--glow-dim) * 0.7));
  transition: opacity 0.15s linear;
  mix-blend-mode: screen;
}

.orb-1 {
  width: 230px;
  height: 230px;
  left: 8%;
  top: 18%;
  background: rgba(255, 194, 141, 0.5);
  animation: driftA 8s ease-in-out infinite;
}

.orb-2 {
  width: 160px;
  height: 160px;
  right: 12%;
  top: 22%;
  background: rgba(249, 219, 179, 0.42);
  animation: driftB 11s ease-in-out infinite;
}

.orb-3 {
  width: 190px;
  height: 190px;
  left: 18%;
  bottom: 26%;
  background: rgba(173, 185, 196, 0.35);
  animation: driftC 10s ease-in-out infinite;
}

.orb-4 {
  width: 300px;
  height: 300px;
  right: -30px;
  bottom: 10%;
  background: rgba(154, 109, 79, 0.25);
  animation: driftA 14s ease-in-out infinite;
}

.hero {
  min-height: 82vh;
  display: grid;
  place-items: center;
  padding: 2rem;
}

.dune-hero {
  background:
    linear-gradient(180deg, rgba(255, 241, 223, 0.22), rgba(102, 71, 49, 0.12)),
    radial-gradient(circle at 20% 30%, rgba(255, 233, 205, 0.2), transparent 40%),
    radial-gradient(circle at 80% 20%, rgba(131, 139, 146, 0.2), transparent 40%);
}

.hero-card {
  max-width: 1160px;
  width: 100%;
  border-radius: 22px;
  padding: 2.2rem;
  color: var(--caliza);
  background: linear-gradient(125deg, #2c231d, #4a3528);
  box-shadow: 0 26px 60px rgba(44, 34, 27, 0.35);
  margin: 0 auto;
}

.hero-premium {
  padding: 2.4rem;
}

.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 360px);
  gap: 1.2rem;
  align-items: stretch;
}

.hero-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.hero-aside {
  display: grid;
  gap: 0.9rem;
}

.hero-aside-card {
  border-radius: 22px;
  padding: 1rem 1.1rem;
  background: #f1e7db;
  border: 1px solid rgba(132, 103, 77, 0.12);
  color: #3a2e25;
}

.hero-aside-card span {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(95, 69, 46, 0.7);
}

.hero-aside-card strong {
  display: block;
  font-size: 1.06rem;
  line-height: 1.35;
}

.hero-aside-card p {
  margin: 0.45rem 0 0;
  font-size: 0.94rem;
  color: rgba(63, 54, 45, 0.82);
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.78rem;
  opacity: 0.82;
  margin-bottom: 0.6rem;
}

.hero h1 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.4rem, 7vw, 5.2rem);
  line-height: 0.94;
}

.hero p {
  font-size: 1.08rem;
  max-width: 700px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1rem;
}

.proof-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1.25rem;
}

.proof-chip {
  border-radius: 999px;
  padding: 0.55rem 0.85rem;
  font-size: 0.78rem;
  color: #f3eadf;
  background: #6a4a33;
  border: 1px solid rgba(248, 233, 214, 0.1);
}

.section {
  max-width: 1180px;
  margin: 0 auto;
  padding: 1.5rem;
}

.section h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2rem, 4vw, 3.2rem);
  margin: 0 0 0.7rem;
}

.section-heading {
  max-width: 760px;
  margin-bottom: 1rem;
}

.section-heading p:not(.eyebrow) {
  margin: 0.2rem 0 0;
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(56, 46, 39, 0.82);
}

.section-heading.compact {
  margin-bottom: 0.8rem;
}

.section-heading-surface {
  padding: 1rem 1.1rem;
  border-radius: 24px;
  background: #f0e6da;
  border: 1px solid rgba(95, 69, 46, 0.12);
  box-shadow: 0 16px 34px rgba(33, 25, 19, 0.12);
}

.section-heading-surface h2,
.section-heading-surface p:not(.eyebrow),
.section-heading-surface .eyebrow {
  color: inherit;
  text-shadow: none;
}

.story-root > .section .eyebrow {
  color: rgba(238, 223, 204, 0.74);
}

.story-root > .section .section-heading h2,
.story-root > .section.split-section .split-left h2 {
  color: rgba(246, 236, 223, 0.96);
  text-shadow: 0 10px 24px rgba(24, 18, 14, 0.22);
}

.story-root > .section .section-heading p:not(.eyebrow),
.story-root > .section.split-section .split-left p,
.story-root > .section.split-section .quote {
  color: rgba(237, 227, 216, 0.82);
}

.story-root > .section .section-heading.section-heading-surface .eyebrow {
  color: rgba(95, 69, 46, 0.74);
}

.story-root > .section .section-heading.section-heading-surface h2 {
  color: rgba(53, 44, 36, 0.96);
}

.story-root > .section .section-heading.section-heading-surface p:not(.eyebrow) {
  color: rgba(63, 54, 45, 0.84);
}

.section-band {
  padding-top: 0.4rem;
}

.band-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
  gap: 1rem;
  align-items: end;
  padding: 1.25rem 1.3rem;
  border-radius: 24px;
  background: #eadfd1;
  border: 1px solid rgba(95, 69, 46, 0.12);
  box-shadow: 0 16px 34px rgba(52, 40, 28, 0.1);
}

.band-shell p:last-child {
  margin: 0;
  line-height: 1.7;
  color: rgba(63, 54, 45, 0.8);
}

.grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.card {
  background: #f1e8de;
  border: 1px solid rgba(93, 76, 61, 0.12);
  border-radius: 18px;
  padding: 1.1rem;
  box-shadow: 0 14px 34px rgba(52, 40, 28, 0.14);
}

.dune-card {
  min-height: 220px;
}

.experience-card {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.experience-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.45rem;
  margin-top: auto;
}

.experience-detail {
  font-size: 0.84rem;
  color: rgba(65, 58, 51, 0.72);
}

.ritual-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.ritual-card {
  min-height: 220px;
}

.ritual-step {
  display: inline-block;
  margin-bottom: 0.75rem;
  padding: 0.22rem 0.58rem;
  border-radius: 999px;
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--caliza);
  background: linear-gradient(120deg, #7f5d41, #9d7354);
}

.tag {
  display: inline-block;
  margin-bottom: 0.55rem;
  border-radius: 999px;
  border: 1px solid rgba(95, 69, 46, 0.3);
  padding: 0.17rem 0.55rem;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.split-section {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1.1fr 1fr;
}

.split-left p {
  max-width: 46ch;
}

.split-left h2 {
  color: rgba(53, 44, 36, 0.96);
}

.split-left p {
  color: rgba(63, 54, 45, 0.84);
}

.split-left .quote {
  color: rgba(95, 69, 46, 0.8);
}

.story-root > .section.split-section .split-left h2 {
  color: rgba(53, 44, 36, 0.96);
  text-shadow: none;
}

.story-root > .section.split-section .split-left p,
.story-root > .section.split-section .split-left .quote {
  color: rgba(63, 54, 45, 0.84);
}

.premium-copy p + p {
  margin-top: 0.85rem;
}

.quote {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.4rem;
  margin-top: 0.9rem;
}

.split-right {
  display: grid;
  place-items: center;
  min-height: 260px;
  background: linear-gradient(145deg, #b08a68, #8d694c);
}

.premium-preview {
  align-content: center;
  gap: 1rem;
}

.clay-shape {
  width: min(320px, 85%);
  aspect-ratio: 1 / 1;
  border-radius: 22% 78% 61% 39% / 34% 35% 65% 66%;
  background: radial-gradient(circle at 30% 30%, #c18459, #8f5f43 70%);
  box-shadow: inset -18px -20px 42px rgba(49, 31, 22, 0.4);
}

.preview-caption {
  text-align: center;
}

.preview-caption strong {
  display: block;
  margin-bottom: 0.25rem;
  color: rgba(54, 41, 31, 0.96);
}

.preview-caption p {
  margin: 0;
  color: rgba(60, 46, 35, 0.92);
}

.schedule-shell {
  position: relative;
}

.schedule-board {
  background: #f2e8dd;
}

.timeline {
  margin: 0.8rem 0 1rem;
}

.timeline-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  border-bottom: 1px solid rgba(83, 62, 45, 0.18);
  padding: 0.8rem 0;
}

.timeline-row p {
  margin: 0.16rem 0 0;
  color: rgba(65, 58, 51, 0.78);
}

.timeline-right {
  text-align: right;
}

.timeline-right span {
  font-weight: 700;
}

.timeline-right small {
  display: block;
  margin-top: 0.2rem;
}

.final-manifesto {
  text-align: center;
  padding: 2rem;
  background:
    radial-gradient(circle at 50% 0, rgba(207, 158, 113, 0.16), transparent 46%),
    linear-gradient(160deg, #2f2620, #171412);
  color: #f0ece5;
}

.ops-showcase {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 1fr);
  gap: 1rem;
  align-items: stretch;
  background:
    radial-gradient(circle at 100% 0, rgba(207, 158, 113, 0.12), transparent 42%),
    linear-gradient(155deg, #302720, #171412);
  color: #f4eee7;
}

.ops-copy p:not(.eyebrow) {
  max-width: 52ch;
  color: rgba(242, 233, 223, 0.85);
}

.ops-panels {
  display: grid;
  gap: 0.8rem;
}

.ops-panel {
  border-radius: 20px;
  padding: 1rem;
  background: #f0e6da;
  border: 1px solid rgba(93, 76, 61, 0.12);
  color: #372c24;
}

.ops-panel span {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(121, 82, 54, 0.74);
}

.ops-panel strong {
  display: block;
  line-height: 1.35;
}

.btn {
  background: linear-gradient(120deg, #9d6646, #a87352);
  color: var(--caliza);
  border: 0;
  padding: 0.66rem 1rem;
  border-radius: 999px;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  font-weight: 600;
  transition: transform 0.18s ease, filter 0.18s ease;
}

.btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.04);
}

.btn.alt {
  background: linear-gradient(120deg, #64724f, #7f8e61);
}

.form-row {
  display: grid;
  gap: 0.3rem;
  margin-bottom: 0.8rem;
}

input,
select,
textarea {
  width: 100%;
  padding: 0.66rem;
  border-radius: 10px;
  border: 1px solid rgba(63, 63, 59, 0.24);
  background: rgba(255, 255, 255, 0.72);
  color: #2f2924;
}

.metric {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--tierra-tostada);
}

.status-pill {
  font-size: 0.8rem;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  background: var(--olivo-mineral);
  color: white;
}

.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: all 0.55s ease;
}

.reveal.show {
  opacity: 1;
  transform: translateY(0);
}

.parallax {
  transform: translateY(var(--parallax, 0));
  transition: transform 0.1s linear;
}

.table {
  width: 100%;
  border-collapse: collapse;
}

.table td,
.table th {
  border-bottom: 1px solid rgba(63, 63, 59, 0.18);
  padding: 0.55rem;
  text-align: left;
}

.qr {
  width: 180px;
  height: 180px;
  object-fit: contain;
  background: white;
  padding: 0.4rem;
  border-radius: 12px;
}

@keyframes driftA {
  0%,
  100% { transform: translateY(0) translateX(0); }
  50% { transform: translateY(18px) translateX(12px); }
}

@keyframes driftB {
  0%,
  100% { transform: translateY(0) translateX(0); }
  50% { transform: translateY(-14px) translateX(-16px); }
}

@keyframes driftC {
  0%,
  100% { transform: translateY(0) translateX(0); }
  50% { transform: translateY(10px) translateX(-8px); }
}

@media (max-width: 900px) {
  .intro-shell,
  .hero-grid,
  .band-shell,
  .ops-showcase {
    grid-template-columns: 1fr;
  }

  .landing-intro {
    place-items: stretch;
    padding: 0;
    overflow: hidden;
  }

  .intro-shell {
    width: 100%;
    min-height: 100dvh;
    padding: 0;
    align-items: center;
  }

  .split-section {
    grid-template-columns: 1fr;
  }

  .timeline-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .timeline-right {
    text-align: left;
  }
}

@media (max-width: 760px) {
  .landing-intro {
    background: #d7c1ab;
  }

  .landing-intro::before,
  .landing-intro::after {
    display: none;
  }

  .site-header {
    align-items: stretch;
    gap: 0.5rem;
    flex-direction: column;
    padding: 0.75rem 0.9rem;
  }

  .brand {
    font-size: 1.35rem;
  }

  .top-nav {
    gap: 0.5rem;
    font-size: 0.88rem;
    flex-wrap: nowrap;
    overflow-x: auto;
    white-space: nowrap;
    width: 100%;
    padding-bottom: 0.2rem;
    scrollbar-width: none;
  }

  .top-nav::-webkit-scrollbar {
    display: none;
  }

  .top-nav a,
  .top-nav button {
    flex: 0 0 auto;
  }

  .hero {
    min-height: auto;
    padding: 1rem;
  }

  .hero-card {
    padding: 1rem;
    border-radius: 20px;
  }

  .hero-premium {
    padding: 1rem;
  }

  .hero-grid {
    gap: 0.75rem;
  }

  .hero-aside {
    display: none;
  }

  .intro-copy {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-end;
    width: 100%;
    min-height: 100dvh;
    padding: max(1.25rem, env(safe-area-inset-top)) 1rem max(1rem, env(safe-area-inset-bottom));
    border-radius: 0;
    box-shadow: none;
    background:
      linear-gradient(180deg, rgba(17, 13, 11, 0.02), rgba(17, 13, 11, 0.12)),
      url('/static/intro-background-plate.png') center 56% / cover no-repeat;
    overflow: hidden;
  }

  .intro-copy::before {
    display: none;
  }

  .intro-mobile-stage {
    position: absolute;
    inset: 0 auto auto 0;
    display: block;
    z-index: 1;
    height: min(50svh, 29.5rem);
    width: 100%;
    background:
      linear-gradient(180deg, rgba(255, 250, 243, 0.03), rgba(19, 14, 12, 0.02)),
      url('/static/logocompleto-upscaled.jpg') center top / 158% auto no-repeat;
    filter: saturate(1.02) brightness(1.01);
    -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 76%, rgba(0, 0, 0, 0.9) 86%, rgba(0, 0, 0, 0.48) 94%, transparent 100%);
    mask-image: linear-gradient(180deg, #000 0%, #000 76%, rgba(0, 0, 0, 0.9) 86%, rgba(0, 0, 0, 0.48) 94%, transparent 100%);
    pointer-events: none;
  }

  .intro-mobile-stage::before,
  .intro-mobile-stage::after {
    content: '';
    position: absolute;
    pointer-events: none;
  }

  .intro-mobile-stage::before {
    left: -10%;
    right: -10%;
    bottom: -4.25rem;
    height: 10.5rem;
    background: url('/static/logocompleto-upscaled.jpg') center 92% / 164% auto no-repeat;
    filter: blur(34px) saturate(0.96);
    opacity: 0.96;
  }

  .intro-mobile-stage::after {
    left: -12%;
    right: -12%;
    bottom: -0.75rem;
    height: 7rem;
    background:
      radial-gradient(circle at 18% 34%, rgba(247, 226, 203, 0.24), transparent 34%),
      radial-gradient(circle at 82% 38%, rgba(213, 217, 220, 0.16), transparent 28%),
      linear-gradient(180deg, rgba(208, 178, 149, 0.22), rgba(169, 146, 123, 0.12) 44%, rgba(126, 110, 95, 0.06) 74%, transparent 100%);
    filter: blur(22px);
    opacity: 0.88;
  }

  .intro-body {
    margin-top: 1.5rem;
    grid-template-columns: 1fr;
    gap: 1.2rem;
  }

  .intro-breathing {
    --breath-duration: 8.4s;
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.75rem;
    width: min(100%, 21.5rem);
    margin-left: auto;
    margin-right: auto;
    margin-top: clamp(21.4rem, 46svh, 24.25rem);
    margin-bottom: clamp(1.4rem, 4svh, 2rem);
    padding: 1rem 1rem 1.2rem;
    border-radius: 2rem;
    border: 1px solid rgba(248, 235, 220, 0.1);
    background:
      linear-gradient(180deg, rgba(247, 238, 228, 0.11), rgba(247, 238, 228, 0.05));
    box-shadow:
      0 24px 52px rgba(12, 10, 8, 0.14),
      inset 0 1px 0 rgba(255, 247, 236, 0.1);
    backdrop-filter: blur(16px);
  }

  .intro-breathing-kicker {
    display: block;
    margin: 0;
    text-align: center;
    color: #f7eee4;
    font-size: 0.76rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.74;
  }

  .intro-breathing-core {
    position: relative;
    width: 11rem;
    height: 11rem;
    display: grid;
    place-items: center;
  }

  .intro-breathing-aura,
  .intro-breathing-orb {
    position: absolute;
    border-radius: 50%;
    animation: breathePulse var(--breath-duration) linear infinite;
    transform-origin: center;
  }

  .intro-breathing-aura-primary {
    inset: 0.45rem;
    background:
      radial-gradient(circle at 35% 32%, rgba(255, 245, 230, 0.72), rgba(231, 192, 156, 0.42) 34%, rgba(161, 134, 98, 0.2) 62%, transparent 78%);
    filter: blur(18px);
    opacity: 0.92;
    animation-name: breathePulse, breatheAuraPalette;
    animation-duration: var(--breath-duration), var(--breath-duration);
    animation-timing-function: linear, linear;
    animation-iteration-count: infinite, infinite;
  }

  .intro-breathing-aura-secondary {
    inset: 1.1rem;
    background:
      radial-gradient(circle at 62% 34%, rgba(208, 213, 196, 0.34), transparent 40%),
      radial-gradient(circle at 48% 58%, rgba(196, 160, 123, 0.3), rgba(114, 109, 82, 0.16) 58%, transparent 78%);
    filter: blur(14px);
    animation-name: breathePulse, breatheAuraPaletteSoft;
    animation-duration: var(--breath-duration), var(--breath-duration);
    animation-timing-function: linear, linear;
    animation-iteration-count: infinite, infinite;
    opacity: 0.88;
  }

  .intro-breathing-orb {
    inset: 2.2rem;
    overflow: hidden;
    isolation: isolate;
    background:
      radial-gradient(circle at 32% 28%, rgba(255, 249, 241, 0.98), rgba(247, 229, 205, 0.92) 24%, rgba(222, 189, 154, 0.7) 48%, rgba(171, 165, 129, 0.52) 72%, rgba(129, 146, 151, 0.38) 100%);
    box-shadow:
      0 0 26px rgba(255, 230, 199, 0.2),
      0 0 72px rgba(153, 124, 88, 0.2);
    will-change: transform, filter, box-shadow, opacity;
    animation-name: breatheOrbPulse, breatheOrbTint;
    animation-duration: var(--breath-duration), var(--breath-duration);
    animation-timing-function: linear, linear;
    animation-iteration-count: infinite, infinite;
  }

  .intro-breathing-orb::before,
  .intro-breathing-orb::after {
    content: '';
    position: absolute;
    inset: -20%;
    pointer-events: none;
    border-radius: 44% 56% 48% 52% / 53% 41% 59% 47%;
  }

  .intro-breathing-orb::before {
    background:
      radial-gradient(circle at 28% 30%, rgba(255, 245, 230, 0.92), transparent 20%),
      radial-gradient(circle at 62% 28%, rgba(236, 193, 143, 0.74), transparent 30%),
      radial-gradient(circle at 46% 66%, rgba(189, 172, 107, 0.52), transparent 34%),
      radial-gradient(circle at 78% 70%, rgba(171, 140, 103, 0.42), transparent 28%);
    mix-blend-mode: soft-light;
    filter: blur(10px) saturate(1.16);
    opacity: 0.9;
    animation:
      orbMarbleDrift 18s ease-in-out infinite,
      orbWarmPresence var(--breath-duration) linear infinite;
  }

  .intro-breathing-orb::after {
    background:
      radial-gradient(circle at 38% 22%, rgba(255, 240, 220, 0.62), transparent 26%),
      radial-gradient(circle at 72% 42%, rgba(188, 206, 176, 0.62), transparent 30%),
      radial-gradient(circle at 34% 74%, rgba(172, 190, 205, 0.5), transparent 34%),
      radial-gradient(circle at 68% 74%, rgba(214, 177, 127, 0.42), transparent 28%);
    mix-blend-mode: screen;
    filter: blur(12px) saturate(1.12);
    opacity: 0.72;
    animation:
      orbMarbleDriftReverse 22s ease-in-out infinite,
      orbCoolPresence var(--breath-duration) linear infinite;
  }

  .intro-breathing-steps {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    width: 100%;
  }

  .intro-breathing-steps span {
    min-width: 4.85rem;
    padding: 0.46rem 0.7rem;
    border-radius: 999px;
    text-align: center;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    color: rgba(247, 238, 228, 0.42);
    background: rgba(247, 238, 228, 0.03);
    border: 1px solid rgba(248, 235, 220, 0.08);
    box-shadow:
      inset 0 1px 0 rgba(255, 247, 236, 0.04),
      0 0 0 rgba(0, 0, 0, 0);
    transform: scale(0.94);
    will-change: transform, opacity, color, background, border-color, box-shadow;
  }

  .intro-breathing-steps .is-inhale {
    animation: phaseInhale var(--breath-duration) linear infinite;
  }

  .intro-breathing-steps .is-hold {
    animation: phaseHold var(--breath-duration) linear infinite;
  }

  .intro-breathing-steps .is-exhale {
    animation: phaseExhale var(--breath-duration) linear infinite;
  }

  .intro-breathing-copy {
    display: grid;
    gap: 0.3rem;
    width: 100%;
    text-align: center;
  }

  .intro-breathing-copy p {
    margin: 0;
    color: rgba(247, 238, 228, 0.48);
    font-size: 0.97rem;
    line-height: 1.4;
    letter-spacing: 0.005em;
    transition: color 0.2s linear, opacity 0.2s linear, transform 0.2s linear;
  }

  .intro-breathing-copy .is-inhale,
  .intro-breathing-copy .is-hold,
  .intro-breathing-copy .is-exhale {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.38rem;
    line-height: 1.05;
    letter-spacing: 0.01em;
    opacity: 0.46;
    transform: translateY(0.1rem);
  }

  .intro-breathing-copy .is-inhale {
    animation: phaseInhaleText var(--breath-duration) linear infinite;
  }

  .intro-breathing-copy .is-hold {
    animation: phaseHoldText var(--breath-duration) linear infinite;
  }

  .intro-breathing-copy .is-exhale {
    animation: phaseExhaleText var(--breath-duration) linear infinite;
  }

  .intro-breathing-copy .is-center {
    color: rgba(247, 238, 228, 0.92);
    font-size: 1rem;
    font-weight: 600;
    margin-top: 0.15rem;
  }

  .intro-copy-header,
  .intro-copy-block,
  .intro-brand,
  .intro-emblem {
    align-items: center;
    text-align: center;
  }

  .intro-manifesto {
    max-width: none;
    font-size: clamp(1.15rem, 3.9vw, 1.35rem);
    line-height: 1.15;
    white-space: nowrap;
  }

  .intro-actions,
  .proof-row {
    gap: 0.5rem;
  }

  .eyebrow,
  .hero-aside-card span {
    letter-spacing: 0.14em;
  }

  .hero p,
  .section-heading p:not(.eyebrow),
  .ops-copy p:not(.eyebrow) {
    font-size: 0.98rem;
    line-height: 1.6;
  }

  .hero h1,
  .intro-core h1 {
    line-height: 1;
  }

  .intro-actions .btn,
  .hero-actions .btn {
    width: 100%;
    text-align: center;
  }

  .proof-chip {
    width: 100%;
  }

  .section {
    padding: 1rem;
  }

  .section-heading {
    margin-bottom: 0.85rem;
  }

  .section-heading-surface {
    padding: 0.9rem 1rem;
    border-radius: 20px;
  }

  .card,
  .ops-panel {
    padding: 1rem 0.95rem;
  }

  .intro-shell {
    width: 100%;
    min-height: 100dvh;
    padding: 0;
    gap: 0;
  }

  .intro-actions {
    margin-top: auto;
    margin-bottom: max(1rem, env(safe-area-inset-bottom));
    justify-content: center;
    width: 100%;
    position: relative;
    z-index: 2;
  }

  .intro-actions .btn {
    width: 100%;
    min-width: 0;
    min-height: 3.9rem;
    border: 1px solid rgba(248, 235, 220, 0.18);
    border-radius: 999px;
    background: rgba(45, 32, 24, 0.82);
    color: #f7eee4;
    box-shadow:
      0 18px 40px rgba(10, 8, 7, 0.22),
      inset 0 1px 0 rgba(255, 247, 236, 0.08);
    font-size: 1.04rem;
    font-weight: 600;
    letter-spacing: 0.01em;
    backdrop-filter: blur(6px);
  }

  @keyframes breathePulse {
    0%, 100% {
      transform: scale(0.82);
      opacity: 0.68;
    }

    18% {
      transform: scale(0.96);
      opacity: 0.84;
    }

    32% {
      transform: scale(1.08);
      opacity: 0.96;
    }

    50% {
      transform: scale(1.12);
      opacity: 1;
    }

    84% {
      transform: scale(0.9);
      opacity: 0.8;
    }
  }

  @keyframes breatheOrbPulse {
    0%, 100% {
      transform: scale(0.78);
      opacity: 0.88;
      box-shadow:
        0 0 18px rgba(255, 230, 199, 0.12),
        0 0 38px rgba(153, 124, 88, 0.1);
    }

    20% {
      transform: scale(0.96);
      opacity: 0.96;
      box-shadow:
        0 0 28px rgba(255, 236, 213, 0.22),
        0 0 74px rgba(187, 144, 95, 0.18);
    }

    32% {
      transform: scale(1.08);
      opacity: 1;
      box-shadow:
        0 0 34px rgba(255, 241, 220, 0.26),
        0 0 88px rgba(188, 144, 96, 0.24);
    }

    50% {
      transform: scale(1.12);
      opacity: 1;
      box-shadow:
        0 0 36px rgba(255, 244, 228, 0.28),
        0 0 96px rgba(193, 156, 113, 0.24);
    }

    68% {
      transform: scale(0.98);
      opacity: 0.96;
      box-shadow:
        0 0 28px rgba(225, 233, 220, 0.22),
        0 0 74px rgba(126, 140, 121, 0.2);
    }

    84% {
      transform: scale(0.84);
      opacity: 0.9;
      box-shadow:
        0 0 24px rgba(213, 223, 219, 0.18),
        0 0 58px rgba(111, 126, 125, 0.16);
    }
  }

  @keyframes breatheOrbTint {
    0%, 100% {
      filter: hue-rotate(-4deg) saturate(1.08) brightness(1.02);
    }

    20% {
      filter: hue-rotate(-12deg) saturate(1.26) brightness(1.08);
    }

    36% {
      filter: hue-rotate(-4deg) saturate(1.24) brightness(1.12);
    }

    50% {
      filter: hue-rotate(6deg) saturate(1.18) brightness(1.08);
    }

    68% {
      filter: hue-rotate(18deg) saturate(1.2) brightness(1.01);
    }

    84% {
      filter: hue-rotate(34deg) saturate(1.22) brightness(0.96);
    }
  }

  @keyframes breatheAuraPalette {
    0%, 100% {
      filter: blur(18px) hue-rotate(-4deg) saturate(1.04);
    }

    20% {
      filter: blur(18px) hue-rotate(-12deg) saturate(1.18);
    }

    50% {
      filter: blur(18px) hue-rotate(6deg) saturate(1.12);
    }

    84% {
      filter: blur(18px) hue-rotate(28deg) saturate(1.08);
    }
  }

  @keyframes breatheAuraPaletteSoft {
    0%, 100% {
      filter: blur(14px) hue-rotate(-4deg) saturate(1.02);
    }

    20% {
      filter: blur(14px) hue-rotate(-12deg) saturate(1.12);
    }

    50% {
      filter: blur(14px) hue-rotate(8deg) saturate(1.08);
    }

    84% {
      filter: blur(14px) hue-rotate(28deg) saturate(1.04);
    }
  }

  @keyframes orbMarbleDrift {
    0%, 100% {
      transform: translate(-10%, -8%) rotate(0deg) scale(1.02);
    }

    28% {
      transform: translate(4%, -2%) rotate(42deg) scale(1.08);
    }

    54% {
      transform: translate(8%, 10%) rotate(96deg) scale(1.12);
    }

    78% {
      transform: translate(-4%, 6%) rotate(148deg) scale(1.04);
    }
  }

  @keyframes orbMarbleDriftReverse {
    0%, 100% {
      transform: translate(10%, 8%) rotate(0deg) scale(1.08);
    }

    24% {
      transform: translate(-6%, 2%) rotate(-38deg) scale(1.02);
    }

    52% {
      transform: translate(-8%, -10%) rotate(-92deg) scale(1.1);
    }

    80% {
      transform: translate(5%, -4%) rotate(-146deg) scale(1.04);
    }
  }

  @keyframes orbWarmPresence {
    0%, 100% {
      opacity: 0.28;
      filter: blur(10px) saturate(1.06) hue-rotate(-4deg);
    }

    18% {
      opacity: 0.72;
      filter: blur(10px) saturate(1.16) hue-rotate(-10deg);
    }

    32%, 50% {
      opacity: 0.98;
      filter: blur(10px) saturate(1.26) hue-rotate(-12deg);
    }

    68% {
      opacity: 0.56;
      filter: blur(10px) saturate(1.1) hue-rotate(4deg);
    }

    84% {
      opacity: 0.16;
      filter: blur(10px) saturate(0.98) hue-rotate(18deg);
    }
  }

  @keyframes orbCoolPresence {
    0%, 50%, 100% {
      opacity: 0.12;
      filter: blur(12px) saturate(0.98) hue-rotate(-2deg);
    }

    62% {
      opacity: 0.48;
      filter: blur(12px) saturate(1.08) hue-rotate(16deg);
    }

    76%, 84% {
      opacity: 0.9;
      filter: blur(12px) saturate(1.16) hue-rotate(34deg);
    }
  }

  @keyframes phaseInhale {
    0%, 30% {
      color: #fffaf3;
      background: rgba(255, 244, 230, 0.44);
      border-color: rgba(255, 243, 228, 0.5);
      box-shadow:
        inset 0 1px 0 rgba(255, 247, 236, 0.26),
        0 12px 26px rgba(116, 88, 58, 0.24),
        0 0 38px rgba(247, 226, 203, 0.26);
      transform: scale(1.1);
    }

    36%, 100% {
      color: rgba(247, 238, 228, 0.4);
      background: rgba(247, 238, 228, 0.03);
      border-color: rgba(248, 235, 220, 0.08);
      box-shadow:
        inset 0 1px 0 rgba(255, 247, 236, 0.04),
        0 0 0 rgba(0, 0, 0, 0);
      transform: scale(0.94);
    }

    90%, 100% {
      color: #fffaf3;
      background: rgba(255, 244, 230, 0.34);
      border-color: rgba(255, 243, 228, 0.34);
      box-shadow:
        inset 0 1px 0 rgba(255, 247, 236, 0.18),
        0 10px 20px rgba(116, 88, 58, 0.16),
        0 0 24px rgba(247, 226, 203, 0.18);
      transform: scale(1.02);
    }
  }

  @keyframes phaseHold {
    0%, 30%, 100% {
      color: rgba(247, 238, 228, 0.4);
      background: rgba(247, 238, 228, 0.03);
      border-color: rgba(248, 235, 220, 0.08);
      box-shadow:
        inset 0 1px 0 rgba(255, 247, 236, 0.04),
        0 0 0 rgba(0, 0, 0, 0);
      transform: scale(0.94);
    }

    36%, 52% {
      color: #fffaf3;
      background: rgba(255, 244, 230, 0.46);
      border-color: rgba(255, 243, 228, 0.52);
      box-shadow:
        inset 0 1px 0 rgba(255, 247, 236, 0.28),
        0 12px 26px rgba(116, 88, 58, 0.24),
        0 0 38px rgba(247, 226, 203, 0.24);
      transform: scale(1.1);
    }
  }

  @keyframes phaseExhale {
    0%, 52%, 100% {
      color: rgba(247, 238, 228, 0.4);
      background: rgba(247, 238, 228, 0.03);
      border-color: rgba(248, 235, 220, 0.08);
      box-shadow:
        inset 0 1px 0 rgba(255, 247, 236, 0.04),
        0 0 0 rgba(0, 0, 0, 0);
      transform: scale(0.94);
    }

    58%, 84% {
      color: #fffaf3;
      background: rgba(237, 244, 239, 0.28);
      border-color: rgba(233, 241, 235, 0.32);
      box-shadow:
        inset 0 1px 0 rgba(246, 249, 247, 0.22),
        0 12px 26px rgba(76, 97, 92, 0.22),
        0 0 36px rgba(210, 227, 223, 0.24);
      transform: scale(1.08);
    }
  }

  @keyframes phaseInhaleText {
    0%, 30% {
      color: #fbf4eb;
      opacity: 1;
      transform: translateY(0);
    }

    36%, 100% {
      color: rgba(247, 238, 228, 0.4);
      opacity: 0.38;
      transform: translateY(0.1rem);
    }

    90%, 100% {
      color: rgba(251, 244, 235, 0.94);
      opacity: 0.88;
      transform: translateY(0);
    }
  }

  @keyframes phaseHoldText {
    0%, 30%, 100% {
      color: rgba(247, 238, 228, 0.4);
      opacity: 0.38;
      transform: translateY(0.1rem);
    }

    36%, 52% {
      color: #fbf4eb;
      opacity: 1;
      transform: translateY(0);
    }
  }

  @keyframes phaseExhaleText {
    0%, 52%, 100% {
      color: rgba(247, 238, 228, 0.4);
      opacity: 0.38;
      transform: translateY(0.1rem);
    }

    58%, 84% {
      color: #fbf4eb;
      opacity: 1;
      transform: translateY(0);
    }
  }

  .dune-card,
  .ritual-card {
    min-height: unset;
  }

  .split-left,
  .split-right,
  .band-shell,
  .schedule-board,
  .ops-showcase,
  .final-manifesto {
    border-radius: 20px;
  }

  .split-left h2,
  .ops-showcase h2,
  .final-manifesto h2 {
    font-size: clamp(2rem, 10vw, 2.8rem);
  }

  .split-left p,
  .band-shell p,
  .preview-caption p,
  .ops-copy p,
  .final-manifesto p {
    font-size: 0.98rem;
    line-height: 1.58;
  }

  .clay-shape {
    width: min(220px, 68vw);
  }

  .calendar-toolbar,
  .calendar-toolbar-actions {
    align-items: flex-start;
    flex-direction: column;
  }

  .calendar-toolbar-actions > * {
    width: 100%;
  }

  .calendar-range {
    width: 100%;
    text-align: center;
  }

  .mobile-concept-shell {
    padding: 0.8rem 0.8rem 1.5rem;
  }

  .mobile-device-frame {
    width: 100%;
    padding: 10px;
    border-radius: 30px;
  }

  .mobile-device-inner {
    min-height: auto;
    border-radius: 24px;
  }

  .mobile-hero-card {
    padding: 1rem 1rem 1.15rem;
  }

  .mobile-hero-card h1 {
    max-width: none;
    font-size: clamp(2.15rem, 11vw, 3.2rem);
  }

  .mobile-card-stack {
    padding: 0 0.7rem 0.7rem;
    gap: 0.75rem;
  }

  .mobile-schedule-card,
  .mobile-booking-card,
  .mobile-confirm-card {
    border-radius: 22px;
    padding: 0.9rem;
  }

  .mobile-section-head {
    gap: 0.4rem;
    align-items: flex-start;
    flex-direction: column;
  }

  .mobile-concept-class {
    border-radius: 18px;
  }

  .mobile-booking-meta {
    grid-template-columns: 1fr 1fr;
    gap: 0.7rem;
  }

  .mobile-confirm-row {
    grid-template-columns: 76px minmax(0, 1fr);
    gap: 0.75rem;
  }
}

@media (max-width: 520px) {
  .hero-card,
  .band-shell,
  .ops-showcase {
    width: 100%;
  }

  .hero-card,
  .band-shell,
  .ops-showcase,
  .final-manifesto {
    border-radius: 18px;
  }

  .hero-aside-card,
  .intro-panel-card {
    border-radius: 18px;
  }

  .calendar-month-grid {
    grid-template-columns: 1fr;
  }

  .mobile-booking-meta {
    grid-template-columns: 1fr;
  }
}

.calendar-subtitle {
  margin-top: 0;
  opacity: 0.8;
}

.calendar-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.calendar-toolbar-actions {
  display: flex;
  gap: 0.45rem;
  align-items: center;
  flex-wrap: wrap;
}

.calendar-range {
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  background: #e7d8c8;
  border: 1px solid rgba(95, 69, 46, 0.24);
  font-size: 0.86rem;
}

.calendar-shell {
  border: 1px solid rgba(66, 50, 37, 0.22);
  border-radius: 16px;
  overflow: auto;
  background: #f4ebe1;
  box-shadow: 0 12px 28px rgba(35, 25, 18, 0.14);
}

.calendar-grid-header {
  display: grid;
  grid-template-columns: 88px repeat(7, minmax(140px, 1fr));
  position: sticky;
  top: 0;
  z-index: 2;
  background: #efe4d8;
  border-bottom: 1px solid rgba(80, 62, 48, 0.2);
}

.calendar-time-head {
  padding: 0.65rem;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.calendar-day-head {
  padding: 0.65rem;
  border-left: 1px solid rgba(80, 62, 48, 0.14);
}

.calendar-day-head span {
  display: block;
  font-size: 0.73rem;
  opacity: 0.75;
}

.calendar-day-head strong {
  font-size: 0.95rem;
}

.calendar-grid-body {
  display: grid;
  grid-template-columns: 88px repeat(7, minmax(140px, 1fr));
  min-width: 1030px;
}

.calendar-time-col {
  background: #e3d4c3;
}

.calendar-time-label {
  height: 78px;
  padding: 0.35rem 0.45rem;
  font-size: 0.75rem;
  border-bottom: 1px solid rgba(80, 62, 48, 0.13);
}

.calendar-day-column {
  border-left: 1px solid rgba(80, 62, 48, 0.13);
  position: relative;
}

.calendar-day-track {
  position: relative;
}

.calendar-hour-line {
  height: 78px;
  border-bottom: 1px solid rgba(80, 62, 48, 0.12);
}

.calendar-class-block {
  position: absolute;
  left: 6px;
  right: 6px;
  border: 0;
  border-radius: 12px;
  padding: 0.4rem 0.45rem;
  text-align: left;
  background: linear-gradient(140deg, rgba(153, 103, 69, 0.95), rgba(118, 82, 58, 0.95));
  color: #f4eee8;
  box-shadow: 0 8px 18px rgba(61, 37, 24, 0.3);
  cursor: pointer;
}

.calendar-class-block strong {
  display: block;
  font-size: 0.82rem;
  line-height: 1.1;
}

.calendar-class-block small {
  display: block;
  font-size: 0.68rem;
  opacity: 0.92;
}

.calendar-class-block.is-full {
  background: linear-gradient(140deg, rgba(96, 92, 87, 0.95), rgba(62, 59, 54, 0.95));
  cursor: not-allowed;
}

.calendar-class-block.is-cancelled {
  background: linear-gradient(140deg, rgba(138, 63, 63, 0.94), rgba(97, 43, 43, 0.94));
  text-decoration: line-through;
  opacity: 0.86;
}

.calendar-month-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(150px, 1fr));
  gap: 1px;
  background: #d7c4b0;
}

.calendar-month-day {
  min-height: 170px;
  padding: 0.5rem;
  background: #f4ebe1;
  display: flex;
  flex-direction: column;
}

.calendar-month-day.is-out-month {
  opacity: 0.55;
}

.month-day-number {
  font-weight: 700;
  font-size: 0.85rem;
  margin-bottom: 0.3rem;
}

.month-day-events {
  display: grid;
  gap: 0.33rem;
}

.month-class-chip {
  border: 0;
  border-radius: 10px;
  background: linear-gradient(140deg, rgba(153, 103, 69, 0.95), rgba(118, 82, 58, 0.95));
  color: #f4eee8;
  text-align: left;
  padding: 0.35rem 0.4rem;
  cursor: pointer;
}

.month-class-chip span {
  font-size: 0.68rem;
  display: block;
  opacity: 0.9;
}

.month-class-chip strong {
  font-size: 0.72rem;
}

.month-class-chip.is-full {
  background: linear-gradient(140deg, rgba(96, 92, 87, 0.95), rgba(62, 59, 54, 0.95));
}

.month-class-chip.is-cancelled {
  background: linear-gradient(140deg, rgba(138, 63, 63, 0.94), rgba(97, 43, 43, 0.94));
  text-decoration: line-through;
}

.month-empty {
  font-size: 0.72rem;
  opacity: 0.62;
}

.booking-modal {
  border: 0;
  padding: 0;
  background: transparent;
}

.booking-modal::backdrop {
  background: rgba(8, 7, 6, 0.62);
}

.booking-modal-card {
  width: min(520px, 92vw);
  border-radius: 16px;
  border: 1px solid rgba(83, 63, 50, 0.22);
  background: linear-gradient(170deg, #f5ece2, #e2d3c1);
  color: #31271f;
  padding: 1rem;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.38);
  position: relative;
}

.booking-close {
  position: absolute;
  right: 0.45rem;
  top: 0.35rem;
  border: 0;
  background: transparent;
  font-size: 1.9rem;
  cursor: pointer;
  line-height: 1;
}

.trainer-create-card {
  margin-bottom: 1rem;
}

@media (max-width: 860px) {
  .calendar-month-grid {
    grid-template-columns: repeat(2, minmax(170px, 1fr));
  }
}

.brand {
  display: inline-flex;
  flex-direction: column;
  gap: 0.08rem;
  text-decoration: none;
}

.brand span {
  font-size: 2rem;
  line-height: 0.9;
}

.brand small {
  font-family: 'Outfit', sans-serif;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(63, 63, 59, 0.72);
}

.public-nav a {
  padding: 0.38rem 0.65rem;
  border-radius: 999px;
}

.public-nav a:hover,
.staff-nav a:hover,
.staff-nav button:hover {
  background: rgba(95, 69, 46, 0.08);
}

.nav-cta {
  color: var(--caliza) !important;
  background: linear-gradient(120deg, #8c5d40, #b27e57);
  box-shadow: 0 12px 22px rgba(58, 38, 24, 0.18);
}

.concept-nav {
  gap: 0.5rem;
}

.concept-nav a {
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(255, 247, 235, 0.06);
}

.concept-header {
  max-width: 1440px;
  margin: 0 auto;
  padding-top: 1.15rem;
  padding-bottom: 1.15rem;
  background: transparent;
  border-bottom: 0;
  backdrop-filter: none;
}

body.is-concept-board {
  background:
    radial-gradient(circle at 10% 0%, rgba(152, 109, 79, 0.14), transparent 26%),
    radial-gradient(circle at 90% 4%, rgba(130, 138, 145, 0.14), transparent 24%),
    linear-gradient(180deg, #d8bea0 0%, #cfb39a 32%, #1a1613 100%);
}

body.is-concept-board::before {
  display: none;
}

.page-shell {
  display: grid;
  gap: 1.25rem;
}

.page-hero {
  border-radius: 28px;
  padding: 1.35rem;
  border: 1px solid rgba(95, 69, 46, 0.12);
  background:
    radial-gradient(circle at 100% 0, rgba(255, 222, 188, 0.22), transparent 40%),
    linear-gradient(155deg, #efe5d8, #dfd0bf);
  box-shadow: 0 18px 38px rgba(52, 40, 28, 0.14);
}

.page-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 360px);
  gap: 1rem;
  align-items: stretch;
}

.page-hero-copy h1 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(2.2rem, 5vw, 4.2rem);
  line-height: 0.94;
  color: rgba(64, 52, 40, 0.96);
}

.page-kicker {
  margin: 0 0 0.55rem;
  font-size: 0.74rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(95, 69, 46, 0.78);
}

.page-kicker.compact {
  margin-bottom: 0.45rem;
}

.page-lede {
  margin: 0.7rem 0 0;
  max-width: 60ch;
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(60, 50, 42, 0.9);
}

.page-hero-side {
  display: grid;
  gap: 0.85rem;
}

.spotlight-card {
  border-radius: 22px;
  padding: 1rem 1.05rem;
  background: #f5ece1;
  border: 1px solid rgba(95, 69, 46, 0.12);
}

.spotlight-card.muted {
  background: linear-gradient(160deg, #2e241d, #171412);
  color: #f2ebe2;
  border-color: rgba(244, 230, 210, 0.08);
}

.spotlight-card span {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(95, 69, 46, 0.68);
}

.spotlight-card.muted span {
  color: rgba(246, 227, 199, 0.68);
}

.spotlight-card strong {
  display: block;
  line-height: 1.35;
  font-size: 1.05rem;
}

.spotlight-card p {
  margin: 0.45rem 0 0;
  line-height: 1.6;
}

.mini-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
  margin-top: 1rem;
}

.mini-stat {
  border-radius: 18px;
  padding: 0.9rem;
  background: #f5ece1;
  border: 1px solid rgba(95, 69, 46, 0.12);
}

.mini-stat span {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(95, 69, 46, 0.7);
}

.mini-stat strong {
  font-size: 1rem;
  line-height: 1.35;
  color: rgba(57, 46, 36, 0.92);
}

.page-toolbar {
  padding: 0 0.15rem;
}

.detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.detail-card {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  min-height: 100%;
}

.detail-card h2,
.detail-card h3,
.action-card h2,
.confirmation-card h2,
.booking-modal-card h3 {
  margin: 0;
}

.accent-card {
  background:
    radial-gradient(circle at 100% 0, rgba(210, 169, 127, 0.14), transparent 46%),
    linear-gradient(160deg, #342821, #171412);
  color: #f4eee7;
}

.accent-card p {
  color: rgba(241, 232, 220, 0.82);
}

.accent-card .page-kicker {
  color: rgba(245, 223, 194, 0.72);
}

.stacked-form {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.info-list {
  display: grid;
  gap: 0.65rem;
}

.info-list div {
  display: flex;
  flex-direction: column;
  gap: 0.14rem;
  padding-top: 0.65rem;
  border-top: 1px solid rgba(95, 69, 46, 0.12);
}

.info-list span {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(95, 69, 46, 0.62);
}

.info-list strong {
  font-size: 1rem;
  line-height: 1.4;
}

.action-card,
.confirmation-card {
  display: grid;
  gap: 1rem;
  text-align: center;
  justify-items: center;
  padding: 2rem 1.4rem;
}

.action-card-wide {
  text-align: left;
  justify-items: start;
}

.action-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.info-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.info-strip span,
.modal-support {
  margin: 0;
  border-radius: 999px;
  padding: 0.5rem 0.8rem;
  font-size: 0.8rem;
  background: rgba(95, 69, 46, 0.08);
  color: rgba(63, 53, 45, 0.8);
}

.qr-card {
  align-items: center;
  text-align: center;
}

@media (max-width: 900px) {
  .page-hero-grid,
  .detail-grid,
  .mini-stat-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .brand {
    gap: 0;
  }

  .brand span {
    font-size: 1.45rem;
  }

  .brand small {
    font-size: 0.64rem;
  }

  .page-hero {
    padding: 1rem;
    background: #efe3d5;
  }

  .page-kicker {
    color: rgba(103, 79, 58, 0.82);
  }

  .page-lede {
    color: rgba(78, 63, 49, 0.9);
  }

  .mini-stat {
    background: #f4eadf;
  }

  .mini-stat span {
    color: rgba(105, 81, 60, 0.74);
  }

  .ambient-lights {
    opacity: 0.38;
  }

  .light-orb {
    filter: blur(28px);
  }

  .action-stack .btn,
  .info-strip span,
  .modal-support {
    width: 100%;
    text-align: center;
  }
}

.concept-shell {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 2rem;
  padding: 1rem 1.5rem 2.5rem;
  max-width: 1440px;
  margin: 0 auto;
}

.concept-hero,
.concept-panel,
.concept-final-card {
  position: relative;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(255, 246, 232, 0.08);
  box-shadow: 0 24px 60px rgba(10, 8, 7, 0.2);
}

.concept-hero {
  min-height: 72vh;
  padding: 2rem;
  background:
    radial-gradient(circle at 18% 20%, rgba(211, 161, 115, 0.24), transparent 26%),
    radial-gradient(circle at 86% 14%, rgba(91, 111, 137, 0.24), transparent 24%),
    linear-gradient(135deg, #131110 0%, #1d1916 32%, #29211a 58%, #0f1013 100%);
}

.concept-noise {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(115deg, rgba(255, 255, 255, 0.04), transparent 38%),
    linear-gradient(300deg, rgba(214, 155, 107, 0.12), transparent 32%);
  mix-blend-mode: screen;
  pointer-events: none;
}

.concept-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 420px);
  gap: 1.5rem;
  align-items: end;
  min-height: calc(72vh - 4rem);
}

.concept-headline,
.concept-poster {
  display: grid;
  gap: 1rem;
}

.concept-label {
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(240, 226, 205, 0.64);
}

.concept-headline h1,
.concept-section-heading h2,
.concept-panel h2,
.concept-final-card h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  line-height: 0.94;
}

.concept-headline h1 {
  max-width: 10ch;
  font-size: clamp(3.4rem, 9vw, 7.4rem);
  color: #f6efdf;
}

.concept-copy,
.concept-panel p,
.concept-final-card p {
  margin: 0;
  max-width: 58ch;
  color: rgba(233, 224, 213, 0.8);
  line-height: 1.75;
}

.concept-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.concept-poster {
  align-self: stretch;
}

.concept-poster-card,
.concept-poster-aside {
  border-radius: 28px;
  padding: 1.1rem;
  border: 1px solid rgba(247, 234, 213, 0.1);
  background: rgba(248, 240, 228, 0.05);
  backdrop-filter: blur(10px);
}

.concept-poster-card span,
.concept-poster-aside p,
.concept-schedule-card span,
.concept-ritual-card span,
.concept-bundle-card p {
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.concept-poster-card span,
.concept-poster-aside p {
  color: rgba(244, 228, 204, 0.62);
}

.concept-poster-card strong {
  display: block;
  margin: 0.45rem 0;
  font-size: 1.8rem;
  line-height: 1.05;
  color: #fff7eb;
}

.concept-poster-card p {
  margin: 0;
  color: rgba(238, 231, 220, 0.8);
  line-height: 1.65;
}

.concept-poster-aside {
  display: grid;
  gap: 0.65rem;
  align-content: end;
}

.concept-poster-aside p {
  margin: 0;
}

.concept-section {
  display: grid;
  gap: 1.2rem;
}

.concept-split,
.concept-dual-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.concept-panel,
.concept-final-card {
  padding: 1.35rem;
}

.concept-panel.dark {
  background: linear-gradient(160deg, rgba(32, 27, 22, 0.96), rgba(18, 16, 15, 0.98));
  color: #f4ece1;
}

.concept-panel.light {
  background: linear-gradient(155deg, rgba(240, 232, 220, 0.92), rgba(226, 216, 203, 0.86));
  color: #2d2520;
}

.concept-panel.light .concept-label,
.concept-panel.accent .concept-label,
.concept-section-heading .concept-label,
.concept-final-card .concept-label {
  color: rgba(88, 63, 43, 0.64);
}

.concept-panel.light p,
.concept-panel.light li,
.concept-panel.accent p,
.concept-panel.accent li,
.concept-section-heading p,
.concept-final-card p {
  color: rgba(52, 42, 35, 0.82);
}

.concept-panel.accent {
  background:
    radial-gradient(circle at 100% 0, rgba(255, 215, 178, 0.18), transparent 42%),
    linear-gradient(155deg, rgba(121, 82, 54, 0.96), rgba(51, 38, 29, 0.98));
  color: #f6efe8;
}

.concept-panel.accent p,
.concept-panel.accent li,
.concept-panel.accent .concept-label {
  color: rgba(245, 234, 218, 0.82);
}

.concept-list,
.concept-program-list {
  margin: 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.65rem;
}

.concept-program-list li {
  display: grid;
  gap: 0.2rem;
}

.concept-program-list strong {
  font-size: 1rem;
}

.concept-program-list span {
  font-size: 0.94rem;
  line-height: 1.6;
}

.concept-section-heading {
  max-width: 760px;
  padding: 0 0.2rem;
}

.concept-schedule-grid,
.concept-ritual-grid,
.concept-bundle-grid {
  display: grid;
  gap: 1rem;
}

.concept-schedule-grid {
  grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr));
}

.concept-schedule-card,
.concept-ritual-card,
.concept-bundle-card {
  border-radius: 28px;
  padding: 1rem;
}

.concept-schedule-card {
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: end;
  background:
    linear-gradient(155deg, rgba(245, 238, 229, 0.9), rgba(223, 213, 198, 0.86)),
    radial-gradient(circle at 100% 0, rgba(208, 160, 117, 0.18), transparent 48%);
  color: #2b231e;
}

.concept-schedule-card.is-featured {
  background:
    radial-gradient(circle at 20% 25%, rgba(226, 176, 127, 0.3), transparent 28%),
    linear-gradient(135deg, #161311 0%, #251d16 38%, #3f2f22 100%);
  color: #f7f0e6;
}

.concept-schedule-card h3,
.concept-ritual-card h3 {
  margin: 0.4rem 0 0.3rem;
  font-size: 1.5rem;
  line-height: 1.05;
}

.concept-schedule-card p,
.concept-ritual-card p {
  margin: 0;
  line-height: 1.6;
}

.concept-schedule-card span {
  color: inherit;
  opacity: 0.65;
}

.concept-ritual-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.concept-ritual-card {
  background: rgba(247, 240, 232, 0.9);
  border: 1px solid rgba(95, 69, 46, 0.12);
}

.concept-ritual-card span {
  color: rgba(95, 69, 46, 0.62);
}

.concept-bundle-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.concept-bundle-card {
  background: rgba(255, 249, 242, 0.08);
  border: 1px solid rgba(246, 226, 198, 0.12);
  color: #f7eee3;
}

.concept-bundle-card strong {
  display: block;
  margin: 0.35rem 0;
  font-size: 1.6rem;
  line-height: 1;
}

.concept-bundle-card span {
  font-size: 0.92rem;
}

.concept-final-card {
  background:
    radial-gradient(circle at 50% 0, rgba(221, 171, 122, 0.2), transparent 46%),
    linear-gradient(145deg, rgba(18, 16, 15, 0.98), rgba(34, 27, 22, 0.96));
  color: #f3ede3;
  padding-top: 1.8rem;
  padding-bottom: 1.8rem;
}

@media (max-width: 1100px) {
  .concept-hero-grid,
  .concept-schedule-grid,
  .concept-ritual-grid,
  .concept-bundle-grid,
  .concept-split,
  .concept-dual-grid {
    grid-template-columns: 1fr;
  }

  .concept-headline h1 {
    max-width: 12ch;
  }
}

@media (max-width: 760px) {
  .concept-header {
    padding: 0.9rem 1rem;
  }

  .concept-shell {
    padding: 1rem;
  }

  .concept-hero,
  .concept-panel,
  .concept-final-card {
    border-radius: 24px;
    padding: 1rem;
  }

  .concept-hero {
    min-height: auto;
  }

  .concept-headline h1 {
    max-width: none;
    font-size: clamp(2.7rem, 15vw, 4.4rem);
  }

  .concept-actions .btn {
    width: 100%;
    text-align: center;
  }
}

.concept2-shell {
  max-width: 1440px;
  margin: 0 auto;
  padding: 1rem 1.5rem 2.5rem;
  display: grid;
  gap: 1.6rem;
}

.concept2-hero,
.concept2-panel,
.concept2-final {
  border-radius: 30px;
  border: 1px solid rgba(255, 243, 227, 0.1);
  box-shadow: 0 24px 60px rgba(16, 12, 10, 0.2);
}

.concept2-hero {
  padding: 1.8rem;
  background:
    radial-gradient(circle at 12% 20%, rgba(211, 168, 128, 0.22), transparent 24%),
    linear-gradient(135deg, #12100f 0%, #201814 35%, #2e2119 100%);
  color: #f7efe4;
}

.concept2-copy h1,
.concept2-panel h2,
.concept2-final h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  line-height: 0.94;
}

.concept2-copy h1 {
  max-width: 12ch;
  font-size: clamp(3rem, 8vw, 5.8rem);
}

.concept2-copy p:last-child {
  max-width: 58ch;
  line-height: 1.75;
  color: rgba(238, 228, 216, 0.82);
}

.concept2-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 1rem;
}

.concept2-chip-row span {
  border-radius: 999px;
  padding: 0.48rem 0.8rem;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(247, 236, 222, 0.86);
  background: rgba(255, 248, 239, 0.08);
  border: 1px solid rgba(255, 236, 215, 0.12);
}

.concept2-board,
.concept2-secondary-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(360px, 0.8fr);
  gap: 1rem;
}

.concept2-panel {
  padding: 1.25rem;
}

.concept2-agenda-panel,
.concept2-wallet-panel {
  background: linear-gradient(160deg, rgba(245, 239, 232, 0.92), rgba(227, 217, 204, 0.88));
}

.concept2-booking-panel,
.concept2-qr-panel,
.concept2-final {
  background:
    radial-gradient(circle at 100% 0, rgba(215, 171, 129, 0.16), transparent 38%),
    linear-gradient(155deg, rgba(33, 27, 23, 0.97), rgba(17, 15, 14, 0.98));
  color: #f5eee5;
}

.concept2-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
}

.concept2-status {
  border-radius: 999px;
  padding: 0.42rem 0.7rem;
  font-size: 0.76rem;
  background: rgba(95, 69, 46, 0.1);
  color: rgba(88, 63, 43, 0.82);
}

.concept2-schedule-list,
.concept2-bundle-list {
  display: grid;
  gap: 0.75rem;
}

.concept2-schedule-row,
.concept2-bundle-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  border-radius: 22px;
  padding: 0.9rem 1rem;
  background: rgba(255, 251, 246, 0.7);
  border: 1px solid rgba(95, 69, 46, 0.1);
}

.concept2-schedule-row.is-active {
  background: linear-gradient(135deg, rgba(39, 31, 26, 0.96), rgba(93, 63, 44, 0.92));
  color: #f7efe6;
}

.concept2-schedule-row strong,
.concept2-bundle-row strong {
  display: block;
  font-size: 1.04rem;
}

.concept2-schedule-row p,
.concept2-bundle-row p,
.concept2-qr-card p {
  margin: 0.2rem 0 0;
  line-height: 1.55;
}

.concept2-row-meta {
  text-align: right;
}

.concept2-row-meta span {
  display: block;
  font-weight: 700;
}

.concept2-detail-stack {
  display: grid;
  gap: 0.75rem;
  margin-top: 1rem;
}

.concept2-detail-stack div {
  display: flex;
  flex-direction: column;
  gap: 0.16rem;
  padding-top: 0.7rem;
  border-top: 1px solid rgba(255, 237, 217, 0.1);
}

.concept2-detail-stack span {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(245, 233, 215, 0.64);
}

.concept2-detail-stack strong {
  font-size: 1rem;
  line-height: 1.4;
}

.concept2-action-box {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.concept2-wallet-card,
.concept2-qr-card {
  border-radius: 24px;
  padding: 1rem;
}

.concept2-wallet-card {
  margin: 0.9rem 0 1rem;
  background: linear-gradient(145deg, rgba(37, 29, 24, 0.96), rgba(93, 64, 45, 0.9));
  color: #f7efe5;
}

.concept2-wallet-card span {
  display: block;
  font-size: 0.76rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.7;
}

.concept2-wallet-card strong {
  display: block;
  margin: 0.45rem 0;
  font-size: 4rem;
  line-height: 0.9;
}

.concept2-wallet-card p {
  margin: 0;
}

.concept2-bundle-row span {
  font-weight: 700;
  white-space: nowrap;
}

.concept2-qr-card {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
  margin-top: 1rem;
  background: rgba(255, 248, 237, 0.05);
  border: 1px solid rgba(255, 237, 217, 0.1);
}

.concept2-qr-mock {
  aspect-ratio: 1 / 1;
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.92) 12%, transparent 12%, transparent 18%, rgba(255,255,255,0.92) 18%, rgba(255,255,255,0.92) 28%, transparent 28%, transparent 34%, rgba(255,255,255,0.92) 34%),
    linear-gradient(rgba(255,255,255,0.92) 12%, transparent 12%, transparent 18%, rgba(255,255,255,0.92) 18%, rgba(255,255,255,0.92) 28%, transparent 28%, transparent 34%, rgba(255,255,255,0.92) 34%),
    #141210;
  box-shadow: inset 0 0 0 14px #f6eee4;
}

.concept2-final {
  padding: 1.35rem;
}

@media (max-width: 1100px) {
  .concept2-board,
  .concept2-secondary-grid,
  .concept2-qr-card {
    grid-template-columns: 1fr;
  }

  .concept2-copy h1 {
    max-width: none;
  }
}

@media (max-width: 760px) {
  .concept2-shell {
    padding: 1rem;
  }

  .concept2-hero,
  .concept2-panel,
  .concept2-final {
    padding: 1rem;
    border-radius: 24px;
  }

  .concept2-copy h1 {
    font-size: clamp(2.5rem, 14vw, 4.3rem);
  }

  .concept2-chip-row span,
  .concept2-action-box .btn {
    width: 100%;
    text-align: center;
  }

  .concept2-panel-head,
  .concept2-schedule-row,
  .concept2-bundle-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .concept2-row-meta {
    text-align: left;
  }

  .concept2-wallet-card strong {
    font-size: 3.2rem;
  }
}

.mobile-concept-shell {
  max-width: 1440px;
  margin: 0 auto;
  padding: 1rem 1.5rem 2.5rem;
  display: grid;
  place-items: center;
}

.mobile-device-frame {
  width: min(420px, 100%);
  border-radius: 42px;
  padding: 14px;
  background: linear-gradient(180deg, #201a16 0%, #0f0f12 100%);
  box-shadow: 0 28px 70px rgba(10, 8, 8, 0.28);
}

.mobile-device-inner {
  border-radius: 32px;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 10%, rgba(210, 166, 124, 0.18), transparent 24%),
    linear-gradient(180deg, #141211 0%, #261c16 34%, #f0e8de 34%, #e8ddd0 100%);
  min-height: 860px;
}

.mobile-hero-card {
  padding: 1.2rem 1.2rem 1.4rem;
  color: #f7efe5;
}

.mobile-hero-card h1,
.mobile-section-head h2,
.mobile-booking-card h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  line-height: 0.94;
}

.mobile-hero-card h1 {
  font-size: clamp(2.6rem, 12vw, 4.2rem);
  max-width: 7ch;
}

.mobile-hero-card p:last-child {
  max-width: 30ch;
  line-height: 1.7;
  color: rgba(241, 233, 222, 0.82);
}

.mobile-card-stack {
  padding: 0 0.85rem 0.85rem;
  display: grid;
  gap: 0.9rem;
}

.mobile-schedule-card,
.mobile-booking-card,
.mobile-confirm-card {
  border-radius: 28px;
  padding: 1rem;
  box-shadow: 0 16px 34px rgba(37, 25, 19, 0.12);
}

.mobile-schedule-card {
  background: rgba(252, 248, 243, 0.9);
}

.mobile-booking-card,
.mobile-confirm-card {
  background: linear-gradient(160deg, rgba(34, 28, 24, 0.97), rgba(17, 15, 14, 0.98));
  color: #f7efe5;
}

.mobile-section-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  margin-bottom: 0.8rem;
}

.mobile-section-head span {
  border-radius: 999px;
  padding: 0.35rem 0.65rem;
  font-size: 0.74rem;
  background: rgba(95, 69, 46, 0.1);
}

.mobile-class-list {
  display: grid;
  gap: 0.7rem;
}

.mobile-concept-class {
  border-radius: 22px;
  padding: 0.9rem;
  background: rgba(243, 235, 225, 0.82);
  border: 1px solid rgba(95, 69, 46, 0.1);
}

.mobile-concept-class.is-active {
  background: linear-gradient(145deg, rgba(40, 31, 26, 0.97), rgba(99, 67, 46, 0.92));
  color: #f7efe5;
}

.mobile-concept-class-top {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.45rem;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mobile-concept-class h3 {
  margin: 0;
  font-size: 1.15rem;
}

.mobile-concept-class p,
.mobile-confirm-row p {
  margin: 0.22rem 0 0;
  line-height: 1.55;
}

.mobile-booking-meta {
  display: grid;
  gap: 0.6rem;
  margin: 0.9rem 0 1rem;
}

.mobile-booking-meta div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid rgba(255, 239, 220, 0.1);
}

.mobile-booking-meta span {
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(243, 230, 214, 0.66);
}

.mobile-booking-card .btn {
  width: 100%;
  text-align: center;
  margin-top: 0.55rem;
}

.mobile-confirm-row {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 0.9rem;
  align-items: center;
}

.mobile-qr-mock {
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.92) 12%, transparent 12%, transparent 18%, rgba(255,255,255,0.92) 18%, rgba(255,255,255,0.92) 28%, transparent 28%, transparent 34%, rgba(255,255,255,0.92) 34%),
    linear-gradient(rgba(255,255,255,0.92) 12%, transparent 12%, transparent 18%, rgba(255,255,255,0.92) 18%, rgba(255,255,255,0.92) 28%, transparent 28%, transparent 34%, rgba(255,255,255,0.92) 34%),
    #141210;
  box-shadow: inset 0 0 0 10px #f6eee4;
}

.system-shell {
  max-width: 1440px;
  margin: 0 auto;
  padding: 1rem 1.5rem 2.5rem;
  display: grid;
  gap: 1rem;
}

.system-hero,
.system-panel {
  border-radius: 30px;
  border: 1px solid rgba(255, 243, 227, 0.1);
  box-shadow: 0 24px 58px rgba(17, 12, 10, 0.14);
}

.system-hero {
  padding: 1.8rem;
  background:
    radial-gradient(circle at 18% 20%, rgba(219, 170, 126, 0.16), transparent 24%),
    linear-gradient(160deg, rgba(31, 24, 20, 0.98), rgba(16, 14, 13, 0.98));
  color: #f7efe4;
}

.system-hero h1,
.system-panel h2 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  line-height: 0.96;
}

.system-hero h1 {
  font-size: clamp(3rem, 7vw, 5.4rem);
  max-width: 11ch;
}

.system-hero p:last-child {
  max-width: 64ch;
  line-height: 1.75;
  color: rgba(241, 232, 221, 0.82);
}

.system-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin-top: 1.2rem;
}

.system-chip-row span {
  border-radius: 999px;
  padding: 0.48rem 0.8rem;
  border: 1px solid rgba(244, 226, 200, 0.14);
  background: #4b382b;
  font-size: 0.73rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.scroll-hero {
  cursor: pointer;
}

.system-chip-button {
  border-radius: 999px;
  padding: 0.48rem 0.8rem;
  border: 1px solid rgba(244, 226, 200, 0.14);
  background: #4b382b;
  color: #f3eadf;
  font: inherit;
  font-size: 0.73rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}

.system-chip-button:hover {
  background: #614736;
}

.system-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.system-panel {
  padding: 1.25rem;
}

.system-panel-light {
  background: #f2e8dd;
}

.system-panel-soft {
  background: #e8dbcc;
}

.system-panel-dark {
  background:
    radial-gradient(circle at 100% 0, rgba(215, 171, 129, 0.12), transparent 30%),
    linear-gradient(160deg, #221a16, #100f0f);
  color: #f7efe5;
}

.system-panel h2 {
  font-size: clamp(1.9rem, 4vw, 3rem);
}

.system-detail-list {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.system-detail-list div {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
}

.system-detail-list span {
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.72;
}

.system-action-stack {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.calendar-concept-week {
  display: grid;
  grid-template-columns: repeat(7, minmax(120px, 1fr));
  gap: 0.75rem;
  margin-top: 1rem;
}

.calendar-concept-day,
.calendar-month-card,
.calendar-modal-mock,
.mail-chip,
.admin-input,
.ops-camera,
.admin-list-row,
.access-product-row {
  border-radius: 22px;
  border: 1px solid rgba(95, 69, 46, 0.12);
}

.calendar-concept-day {
  background: #f7efe6;
  padding: 0.8rem;
}

.calendar-concept-day header span,
.calendar-month-card span {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(83, 62, 44, 0.62);
}

.calendar-concept-day header strong,
.calendar-month-card strong {
  font-size: 1.1rem;
}

.calendar-concept-events {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.8rem;
}

.calendar-concept-event {
  border-radius: 18px;
  padding: 0.7rem;
  background: #efe4d8;
}

.calendar-concept-event.is-featured {
  background: linear-gradient(145deg, rgba(40, 31, 26, 0.97), rgba(99, 67, 46, 0.92));
  color: #f7efe5;
}

.calendar-concept-event strong,
.access-product-row strong,
.admin-list-row strong {
  display: block;
  font-size: 1rem;
}

.calendar-concept-event p,
.access-product-row p,
.admin-list-row p {
  margin: 0.2rem 0 0;
  line-height: 1.5;
}

.calendar-concept-empty {
  padding: 1rem 0.7rem;
  color: rgba(83, 62, 44, 0.62);
}

.calendar-month-strip {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.7rem;
  margin-top: 1rem;
}

.calendar-month-card {
  padding: 0.85rem;
  background: #f7efe7;
  text-align: center;
}

.calendar-month-card.is-selected {
  background: linear-gradient(145deg, rgba(40, 31, 26, 0.97), rgba(99, 67, 46, 0.92));
  color: #f7efe5;
}

.calendar-month-card p {
  margin: 0.2rem 0 0;
  opacity: 0.72;
}

.calendar-modal-mock {
  margin-top: 1rem;
  padding: 1rem;
  background: #f4eade;
}

.calendar-modal-mock p,
.calendar-modal-mock small {
  display: block;
  margin-top: 0.35rem;
  line-height: 1.6;
}

.access-product-list,
.admin-list {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.access-product-row,
.admin-list-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  padding: 0.85rem 0.9rem;
  background: #f0e5d7;
}

.mail-chip {
  margin-top: 1rem;
  padding: 0.8rem 0.9rem;
  background: #f4eade;
  width: fit-content;
}

.access-qr-card {
  display: grid;
  grid-template-columns: 168px minmax(0, 1fr);
  gap: 1rem;
  margin-top: 1rem;
  align-items: center;
}

.admin-login-mock,
.ops-mock {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.admin-input,
.ops-camera {
  padding: 0.9rem 1rem;
  background: #f7efe6;
}

.admin-input.tall {
  min-height: 120px;
}

.ops-camera {
  min-height: 180px;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 50% 45%, rgba(215, 171, 129, 0.18), transparent 28%),
    linear-gradient(160deg, rgba(36, 28, 24, 0.97), rgba(18, 17, 15, 0.98));
  color: #f7efe5;
}

.admin-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.admin-metric-grid div {
  border-radius: 22px;
  padding: 1rem;
  background: #2a211b;
  border: 1px solid rgba(255, 237, 217, 0.06);
}

.admin-metric-grid span {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(243, 230, 214, 0.66);
}

.admin-metric-grid strong {
  display: block;
  margin-top: 0.45rem;
  font-size: 3rem;
  line-height: 0.95;
}

@media (max-width: 1100px) {
  .system-grid,
  .calendar-concept-week,
  .calendar-month-strip,
  .access-qr-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .is-home .sim-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 45;
  }

  .is-home .site-header {
    position: fixed;
    top: 32px;
    left: 0;
    right: 0;
    z-index: 44;
    background: rgba(232, 232, 230, 0.58);
  }

  .landing-banner {
    padding: 0;
    margin-top: 0;
  }

  .landing-banner-card {
    min-height: 100svh;
    border-radius: 0 0 26px 26px;
    padding: 8rem 1.6rem 1.6rem;
    display: grid;
    align-content: center;
    background:
      linear-gradient(165deg, rgba(46, 35, 27, 0.94), rgba(110, 77, 54, 0.96)),
      linear-gradient(180deg, #2a211c, #77553c);
  }

  .landing-banner-card h1 {
    max-width: none;
    font-size: clamp(2.5rem, 14vw, 4.2rem);
  }

  .landing-banner-card p:last-child {
    font-size: 1rem;
    color: rgba(248, 240, 230, 0.94);
  }

  .landing-banner-hint {
    background: rgba(115, 83, 59, 0.56);
    border-color: rgba(245, 228, 206, 0.14);
    color: rgba(249, 240, 228, 0.96);
  }

  .hero-card.hero-premium {
    background:
      linear-gradient(160deg, rgba(40, 30, 24, 0.97), rgba(103, 72, 49, 0.96)),
      linear-gradient(180deg, #211916, #6f5038);
    box-shadow: 0 18px 40px rgba(27, 18, 14, 0.24);
  }

  .hero-card.hero-premium .hero-copy p:not(.eyebrow) {
    color: rgba(245, 236, 226, 0.94);
  }

  .hero-card.hero-premium .hero-aside-card {
    background: rgba(104, 72, 49, 0.78);
    border-color: rgba(248, 233, 214, 0.1);
  }

  .hero-card.hero-premium .hero-aside-card p {
    color: rgba(245, 236, 226, 0.92);
  }

  .hero {
    padding-bottom: 1.25rem;
  }

  #landing-main-hero {
    padding-top: 1.5rem;
  }

  .section-band {
    padding-top: 1.1rem;
  }

  .band-shell {
    margin-top: 0.35rem;
  }

  .split-right,
  .premium-preview {
    background: linear-gradient(160deg, #b88a62, #a47955);
  }

  .clay-shape {
    box-shadow: inset -14px -16px 34px rgba(58, 35, 23, 0.28);
  }

  .system-shell {
    padding: 1rem;
  }

  .system-hero,
  .system-panel {
    padding: 1rem;
    border-radius: 24px;
  }

  .system-hero h1 {
    max-width: none;
    font-size: clamp(2.5rem, 14vw, 4.3rem);
  }

  .system-chip-row span,
  .system-action-stack .btn {
    width: 100%;
    text-align: center;
  }

  .access-product-row,
  .admin-list-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-metric-grid {
    grid-template-columns: 1fr;
  }
}
