/* 
  RBJ Brand Palette Update
  Paleta alinhada à logo Renata Bandeira Jardim:
  bordô, malva, rosé, lavanda acinzentado e off-white.
  Alteração conservadora: preserva estrutura, seletores e responsividade.
*/
:root {
  --purple-950: #4B3035;
  --purple-900: #633F43;
  --purple-800: #744D53;
  --purple-700: #A27577;
  --purple-500: #B88A8C;
  --lilac-300: #D8C9CE;
  --lilac-200: #E6D9DB;
  --lavender-100: #F3EAEB;
  --lavender-50: #FAF7F5;
  --rose-500: #A27577;
  --rose-300: #D8C9CE;
  --rose-100: #F3EAEB;
  --offwhite: #FAF7F5;
  --white: #FFFFFF;
  --text: #4A3A40;
  --muted: #7A686E;
  --border: #E3D7DA;
  --shadow-soft: 0 18px 50px rgba(99, 63, 67, 0.10);
  --shadow-card: 0 10px 30px rgba(99, 63, 67, 0.08);
  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --color-purple-dark: var(--purple-900);
  --color-purple: var(--purple-700);
  --color-lilac: var(--purple-500);
  --color-lavender: var(--lavender-100);
  --color-lavender-soft: var(--lavender-50);
  --color-rose: var(--rose-500);
  --color-rose-soft: var(--rose-100);
  --color-offwhite: var(--offwhite);
  --color-white: var(--white);
  --color-text: var(--text);
  --color-muted: var(--muted);
  --color-border: var(--border);
  --cream: var(--offwhite);
  --lavender: var(--lavender-100);
  --rose: var(--rose-500);
  --plum: var(--purple-900);
  --lilac: var(--purple-700);
  --gold: #B88A8C;
  --graphite: var(--color-text);
}

body {
  background: var(--cream);
  color: var(--graphite);
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

a { color: inherit; text-decoration: none; }
a[aria-disabled="true"] { cursor: not-allowed; opacity: .72; }
.serif { font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif; }
.text-plum { color: var(--plum); }
.text-rose { color: var(--rose); }
.muted { color: rgba(74, 58, 64, .72); }
.muted-light { color: rgba(255, 255, 255, .74); }
.bg-cream { background: var(--cream); }
.bg-white { background: #fff; }
.bg-lavender { background: linear-gradient(135deg, rgba(243, 234, 235, .95), rgba(250, 247, 245, .72)); }
.bg-plum { background: var(--plum); }
.narrow { max-width: 880px; }

.topbar {
  background: var(--plum);
  color: rgba(255, 255, 255, .86);
  font-size: .82rem;
  letter-spacing: .04em;
  padding: .55rem 1rem;
  text-align: center;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(251, 246, 239, .92);
  border-bottom: 1px solid rgba(99, 63, 67, .09);
  backdrop-filter: blur(18px);
}

.brand span { display: block; color: var(--plum); font-weight: 800; letter-spacing: .18em; text-transform: uppercase; font-size: .78rem; }
.brand small { color: rgba(74, 58, 64, .65); }
.nav-links a { color: rgba(74, 58, 64, .76); font-weight: 600; }
.nav-links a:hover { color: var(--plum); }

.btn-plum {
  --bs-btn-bg: var(--plum);
  --bs-btn-border-color: var(--plum);
  --bs-btn-color: #fff;
  --bs-btn-hover-bg: var(--lilac);
  --bs-btn-hover-border-color: var(--lilac);
  --bs-btn-hover-color: var(--plum);
  border-radius: 999px;
  font-weight: 800;
  padding-inline: 1.35rem;
  box-shadow: 0 12px 24px rgba(99, 63, 67, .16);
}

.btn-outline-plum {
  --bs-btn-color: var(--plum);
  --bs-btn-border-color: rgba(99, 63, 67, .25);
  --bs-btn-hover-bg: var(--lavender);
  --bs-btn-hover-color: var(--plum);
  --bs-btn-hover-border-color: var(--lilac);
  border-radius: 999px;
  font-weight: 800;
}

.hero { padding: clamp(4rem, 8vw, 7rem) 0; background-image: radial-gradient(circle at 15% 10%, rgba(184, 138, 140, .42), transparent 30%), radial-gradient(circle at 85% 15%, rgba(180, 163, 169, .35), transparent 28%); }
.home-hero { position: relative; overflow: hidden; }
.home-hero::after { content: ""; position: absolute; right: -8rem; top: 20%; width: 22rem; height: 22rem; border: 1px solid rgba(180, 163, 169,.28); border-radius: 46% 54% 65% 35%; pointer-events: none; }
.section { padding: clamp(4rem, 7vw, 6rem) 0; }
.eyebrow { color: var(--lilac); font-size: .78rem; font-weight: 900; letter-spacing: .26em; text-transform: uppercase; }
.section-heading { max-width: 760px; }
.text-content { font-size: 1.05rem; line-height: 1.9; }

.proof-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }
.proof-grid div, .feature-card, .card-soft, .checkout-card, .legal-card {
  background: rgba(255, 255, 255, .86);
  border: 1px solid rgba(99, 63, 67, .1);
  border-radius: 2rem;
  box-shadow: 0 20px 60px rgba(99, 63, 67, .08);
}
.proof-grid div { padding: 1.15rem; }
.proof-grid small { display: block; color: var(--lilac); text-transform: uppercase; letter-spacing: .18em; font-size: .68rem; }
.proof-grid strong { color: var(--plum); display: block; margin-top: .35rem; }
.feature-card, .card-soft, .checkout-card, .legal-card { padding: clamp(1.35rem, 3vw, 2rem); }

.portrait-card { min-height: 520px; position: relative; overflow: hidden; border-radius: 3rem; border: 1px solid rgba(255, 255, 255, .8); background: linear-gradient(145deg, #F3EAEB, #fff, #E6D9DB); box-shadow: 0 30px 80px rgba(99, 63, 67,.18); }
.portrait-glow { position: absolute; inset: 8%; border-radius: 50%; background: radial-gradient(circle, rgba(99, 63, 67,.22), transparent 62%); filter: blur(12px); }
.portrait-body { position: absolute; left: 10%; right: 10%; bottom: 15%; padding: 1.4rem; border-radius: 2rem; background: rgba(255,255,255,.72); text-align: center; backdrop-filter: blur(12px); }
.portrait-body span { display: block; font-family: Georgia, serif; font-size: 2rem; color: var(--plum); }
.portrait-body small { text-transform: uppercase; letter-spacing: .18em; font-size: .68rem; color: rgba(74, 58, 64,.62); }
.portrait-badge { position: absolute; left: 1.2rem; bottom: 1.2rem; background: var(--plum); color: #fff; border-radius: 999px; padding: .75rem 1rem; font-weight: 800; }

.renata-photo-card { min-height: 540px; position: relative; overflow: hidden; border-radius: 3rem; background: linear-gradient(145deg, #F3EAEB, #FAF7F5 48%, #E6D9DB); border: 1px solid rgba(255,255,255,.85); box-shadow: 0 30px 80px rgba(99, 63, 67,.18); }
.renata-photo-card img { width: 100%; height: 100%; min-height: 540px; object-fit: cover; object-position: center top; display: block; }
.floral { position: absolute; z-index: 1; border-radius: 45% 55% 65% 35%; border: 1px solid rgba(99, 63, 67,.12); background: radial-gradient(circle, rgba(184, 138, 140,.45), rgba(255,255,255,.05)); }
.floral-one { width: 9rem; height: 9rem; left: 1.4rem; top: 1.4rem; transform: rotate(-18deg); }
.floral-two { width: 12rem; height: 12rem; right: -2rem; bottom: 6rem; transform: rotate(28deg); }
.renata-photo-card .portrait-body, .renata-photo-card .portrait-badge { z-index: 2; }

.authority-strip { padding: 1.5rem 0; border-bottom: 1px solid rgba(99, 63, 67,.08); }
.authority-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: .8rem; }
.authority-grid div { background: var(--cream); border: 1px solid rgba(99, 63, 67,.08); border-radius: 1.25rem; color: var(--plum); font-size: .85rem; font-weight: 800; line-height: 1.35; padding: 1rem; text-align: center; }

.text-link { color: var(--plum); font-weight: 900; border-bottom: 2px solid var(--rose); }
.timeline { display: grid; grid-template-columns: repeat(6, minmax(160px, 1fr)); gap: 1rem; overflow-x: auto; padding-bottom: .5rem; }
.timeline-card { min-height: 150px; background: var(--cream); border: 1px solid rgba(99, 63, 67,.1); border-radius: 1.6rem; color: var(--plum); display: grid; align-content: space-between; gap: 1rem; padding: 1.2rem; font-weight: 800; }
.timeline-card span { width: 2.35rem; height: 2.35rem; display: grid; place-items: center; border-radius: 50%; background: var(--plum); color: #fff; font-size: .9rem; }

.service-card { background: rgba(255,255,255,.86); border: 1px solid rgba(255,255,255,.75); border-radius: 2rem; padding: 1.35rem; box-shadow: 0 18px 45px rgba(99, 63, 67,.08); }
.service-card h3 { color: var(--plum); font-family: Georgia, serif; font-size: 1.65rem; }
.service-card p { color: rgba(74, 58, 64,.68); line-height: 1.7; }
.service-card a { color: var(--plum); font-weight: 900; }

.numbers-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 1rem; }
.number-card { background: var(--plum); border-radius: 1.8rem; color: #fff; padding: 1.4rem; min-height: 150px; display: grid; align-content: center; }
.number-card strong { display: block; font-family: Georgia, serif; font-size: clamp(2rem, 4vw, 3rem); line-height: 1; color: var(--rose); }
.number-card span { display: block; margin-top: .8rem; color: rgba(255,255,255,.78); }

.deep-card { background: var(--plum); color: #fff; padding: clamp(1.5rem, 4vw, 3rem); border-radius: 2.5rem; box-shadow: 0 25px 75px rgba(99, 63, 67, .24); }
.deep-card h3 { font-size: clamp(2rem, 4vw, 3rem); }
.quote-card { font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.08; color: var(--plum); }
.method-row { display: flex; gap: 1rem; align-items: center; background: rgba(255,255,255,.82); border-radius: 1.5rem; padding: 1rem; margin-bottom: .8rem; }
.method-row span { width: 2.5rem; height: 2.5rem; border-radius: 50%; display: grid; place-items: center; background: var(--plum); color: #fff; font-weight: 900; }
.price-box { display: inline-flex; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); border-radius: 1.5rem; padding: 1rem 1.4rem; font-size: 2rem; font-weight: 900; }

.form-control, .form-select { border-radius: 1rem; border-color: rgba(99, 63, 67,.14); padding: .85rem 1rem; background: #FAF7F5; }
.form-control:focus, .form-select:focus { border-color: var(--lilac); box-shadow: 0 0 0 .25rem rgba(180, 163, 169,.15); }
.form-label { color: rgba(74, 58, 64,.78); font-weight: 700; }
.slot-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: .7rem; }
.slot-button { border: 1px solid rgba(99, 63, 67,.16); background: #FAF7F5; color: var(--plum); border-radius: 1rem; padding: .9rem; font-weight: 800; }
.slot-button.active, .slot-button:hover { background: var(--plum); color: #fff; border-color: var(--plum); }
.reference { display: inline-block; background: var(--lavender); color: var(--plum); border-radius: 1rem; padding: .8rem 1rem; }
.legal-card { max-width: 920px; line-height: 1.9; }
.legal-card h2 { color: var(--plum); font-family: Georgia, serif; font-size: 1.65rem; margin-top: 2rem; }

.schedule-board { background: #fff; border: 1px solid rgba(99, 63, 67,.1); border-radius: 2.5rem; box-shadow: 0 25px 80px rgba(99, 63, 67,.1); padding: clamp(1rem, 3vw, 1.8rem); }
.schedule-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; margin-bottom: 1.2rem; }
.schedule-steps span { border-radius: 999px; background: var(--lavender); color: var(--plum); font-size: .8rem; font-weight: 900; padding: .7rem .8rem; text-align: center; }
.schedule-panel { background: rgba(251,246,239,.78); border: 1px solid rgba(99, 63, 67,.08); border-radius: 2rem; padding: 1.25rem; }
.service-notes { display: grid; gap: .75rem; }
.service-notes div { border-top: 1px solid rgba(99, 63, 67,.1); padding-top: .75rem; }
.service-notes strong { display: block; color: var(--plum); font-size: .9rem; }
.service-notes small { color: rgba(74, 58, 64,.62); line-height: 1.5; }
.schedule-summary { background: var(--plum); color: #fff; border-radius: 2rem; padding: 1.25rem; box-shadow: inset 0 0 0 1px rgba(255,255,255,.12); }
.schedule-summary h3 { font-family: Georgia, serif; font-size: 1.7rem; }
.schedule-summary p { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px solid rgba(255,255,255,.14); padding: .8rem 0; margin: 0; }
.schedule-summary p span, .schedule-summary small, .schedule-summary .form-check-label { color: rgba(255,255,255,.72); }
.schedule-summary p strong { text-align: right; }

.course-banner { display: grid; grid-template-columns: 1.25fr .9fr auto; gap: 2rem; align-items: center; background: radial-gradient(circle at top left, rgba(184, 138, 140,.22), transparent 38%), var(--plum); color: #fff; border-radius: 2.5rem; padding: clamp(1.5rem, 4vw, 3rem); box-shadow: 0 28px 80px rgba(99, 63, 67,.18); }
.course-banner p { color: rgba(255,255,255,.78); margin: 0; }
.course-banner ul { margin: 0; padding-left: 1.1rem; color: rgba(255,255,255,.88); display: grid; gap: .35rem; }
.testimonial-card { background: rgba(255,255,255,.86); border: 1px solid rgba(255,255,255,.75); border-radius: 2rem; padding: 1.5rem; box-shadow: 0 20px 60px rgba(99, 63, 67,.08); }
.testimonial-card p { color: rgba(74, 58, 64,.72); line-height: 1.8; }
.testimonial-card strong { color: var(--plum); display: block; }
.testimonial-card small { color: rgba(74, 58, 64,.58); }
.stars { color: var(--gold); letter-spacing: .18em; margin-bottom: 1rem; }
.contact-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.contact-grid div { background: var(--cream); border: 1px solid rgba(99, 63, 67,.08); border-radius: 1.5rem; padding: 1.15rem; }
.contact-grid span { display: block; color: var(--lilac); text-transform: uppercase; font-size: .72rem; letter-spacing: .18em; font-weight: 900; }
.contact-grid strong { display: block; color: var(--plum); margin-top: .45rem; word-break: break-word; }

.footer { background: var(--plum); color: #fff; }
.footer-links { display: grid; gap: .7rem; margin-top: 1rem; }
.footer-links a { color: rgba(255,255,255,.78); }
.footer-links a:hover { color: #fff; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.62); font-size: .82rem; padding: 1rem; text-align: center; }

@media (max-width: 767px) {
  .proof-grid { grid-template-columns: 1fr; }
  .portrait-card { min-height: 410px; }
  .site-header .btn { font-size: .78rem; padding: .55rem .8rem; }
  .authority-grid, .numbers-grid, .contact-grid, .schedule-steps { grid-template-columns: 1fr; }
  .course-banner { grid-template-columns: 1fr; }
  .renata-photo-card, .renata-photo-card img { min-height: 430px; }
}

@media (min-width: 768px) and (max-width: 1199px) {
  .authority-grid, .numbers-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .course-banner { grid-template-columns: 1fr; }
}

/* Mockup home */
.topbar-inner { display: flex; align-items: center; justify-content: center; position: relative; }
.topbar-icons { position: absolute; right: 0; display: flex; gap: .8rem; opacity: .9; }
.brand { display: inline-flex; align-items: center; gap: .75rem; }
.brand-mark { width: 2.2rem; height: 2.9rem; border-radius: 50% 50% 45% 45%; background: linear-gradient(180deg, rgba(99, 63, 67,.18), rgba(99, 63, 67,.04)); position: relative; }
.brand-mark::before { content: ""; position: absolute; left: 50%; top: .35rem; width: 1px; height: 2rem; background: var(--plum); transform: rotate(-12deg); }
.brand-mark::after { content: ""; position: absolute; left: .75rem; top: .75rem; width: 1.1rem; height: 1.1rem; border: 1px solid var(--lilac); border-left: 0; border-bottom: 0; border-radius: 90% 10%; transform: rotate(-30deg); box-shadow: .5rem .55rem 0 -.42rem var(--lilac), -.35rem .9rem 0 -.42rem var(--lilac); }
.brand-copy strong { display: block; color: var(--plum); font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.35rem; font-weight: 700; line-height: 1; letter-spacing: 0; text-transform: none; }
.brand-copy small { display: block; margin-top: .18rem; color: rgba(99, 63, 67,.7); font-size: .62rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.site-header { background: rgba(255,255,255,.94); }
.site-header nav { min-height: 74px; }
.nav-links a { font-size: .84rem; position: relative; padding: .7rem .15rem; }
.nav-links a:first-child::after { content: ""; position: absolute; left: 0; right: 0; bottom: .15rem; height: 2px; background: #B88A8C; }
.header-cta { display: inline-flex; align-items: center; gap: .45rem; white-space: nowrap; }
.mobile-menu-toggle { display: none; width: 2.6rem; height: 2.6rem; border: 1px solid var(--color-border); border-radius: .8rem; background: #fff; padding: .55rem; }
.mobile-menu-toggle span { display: block; height: 2px; background: var(--plum); border-radius: 99px; margin: .28rem 0; }

.mock-hero { min-height: 432px; background: radial-gradient(circle at 54% 52%, rgba(216, 201, 206,.36), transparent 21rem), linear-gradient(90deg, #fff 0%, #FAF7F5 58%, #fff 100%); overflow: hidden; }
.mock-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(380px, 520px) 110px; gap: 2.2rem; align-items: center; position: relative; padding-top: 2.1rem; }
.mock-eyebrow { color: var(--color-purple); text-transform: uppercase; letter-spacing: .22em; font-size: .76rem; font-weight: 900; margin-bottom: .65rem; }
.mock-hero-copy h1 { color: var(--plum); font-size: clamp(2.55rem, 5.2vw, 4.9rem); line-height: .94; letter-spacing: -.04em; max-width: 720px; }
.mock-hero-copy h1 span { color: #A27577; }
.mock-hero-copy p { max-width: 610px; color: rgba(74, 58, 64,.82); font-size: 1.02rem; line-height: 1.78; margin: 1.4rem 0; }
.mock-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.mock-actions .btn { min-width: 190px; justify-content: center; display: inline-flex; align-items: center; gap: .8rem; }
.mock-hero-visual { min-height: 350px; position: relative; display: grid; place-items: end center; }
.hero-orbit { position: absolute; width: 410px; height: 410px; border-radius: 50%; background: radial-gradient(circle at 45% 40%, rgba(180, 163, 169,.42), rgba(180, 163, 169,.12) 55%, transparent 56%); border: 1px solid rgba(99, 63, 67,.18); bottom: -5rem; }
.hero-orbit::after { content: ""; position: absolute; right: -2.6rem; top: 4rem; width: 9rem; height: 17rem; border-right: 2px solid rgba(99, 63, 67,.13); border-radius: 50%; transform: rotate(-24deg); }
.hero-person { position: relative; z-index: 2; max-height: 378px; width: auto; object-fit: contain; filter: drop-shadow(0 22px 28px rgba(75, 48, 53,.18)); }
.hero-quote { position: absolute; z-index: 3; right: -6.5rem; top: 3.3rem; width: 190px; background: rgba(255,255,255,.9); border: 1px solid rgba(99, 63, 67,.08); border-radius: 1.2rem; box-shadow: 0 22px 52px rgba(99, 63, 67,.12); padding: 1.35rem; }
.hero-quote strong { color: #D8C9CE; font-size: 2.2rem; font-family: Georgia, serif; line-height: .7; }
.hero-quote p { color: var(--plum); font-size: .82rem; line-height: 1.6; margin: .35rem 0 1rem; }
.hero-quote span { color: #B88A8C; display: block; text-align: center; }
.lavender-pot { align-self: end; justify-self: center; width: 78px; height: 150px; position: relative; }
.lavender-pot::before { content: ""; position: absolute; left: 28px; top: 10px; width: 22px; height: 105px; border-left: 2px solid #633F43; border-radius: 50%; box-shadow: -16px 18px 0 -15px #633F43, 16px 15px 0 -15px #633F43; }
.lavender-pot span { position: absolute; bottom: 0; left: 13px; width: 52px; height: 38px; background: #D8C9CE; border-radius: 0 0 1.5rem 1.5rem; }

.mock-authority-wrap { margin-top: -1.15rem; position: relative; z-index: 5; }
.mock-authority-card { background: #fff; border: 1px solid rgba(99, 63, 67,.1); border-radius: .85rem; box-shadow: 0 18px 48px rgba(99, 63, 67,.09); display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); padding: .9rem .8rem; }
.mock-authority-item { display: flex; align-items: center; gap: .75rem; padding: .65rem .9rem; border-right: 1px solid rgba(99, 63, 67,.08); min-height: 58px; }
.mock-authority-item:last-child { border-right: 0; }
.mock-authority-item strong { color: var(--plum); font-size: .74rem; line-height: 1.25; }
.mock-icon, .mock-card-icon { width: 2rem; height: 2rem; flex: 0 0 auto; border: 2px solid #633F43; border-radius: .5rem; display: inline-block; position: relative; opacity: .95; }
.mock-icon-star, .mock-icon-medal { border-radius: 50%; }
.mock-icon-group::after, .mock-icon-person::after { content: ""; position: absolute; inset: .42rem; border: 2px solid #633F43; border-radius: 50%; }
.mock-icon-brain { border-radius: 50%; }

.mock-about { padding: 4.2rem 0 2.2rem; background: radial-gradient(circle at 12% 52%, rgba(184, 138, 140,.12), transparent 18rem), var(--color-white); }
.mock-about-grid { display: grid; grid-template-columns: .8fr 1fr; gap: 4rem; align-items: center; max-width: 1040px; }
.about-photo-card { min-height: 300px; position: relative; display: grid; place-items: end center; }
.about-photo-card img { width: 330px; height: 330px; border-radius: 50% 50% 8px 8px; object-fit: cover; object-position: center top; box-shadow: 0 20px 48px rgba(99, 63, 67,.11); position: relative; z-index: 2; }
.botanical-line { position: absolute; left: 2rem; top: 0; width: 150px; height: 300px; border-left: 2px solid rgba(162, 117, 119,.16); border-radius: 50%; transform: rotate(12deg); }
.mock-section-kicker { color: #A27577; font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; font-weight: 900; position: relative; padding-left: 2.8rem; }
.mock-section-kicker::before { content: ""; position: absolute; left: 0; top: 50%; width: 2rem; height: 2px; background: #A27577; }
.about-copy h2 { color: var(--plum); font-size: clamp(2.4rem, 4vw, 4rem); line-height: .98; }
.about-copy h2 span { color: #A27577; }
.about-copy p { color: rgba(74, 58, 64,.8); line-height: 1.8; font-size: .95rem; max-width: 620px; }

.mock-timeline-section { background: #fff; padding: 1.4rem 0 2.2rem; }
.mock-center-title { color: var(--plum); text-align: center; font-size: clamp(1.7rem, 2.6vw, 2.45rem); }
.mock-center-subtitle { color: var(--color-muted); line-height: 1.65; max-width: 680px; text-align: center; margin: .7rem auto 1.4rem; }
.mock-timeline { display: grid; grid-template-columns: repeat(6, minmax(150px, 1fr)); gap: .85rem; position: relative; padding-top: 2rem; }
.mock-timeline::before { content: ""; position: absolute; left: 0; right: 0; top: .75rem; height: 2px; background: linear-gradient(90deg, transparent, #E6D9DB, #633F43, #E6D9DB, transparent); }
.mock-timeline-card { background: #fff; border: 1px solid rgba(99, 63, 67,.16); border-radius: .65rem; min-height: 160px; padding: 1rem; box-shadow: 0 10px 26px rgba(99, 63, 67,.04); position: relative; }
.timeline-dot { position: absolute; top: -1.74rem; left: 50%; width: 1.15rem; height: 1.15rem; border-radius: 50%; border: 2px solid #633F43; background: #fff; transform: translateX(-50%); }
.mock-timeline-card small { color: var(--plum); font-weight: 900; }
.mock-timeline-card h3 { color: var(--plum); font-size: .86rem; margin: .55rem 0; }
.mock-timeline-card p { color: rgba(74, 58, 64,.68); font-size: .76rem; line-height: 1.45; margin: 0; }

.mock-section.compact { background: #fff; padding: 1.2rem 0 1rem; }
.mock-service-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: .9rem; margin-top: 1.6rem; }
.mock-service-card { background: #fff; border: 1px solid var(--color-border); border-radius: .75rem; padding: 1.15rem; min-height: 175px; box-shadow: 0 10px 26px rgba(99, 63, 67,.04); }
.mock-card-icon { border-radius: .45rem; margin-bottom: .7rem; }
.mock-card-icon.small { width: 1.6rem; height: 1.6rem; margin: 0; }
.mock-service-card h3 { color: var(--plum); font-size: .95rem; font-weight: 900; }
.mock-service-card p { color: rgba(74, 58, 64,.68); font-size: .78rem; line-height: 1.45; min-height: 58px; }
.mock-service-card a { color: #633F43; font-size: .78rem; font-weight: 900; }
.mock-numbers-strip { margin-top: 1rem; background: linear-gradient(90deg, #FAF7F5, var(--color-lavender), #FAF7F5); border: 1px solid var(--color-border); border-radius: .75rem; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); padding: 1.1rem; gap: .9rem; }
.mock-numbers-strip div { display: flex; align-items: center; gap: .75rem; }
.mock-numbers-strip strong { color: var(--plum); font-family: Georgia, serif; font-size: 2rem; line-height: 1; }
.mock-numbers-strip span { color: rgba(74, 58, 64,.68); font-size: .8rem; line-height: 1.25; }

.mock-schedule-section { background: #fff; padding: 1rem 0 1.4rem; }
.mock-schedule-card { border: 1px solid var(--color-border); border-radius: .8rem; box-shadow: 0 18px 52px rgba(99, 63, 67,.08); overflow: hidden; background: #fff; }
.mock-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; padding: 1rem 1.4rem; border-bottom: 1px solid rgba(99, 63, 67,.1); }
.mock-steps span { display: flex; align-items: center; justify-content: center; gap: .5rem; color: rgba(74, 58, 64,.75); font-size: .78rem; font-weight: 900; }
.mock-steps span::before { content: ""; width: 1.3rem; height: 1.3rem; display: inline-grid; place-items: center; border-radius: 50%; background: #E6D9DB; }
.mock-steps .active::before { background: #633F43; }
.mock-schedule-grid { display: grid; grid-template-columns: 1.15fr 1.2fr .85fr 1.1fr; }
.mock-schedule-column { padding: 1.3rem; border-right: 1px solid rgba(99, 63, 67,.1); }
.mock-schedule-column h3 { color: var(--plum); font-size: 1rem; font-weight: 900; }
.mock-schedule-column p { color: rgba(74, 58, 64,.58); font-size: .78rem; }
.appointment-services { display: grid; gap: .7rem; }
.appointment-service { text-align: left; display: grid; grid-template-columns: auto 1fr; gap: .75rem; align-items: center; border: 1px solid rgba(99, 63, 67,.12); background: #fff; border-radius: .7rem; padding: .75rem; transition: .18s ease; }
.appointment-service.active, .appointment-service:hover { border-color: #633F43; background: #FAF7F5; box-shadow: 0 10px 24px rgba(99, 63, 67,.08); }
.appointment-service strong { display: block; color: var(--plum); font-size: .82rem; }
.appointment-service small { display: block; color: rgba(74, 58, 64,.58); font-size: .7rem; line-height: 1.25; }
.calendar-shell { border: 1px solid rgba(99, 63, 67,.1); border-radius: .75rem; padding: .9rem; background: #fff; }
.calendar-head { display: flex; align-items: center; justify-content: space-between; color: var(--plum); margin-bottom: .75rem; }
.calendar-head button { width: 2rem; height: 2rem; border: 0; border-radius: 50%; background: #F3EAEB; color: var(--plum); font-size: 1.2rem; }
.calendar-week, .calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: .35rem; text-align: center; }
.calendar-week span { color: rgba(74, 58, 64,.55); font-size: .68rem; font-weight: 800; }
.calendar-grid button { height: 2rem; border: 0; border-radius: 50%; background: transparent; color: var(--plum); font-size: .78rem; }
.calendar-grid button:hover, .calendar-grid button.active { background: #633F43; color: #fff; }
.calendar-grid button:disabled { cursor: not-allowed; opacity: .32; }
.calendar-grid button.muted-day { color: rgba(74, 58, 64,.22); }
.calendar-note { margin-top: .8rem; border-radius: .65rem; background: #F3EAEB; color: rgba(74, 58, 64,.68); font-size: .75rem; padding: .75rem; }
.time-column { background: #fff; }
.time-date { color: var(--plum) !important; font-weight: 900; text-align: center; }
.mock-slot-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.mock-slot-grid.is-loading, .mock-slot-grid.is-empty, .mock-slot-grid.is-error { display: block; border: 1px dashed var(--color-border); border-radius: .7rem; color: var(--color-muted); padding: 1rem; text-align: center; }
.mock-slot-grid.is-error { color: #8A4C51; background: #FAF7F5; }
.mock-order-summary { background: #FAF7F5; padding: 1.3rem; }
.mock-order-summary > a { float: right; color: #A27577; font-size: .76rem; }
.mock-order-summary h3 { color: var(--plum); font-size: 1.1rem; margin-bottom: 1.2rem; }
.summary-service { display: flex; align-items: center; gap: .8rem; background: #fff; border-radius: .8rem; padding: .8rem; margin-bottom: 1rem; }
.summary-service strong { display: block; color: var(--plum); font-size: .86rem; }
.summary-service small { color: rgba(74, 58, 64,.58); font-size: .72rem; }
.mock-order-summary dl { margin: 0; }
.mock-order-summary dl div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px solid rgba(99, 63, 67,.12); padding: .6rem 0; }
.mock-order-summary dt { color: rgba(74, 58, 64,.62); font-size: .76rem; font-weight: 700; }
.mock-order-summary dd { color: var(--plum); font-size: .76rem; font-weight: 900; margin: 0; text-align: right; }
.summary-total { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; color: var(--plum); font-weight: 900; }
.summary-total strong { font-size: 1.35rem; }
.summary-fields { display: grid; gap: .55rem; margin-bottom: .7rem; }
.summary-fields .form-control { padding: .68rem .8rem; border-radius: .65rem; font-size: .85rem; }
.safe-note { display: block; text-align: center; color: rgba(74, 58, 64,.62); margin-top: .65rem; }
.mercado-pago-seal { display: flex; align-items: center; gap: .65rem; background: #fff; border: 1px solid var(--color-border); border-radius: .7rem; margin-top: .75rem; padding: .65rem; }
.mercado-pago-seal span { color: #0477bf; font-weight: 900; font-size: .82rem; }
.mercado-pago-seal small { color: var(--color-muted); font-size: .68rem; line-height: 1.25; margin: 0; text-align: left; }

.mock-course-section { background: #fff; padding: 1rem 0; }
.mock-course-banner { display: grid; grid-template-columns: 250px 1fr auto; align-items: center; gap: 1.6rem; min-height: 175px; background: radial-gradient(circle at 10% 0%, rgba(255,255,255,.2), transparent 35%), linear-gradient(135deg, #4B3035, #633F43); color: #fff; border-radius: .8rem; overflow: hidden; padding: 0 1.6rem 0 0; }
.mock-course-banner img { align-self: end; width: 250px; height: 175px; object-fit: contain; object-position: bottom center; }
.mock-course-banner p { color: rgba(255,255,255,.72); text-transform: uppercase; letter-spacing: .18em; font-size: .68rem; font-weight: 900; margin: 0 0 .35rem; }
.mock-course-banner h2 { font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1; margin: 0; }
.mock-course-banner span { color: rgba(255,255,255,.76); font-size: .9rem; }

.mock-testimonials-section { background: #fff; padding: 1rem 0 1.5rem; }
.mock-testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; margin-top: 1.4rem; }
.mock-testimonial-card { display: grid; grid-template-columns: 58px 1fr auto; gap: .7rem 1rem; align-items: center; border: 1px solid rgba(99, 63, 67,.12); border-radius: .75rem; padding: 1.2rem; }
.mock-testimonial-card .avatar { grid-row: span 3; width: 56px; height: 56px; border-radius: 50%; background: radial-gradient(circle, #E6D9DB, #fff); border: 1px solid rgba(99, 63, 67,.1); }
.mock-testimonial-card p { grid-column: 2 / 4; color: rgba(74, 58, 64,.72); font-size: .84rem; line-height: 1.6; margin: 0; }
.mock-testimonial-card strong { color: var(--plum); font-size: .84rem; }
.mock-testimonial-card small { color: rgba(74, 58, 64,.55); font-size: .75rem; }
.mock-testimonial-card .stars { justify-self: end; font-size: .85rem; letter-spacing: .08em; }
.more-link { display: block; width: max-content; margin: 1rem auto 0; color: #633F43; font-weight: 900; font-size: .84rem; }

.mock-lead-band { background: #fff; padding: 1.5rem 0; }
.mock-lead-card { display: grid; grid-template-columns: .9fr 1.4fr; gap: 1.5rem; align-items: center; border-radius: .8rem; background: linear-gradient(90deg, #F3EAEB, #fff, #F3EAEB); padding: 1.6rem; position: relative; overflow: hidden; }
.mock-lead-card::before, .mock-lead-card::after { content: ""; position: absolute; width: 105px; height: 170px; border-left: 1px solid rgba(162, 117, 119,.16); border-radius: 50%; pointer-events: none; }
.mock-lead-card::before { left: 1.2rem; bottom: -2rem; transform: rotate(24deg); }
.mock-lead-card::after { right: 1.2rem; top: -2rem; transform: rotate(-24deg); }
.mock-lead-card > * { position: relative; z-index: 1; }
.mock-lead-card h2 { color: var(--plum); font-size: 1.8rem; }
.mock-lead-card p { color: rgba(74, 58, 64,.68); font-size: .86rem; }
.mock-lead-card .lead-form { box-shadow: none; border: 0; background: transparent; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem; }
.mock-lead-card .lead-form .row { display: contents; }
.mock-lead-card .lead-form .col-md-6 { width: auto; }
.mock-lead-card .lead-form .form-label { display: none; }
.mock-lead-card .lead-form .form-check, .mock-lead-card .lead-form button, .mock-lead-card .lead-form .form-message { grid-column: 1 / -1; }
.mock-lead-card .lead-form .form-check { font-size: .78rem; color: rgba(74, 58, 64,.65); margin: 0; }

.mock-contact-section { background: #fff; padding: 1.5rem 0 1rem; }
.mock-contact-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: .9rem; align-items: stretch; }
.mock-contact-grid div, .mock-contact-grid .btn { border-radius: .75rem; min-height: 78px; }
.mock-contact-grid div { border: 1px solid rgba(99, 63, 67,.12); padding: .9rem; }
.mock-contact-grid span { color: var(--plum); font-size: .78rem; font-weight: 900; display: block; }
.mock-contact-grid strong { color: var(--plum); display: block; font-size: .78rem; margin-top: .2rem; word-break: break-word; }
.mock-contact-grid small { color: rgba(74, 58, 64,.55); font-size: .68rem; }
.mock-contact-grid .btn { display: grid; place-items: center; align-self: stretch; }

.mock-final-cta { background: linear-gradient(90deg, #fff, #F3EAEB, #fff); padding: 1.4rem 0 1rem; text-align: center; }
.mock-final-cta h2 { color: var(--plum); font-size: 2rem; }
.mock-final-cta p { color: rgba(74, 58, 64,.72); }
.mock-final-cta div div { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }

@media (max-width: 1199px) {
  .mobile-menu-toggle { display: inline-block; order: 2; }
  .header-cta { order: 3; }
  .nav-links { order: 4; position: absolute; left: 1rem; right: 1rem; top: calc(100% + .35rem); background: #fff; border: 1px solid var(--color-border); border-radius: 1rem; box-shadow: 0 20px 45px rgba(99, 63, 67,.12); padding: 1rem; flex-direction: column; gap: .35rem !important; }
  .nav-links.is-open { display: flex !important; }
  .nav-links a { padding: .75rem; }
  .nav-links a:first-child::after { display: none; }
  .site-header { position: sticky; }
  .site-header nav { position: relative; }
  .mock-hero-grid { grid-template-columns: 1fr 420px; }
  .lavender-pot { display: none; }
  .hero-quote { right: 0; }
  .mock-authority-card, .mock-service-grid, .mock-numbers-strip { grid-template-columns: repeat(3, 1fr); }
  .mock-timeline { overflow-x: auto; }
  .mock-schedule-grid { grid-template-columns: 1fr 1fr; }
  .mock-order-summary { grid-column: span 2; }
  .mock-course-banner { grid-template-columns: 180px 1fr; padding: 1.4rem; }
  .mock-course-banner img { width: 180px; }
  .mock-contact-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 767px) {
  .topbar-icons { display: none; }
  .topbar { font-size: .72rem; padding: .5rem .8rem; }
  .brand-mark { width: 1.8rem; height: 2.3rem; }
  .brand-copy strong { font-size: 1.05rem; }
  .brand-copy small { font-size: .52rem; }
  .header-cta { display: none; }
  .mock-hero-grid, .mock-about-grid, .mock-lead-card { grid-template-columns: 1fr; }
  .mock-hero { text-align: center; }
  .mock-actions { justify-content: center; }
  .mock-hero-visual { min-height: 320px; }
  .hero-person { max-height: 330px; }
  .hero-orbit { width: 330px; height: 330px; }
  .hero-quote { display: none; }
  .mock-authority-card, .mock-service-grid, .mock-numbers-strip, .mock-schedule-grid, .mock-testimonials-grid, .mock-contact-grid, .mock-lead-card .lead-form { grid-template-columns: 1fr; }
  .mock-authority-card { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mock-authority-item { border-right: 0; border-bottom: 1px solid rgba(99, 63, 67,.08); }
  .mock-order-summary { grid-column: auto; }
  .mock-steps { grid-template-columns: 1fr 1fr; }
  .mock-course-banner { grid-template-columns: 1fr; text-align: center; padding: 1.4rem; }
  .mock-course-banner img { margin: 0 auto; }
  .mock-testimonial-card { grid-template-columns: 1fr; text-align: center; }
  .mock-testimonial-card p { grid-column: auto; }
  .mock-testimonial-card .avatar { grid-row: auto; margin: 0 auto; }
  .mock-timeline { display: grid; grid-template-columns: 1fr; overflow: visible; padding-left: 1.5rem; }
  .mock-timeline::before { left: .45rem; right: auto; top: 0; bottom: 0; width: 2px; height: auto; background: linear-gradient(180deg, transparent, #E6D9DB, #633F43, #E6D9DB, transparent); }
  .timeline-dot { left: -1.05rem; top: 1rem; transform: none; }
}

/* Premium Home rebuild */
.container-xl { max-width: 1220px; }

body {
  background: var(--white);
  color: var(--text);
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
}

a { transition: color .2s ease, border-color .2s ease, background .2s ease, transform .2s ease, box-shadow .2s ease; }
a[aria-disabled="true"] { cursor: not-allowed; opacity: .68; pointer-events: auto; }

.topbar {
  min-height: 36px;
  display: flex;
  align-items: center;
  background: linear-gradient(90deg, var(--purple-950), var(--purple-700), var(--purple-900));
  color: rgba(255,255,255,.9);
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .01em;
  padding: .45rem 1rem;
}

.topbar-inner { width: 100%; display: flex; align-items: center; justify-content: center; position: relative; }
.topbar-icons { position: absolute; right: 0; top: 50%; transform: translateY(-50%); display: inline-flex; gap: .75rem; font-size: .82rem; color: rgba(255,255,255,.82); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(255,255,255,.94);
  border-bottom: 1px solid rgba(227, 215, 218,.76);
  box-shadow: 0 10px 28px rgba(75, 48, 53,.05);
  backdrop-filter: blur(18px);
}

.site-header nav { min-height: 76px; padding-top: .8rem !important; padding-bottom: .8rem !important; }
.brand { display: inline-flex; align-items: center; gap: .75rem; min-width: max-content; position: relative; }
.brand-logo { display: block; width: auto; height: 3.05rem; max-width: 230px; object-fit: contain; object-position: left center; }
.brand-copy-fallback { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; }
.brand-mark { width: 2.25rem; height: 2.9rem; border-radius: 50% 50% 46% 46%; background: linear-gradient(180deg, rgba(230, 217, 219,.32), rgba(250, 247, 245,.3)); position: relative; }
.brand-mark::before { content: ""; position: absolute; left: 50%; top: .35rem; width: 1px; height: 2rem; background: var(--purple-800); transform: rotate(-12deg); }
.brand-mark::after { content: ""; position: absolute; left: .72rem; top: .74rem; width: 1.15rem; height: 1.15rem; border: 1.5px solid var(--purple-700); border-left: 0; border-bottom: 0; border-radius: 95% 5%; transform: rotate(-30deg); box-shadow: .55rem .55rem 0 -.42rem var(--purple-700), -.38rem .92rem 0 -.42rem var(--purple-700); }
.brand-copy strong { display: block; color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.48rem; font-weight: 700; line-height: .92; letter-spacing: -.01em; text-transform: none; }
.brand-copy small { display: block; margin-top: .22rem; color: rgba(99, 63, 67,.72); font-size: .62rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.nav-links a { color: var(--text); font-size: .82rem; font-weight: 700; padding: .8rem .1rem; position: relative; }
.nav-links a:hover { color: var(--purple-700); }
.nav-links a:first-child::after { content: ""; position: absolute; left: 0; right: 0; bottom: .2rem; height: 2px; background: var(--rose-500); border-radius: 999px; }
.header-cta { display: inline-flex; align-items: center; gap: .55rem; white-space: nowrap; }
.mobile-menu-toggle { display: none; width: 2.65rem; height: 2.65rem; border: 1px solid var(--border); border-radius: .9rem; background: var(--white); box-shadow: var(--shadow-card); padding: .55rem; }
.mobile-menu-toggle span { display: block; height: 2px; background: var(--purple-900); border-radius: 99px; margin: .3rem 0; }

.btn {
  border-radius: 999px;
  font-family: "Inter", sans-serif;
  font-size: .86rem;
  font-weight: 800;
  padding: .82rem 1.35rem;
  line-height: 1;
}

.btn-primary-soft {
  --bs-btn-bg: var(--purple-900);
  --bs-btn-border-color: var(--purple-900);
  --bs-btn-color: var(--white);
  --bs-btn-hover-bg: var(--purple-700);
  --bs-btn-hover-border-color: var(--purple-700);
  --bs-btn-hover-color: var(--white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .65rem;
  box-shadow: 0 16px 34px rgba(99, 63, 67,.18);
}

.btn-primary-soft:hover { transform: translateY(-1px); box-shadow: 0 20px 38px rgba(99, 63, 67,.22); }

.btn-outline-soft {
  --bs-btn-color: var(--purple-900);
  --bs-btn-border-color: rgba(116, 77, 83,.28);
  --bs-btn-bg: rgba(255,255,255,.68);
  --bs-btn-hover-bg: var(--lavender-100);
  --bs-btn-hover-border-color: var(--purple-500);
  --bs-btn-hover-color: var(--purple-900);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .65rem;
}

.btn-light-soft {
  --bs-btn-bg: var(--white);
  --bs-btn-border-color: var(--white);
  --bs-btn-color: var(--purple-900);
  --bs-btn-hover-bg: var(--lavender-100);
  --bs-btn-hover-border-color: var(--lavender-100);
  --bs-btn-hover-color: var(--purple-900);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .65rem;
}

.btn-icon-calendar { width: 1rem; height: 1rem; border: 1.6px solid currentColor; border-radius: .22rem; position: relative; display: inline-block; }
.btn-icon-calendar::before { content: ""; position: absolute; left: .16rem; right: .16rem; top: .3rem; height: 1.5px; background: currentColor; }
.btn-icon-calendar::after { content: ""; position: absolute; left: .25rem; top: -.2rem; width: .46rem; height: .28rem; border-left: 1.5px solid currentColor; border-right: 1.5px solid currentColor; }

.section-pad { padding: clamp(4.4rem, 8vw, 7.2rem) 0; }
.section-pad-sm { padding: clamp(2.8rem, 6vw, 4.8rem) 0; }
.section-title { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.55rem, 4.8vw, 3.4rem); font-weight: 700; line-height: .98; letter-spacing: -.025em; margin: 0; }
.section-title.centered { max-width: 850px; margin: 0 auto; text-align: center; }
.section-subtitle { max-width: 700px; margin: 1rem auto 2rem; color: var(--muted); font-size: 1.03rem; line-height: 1.7; text-align: center; }
.eyebrow, .section-kicker { color: var(--purple-700); font-size: .74rem; font-weight: 900; letter-spacing: .22em; line-height: 1.2; text-transform: uppercase; }
.section-kicker { color: var(--rose-500); position: relative; padding-left: 3rem; margin-bottom: .8rem; }
.section-kicker::before { content: ""; position: absolute; left: 0; top: 50%; width: 2.2rem; height: 2px; background: var(--rose-500); border-radius: 99px; }

.line-icon { width: 2.35rem; height: 2.35rem; display: inline-block; flex: 0 0 auto; border: 2px solid currentColor; border-radius: .65rem; color: var(--purple-700); position: relative; background: rgba(243, 234, 235,.72); }
.line-icon::before, .line-icon::after { content: ""; position: absolute; border-color: currentColor; }
.icon-cap { border-radius: .5rem; border-width: 0; background: transparent; }
.icon-cap::before { left: .25rem; right: .25rem; top: .64rem; height: .85rem; border: 2px solid currentColor; transform: skew(-20deg) rotate(-2deg); }
.icon-cap::after { left: .82rem; top: 1.35rem; width: .72rem; height: .44rem; border-left: 2px solid currentColor; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; border-radius: 0 0 .35rem .35rem; }
.icon-brain, .icon-medal, .icon-person, .icon-group, .icon-people, .icon-star, .icon-therapy { border-radius: 50%; }
.icon-brain::before { inset: .43rem; border: 2px solid currentColor; border-radius: 50% 45% 50% 45%; }
.icon-brain::after { top: .4rem; bottom: .4rem; left: 50%; border-left: 2px solid currentColor; }
.icon-person::before { top: .42rem; left: 50%; width: .65rem; height: .65rem; border: 2px solid currentColor; border-radius: 50%; transform: translateX(-50%); }
.icon-person::after { left: .55rem; right: .55rem; bottom: .45rem; height: .62rem; border: 2px solid currentColor; border-radius: 50% 50% 0 0; }
.icon-group::before, .icon-people::before { top: .55rem; left: .55rem; width: .45rem; height: .45rem; border: 2px solid currentColor; border-radius: 50%; box-shadow: .74rem 0 0 -.02rem var(--lavender-50), .74rem 0 0 0 currentColor; }
.icon-group::after, .icon-people::after { left: .43rem; right: .43rem; bottom: .55rem; height: .55rem; border: 2px solid currentColor; border-radius: 50% 50% 0 0; }
.icon-medal::before { left: .72rem; right: .72rem; top: .34rem; height: .75rem; border-left: 2px solid currentColor; border-right: 2px solid currentColor; transform: skew(-12deg); }
.icon-medal::after { left: 50%; bottom: .42rem; width: .82rem; height: .82rem; border: 2px solid currentColor; border-radius: 50%; transform: translateX(-50%); }
.icon-star::before { left: 50%; top: 50%; width: 1.1rem; height: 1.1rem; border: 2px solid currentColor; transform: translate(-50%, -50%) rotate(45deg); border-radius: .18rem; }
.icon-building::before { left: .55rem; right: .55rem; bottom: .5rem; height: 1.25rem; border: 2px solid currentColor; border-bottom: 0; }
.icon-building::after { left: .85rem; bottom: .5rem; width: .2rem; height: .2rem; background: currentColor; box-shadow: .45rem 0 0 currentColor, .9rem 0 0 currentColor, 0 -.42rem 0 currentColor, .45rem -.42rem 0 currentColor, .9rem -.42rem 0 currentColor; }
.icon-sofa::before { left: .35rem; right: .35rem; bottom: .62rem; height: .68rem; border: 2px solid currentColor; border-radius: .5rem .5rem .25rem .25rem; }
.icon-sofa::after { left: .5rem; right: .5rem; bottom: .42rem; border-bottom: 2px solid currentColor; box-shadow: -.15rem -.34rem 0 -.06rem currentColor, 1.2rem -.34rem 0 -.06rem currentColor; }
.icon-mic::before { left: 50%; top: .38rem; width: .74rem; height: 1.18rem; border: 2px solid currentColor; border-radius: 99px; transform: translateX(-50%); }
.icon-mic::after { left: 50%; bottom: .38rem; width: 1.1rem; height: .7rem; border: 2px solid currentColor; border-top: 0; border-radius: 0 0 .8rem .8rem; transform: translateX(-50%); }
.icon-clipboard::before { left: .54rem; right: .54rem; top: .5rem; bottom: .42rem; border: 2px solid currentColor; border-radius: .25rem; }
.icon-clipboard::after { left: .86rem; right: .86rem; top: .34rem; height: .42rem; border: 2px solid currentColor; border-radius: .22rem; background: var(--white); }
.icon-therapy::before { left: .62rem; top: .38rem; width: .68rem; height: .68rem; border: 2px solid currentColor; border-radius: 50%; }
.icon-therapy::after { right: .45rem; bottom: .45rem; width: 1.05rem; height: 1.05rem; border: 2px solid currentColor; border-radius: 50%; }

.hero:not(.bg-cream) {
  position: relative;
  overflow: hidden;
  min-height: 620px;
  padding: clamp(3rem, 5vw, 4.8rem) 0 3.4rem;
  background: radial-gradient(circle at 67% 47%, rgba(230, 217, 219,.38), transparent 22rem), linear-gradient(90deg, #fff 0%, #fff 48%, var(--lavender-50) 76%, #fff 100%);
}

.hero:not(.bg-cream)::before, .hero:not(.bg-cream)::after {
  content: "";
  position: absolute;
  pointer-events: none;
  border-left: 1.5px solid rgba(162, 117, 119,.14);
  border-radius: 50%;
}

.hero:not(.bg-cream)::before { right: 7vw; top: 8rem; width: 150px; height: 300px; transform: rotate(-26deg); }
.hero:not(.bg-cream)::after { right: 2.4vw; bottom: 2rem; width: 86px; height: 170px; transform: rotate(12deg); }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr); align-items: center; gap: clamp(2rem, 5vw, 4.5rem); position: relative; z-index: 1; }
.hero-copy { padding-top: 1rem; }
.hero-copy h1 { max-width: 700px; margin: 0; color: var(--purple-950); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(3.45rem, 6vw, 4rem); font-weight: 700; line-height: .97; letter-spacing: -.042em; }
.hero-copy h1 span { color: var(--rose-500); }
.hero-text { max-width: 650px; color: rgba(74, 58, 64,.84); font-size: 1.06rem; line-height: 1.78; margin: 1.35rem 0 1.6rem; }
.hero-actions { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.hero-actions .btn { min-width: 190px; }
.hero-visual { min-height: 485px; position: relative; display: grid; place-items: end center; }
.hero-orb { position: absolute; left: 50%; bottom: -1.3rem; width: min(92%, 500px); aspect-ratio: 1; border-radius: 50% 50% 44% 56%; background: radial-gradient(circle at 45% 36%, rgba(230, 217, 219,.85), rgba(230, 217, 219,.55) 54%, rgba(250, 247, 245,.1) 55%); border: 1px solid rgba(162, 117, 119,.13); transform: translateX(-50%); }
.hero-orb::after { content: ""; position: absolute; right: -3rem; top: 4rem; width: 9rem; height: 18rem; border-right: 2px solid rgba(162, 117, 119,.13); border-radius: 50%; transform: rotate(-22deg); }
.hero-image { position: relative; z-index: 2; max-height: 500px; width: auto; max-width: 92%; object-fit: contain; object-position: bottom center; filter: drop-shadow(0 24px 32px rgba(75, 48, 53,.16)); }
.hero-floating-card { position: absolute; z-index: 4; right: -1.4rem; top: 5.4rem; width: 210px; margin: 0; padding: 1.4rem 1.25rem; border: 1px solid rgba(227, 215, 218,.9); border-radius: var(--radius-lg); background: rgba(255,255,255,.9); box-shadow: var(--shadow-soft); backdrop-filter: blur(10px); }
.hero-floating-card span { display: block; color: var(--rose-300); font-family: Georgia, serif; font-size: 2.55rem; line-height: .68; }
.hero-floating-card p { margin: .42rem 0 1rem; color: var(--purple-900); font-size: .86rem; font-weight: 650; line-height: 1.62; }
.hero-floating-card i { display: block; color: var(--rose-500); font-style: normal; text-align: center; }
.hero-floral { position: absolute; z-index: 1; width: 118px; height: 250px; border-left: 1.5px solid rgba(162, 117, 119,.14); border-radius: 50%; pointer-events: none; }
.hero-floral::before, .hero-floral::after { content: ""; position: absolute; width: 32px; height: 58px; border: 1.5px solid rgba(162, 117, 119,.16); border-left: 0; border-bottom: 0; border-radius: 90% 10%; }
.hero-floral::before { left: 18px; top: 58px; transform: rotate(-36deg); }
.hero-floral::after { left: 44px; top: 122px; transform: rotate(22deg); }
.hero-floral-left { left: 0; bottom: 2.5rem; transform: rotate(18deg); opacity: .5; }
.hero-floral-right { right: 2.2rem; bottom: 4.8rem; transform: rotate(-18deg); }

.authority { position: relative; z-index: 5; margin-top: -2rem; padding-bottom: 2.5rem; background: linear-gradient(180deg, transparent 0, var(--white) 36%); }
.authority-card { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); align-items: stretch; border: 1px solid rgba(227, 215, 218,.9); border-radius: var(--radius-md); background: rgba(255,255,255,.96); box-shadow: var(--shadow-soft); overflow: hidden; }
.authority-item { min-height: 78px; display: flex; align-items: center; gap: .75rem; padding: 1rem .9rem; border-right: 1px solid rgba(227, 215, 218,.88); }
.authority-item:last-child { border-right: 0; }
.authority-item .line-icon { width: 2rem; height: 2rem; }
.authority-item strong { color: var(--purple-900); font-size: .78rem; font-weight: 800; line-height: 1.28; }

.about-section { background: radial-gradient(circle at 13% 54%, rgba(184, 138, 140,.16), transparent 18rem), var(--white); }
.about-grid { display: grid; grid-template-columns: minmax(320px, .86fr) minmax(0, 1.14fr); gap: clamp(2.5rem, 7vw, 5.8rem); align-items: center; max-width: 1080px; }
.about-visual { min-height: 430px; position: relative; display: grid; place-items: end center; }
.about-visual img { position: relative; z-index: 3; width: min(100%, 380px); height: 405px; object-fit: cover; object-position: center top; border-radius: 48% 48% .9rem .9rem; box-shadow: 0 26px 55px rgba(99, 63, 67,.12); }
.about-arch { position: absolute; z-index: 1; width: 365px; height: 388px; bottom: 0; border-radius: 50% 50% .9rem .9rem; background: linear-gradient(180deg, rgba(243, 234, 235,.96), rgba(255,255,255,.65)); border: 1px solid rgba(227, 215, 218,.95); }
.about-floral { position: absolute; z-index: 2; left: 0; bottom: 0; width: 145px; height: 320px; border-left: 1.5px solid rgba(162, 117, 119,.2); border-radius: 50%; transform: rotate(18deg); }
.about-floral::before, .about-floral::after { content: ""; position: absolute; width: 40px; height: 70px; border: 1.5px solid rgba(162, 117, 119,.2); border-left: 0; border-bottom: 0; border-radius: 90% 10%; }
.about-floral::before { left: 22px; top: 76px; transform: rotate(-35deg); }
.about-floral::after { left: 58px; top: 160px; transform: rotate(22deg); }
.about-copy h2 { max-width: 560px; color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(3rem, 5.6vw, 4.25rem); font-weight: 700; line-height: .94; letter-spacing: -.035em; margin: 0 0 1rem; }
.about-copy h2 span { color: var(--rose-500); }
.about-copy p:not(.section-kicker) { max-width: 650px; color: rgba(74, 58, 64,.82); font-size: 1rem; line-height: 1.78; margin-bottom: .95rem; }
.about-copy .btn { margin-top: .55rem; min-width: 205px; }

.timeline-section { background: var(--white); }
.timeline-track { display: grid; grid-template-columns: repeat(6, minmax(150px, 1fr)); gap: .95rem; position: relative; margin-top: 2.7rem; padding-top: 2.3rem; }
.timeline-track::before { content: ""; position: absolute; left: 0; right: 0; top: .8rem; height: 2px; background: linear-gradient(90deg, transparent, var(--lilac-200), var(--purple-700), var(--lilac-200), transparent); }
.timeline-card { position: relative; min-height: 210px; display: flex; flex-direction: column; align-items: flex-start; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); box-shadow: 0 8px 24px rgba(99, 63, 67,.045); padding: 1rem; }
.timeline-dot { position: absolute; top: -2.05rem; left: 50%; width: 1.1rem; height: 1.1rem; border: 2px solid var(--purple-700); border-radius: 50%; background: var(--white); box-shadow: 0 0 0 6px rgba(243, 234, 235,.9); transform: translateX(-50%); }
.timeline-card .line-icon { width: 2.05rem; height: 2.05rem; margin-bottom: .8rem; }
.timeline-card small { color: var(--purple-900); font-size: .76rem; font-weight: 900; }
.timeline-card h3 { color: var(--purple-900); font-family: "Inter", sans-serif; font-size: .93rem; font-weight: 850; line-height: 1.25; margin: .45rem 0 .45rem; }
.timeline-card p { color: rgba(74, 58, 64,.68); font-size: .78rem; line-height: 1.48; margin: 0; }

.services-section { background: var(--white); }
.service-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; margin-top: 2rem; }
.service-card { min-height: 240px; display: flex; flex-direction: column; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-lg); background: var(--white); box-shadow: 0 8px 24px rgba(99, 63, 67,.045); padding: 1.35rem; }
.service-card:hover { transform: translateY(-4px); border-color: rgba(162, 117, 119,.28); box-shadow: var(--shadow-card); }
.service-card .line-icon { margin-bottom: 1rem; }
.service-card h3 { color: var(--purple-900); font-family: "Inter", sans-serif; font-size: 1rem; font-weight: 900; margin-bottom: .65rem; }
.service-card p { color: rgba(74, 58, 64,.68); font-size: .84rem; line-height: 1.52; margin-bottom: 1rem; }
.service-card a { margin-top: auto; color: var(--purple-700); font-size: .82rem; font-weight: 900; }
.service-card a:hover { color: var(--rose-500); }
.numbers-band { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: .9rem; margin-top: 1.2rem; padding: 1.15rem; border: 1px solid rgba(227, 215, 218,.9); border-radius: var(--radius-lg); background: linear-gradient(90deg, #fff, var(--lavender-100), #fff); box-shadow: 0 8px 28px rgba(99, 63, 67,.04); }
.number-item { display: grid; grid-template-columns: auto 1fr; gap: .1rem .75rem; align-items: center; min-height: 76px; }
.number-item .line-icon { grid-row: span 2; width: 2.55rem; height: 2.55rem; color: var(--purple-500); background: rgba(255,255,255,.72); }
.number-item strong { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: 2.25rem; font-weight: 700; line-height: .9; }
.number-item p { margin: 0; color: rgba(74, 58, 64,.68); font-size: .8rem; font-weight: 650; line-height: 1.25; }

.schedule-section { background: linear-gradient(180deg, var(--white), var(--lavender-50) 52%, var(--white)); }
.schedule-card { overflow: hidden; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-xl); background: var(--white); box-shadow: var(--shadow-soft); }
.schedule-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .8rem; padding: 1.05rem 1.35rem; border-bottom: 1px solid rgba(227, 215, 218,.86); }
.schedule-steps span { display: flex; align-items: center; justify-content: center; gap: .55rem; color: rgba(74, 58, 64,.68); font-size: .78rem; font-weight: 900; white-space: nowrap; }
.schedule-steps span::before { content: ""; width: 1.38rem; height: 1.38rem; border-radius: 50%; background: linear-gradient(180deg, var(--lavender-100), var(--rose-100)); box-shadow: inset 0 0 0 1px rgba(162, 117, 119,.08); }
.schedule-steps span.active { color: var(--purple-900); }
.schedule-steps span.active::before { background: var(--purple-900); box-shadow: 0 0 0 5px rgba(243, 234, 235,.95); }
.schedule-layout { display: grid; grid-template-columns: minmax(260px, 30%) minmax(360px, 40%) minmax(280px, 30%); align-items: stretch; }
.schedule-panel { padding: 1.35rem; border-right: 1px solid rgba(227, 215, 218,.86); }
.panel-label { color: var(--purple-900); font-size: 1rem; font-weight: 900; margin: 0 0 .25rem; }
.panel-hint { color: rgba(74, 58, 64,.6); font-size: .82rem; line-height: 1.45; margin: 0 0 1rem; }
.appointment-services { display: grid; gap: .75rem; }
.appointment-service { width: 100%; display: grid; grid-template-columns: auto 1fr; gap: .78rem; align-items: center; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); padding: .88rem; text-align: left; transition: background .18s ease, border-color .18s ease, box-shadow .18s ease, transform .18s ease; }
.appointment-service:hover, .appointment-service.active { border-color: rgba(162, 117, 119,.55); background: var(--lavender-50); box-shadow: 0 10px 26px rgba(99, 63, 67,.07); transform: translateY(-1px); }
.appointment-service .line-icon { width: 2rem; height: 2rem; }
.service-info strong { display: block; color: var(--purple-900); font-size: .84rem; font-weight: 900; line-height: 1.2; }
.service-info small { display: block; color: rgba(74, 58, 64,.6); font-size: .72rem; line-height: 1.3; margin-top: .22rem; }
.service-info em { display: block; color: var(--purple-700); font-size: .7rem; font-style: normal; font-weight: 900; margin-top: .28rem; }
.calendar-panel { background: linear-gradient(180deg, #fff, rgba(243, 234, 235,.5)); }
.date-time-grid { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(140px, .85fr); gap: .9rem; align-items: start; }
.calendar-box { border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); padding: .95rem; }
.calendar-head { display: flex; align-items: center; justify-content: space-between; color: var(--purple-900); margin-bottom: .8rem; }
.calendar-head strong { font-size: .92rem; font-weight: 900; text-transform: capitalize; }
.calendar-head button { width: 2rem; height: 2rem; display: grid; place-items: center; border: 0; border-radius: 50%; background: var(--lavender-100); color: var(--purple-900); font-size: 1.15rem; line-height: 1; }
.calendar-head button:hover { background: var(--purple-900); color: var(--white); }
.calendar-week, .calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: .32rem; text-align: center; }
.calendar-week span { color: rgba(74, 58, 64,.58); font-size: .66rem; font-weight: 900; }
.calendar-grid button { height: 2rem; border: 0; border-radius: 50%; background: transparent; color: var(--purple-900); font-size: .76rem; font-weight: 800; }
.calendar-grid button:hover, .calendar-grid button.active { background: var(--purple-900); color: var(--white); }
.calendar-grid button:disabled { cursor: not-allowed; opacity: .32; }
.calendar-grid button.muted-day { color: rgba(74, 58, 64,.22); }
.calendar-note { margin-top: .9rem; border-radius: .75rem; background: var(--lavender-50); color: rgba(74, 58, 64,.68); font-size: .72rem; line-height: 1.35; padding: .72rem .8rem; }
.time-box { display: grid; gap: .75rem; }
.time-box > strong { color: var(--purple-900); font-size: .82rem; font-weight: 900; line-height: 1.35; text-align: center; }
.home-slot-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .55rem; }
.slot-button { border: 1px solid rgba(227, 215, 218,.95); background: var(--white); color: var(--purple-900); border-radius: .85rem; padding: .72rem .48rem; font-size: .78rem; font-weight: 900; }
.slot-button:hover, .slot-button.active { background: var(--purple-900); border-color: var(--purple-900); color: var(--white); }
.slot-button.is-visual { border-style: dashed; }
.home-slot-grid.is-loading { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.slot-skeleton { height: 2.55rem; border-radius: .85rem; background: linear-gradient(90deg, var(--lavender-50), var(--lavender-100), var(--lavender-50)); background-size: 220% 100%; animation: slotPulse 1.2s ease-in-out infinite; }
@keyframes slotPulse { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }
.home-slot-grid.is-empty, .home-slot-grid.is-error { display: block; border: 1px dashed var(--border); border-radius: var(--radius-md); padding: 1rem; color: var(--muted); font-size: .82rem; font-weight: 750; line-height: 1.45; text-align: center; }
.home-slot-grid.is-error { background: #FAF7F5; color: #8A4C51; border-color: rgba(162, 117, 119,.3); }
.availability-message { min-height: 1.1rem; margin: 0; color: rgba(74, 58, 64,.62); font-size: .72rem; line-height: 1.35; text-align: center; }
.availability-message.is-success { color: #1f7a4d; font-weight: 800; }
.availability-message.is-error { color: #8A4C51; font-weight: 800; }
.order-summary { position: relative; background: linear-gradient(180deg, var(--lavender-50), #fff); padding: 1.35rem; }
.order-summary > a { position: absolute; right: 1.35rem; top: 1.35rem; color: var(--purple-500); font-size: .76rem; font-weight: 900; }
.order-summary h3 { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: 1.55rem; font-weight: 700; margin: 0 0 1.2rem; padding-right: 3rem; }
.summary-service { display: flex; align-items: center; gap: .78rem; border: 1px solid rgba(227, 215, 218,.86); border-radius: var(--radius-md); background: var(--white); padding: .8rem; margin-bottom: 1rem; }
.summary-service .line-icon { width: 2.1rem; height: 2.1rem; }
.summary-service strong { display: block; color: var(--purple-900); font-size: .86rem; font-weight: 900; }
.summary-service small { display: block; color: rgba(74, 58, 64,.58); font-size: .72rem; line-height: 1.3; margin-top: .2rem; }
.order-summary dl { margin: 0; }
.order-summary dl div { display: flex; justify-content: space-between; gap: 1rem; border-bottom: 1px solid rgba(227, 215, 218,.95); padding: .65rem 0; }
.order-summary dt { color: rgba(74, 58, 64,.62); font-size: .76rem; font-weight: 750; }
.order-summary dd { color: var(--purple-900); font-size: .76rem; font-weight: 900; margin: 0; text-align: right; }
.summary-total { display: flex; justify-content: space-between; align-items: center; color: var(--purple-900); font-weight: 900; padding: 1rem 0; }
.summary-total strong { font-size: 1.35rem; }
.summary-fields { display: grid; gap: .58rem; margin-bottom: .72rem; }
.summary-fields .form-control, .lead-form .form-control, .lead-form .form-select { border: 1px solid rgba(227, 215, 218,.95); border-radius: .9rem; background: rgba(255,255,255,.92); color: var(--text); font-size: .85rem; padding: .78rem .9rem; }
.summary-fields .form-control:focus, .lead-form .form-control:focus, .lead-form .form-select:focus { border-color: var(--purple-500); box-shadow: 0 0 0 .22rem rgba(184, 138, 140,.16); }
.summary-check { color: rgba(74, 58, 64,.68); font-size: .76rem; line-height: 1.35; margin-bottom: .9rem; }
.mercado-pago-seal { display: flex; align-items: center; gap: .68rem; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); padding: .72rem; margin-top: .8rem; }
.mercado-pago-seal span { color: #0477bf; font-size: .86rem; font-weight: 950; }
.mercado-pago-seal small { color: var(--muted); font-size: .69rem; line-height: 1.3; }
.safe-note { display: block; color: rgba(74, 58, 64,.62); font-size: .72rem; text-align: center; margin-top: .72rem; }

.course-callout { background: var(--white); }
.course-banner { min-height: 210px; display: grid; grid-template-columns: 260px minmax(0, 1fr) auto 255px; align-items: center; gap: 1.5rem; overflow: hidden; border-radius: var(--radius-lg); background: radial-gradient(circle at 10% 12%, rgba(255,255,255,.18), transparent 32%), linear-gradient(135deg, var(--purple-950), var(--purple-700)); color: var(--white); box-shadow: var(--shadow-soft); padding: 0 1.5rem 0 0; }
.course-image-wrap { align-self: stretch; display: grid; place-items: end center; position: relative; overflow: hidden; }
.course-image-wrap::before { content: ""; position: absolute; left: 1rem; bottom: -1.8rem; width: 130px; height: 260px; border-left: 1.5px solid rgba(255,255,255,.16); border-radius: 50%; transform: rotate(20deg); }
.course-image-wrap img { position: relative; z-index: 1; width: 255px; height: 205px; object-fit: contain; object-position: bottom center; filter: drop-shadow(0 18px 28px rgba(0,0,0,.18)); }
.course-copy p { color: rgba(255,255,255,.72); font-size: .7rem; font-weight: 900; letter-spacing: .18em; text-transform: uppercase; margin: 0 0 .45rem; }
.course-copy h2 { color: var(--white); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.35rem, 4.8vw, 3.55rem); font-weight: 700; line-height: .94; letter-spacing: -.03em; margin: 0 .1rem .55rem 0; }
.course-copy span { color: rgba(255,255,255,.8); display: block; max-width: 600px; font-size: .94rem; line-height: 1.55; }
.course-banner ul { display: grid; gap: .45rem; list-style: none; margin: 0; padding: 0; color: rgba(255,255,255,.88); font-size: .82rem; font-weight: 700; }
.course-banner li::before { content: "○"; color: var(--rose-300); font-weight: 900; margin-right: .5rem; }

.testimonials-section { background: var(--white); }
.testimonial-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.15rem; margin-top: 1.8rem; }
.testimonial-card { min-height: 230px; display: grid; grid-template-columns: auto 1fr; gap: .25rem .85rem; align-content: start; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-lg); background: var(--white); box-shadow: 0 8px 24px rgba(99, 63, 67,.045); padding: 1.35rem; }
.quote-mark { grid-row: span 4; color: var(--rose-300); font-family: Georgia, serif; font-size: 3rem; line-height: .8; }
.testimonial-card p { color: rgba(74, 58, 64,.72); font-size: .9rem; line-height: 1.68; margin: 0 0 .7rem; }
.testimonial-card strong { color: var(--purple-900); font-size: .9rem; font-weight: 900; }
.testimonial-card small { color: rgba(74, 58, 64,.58); font-size: .78rem; }
.testimonial-card .stars { color: var(--purple-700); font-size: .86rem; letter-spacing: .1em; margin-top: .7rem; }

.lead-section { background: var(--white); }
.lead-card { position: relative; display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.45fr); gap: 1.8rem; align-items: center; overflow: hidden; border: 1px solid rgba(227, 215, 218,.9); border-radius: var(--radius-xl); background: linear-gradient(90deg, var(--lavender-100), #fff 47%, var(--lavender-100)); padding: clamp(1.5rem, 3vw, 2.05rem); }
.lead-copy h2 { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2rem, 3.4vw, 2.65rem); font-weight: 700; line-height: 1; letter-spacing: -.025em; margin: 0 0 .75rem; }
.lead-copy h2 span { display: block; }
.lead-copy p { max-width: 390px; color: rgba(74, 58, 64,.72); font-size: .92rem; line-height: 1.6; margin: 0; }
.lead-floral { position: absolute; width: 135px; height: 260px; border-left: 1.5px solid rgba(162, 117, 119,.15); border-radius: 50%; pointer-events: none; }
.lead-floral.left { left: 1.4rem; bottom: -3.2rem; transform: rotate(24deg); }
.lead-floral.right { right: 1.4rem; top: -4rem; transform: rotate(-24deg); }
.lead-card > *:not(.lead-floral) { position: relative; z-index: 1; }
.lead-card .lead-form { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .8rem; align-items: start; border: 0; border-radius: 0; background: transparent; box-shadow: none; padding: 0; }
.lead-card .lead-form .row { display: contents; }
.lead-card .lead-form .col-md-6 { width: auto; }
.lead-card .lead-form .form-label { display: none; }
.lead-card .lead-form .form-check, .lead-card .lead-form .form-message, .lead-card .lead-form button { grid-column: 1 / -1; }
.lead-card .lead-form .form-check { color: rgba(74, 58, 64,.62); font-size: .76rem; line-height: 1.4; margin-top: .1rem !important; }
.lead-card .lead-form button { margin-top: .2rem !important; }

.contact-section { background: var(--white); }
.contact-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: .9rem; margin-top: 1.7rem; }
.contact-grid article, .contact-whatsapp { min-height: 96px; border-radius: var(--radius-lg); }
.contact-grid article { border: 1px solid rgba(227, 215, 218,.95); background: var(--white); box-shadow: 0 8px 22px rgba(99, 63, 67,.04); padding: 1rem; }
.contact-grid span { display: block; color: var(--purple-700); font-size: .78rem; font-weight: 900; margin-bottom: .4rem; }
.contact-grid strong { display: block; color: var(--purple-900); font-size: .84rem; font-weight: 900; line-height: 1.28; word-break: break-word; }
.contact-grid small { display: block; color: rgba(74, 58, 64,.58); font-size: .72rem; line-height: 1.3; margin-top: .28rem; }
.contact-whatsapp { display: flex; align-items: center; justify-content: center; text-align: center; align-self: stretch; }

.final-cta { position: relative; background: var(--white); padding: 1.2rem 0 0; }
.final-cta-card { position: relative; overflow: hidden; border-radius: var(--radius-xl) var(--radius-xl) 0 0; background: linear-gradient(90deg, var(--white), var(--lavender-100), var(--white)); padding: clamp(2rem, 4vw, 3rem); text-align: center; }
.final-cta h2 { max-width: 880px; margin: 0 auto .65rem; color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.2rem, 4.2vw, 3.15rem); font-weight: 700; line-height: 1; letter-spacing: -.025em; }
.final-cta p { color: rgba(74, 58, 64,.72); font-size: 1rem; margin-bottom: 1.35rem; }
.final-actions { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.cta-floral { position: absolute; width: 130px; height: 250px; border-left: 1.5px solid rgba(162, 117, 119,.13); border-radius: 50%; pointer-events: none; }
.cta-floral.left { left: 2rem; bottom: -4rem; transform: rotate(32deg); }
.cta-floral.right { right: 2rem; bottom: -3.5rem; transform: rotate(-32deg); }

.footer { background: linear-gradient(135deg, var(--purple-950), var(--purple-900)); color: var(--white); }
.footer-grid { display: grid; grid-template-columns: 1.6fr .8fr .9fr 1fr 1fr; gap: 2rem; }
.footer h2, .footer .serif { color: var(--white); font-family: "Cormorant Garamond", Georgia, serif; }
.footer h3 { color: var(--rose-300); font-size: .82rem; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.footer-links { display: grid; gap: .62rem; margin-top: 1rem; }
.footer-links a, .footer p { color: rgba(255,255,255,.72); font-size: .86rem; }
.footer-links a:hover { color: var(--white); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.62); font-size: .78rem; padding: 1rem; text-align: center; }

@media (max-width: 1199px) {
  .mobile-menu-toggle { display: inline-block; order: 2; }
  .header-cta { order: 3; }
  .nav-links { order: 4; position: absolute; left: 1rem; right: 1rem; top: calc(100% + .35rem); display: none !important; flex-direction: column; gap: .2rem !important; border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--white); box-shadow: var(--shadow-soft); padding: .8rem; }
  .nav-links.is-open { display: flex !important; }
  .nav-links a { padding: .8rem; }
  .nav-links a:first-child::after { display: none; }
  .site-header nav { position: relative; }
  .hero-grid { grid-template-columns: minmax(0, 1fr) minmax(360px, .85fr); gap: 2rem; }
  .hero-copy h1 { font-size: clamp(3rem, 5.6vw, 3.75rem); }
  .hero-floating-card { right: 0; }
  .authority-card { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .authority-item:nth-child(3n) { border-right: 0; }
  .authority-item:nth-child(-n+3) { border-bottom: 1px solid rgba(227, 215, 218,.88); }
  .timeline-track { overflow-x: auto; padding-bottom: .45rem; }
  .service-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .numbers-band { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .schedule-layout { grid-template-columns: minmax(260px, .9fr) minmax(360px, 1.1fr); }
  .order-summary { grid-column: 1 / -1; }
  .calendar-panel { border-right: 0; }
  .course-banner { grid-template-columns: 190px 1fr auto; padding: 1.3rem; }
  .course-image-wrap { min-height: 170px; }
  .course-image-wrap img { width: 190px; height: 170px; }
  .course-banner ul { grid-column: 1 / -1; grid-template-columns: repeat(5, minmax(0, 1fr)); }
  .contact-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 991px) {
  .hero:not(.bg-cream) { min-height: auto; padding-top: 3rem; text-align: center; }
  .hero-grid, .about-grid, .lead-card { grid-template-columns: 1fr; }
  .hero-copy h1, .hero-text { margin-left: auto; margin-right: auto; }
  .hero-actions { justify-content: center; }
  .hero-visual { min-height: 430px; }
  .authority-card { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .authority-item { border-right: 0; border-bottom: 1px solid rgba(227, 215, 218,.88); }
  .authority-item:nth-last-child(-n+2) { border-bottom: 0; }
  .about-grid { text-align: left; }
  .timeline-track { grid-template-columns: 1fr; overflow: visible; padding-top: 0; padding-left: 2rem; margin-top: 2rem; }
  .timeline-track::before { left: .6rem; right: auto; top: 0; bottom: 0; width: 2px; height: auto; background: linear-gradient(180deg, transparent, var(--lilac-200), var(--purple-700), var(--lilac-200), transparent); }
  .timeline-card { min-height: auto; }
  .timeline-dot { top: 1.15rem; left: -1.98rem; transform: none; }
  .service-grid, .testimonial-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .numbers-band { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .schedule-layout { grid-template-columns: 1fr; }
  .schedule-panel { border-right: 0; border-bottom: 1px solid rgba(227, 215, 218,.86); }
  .date-time-grid { grid-template-columns: 1fr 1fr; }
  .course-banner { grid-template-columns: 170px 1fr; }
  .course-banner .btn { grid-column: 2; justify-self: start; }
  .course-banner ul { grid-column: 1 / -1; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .lead-card .lead-form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767px) {
  .topbar { min-height: 34px; font-size: .68rem; padding: .45rem .8rem; text-align: center; }
  .topbar-icons { display: none; }
  .site-header nav { min-height: 66px; }
  .brand-mark { width: 1.8rem; height: 2.35rem; }
  .brand-logo { height: 2.45rem; max-width: 178px; }
  .brand-copy strong { font-size: 1.15rem; }
  .brand-copy small { font-size: .5rem; }
  .header-cta { display: none; }
  .hero:not(.bg-cream) { padding: 2.4rem 0 2.6rem; }
  .hero-copy h1 { font-size: clamp(2.75rem, 14vw, 3.35rem); line-height: .98; }
  .hero-text { font-size: .98rem; }
  .hero-actions .btn { width: 100%; max-width: 330px; }
  .hero-visual { min-height: 345px; }
  .hero-image { max-height: 350px; }
  .hero-orb { width: 330px; }
  .hero-floating-card { display: none; }
  .authority { margin-top: 0; padding-bottom: 1.4rem; }
  .authority-card { grid-template-columns: 1fr; }
  .authority-item, .authority-item:nth-last-child(-n+2) { border-bottom: 1px solid rgba(227, 215, 218,.88); }
  .authority-item:last-child { border-bottom: 0; }
  .section-pad { padding: 3.5rem 0; }
  .section-pad-sm { padding: 2.6rem 0; }
  .section-title { font-size: clamp(2.2rem, 11vw, 2.75rem); }
  .section-kicker { padding-left: 2.4rem; }
  .about-visual { min-height: 350px; }
  .about-visual img { width: 300px; height: 330px; }
  .about-arch { width: 300px; height: 330px; }
  .about-copy h2 { font-size: clamp(2.55rem, 12vw, 3.1rem); }
  .service-grid, .numbers-band, .testimonial-grid, .contact-grid, .lead-card .lead-form { grid-template-columns: 1fr; }
  .service-card { min-height: auto; }
  .schedule-steps { grid-template-columns: 1fr 1fr; gap: .6rem; padding: .9rem; }
  .schedule-steps span { justify-content: flex-start; font-size: .72rem; }
  .date-time-grid { grid-template-columns: 1fr; }
  .home-slot-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .appointment-service { grid-template-columns: auto 1fr; }
  .course-banner { grid-template-columns: 1fr; text-align: center; padding: 1.4rem; }
  .course-image-wrap { min-height: 170px; }
  .course-image-wrap img { margin: 0 auto; }
  .course-copy span { margin: 0 auto; }
  .course-banner .btn { grid-column: auto; justify-self: center; width: 100%; max-width: 300px; }
  .course-banner ul { grid-template-columns: 1fr; text-align: left; }
  .testimonial-card { min-height: auto; }
  .lead-card { padding: 1.35rem; }
  .lead-copy { text-align: center; }
  .lead-copy p { margin: 0 auto; }
  .contact-grid article, .contact-whatsapp { min-height: 84px; }
  .final-actions .btn { width: 100%; max-width: 330px; }
  .cta-floral, .lead-floral { opacity: .42; }
  .footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 420px) {
  .home-slot-grid { grid-template-columns: 1fr; }
  .schedule-card, .final-cta-card, .lead-card { border-radius: var(--radius-lg); }
  .course-copy h2 { font-size: 2.35rem; }
}

/* Course landing rebuild */
.course-topbar {
  background: linear-gradient(90deg, var(--purple-500), var(--purple-700), var(--purple-500));
}

.course-nav a:first-child::after { display: none; }
.course-nav a.is-active { color: var(--purple-900); }
.course-nav a.is-active::after { content: ""; position: absolute; left: 0; right: 0; bottom: .2rem; height: 2px; display: block; background: var(--rose-500); border-radius: 99px; }
.btn-icon-lock { width: .9rem; height: .72rem; display: inline-block; border: 1.6px solid currentColor; border-radius: .18rem; position: relative; }
.btn-icon-lock::before { content: ""; position: absolute; left: 50%; top: -.52rem; width: .58rem; height: .55rem; border: 1.6px solid currentColor; border-bottom: 0; border-radius: .5rem .5rem 0 0; transform: translateX(-50%); }

.course-page {
  --course-bg: #FAF7F5;
  background: var(--course-bg);
  color: var(--text);
  overflow: hidden;
}

.course-page .container-xl { max-width: 1220px; }
.course-eyebrow { color: var(--purple-700); font-size: .74rem; font-weight: 900; letter-spacing: .2em; text-transform: uppercase; margin-bottom: .7rem; }
.course-title { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.35rem, 4.1vw, 3.05rem); font-weight: 700; line-height: 1; letter-spacing: -.02em; margin: 0 0 1.45rem; text-align: center; }
.course-title.align-left { text-align: left; }
.course-title.with-lines { display: flex; align-items: center; justify-content: center; gap: 1.2rem; }
.course-title.with-lines::before, .course-title.with-lines::after { content: ""; width: 58px; height: 1px; background: var(--rose-300); opacity: .9; }
.course-section { padding: clamp(2.8rem, 5vw, 4.2rem) 0; background: var(--course-bg); }

.course-icon { width: 2.65rem; height: 2.65rem; display: inline-block; position: relative; color: var(--purple-700); border: 2px solid currentColor; border-radius: .7rem; background: rgba(243, 234, 235,.75); flex: 0 0 auto; }
.course-icon::before, .course-icon::after { content: ""; position: absolute; border-color: currentColor; }
.course-icon.icon-person, .course-icon.icon-clock, .course-icon.icon-shield, .course-icon.icon-heart, .course-icon.icon-target, .course-icon.icon-diamond { border-radius: 50%; }
.course-icon.icon-screen::before { left: .45rem; right: .45rem; top: .55rem; height: 1.15rem; border: 2px solid currentColor; border-radius: .18rem; }
.course-icon.icon-screen::after { left: .85rem; right: .85rem; bottom: .48rem; border-bottom: 2px solid currentColor; }
.course-icon.icon-clock::before { inset: .55rem; border: 2px solid currentColor; border-radius: 50%; }
.course-icon.icon-clock::after { left: 50%; top: .8rem; width: .48rem; height: .62rem; border-left: 2px solid currentColor; border-bottom: 2px solid currentColor; }
.course-icon.icon-shield::before { left: .7rem; right: .7rem; top: .45rem; bottom: .45rem; border: 2px solid currentColor; border-radius: .9rem .9rem 1.2rem 1.2rem; transform: perspective(30px) rotateX(-8deg); }
.course-icon.icon-document::before { left: .68rem; right: .68rem; top: .45rem; bottom: .45rem; border: 2px solid currentColor; border-radius: .22rem; }
.course-icon.icon-document::after { left: .95rem; right: .95rem; top: 1.05rem; height: .1rem; background: currentColor; box-shadow: 0 .45rem 0 currentColor; }
.course-icon.icon-person::before { left: 50%; top: .48rem; width: .75rem; height: .75rem; border: 2px solid currentColor; border-radius: 50%; transform: translateX(-50%); }
.course-icon.icon-person::after { left: .58rem; right: .58rem; bottom: .5rem; height: .72rem; border: 2px solid currentColor; border-radius: 50% 50% 0 0; }
.course-icon.icon-cap { border: 0; background: transparent; }
.course-icon.icon-cap::before { left: .32rem; right: .32rem; top: .75rem; height: .9rem; border: 2px solid currentColor; transform: skew(-22deg); }
.course-icon.icon-cap::after { left: .95rem; right: .95rem; bottom: .48rem; height: .5rem; border-left: 2px solid currentColor; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; border-radius: 0 0 .35rem .35rem; }
.course-icon.icon-building::before { left: .55rem; right: .55rem; bottom: .48rem; height: 1.5rem; border: 2px solid currentColor; border-bottom: 0; }
.course-icon.icon-building::after { left: .86rem; bottom: .55rem; width: .22rem; height: .22rem; background: currentColor; box-shadow: .5rem 0 0 currentColor, .98rem 0 0 currentColor, 0 -.48rem 0 currentColor, .5rem -.48rem 0 currentColor, .98rem -.48rem 0 currentColor; }
.course-icon.icon-target::before { inset: .5rem; border: 2px solid currentColor; border-radius: 50%; }
.course-icon.icon-target::after { left: 50%; top: 50%; width: .38rem; height: .38rem; background: currentColor; border-radius: 50%; transform: translate(-50%, -50%); }
.course-icon.icon-heart::before { left: .63rem; top: .7rem; width: .75rem; height: .75rem; border: 2px solid currentColor; border-right: 0; border-bottom: 0; border-radius: 50% 0 0 0; transform: rotate(45deg); }
.course-icon.icon-heart::after { left: 1.2rem; top: .7rem; width: .75rem; height: .75rem; border: 2px solid currentColor; border-left: 0; border-bottom: 0; border-radius: 0 50% 0 0; transform: rotate(-45deg); }
.course-icon.icon-cube::before { left: .58rem; right: .58rem; top: .65rem; height: 1.1rem; border: 2px solid currentColor; transform: rotate(45deg); border-radius: .18rem; }
.course-icon.icon-megaphone::before { left: .45rem; top: .86rem; width: 1.18rem; height: .75rem; border: 2px solid currentColor; transform: skewY(-16deg); }
.course-icon.icon-megaphone::after { right: .45rem; top: .75rem; height: 1.05rem; border-right: 2px solid currentColor; box-shadow: .3rem -.12rem 0 -.1rem currentColor, .3rem .34rem 0 -.1rem currentColor; }
.course-icon.icon-group::before { top: .55rem; left: .52rem; width: .5rem; height: .5rem; border: 2px solid currentColor; border-radius: 50%; box-shadow: .82rem 0 0 -.02rem var(--lavender-50), .82rem 0 0 0 currentColor; }
.course-icon.icon-group::after { left: .45rem; right: .45rem; bottom: .55rem; height: .62rem; border: 2px solid currentColor; border-radius: 50% 50% 0 0; }
.course-icon.icon-chart::before { left: .55rem; right: .55rem; bottom: .55rem; height: 1.25rem; border-left: 2px solid currentColor; border-bottom: 2px solid currentColor; }
.course-icon.icon-chart::after { left: .82rem; bottom: .86rem; width: 1.15rem; height: .8rem; border-top: 2px solid currentColor; border-right: 2px solid currentColor; transform: skewY(-24deg); }
.course-icon.icon-briefcase::before { left: .45rem; right: .45rem; bottom: .55rem; height: 1.2rem; border: 2px solid currentColor; border-radius: .18rem; }
.course-icon.icon-briefcase::after { left: .95rem; right: .95rem; top: .45rem; height: .48rem; border: 2px solid currentColor; border-bottom: 0; border-radius: .4rem .4rem 0 0; }
.course-icon.icon-rocket::before { left: .9rem; top: .4rem; width: .85rem; height: 1.55rem; border: 2px solid currentColor; border-radius: 60% 60% .25rem .25rem; transform: rotate(24deg); }
.course-icon.icon-rocket::after { left: .58rem; bottom: .5rem; width: .55rem; height: .55rem; border-left: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(20deg); }
.course-icon.icon-cards::before { left: .52rem; top: .7rem; width: 1rem; height: 1.2rem; border: 2px solid currentColor; border-radius: .2rem; transform: rotate(-8deg); }
.course-icon.icon-cards::after { right: .55rem; top: .55rem; width: 1rem; height: 1.2rem; border: 2px solid currentColor; border-radius: .2rem; transform: rotate(8deg); }
.course-icon.icon-diamond::before { left: 50%; top: 50%; width: 1.2rem; height: 1.2rem; border: 2px solid currentColor; border-radius: .18rem; transform: translate(-50%, -50%) rotate(45deg); }

.course-hero { position: relative; padding: clamp(3rem, 6vw, 4.8rem) 0 3.6rem; background: radial-gradient(circle at 67% 45%, rgba(230, 217, 219,.75), transparent 21rem), linear-gradient(90deg, #fff 0%, #fff 52%, var(--lavender-50) 78%, #fff 100%); }
.course-hero::after { content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 78px; background: linear-gradient(180deg, rgba(250, 247, 245,0), rgba(243, 234, 235,.62)); clip-path: ellipse(75% 70% at 50% 100%); pointer-events: none; }
.course-hero-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(420px, .95fr); gap: clamp(2rem, 5vw, 4rem); align-items: center; position: relative; z-index: 1; }
.course-hero-copy h1 { max-width: 670px; color: var(--purple-950); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(3.8rem, 6.4vw, 5.35rem); font-weight: 700; line-height: .94; letter-spacing: -.045em; margin: 0; }
.course-hero-copy h1 span { color: var(--rose-500); }
.course-hero-copy > p:not(.course-eyebrow) { max-width: 610px; color: rgba(74, 58, 64,.82); font-size: 1.05rem; line-height: 1.65; margin: 1.2rem 0 1.55rem; }
.course-hero-actions { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; }
.course-social-proof { display: grid; grid-template-columns: repeat(3, 24px) minmax(160px, 1fr); align-items: center; column-gap: 0; }
.course-social-proof span { width: 30px; height: 30px; border: 2px solid #fff; border-radius: 50%; background: linear-gradient(135deg, var(--rose-300), var(--lilac-300)); margin-left: -6px; box-shadow: 0 8px 18px rgba(99, 63, 67,.12); }
.course-social-proof span:first-child { margin-left: 0; }
.course-social-proof strong { margin-left: .45rem; color: var(--purple-900); font-size: .78rem; line-height: 1.25; max-width: 210px; }
.course-hero-visual { min-height: 465px; display: grid; place-items: end center; position: relative; }
.course-hero-orb { position: absolute; left: 48%; bottom: -1rem; width: min(92%, 490px); aspect-ratio: 1; border-radius: 50% 50% 0 0; background: radial-gradient(circle at 48% 38%, rgba(250, 247, 245,.65), rgba(230, 217, 219,.88)); border: 1px solid rgba(162, 117, 119,.18); transform: translateX(-50%); }
.course-hero-visual img { position: relative; z-index: 2; max-height: 505px; max-width: 90%; object-fit: contain; object-position: bottom center; filter: drop-shadow(0 24px 32px rgba(75, 48, 53,.16)); }
.course-hero-floral { position: absolute; z-index: 1; right: 5.6rem; bottom: 2rem; width: 160px; height: 330px; border-left: 1.5px solid rgba(162, 117, 119,.22); border-radius: 50%; transform: rotate(18deg); }
.course-hero-floral::before, .course-hero-floral::after { content: ""; position: absolute; width: 48px; height: 86px; border: 1.5px solid rgba(162, 117, 119,.24); border-left: 0; border-bottom: 0; border-radius: 90% 10%; }
.course-hero-floral::before { left: 28px; top: 72px; transform: rotate(-35deg); }
.course-hero-floral::after { left: 72px; top: 168px; transform: rotate(24deg); }
.course-floating-card { position: absolute; z-index: 4; right: 0; top: 4.1rem; width: 205px; display: grid; justify-items: center; gap: .8rem; margin: 0; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-xl); background: rgba(255,255,255,.9); box-shadow: var(--shadow-soft); padding: 2rem 1.3rem; text-align: center; backdrop-filter: blur(10px); }
.course-floating-card p { margin: 0; color: var(--purple-900); font-size: .92rem; font-weight: 700; line-height: 1.55; }
.course-floating-card i { color: var(--rose-500); font-style: normal; }

.course-proof { position: relative; z-index: 4; margin-top: -1.9rem; padding-bottom: 1.8rem; }
.course-proof-card { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); overflow: hidden; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: rgba(255,255,255,.96); box-shadow: var(--shadow-soft); }
.course-proof-item { display: flex; align-items: center; gap: .82rem; min-height: 76px; padding: .95rem 1rem; border-right: 1px solid rgba(227, 215, 218,.9); }
.course-proof-item:last-child { border-right: 0; }
.course-proof-item .course-icon { width: 2.2rem; height: 2.2rem; }
.course-proof-item strong { display: block; color: var(--purple-900); font-size: .8rem; font-weight: 900; line-height: 1.2; }
.course-proof-item small { display: block; color: rgba(74, 58, 64,.58); font-size: .71rem; line-height: 1.25; margin-top: .12rem; }

.course-card-grid { display: grid; gap: .9rem; }
.course-card-grid.five { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.course-card-grid.six { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.course-mini-card { min-height: 168px; display: grid; justify-items: center; align-content: start; text-align: center; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-lg); background: var(--white); box-shadow: 0 8px 24px rgba(99, 63, 67,.04); padding: 1.35rem 1rem; }
.course-mini-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card); }
.course-mini-card h3 { color: var(--purple-900); font-family: "Inter", sans-serif; font-size: .92rem; font-weight: 900; line-height: 1.25; margin: .9rem 0 .45rem; }
.course-mini-card p { color: rgba(74, 58, 64,.66); font-size: .78rem; line-height: 1.42; margin: 0; }
.learning-card { min-height: 176px; }

.course-modules-authority { border-top: 1px solid rgba(227, 215, 218,.82); border-bottom: 1px solid rgba(227, 215, 218,.82); background: linear-gradient(90deg, #fff, var(--lavender-50)); }
.course-split-grid { display: grid; grid-template-columns: minmax(360px, .95fr) minmax(0, 1.05fr); gap: clamp(2rem, 4vw, 3.5rem); align-items: start; }
.course-module-list { display: grid; gap: .7rem; }
.course-module-card { display: grid; grid-template-columns: auto 1fr auto; gap: .75rem; align-items: center; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: rgba(255,255,255,.88); box-shadow: 0 6px 18px rgba(99, 63, 67,.035); padding: .78rem .9rem; }
.course-module-number { width: 2rem; height: 2rem; display: grid; place-items: center; border-radius: 50%; background: var(--purple-900); color: var(--white); font-size: .72rem; font-weight: 900; }
.course-module-card strong { display: block; color: var(--purple-900); font-size: .84rem; font-weight: 900; }
.course-module-card small { display: block; color: rgba(74, 58, 64,.62); font-size: .71rem; line-height: 1.35; margin-top: .15rem; }
.course-module-card > span:last-child { color: var(--purple-700); font-size: 1.1rem; }
.course-authority-block { display: grid; grid-template-columns: minmax(0, 1fr) 260px; align-items: end; gap: 1.6rem; min-height: 430px; }
.course-authority-copy h2 { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.35rem, 4vw, 3.2rem); font-weight: 700; line-height: .95; letter-spacing: -.025em; margin-bottom: 1rem; }
.course-authority-copy h2 span { color: var(--rose-500); display: block; }
.course-authority-copy p { color: rgba(74, 58, 64,.72); font-size: .92rem; line-height: 1.62; }
.course-authority-copy ul { display: grid; gap: .48rem; list-style: none; padding: 0; margin: 1rem 0; color: rgba(74, 58, 64,.75); font-size: .84rem; }
.course-authority-copy li::before { content: "⊙"; color: var(--purple-700); font-weight: 900; margin-right: .45rem; }
.course-authority-copy blockquote { border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-lg); background: rgba(255,255,255,.86); color: var(--purple-900); font-size: .84rem; line-height: 1.55; margin: 1.1rem 0 0; padding: 1rem 1.1rem; }
.course-authority-copy blockquote::before { content: "“"; color: var(--purple-500); font-family: Georgia, serif; font-size: 2.4rem; line-height: .5; display: block; }
.course-authority-copy blockquote strong { display: block; margin-top: .55rem; }
.course-authority-image { position: relative; display: grid; place-items: end center; align-self: stretch; }
.course-authority-image img { position: relative; z-index: 2; width: 285px; height: 395px; object-fit: cover; object-position: center top; border-radius: 50% 50% 0 0; filter: drop-shadow(0 22px 28px rgba(75, 48, 53,.14)); }
.course-authority-floral { position: absolute; z-index: 1; left: -2.2rem; bottom: 0; width: 130px; height: 285px; border-left: 1.5px solid rgba(162, 117, 119,.22); border-radius: 50%; transform: rotate(18deg); }

.course-journey { background: var(--white); }
.course-steps-grid { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr; gap: .9rem; align-items: center; }
.course-step-card { min-height: 128px; display: flex; align-items: center; gap: 1rem; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-lg); background: var(--white); box-shadow: 0 8px 24px rgba(99, 63, 67,.04); padding: 1rem; }
.course-step-card small { color: var(--rose-500); font-weight: 950; }
.course-step-card h3 { color: var(--purple-900); font-size: .9rem; font-weight: 900; margin: .1rem 0 .25rem; }
.course-step-card p { color: rgba(74, 58, 64,.65); font-size: .76rem; line-height: 1.35; margin: 0; }
.course-step-arrow { color: var(--purple-700); font-size: 1.8rem; }

.course-bonus-testimonials { border-top: 1px solid rgba(227, 215, 218,.82); border-bottom: 1px solid rgba(227, 215, 218,.82); background: var(--course-bg); }
.course-bonus-grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: 2.2rem; align-items: start; }
.leaf-title::before { content: "♧"; color: var(--lilac-300); font-family: Georgia, serif; font-size: 1.5rem; margin-right: .4rem; }
.course-bonus-cards { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; }
.course-bonus-card { min-height: 150px; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); box-shadow: 0 8px 22px rgba(99, 63, 67,.04); padding: 1rem .85rem; text-align: center; }
.course-bonus-card .course-icon { width: 2.2rem; height: 2.2rem; }
.course-bonus-card h3 { color: var(--purple-900); font-size: .8rem; font-weight: 900; line-height: 1.25; margin: .75rem 0 .35rem; }
.course-bonus-card p { color: rgba(74, 58, 64,.62); font-size: .7rem; line-height: 1.35; margin: 0; }
.course-bonus-note { color: var(--purple-900); font-size: .78rem; font-weight: 900; margin: .9rem 0 0; text-align: center; }
.course-testimonials-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.45rem; }
.course-testimonials-head .course-title { margin: 0; }
.course-testimonials-head a { color: var(--purple-700); font-size: .78rem; font-weight: 900; }
.course-testimonial-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .85rem; }
.course-testimonial-card { min-height: 160px; display: grid; align-content: start; border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); box-shadow: 0 8px 22px rgba(99, 63, 67,.04); padding: 1rem; text-align: center; }
.course-testimonial-card p { color: rgba(74, 58, 64,.68); font-size: .78rem; font-style: italic; line-height: 1.48; margin: 0 0 .75rem; }
.course-testimonial-card .stars { color: var(--rose-500); letter-spacing: .12em; font-size: .82rem; margin-bottom: .75rem; }
.course-testimonial-card strong { color: var(--purple-900); font-size: .82rem; font-weight: 900; }
.course-testimonial-card small { color: rgba(74, 58, 64,.58); font-size: .72rem; }

.course-investment { background: linear-gradient(180deg, var(--white), var(--lavender-50)); }
.course-investment-grid { display: grid; grid-template-columns: minmax(250px, 1fr) minmax(250px, .9fr) minmax(230px, .85fr) minmax(320px, 1.25fr); gap: 1rem; align-items: stretch; }
.course-invest-card, .course-price-card, .course-checkout-card { border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-lg); background: var(--white); box-shadow: 0 8px 24px rgba(99, 63, 67,.045); padding: 1.2rem; }
.course-product-card { display: grid; grid-template-columns: 82px 1fr; gap: 1rem; align-items: center; }
.course-product-card small { color: var(--purple-700); font-size: .76rem; font-weight: 900; }
.course-product-card h3 { color: var(--purple-900); font-size: .95rem; font-weight: 900; margin: .15rem 0 .55rem; }
.course-product-card ul { list-style: none; padding: 0; margin: 0; color: rgba(74, 58, 64,.72); font-size: .76rem; line-height: 1.5; }
.course-product-card li::before { content: "●"; color: var(--purple-700); font-size: .45rem; margin-right: .45rem; vertical-align: middle; }
.course-plant { width: 74px; height: 118px; border-radius: 0 0 1.2rem 1.2rem; background: linear-gradient(180deg, transparent 58%, var(--lavender-100) 58%); position: relative; }
.course-plant::before { content: ""; position: absolute; left: 50%; top: .8rem; width: 1px; height: 74px; background: var(--purple-700); transform: rotate(-8deg); box-shadow: -14px 16px 0 -13px var(--purple-700), 14px 20px 0 -13px var(--purple-700); }
.course-price-card { display: grid; place-items: center; text-align: center; background: radial-gradient(circle at 18% 14%, rgba(255,255,255,.18), transparent 34%), linear-gradient(135deg, var(--purple-950), var(--purple-700)); color: var(--white); }
.course-price-card span { color: rgba(255,255,255,.78); font-size: .9rem; font-weight: 800; }
.course-price-card strong { color: var(--white); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.4rem, 4vw, 3.35rem); font-weight: 700; line-height: .95; }
.course-price-card small, .course-price-card p { color: rgba(255,255,255,.8); font-size: .8rem; margin: 0; }
.course-guarantee-card { text-align: center; display: grid; align-content: center; justify-items: center; }
.course-guarantee-card h3 { color: var(--purple-900); font-size: .95rem; font-weight: 900; margin: .7rem 0 .35rem; }
.course-guarantee-card p { color: rgba(74, 58, 64,.65); font-size: .78rem; line-height: 1.45; margin: 0; }
.course-checkout-card { display: grid; gap: .55rem; background: rgba(255,255,255,.96); }
.course-checkout-card .form-label { color: var(--purple-900); font-size: .72rem; font-weight: 900; margin: 0; }
.course-checkout-card .form-control { border: 1px solid rgba(227, 215, 218,.95); border-radius: .85rem; font-size: .84rem; padding: .75rem .9rem; }
.course-checkout-card .form-control:focus { border-color: var(--purple-500); box-shadow: 0 0 0 .22rem rgba(184, 138, 140,.16); }
.course-checkout-card .form-check { color: rgba(74, 58, 64,.62); font-size: .74rem; line-height: 1.35; margin: .2rem 0 .35rem; }

.course-faq-final { background: var(--course-bg); }
.course-faq-grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr); gap: 2rem; align-items: stretch; }
.course-faq-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem 1rem; }
.course-faq-item { border: 1px solid rgba(227, 215, 218,.95); border-radius: var(--radius-md); background: var(--white); box-shadow: 0 6px 18px rgba(99, 63, 67,.035); overflow: hidden; }
.course-faq-item summary { cursor: pointer; color: var(--purple-900); font-size: .84rem; font-weight: 850; list-style: none; padding: .85rem 1rem; }
.course-faq-item summary::-webkit-details-marker { display: none; }
.course-faq-item summary::after { content: "⌄"; float: right; color: var(--purple-700); }
.course-faq-item[open] summary::after { transform: rotate(180deg); }
.course-faq-item p { color: rgba(74, 58, 64,.66); font-size: .78rem; line-height: 1.5; margin: 0; padding: 0 1rem 1rem; }
.course-final-card { position: relative; overflow: hidden; display: grid; align-content: center; border-radius: var(--radius-xl); background: radial-gradient(circle at 80% 45%, rgba(255,255,255,.23), transparent 28%), linear-gradient(135deg, var(--lavender-100), var(--lilac-300)); padding: 2.2rem; }
.course-final-card h2 { color: var(--purple-900); font-family: "Cormorant Garamond", Georgia, serif; font-size: clamp(2.2rem, 4vw, 3.2rem); font-weight: 700; line-height: .95; letter-spacing: -.025em; max-width: 360px; margin-bottom: .8rem; }
.course-final-card p { color: rgba(74, 58, 64,.72); max-width: 380px; line-height: 1.55; }
.course-final-card .btn { width: max-content; position: relative; z-index: 1; }
.course-final-floral { position: absolute; right: 1.2rem; bottom: -3rem; width: 160px; height: 300px; border-left: 1.5px solid rgba(255,255,255,.55); border-radius: 50%; transform: rotate(-28deg); }

@media (max-width: 1199px) {
  .course-hero-grid { grid-template-columns: minmax(0, 1fr) minmax(360px, .85fr); }
  .course-floating-card { right: -.4rem; width: 190px; }
  .course-proof-card { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .course-proof-item { border-bottom: 1px solid rgba(227, 215, 218,.9); }
  .course-card-grid.five, .course-card-grid.six { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .course-authority-block { grid-template-columns: 1fr; }
  .course-authority-image { display: none; }
  .course-bonus-grid, .course-faq-grid { grid-template-columns: 1fr; }
  .course-investment-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .course-checkout-card { grid-column: span 2; }
}

@media (max-width: 991px) {
  .course-hero { text-align: center; padding-top: 3rem; }
  .course-hero-grid, .course-split-grid { grid-template-columns: 1fr; }
  .course-hero-copy h1, .course-hero-copy > p:not(.course-eyebrow) { margin-left: auto; margin-right: auto; }
  .course-hero-actions { justify-content: center; }
  .course-hero-visual { min-height: 420px; }
  .course-floating-card { display: none; }
  .course-proof-card { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .course-steps-grid { grid-template-columns: 1fr; }
  .course-step-arrow { transform: rotate(90deg); text-align: center; }
  .course-bonus-cards, .course-testimonial-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .course-faq-list { grid-template-columns: 1fr; }
}

@media (max-width: 767px) {
  .course-title { font-size: clamp(2.15rem, 10vw, 2.65rem); }
  .course-title.with-lines::before, .course-title.with-lines::after { width: 34px; }
  .course-hero-copy h1 { font-size: clamp(3rem, 14vw, 3.6rem); }
  .course-hero-copy > p:not(.course-eyebrow) { font-size: .98rem; }
  .course-hero-actions .btn { width: 100%; max-width: 340px; }
  .course-social-proof { grid-template-columns: repeat(3, 24px); justify-content: center; row-gap: .5rem; }
  .course-social-proof strong { grid-column: 1 / -1; margin: .25rem 0 0; max-width: 260px; text-align: center; }
  .course-hero-visual { min-height: 335px; }
  .course-hero-visual img { max-height: 350px; }
  .course-hero-orb { width: 330px; }
  .course-proof-card, .course-card-grid.five, .course-card-grid.six, .course-bonus-cards, .course-testimonial-grid, .course-investment-grid { grid-template-columns: 1fr; }
  .course-proof-item { border-right: 0; }
  .course-mini-card { min-height: auto; }
  .course-section { padding: 2.6rem 0; }
  .course-authority-copy h2, .course-title.align-left { text-align: center; }
  .course-module-card { grid-template-columns: auto 1fr; }
  .course-module-card > span:last-child { display: none; }
  .course-product-card { grid-template-columns: 1fr; text-align: center; justify-items: center; }
  .course-checkout-card { grid-column: auto; }
  .course-final-card { padding: 1.6rem; text-align: center; justify-items: center; }
  .course-final-card .btn { width: 100%; }
}

/* Conversion UX refinements */
.section-breath {
  padding-top: clamp(5rem, 10vw, 8rem);
  padding-bottom: clamp(5rem, 10vw, 8rem);
}

.section-pad {
  padding-top: clamp(5rem, 10vw, 8rem);
  padding-bottom: clamp(5rem, 10vw, 8rem);
}

.btn-plum,
.btn-outline-plum,
.btn-primary-soft,
.btn-outline-soft,
.btn-light-soft {
  transition: transform .3s ease, box-shadow .3s ease, background-color .3s ease, border-color .3s ease, color .3s ease;
  transform-origin: center;
}

.btn-plum:hover,
.btn-outline-plum:hover,
.btn-primary-soft:hover,
.btn-outline-soft:hover,
.btn-light-soft:hover,
.btn-plum:active,
.btn-outline-plum:active,
.btn-primary-soft:active,
.btn-outline-soft:active,
.btn-light-soft:active {
  transform: translateY(-1px) scale(1.02);
}

.line-icon {
  color: var(--purple-700);
  border: 1.8px solid currentColor;
  background: transparent;
  box-shadow: none;
}

.line-icon::before,
.line-icon::after {
  box-sizing: border-box;
  border-color: currentColor;
}

.about-video-placeholder {
  display: flex;
  align-items: center;
  gap: 1rem;
  max-width: 560px;
  border: 1px solid rgba(227, 215, 218,.95);
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, var(--lavender-50), var(--white));
  box-shadow: 0 10px 28px rgba(99, 63, 67,.06);
  padding: 1rem;
  margin: 1.15rem 0 1.25rem;
}

.video-play {
  width: 3.4rem;
  height: 3.4rem;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 50%;
  background: var(--purple-900);
  color: var(--white);
  box-shadow: 0 14px 30px rgba(99, 63, 67,.2);
}

.video-play::before {
  content: "";
  width: 0;
  height: 0;
  margin-left: .2rem;
  border-top: .52rem solid transparent;
  border-bottom: .52rem solid transparent;
  border-left: .78rem solid currentColor;
}

.about-video-placeholder strong {
  display: block;
  color: var(--purple-900);
  font-size: .92rem;
  font-weight: 900;
}

.about-video-placeholder small {
  display: block;
  color: rgba(74, 58, 64,.66);
  font-size: .8rem;
  line-height: 1.45;
  margin-top: .18rem;
}

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

.course-module-benefit-card {
  position: relative;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(227, 215, 218,.95);
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.9);
  box-shadow: 0 8px 24px rgba(99, 63, 67,.045);
  padding: 1.05rem;
  overflow: hidden;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease, background .3s ease;
}

.course-module-benefit-card::after {
  content: "";
  position: absolute;
  inset: auto -2rem -2.8rem auto;
  width: 7rem;
  height: 7rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(230, 217, 219,.22), transparent 68%);
  pointer-events: none;
}

.course-module-benefit-card:hover {
  transform: translateY(-4px);
  border-color: rgba(162, 117, 119,.34);
  background: var(--white);
  box-shadow: var(--shadow-card);
}

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

.course-module-head .course-icon {
  width: 2.25rem;
  height: 2.25rem;
}

.course-module-benefit-card strong {
  color: var(--purple-900);
  font-size: .92rem;
  font-weight: 900;
  line-height: 1.25;
}

.course-module-benefit-card p {
  color: rgba(74, 58, 64,.66);
  font-size: .78rem;
  line-height: 1.48;
  margin: .65rem 0 1rem;
}

.course-module-benefit-card small {
  margin-top: auto;
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  background: var(--lavender-100);
  color: var(--purple-900);
  font-size: .7rem;
  font-weight: 900;
  line-height: 1.2;
  padding: .45rem .65rem;
}

.course-scarcity-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  border: 1px solid rgba(162, 117, 119,.28);
  border-radius: 999px;
  background: var(--rose-100);
  color: var(--purple-900);
  font-size: .78rem;
  font-weight: 900;
  line-height: 1.25;
  padding: .68rem .8rem;
  margin: .15rem 0 .2rem;
  text-align: center;
}

.course-scarcity-note::before {
  content: "✦";
  color: var(--rose-500);
}

@media (max-width: 991px) {
  .course-module-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 767px) {
  .section-pad {
    padding-top: clamp(4rem, 12vw, 5.5rem);
    padding-bottom: clamp(4rem, 12vw, 5.5rem);
  }

  .about-video-placeholder {
    align-items: flex-start;
  }

  .course-module-grid { grid-template-columns: 1fr; }
  .course-module-benefit-card { min-height: auto; }
}
