:root {
  --ink: #15171a;
  --muted: #5c6570;
  --line: #d8dde3;
  --paper: #ffffff;
  --soft: #f4f6f8;
  --cream: #fbf7ef;
  --red: #c7202f;
  --red-dark: #971827;
  --teal: #146c72;
  --gold: #d99a19;
  --shadow: 0 18px 45px rgba(16, 24, 40, .13);
  --radius: 8px;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html:has(body.app-shell) {
  height: 100%;
  overflow: hidden;
  scroll-behavior: auto;
}
.anchor-target { display: block; scroll-margin-top: 88px; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.5;
}
a { color: inherit; }
img { max-width: 100%; display: block; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  gap: 20px;
  min-height: 72px;
  padding: 12px clamp(18px, 4vw, 56px);
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(21, 23, 26, .08);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  min-width: 190px;
}
.brand-mark {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  background: var(--red);
  color: #fff;
  border-radius: 8px;
  font-weight: 900;
  letter-spacing: 0;
}
.brand small { display: block; color: var(--muted); font-size: 12px; line-height: 1.2; }
.site-nav {
  display: flex;
  gap: 2px;
  align-items: center;
  margin-left: auto;
}
.site-nav a {
  text-decoration: none;
  padding: 8px 8px;
  border-radius: 7px;
  font-weight: 700;
  font-size: 13px;
  color: #303741;
  white-space: nowrap;
}
.site-nav a:hover, .site-nav a.active { background: #f0f3f5; color: var(--red-dark); }
.nav-formula-menu {
  position: relative;
}
.nav-formula-trigger {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 33px;
  border: 0;
  border-radius: 7px;
  padding: 8px 8px;
  background: transparent;
  color: #303741;
  font: inherit;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}
.nav-formula-trigger:hover,
.nav-formula-trigger.active,
.nav-formula-menu.is-open .nav-formula-trigger {
  background: #f0f3f5;
  color: var(--red-dark);
}
.nav-formula-trigger small {
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  padding: 2px 6px;
  border-radius: 999px;
  background: #fff1f2;
  color: var(--red-dark);
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.nav-formula-trigger:hover small,
.nav-formula-trigger.active small {
  background: var(--red);
  color: #fff;
}
.nav-formula-panel {
  position: absolute;
  left: 50%;
  top: calc(100% + 10px);
  z-index: 90;
  display: none;
  width: min(760px, calc(100vw - 32px));
  grid-template-columns: 1fr;
  gap: 9px;
  max-height: min(76vh, 620px);
  overflow: auto;
  padding: 12px;
  border: 1px solid #dfe7e8;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 26px 70px rgba(16,24,40,.16);
  transform: translateX(-50%);
}
.nav-formula-menu:hover .nav-formula-panel,
.nav-formula-menu:focus-within .nav-formula-panel,
.nav-formula-menu.is-open .nav-formula-panel {
  display: grid;
}
.nav-formula-intro {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 5px 12px;
  align-items: center;
  padding: 13px 14px;
  border: 1px solid rgba(17,122,122,.16);
  border-radius: 10px;
  background:
    radial-gradient(circle at 100% 50%, rgba(199,32,47,.12), transparent 38%),
    linear-gradient(135deg, rgba(17,122,122,.09), rgba(255,247,248,.9)),
    #fff;
}
.nav-formula-intro span {
  grid-column: 1 / -1;
  color: var(--red-dark);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.nav-formula-intro strong {
  color: var(--ink);
  font-size: 18px;
  font-weight: 950;
  line-height: 1.1;
}
.nav-formula-intro a {
  padding: 9px 12px !important;
  border-radius: 999px !important;
  background: var(--red) !important;
  color: #fff !important;
  font-size: 12px;
  font-weight: 950;
}
.nav-formula-main-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.nav-formula-card {
  position: relative;
  display: grid;
  gap: 6px;
  align-content: start;
  min-height: 0;
  padding: 12px !important;
  border: 1px solid #e4ecec;
  border-radius: 8px !important;
  background: #f9fbfb;
  color: var(--ink) !important;
  white-space: normal !important;
  overflow: hidden;
}
.nav-formula-card-main {
  min-height: 172px;
  padding: 14px !important;
  border-color: rgba(17,122,122,.22);
  background:
    radial-gradient(circle at 100% 100%, rgba(199,32,47,.10), transparent 36%),
    linear-gradient(145deg, #ffffff, #f7fcfb);
  box-shadow: 0 14px 34px rgba(16,24,40,.05);
}
.nav-formula-card-main::after {
  content: "";
  position: absolute;
  right: -20px;
  bottom: -24px;
  width: 86px;
  height: 86px;
  border-radius: 999px;
  background: rgba(17,122,122,.08);
}
.nav-formula-card-main:nth-child(2),
.nav-formula-card-main:nth-child(4) {
  background:
    radial-gradient(circle at 100% 100%, rgba(17,122,122,.10), transparent 36%),
    linear-gradient(145deg, #ffffff, #fff7f8);
}
.nav-formula-card:hover,
.nav-formula-card.active {
  border-color: rgba(199,32,47,.28);
  background-color: #fff6f7 !important;
  color: var(--ink) !important;
}
.nav-formula-kicker {
  justify-self: start;
  padding: 4px 8px;
  border-radius: 999px;
  background: #111820;
  color: #fff;
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.nav-formula-card strong {
  color: var(--ink);
  font-size: 19px;
  font-weight: 950;
  line-height: 1.08;
}
.nav-formula-card small {
  color: var(--teal);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.1;
}
.nav-formula-badge {
  justify-self: start;
  padding: 4px 8px;
  border-radius: 999px;
  background: #e8f6f5;
  color: var(--teal);
  font-size: 10px;
  font-weight: 950;
}
.nav-formula-moment {
  color: #5d6672;
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.26;
}
.nav-formula-cta {
  align-self: end;
  justify-self: start;
  margin-top: 2px;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}
.nav-formula-quick-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 0 2px;
}
.nav-formula-quick-title span {
  color: var(--red-dark);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.nav-formula-quick-title strong {
  color: #5d6672;
  font-size: 12px;
  font-weight: 900;
}
.nav-formula-quick-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}
.nav-formula-card-quick {
  grid-template-columns: 1fr auto;
  gap: 3px 8px;
  align-items: center;
  min-height: 64px;
  padding: 9px 10px !important;
  background: #fff;
}
.nav-formula-card-quick .nav-formula-kicker {
  grid-column: 1 / -1;
  padding: 0;
  background: transparent;
  color: var(--red-dark);
  font-size: 9px;
}
.nav-formula-card-quick strong {
  font-size: 13px;
}
.nav-formula-card-quick small {
  justify-self: end;
  color: var(--ink);
  font-size: 11px;
}
.nav-formula-card-quick .nav-formula-badge,
.nav-formula-card-quick .nav-formula-moment {
  display: none;
}
.nav-formula-card-quick .nav-formula-cta {
  grid-column: 1 / -1;
  justify-self: start;
  padding: 0;
  background: transparent;
  color: var(--red-dark);
  font-size: 10px;
}
.nav-formula-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}
.nav-formula-steps span {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 30px;
  border: 1px solid #e4ecec;
  border-radius: 999px;
  background: #fff;
  color: #303741;
  font-size: 11px;
  font-weight: 950;
}
.header-login {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.header-client-tab {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 12px;
  border: 1px solid rgba(199,32,47,.22);
  border-radius: 7px;
  background: #fff6f7;
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}
.header-client-tab:hover,
.header-client-tab.active {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
.header-login-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 60;
  display: none;
  min-width: 220px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.header-login:hover .header-login-menu,
.header-login:focus-within .header-login-menu {
  display: grid;
  gap: 5px;
}
.header-login-menu a {
  text-decoration: none;
  display: flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 10px;
  border-radius: 7px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 850;
}
.header-login-menu a:hover {
  background: #fff6f7;
  color: var(--red-dark);
}
.header-call {
  text-decoration: none;
  background: var(--ink);
  color: #fff;
  padding: 10px 13px;
  border-radius: 7px;
  font-weight: 800;
  white-space: nowrap;
}
.menu-toggle { display: none; }

.hero {
  position: relative;
  min-height: min(420px, calc(44vh - 72px));
  background-image: var(--hero-image);
  background-size: cover;
  background-position: center;
  isolation: isolate;
  display: flex;
  align-items: center;
}
.hero-shade {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(90deg, rgba(10,13,16,.84) 0%, rgba(10,13,16,.64) 38%, rgba(10,13,16,.16) 73%, rgba(10,13,16,.05) 100%);
}
.hero-content {
  width: min(760px, 92vw);
  padding: clamp(24px, 4vw, 42px) clamp(20px, 5vw, 64px);
  color: #fff;
}
.eyebrow {
  margin: 0 0 10px;
  color: var(--red);
  font-size: 13px;
  line-height: 1.2;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.hero .eyebrow { color: #ffcb58; }
h1, h2, h3 { line-height: 1.05; letter-spacing: 0; }
h1 {
  margin: 0;
  font-size: clamp(36px, 5.4vw, 66px);
  max-width: 760px;
}
.hero-lead {
  margin: 16px 0 0;
  font-size: clamp(17px, 2vw, 22px);
  max-width: 640px;
  color: rgba(255,255,255,.92);
}
.hero-actions, .form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 20px;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 18px;
  border-radius: 7px;
  border: 1px solid transparent;
  text-decoration: none;
  font-weight: 900;
  cursor: pointer;
  font: inherit;
}
.btn.primary { background: var(--red); color: #fff; }
.btn.primary:hover { background: var(--red-dark); }
.btn.ghost { color: #fff; border-color: rgba(255,255,255,.55); background: rgba(255,255,255,.06); }
.btn.outline { color: var(--ink); border-color: var(--line); background: #fff; }
.btn.compact { min-height: 40px; padding: 10px 14px; }
.action-assistant[hidden] {
  display: none;
}
.action-assistant {
  position: fixed;
  left: clamp(14px, 4vw, 58px);
  right: clamp(14px, 4vw, 58px);
  bottom: 18px;
  z-index: 80;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto 34px;
  gap: 12px;
  align-items: center;
  max-width: 1040px;
  margin: 0 auto;
  padding: 12px;
  border: 1px solid rgba(20,108,114,.24);
  border-radius: 8px;
  background: rgba(255,255,255,.98);
  box-shadow: 0 20px 60px rgba(16,24,40,.22);
}
.action-assistant.is-visible {
  animation: actionPop .22s ease-out;
}
@keyframes actionPop {
  from { transform: translateY(10px); opacity: .4; }
  to { transform: translateY(0); opacity: 1; }
}
.action-assistant-copy span {
  display: inline-block;
  margin-bottom: 2px;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.action-assistant-copy strong {
  display: block;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.08;
}
.action-assistant-copy p {
  margin: 3px 0 0;
  color: var(--muted);
  font-size: 14px;
}
.action-assistant-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.action-assistant-actions .btn {
  white-space: nowrap;
}
.action-assistant > button {
  width: 34px;
  height: 34px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  color: var(--muted);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}
.hero-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  max-width: 600px;
  margin: 22px 0 0;
}
.hero-proof div {
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.08);
  border-radius: 8px;
  padding: 12px;
}
.hero-proof dt { font-size: 23px; font-weight: 950; }
.hero-proof dd { margin: 2px 0 0; color: rgba(255,255,255,.78); }

.page-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 18px;
  padding: clamp(28px, 4vw, 42px) clamp(20px, 5vw, 64px);
  background: linear-gradient(135deg, #fff 0%, #f6f7f9 54%, #fff4f3 100%);
  border-bottom: 1px solid var(--line);
}
.page-hero h1 { color: var(--ink); font-size: clamp(30px, 4.4vw, 48px); }
.page-hero p { max-width: 720px; font-size: 18px; color: var(--muted); }
.quick-panel {
  align-self: end;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
  box-shadow: var(--shadow);
}
.quick-panel strong, .quick-panel span { display: block; }
.quick-panel span { margin: 8px 0 16px; color: var(--muted); }
.quick-whatsapp { display: inline-block; margin-top: 12px; }

.fast-conversion-bar {
  display: grid;
  grid-template-columns: minmax(260px, .86fr) minmax(0, 1.14fr);
  gap: 16px;
  align-items: center;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
  background: #111418;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.fast-conversion-bar strong {
  display: block;
  margin-bottom: 3px;
  color: #ffcb58;
  font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.05;
}
.fast-conversion-bar span {
  color: rgba(255,255,255,.78);
  font-size: 15px;
}
.fast-conversion-bar nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.fast-action-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 14px;
  border-radius: 7px;
  text-decoration: none;
  font-weight: 950;
}
.fast-action-link.primary {
  background: var(--red);
  color: #fff;
}
.fast-action-link.outline {
  border: 1px solid rgba(255,255,255,.28);
  color: #fff;
}
.fast-action-link.ghost {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.9);
}
.fast-action-link.active {
  box-shadow: 0 0 0 2px rgba(255,203,88,.35);
}

.source-funnel {
  background: linear-gradient(180deg, #f7fbfa 0%, #ffffff 100%);
  border-bottom: 1px solid var(--line);
}
.source-funnel-head {
  display: grid;
  grid-template-columns: minmax(280px, .8fr) minmax(260px, .52fr);
  gap: 18px;
  align-items: end;
  margin-bottom: 14px;
}
.source-funnel-head h2 {
  margin: 4px 0 0;
  font-size: clamp(30px, 4vw, 54px);
  line-height: .98;
}
.source-funnel-head p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}
.source-funnel-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}
.source-step {
  display: flex;
  flex-direction: column;
  min-height: 218px;
  padding: 15px;
  border: 1px solid #d8e3e2;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16, 24, 40, .05);
}
.source-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: var(--teal);
  color: #fff;
  font-weight: 950;
}
.source-step h3 {
  margin: 14px 0 7px;
  font-size: 24px;
  line-height: 1;
}
.source-step p {
  margin: 0 0 14px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}
.source-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: auto;
}
.source-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid #d6e1e0;
  border-radius: 7px;
  background: #f8fbfb;
  color: var(--ink);
  font-size: 13px;
  font-weight: 950;
  text-decoration: none;
}
.source-actions a.primary,
.source-actions a.pay {
  border-color: var(--red);
  background: var(--red);
  color: #fff;
}
.source-actions a.pay {
  background: var(--ink);
  border-color: var(--ink);
}
.source-funnel-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 12px;
  padding: 12px 14px;
  border: 1px solid #d8e3e2;
  border-radius: 8px;
  background: #eef8f7;
  color: #17383c;
}
.source-funnel-strip strong {
  color: var(--teal);
}
.source-funnel-strip span {
  flex: 1 1 520px;
  color: #43515a;
  font-weight: 800;
}
.source-funnel-strip a {
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.source-funnel-strip a::after { content: " ->"; }

.essential-workflow {
  background:
    linear-gradient(180deg, #f7fbfa 0%, #ffffff 100%);
  border-bottom: 1px solid var(--line);
}
.essential-head {
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(260px, .55fr);
  gap: 18px;
  align-items: end;
  margin-bottom: 14px;
}
.essential-head h2 {
  margin: 3px 0 0;
  max-width: 780px;
  font-size: clamp(30px, 4.5vw, 56px);
  line-height: .96;
}
.essential-head p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  font-weight: 750;
}
.essential-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1.05fr) minmax(220px, .82fr) minmax(220px, .82fr) minmax(210px, .72fr);
  gap: 12px;
  align-items: stretch;
}
.essential-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 258px;
  padding: 16px;
  border: 1px solid #d7e5e4;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(16, 24, 40, .06);
}
.essential-card > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: var(--teal);
  color: #fff;
  font-weight: 950;
}
.essential-card h3 {
  margin: 14px 0 10px;
  font-size: clamp(24px, 2.7vw, 34px);
  line-height: .98;
}
.essential-card > strong {
  display: block;
  margin: 0 0 7px;
  color: var(--red-dark);
  font-size: clamp(21px, 2.6vw, 31px);
  line-height: 1.02;
}
.essential-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  font-weight: 760;
}
.essential-card ul {
  display: grid;
  gap: 8px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}
.essential-card li {
  padding: 9px 10px;
  border-left: 4px solid #e8b000;
  border-radius: 7px;
  background: #f8fafb;
  color: #28313a;
  font-size: 14px;
  font-weight: 900;
}
.essential-date-list {
  display: grid;
  gap: 9px;
  margin-top: auto;
}
.essential-date .essential-date-list {
  max-height: 420px;
  overflow: auto;
  padding-right: 4px;
  overscroll-behavior: contain;
}
.essential-date .essential-date-list::-webkit-scrollbar {
  width: 6px;
}
.essential-date .essential-date-list::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #cfe0df;
}
.essential-date-pill {
  display: block;
  padding: 12px;
  border: 1px solid #cfe0df;
  border-radius: 8px;
  background: #f7fbfa;
  color: var(--ink);
  text-decoration: none;
}
.essential-date-pill.active,
.essential-date-pill:hover {
  border-color: var(--red);
  box-shadow: 0 10px 24px rgba(207, 24, 43, .1);
}
.essential-date-pill strong {
  display: block;
  margin-bottom: 4px;
  color: var(--teal);
  font-size: 16px;
  line-height: 1;
}
.essential-date-pill span {
  display: block;
  color: #303943;
  font-weight: 950;
  line-height: 1.2;
}
.essential-pay {
  background: #111418;
  color: #fff;
  border-color: #111418;
}
.essential-pay > span {
  background: var(--red);
}
.essential-pay h3,
.essential-pay > strong {
  color: #fff;
}
.essential-pay p {
  color: rgba(255,255,255,.78);
}
.essential-pay .btn {
  width: 100%;
  margin-top: 12px;
}
.essential-pay .btn.outline {
  color: #fff;
  border-color: rgba(255,255,255,.3);
  background: rgba(255,255,255,.08);
}
.essential-founder {
  padding: 0;
  overflow: hidden;
  background: #fff;
}
.essential-founder img {
  width: 100%;
  height: 172px;
  object-fit: cover;
  object-position: center 28%;
}
.essential-founder div {
  padding: 13px;
}
.essential-founder div > span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 8px;
  border-radius: 7px;
  background: #f5e9d7;
  color: #8a5c12;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.essential-founder h3 {
  margin: 0 0 8px;
  color: var(--ink);
  font-size: clamp(21px, 2vw, 28px);
  line-height: 1;
}
.essential-founder p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.32;
}

.cards-wrap, .content-band, .pricing-section, .price-highlights, .tariff-chooser, .tariff-offers, .tariff-rules, .tariff-details, .visual-band, .faq-section, .lead-section, .source-band, .case-router, .steps-section, .hour-guide, .reassurance-bar, .whatsapp-section, .motivation-gallery, .evaluation-section, .exam-projection, .training-emotion, .enrollment-boost, .training-schedule, .journey-path, .ultra-path, .monitor-hub, .monitor-profile, .center-seo, .next-dates-home, .decision-dashboard, .audience-gateway, .customer-momentum, .network-teaser, .mobility-support, .notification-center, .fast-conversion-bar, .source-funnel, .essential-workflow, .simple-access, .access-help, .compact-details, .portal-switcher, .portal-overview, .pilot-command, .portal-roles, .portal-metrics, .portal-modules, .portal-next, .livret-followup, .data-privacy-map, .partner-momentum, .partner-intro, .recruitment-payoff, .monitor-desire, .monitor-selection, .apporteur-management, .awards-panel, .partner-method, .monitor-space, .monitor-docs, .monitor-conditions, .monitor-ops, .partner-fit, .partner-form-section {
  padding: clamp(20px, 3vw, 34px) clamp(18px, 4.5vw, 58px);
}
.ultra-path {
  display: grid;
  grid-template-columns: minmax(260px, .55fr) minmax(0, 1.45fr);
  gap: 18px;
  align-items: stretch;
  background: #15171a;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ultra-path .eyebrow {
  color: #ffcb58;
}
.ultra-path-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.ultra-path-copy h2 {
  margin: 4px 0 10px;
  font-size: clamp(26px, 3.5vw, 40px);
  line-height: 1;
}
.ultra-path-copy p {
  max-width: 560px;
  color: rgba(255,255,255,.76);
  font-size: 16px;
}
.ultra-step-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.ultra-step-card {
  display: flex;
  flex-direction: column;
  min-height: 132px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
  color: #fff;
  text-decoration: none;
}
.ultra-step-card span {
  align-self: flex-start;
  padding: 5px 8px;
  border-radius: 6px;
  background: rgba(255,203,88,.14);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.ultra-step-card strong {
  display: block;
  margin: 10px 0 5px;
  font-size: 20px;
  line-height: 1.04;
}
.ultra-step-card small {
  color: rgba(255,255,255,.72);
  font-size: 14px;
}
.ultra-step-card em {
  margin-top: auto;
  padding-top: 14px;
  color: #ffcb58;
  font-style: normal;
  font-weight: 950;
}
.ultra-step-card em::after { content: " ->"; }
.journey-path {
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.journey-path-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.journey-path-grid article {
  display: flex;
  flex-direction: column;
  min-height: 210px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafb;
}
.journey-path-grid span {
  align-self: flex-start;
  padding: 6px 8px;
  border-radius: 6px;
  background: #eef6f5;
  color: #0e555c;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.journey-path-grid h3 {
  margin: 14px 0 8px;
  font-size: 23px;
}
.journey-path-grid p {
  margin: 0;
  color: var(--muted);
}
.journey-path-grid a {
  margin-top: auto;
  padding-top: 16px;
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.journey-path-grid a::after { content: " ->"; }
.decision-dashboard {
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1.28fr);
  gap: 18px;
  align-items: stretch;
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.decision-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 640px;
}
.decision-copy h2 {
  margin: 4px 0 10px;
  font-size: clamp(28px, 3.8vw, 44px);
  line-height: 1;
}
.decision-copy p {
  max-width: 560px;
  color: var(--muted);
  font-size: 17px;
}
.decision-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.decision-grid article {
  display: flex;
  flex-direction: column;
  min-height: 132px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafb;
  box-shadow: 0 10px 24px rgba(16,24,40,.04);
}
.decision-grid span {
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.decision-grid strong {
  display: block;
  margin: 8px 0 5px;
  font-size: 18px;
  line-height: 1.05;
}
.decision-grid em {
  color: #0e555c;
  font-style: normal;
  font-weight: 950;
}
.decision-grid a {
  margin-top: auto;
  padding-top: 14px;
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.decision-grid a::after { content: " ->"; }
.compact-details {
  background: #f7f9fa;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.compact-details details {
  max-width: 1220px;
  margin: 0 auto;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.compact-details summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 56px;
  padding: 14px 16px;
  cursor: pointer;
  font-weight: 950;
}
.compact-details summary::after {
  content: "Ouvrir";
  flex: 0 0 auto;
  padding: 8px 10px;
  border-radius: 7px;
  background: var(--red);
  color: #fff;
  font-size: 13px;
  font-weight: 950;
}
.compact-details details[open] summary::after {
  content: "Réduire";
  background: var(--ink);
}
.compact-details summary span {
  font-size: clamp(19px, 2.2vw, 25px);
}
.compact-details summary small {
  color: var(--muted);
  font-weight: 800;
}
.compact-details-body {
  border-top: 1px solid var(--line);
  padding: 0 16px 6px;
}
.compact-details-body section {
  padding: 18px 0;
}
.compact-details-body .section-head {
  margin-bottom: 14px;
}
.compact-details-body .section-head h2 {
  font-size: clamp(22px, 3vw, 34px);
}
.compact-details-body .section-head p,
.compact-details-body p {
  font-size: 15px;
}
.compact-text-mode {
  color: #222b34;
}
.compact-text-mode section {
  padding: 12px 0;
  border-bottom: 1px solid #edf1f3;
}
.compact-text-mode section:last-child {
  border-bottom: 0;
}
.compact-text-mode .section-head,
.compact-text-mode .section-head.compact {
  margin-bottom: 9px;
}
.compact-text-mode .section-head h2,
.compact-text-mode h2 {
  font-size: clamp(19px, 2.4vw, 28px);
  line-height: 1.08;
}
.compact-text-mode h3 {
  font-size: clamp(17px, 2vw, 22px);
  line-height: 1.08;
}
.compact-text-mode p,
.compact-text-mode li,
.compact-text-mode small {
  font-size: 14px;
  line-height: 1.42;
}
.compact-text-mode .eyebrow {
  margin-bottom: 5px;
  font-size: 11px;
}
.compact-text-mode ul,
.compact-text-mode ol {
  margin: 8px 0 0;
  padding-left: 18px;
}
.compact-text-mode :where(
  .card-grid,
  .check-list,
  .case-grid,
  .steps-grid,
  .hour-grid,
  .decision-grid,
  .ultra-step-grid,
  .journey-path-grid,
  .partner-momentum-grid,
  .simple-access-grid,
  .access-help-grid,
  .source-funnel-grid,
  .price-chip-grid,
  .tariff-situation-grid,
  .tariff-offer-grid,
  .tariff-rule-grid,
  .projection-windows,
  .projection-offer-grid,
  .projection-buying-strip,
  .training-pass-route,
  .training-emotion-road,
  .training-emotion-stats,
  .schedule-data-grid,
  .schedule-road,
  .payment-direct-strip,
  .enrollment-steps,
  .contract-extra-grid,
  .schedule-flow,
  .schedule-grid,
  .monitor-grid,
  .monitor-detail-grid,
  .monitor-method-grid,
  .center-seo-grid,
  .partner-step-grid,
  .payoff-grid,
  .desire-grid,
  .portal-switch-grid,
  .portal-metrics,
  .pilot-kpi-grid,
  .pilot-queue,
  .pilot-role-grid,
  .pilot-position-grid,
  .pilot-timeline,
  .portal-role-grid,
  .portal-module-grid,
  .portal-access-flow,
  .portal-access-fields,
  .livret-track-grid,
  .livret-competence-grid,
  .livret-hub-grid,
  .data-access-grid,
  .data-access-columns,
  .data-rule-grid,
  .doc-check-grid,
  .condition-grid,
  .notification-grid,
  .ops-layout,
  .quick-reply-grid
) {
  gap: 8px;
}
.compact-text-mode :where(article, .card, .source-card, .case-card, .step-card, .hour-card, .tariff-situation, .tariff-offer-card, .tariff-rule-card, .projection-window, .projection-offer-card, .payment-method-card, .monitor-card, .partner-track-card, .ops-card, .pilot-role-card, .portal-role-card, .data-access-card, .data-rule-grid article, .portal-module-grid article, .livret-track-grid article, .doc-check-grid article, .condition-grid article, .notification-grid article, .quick-reply-grid article) {
  min-height: 0;
  padding: 11px;
  border-radius: 8px;
}
.compact-text-mode :where(article, .card) strong {
  line-height: 1.1;
}
.compact-text-mode :where(.visual-band, .motivation-gallery, .portal-hero-card, .monitor-profile-hero, .monitor-scorecard, .training-pass-visual, .schedule-side-card figure, .portal-login-visual) {
  display: none;
}
.compact-text-mode :where(img) {
  max-height: 160px;
  object-fit: cover;
}
.compact-text-mode :where(.motivation-card, .ultra-step-card, .journey-path-grid article, .source-step, .partner-track-card, .monitor-card) {
  min-height: 0;
}
.compact-text-mode :where(.projection-date-card, .next-date-card, .essential-date-pill) {
  min-height: 0;
}
.compact-text-mode :where(.btn) {
  min-height: 38px;
  padding: 9px 12px;
}
.compact-text-mode :where(.lead-form, .partner-form, .evaluation-form, .enrollment-panel, .contract-modal-fields, .portal-access-fields) {
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  max-width: none;
}
.compact-text-mode :where(input, select, textarea) {
  min-height: 38px;
  padding: 8px 10px;
  font-size: 14px;
}
.compact-text-mode :where(textarea) {
  min-height: 68px;
  max-height: 96px;
}
.compact-text-mode :where(.lead-form label, .partner-form label, .evaluation-form label, .enrollment-panel label) {
  gap: 4px;
  font-size: 13px;
  line-height: 1.2;
}
.compact-text-mode .form-optional {
  border-color: #dbe5e5;
  background: #f8faf9;
}
.compact-text-mode .form-optional summary {
  padding: 9px 10px;
  color: #0e555c;
  font-size: 13px;
}
.compact-text-mode .form-optional:not([open]) > :not(summary) {
  display: none !important;
}
.compact-text-mode .form-optional-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 7px;
  padding: 0 10px 10px;
}
.compact-text-mode .form-optional-grid label {
  color: #24303a;
}
.compact-text-mode :where(.form-actions, .evaluation-actions, .evaluation-result-actions, .payment-method-row) {
  gap: 7px;
}
.compact-text-mode .consent {
  font-size: 12px;
}
.compact-text-mode .faq-list details,
.compact-text-mode .contract-preview-wrap,
.compact-text-mode .contract-extra-fields {
  margin-top: 8px;
}
.compact-text-mode .exam-projection {
  max-height: none;
}
.compact-text-mode .projection-head {
  margin-bottom: 10px;
}
.compact-text-mode .projection-head h2 {
  font-size: clamp(20px, 2.6vw, 30px);
}
.compact-text-mode .projection-head p:last-child {
  font-size: 14px;
}
.compact-text-mode .projection-stage,
.compact-text-mode .projection-layout {
  grid-template-columns: 1fr;
  gap: 10px;
}
.compact-text-mode .projection-zone-head,
.compact-text-mode .projection-selected-action {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 10px;
}
.compact-text-mode .projection-selected-action strong {
  font-size: 18px;
}
.compact-text-mode .projection-selected-action p {
  font-size: 13px;
}
.compact-text-mode .projection-selected-actions {
  justify-content: flex-start;
  min-width: 0;
}
.compact-text-mode .projection-date-grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  max-height: 340px;
  overflow: auto;
  padding-right: 4px;
  gap: 8px;
}
.compact-text-mode .projection-date-card {
  min-height: 92px;
  padding: 10px;
  gap: 4px;
}
.compact-text-mode .projection-date-card span {
  font-size: 11px;
  padding: 4px 6px;
}
.compact-text-mode .projection-date-card strong {
  font-size: 22px;
}
.compact-text-mode .projection-date-card small,
.compact-text-mode .projection-date-card em {
  font-size: 12px;
  line-height: 1.25;
}
.compact-text-mode .projection-date-card.active::after {
  position: static;
  justify-self: start;
  margin-top: 2px;
}
.compact-text-mode .projection-offer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 7px;
}
.compact-text-mode .projection-offer-chip {
  min-height: 0;
  padding: 8px;
}
.compact-text-mode .projection-result {
  padding: 12px;
}
.compact-text-mode .projection-result h3,
.compact-text-mode .projection-hero-date strong {
  font-size: 22px;
}
.compact-text-mode .projection-countdown,
.compact-text-mode .projection-day-scene,
.compact-text-mode .projection-after-payment,
.compact-text-mode .projection-buying-strip {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
}
.compact-text-mode .projection-center-photo-card {
  display: none;
}
.compact-text-mode .projection-meta,
.compact-text-mode .projection-actions {
  gap: 7px;
}
.compact-text-mode .case-router .section-head,
.compact-text-mode .monitor-hub .section-head {
  max-width: 760px;
}
.compact-text-mode .formula-selected-action,
.compact-text-mode .emotion-selected-action {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  margin-bottom: 10px;
  padding: 10px;
  box-shadow: none;
}
.compact-text-mode .formula-selected-action > div:first-child > strong,
.compact-text-mode .emotion-selected-action > div:first-child > strong {
  font-size: clamp(18px, 2.1vw, 24px);
}
.compact-text-mode .formula-selected-price,
.compact-text-mode .emotion-selected-meta {
  padding: 9px;
}
.compact-text-mode .formula-selected-price strong,
.compact-text-mode .emotion-selected-meta strong {
  font-size: 22px;
}
.compact-text-mode .formula-selected-action ul,
.compact-text-mode .emotion-selected-action ul {
  display: none;
}
.compact-text-mode .formula-selected-actions,
.compact-text-mode .emotion-selected-actions {
  grid-column: 1 / -1;
}
.compact-text-mode .case-grid,
.compact-text-mode .monitor-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  max-height: 560px;
  overflow: auto;
  padding-right: 4px;
}
.compact-text-mode .case-card {
  min-height: 0;
  padding: 10px;
}
.compact-text-mode .case-card h3 {
  margin: 7px 0 4px;
  font-size: 18px;
}
.compact-text-mode .case-card p {
  font-size: 13px;
  line-height: 1.32;
}
.compact-text-mode .case-card > strong {
  margin-top: 8px;
  font-size: 20px;
}
.compact-text-mode .case-card em {
  padding-top: 8px;
  font-size: 13px;
}
.compact-text-mode .monitor-hub-layout {
  grid-template-columns: 1fr;
  gap: 10px;
}
.compact-text-mode .monitor-map-card {
  position: static;
  padding: 11px;
  box-shadow: none;
}
.compact-text-mode .monitor-map-card h3 {
  font-size: 20px;
  margin-bottom: 6px;
}
.compact-text-mode .monitor-map-card p {
  font-size: 13px;
}
.compact-text-mode .monitor-zone-cloud,
.compact-text-mode .monitor-tags {
  gap: 5px;
  margin-top: 8px;
}
.compact-text-mode .monitor-zone-cloud span,
.compact-text-mode .monitor-tags span {
  min-height: 26px;
  padding: 4px 7px;
  font-size: 11px;
}
.compact-text-mode .monitor-hub-actions,
.compact-text-mode .monitor-actions {
  margin-top: 10px;
  gap: 7px;
}
.compact-text-mode .monitor-card {
  min-height: 0;
  padding: 10px;
}
.compact-text-mode .monitor-card-head {
  grid-template-columns: 44px 1fr;
  gap: 8px;
}
.compact-text-mode .monitor-avatar {
  width: 44px;
  height: 44px;
}
.compact-text-mode .monitor-photo {
  width: 46px;
}
.compact-text-mode .monitor-photo span {
  display: none;
}
.compact-text-mode .monitor-photo.large {
  width: 64px;
}
.compact-text-mode .monitor-avatar strong {
  font-size: 17px;
}
.compact-text-mode .monitor-card-head h3 {
  margin: 2px 0 0;
  font-size: 17px;
}
.compact-text-mode .monitor-card blockquote {
  margin: 7px 0;
  padding: 8px;
  font-size: 13px;
}
.compact-text-mode .monitor-fit,
.compact-text-mode .monitor-card dl {
  margin-top: 8px;
}
.compact-text-mode .monitor-style-chips {
  gap: 5px;
  margin-top: 8px;
}
.compact-text-mode .monitor-style-chips span {
  min-height: 24px;
  padding: 4px 7px;
  font-size: 11px;
}
.compact-text-mode .monitor-team-spirit {
  grid-template-columns: 1fr;
  gap: 8px;
  margin: 8px 0;
  padding: 10px;
}
.compact-text-mode .monitor-team-faces {
  grid-template-columns: repeat(5, minmax(42px, 1fr));
  gap: 5px;
}
.compact-text-mode .monitor-team-faces figcaption {
  display: none;
}
.compact-text-mode .monitor-team-note {
  padding: 8px;
  font-size: 12px !important;
}
.compact-text-mode .partner-onboarding-panel {
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 8px;
  padding: 10px;
}
.compact-text-mode .partner-doc-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}
.compact-text-mode .partner-doc-grid article {
  padding: 8px;
}
.compact-text-mode .partner-doc-grid strong {
  font-size: 13px;
}
.compact-text-mode .partner-doc-grid p {
  font-size: 11px;
}
.simple-access {
  background: #f7faf9;
  border-bottom: 1px solid #dce7e7;
}
.simple-access-head {
  max-width: 840px;
  margin-bottom: 22px;
}
.simple-access-head h2 {
  margin: 4px 0 10px;
  font-size: clamp(38px, 6vw, 82px);
  line-height: .95;
}
.simple-access-head p {
  max-width: 720px;
  color: var(--muted);
  font-size: 20px;
}
.portal-hero-card {
  display: grid;
  grid-template-columns: minmax(260px, .72fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  margin: 0 0 18px;
  overflow: hidden;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(16,24,40,.08);
}
.portal-hero-card img {
  width: 100%;
  height: 100%;
  min-height: 230px;
  object-fit: cover;
}
.portal-hero-card figcaption {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  padding: clamp(18px, 3vw, 28px);
}
.portal-hero-card span,
.portal-login-visual figcaption {
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.portal-hero-card strong {
  color: var(--ink);
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: 1;
}
.portal-hero-card p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}
.simple-access-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.simple-access-card {
  display: flex;
  flex-direction: column;
  min-height: 190px;
  padding: 18px;
  border: 1px solid #d7e4e4;
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 14px 34px rgba(16,24,40,.06);
}
.simple-access-card:hover {
  border-color: var(--teal);
  transform: translateY(-1px);
}
.simple-access-card span {
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.simple-access-card strong {
  display: block;
  margin: 18px 0;
  font-size: clamp(24px, 2.5vw, 34px);
  line-height: 1.05;
}
.simple-access-card small {
  margin-top: auto;
  color: #0e555c;
  font-weight: 950;
}
.access-help {
  display: grid;
  grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr);
  gap: 22px;
  align-items: start;
  background: #fff;
}
.access-help h2 {
  margin: 4px 0 12px;
  font-size: clamp(30px, 4vw, 54px);
  line-height: 1;
}
.access-help p {
  color: var(--muted);
}
.access-help-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.access-help-grid article {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f7faf9;
}
.access-help-grid strong {
  display: block;
  margin-bottom: 8px;
  font-size: 21px;
}
.access-help-grid p {
  margin: 0;
  color: var(--muted);
}
.audience-gateway {
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.audience-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.audience-card {
  display: flex;
  flex-direction: column;
  min-height: 190px;
  padding: 18px;
  border: 1px solid #dde4e8;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16, 24, 40, .05);
}
.audience-card h3 {
  margin: 0 0 10px;
  font-size: 24px;
}
.audience-card p {
  margin: 0 0 18px;
  color: var(--muted);
}
.audience-card a {
  align-self: flex-start;
  margin-top: auto;
}
.customer-momentum {
  background: #151b20;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.customer-momentum .eyebrow {
  color: #ffcb58;
}
.momentum-layout {
  display: grid;
  grid-template-columns: minmax(280px, .84fr) minmax(0, 1.16fr);
  gap: 22px;
  align-items: start;
}
.momentum-copy h2 {
  margin: 4px 0 12px;
  max-width: 760px;
  font-size: clamp(31px, 4vw, 58px);
  line-height: 1;
}
.momentum-copy p {
  max-width: 700px;
  color: rgba(255,255,255,.78);
  font-size: 18px;
}
.momentum-actions,
.partner-momentum-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.customer-momentum .btn.outline,
.partner-momentum .btn.outline {
  color: #fff;
  border-color: rgba(255,255,255,.35);
  background: transparent;
}
.momentum-path {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.momentum-step {
  display: grid;
  gap: 10px;
  min-height: 168px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
  color: #fff;
  text-decoration: none;
}
.momentum-step:hover {
  border-color: rgba(255,203,88,.65);
  transform: translateY(-1px);
}
.momentum-step span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  min-height: 34px;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.partner-momentum-grid span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-weight: 950;
}
.momentum-step strong {
  font-size: 22px;
  line-height: 1.05;
}
.momentum-step p {
  margin: 0;
  color: rgba(255,255,255,.76);
}
.partner-momentum {
  display: grid;
  grid-template-columns: minmax(280px, .86fr) minmax(0, 1.14fr);
  gap: 22px;
  align-items: start;
  background: #101820;
  color: #fff;
}
.partner-momentum .eyebrow {
  color: #ffcb58;
}
.partner-momentum-copy h2 {
  margin: 4px 0 12px;
  font-size: clamp(32px, 4vw, 60px);
  line-height: 1;
}
.partner-momentum-copy p {
  max-width: 720px;
  color: rgba(255,255,255,.78);
  font-size: 18px;
}
.partner-momentum > .emotion-selected-action {
  margin: 0;
}
.partner-momentum-grid {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.partner-momentum-grid article {
  min-height: 168px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
  color: #fff;
  cursor: pointer;
}
.partner-momentum-grid strong {
  display: block;
  margin: 18px 0 8px;
  font-size: 24px;
  line-height: 1.05;
}
.partner-momentum-grid p {
  margin: 0;
  color: rgba(255,255,255,.76);
}
.client-space-app,
.client-training-film,
.client-quick-modules {
  background: #fff;
}
.client-space-head {
  max-width: 900px;
  margin-bottom: 16px;
}
.client-space-head h2,
.client-film-copy h2 {
  margin: 4px 0 10px;
  font-size: clamp(30px, 4vw, 58px);
  line-height: 1;
}
.client-space-head p,
.client-film-copy p {
  color: var(--muted);
  font-size: 18px;
}
.client-space-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .72fr);
  gap: 14px;
  align-items: stretch;
}
.client-journey-card {
  display: grid;
  gap: 14px;
  padding: 20px;
  border-radius: 8px;
  background: #15171a;
  color: #fff;
}
.client-journey-top span,
.client-login-card > span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 6px 8px;
  border-radius: 7px;
  background: rgba(255,255,255,.1);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.client-journey-top strong {
  display: block;
  font-size: clamp(25px, 3vw, 42px);
  line-height: 1.02;
}
.client-journey-top p {
  max-width: 720px;
  color: rgba(255,255,255,.78);
}
.client-status-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
}
.client-status-grid article {
  min-height: 126px;
  padding: 13px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
}
.client-status-grid article.active {
  border-color: rgba(255,203,88,.55);
  background: rgba(255,203,88,.12);
}
.client-status-grid span {
  display: block;
  color: #ffcb58;
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
}
.client-status-grid strong {
  display: block;
  margin: 8px 0 5px;
  color: #fff;
  font-size: 22px;
  line-height: 1;
}
.client-status-grid small {
  color: rgba(255,255,255,.72);
  font-weight: 760;
}
.client-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.client-login-card {
  padding: 18px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #f7faf9;
}
.client-login-card > span {
  background: rgba(199,32,47,.1);
  color: var(--red-dark);
}
.client-login-card h3 {
  margin: 0 0 8px;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1;
}
.client-login-card p,
.client-login-card small {
  color: var(--muted);
}
.client-login-form {
  display: grid;
  gap: 9px;
  margin: 14px 0 10px;
}
.client-login-form label {
  display: grid;
  gap: 5px;
  color: #303741;
  font-size: 13px;
  font-weight: 900;
}
.client-login-form input {
  width: 100%;
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 9px 10px;
  font: inherit;
}
.client-login-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.client-space-connected .client-login-card {
  border-color: rgba(20,108,114,.38);
  background: #effaf8;
}
.client-space-connected .client-login-card > span {
  background: rgba(20,108,114,.12);
  color: var(--teal);
}
.client-space-connected [data-client-access-request] {
  background: var(--teal);
  border-color: var(--teal);
}
.client-training-film {
  border-top: 1px solid #dce7e7;
}
.client-film-steps,
.client-module-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.client-film-steps article,
.client-module-grid article {
  padding: 16px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16,24,40,.05);
}
.client-film-steps span,
.client-module-grid span {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.client-film-steps strong,
.client-module-grid strong {
  display: block;
  color: var(--ink);
  font-size: 20px;
  line-height: 1.08;
}
.client-film-steps p,
.client-module-grid p {
  margin: 8px 0 0;
  color: var(--muted);
}
.portal-switcher {
  display: grid;
  grid-template-columns: minmax(280px, .82fr) minmax(0, 1.18fr);
  gap: 20px;
  align-items: center;
  background: #151b20;
  color: #fff;
}
.portal-switcher .eyebrow {
  color: #ffcb58;
}
.portal-switcher-copy h2 {
  margin: 4px 0 10px;
  font-size: clamp(30px, 4vw, 54px);
}
.portal-switcher-copy p {
  max-width: 720px;
  color: rgba(255,255,255,.78);
}
.portal-switch-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.portal-switch-card {
  display: grid;
  gap: 8px;
  min-height: 112px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.06);
  color: #fff;
  text-decoration: none;
}
.portal-switch-card.active {
  border-color: #ffcb58;
  background: rgba(255,203,88,.12);
}
.portal-switch-card span {
  color: #ffcb58;
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.portal-switch-card strong {
  font-size: 20px;
  line-height: 1.05;
}
.portal-switch-card small {
  align-self: end;
  color: rgba(255,255,255,.7);
  font-weight: 800;
}
.partner-intro {
  background: #f6faf9;
  border-bottom: 1px solid #dce7e7;
}
.partner-hero-card {
  display: grid;
  grid-template-columns: minmax(260px, .62fr) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
  margin: 0 0 18px;
  overflow: hidden;
  border: 1px solid rgba(20,108,114,.2);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(16,24,40,.08);
}
.partner-hero-card img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  object-fit: cover;
}
.partner-hero-card figcaption {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 10px;
  padding: clamp(18px, 3vw, 28px);
}
.partner-hero-card span {
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.partner-hero-card strong {
  color: var(--ink);
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: 1;
}
.partner-hero-card p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}
.partner-track-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.partner-track-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 420px;
  padding: 24px;
  border: 1px solid #dce4e5;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(16, 24, 40, .06);
}
.partner-track-card.dark {
  background: #151b20;
  color: #fff;
  border-color: #151b20;
}
.partner-track-card > span {
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.partner-track-card.dark > span {
  color: #ffcb58;
}
.partner-track-card h3 {
  margin: 0;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1;
}
.partner-track-card p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}
.partner-track-card.dark p,
.partner-track-card.dark li {
  color: rgba(255,255,255,.78);
}
.partner-track-card ul {
  margin: 0 0 auto;
  padding-left: 20px;
}
.partner-track-card li {
  margin: 6px 0;
  color: #36404a;
}
.partner-method {
  background: #fff;
}
.partner-step-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.partner-step-grid article {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.partner-step-grid span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-weight: 950;
}
.partner-step-grid h3 {
  margin: 16px 0 8px;
  font-size: 22px;
}
.partner-step-grid p {
  margin: 0;
  color: var(--muted);
}
.partner-fit {
  display: grid;
  grid-template-columns: minmax(260px, .85fr) minmax(0, 1.15fr);
  gap: 18px;
  align-items: start;
  background: #151b20;
  color: #fff;
}
.partner-fit .eyebrow {
  color: #ffcb58;
}
.partner-fit h2 {
  margin: 4px 0 12px;
  font-size: clamp(31px, 4vw, 58px);
  line-height: 1;
}
.partner-fit p {
  color: rgba(255,255,255,.78);
}
.partner-fit-list {
  display: grid;
  gap: 10px;
}
.partner-fit-list article {
  padding: 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.06);
}
.partner-fit-list strong {
  display: block;
  margin-bottom: 7px;
  color: #fff;
  font-size: 20px;
}
.partner-fit-list p {
  margin: 0;
}
.partner-form-section {
  background: linear-gradient(135deg, #fff 0%, #f7f9fa 100%);
}
.partner-form {
  max-width: 1080px;
}
.compact-partner .section-head {
  margin-bottom: 14px;
}
.compact-partner .partner-step-grid article,
.compact-partner .condition-grid article,
.compact-desire article,
.compact-payoff article {
  min-height: 0;
  padding: 16px;
}
.fast-apply {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}
.compact-form {
  margin-top: 0;
}
.compact-form textarea {
  min-height: 96px;
}
.notification-center {
  background: #fff;
  border-top: 1px solid #dce7e7;
  border-bottom: 1px solid #dce7e7;
}
.notification-head {
  display: grid;
  grid-template-columns: minmax(250px, .85fr) minmax(0, 1.15fr);
  gap: 18px;
  align-items: end;
  margin-bottom: 14px;
}
.notification-head h2 {
  margin: 4px 0 0;
  font-size: clamp(28px, 3.5vw, 48px);
  line-height: 1;
}
.notification-head p:last-child {
  margin: 0;
  color: var(--muted);
  font-weight: 760;
}
.notification-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.notification-grid article {
  min-height: 132px;
  padding: 14px;
  border: 1px solid #dce7e7;
  border-radius: 12px;
  background: #f8fbfb;
}
.notification-grid span {
  display: inline-flex;
  margin-bottom: 9px;
  padding: 5px 8px;
  border-radius: 999px;
  background: #fff1f2;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
}
.notification-grid strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.25;
}
.form-notification-note {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 8px;
  background: rgba(255,255,255,.08);
  color: inherit;
}
.form-notification-note strong {
  flex: 0 0 auto;
  color: #ffcb58;
}
.form-notification-note span {
  color: inherit;
  opacity: .88;
}
.partner-form .form-notification-note {
  border-color: #dce7e7;
  background: #f8fbfb;
  color: var(--ink);
}
.partner-form .form-notification-note strong {
  color: var(--teal);
}
.network-teaser {
  display: grid;
  grid-template-columns: minmax(260px, .95fr) minmax(0, 1.05fr);
  gap: 18px;
  align-items: center;
  background: #f7faf9;
  border-top: 1px solid #dce7e7;
  border-bottom: 1px solid #dce7e7;
}
.network-teaser-copy h2 {
  margin: 4px 0 12px;
  font-size: clamp(30px, 4vw, 54px);
  line-height: 1;
}
.network-teaser-copy p {
  max-width: 680px;
  color: var(--muted);
}
.network-teaser-panel {
  padding: 20px;
  border: 1px solid #d8e5e4;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(16,24,40,.06);
}
.network-pay-chips {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}
.network-pay-chips span {
  display: grid;
  place-items: center;
  min-height: 58px;
  border-radius: 8px;
  background: #151b20;
  color: #ffcb58;
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 950;
}
.network-teaser-panel p {
  margin: 0;
  color: var(--muted);
}
.network-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 18px;
}
.mobility-support {
  background: linear-gradient(135deg, #fff 0%, #f7fbfb 100%);
  border-top: 1px solid #dce7e7;
  border-bottom: 1px solid #dce7e7;
}
.mobility-support-head {
  display: grid;
  grid-template-columns: minmax(260px, .9fr) minmax(0, 1.1fr);
  gap: 18px;
  align-items: end;
  margin-bottom: 16px;
}
.mobility-support-head h2 {
  margin: 4px 0 0;
  font-size: clamp(28px, 3.6vw, 50px);
  line-height: 1;
}
.mobility-support-head > p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  font-weight: 760;
}
.mobility-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.mobility-grid article {
  min-height: 190px;
  padding: 16px;
  border: 1px solid #dce7e7;
  border-radius: 12px;
  background: #fff;
}
.mobility-grid article span {
  display: inline-flex;
  margin-bottom: 12px;
  padding: 6px 9px;
  border-radius: 999px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
}
.mobility-grid article strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: 21px;
  line-height: 1.04;
}
.mobility-grid article p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}
.partner-monetization-panel {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid #d7e5e4;
  border-radius: 10px;
  background: #fff;
}
.partner-monetization-panel .section-head {
  margin-bottom: 10px;
}
.partner-monetization-panel .section-head h2 {
  font-size: clamp(24px, 3vw, 38px);
}
.partner-monetization-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
.partner-monetization-grid article {
  min-height: 150px;
  padding: 12px;
  border: 1px solid #e0e9e8;
  border-radius: 8px;
  background: #f8fbfb;
}
.partner-monetization-grid span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 7px;
  border-radius: 7px;
  background: #e7f3f2;
  color: var(--teal);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.partner-monetization-grid strong {
  display: block;
  margin-bottom: 6px;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.08;
}
.partner-monetization-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.32;
}
.mobility-direct {
  border-color: rgba(199,32,47,.22) !important;
  background: #fff8f9 !important;
}
.mobility-direct .btn {
  width: 100%;
  margin-top: 12px;
}
.mobility-note {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}
.mobility-note a {
  color: var(--teal);
  font-weight: 900;
}
.portal-page .page-hero {
  background: linear-gradient(135deg, #f6faf9 0%, #fff 46%, #fff4f3 100%);
}
.portal-overview {
  display: grid;
  grid-template-columns: minmax(280px, .95fr) minmax(0, 1.05fr);
  gap: 20px;
  align-items: start;
  background: #fff;
}
.portal-overview-copy h2 {
  margin: 4px 0 14px;
  font-size: clamp(32px, 4vw, 58px);
  line-height: 1;
}
.portal-overview-copy p {
  color: var(--muted);
  font-size: 18px;
}
.portal-badges, .portal-mini-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.portal-badges span, .portal-mini-badges span {
  padding: 8px 10px;
  border-radius: 999px;
  background: #eef6f5;
  color: #0e555c;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.portal-login-panel {
  padding: 22px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #f7faf9;
  box-shadow: 0 14px 34px rgba(16,24,40,.06);
}
.portal-login-visual {
  margin: 0 0 16px;
  overflow: hidden;
  border: 1px solid rgba(20,108,114,.16);
  border-radius: 8px;
  background: #fff;
}
.portal-login-visual img {
  width: 100%;
  aspect-ratio: 16 / 7;
  object-fit: cover;
}
.portal-login-visual figcaption {
  padding: 10px 12px;
  color: var(--teal);
}
.portal-login-panel > span {
  display: inline-flex;
  margin-bottom: 12px;
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.portal-login-panel h3 {
  margin: 0 0 10px;
  font-size: clamp(26px, 3vw, 40px);
}
.portal-login-panel p {
  color: var(--muted);
}
.portal-access-flow {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 16px;
}
.portal-access-flow article {
  padding: 13px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
}
.portal-access-flow span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  margin-bottom: 10px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-weight: 950;
}
.portal-access-flow strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink);
  font-size: 15px;
  line-height: 1.1;
}
.portal-access-flow p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
}
.portal-access-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}
.portal-access-fields label {
  display: grid;
  gap: 6px;
  color: #303741;
  font-weight: 800;
}
.portal-access-fields input {
  width: 100%;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  color: var(--muted);
  font: inherit;
}
.portal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.portal-entry-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid #dce7e7;
}
.portal-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  padding-top: 0;
  padding-bottom: 0;
  background: var(--line);
}
.portal-metrics article {
  min-height: 92px;
  padding: 18px;
  background: #151b20;
  color: #fff;
}
.portal-metrics span {
  display: block;
  margin-bottom: 10px;
  color: rgba(255,255,255,.66);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.portal-metrics strong {
  color: #ffcb58;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1;
}
.portal-roles, .portal-modules {
  background: #f7faf9;
}
.portal-role-grid, .portal-module-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.portal-role-card, .portal-module-grid article {
  padding: 22px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.portal-role-card > span, .portal-module-grid article > span {
  display: inline-flex;
  margin-bottom: 14px;
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.portal-role-card h3, .portal-module-grid strong {
  display: block;
  margin: 0 0 10px;
  font-size: 24px;
  line-height: 1.08;
}
.portal-role-card p, .portal-module-grid p {
  color: var(--muted);
}
.portal-next {
  display: grid;
  grid-template-columns: minmax(280px, .8fr) minmax(0, 1.2fr);
  gap: 20px;
  align-items: start;
  background: #151b20;
  color: #fff;
}
.portal-next .eyebrow {
  color: #ffcb58;
}
.portal-next h2 {
  margin: 4px 0 0;
  font-size: clamp(30px, 4vw, 54px);
}
.portal-next ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.portal-next li {
  padding: 16px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.82);
}
.pilot-command {
  background: #f7faf9;
  border-top: 1px solid #dce7e7;
  border-bottom: 1px solid #dce7e7;
}
.pilot-hub {
  background: #151b20;
  color: #fff;
}
.pilot-layout {
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr);
  gap: 18px;
  align-items: start;
}
.pilot-lead h2 {
  margin: 4px 0 12px;
  max-width: 820px;
  font-size: clamp(31px, 4vw, 58px);
  line-height: 1;
}
.pilot-lead p {
  max-width: 760px;
  color: var(--muted);
  font-size: 18px;
}
.pilot-hub .pilot-lead p,
.pilot-hub .section-head p {
  color: rgba(255,255,255,.78);
}
.pilot-hub .eyebrow {
  color: #ffcb58;
}
.pilot-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.pilot-kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.pilot-kpi-grid article {
  min-height: 94px;
  padding: 16px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.pilot-hub .pilot-kpi-grid article {
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  box-shadow: none;
}
.pilot-kpi-grid span {
  display: block;
  margin-bottom: 12px;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.pilot-hub .pilot-kpi-grid span {
  color: #ffcb58;
}
.pilot-kpi-grid strong {
  display: block;
  color: var(--ink);
  font-size: clamp(22px, 3vw, 34px);
  line-height: 1;
}
.pilot-hub .pilot-kpi-grid strong {
  color: #fff;
}
.pilot-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 18px;
  margin-top: 24px;
}
.pilot-queue,
.pilot-workflow,
.pilot-role-grid {
  display: grid;
  gap: 10px;
}
.pilot-queue {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.pilot-workflow {
  grid-template-columns: 1fr;
}
.pilot-role-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 24px;
}
.pilot-queue article,
.pilot-workflow article,
.pilot-role-card {
  padding: 18px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
}
.pilot-role-card {
  display: flex;
  flex-direction: column;
  min-height: 260px;
  border-color: rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
}
.pilot-queue span,
.pilot-role-card span {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.pilot-role-card span {
  color: #ffcb58;
}
.pilot-queue p,
.pilot-workflow p,
.pilot-role-card p {
  margin: 0;
  color: var(--muted);
}
.pilot-workflow strong,
.pilot-role-card h3 {
  display: block;
  margin: 0 0 8px;
  color: var(--ink);
  font-size: 21px;
  line-height: 1.08;
}
.pilot-role-card h3 {
  color: #fff;
}
.pilot-role-card p {
  color: rgba(255,255,255,.76);
}
.pilot-role-card a {
  align-self: flex-start;
  margin-top: auto;
}
.pilot-position {
  margin-top: 26px;
  padding-top: 8px;
}
.pilot-position-grid,
.pilot-timeline {
  display: grid;
  gap: 10px;
}
.pilot-position-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.pilot-timeline {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 12px;
}
.pilot-position-grid article,
.pilot-timeline article {
  padding: 18px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.04);
}
.pilot-position-grid span,
.pilot-timeline span {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 5px 7px;
  border-radius: 6px;
  background: #eef6f5;
  color: #0e555c;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.pilot-position-grid p,
.pilot-timeline p {
  margin: 0;
  color: var(--muted);
}
.pilot-timeline strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: 21px;
}
.livret-followup {
  background: #fff;
  border-top: 1px solid #dce7e7;
  border-bottom: 1px solid #dce7e7;
}
.livret-hub, .livret-limited {
  background: #f7faf9;
}
.livret-layout {
  display: grid;
  grid-template-columns: minmax(280px, .95fr) minmax(0, 1.05fr);
  gap: 18px;
  align-items: start;
}
.livret-lead h2 {
  margin: 4px 0 12px;
  max-width: 760px;
  font-size: clamp(31px, 4vw, 58px);
  line-height: 1;
}
.livret-lead p {
  max-width: 780px;
  color: var(--muted);
  font-size: 18px;
}
.livret-action-list {
  display: grid;
  gap: 10px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}
.livret-action-list li {
  position: relative;
  padding: 14px 14px 14px 42px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #f7faf9;
  color: #303741;
  font-weight: 850;
}
.livret-action-list li::before {
  content: "";
  position: absolute;
  left: 16px;
  top: 19px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--teal);
}
.livret-alert {
  padding: 24px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #151b20;
  color: #fff;
  box-shadow: 0 14px 34px rgba(16,24,40,.08);
}
.livret-alert strong {
  display: block;
  margin-bottom: 10px;
  color: #ffcb58;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1;
}
.livret-alert p {
  margin: 0;
  color: rgba(255,255,255,.82);
}
.section-head.compact {
  margin-top: clamp(28px, 5vw, 54px);
}
.livret-track-grid,
.livret-competence-grid,
.livret-hub-grid {
  display: grid;
  gap: 12px;
}
.livret-track-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.livret-competence-grid,
.livret-hub-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.livret-track-grid article,
.livret-competence-grid article,
.livret-hub-grid article {
  padding: 20px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.livret-track-grid article > span,
.livret-competence-grid article > span {
  display: inline-flex;
  margin-bottom: 12px;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.livret-track-grid strong,
.livret-competence-grid strong,
.livret-hub-grid strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: 22px;
  line-height: 1.08;
}
.livret-track-grid p,
.livret-competence-grid p,
.livret-hub-grid p {
  margin: 0;
  color: var(--muted);
}
.livret-source {
  max-width: 980px;
  margin: 20px 0 0;
  color: var(--muted);
  font-size: 14px;
}
.livret-source a {
  color: var(--red-dark);
  font-weight: 850;
}
.data-privacy-map {
  background: #f7faf9;
  border-top: 1px solid #dce7e7;
  border-bottom: 1px solid #dce7e7;
}
.data-access-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.data-access-card {
  display: grid;
  gap: 14px;
  padding: 20px;
  border: 1px solid #dce7e7;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(16,24,40,.05);
}
.data-access-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}
.data-access-head span {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 9px;
  background: #e8f6f4;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.data-access-head strong {
  color: var(--red-dark);
  font-size: 15px;
  text-align: right;
}
.data-access-card p,
.data-access-card small,
.data-rule-grid p {
  margin: 0;
  color: var(--muted);
  line-height: 1.35;
}
.data-access-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.data-access-columns div {
  padding: 12px;
  border: 1px solid #edf2f2;
  border-radius: 10px;
  background: #fbfdfd;
}
.data-access-columns em {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-style: normal;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.data-access-columns ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 18px;
}
.data-access-columns li {
  color: #3f4853;
  font-size: 14px;
  font-weight: 750;
  line-height: 1.25;
}
.data-table-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.data-table-tags span {
  padding: 6px 8px;
  border-radius: 999px;
  background: #f1f4f4;
  color: #4b5560;
  font-size: 12px;
  font-weight: 850;
}
.data-rule-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.data-rule-grid article {
  padding: 14px;
  border: 1px solid #dce7e7;
  border-radius: 10px;
  background: #111418;
  color: #fff;
}
.data-rule-grid span {
  display: block;
  margin-bottom: 7px;
  color: #ffcb58;
  font-size: 13px;
  font-weight: 950;
}
.data-rule-grid p {
  color: rgba(255,255,255,.78);
  font-size: 13px;
}
.recruitment-payoff {
  background: #151b20;
  color: #fff;
}
.recruitment-payoff .eyebrow {
  color: #ffcb58;
}
.recruitment-payoff .section-head p {
  color: rgba(255,255,255,.74);
}
.payoff-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.payoff-grid article {
  min-height: 170px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
}
.payoff-grid span {
  display: block;
  min-height: 34px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.payoff-grid strong {
  display: block;
  margin: 10px 0 12px;
  color: #ffcb58;
  font-size: clamp(38px, 5vw, 58px);
  line-height: .9;
}
.payoff-grid p {
  margin: 0;
  color: rgba(255,255,255,.78);
}
.recruitment-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.recruitment-split article {
  padding: 24px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
}
.recruitment-split .eyebrow {
  color: var(--red-dark);
}
.recruitment-split h3 {
  margin: 4px 0 14px;
  font-size: clamp(28px, 3vw, 42px);
}
.recruitment-split ol {
  margin: 0 0 22px;
  padding-left: 22px;
}
.recruitment-split li {
  margin: 8px 0;
  color: #36404a;
}
.monitor-desire {
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr);
  gap: 24px;
  align-items: start;
  background: #f7faf9;
  border-bottom: 1px solid #dce7e7;
}
.monitor-desire-copy {
  position: sticky;
  top: 92px;
}
.monitor-desire-copy h2 {
  margin: 4px 0 14px;
  font-size: clamp(34px, 4.4vw, 64px);
  line-height: .98;
}
.monitor-desire-copy p {
  max-width: 620px;
  color: var(--muted);
  font-size: 19px;
}
.desire-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.desire-grid article {
  min-height: 150px;
  padding: 20px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16, 24, 40, .05);
}
.desire-grid span {
  display: inline-flex;
  margin-bottom: 18px;
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.desire-grid strong {
  display: block;
  margin-bottom: 9px;
  font-size: 22px;
  line-height: 1.08;
}
.desire-grid p {
  margin: 0;
  color: var(--muted);
}
.monitor-selection,
.apporteur-management {
  background: #fff;
  border-top: 1px solid #e1e8e8;
  border-bottom: 1px solid #e1e8e8;
}
.selection-kicker {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: end;
}
.selection-kicker .section-head {
  margin-bottom: 0;
}
.partner-onboarding-panel {
  display: grid;
  grid-template-columns: minmax(0, .75fr) minmax(0, 1.25fr);
  gap: 14px;
  align-items: stretch;
  margin-top: 16px;
  padding: 16px;
  border: 1px solid #cfdfe1;
  border-radius: 10px;
  background: #f6fbfb;
}
.partner-onboarding-panel h3 {
  margin: 0 0 8px;
  font-size: clamp(22px, 2.4vw, 34px);
}
.partner-onboarding-panel p {
  margin: 0;
  color: #5b6573;
  font-weight: 750;
}
.partner-doc-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.partner-doc-grid article {
  min-height: 0;
  padding: 12px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #fff;
}
.partner-doc-grid span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 7px;
  border-radius: 6px;
  background: #eaf7f7;
  color: var(--teal);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.partner-doc-grid strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink);
  font-size: 16px;
}
.partner-doc-grid p {
  font-size: 13px;
  line-height: 1.3;
}
.selection-service-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}
.selection-service-grid article {
  min-height: 152px;
  padding: 16px;
  border: 1px solid #dce7e7;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.selection-service-grid article.feature {
  grid-column: span 2;
  border-color: rgba(199,32,47,.22);
  background: #fff7f8;
}
.selection-service-grid span,
.selection-test-panel span,
.selection-rate-grid span {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.selection-service-grid strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: 21px;
  line-height: 1.06;
}
.selection-service-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.32;
}
.selection-test-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(300px, .98fr);
  gap: 12px;
  margin-top: 12px;
  padding: 14px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 12px;
  background: #f2faf9;
}
.selection-test-panel > div:first-child {
  padding: 16px;
  border-radius: 10px;
  background: #fff;
}
.selection-test-panel > div:first-child strong {
  display: block;
  color: var(--ink);
  font-size: clamp(22px, 2.4vw, 34px);
  line-height: 1.02;
}
.selection-test-panel > div:first-child p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.35;
}
.selection-rate-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.selection-rate-grid article {
  display: flex;
  min-height: 160px;
  flex-direction: column;
  justify-content: center;
  padding: 16px;
  border: 1px solid #ead8a6;
  border-radius: 10px;
  background: #fffdf6;
}
.selection-rate-grid strong {
  display: block;
  color: var(--red-dark);
  font-size: clamp(36px, 4vw, 54px);
  line-height: .92;
}
.selection-rate-grid p {
  margin: 10px 0 0;
  color: #5d4824;
  font-size: 14px;
  line-height: 1.3;
}
.selection-camaraderie {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  margin-top: 12px;
  padding: 14px 16px;
  border: 1px solid rgba(199,32,47,.16);
  border-radius: 12px;
  background: #fff8f9;
}
.selection-camaraderie strong {
  color: var(--red-dark);
  font-size: 18px;
}
.selection-camaraderie p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.34;
}
.partner-tier-panel {
  margin-top: 14px;
  padding: 16px;
  border: 1px solid rgba(199,32,47,.16);
  border-radius: 14px;
  background: linear-gradient(135deg, #fff 0%, #fff8f9 100%);
}
.partner-tier-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.partner-tier-grid article {
  min-height: 156px;
  padding: 14px;
  border: 1px solid #e2e8ea;
  border-radius: 12px;
  background: #fff;
}
.partner-tier-grid span {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.partner-tier-grid strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: 20px;
  line-height: 1.05;
}
.partner-tier-grid p,
.partner-tier-note {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.32;
}
.partner-tier-note {
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid #ead8a6;
  border-radius: 10px;
  background: #fffdf6;
  color: #5d4824;
  font-weight: 850;
}
.awards-panel {
  margin-top: 14px;
  padding: 16px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 14px;
  background: linear-gradient(135deg, #f7fbfb 0%, #fff 100%);
}
.awards-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.awards-grid article {
  min-height: 142px;
  padding: 14px;
  border: 1px solid #dce7e7;
  border-radius: 12px;
  background: #fff;
}
.awards-grid article.warning {
  border-color: rgba(199,32,47,.22);
  background: #fff7f8;
}
.awards-grid span {
  display: inline-flex;
  margin-bottom: 9px;
  padding: 5px 8px;
  border-radius: 999px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
}
.awards-grid article.warning span {
  background: #fff0f1;
  color: var(--red-dark);
}
.awards-grid strong {
  display: block;
  margin-bottom: 7px;
  color: var(--ink);
  font-size: 19px;
  line-height: 1.06;
}
.awards-grid p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.32;
}
.award-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.award-badges span {
  display: inline-flex;
  padding: 7px 10px;
  border: 1px solid rgba(199,32,47,.16);
  border-radius: 999px;
  background: #fff8f9;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
}
.awards-ranking {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid #dce7e7;
  border-radius: 12px;
  background: #fff;
}
.awards-ranking > strong {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-size: 18px;
}
.awards-ranking ul {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.awards-ranking li {
  padding: 10px;
  border-radius: 10px;
  background: #f7fbfb;
}
.awards-ranking li span {
  display: block;
  margin-bottom: 5px;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0;
}
.awards-ranking li p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.28;
}
.monitor-space {
  display: grid;
  grid-template-columns: minmax(260px, .9fr) minmax(0, 1.1fr);
  gap: 22px;
  align-items: start;
  background: #fff;
}
.monitor-space-copy h2 {
  margin: 4px 0 12px;
  font-size: clamp(32px, 4vw, 58px);
  line-height: 1;
}
.monitor-space-copy p {
  max-width: 660px;
  color: var(--muted);
}
.space-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}
.space-benefits {
  display: grid;
  gap: 12px;
}
.space-benefits article {
  padding: 20px;
  border: 1px solid #dbe4e6;
  border-radius: 8px;
  background: #f7fbfb;
}
.space-benefits strong {
  display: block;
  margin-bottom: 8px;
  color: #0e555c;
  font-size: 21px;
}
.space-benefits p {
  margin: 0;
  color: var(--muted);
}
.monitor-docs {
  background: #f7f9fa;
  border-top: 1px solid #e5eaee;
  border-bottom: 1px solid #e5eaee;
}
.doc-check-grid, .condition-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.doc-check-grid article, .condition-grid article {
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.doc-check-grid span {
  display: inline-flex;
  margin-bottom: 14px;
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.doc-check-grid strong, .condition-grid strong {
  display: block;
  margin-bottom: 8px;
  font-size: 20px;
}
.doc-check-grid p, .condition-grid p {
  margin: 0;
  color: var(--muted);
}
.monitor-conditions {
  background: #fff;
}
.condition-alert {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px 18px;
  align-items: center;
  margin-top: 16px;
  padding: 20px;
  border: 1px solid #f0d39a;
  border-radius: 8px;
  background: #fff8e7;
}
.condition-alert strong {
  color: #7d4a00;
  font-size: 20px;
}
.condition-alert p {
  grid-column: 1;
  margin: 0;
  color: #5d4824;
}
.condition-alert a {
  grid-column: 2;
  grid-row: 1 / span 2;
}
.monitor-ops {
  background: #101820;
  color: #fff;
}
.monitor-ops .section-head p {
  color: rgba(255,255,255,.72);
}
.ops-layout {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.ops-card {
  padding: 20px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 8px;
  background: rgba(255,255,255,.06);
}
.ops-card span {
  color: #ffcb58;
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.ops-card h3 {
  margin: 10px 0 12px;
  font-size: 25px;
}
.ops-card ol, .ops-card ul {
  margin: 0;
  padding-left: 19px;
}
.ops-card li {
  margin: 7px 0;
  color: rgba(255,255,255,.8);
}
.ops-card p {
  color: rgba(255,255,255,.78);
}
.ops-note {
  margin: 14px 0 0;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.12);
  font-size: 14px;
}
.finance-panel {
  display: grid;
  grid-template-columns: minmax(240px, .52fr) minmax(0, 1fr);
  gap: 18px;
  margin-top: 18px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
}
.finance-panel h3 {
  margin: 4px 0 10px;
  font-size: clamp(26px, 3vw, 38px);
}
.finance-panel p {
  color: var(--muted);
}
.monitor-fee-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
}
.monitor-fee-table th, .monitor-fee-table td {
  padding: 12px;
  border: 1px solid #dfe5e7;
  text-align: left;
  vertical-align: top;
}
.monitor-fee-table th {
  background: #edf6f5;
  color: #0e555c;
}
.monitor-fee-table td:nth-child(2) {
  color: var(--red-dark);
  font-weight: 950;
}
.quick-reply-kit {
  margin-top: 18px;
  padding: 20px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(255,255,255,.06);
}
.quick-reply-kit h3 {
  margin: 4px 0 16px;
  color: #fff;
  font-size: clamp(26px, 3vw, 38px);
}
.quick-reply-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.quick-reply-grid article {
  padding: 16px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(0,0,0,.12);
}
.quick-reply-grid strong {
  display: block;
  margin-bottom: 8px;
  color: #ffcb58;
  font-size: 18px;
}
.quick-reply-grid p {
  margin: 0;
  color: rgba(255,255,255,.78);
}
.next-dates-home {
  display: grid;
  grid-template-columns: minmax(260px, .8fr) minmax(0, 1.2fr) auto;
  gap: 18px;
  align-items: center;
  background: #f4f9f7;
  border-bottom: 1px solid #dce7e7;
}
.next-dates-copy {
  max-width: 530px;
}
.next-dates-copy h2 {
  margin: 4px 0 8px;
  font-size: clamp(26px, 2.8vw, 38px);
  line-height: 1;
}
.next-dates-copy p:last-child {
  margin: 0;
  color: var(--muted);
}
.next-dates-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.next-date-card {
  display: grid;
  gap: 6px;
  min-height: 108px;
  padding: 14px;
  border: 1px solid #d5e4e1;
  border-radius: 8px;
  background: #fff;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(16, 24, 40, .07);
}
.next-date-card:hover {
  border-color: var(--teal);
  transform: translateY(-2px);
  box-shadow: 0 18px 34px rgba(14, 85, 92, .14);
}
.next-date-kicker {
  justify-self: start;
  padding: 5px 8px;
  border-radius: 6px;
  background: #e7f5f2;
  color: var(--teal);
  font-size: 13px;
  font-weight: 950;
}
.next-date-card strong {
  font-size: 24px;
  line-height: 1;
  color: var(--red-dark);
}
.next-date-card small {
  color: #2c333a;
  font-weight: 800;
}
.next-date-card em {
  color: var(--muted);
  font-size: 13px;
  font-style: normal;
  font-weight: 850;
}
.next-dates-actions {
  display: grid;
  gap: 10px;
  align-items: center;
}
.reassurance-bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  padding-top: 0;
  padding-bottom: 0;
  background: var(--line);
}
.reassurance-bar a {
  display: grid;
  gap: 4px;
  min-height: 74px;
  padding: 16px;
  background: #fff;
  text-decoration: none;
}
.reassurance-bar strong { font-size: 18px; }
.reassurance-bar span { color: var(--muted); }
.evaluation-section {
  background: #f8fafb;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.evaluation-layout {
  display: grid;
  grid-template-columns: minmax(260px, .82fr) minmax(0, 1fr) minmax(320px, .8fr);
  gap: 18px;
  align-items: stretch;
}
.evaluation-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100%;
}
.evaluation-copy h2 {
  margin: 0 0 14px;
  font-size: clamp(30px, 4vw, 54px);
}
.evaluation-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}
.official-strip {
  display: grid;
  gap: 3px;
  margin-top: 18px;
  padding: 16px;
  border: 1px solid #cfd7df;
  border-left: 5px solid var(--red);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .05);
}
.official-strip strong {
  font-size: 18px;
}
.official-strip span {
  color: #303741;
  font-weight: 900;
}
.official-strip small {
  color: var(--muted);
  font-weight: 800;
}
.evaluation-copy ul {
  display: grid;
  gap: 8px;
  padding: 0;
  margin: 22px 0 0;
  list-style: none;
}
.evaluation-copy li {
  position: relative;
  padding-left: 22px;
  color: #303741;
  font-weight: 750;
}
.evaluation-copy li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--teal);
}
.evaluation-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 34px rgba(16, 24, 40, .07);
}
.evaluation-form label {
  display: grid;
  gap: 7px;
  color: #303741;
  font-size: 14px;
  font-weight: 900;
}
.evaluation-form input, .evaluation-form select {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px 12px;
  background: #fff;
  color: var(--ink);
  font: inherit;
}
.evaluation-actions {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 4px;
}
.evaluation-result {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 24px;
  border-radius: 8px;
  background: #15171a;
  color: #fff;
}
.evaluation-result span {
  align-self: flex-start;
  padding: 6px 8px;
  border-radius: 6px;
  background: rgba(255,255,255,.12);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.evaluation-result h3 {
  margin: 18px 0 10px;
  font-size: clamp(26px, 3vw, 42px);
}
.evaluation-result strong {
  display: block;
  color: #ffcb58;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1;
}
.evaluation-meta {
  display: grid;
  gap: 7px;
  margin-top: 16px;
}
.evaluation-meta small {
  display: block;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 7px;
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.82);
  font-weight: 800;
}
.evaluation-result p {
  margin: 16px 0;
  color: rgba(255,255,255,.8);
}
.evaluation-result ul {
  display: grid;
  gap: 8px;
  padding: 0;
  margin: 0 0 22px;
  list-style: none;
}
.evaluation-result li {
  position: relative;
  padding-left: 20px;
  color: rgba(255,255,255,.84);
}
.evaluation-result li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
}
.evaluation-result-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-top: auto;
}
.evaluation-result .text-link { color: #ffcb58; }
.evaluation-result a[aria-disabled="true"] {
  opacity: .7;
  cursor: not-allowed;
}
.evaluation-note {
  margin: 16px 0 0 !important;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.68) !important;
  font-size: 14px;
}
.exam-projection {
  background: #f4f8f6;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.projection-head {
  max-width: 980px;
  margin-bottom: 18px;
}
.projection-head h2 {
  margin: 4px 0 10px;
  max-width: 900px;
  font-size: clamp(32px, 4.8vw, 64px);
  line-height: .98;
}
.projection-head p:last-child {
  max-width: 780px;
  color: var(--muted);
  font-size: 18px;
}
.projection-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(340px, .75fr);
  gap: 18px;
  align-items: stretch;
}
.projection-date-zone {
  display: grid;
  gap: 14px;
}
.projection-date-zone > .projection-zone-head { order: 1; }
.projection-date-zone > .projection-selected-action { order: 2; }
.projection-date-zone > .projection-calendar { order: 3; }
.projection-date-zone > .projection-date-grid { order: 4; }
.projection-date-zone > .reservation-model-card { order: 5; }
.projection-date-zone > .projection-offer-zone { order: 6; }
.projection-date-zone > .reservation-flow-card { order: 7; }
.projection-date-zone > .projection-hidden-controls { order: 99; }
.projection-zone-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: end;
}
.projection-zone-head span,
.projection-offer-zone > span {
  display: block;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-zone-head strong {
  display: block;
  margin-top: 4px;
  font-size: clamp(22px, 2.8vw, 34px);
  line-height: 1.05;
}
.projection-zone-head small {
  max-width: 420px;
  color: var(--muted);
  font-weight: 750;
}
.projection-date-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.projection-calendar {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid #d2e2df;
  border-radius: 18px;
  background: linear-gradient(135deg, #ffffff 0%, #f2faf8 100%);
  box-shadow: 0 14px 34px rgba(14,85,92,.08);
}
.projection-calendar.is-calendar-focus {
  box-shadow: 0 0 0 3px rgba(241,180,43,.22), 0 14px 34px rgba(14,85,92,.11);
}
.projection-calendar-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(180px, .8fr);
  gap: 12px;
  align-items: end;
}
.projection-calendar-head span,
.projection-calendar-helper span {
  display: inline-flex;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-calendar-head strong {
  display: block;
  margin-top: 3px;
  color: var(--ink);
  font-size: clamp(20px, 2vw, 30px);
  line-height: .98;
}
.projection-calendar-head small {
  max-width: 320px;
  color: var(--muted);
  font-weight: 850;
  text-align: right;
}
.projection-calendar-nav {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  justify-self: center;
}
.projection-calendar-nav button {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid #d6e4e2;
  border-radius: 999px;
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-size: 18px;
  font-weight: 950;
  cursor: pointer;
}
.projection-calendar-nav button:hover:not(:disabled) {
  border-color: var(--red);
  color: var(--red-dark);
  box-shadow: inset 0 0 0 2px rgba(207,31,50,.10);
}
.projection-calendar-nav button:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.projection-calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}
.projection-calendar-weekdays span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 950;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-calendar-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}
.projection-calendar-cell {
  min-height: 58px;
  border-radius: 13px;
}
.projection-calendar-cell.is-empty {
  background: transparent;
}
.projection-calendar-cell.is-muted {
  display: grid;
  place-items: start;
  padding: 9px;
  border: 1px dashed #dce7e7;
  background: rgba(255,255,255,.50);
  color: #a5b0b7;
}
.projection-calendar-cell.is-muted strong {
  font-size: 15px;
  font-weight: 950;
}
.projection-calendar-cell.is-muted.is-past {
  opacity: .5;
}
.projection-calendar-day {
  display: grid;
  position: relative;
  align-content: start;
  gap: 4px;
  min-height: 58px;
  padding: 9px;
  border: 1px solid #d6e4e2;
  border-radius: 13px;
  background: #fff;
  color: var(--ink);
  text-align: left;
  font: inherit;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(18,24,32,.05);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.projection-calendar-day:hover,
.projection-calendar-day.active {
  border-color: var(--red);
  background: #fff7f8;
  transform: translateY(-1px);
  box-shadow: inset 0 0 0 2px rgba(207,31,50,.12), 0 14px 30px rgba(166,22,43,.10);
}
.projection-calendar-day strong {
  color: var(--red-dark);
  font-size: clamp(22px, 2vw, 30px);
  line-height: .9;
}
.projection-calendar-day span {
  color: var(--teal);
  font-size: 11px;
  font-weight: 950;
}
.projection-calendar-day em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.15;
}
.projection-calendar-empty {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}
.projection-calendar-helper {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
  color: var(--muted);
}
.projection-date-card.is-calendar-hidden {
  display: none;
}
.projection-selected-action {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  padding: 16px;
  border: 2px solid #f1b42b;
  border-radius: 8px;
  background: linear-gradient(135deg, #fff 0%, #fff8e7 100%);
  box-shadow: 0 18px 40px rgba(166, 22, 43, .10);
}
.projection-selected-action span {
  display: inline-flex;
  margin-bottom: 6px;
  padding: 5px 8px;
  border-radius: 7px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.projection-selected-action strong {
  display: block;
  color: var(--ink);
  font-size: clamp(20px, 2.4vw, 30px);
  line-height: 1.08;
}
.projection-selected-action p {
  margin: 7px 0 0;
  max-width: 760px;
  color: var(--muted);
  font-weight: 800;
}
.projection-selected-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  min-width: 240px;
}
.projection-selected-action.is-pulsing {
  animation: selectedProjectionPulse 1.6s ease;
}
@keyframes selectedProjectionPulse {
  0% { box-shadow: 0 0 0 0 rgba(241, 180, 43, .62), 0 18px 40px rgba(166, 22, 43, .10); }
  65% { box-shadow: 0 0 0 14px rgba(241, 180, 43, 0), 0 18px 40px rgba(166, 22, 43, .13); }
  100% { box-shadow: 0 18px 40px rgba(166, 22, 43, .10); }
}
.projection-date-card {
  position: relative;
  display: grid;
  gap: 7px;
  min-height: 142px;
  padding: 16px;
  border: 1px solid #d2e2df;
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  text-align: left;
  font: inherit;
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(16,24,40,.06);
}
.projection-date-card:hover,
.projection-date-card.active {
  border-color: var(--teal);
  box-shadow: 0 18px 38px rgba(14,85,92,.14);
  transform: translateY(-1px);
}
.projection-date-card.active::after {
  content: "Date choisie";
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 4px 7px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  font-size: 11px;
  font-weight: 950;
}
.projection-date-card.just-selected {
  animation: dateCardPop .36s ease;
}
.projection-date-grid.is-date-focus .projection-date-card.active,
.projection-date-grid.is-date-focus .projection-date-card:first-child {
  box-shadow: 0 0 0 3px rgba(207,31,50,.18), 0 18px 38px rgba(14,85,92,.14);
}
@keyframes dateCardPop {
  0% { transform: scale(.985); }
  70% { transform: scale(1.012); }
  100% { transform: translateY(-1px); }
}
.projection-date-card span {
  justify-self: start;
  padding: 5px 8px;
  border-radius: 7px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 13px;
  font-weight: 950;
}
.projection-date-card strong {
  color: var(--red-dark);
  font-size: clamp(26px, 3vw, 38px);
  line-height: 1;
}
.projection-date-card small {
  color: #2c333a;
  font-size: 17px;
  font-weight: 900;
}
.projection-date-card em {
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  font-weight: 850;
}
.projection-offer-zone {
  display: grid;
  gap: 9px;
  padding: 16px;
  border: 1px solid #d7e4e2;
  border-radius: 8px;
  background: #fff;
}
.projection-offer-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}
.projection-offer-chip {
  display: grid;
  gap: 4px;
  min-height: 86px;
  padding: 10px;
  border: 1px solid #d9e3e3;
  border-radius: 8px;
  background: #f7faf9;
  color: var(--ink);
  text-align: left;
  font: inherit;
  cursor: pointer;
}
.projection-offer-chip:hover,
.projection-offer-chip.active {
  border-color: var(--red);
  background: #fff;
}
.projection-offer-chip span {
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.projection-offer-chip strong {
  font-size: 14px;
  line-height: 1.05;
}
.projection-offer-chip small {
  color: var(--teal);
  font-weight: 950;
}
.projection-hidden-controls {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
}
.projection-layout {
  display: grid;
  grid-template-columns: minmax(260px, .78fr) minmax(320px, .72fr) minmax(340px, 1fr);
  gap: 18px;
  align-items: stretch;
}
.projection-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.projection-copy h2 {
  margin: 0 0 14px;
  font-size: clamp(30px, 4vw, 52px);
}
.projection-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}
.projection-copy ul {
  display: grid;
  gap: 8px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}
.projection-copy li {
  position: relative;
  padding-left: 22px;
  color: #303741;
  font-weight: 800;
}
.projection-copy li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--red);
}
.projection-panel {
  display: grid;
  gap: 14px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 34px rgba(16, 24, 40, .06);
}
.projection-panel label {
  display: grid;
  gap: 7px;
  color: #303741;
  font-size: 14px;
  font-weight: 900;
}
.projection-panel select {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px 12px;
  background: #fff;
  color: var(--ink);
  font: inherit;
}
.projection-source {
  margin: 0;
  padding: 12px;
  border-left: 4px solid var(--teal);
  border-radius: 7px;
  background: #fff;
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
}
.projection-result {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  padding: 24px;
  border-radius: 8px;
  background: #141719;
  color: #fff;
  box-shadow: 0 22px 54px rgba(16, 24, 40, .2);
}
.projection-result > span {
  align-self: flex-start;
  padding: 6px 8px;
  border-radius: 6px;
  background: rgba(255,255,255,.12);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-result h3 {
  margin: 18px 0 10px;
  font-size: clamp(25px, 3vw, 38px);
}
.projection-hero-date {
  display: grid;
  gap: 8px;
  margin-top: 8px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.08);
}
.projection-hero-date span {
  color: #ffcb58;
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-hero-date strong {
  display: block;
  color: #ffcb58;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1;
}
.projection-hero-date small {
  color: rgba(255,255,255,.82);
  font-size: 15px;
  font-weight: 850;
}
.projection-countdown {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.projection-countdown article {
  min-height: 88px;
  padding: 14px;
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
}
.projection-countdown span {
  display: block;
  color: var(--red-dark);
  font-size: 22px;
  font-weight: 950;
  line-height: 1;
}
.projection-countdown small {
  display: block;
  margin-top: 7px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}
.projection-center-focus {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 16px;
  border-left: 4px solid #ffcb58;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
}
.projection-center-focus span {
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-center-focus strong {
  color: #fff;
  font-size: 22px;
  line-height: 1.1;
}
.projection-center-focus p {
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 14px;
  line-height: 1.45;
}
.projection-center-photo-card {
  position: relative;
  min-height: 190px;
  margin-top: 12px;
  overflow: hidden;
  border-radius: 8px;
  background: #222;
}
.projection-center-photo-card img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  filter: saturate(1.02) contrast(1.02);
}
.projection-center-photo-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.74));
}
.projection-center-photo-card div {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 1;
}
.projection-center-photo-card span {
  display: inline-flex;
  padding: 6px 8px;
  border-radius: 7px;
  background: rgba(255,255,255,.16);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-center-photo-card strong {
  display: block;
  margin-top: 8px;
  color: #fff;
  font-size: 25px;
  line-height: 1.05;
}
.projection-day-video-card {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  gap: 12px;
  align-items: stretch;
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.08);
}
.projection-video-trigger {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 170px;
  overflow: hidden;
  border: 0;
  border-radius: 7px;
  background: #050708;
  cursor: pointer;
}
.projection-video-trigger img {
  width: 100%;
  height: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  filter: saturate(1.04) contrast(1.02) brightness(.78);
}
.projection-video-trigger::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.55));
}
.projection-video-trigger::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 54px;
  height: 54px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: #cf1f32;
  box-shadow: 0 12px 30px rgba(0,0,0,.25);
}
.projection-video-trigger span {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 1;
  width: 0;
  height: 0;
  margin-left: 3px;
  transform: translate(-50%, -50%);
  overflow: hidden;
  border-top: 12px solid transparent;
  border-bottom: 12px solid transparent;
  border-left: 18px solid #fff;
  color: transparent;
}
.projection-day-video-card div {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}
.projection-day-video-card span {
  align-self: flex-start;
  padding: 5px 7px;
  border-radius: 6px;
  background: rgba(255,203,88,.14);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-day-video-card strong {
  display: block;
  margin-top: 10px;
  color: #fff;
  font-size: 22px;
  line-height: 1.08;
}
.projection-day-video-card p {
  margin: 8px 0 0;
  color: rgba(255,255,255,.76);
  font-size: 13px;
  line-height: 1.35;
}
.projection-date-video-card {
  display: none;
}
.jour-j-video-modal[hidden] {
  display: none;
}
.jour-j-video-modal {
  position: fixed;
  inset: 0;
  z-index: 250;
  display: grid;
  place-items: center;
  padding: clamp(14px, 4vw, 32px);
  background: rgba(10,14,16,.78);
  backdrop-filter: blur(10px);
}
.jour-j-video-shell {
  display: grid;
  gap: 10px;
  width: min(980px, 100%);
  max-height: calc(100dvh - 40px);
  padding: 12px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 10px;
  background: #11171a;
  box-shadow: 0 28px 80px rgba(0,0,0,.34);
}
.jour-j-video-shell video {
  width: 100%;
  max-height: min(76dvh, 680px);
  border-radius: 8px;
  background: #000;
}
.jour-j-video-shell p {
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 14px;
  font-weight: 750;
}
.jour-j-video-close {
  justify-self: end;
  min-height: 38px;
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 7px;
  padding: 8px 12px;
  background: rgba(255,255,255,.08);
  color: #fff;
  font: inherit;
  font-weight: 950;
  cursor: pointer;
}
.projection-day-scene {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}
.projection-day-scene article {
  min-height: 108px;
  padding: 13px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
  background: rgba(255,255,255,.08);
}
.projection-day-scene span {
  display: block;
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-day-scene strong {
  display: block;
  margin: 8px 0 6px;
  color: #fff;
  font-size: 24px;
  line-height: 1;
}
.projection-day-scene small {
  color: rgba(255,255,255,.74);
  font-weight: 800;
}
.projection-meta {
  display: grid;
  gap: 7px;
  margin-top: 16px;
}
.projection-meta small {
  display: block;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 7px;
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.82);
  font-weight: 800;
}
.projection-after-payment {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.projection-after-payment article {
  padding: 13px;
  border-radius: 8px;
  background: rgba(255,203,88,.12);
  border: 1px solid rgba(255,203,88,.2);
}
.projection-after-payment span {
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-after-payment strong {
  display: block;
  margin-top: 5px;
  color: #fff;
  font-size: 17px;
  line-height: 1.12;
}
.projection-after-payment p {
  margin: 6px 0 0;
  color: rgba(255,255,255,.76);
  font-size: 13px;
}
.projection-buying-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}
.projection-buying-strip article {
  min-height: 82px;
  padding: 12px;
  border-radius: 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
}
.projection-buying-strip span {
  display: block;
  color: #ffcb58;
  font-size: 17px;
  font-weight: 950;
  line-height: 1;
}
.projection-buying-strip strong {
  display: block;
  margin-top: 8px;
  color: rgba(255,255,255,.82);
  font-size: 13px;
  line-height: 1.15;
}
.projection-result ul {
  display: grid;
  gap: 8px;
  margin: 16px 0 22px;
  padding: 0;
  list-style: none;
}
.projection-result li {
  position: relative;
  padding-left: 20px;
  color: rgba(255,255,255,.84);
}
.projection-result li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
}
.projection-payment-preview {
  display: grid;
  gap: 8px;
  margin-top: auto;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
}
.projection-payment-preview span {
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-payment-preview strong {
  color: #fff;
  font-size: 19px;
  line-height: 1.15;
}
.projection-payment-preview p {
  margin: 0;
  color: rgba(255,255,255,.76);
  font-size: 14px;
}
.projection-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.projection-actions a {
  justify-content: center;
}
.projection-actions .btn.ghost {
  color: #fff;
  border-color: rgba(255,255,255,.34);
  background: rgba(255,255,255,.08);
}
.projection-windows {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.projection-windows article {
  min-height: 150px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafb;
}
.projection-windows span {
  display: inline-flex;
  padding: 5px 8px;
  border-radius: 6px;
  background: #fff;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.projection-windows strong {
  display: block;
  margin: 14px 0 8px;
  color: var(--teal);
  font-size: 25px;
  line-height: 1.1;
}
.projection-windows p { margin: 0; color: var(--muted); }
.training-emotion {
  background: linear-gradient(180deg, #f6fbfa 0%, #ffffff 72%);
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.training-emotion-lead {
  max-width: 920px;
  margin-bottom: 22px;
}
.training-emotion-lead h2 {
  margin: 4px 0 10px;
  max-width: 820px;
  font-size: clamp(30px, 4vw, 54px);
  line-height: 1;
}
.training-emotion-lead p:last-child {
  max-width: 760px;
  color: var(--muted);
  font-size: 18px;
}
.training-emotion-board {
  display: grid;
  grid-template-columns: minmax(320px, .92fr) minmax(0, 1.08fr);
  gap: 18px;
  align-items: stretch;
}
.training-emotion-pass {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  padding: clamp(18px, 2.5vw, 26px);
  border: 1px solid rgba(20,108,114,.24);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255,255,255,.95), rgba(255,255,255,.86)),
    radial-gradient(circle at 92% 12%, rgba(199,32,47,.12), transparent 28%),
    radial-gradient(circle at 14% 86%, rgba(20,108,114,.13), transparent 30%);
  box-shadow: 0 24px 58px rgba(16,24,40,.13);
}
.training-pass-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.training-pass-top span,
.training-pass-main small,
.training-pass-after span {
  display: inline-flex;
  width: fit-content;
  padding: 7px 9px;
  border-radius: 7px;
  background: rgba(20,108,114,.1);
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.training-pass-top strong {
  max-width: 240px;
  color: var(--red-dark);
  font-size: clamp(24px, 3.4vw, 42px);
  line-height: .98;
  text-align: right;
}
.training-pass-main h3 {
  margin: 12px 0 8px;
  max-width: 560px;
  color: var(--ink);
  font-size: clamp(30px, 3.4vw, 46px);
  line-height: .98;
}
.training-pass-main p {
  margin: 0;
  max-width: 580px;
  color: var(--muted);
  font-size: 16px;
}
.training-pass-route {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: auto;
}
.training-pass-route div {
  min-height: 86px;
  padding: 12px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(16,24,40,.07);
}
.training-pass-route span {
  display: block;
  margin-bottom: 9px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.training-pass-route strong {
  display: block;
  color: var(--red-dark);
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.05;
}
.training-pass-after {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 8px;
  background: #eef8f6;
}
.training-pass-after p {
  margin: 0;
  color: var(--ink);
  font-weight: 850;
}
.training-emotion-scene {
  display: grid;
  grid-template-rows: 240px auto;
  gap: 12px;
  min-width: 0;
}
.training-photo-card {
  position: relative;
  min-height: 0;
  margin: 0;
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid rgba(20,108,114,.22);
  background: #15171a;
  box-shadow: 0 18px 42px rgba(16,24,40,.13);
}
.training-photo-card img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  opacity: .78;
}
.training-photo-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10,13,16,.62), rgba(10,13,16,.12) 70%);
}
.training-photo-card figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 1;
  max-width: 560px;
  color: #fff;
}
.training-photo-card span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 7px 9px;
  border-radius: 7px;
  background: rgba(255,203,88,.18);
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.training-photo-card strong {
  display: block;
  max-width: 620px;
  font-size: clamp(23px, 3vw, 38px);
  line-height: 1;
}
.training-emotion-road {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.training-emotion-road article {
  min-height: 132px;
  padding: 14px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.07);
}
.training-emotion-road span {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(199,32,47,.1);
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.training-emotion-road strong {
  display: block;
  margin: 10px 0 6px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.08;
}
.training-emotion-road p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}
.training-emotion-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 2px;
}
.training-emotion-actions .btn.outline {
  background: #fff;
}
.enrollment-boost {
  background: #f4f7f7;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.payment-direct-head {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(280px, .65fr);
  gap: 18px;
  align-items: end;
  margin-bottom: 14px;
}
.payment-direct-head h2 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(28px, 3.6vw, 48px);
  line-height: 1;
}
.payment-direct-head p:last-child {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  font-weight: 780;
}
.payment-direct-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.payment-direct-strip article {
  min-height: 112px;
  padding: 14px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16,24,40,.06);
}
.payment-direct-strip span {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 5px 8px;
  border-radius: 7px;
  background: rgba(20,108,114,.1);
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.payment-direct-strip strong {
  display: block;
  color: var(--ink);
  font-size: 20px;
  line-height: 1.08;
}
.payment-direct-strip small {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-weight: 800;
}
.monitor-handoff {
  display: grid;
  grid-template-columns: minmax(230px, .62fr) minmax(0, 1.38fr);
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;
  padding: 12px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16,24,40,.06);
}
.monitor-handoff h3 {
  margin: 4px 0 8px;
  color: var(--ink);
  font-size: clamp(22px, 2.3vw, 32px);
  line-height: 1;
}
.monitor-handoff p {
  margin: 0;
  color: var(--muted);
  font-weight: 720;
}
.monitor-handoff-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.monitor-handoff-grid article {
  min-height: 0;
  padding: 10px;
  border: 1px solid #dce7e7;
  border-radius: 8px;
  background: #f8fbfb;
}
.monitor-handoff-grid span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 7px;
  border-radius: 8px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
}
.monitor-handoff-grid strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.08;
}
.monitor-handoff-grid p {
  margin-top: 6px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.28;
}
.monitor-handoff-grid a {
  color: var(--teal);
  font-weight: 950;
  text-decoration: none;
}
.enrollment-layout {
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1.28fr);
  gap: 18px;
  align-items: stretch;
}
.enrollment-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.enrollment-copy h2 {
  margin: 0 0 14px;
  font-size: clamp(30px, 4vw, 52px);
}
.enrollment-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}
.enrollment-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.enrollment-steps article {
  min-height: 140px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16, 24, 40, .05);
}
.enrollment-steps span {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--teal);
  color: #fff;
  font-weight: 950;
}
.enrollment-steps h3 {
  margin: 16px 0 8px;
  font-size: 21px;
}
.enrollment-steps p {
  margin: 0;
  color: var(--muted);
}
.enrollment-action {
  display: grid;
  grid-template-columns: minmax(320px, .75fr) minmax(320px, 1fr);
  gap: 18px;
  margin-top: 18px;
}
.enrollment-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.enrollment-panel label {
  display: grid;
  gap: 7px;
  color: #303741;
  font-size: 14px;
  font-weight: 900;
}
.enrollment-panel select, .enrollment-panel input {
  width: 100%;
  min-height: 48px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px 12px;
  background: #fff;
  color: var(--ink);
  font: inherit;
}
.wide-field {
  grid-column: 1 / -1;
}
.contract-consent {
  grid-column: 1 / -1;
  grid-template-columns: auto 1fr !important;
  align-items: start;
  padding: 14px;
  border-radius: 8px;
  background: #f8fafb;
}
.contract-consent input {
  width: 18px;
  height: 18px;
  margin-top: 2px;
}
.conditions-before-action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  grid-column: 1 / -1;
  margin: 0 0 4px;
  padding: 14px;
  border: 1px solid #cfe2e3;
  border-radius: 8px;
  background: #f7fbfb;
}
.conditions-before-action span {
  display: block;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.conditions-before-action strong {
  display: block;
  margin-top: 3px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.1;
}
.conditions-before-action p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}
.conditions-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}
.contract-extra-fields {
  padding: 0;
  border: 1px solid #dbe4e6;
  border-radius: 8px;
  background: #f7faf9;
}
.contract-extra-fields summary {
  padding: 14px 16px;
  color: var(--teal);
  font-weight: 950;
}
.contract-extra-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 0 16px 16px;
}
.enrollment-result {
  display: flex;
  flex-direction: column;
  padding: 22px;
  border: 1px solid #d6e4e2;
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  box-shadow: 0 16px 38px rgba(16,24,40,.08);
}
.enrollment-result > span {
  align-self: flex-start;
  padding: 6px 8px;
  border-radius: 6px;
  background: rgba(199,32,47,.09);
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.enrollment-result h3 {
  margin: 18px 0 10px;
  font-size: clamp(27px, 3.4vw, 44px);
}
.enrollment-result p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}
.enrollment-result ul {
  display: grid;
  gap: 8px;
  margin: 18px 0 22px;
  padding: 0;
  list-style: none;
}
.enrollment-result li {
  position: relative;
  padding-left: 20px;
  color: #303741;
}
.enrollment-result li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
}
.enrollment-result a {
  align-self: flex-start;
  margin-top: auto;
}
.enrollment-result .post-payment-trigger {
  align-self: flex-start;
  margin-top: 10px;
  border-color: #cfe0df;
  background: #fff;
  color: var(--teal);
}
.payment-method-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 16px;
}
.payment-method-row button {
  min-height: 40px;
  padding: 9px 12px;
  border: 1px solid #cfe0df;
  border-radius: 7px;
  background: #f7fbfa;
  color: var(--teal);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}
.payment-method-row button:hover {
  border-color: var(--teal);
  background: #eaf6f4;
}
.enrollment-result a[aria-disabled="true"] {
  opacity: .65;
}
.payment-note {
  margin: 14px 0 0 !important;
  color: var(--muted) !important;
  font-size: 14px !important;
}
.contract-signature-modal[hidden] {
  display: none;
}
body.contract-modal-open {
  overflow: hidden;
}
.contract-signature-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(16, 20, 24, .34);
  backdrop-filter: blur(3px);
}
.contract-signature-card {
  position: relative;
  width: min(720px, 100%);
  max-height: min(86vh, 760px);
  overflow: auto;
  padding: clamp(18px, 3vw, 28px);
  border: 1px solid rgba(20,108,114,.22);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 26px 80px rgba(16, 24, 40, .24);
}
.contract-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  color: var(--muted);
  font-size: 22px;
  cursor: pointer;
}
.contract-signature-card h3 {
  margin: 4px 42px 8px 0;
  font-size: clamp(26px, 3.2vw, 38px);
  line-height: 1;
}
.contract-modal-intro {
  max-width: 620px;
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 16px;
}
.contract-modal-summary {
  display: grid;
  grid-template-columns: 1.15fr .75fr .9fr;
  gap: 10px;
  margin-bottom: 14px;
}
.contract-modal-summary article {
  padding: 12px;
  border: 1px solid #d9e4e5;
  border-radius: 8px;
  background: #f7fbfa;
}
.contract-modal-summary span {
  display: block;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.contract-modal-summary strong {
  display: block;
  margin-top: 5px;
  color: var(--ink);
  font-size: 17px;
  line-height: 1.12;
}
.contract-modal-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 14px;
}
.contract-modal-steps button {
  display: flex;
  gap: 8px;
  align-items: center;
  min-height: 44px;
  padding: 8px 10px;
  border: 1px solid #d9e4e5;
  border-radius: 8px;
  background: #fff;
  color: var(--muted);
  font: inherit;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
}
.contract-modal-steps span {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 7px;
  background: #edf5f4;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
}
.contract-modal-steps button.is-active {
  border-color: var(--red);
  background: #fff7f8;
  color: var(--red-dark);
}
.contract-modal-steps button.is-active span {
  background: var(--red);
  color: #fff;
}
.contract-step-panel[hidden] {
  display: none !important;
}
.contract-modal-terms {
  display: grid;
  gap: 10px;
  margin: 0 0 14px;
  padding: 14px;
  border: 1px solid #f2d4d8;
  border-radius: 8px;
  background: #fff7f8;
}
.contract-modal-terms strong {
  color: var(--red-dark);
  font-size: 18px;
}
.contract-modal-terms ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 20px;
}
.contract-modal-terms li {
  color: #313943;
  font-size: 14px;
  font-weight: 750;
  line-height: 1.3;
}
.contract-modal-legal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.contract-modal-legal-grid article {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 9px;
  align-items: start;
  padding: 10px;
  border: 1px solid #efd8dc;
  border-radius: 8px;
  background: #fff;
}
.contract-modal-legal-grid span {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: rgba(199, 32, 47, .1);
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
}
.contract-modal-legal-grid p {
  margin: 0;
  color: #303741;
  font-size: 14px;
  font-weight: 760;
  line-height: 1.28;
}
.official-contract-conditions {
  display: grid;
  gap: 14px;
}
.official-contract-head {
  display: grid;
  gap: 6px;
}
.official-contract-head h2 {
  max-width: 860px;
  margin: 0;
  font-size: clamp(30px, 4vw, 54px);
  line-height: .96;
}
.official-contract-head p {
  max-width: 860px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(16px, 1.6vw, 21px);
  line-height: 1.35;
}
.official-contract-dialog {
  padding: clamp(12px, 2vw, 18px);
  border: 1px solid #cfe0df;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 44px rgba(16, 24, 40, .08);
}
.official-contract-scrollbox {
  display: grid;
  gap: 10px;
  max-height: min(58vh, 560px);
  overflow: auto;
  padding: 12px;
  border: 1px solid #d9e5e5;
  border-radius: 8px;
  background: #f9fcfc;
  scroll-padding: 12px;
}
.contract-modal-terms .official-contract-scrollbox {
  max-height: min(34vh, 280px);
  background: #fff;
}
.official-contract-scrollbox:focus {
  outline: 3px solid rgba(20, 108, 114, .22);
  outline-offset: 2px;
}
.official-contract-source {
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  justify-content: space-between;
  padding: 10px;
  border: 1px solid #dce8e8;
  border-radius: 7px;
  background: #fff;
}
.official-contract-source strong {
  color: var(--ink);
  font-size: 16px;
}
.official-contract-source a {
  color: var(--teal);
  font-size: 13px;
  font-weight: 900;
}
.official-contract-scrollbox article {
  display: grid;
  gap: 7px;
  padding: 12px;
  border: 1px solid #e0e9ea;
  border-radius: 7px;
  background: #fff;
}
.official-contract-scrollbox h4 {
  margin: 0;
  color: var(--red-dark);
  font-size: 15px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.official-contract-scrollbox p,
.official-contract-scrollbox li {
  margin: 0;
  color: #343c46;
  font-size: 14px;
  font-weight: 650;
  line-height: 1.36;
}
.official-contract-scrollbox p strong {
  color: var(--ink);
  font-size: inherit;
}
.official-contract-scrollbox ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding-left: 18px;
}
.official-contract-signatures {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 4px;
}
.official-contract-signatures span {
  min-height: 48px;
  padding: 10px;
  border: 1px dashed #c9d7d8;
  border-radius: 7px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}
.official-contract-note {
  margin: 0;
  padding: 10px 12px;
  border-left: 4px solid var(--teal);
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
}
.contract-modal-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}
.contract-modal-error {
  grid-column: 1 / -1;
  margin: 0;
  padding: 11px 12px;
  border: 1px solid rgba(199, 32, 47, .35);
  border-radius: 8px;
  background: #fff7f8;
  color: var(--red-dark);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.3;
}
.contract-modal-error[hidden] {
  display: none !important;
}
.contract-modal-error strong {
  display: block;
  color: var(--red-dark);
  font-size: 14px;
}
.contract-modal-error span {
  display: block;
  margin-top: 3px;
  color: #5c6570;
  font-size: 13px;
  font-weight: 750;
}
.contract-modal-error ul {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}
.contract-modal-error li {
  padding: 7px 9px;
  border-radius: 7px;
  background: #fff;
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}
.contract-modal-fields label {
  display: grid;
  gap: 7px;
  color: #303741;
  font-size: 14px;
  font-weight: 900;
}
.contract-modal-fields input,
.contract-modal-fields select {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 10px 12px;
  background: #fff;
  color: var(--ink);
  font: inherit;
}
.enrollment-panel input.is-missing,
.enrollment-panel select.is-missing,
.contract-modal-fields input.is-missing,
.contract-modal-fields select.is-missing {
  border-color: var(--red);
  background: #fff7f8;
  box-shadow: 0 0 0 3px rgba(199, 32, 47, .12);
}
.contract-field-hint {
  display: block;
  margin-top: -1px;
  padding: 7px 9px;
  border-radius: 7px;
  background: rgba(199, 32, 47, .08);
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 850;
  line-height: 1.25;
}
.contract-modal-consent {
  margin: 0;
}
.contract-modal-signature {
  display: grid;
  gap: 12px;
  margin-bottom: 14px;
  padding: 14px;
  border: 1px solid #d9e4e5;
  border-radius: 8px;
  background: #f8fbfb;
}
.contract-modal-signature > strong {
  color: var(--ink);
  font-size: 20px;
}
.contract-modal-signature > p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.35;
}
.contract-signature-recap {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.contract-signature-recap article {
  padding: 10px;
  border: 1px solid #d9e4e5;
  border-radius: 8px;
  background: #fff;
}
.contract-signature-recap span {
  display: block;
  color: var(--teal);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.contract-signature-recap strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.15;
}
.contract-modal-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
}
.contract-modal-actions .text-link {
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
}
.contract-modal-actions a[aria-disabled="true"] {
  opacity: .55;
  pointer-events: none;
}
.contract-modal-note {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 14px;
}
.contract-preview-wrap {
  margin-top: 18px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}
.contract-preview-wrap > summary {
  padding: 16px 18px;
  color: var(--teal);
  font-weight: 950;
}
.contract-preview {
  margin-top: 0;
  padding: 22px;
  border: 0;
  border-top: 1px solid var(--line);
  border-radius: 0 0 8px 8px;
  background: #fff;
  box-shadow: none;
  scroll-margin-top: 96px;
  outline: 0;
}
.contract-preview.is-highlighted {
  border-color: var(--red);
  box-shadow: 0 0 0 4px rgba(199, 32, 47, .12), 0 18px 44px rgba(16, 24, 40, .12);
}
.contract-preview-head {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.contract-preview-head h3 {
  margin: 4px 0 0;
  font-size: clamp(26px, 3vw, 38px);
}
.contract-preview-head button {
  min-height: 44px;
  padding: 10px 14px;
  border: 0;
  border-radius: 7px;
  background: var(--teal);
  color: #fff;
  font: inherit;
  font-weight: 950;
  cursor: pointer;
}
.contract-status {
  margin: 0 0 16px;
  padding: 12px 14px;
  border: 1px solid #d6e2e4;
  border-radius: 8px;
  background: #f4f7f7;
  color: var(--muted);
}
.contract-status a {
  color: var(--teal);
  font-weight: 900;
}
.contract-reader-notice {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  margin: 0 0 14px;
  padding: 12px 14px;
  border: 1px solid #f2d6d9;
  border-radius: 8px;
  background: #fff7f7;
  color: #3a1a1e;
}
.contract-reader-notice strong {
  color: var(--red-dark);
  white-space: nowrap;
}
.contract-reader-notice span {
  color: #6a3a40;
  font-size: 14px;
}
.contract-sheet {
  padding: 20px;
  border: 1px solid #d9dde2;
  border-radius: 8px;
  background: #fff;
  color: #171b20;
}
.contract-sheet-head {
  display: grid;
  gap: 4px;
  padding-bottom: 14px;
  border-bottom: 2px solid #171b20;
}
.contract-sheet-head strong {
  font-size: 24px;
}
.contract-sheet-head span {
  font-weight: 900;
}
.contract-sheet-head small {
  color: var(--muted);
}
.contract-official-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.contract-official-tags span {
  padding: 8px 10px;
  border: 1px solid #d8e2e4;
  border-radius: 999px;
  background: #f4f8f8;
  color: #204347;
  font-size: 13px;
  font-weight: 900;
}
.contract-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.contract-columns article,
.contract-main-terms article {
  padding: 14px;
  border: 1px solid #e1e5ea;
  border-radius: 7px;
  background: #fbfcfd;
}
.contract-sheet h4 {
  margin: 0 0 8px;
  font-size: 15px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--teal);
}
.contract-sheet p {
  margin: 0;
  color: #2d333a;
  font-size: 15px;
}
.contract-main-terms {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}
.contract-main-terms ul {
  margin: 8px 0 0;
  padding-left: 20px;
}
.contract-main-terms li {
  margin: 5px 0;
}
.contract-price-table {
  width: 100%;
  margin: 8px 0 10px;
  border-collapse: collapse;
  overflow: hidden;
  border-radius: 6px;
  font-size: 14px;
}
.contract-price-table th,
.contract-price-table td {
  padding: 8px 10px;
  border: 1px solid #dfe5e8;
  text-align: left;
  vertical-align: top;
}
.contract-price-table th {
  background: #eef5f5;
  color: #123f44;
}
.contract-signatures {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}
.contract-signatures p {
  min-height: 70px;
  padding: 12px;
  border: 1px solid #d9dde2;
  border-radius: 7px;
  background: #fff;
}
.training-schedule {
  background:
    linear-gradient(180deg, #fff 0%, #f7fbfa 100%);
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.schedule-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
  gap: 16px;
  align-items: stretch;
  margin-bottom: 16px;
}
.schedule-main-card,
.schedule-side-card {
  border: 1px solid rgba(20,108,114,.22);
  border-radius: 8px;
  box-shadow: 0 18px 42px rgba(16,24,40,.08);
}
.schedule-main-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: clamp(18px, 3vw, 28px);
  background:
    linear-gradient(135deg, rgba(255,255,255,.97), rgba(255,255,255,.88)),
    radial-gradient(circle at 92% 10%, rgba(199,32,47,.11), transparent 27%),
    radial-gradient(circle at 6% 90%, rgba(20,108,114,.13), transparent 30%);
}
.schedule-main-top {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}
.schedule-main-top span,
.schedule-side-card > span,
.schedule-data-grid span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 8px;
  border-radius: 7px;
  background: rgba(20,108,114,.1);
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.schedule-main-top strong {
  max-width: 260px;
  color: var(--red-dark);
  font-size: clamp(28px, 4vw, 50px);
  line-height: .95;
  text-align: right;
}
.schedule-main-card h3 {
  margin: 0;
  max-width: 760px;
  color: var(--ink);
  font-size: clamp(30px, 4vw, 54px);
  line-height: .98;
}
.schedule-main-card p {
  margin: 0;
  max-width: 760px;
  color: var(--muted);
  font-size: 17px;
}
.schedule-data-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: auto;
}
.schedule-data-grid div {
  min-height: 96px;
  padding: 13px;
  border: 1px solid rgba(20,108,114,.17);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16,24,40,.06);
}
.schedule-data-grid span {
  margin-bottom: 9px;
  background: transparent;
  padding: 0;
  color: var(--muted);
}
.schedule-data-grid strong {
  display: block;
  color: var(--red-dark);
  font-size: clamp(18px, 2vw, 25px);
  line-height: 1.08;
}
.schedule-side-card {
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: center;
  padding: clamp(18px, 2.6vw, 26px);
  background: #142f33;
  color: #fff;
}
.schedule-side-card > span {
  background: rgba(255,203,88,.16);
  color: #ffcb58;
}
.schedule-side-card strong {
  display: block;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: .98;
}
.schedule-side-card p {
  margin: 0;
  color: rgba(255,255,255,.78);
  font-size: 16px;
}
.schedule-side-card .btn {
  align-self: flex-start;
  margin-top: 6px;
}
.schedule-road {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.schedule-road article {
  min-height: 168px;
  padding: 16px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.06);
}
.schedule-road span {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(199,32,47,.1);
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.schedule-road h3 {
  margin: 12px 0 7px;
  color: var(--ink);
  font-size: 19px;
  line-height: 1.08;
}
.schedule-road p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}
.schedule-note {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  margin-top: 18px;
  padding: 16px;
  border: 1px solid rgba(20,108,114,.22);
  border-radius: 8px;
  background: #eef8f6;
}
.schedule-note strong {
  color: var(--teal);
}
.schedule-note span {
  color: var(--muted);
  flex: 1 1 320px;
}
.schedule-note a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 9px 12px;
  border: 1px solid #e2c2c7;
  border-radius: 7px;
  background: #fff;
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.schedule-note a:last-child {
  border-color: var(--red);
  background: var(--red);
  color: #fff;
}
.case-router {
  background: #fff;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.case-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.formula-selected-action {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(170px, .35fr) minmax(230px, .55fr);
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;
  padding: 16px;
  border: 2px solid #f1b42b;
  border-radius: 8px;
  background: linear-gradient(135deg, #fff 0%, #fff8e7 100%);
  box-shadow: 0 18px 40px rgba(166, 22, 43, .10);
}
.formula-selected-action > div:first-child > span,
.formula-selected-price small {
  display: inline-flex;
  margin-bottom: 6px;
  padding: 5px 8px;
  border-radius: 7px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.formula-selected-action > div:first-child > strong {
  display: block;
  color: var(--ink);
  font-size: clamp(22px, 2.7vw, 34px);
  line-height: 1.05;
}
.formula-selected-action p {
  margin: 7px 0 0;
  color: var(--muted);
  font-weight: 800;
}
.formula-selected-price {
  padding: 14px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #ead8a6;
}
.formula-selected-price strong {
  display: block;
  color: var(--red-dark);
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1;
}
.formula-selected-action ul {
  display: grid;
  gap: 5px;
  margin: 0;
  padding-left: 20px;
  color: #303741;
  font-weight: 850;
}
.formula-selected-actions {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.formula-selected-action.is-pulsing {
  animation: selectedProjectionPulse 1.6s ease;
}
.emotion-selected-action {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(160px, .35fr) minmax(220px, .55fr);
  gap: 14px;
  align-items: center;
  margin: 14px 0 16px;
  padding: 16px;
  border: 2px solid #b7d7d5;
  border-radius: 8px;
  background: linear-gradient(135deg, #fff 0%, #f1f9f8 100%);
  box-shadow: 0 18px 40px rgba(14,85,92,.10);
}
.emotion-selected-action > div:first-child > span,
.emotion-selected-meta small {
  display: inline-flex;
  margin-bottom: 6px;
  padding: 5px 8px;
  border-radius: 7px;
  background: #e5f3f1;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.emotion-selected-action > div:first-child > strong {
  display: block;
  color: var(--ink);
  font-size: clamp(21px, 2.4vw, 32px);
  line-height: 1.06;
}
.emotion-selected-action p {
  margin: 7px 0 0;
  color: var(--muted);
  font-weight: 800;
}
.emotion-selected-meta {
  padding: 14px;
  border: 1px solid #cfe1df;
  border-radius: 8px;
  background: #fff;
}
.emotion-selected-meta strong {
  display: block;
  color: var(--red-dark);
  font-size: clamp(20px, 2.4vw, 31px);
  line-height: 1;
}
.emotion-selected-action ul {
  display: grid;
  gap: 5px;
  margin: 0;
  padding-left: 20px;
  color: #303741;
  font-weight: 850;
}
.emotion-selected-actions {
  grid-column: 1 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.emotion-selected-action.is-pulsing {
  animation: selectedProjectionPulse 1.6s ease;
}
.emotion-choice.is-selected,
.emotion-choice[aria-current="true"] {
  border-color: var(--teal) !important;
  box-shadow: 0 18px 38px rgba(14,85,92,.14);
}
.case-card {
  display: flex;
  flex-direction: column;
  min-height: 250px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  text-align: left;
  text-decoration: none;
  font: inherit;
  cursor: pointer;
  box-shadow: 0 8px 24px rgba(16, 24, 40, .05);
}
.case-card:hover,
.case-card.active,
.case-card.is-selected {
  border-color: rgba(199, 32, 47, .45);
  background: #fff8f8;
  transform: translateY(-1px);
}
.case-card span {
  align-self: flex-start;
  padding: 5px 8px;
  border-radius: 6px;
  background: #f2f4f6;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.case-card h3 { margin: 16px 0 8px; font-size: 24px; }
.case-card p { margin: 0; color: var(--muted); }
.case-card > strong {
  margin-top: 16px;
  color: var(--red-dark);
  font-size: 27px;
  line-height: 1;
}
.case-card em {
  margin-top: auto;
  padding-top: 18px;
  color: var(--red-dark);
  font-weight: 900;
  font-style: normal;
  text-decoration: none;
}
.case-card em::after { content: " ->"; }
.monitor-hub {
  background: #fff;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.monitor-hub-layout {
  display: grid;
  grid-template-columns: minmax(280px, .8fr) minmax(0, 1.2fr);
  gap: 18px;
  align-items: start;
}
.monitor-map-card {
  position: sticky;
  top: 96px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafb;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}
.monitor-map-card h3 {
  margin: 0 0 12px;
  font-size: clamp(26px, 3vw, 38px);
}
.monitor-map-card p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
}
.monitor-zone-cloud, .monitor-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.monitor-zone-cloud span, .monitor-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid #cfd7df;
  border-radius: 7px;
  background: #fff;
  color: #303741;
  font-size: 13px;
  font-weight: 900;
}
.monitor-hub-actions, .monitor-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 22px;
}
.monitor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.monitor-card {
  display: flex;
  flex-direction: column;
  min-height: 520px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}
.monitor-card-head {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 14px;
  align-items: center;
}
.monitor-card-head > div:last-child > span {
  align-self: flex-start;
  padding: 6px 8px;
  border-radius: 6px;
  background: #f2f4f6;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.monitor-avatar {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border-radius: 8px;
  background: linear-gradient(135deg, #15171a 0%, #25323a 100%);
  color: #fff;
  text-align: center;
  box-shadow: 0 12px 28px rgba(16, 24, 40, .14);
}
.monitor-avatar strong {
  display: block;
  font-size: 17px;
  line-height: 1;
  font-weight: 950;
}
.monitor-avatar span {
  display: block;
  margin-top: 4px;
  color: #ffcb58;
  font-size: 11px;
  font-weight: 950;
}
.monitor-avatar.large {
  width: 96px;
  height: 96px;
}
.monitor-photo {
  position: relative;
  width: 82px;
  aspect-ratio: 1;
  margin: 0;
  overflow: hidden;
  border: 2px solid #fff;
  border-radius: 8px;
  background: #f4f7f7;
  box-shadow: 0 12px 28px rgba(16, 24, 40, .14);
}
.monitor-photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
.monitor-photo span {
  position: absolute;
  right: 6px;
  bottom: 6px;
  left: 6px;
  padding: 4px 5px;
  border-radius: 5px;
  background: rgba(199, 32, 47, .94);
  color: #fff;
  font-size: 9px;
  font-weight: 950;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.monitor-photo.large {
  width: min(128px, 30vw);
}
.monitor-card h3 {
  margin: 8px 0 0;
  font-size: 24px;
}
.monitor-card p {
  margin: 0;
  color: var(--muted);
}
.monitor-promise {
  margin-top: 18px !important;
  color: #303741 !important;
  font-size: 18px !important;
  font-weight: 850;
}
.monitor-card blockquote, .monitor-person-intro blockquote {
  margin: 16px 0 0;
  padding: 15px 16px;
  border-left: 5px solid var(--red);
  border-radius: 8px;
  background: #fff8f8;
  color: #303741;
  font-weight: 850;
}
.monitor-fit {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid #cfdfe1;
  border-radius: 8px;
  background: #f4f7f7;
}
.monitor-fit strong {
  display: block;
  margin-bottom: 6px;
  color: var(--teal);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.monitor-fit p {
  margin: 0;
  color: #303741;
  font-weight: 750;
}
.monitor-style-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.monitor-style-chips span {
  padding: 7px 10px;
  border-radius: 7px;
  background: #15171a;
  color: #fff;
  font-size: 13px;
  font-weight: 950;
}
.monitor-team-note {
  margin-top: 12px !important;
  padding: 12px 14px;
  border-radius: 8px;
  background: #eef8f8;
  color: #0f6f73 !important;
  font-size: 14px !important;
  font-weight: 900;
}
.monitor-team-spirit {
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(280px, 1fr);
  gap: 16px;
  align-items: center;
  margin: 16px 0;
  padding: 16px;
  border: 1px solid #cfdfe1;
  border-radius: 8px;
  background: #f8fbfb;
}
.monitor-team-spirit h3 {
  margin: 0 0 8px;
  font-size: clamp(22px, 2.2vw, 32px);
}
.monitor-team-spirit p {
  margin: 0;
  color: #5b6573;
  font-weight: 750;
}
.monitor-team-faces {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
.monitor-team-faces figure {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  border: 1px solid #d8e5e7;
  border-radius: 8px;
  background: #fff;
}
.monitor-team-faces img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  object-position: center top;
}
.monitor-team-faces figcaption {
  padding: 7px 4px;
  color: var(--red-dark);
  font-size: 10px;
  font-weight: 950;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .03em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.monitor-card dl {
  display: grid;
  gap: 8px;
  margin: 18px 0;
}
.monitor-card dl div {
  display: grid;
  grid-template-columns: 86px 1fr;
  gap: 10px;
  padding: 10px;
  border-radius: 7px;
  background: #f8fafb;
}
.monitor-card dt {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}
.monitor-card dd {
  margin: 0;
  color: var(--ink);
  font-weight: 850;
}
.monitor-card a {
  display: inline-flex;
  justify-content: center;
  margin-top: auto;
  padding: 12px 14px;
  border-radius: 7px;
  background: var(--ink);
  color: #fff;
  text-decoration: none;
  font-weight: 950;
}
.monitor-profile {
  background: #fff;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.monitor-profile-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .42fr);
  gap: 18px;
  align-items: stretch;
}
.monitor-person-intro {
  padding: clamp(22px, 4vw, 34px);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}
.monitor-profile-kicker {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 18px;
  align-items: center;
}
.monitor-profile-kicker .eyebrow {
  margin-bottom: 8px;
}
.monitor-profile-hero h2 {
  margin: 0 0 12px;
  font-size: clamp(32px, 4vw, 56px);
}
.monitor-profile-hero p {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}
.monitor-profile-hero .monitor-fit p {
  color: #303741;
  font-size: 16px;
  font-weight: 750;
}
.monitor-scorecard {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 24px;
  border-radius: 8px;
  background: #15171a;
  color: #fff;
}
.monitor-scorecard span {
  color: #ffcb58;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.monitor-scorecard strong {
  display: block;
  margin: 14px 0 8px;
  color: #ffcb58;
  font-size: clamp(38px, 5vw, 58px);
  line-height: 1;
}
.monitor-scorecard p {
  color: #fff;
  font-weight: 900;
}
.monitor-scorecard small {
  margin-top: 18px;
  color: rgba(255,255,255,.68);
  font-weight: 750;
}
.monitor-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
  margin-top: 18px;
}
.monitor-detail-grid article {
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafb;
}
.monitor-detail-grid h3 {
  margin: 0 0 14px;
  font-size: 24px;
}
.monitor-detail-grid p {
  margin: 0;
  color: var(--muted);
}
.monitor-detail-grid ul {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.monitor-detail-grid li {
  position: relative;
  padding-left: 22px;
  color: #303741;
  font-weight: 750;
}
.monitor-detail-grid li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--teal);
}
.monitor-method-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}
.monitor-method-grid article {
  min-height: 205px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .05);
}
.monitor-method-grid span {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--red);
  color: #fff;
  font-weight: 950;
}
.monitor-method-grid h3 {
  margin: 16px 0 8px;
  font-size: 23px;
}
.monitor-method-grid p {
  margin: 0;
  color: var(--muted);
}
.monitor-next-step {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  margin-top: 18px;
  padding: 16px;
  border-radius: 8px;
  background: #f4f7f7;
  border: 1px solid #cfdfe1;
}
.monitor-next-step strong {
  color: var(--teal);
}
.monitor-next-step span {
  color: var(--muted);
}
.monitor-next-step a {
  margin-left: auto;
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.center-seo {
  background: #f8fafb;
  border-bottom: 1px solid var(--line);
  scroll-margin-top: 88px;
}
.center-seo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.center-seo-card {
  display: flex;
  flex-direction: column;
  min-height: 210px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(16, 24, 40, .05);
}
.center-seo-card span {
  align-self: flex-start;
  padding: 6px 8px;
  border-radius: 6px;
  background: #eef5f6;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.center-seo-card h3 {
  margin: 12px 0 8px;
  font-size: 20px;
}
.center-seo-card p {
  margin: 0 0 12px;
  color: var(--muted);
}
.center-seo-card ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
}
.center-seo-card a {
  margin-top: auto;
  padding-top: 16px;
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.steps-section {
  background: linear-gradient(135deg, #f7fbfa 0%, #fff 52%, #fff5f4 100%);
  color: var(--ink);
}
.steps-section .eyebrow { color: var(--red); }
.steps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.steps-grid article {
  min-height: 166px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  padding: 18px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(16,24,40,.07);
}
.steps-grid span {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: rgba(199,32,47,.1);
  color: var(--red-dark);
  font-weight: 950;
}
.steps-grid h3 { margin: 16px 0 8px; font-size: 22px; }
.steps-grid p, .steps-section .section-head p { color: var(--muted); }
.prep-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 18px;
  padding: 14px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  color: var(--muted);
}
.prep-strip span {
  padding: 7px 10px;
  border-radius: 6px;
  background: #eef8f6;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.prep-strip a {
  margin-left: auto;
  color: var(--red-dark);
  font-weight: 950;
  text-decoration: none;
}
.hour-guide { background: linear-gradient(180deg, #fff 0%, #f6fbfa 100%); }
.hour-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.hour-card {
  min-height: 150px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  padding: 16px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.06);
}
.hour-card h3 {
  margin: 0 0 12px;
  font-size: 20px;
  color: var(--ink);
}
.hour-card strong {
  display: inline-flex;
  margin-bottom: 12px;
  padding: 6px 8px;
  border-radius: 7px;
  background: rgba(199,32,47,.1);
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.hour-card p { margin: 0; color: var(--muted); }
.section-head {
  max-width: 820px;
  margin-bottom: 16px;
}
.section-head h2 {
  margin: 0;
  font-size: clamp(24px, 3.2vw, 38px);
}
.section-head p { color: var(--muted); font-size: 16px; }
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.info-card {
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  padding: 16px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}
.info-card h3 { margin: 0 0 8px; color: var(--teal); font-size: 19px; }
.info-card p { margin: 0; color: var(--muted); }
.content-band:nth-of-type(even) { background: linear-gradient(180deg, #fff 0%, #f7fbfa 100%); }
.check-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.check-list li {
  position: relative;
  background: #fff;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  padding: 14px 14px 14px 36px;
  min-height: 86px;
  box-shadow: 0 10px 24px rgba(16,24,40,.05);
}
.check-list li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 24px;
  width: 10px;
  height: 10px;
  background: var(--teal);
  border-radius: 50%;
}
.price-highlights {
  background: linear-gradient(180deg, #fff 0%, #f7fbfa 100%);
  border-top: 1px solid rgba(20,108,114,.16);
}
.price-chip-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.price-chip {
  min-height: 150px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  padding: 20px;
  background: #fff;
  box-shadow: 0 14px 32px rgba(16,24,40,.06);
}
.price-chip span {
  display: inline-flex;
  padding: 5px 8px;
  border-radius: 7px;
  background: #eef8f6;
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.price-chip strong {
  display: block;
  margin: 8px 0;
  color: var(--red-dark);
  font-size: 32px;
  line-height: 1;
}
.price-chip p { margin: 0; color: var(--muted); }
.tariff-chooser {
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.tariff-situation-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.tariff-situation {
  min-height: 185px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafb;
  color: var(--ink);
  text-align: left;
  font: inherit;
  cursor: pointer;
}
.tariff-situation:hover {
  border-color: var(--teal);
  background: #fff;
  transform: translateY(-1px);
}
.tariff-situation span {
  display: inline-flex;
  padding: 5px 8px;
  border-radius: 6px;
  background: #fff;
  color: var(--red-dark);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.tariff-situation h3 { margin: 16px 0 8px; font-size: 23px; }
.tariff-situation strong {
  display: block;
  color: var(--teal);
  font-size: 23px;
  line-height: 1.1;
}
.tariff-situation p { margin: 10px 0 0; color: var(--muted); }
.tariff-short-note {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  align-items: center;
  margin-top: 16px;
  padding: 14px 16px;
  border: 1px solid #d7e4e4;
  border-radius: 8px;
  background: #f7faf9;
}
.tariff-short-note strong {
  color: var(--teal);
}
.tariff-short-note span {
  color: var(--muted);
}
.tariff-offers { background: #f4f6f8; }
.tariff-offer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.tariff-offer {
  display: flex;
  flex-direction: column;
  min-height: 360px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}
.tariff-offer.featured {
  border: 2px solid var(--red);
  box-shadow: 0 18px 44px rgba(199, 32, 47, .14);
}
.offer-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}
.offer-meta span {
  padding: 6px 8px;
  border-radius: 6px;
  background: #f2f4f6;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.offer-meta strong {
  color: var(--red-dark);
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1;
  text-align: right;
  white-space: nowrap;
}
.tariff-offer h3 { margin: 24px 0 10px; font-size: 26px; }
.tariff-offer p { margin: 0; color: var(--muted); }
.tariff-offer ul {
  display: grid;
  gap: 8px;
  padding: 0;
  margin: 18px 0;
  list-style: none;
}
.tariff-offer li {
  position: relative;
  padding-left: 20px;
  color: #303741;
}
.tariff-offer li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal);
}
.tariff-offer a {
  display: inline-flex;
  justify-content: center;
  margin-top: auto;
  padding: 12px 14px;
  border-radius: 7px;
  background: var(--ink);
  color: #fff;
  text-decoration: none;
  font-weight: 950;
}
.tariff-offer.featured a { background: var(--red); }
.tariff-rules {
  background: linear-gradient(180deg, #fff 0%, #f7fbfa 100%);
  border-top: 1px solid rgba(20,108,114,.16);
  border-bottom: 1px solid rgba(20,108,114,.16);
}
.tariff-rule-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.tariff-rule-grid article {
  padding: 18px;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.tariff-rule-grid h3 { margin: 0 0 8px; color: var(--teal); font-size: 20px; }
.tariff-rule-grid p { margin: 0; color: var(--muted); }
.tariff-details {
  background: #15171a;
  color: #fff;
}
.tariff-details details {
  max-width: 1180px;
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
}
.tariff-details summary {
  font-size: 20px;
  color: #fff;
}
.tariff-details .table-scroll {
  margin-top: 16px;
}
.tariff-details .legal-note {
  color: rgba(255,255,255,.76);
}
.pricing-section { background: #15171a; color: #fff; }
.pricing-section .eyebrow { color: #ffcb58; }
.pricing-section .section-head p, .legal-note { color: rgba(255,255,255,.76); }
.table-scroll { overflow-x: auto; border-radius: 8px; border: 1px solid rgba(255,255,255,.16); }
table { width: 100%; border-collapse: collapse; min-width: 740px; background: #fff; color: var(--ink); }
th, td { padding: 16px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
thead th { background: #f2f4f6; font-size: 14px; text-transform: uppercase; letter-spacing: .06em; }
tbody tr:last-child th, tbody tr:last-child td { border-bottom: 0; }
.legal-note { max-width: 900px; margin: 16px 0 0; }

.motivation-gallery {
  background: #fff;
  border-top: 1px solid var(--line);
}
.motivation-gallery .section-head {
  max-width: 900px;
}
.motivation-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 16px;
  align-items: stretch;
}
.motivation-card {
  position: relative;
  min-height: 300px;
  overflow: hidden;
  border-radius: 8px;
  background: #15171a;
  color: #fff;
}
.motivation-card.feature {
  grid-row: span 2;
  min-height: 616px;
}
.motivation-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.motivation-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.76));
}
.motivation-card div {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: inherit;
  padding: clamp(20px, 4vw, 34px);
}
.motivation-card h3 {
  margin: 0 0 8px;
  font-size: clamp(25px, 3.5vw, 46px);
  line-height: 1.02;
}
.motivation-card p {
  max-width: 620px;
  margin: 0;
  color: rgba(255,255,255,.9);
  font-size: 17px;
}

.visual-band {
  display: grid;
  grid-template-columns: minmax(280px, 46%) minmax(0, 1fr);
  gap: clamp(24px, 6vw, 70px);
  align-items: center;
  background: linear-gradient(135deg, #fff 0%, #f7fbfa 52%, #fff4f3 100%);
}
.visual-band img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.visual-band h2 { margin: 0 0 14px; font-size: clamp(30px, 4vw, 52px); }
.visual-band p { color: #3e4650; font-size: 18px; max-width: 650px; }
.text-link { color: var(--red-dark); font-weight: 900; }

.faq-section { background: linear-gradient(180deg, #fff 0%, #f7fbfa 100%); }
.faq-list {
  display: grid;
  gap: 10px;
  max-width: 980px;
}
details {
  background: #fff;
  border: 1px solid rgba(20,108,114,.18);
  border-radius: 8px;
  padding: 16px 18px;
  box-shadow: 0 10px 24px rgba(16,24,40,.04);
}
summary { cursor: pointer; color: var(--ink); font-weight: 950; }
details p { color: var(--muted); margin-bottom: 0; }

.whatsapp-section {
  background: linear-gradient(180deg, #f3faf7 0%, #fff 100%);
  border-top: 1px solid #cfe7dc;
  border-bottom: 1px solid #cfe7dc;
}
.whatsapp-section .eyebrow { color: #087454; }
.whatsapp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 14px;
}
.whatsapp-card {
  display: flex;
  flex-direction: column;
  min-height: 218px;
  padding: 20px;
  border: 1px solid #cfe7dc;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(16,24,40,.05);
}
.whatsapp-card h3 { margin: 0 0 10px; color: #087454; font-size: 22px; }
.whatsapp-card p { margin: 0; color: var(--muted); }
.btn.whatsapp {
  margin-top: auto;
  background: #128c7e;
  color: #fff;
}
.btn.whatsapp:hover { background: #0c6d62; }
.advisor-note {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  align-items: center;
  margin-top: 18px;
  padding: 16px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #cfe7dc;
}
.advisor-note span { color: var(--muted); }
.advisor-note a {
  margin-left: auto;
  color: #087454;
  font-weight: 950;
  text-decoration: none;
}

.lead-section {
  background: linear-gradient(135deg, #111418 0%, #25323a 62%, #163f44 100%);
  color: #fff;
}
.lead-section .eyebrow { color: #ffcb58; }
.lead-section .section-head p { color: rgba(255,255,255,.76); }
.lead-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  max-width: 980px;
}
.lead-form label {
  display: grid;
  gap: 7px;
  font-weight: 800;
}
.lead-form input, .lead-form select, .lead-form textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 7px;
  padding: 12px 13px;
  font: inherit;
  color: var(--ink);
  background: #fff;
}
.lead-form .wide { grid-column: 1 / -1; }
.form-optional {
  padding: 0;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  background: rgba(255,255,255,.07);
  overflow: hidden;
}
.form-optional summary {
  cursor: pointer;
  padding: 11px 12px;
  color: inherit;
  font-weight: 900;
}
.form-optional-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 0 12px 12px;
}
.form-optional-grid .wide { grid-column: 1 / -1; }
.consent {
  grid-template-columns: auto 1fr !important;
  align-items: start;
  font-weight: 600 !important;
  color: rgba(255,255,255,.86);
}
.consent input { width: auto; margin-top: 5px; }
.hp { position: absolute; left: -9999px; }

.source-band {
  padding-top: 24px;
  padding-bottom: 24px;
  background: #fff;
  border-top: 1px solid var(--line);
  color: var(--muted);
  font-size: 14px;
}
.source-band a { color: var(--red-dark); font-weight: 800; }
.site-footer {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 34px clamp(20px, 5vw, 72px) 86px;
  background: #101215;
  color: #fff;
}
.site-footer p { color: rgba(255,255,255,.68); margin: 6px 0; }
.site-footer nav { display: flex; gap: 14px; flex-wrap: wrap; align-content: start; }
.site-footer a { color: #fff; text-decoration: none; font-weight: 800; }
.mobile-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  display: none;
  grid-template-columns: repeat(4, 1fr);
  z-index: 40;
  border-top: 1px solid rgba(255,255,255,.15);
}
.mobile-cta a {
  text-align: center;
  padding: 13px 8px;
  background: var(--ink);
  color: #fff;
  text-decoration: none;
  font-weight: 900;
}
.mobile-cta a:first-child { background: var(--red); }
.mobile-cta a:nth-child(3) { background: #128c7e; }
.internal-page .page-hero { background: #20242a; color: #fff; }
.internal-page .page-hero h1, .internal-page .page-hero p { color: #fff; }

body.app-shell {
  height: 100dvh;
  overflow: hidden;
  background: #f4f7f7;
}
.app-shell .site-header {
  position: relative;
  min-height: 58px;
  padding: 7px clamp(14px, 3vw, 42px);
}
.app-shell .brand {
  min-width: 0;
}
.app-shell .brand-mark {
  width: 38px;
  height: 38px;
}
.app-shell .brand small {
  max-width: 190px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.app-shell .site-nav a {
  padding: 7px;
  font-size: 12px;
}
.app-shell .header-client-tab {
  min-height: 36px;
  padding: 7px 10px;
  font-size: 12px;
}
.app-shell .header-call {
  padding: 8px 10px;
  font-size: 13px;
}
.app-shell main {
  height: calc(100dvh - 58px);
  display: grid;
  grid-template-rows: minmax(86px, 19vh) auto minmax(0, 1fr) auto;
  overflow: hidden;
  background: #f4f7f7;
}
.app-shell .hero,
.app-shell .page-hero {
  grid-row: 1;
  min-height: 0;
  overflow: auto;
}
.app-shell .hero {
  align-items: stretch;
}
.app-shell .hero-content {
  width: min(880px, 100%);
  padding: 13px clamp(16px, 4vw, 42px);
  display: grid;
  align-content: center;
}
.app-shell .hero .eyebrow,
.app-shell .page-hero .eyebrow {
  margin-bottom: 4px;
  font-size: 11px;
}
.app-shell h1 {
  max-width: 860px;
  font-size: clamp(25px, 3.2vw, 44px);
  line-height: .98;
}
.app-shell .hero-lead,
.app-shell .page-hero p {
  max-width: 760px;
  margin-top: 7px;
  font-size: clamp(13px, 1.4vw, 17px);
  line-height: 1.28;
}
.app-shell .hero-actions,
.app-shell .form-actions {
  margin-top: 9px;
  gap: 7px;
}
.app-shell .btn {
  min-height: 38px;
  padding: 8px 11px;
  font-size: 13px;
}
.app-shell .hero-proof {
  display: none;
}
.app-shell .page-hero {
  grid-template-columns: minmax(0, 1fr) minmax(210px, 300px);
  gap: 10px;
  padding: 12px clamp(16px, 4vw, 42px);
}
.app-shell .quick-panel {
  align-self: center;
  padding: 10px;
  box-shadow: none;
}
.app-shell .quick-panel span {
  margin: 5px 0 8px;
  font-size: 13px;
}
.app-shell .fast-conversion-bar {
  grid-row: 2;
  grid-template-columns: minmax(220px, .62fr) minmax(0, 1fr);
  gap: 10px;
  padding: 8px clamp(16px, 4vw, 42px) !important;
}
.app-shell .fast-conversion-bar strong {
  font-size: clamp(17px, 2vw, 23px);
}
.app-shell .fast-conversion-bar span {
  font-size: 13px;
}
.app-shell .fast-conversion-bar nav {
  gap: 7px;
}
.app-shell .fast-action-link {
  min-height: 38px;
  padding: 8px 10px;
  font-size: 13px;
}
.app-shell .essential-workflow {
  grid-row: 3;
  min-height: 0;
  overflow: auto;
  padding: 10px clamp(16px, 4vw, 42px) !important;
}
.app-shell .essential-head {
  display: flex;
  gap: 12px;
  justify-content: space-between;
  align-items: end;
  margin-bottom: 8px;
}
.app-shell .essential-head h2 {
  max-width: 720px;
  font-size: clamp(22px, 2.5vw, 36px);
}
.app-shell .essential-head p {
  max-width: 430px;
  font-size: 13px;
  line-height: 1.25;
}
.app-shell .essential-grid {
  height: calc(100% - 56px);
  grid-template-columns: minmax(220px, 1fr) minmax(200px, .85fr) minmax(200px, .85fr) minmax(190px, .72fr);
  gap: 9px;
  min-height: 0;
}
.app-shell .essential-card {
  min-height: 0;
  padding: 11px;
  overflow: auto;
}
.app-shell .essential-card > span {
  width: 28px;
  height: 28px;
}
.app-shell .essential-card h3 {
  margin: 9px 0 5px;
  font-size: clamp(18px, 2vw, 26px);
}
.app-shell .essential-card > strong {
  font-size: clamp(17px, 2vw, 25px);
}
.app-shell .essential-card p,
.app-shell .essential-card li {
  font-size: 12px;
  line-height: 1.28;
}
.app-shell .essential-card ul {
  gap: 5px;
  margin-top: 8px;
}
.app-shell .essential-founder {
  padding: 0 !important;
}
.app-shell .essential-founder img {
  height: 92px;
}
.app-shell .essential-founder div {
  padding: 9px;
}
.app-shell .essential-founder div > span {
  margin-bottom: 6px;
  font-size: 10px;
}
.app-shell .essential-founder h3 {
  margin-bottom: 5px;
  font-size: clamp(16px, 1.7vw, 21px);
}
.app-shell .essential-card li {
  padding: 6px 7px;
}
.app-shell .essential-date {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
}
.app-shell .essential-date-list {
  gap: 6px;
  min-height: 0;
}
.app-shell .essential-date .essential-date-list {
  max-height: min(45vh, 360px);
  overflow: auto;
  padding-right: 4px;
}
.app-shell .essential-date-pill {
  padding: 8px;
}
.app-shell .essential-date-pill strong {
  font-size: 13px;
}
.app-shell .essential-date-pill span {
  font-size: 13px;
}
.app-shell .compact-details {
  grid-row: 4;
  min-height: 0;
  padding: 7px clamp(16px, 4vw, 42px) !important;
  background: #eef4f3;
}
.app-shell .compact-details > details {
  max-width: none;
  max-height: calc(100dvh - 86px);
  padding: 0;
  overflow: hidden;
}
.app-shell .compact-details > details > summary {
  min-height: 42px;
  padding: 9px 11px;
}
.app-shell .compact-details > details > summary span {
  font-size: clamp(16px, 1.8vw, 21px);
}
.app-shell .compact-details > details > summary small {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 12px;
}
.app-shell .compact-details > details > summary::after {
  padding: 6px 8px;
  font-size: 12px;
}
.app-shell .compact-details > details[open] {
  height: min(54vh, 430px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.app-shell .compact-details-body {
  height: 100%;
  min-height: 0;
  overflow: auto;
  padding: 0 10px 8px;
}
.app-shell .compact-details-body > section {
  display: none;
  height: 100%;
  min-height: 0;
  overflow: auto;
  padding: 8px 0;
  border-bottom: 0;
}
.app-shell .compact-details-body > section:first-of-type,
.app-shell .compact-details-body > section.is-app-active {
  display: block;
}
.app-shell .compact-details-body.has-active-panel > section:first-of-type {
  display: none;
}
.app-shell .compact-details-body.has-active-panel > section.is-app-active {
  display: block;
}
.app-shell .compact-details-body.has-active-panel > section:not(.is-app-active) {
  display: none !important;
}
.app-shell .compact-details-body.has-active-panel > section.is-app-active.exam-projection {
  display: grid;
}
.app-shell .compact-text-mode .section-head,
.app-shell .compact-text-mode .projection-head {
  max-width: none;
  margin-bottom: 7px;
}
.app-shell .compact-text-mode .section-head h2,
.app-shell .compact-text-mode .projection-head h2,
.app-shell .compact-text-mode h2 {
  font-size: clamp(18px, 2vw, 27px);
}
.app-shell .compact-text-mode .section-head p,
.app-shell .compact-text-mode p,
.app-shell .compact-text-mode li,
.app-shell .compact-text-mode small {
  font-size: 12px;
  line-height: 1.28;
}
.app-shell .compact-text-mode .exam-projection {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.app-shell .compact-text-mode .projection-head p:last-child,
.app-shell .compact-text-mode .projection-offer-zone,
.app-shell .compact-text-mode .projection-hidden-controls,
.app-shell .compact-text-mode .projection-center-photo-card,
.app-shell .compact-text-mode .projection-after-payment,
.app-shell .compact-text-mode .projection-buying-strip,
.app-shell .compact-text-mode .projection-payment-preview,
.app-shell .compact-text-mode [data-projection-steps] {
  display: none;
}
.app-shell .compact-text-mode .projection-stage {
  height: 100%;
  min-height: 0;
  grid-template-columns: minmax(0, 1.03fr) minmax(300px, .97fr);
  gap: 9px;
}
.app-shell .compact-text-mode .projection-date-zone,
.app-shell .compact-text-mode .projection-result {
  min-height: 0;
  overflow: auto;
}
.app-shell .compact-text-mode .projection-zone-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(170px, .45fr);
  gap: 7px;
  padding: 0;
}
.app-shell .compact-text-mode .projection-zone-head strong {
  font-size: clamp(18px, 2vw, 24px);
}
.app-shell .compact-text-mode .projection-selected-action {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 7px;
  padding: 8px;
}
.app-shell .compact-text-mode .projection-selected-action strong {
  font-size: 16px;
}
.app-shell .compact-text-mode .projection-selected-action p {
  max-height: 34px;
  overflow: auto;
}
.app-shell .compact-text-mode .projection-date-grid {
  max-height: 140px;
  overflow: auto;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  padding: 0;
}
.app-shell .compact-text-mode .projection-date-card {
  min-height: 68px;
  padding: 8px;
}
.app-shell .compact-text-mode .projection-date-card strong {
  font-size: 18px;
}
.app-shell .compact-text-mode .projection-date-card em {
  display: none;
}
.app-shell .compact-text-mode .projection-result {
  padding: 10px;
}
.app-shell .compact-text-mode .projection-result h3,
.app-shell .compact-text-mode .projection-hero-date strong {
  font-size: 18px;
}
.app-shell .compact-text-mode .projection-countdown,
.app-shell .compact-text-mode .projection-day-scene {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}
.app-shell .compact-text-mode .projection-day-scene article,
.app-shell .compact-text-mode .projection-countdown article {
  padding: 8px;
}
.app-shell .compact-text-mode .projection-day-scene small {
  display: none;
}
.app-shell .compact-text-mode .projection-actions,
.app-shell .compact-text-mode .projection-selected-actions,
.app-shell .compact-text-mode .training-emotion-actions,
.app-shell .compact-text-mode .schedule-note,
.app-shell .compact-text-mode .form-actions,
.app-shell .compact-text-mode .payment-method-row {
  gap: 6px;
}
.app-shell .compact-text-mode .training-emotion,
.app-shell .compact-text-mode .training-schedule,
.app-shell .compact-text-mode .enrollment-boost,
.app-shell .compact-text-mode .case-router,
.app-shell .compact-text-mode .lead-section,
.app-shell .compact-text-mode .partner-form-section,
.app-shell .compact-text-mode .portal-overview,
.app-shell .compact-text-mode .pilot-command,
.app-shell .compact-text-mode .livret-followup {
  height: 100%;
  min-height: 0;
  overflow: auto;
}
.app-shell .compact-text-mode .training-emotion-board,
.app-shell .compact-text-mode .schedule-layout,
.app-shell .compact-text-mode .enrollment-action,
.app-shell .compact-text-mode .lead-form,
.app-shell .compact-text-mode .partner-form,
.app-shell .compact-text-mode .portal-overview,
.app-shell .compact-text-mode .pilot-layout {
  height: 100%;
  min-height: 0;
}
.app-shell .compact-text-mode .training-emotion-board {
  grid-template-columns: minmax(0, 1fr) minmax(260px, .78fr);
  gap: 8px;
}
.app-shell .compact-text-mode .training-emotion-scene,
.app-shell .compact-text-mode .training-emotion-stats,
.app-shell .compact-text-mode .training-emotion-road,
.app-shell .compact-text-mode .schedule-road,
.app-shell .compact-text-mode .contract-preview-wrap,
.app-shell .compact-text-mode .motivation-gallery,
.app-shell .compact-text-mode .visual-band,
.app-shell .compact-text-mode .source-band,
.app-shell .compact-text-mode .faq-section {
  display: none;
}
.app-shell .compact-text-mode .training-emotion-pass,
.app-shell .compact-text-mode .schedule-main-card,
.app-shell .compact-text-mode .schedule-side-card,
.app-shell .compact-text-mode .enrollment-result,
.app-shell .compact-text-mode .enrollment-panel {
  min-height: 0;
  padding: 10px;
  overflow: auto;
}
.app-shell .compact-text-mode .training-pass-main h3,
.app-shell .compact-text-mode .schedule-main-card h3,
.app-shell .compact-text-mode .enrollment-result h3 {
  font-size: clamp(19px, 2.2vw, 27px);
}
.app-shell .compact-text-mode .training-pass-route,
.app-shell .compact-text-mode .training-pass-after,
.app-shell .compact-text-mode .schedule-data-grid,
.app-shell .compact-text-mode .payment-direct-strip,
.app-shell .compact-text-mode .monitor-handoff-grid {
  gap: 6px;
}
.app-shell .compact-text-mode .training-pass-route div,
.app-shell .compact-text-mode .training-pass-after,
.app-shell .compact-text-mode .schedule-data-grid div,
.app-shell .compact-text-mode .payment-direct-strip article,
.app-shell .compact-text-mode .monitor-handoff-grid article {
  min-height: 0;
  padding: 8px;
}
.app-shell .compact-text-mode .schedule-layout,
.app-shell .compact-text-mode .enrollment-action {
  grid-template-columns: minmax(0, 1fr) minmax(280px, .78fr);
  gap: 8px;
}
.app-shell .compact-text-mode .monitor-handoff {
  height: auto;
  min-height: 0;
  grid-template-columns: minmax(0, .78fr) minmax(0, 1.22fr);
  margin-bottom: 8px;
  padding: 8px;
}
.app-shell .compact-text-mode .monitor-handoff h3 {
  font-size: 18px;
}
.app-shell .compact-text-mode .monitor-handoff p {
  font-size: 12px;
  line-height: 1.2;
}
.app-shell .compact-text-mode .monitor-handoff-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.app-shell .compact-text-mode .monitor-handoff-grid strong {
  font-size: 13px;
}
.app-shell .compact-text-mode .monitor-handoff-grid p {
  max-height: none;
  overflow: visible;
  font-size: 11px;
}
.app-shell .compact-text-mode .schedule-side-card figure,
.app-shell .compact-text-mode .schedule-road {
  display: none;
}
.app-shell .compact-text-mode .enrollment-panel {
  grid-template-columns: 1fr;
  align-content: start;
}
.app-shell .compact-text-mode .contract-extra-fields {
  display: none;
}
.app-shell .compact-text-mode .enrollment-result ul {
  max-height: 72px;
  overflow: auto;
}
.app-shell .compact-text-mode .case-grid,
.app-shell .compact-text-mode .tariff-offer-grid,
.app-shell .compact-text-mode .tariff-situation-grid,
.app-shell .compact-text-mode .monitor-grid,
.app-shell .compact-text-mode .portal-module-grid,
.app-shell .compact-text-mode .pilot-role-grid,
.app-shell .compact-text-mode .payoff-grid,
.app-shell .compact-text-mode .selection-service-grid,
.app-shell .compact-text-mode .selection-rate-grid,
.app-shell .compact-text-mode .partner-tier-grid,
.app-shell .compact-text-mode .awards-grid,
.app-shell .compact-text-mode .awards-ranking ul,
.app-shell .compact-text-mode .mobility-grid,
.app-shell .compact-text-mode .partner-monetization-grid,
.app-shell .compact-text-mode .notification-grid,
.app-shell .compact-text-mode .condition-grid,
.app-shell .compact-text-mode .quick-reply-grid {
  max-height: 100%;
  overflow: auto;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
}
.app-shell.portal-page .essential-workflow {
  display: none;
}
.app-shell.portal-page main > .portal-overview,
.app-shell.portal-page main > .simple-access {
  grid-row: 3;
  min-height: 0;
  overflow: auto;
  padding: 10px clamp(16px, 4vw, 42px) !important;
}
.app-shell.portal-page main > .portal-overview {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .82fr);
  gap: 10px;
}
.app-shell.portal-page .portal-overview-copy h2,
.app-shell.portal-page .simple-access-head h2 {
  font-size: clamp(20px, 2.3vw, 34px);
  line-height: 1;
}
.app-shell.portal-page .portal-overview-copy p,
.app-shell.portal-page .simple-access-head p,
.app-shell.portal-page .portal-login-panel p {
  font-size: 12px;
  line-height: 1.3;
}
.app-shell.portal-page .portal-login-panel {
  min-height: 0;
  padding: 10px;
  overflow: auto;
}
.app-shell.portal-page .portal-login-visual {
  display: none;
}
.app-shell.portal-page .portal-access-flow {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 8px;
}
.app-shell.portal-page .portal-access-flow article {
  padding: 8px;
}
.app-shell.portal-page .portal-entry-actions,
.app-shell.portal-page .portal-actions {
  gap: 6px;
  margin-top: 8px;
}
.app-shell.portal-page .portal-badges {
  gap: 5px;
  margin-top: 8px;
}
.app-shell.portal-page .portal-badges span {
  padding: 5px 7px;
  font-size: 10px;
}
.app-shell.portal-page .simple-access {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
}
.app-shell.portal-page .portal-hero-card,
.app-shell.portal-page .simple-access > .emotion-selected-action {
  display: none;
}
.app-shell.portal-page .simple-access-grid {
  min-height: 0;
  overflow: auto;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.app-shell.portal-page .simple-access-card {
  min-height: 0;
  padding: 11px;
  overflow: auto;
}
.app-shell.portal-page .simple-access-card strong {
  margin: 8px 0;
  font-size: clamp(17px, 1.8vw, 23px);
}
.app-shell .site-footer {
  display: none;
}
.app-shell .action-assistant {
  left: auto;
  right: 14px;
  bottom: 12px;
  max-width: min(480px, calc(100vw - 28px));
  grid-template-columns: minmax(0, 1fr) 30px;
  padding: 9px;
}
.app-shell .action-assistant-actions {
  grid-column: 1 / -1;
}
.app-shell .action-assistant-copy strong {
  font-size: 15px;
}
.app-shell .action-assistant-copy p {
  font-size: 12px;
}

@media (max-width: 1120px) {
  .menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    min-height: 40px;
    border: 1px solid var(--line);
    background: #fff;
    border-radius: 7px;
    padding: 10px 12px;
    font-weight: 900;
  }
  .site-nav {
    position: absolute;
    left: 16px;
    right: 16px;
    top: 72px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: 10px;
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 8px;
    box-shadow: var(--shadow);
  }
  .site-nav.open {
    display: flex;
    max-height: calc(100dvh - 86px);
    overflow: auto;
  }
  .site-nav .nav-formula-menu {
    display: grid;
    gap: 8px;
  }
  .site-nav .nav-formula-trigger {
    justify-content: space-between;
    width: 100%;
    padding: 10px 12px;
    border: 1px solid #eef1f3;
    background: #fff6f7;
    color: var(--red-dark);
    font-size: 15px;
    font-weight: 950;
  }
  .site-nav .nav-formula-panel,
  .site-nav .nav-formula-menu:hover .nav-formula-panel,
  .site-nav .nav-formula-menu:focus-within .nav-formula-panel {
    position: static;
    display: none;
    width: 100%;
    grid-template-columns: 1fr;
    gap: 10px;
    max-height: none;
    overflow: visible;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    transform: none;
  }
  .site-nav .nav-formula-menu.is-open .nav-formula-panel {
    display: grid;
  }
  .site-nav .nav-formula-intro {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 13px;
    border: 1px solid rgba(199,32,47,.12);
    border-radius: 14px;
    background:
      radial-gradient(circle at 100% 0, rgba(199,32,47,.14), transparent 36%),
      linear-gradient(145deg, #fff, #f7fcfb);
  }
  .site-nav .nav-formula-intro span {
    grid-column: 1 / -1;
    font-size: 10px;
  }
  .site-nav .nav-formula-intro strong {
    font-size: 18px;
    line-height: 1.08;
  }
  .site-nav .nav-formula-intro a {
    justify-self: start;
    padding: 9px 13px !important;
    text-align: center;
  }
  .site-nav .nav-formula-main-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .site-nav .nav-formula-quick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }
  .site-nav .nav-formula-card {
    min-height: 0;
    padding: 12px !important;
  }
  .site-nav .nav-formula-card-main {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 5px 12px;
    align-items: start;
    min-height: 118px;
    border-radius: 14px !important;
    background:
      radial-gradient(circle at 100% 100%, rgba(17,122,122,.10), transparent 34%),
      linear-gradient(145deg, #fff, #fff8f9);
    box-shadow: 0 12px 28px rgba(16,24,40,.06);
  }
  .site-nav .nav-formula-card-quick {
    min-height: 58px;
  }
  .site-nav .nav-formula-kicker {
    grid-column: 1 / -1;
    padding: 3px 7px;
    font-size: 9px;
  }
  .site-nav .nav-formula-card strong {
    font-size: 19px;
    line-height: 1;
  }
  .site-nav .nav-formula-card small {
    justify-self: end;
    color: var(--red-dark);
    font-size: 14px;
  }
  .site-nav .nav-formula-badge {
    justify-self: start;
    font-size: 10px;
  }
  .site-nav .nav-formula-card-main .nav-formula-moment {
    grid-column: 1 / -1;
    display: block;
    max-width: 88%;
    font-size: 11.5px;
  }
  .site-nav .nav-formula-card-main .nav-formula-cta {
    grid-column: 1 / -1;
    justify-self: start;
    padding: 8px 11px;
    font-size: 11px;
  }
  .site-nav .nav-formula-card-quick .nav-formula-kicker {
    font-size: 8px;
  }
  .site-nav .nav-formula-card-quick .nav-formula-cta {
    display: none;
  }
  .site-nav .nav-formula-card-quick .nav-formula-moment,
  .site-nav .nav-formula-steps {
    display: none;
  }
  .site-nav .nav-formula-quick-title {
    margin-top: 1px;
  }
  .header-call { display: none; }
  .page-hero, .visual-band, .motivation-grid, .evaluation-layout, .evaluation-form, .projection-layout, .projection-stage, .projection-day-video-card, .training-emotion-board, .schedule-layout, .payment-direct-head, .monitor-handoff, .enrollment-layout, .enrollment-action, .enrollment-panel, .contract-columns, .contract-signatures, .monitor-hub-layout, .monitor-profile-hero, .next-dates-home, .decision-dashboard, .ultra-path, .audience-gateway, .momentum-layout, .partner-momentum, .network-teaser, .mobility-support-head, .notification-head, .fast-conversion-bar, .source-funnel-head, .essential-head, .access-help, .portal-switcher, .portal-overview, .portal-hero-card, .pilot-layout, .pilot-board, .portal-next, .livret-layout, .partner-track-grid, .partner-hero-card, .recruitment-split, .monitor-desire, .selection-kicker, .selection-test-panel, .selection-camaraderie, .monitor-space, .finance-panel, .partner-fit, .formula-selected-action, .emotion-selected-action { grid-template-columns: 1fr; }
  .fast-conversion-bar nav { justify-content: flex-start; }
  .fast-action-link { flex: 1 1 150px; }
  .quick-panel { align-self: stretch; }
  .card-grid, .check-list, .case-grid, .steps-grid, .hour-grid, .reassurance-bar, .audience-grid, .decision-grid, .ultra-step-grid, .journey-path-grid, .momentum-path, .partner-momentum-grid, .simple-access-grid, .access-help-grid, .source-funnel-grid, .essential-grid, .price-chip-grid, .tariff-situation-grid, .tariff-offer-grid, .tariff-rule-grid, .projection-windows, .projection-offer-grid, .projection-day-scene, .projection-buying-strip, .training-pass-route, .training-emotion-road, .training-emotion-stats, .schedule-data-grid, .schedule-road, .payment-direct-strip, .monitor-handoff-grid, .enrollment-steps, .contract-extra-grid, .official-contract-signatures, .schedule-flow, .schedule-grid, .monitor-grid, .monitor-detail-grid, .monitor-method-grid, .center-seo-grid, .partner-step-grid, .payoff-grid, .desire-grid, .selection-service-grid, .selection-rate-grid, .partner-tier-grid, .awards-grid, .awards-ranking ul, .mobility-grid, .partner-monetization-grid, .notification-grid, .portal-switch-grid, .portal-metrics, .pilot-kpi-grid, .pilot-queue, .pilot-role-grid, .pilot-position-grid, .portal-role-grid, .portal-module-grid, .portal-access-flow, .portal-access-fields, .livret-track-grid, .livret-competence-grid, .livret-hub-grid, .data-access-grid, .data-access-columns, .data-rule-grid, .doc-check-grid, .condition-grid, .ops-layout, .quick-reply-grid { grid-template-columns: 1fr; }
  .selection-service-grid article.feature { grid-column: auto; }
  .source-step { min-height: 0; }
  .monitor-desire-copy { position: static; }
  .condition-alert { grid-template-columns: 1fr; }
  .condition-alert p, .condition-alert a { grid-column: auto; grid-row: auto; }
  .formula-selected-actions, .emotion-selected-actions { grid-column: auto; }
  .projection-selected-action { align-items: stretch; flex-direction: column; }
  .projection-selected-actions { justify-content: flex-start; min-width: 0; }
  .training-pass-top, .training-pass-after, .schedule-main-top { grid-template-columns: 1fr; flex-direction: column; }
  .training-pass-top strong { max-width: none; text-align: left; }
  .schedule-main-top strong { max-width: none; text-align: left; }
  .action-assistant {
    grid-template-columns: 1fr 34px;
    bottom: 74px;
    padding: 10px;
  }
  .action-assistant-actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }
  .action-assistant-actions .btn {
    flex: 1 1 150px;
  }
  .contract-signature-modal {
    align-items: end;
    padding: 10px;
  }
  .contract-signature-card {
    max-height: 88vh;
  }
  .contract-modal-summary,
  .contract-modal-steps,
  .contract-modal-legal-grid,
  .contract-modal-fields,
  .contract-signature-recap {
    grid-template-columns: 1fr;
  }
  .contract-modal-actions .btn,
  .contract-modal-actions .text-link {
    flex: 1 1 100%;
    justify-content: center;
  }
  .projection-date-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .next-dates-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .monitor-map-card { position: static; }
  .monitor-next-step a { margin-left: 0; width: 100%; }
  .motivation-card.feature { grid-row: auto; min-height: 360px; }
  .motivation-card { min-height: 320px; }
  .prep-strip a { margin-left: 0; width: 100%; }
  .advisor-note a { margin-left: 0; width: 100%; }
  .schedule-note a { margin-left: 0; width: 100%; }
  .hero-proof { grid-template-columns: 1fr; max-width: 360px; }
  .lead-form { grid-template-columns: 1fr; }
  .mobile-cta { display: grid; }
}

@media (max-width: 620px) {
  .site-header { min-height: 66px; padding: 10px 14px; }
  .brand { min-width: 0; }
  .brand small { display: none; }
  .brand-mark { width: 40px; height: 40px; }
  .hero { min-height: auto; background-position: 64% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(10,13,16,.9), rgba(10,13,16,.54)); }
  .hero-content { padding: 24px 20px 26px; }
  h1 { font-size: clamp(32px, 10vw, 44px); }
  .hero-lead { margin-top: 10px; font-size: 16px; }
  .hero-actions { margin-top: 14px; gap: 8px; }
  .hero-actions .btn { min-height: 40px; padding: 10px 12px; }
  .hero-proof { display: none; }
  .next-dates-home { padding-top: 30px; padding-bottom: 30px; }
  .essential-workflow { padding-top: 22px; padding-bottom: 22px; }
  .essential-head { margin-bottom: 10px; }
  .essential-head h2 { font-size: clamp(29px, 10vw, 42px); }
  .essential-card { min-height: 0; }
  .essential-date-list {
    display: grid;
    grid-template-columns: 1fr;
    overflow: visible;
    padding-bottom: 4px;
  }
  .official-contract-dialog {
    padding: 10px;
  }
  .official-contract-scrollbox {
    max-height: 52vh;
    padding: 10px;
  }
  .contract-modal-terms .official-contract-scrollbox {
    max-height: 30vh;
  }
  .official-contract-source {
    align-items: flex-start;
    flex-direction: column;
  }
  .essential-date-pill {
    min-width: 0;
  }
  .monitor-team-spirit {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .monitor-team-faces {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  .monitor-team-faces figcaption {
    display: none;
  }
  .monitor-profile-kicker {
    grid-template-columns: 72px 1fr;
    gap: 12px;
  }
  .monitor-photo.large {
    width: 72px;
  }
  .next-dates-list {
    display: grid;
    grid-template-columns: 1fr;
    overflow: visible;
    padding-bottom: 4px;
  }
  .next-date-card { min-width: 0; }
  .projection-zone-head { display: grid; }
  .projection-date-grid { grid-template-columns: 1fr; }
  .projection-video-trigger {
    min-height: 240px;
    aspect-ratio: 9 / 16;
  }
  .projection-date-card { min-height: 126px; }
  .projection-selected-actions .btn { width: 100%; justify-content: center; }
  .page-hero p { font-size: 17px; }
  .page-hero { padding: 20px; }
  .quick-panel { padding: 14px; }
  .quick-panel span { margin-bottom: 12px; }
  .essential-grid {
    display: grid;
    grid-template-columns: 1fr;
    overflow: visible;
    padding-bottom: 4px;
  }
  .essential-card {
    min-width: 0;
  }
  .essential-pay .btn { margin-top: 10px; }
  .portal-overview { padding-top: 20px; padding-bottom: 20px; }
  .portal-overview-copy h2 { font-size: clamp(25px, 8vw, 36px); }
  .portal-login-panel { padding: 14px; }
  .portal-login-visual,
  .portal-access-flow {
    display: none;
  }
  .portal-badges {
    display: flex;
    overflow: visible;
    flex-wrap: wrap;
    padding-bottom: 4px;
  }
  .portal-badges span { flex: 1 1 120px; min-width: 0; }
  .simple-access-head h2 { font-size: clamp(28px, 9vw, 40px); }
  .simple-access .portal-hero-card,
  .simple-access > .emotion-selected-action {
    display: none;
  }
  .simple-access-grid {
    display: grid;
    grid-template-columns: 1fr;
    overflow: visible;
    padding-bottom: 4px;
  }
  .simple-access-card {
    min-width: 0;
  }
  .network-pay-chips { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .monitor-fee-table { min-width: 620px; }
  .finance-panel { overflow-x: auto; }
  .site-footer { flex-direction: column; }
  .app-shell .site-header {
    min-height: 54px;
    padding: 7px 10px;
  }
  .app-shell .brand small,
  .app-shell .header-call {
    display: none;
  }
  .app-shell main {
    height: calc(100dvh - 54px - 47px);
    grid-template-rows: minmax(76px, 17vh) auto minmax(0, 1fr) auto;
  }
  .app-shell .mobile-cta {
    display: grid;
  }
  .app-shell .mobile-cta a {
    padding: 10px 5px;
    font-size: 12px;
  }
  .app-shell .hero-content,
  .app-shell .page-hero {
    padding: 10px 12px;
    overflow: auto;
  }
  .app-shell h1 {
    font-size: clamp(22px, 7vw, 34px);
  }
  .app-shell .hero-lead,
  .app-shell .page-hero p {
    max-height: none;
    overflow: visible;
    font-size: 12px;
  }
  .app-shell .hero-actions .btn:nth-child(n+3) {
    display: none;
  }
  .app-shell .fast-conversion-bar {
    grid-template-columns: 1fr;
    padding: 7px 10px !important;
  }
  .app-shell .fast-conversion-bar > div span {
    display: none;
  }
  .app-shell .fast-conversion-bar nav {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .app-shell .fast-action-link {
    min-width: 0;
    padding: 7px 5px;
    font-size: 11px;
    white-space: normal;
  }
  .app-shell .essential-workflow,
  .app-shell .compact-details {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
  .app-shell .essential-head {
    display: block;
    margin-bottom: 6px;
  }
  .app-shell .essential-head p {
    display: none;
  }
  .app-shell .essential-grid {
    height: calc(100% - 36px);
    display: grid;
    grid-template-columns: 1fr;
    overflow: auto;
  }
  .app-shell .essential-card:not(:first-child) {
    display: none;
  }
  .app-shell .compact-details > details[open] {
    height: min(62vh, 500px);
  }
  .app-shell .compact-details > details > summary small {
    display: none;
  }
  .app-shell .compact-text-mode .projection-stage,
  .app-shell .compact-text-mode .training-emotion-board,
  .app-shell .compact-text-mode .schedule-layout,
  .app-shell .compact-text-mode .monitor-handoff,
  .app-shell .compact-text-mode .enrollment-action {
    grid-template-columns: 1fr;
  }
  .app-shell .compact-text-mode .projection-result,
  .app-shell .compact-text-mode .training-emotion-scene,
  .app-shell .compact-text-mode .schedule-side-card {
    display: none;
  }
  .app-shell .compact-text-mode .projection-date-grid {
    max-height: 176px;
    grid-template-columns: 1fr;
    overflow: auto;
  }
  .app-shell .compact-text-mode .projection-selected-action {
    grid-template-columns: 1fr;
  }
  .app-shell .compact-text-mode .enrollment-panel {
    grid-template-columns: 1fr;
  }
  .app-shell .action-assistant {
    left: 8px;
    right: 8px;
    bottom: 54px;
    max-width: none;
  }
}

/* App cockpit final: one visible decision screen, no page-like stack. */
body.app-shell {
  height: 100dvh;
  overflow: hidden;
  background: #edf3f2;
}
.app-shell .site-header {
  height: 64px;
  min-height: 64px;
  padding: 8px 16px;
  border-bottom: 1px solid #d8e3e1;
  background: rgba(255,255,255,.96);
}
.app-shell .brand-mark {
  width: 40px;
  height: 40px;
}
.app-shell .brand strong {
  font-size: 15px;
}
.app-shell .brand small {
  max-width: 230px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.app-shell .site-nav a {
  padding: 7px 8px;
  font-size: 12px;
}
.app-shell .header-call {
  min-height: 38px;
  padding: 8px 12px;
}
.app-shell main {
  height: calc(100dvh - 64px);
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) 280px;
  grid-template-rows: 56px minmax(0, 1fr);
  gap: 12px;
  padding: 12px;
  overflow: hidden;
  background: #edf3f2;
}
.app-shell .hero,
.app-shell .page-hero {
  grid-column: 1;
  grid-row: 1 / 3;
  height: 100%;
  min-height: 0;
  padding: 14px;
  overflow: auto;
  display: grid;
  grid-template-columns: 1fr;
  align-content: start;
  background: #fff !important;
  border: 1px solid #d8e3e1;
  border-radius: 10px;
  color: var(--ink);
  box-shadow: none;
}
.app-shell .hero-shade {
  display: none;
}
.app-shell .hero-content {
  width: auto;
  padding: 0;
  color: var(--ink);
  display: grid;
  align-content: start;
}
.app-shell .hero .eyebrow,
.app-shell .page-hero .eyebrow {
  margin-bottom: 8px;
  color: var(--teal);
}
.app-shell .hero h1,
.app-shell .page-hero h1,
.app-shell h1 {
  color: var(--ink);
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.03;
}
.app-shell .hero-lead,
.app-shell .page-hero p {
  margin-top: 8px;
  max-height: none;
  overflow: visible;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}
.app-shell .hero-actions,
.app-shell .form-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.app-shell .hero-actions .btn:nth-child(n+3) {
  display: inline-flex;
}
.app-shell .btn {
  min-height: 38px;
  padding: 8px 11px;
  border-radius: 8px;
  font-size: 13px;
}
.app-shell .quick-panel {
  align-self: start;
  margin-top: 10px;
  padding: 12px;
  border: 1px solid #d8e3e1;
  box-shadow: none;
}
.app-shell .quick-panel span {
  margin: 6px 0 10px;
}
.app-shell .fast-conversion-bar {
  grid-column: 2 / 4;
  grid-row: 1;
  min-height: 0;
  padding: 8px 10px !important;
  display: grid;
  grid-template-columns: minmax(190px, .42fr) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  border: 1px solid #d8e3e1;
  border-radius: 10px;
  background: #fff;
  color: var(--ink);
}
.app-shell .fast-conversion-bar strong {
  color: var(--red-dark);
  font-size: 18px;
}
.app-shell .fast-conversion-bar span {
  display: none;
}
.app-shell .fast-conversion-bar nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.app-shell .fast-action-link {
  min-height: 38px;
  padding: 8px 9px;
  border: 1px solid #d8e3e1;
  border-radius: 8px;
  background: #f6f8f8;
  color: var(--ink);
  font-size: 12px;
}
.app-shell .fast-action-link.primary {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
.app-shell .fast-action-link.active {
  border-color: var(--red);
  background: #fff5f6;
  color: var(--red-dark);
}
.app-shell .fast-action-link.primary.active {
  background: var(--red);
  color: #fff;
}
.app-shell .compact-details {
  grid-column: 2;
  grid-row: 2;
  min-height: 0;
  padding: 0 !important;
  background: transparent;
  position: relative;
  overflow: hidden;
}
.app-shell .compact-details > details {
  position: absolute;
  inset: 0;
  height: auto;
  max-height: none;
  display: block;
  padding: 0;
  border: 0;
  background: transparent;
  overflow: hidden;
}
.app-shell .compact-details > details[open] {
  height: auto;
  display: block;
  grid-template-rows: none;
}
.app-shell .compact-details > details > summary {
  display: none;
}
.app-shell .compact-details-body {
  position: absolute;
  inset: 0;
  height: auto;
  width: auto;
  min-height: 0;
  padding: 0;
  overflow: hidden;
}
.app-shell .compact-details-body > section {
  display: none;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  padding: 14px;
  overflow: auto;
  box-sizing: border-box;
  border: 1px solid #d8e3e1;
  border-radius: 10px;
  background: #fff;
}
.app-shell .compact-details-body > section:first-of-type,
.app-shell .compact-details-body > section.is-app-active {
  display: block;
}
.app-shell .compact-details-body.has-active-panel > section:first-of-type {
  display: none;
}
.app-shell .compact-details-body.has-active-panel > section.is-app-active {
  display: block;
}
.app-shell .compact-details-body.has-active-panel > section:not(.is-app-active) {
  display: none !important;
  pointer-events: none;
}
.app-shell .compact-details-body.has-active-panel > section.is-app-active.exam-projection {
  display: grid;
}
.app-shell .compact-text-mode .section-head,
.app-shell .compact-text-mode .projection-head {
  max-width: none;
  margin-bottom: 10px;
}
.app-shell .compact-text-mode .section-head h2,
.app-shell .compact-text-mode .projection-head h2,
.app-shell .compact-text-mode h2 {
  font-size: clamp(22px, 2.8vw, 38px);
  line-height: 1.02;
}
.app-shell .compact-text-mode .section-head p,
.app-shell .compact-text-mode .projection-head p,
.app-shell .compact-text-mode p,
.app-shell .compact-text-mode li,
.app-shell .compact-text-mode small {
  font-size: 13px;
  line-height: 1.35;
}
.app-shell .compact-text-mode .exam-projection {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.app-shell .compact-text-mode .projection-stage {
  height: auto;
  min-height: 0;
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, .92fr);
  gap: 12px;
}
.app-shell .compact-text-mode .projection-date-zone,
.app-shell .compact-text-mode .projection-result,
.app-shell .compact-text-mode .training-emotion,
.app-shell .compact-text-mode .training-schedule,
.app-shell .compact-text-mode .enrollment-boost,
.app-shell .compact-text-mode .case-router,
.app-shell .compact-text-mode .lead-section,
.app-shell .compact-text-mode .partner-form-section,
.app-shell .compact-text-mode .portal-overview,
.app-shell .compact-text-mode .pilot-command,
.app-shell .compact-text-mode .livret-followup {
  min-height: 0;
  overflow: auto;
}
.app-shell .compact-text-mode .projection-result {
  display: block;
  padding: 12px;
}
.app-shell .compact-text-mode .projection-result > span {
  padding: 5px 7px;
  font-size: 10px;
}
.app-shell .compact-text-mode .projection-result h3,
.app-shell .compact-text-mode .projection-hero-date strong {
  margin: 8px 0 6px;
  font-size: 20px;
}
.app-shell .compact-text-mode .projection-hero-date {
  padding: 10px;
}
.app-shell .compact-text-mode .projection-countdown,
.app-shell .compact-text-mode .projection-day-scene {
  gap: 6px;
}
.app-shell .compact-text-mode .projection-day-scene article,
.app-shell .compact-text-mode .projection-countdown article,
.app-shell .compact-text-mode .projection-center-focus {
  padding: 8px;
}
.app-shell .compact-text-mode .projection-day-video-card {
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 8px;
  padding: 8px;
}
.app-shell .compact-text-mode .projection-video-trigger {
  min-height: 86px;
  aspect-ratio: 16 / 9;
}
.app-shell .compact-text-mode .projection-day-video-card strong {
  margin-top: 6px;
  font-size: 15px;
}
.app-shell .compact-text-mode .projection-day-video-card p {
  display: none;
}
.app-shell .compact-text-mode .projection-center-focus p,
.app-shell .compact-text-mode .projection-center-focus,
.app-shell .compact-text-mode .projection-meta,
.app-shell .compact-text-mode .projection-result ul {
  display: none;
}
.app-shell .compact-text-mode .projection-actions {
  gap: 6px;
}
.app-shell .compact-text-mode .projection-actions .btn {
  min-height: 34px;
  padding: 7px 9px;
  font-size: 12px;
}
.app-shell .compact-text-mode .projection-zone-head {
  grid-template-columns: minmax(0, 1fr);
}
.app-shell .compact-text-mode .projection-date-grid {
  max-height: 250px;
  grid-template-columns: 1fr;
  gap: 8px;
  overflow: auto;
}
.app-shell .compact-text-mode .projection-date-card {
  min-height: 104px;
  padding: 10px;
  gap: 5px;
  overflow: hidden;
}
.app-shell .compact-text-mode .projection-date-card strong {
  font-size: 21px;
  line-height: 1;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .projection-date-card span {
  padding: 4px 6px;
  font-size: 10px;
  line-height: 1;
  letter-spacing: 0;
  white-space: normal;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .projection-date-card em {
  display: none;
}
.app-shell .compact-text-mode .projection-date-card.active::after {
  display: none;
}
.app-shell .compact-text-mode .projection-selected-action {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 10px;
  align-items: center;
  overflow: visible;
}
.app-shell .compact-text-mode .projection-selected-action p {
  display: none;
}
.app-shell .compact-text-mode .projection-selected-action > div:first-child {
  min-width: 0;
}
.app-shell .compact-text-mode .projection-selected-action span {
  margin-bottom: 5px;
  padding: 4px 6px;
  font-size: 9px;
}
.app-shell .compact-text-mode .projection-selected-action strong {
  font-size: 14px;
  line-height: 1.12;
  display: block;
  overflow: visible;
}
.app-shell .compact-text-mode .projection-selected-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  width: 100%;
  min-width: 0;
}
.app-shell .compact-text-mode .projection-selected-actions .btn {
  min-height: 31px;
  padding: 6px 8px;
  font-size: 11px;
  line-height: 1.1;
  white-space: normal;
  width: auto;
  max-height: 42px;
  overflow: hidden;
  justify-content: center;
}
.app-shell .compact-text-mode .projection-countdown,
.app-shell .compact-text-mode .projection-day-scene {
  grid-template-columns: 1fr;
}
.app-shell .compact-text-mode .projection-hero-date span {
  font-size: 10px;
  line-height: 1;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .projection-day-scene strong,
.app-shell .compact-text-mode .projection-countdown span,
.app-shell .compact-text-mode .projection-after-payment strong,
.app-shell .compact-text-mode .projection-buying-strip strong {
  font-size: 16px;
  line-height: 1.08;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .evaluation-layout {
  height: 100%;
  min-height: 0;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .82fr);
  gap: 10px;
  overflow: hidden;
}
.app-shell .compact-text-mode .evaluation-copy {
  display: none;
}
.app-shell .compact-text-mode .evaluation-form,
.app-shell .compact-text-mode .evaluation-result {
  min-height: 0;
  padding: 12px;
  overflow: auto;
}
.app-shell .compact-text-mode :where(.lead-form, .partner-form, .evaluation-form, .form-optional-grid, .enrollment-panel, .contract-modal-fields, .portal-access-fields) {
  grid-template-columns: 1fr;
  align-content: start;
}
.app-shell .compact-text-mode :where(.lead-form label, .partner-form label, .evaluation-form label, .enrollment-panel label, .contract-modal-fields label, .portal-access-fields label) {
  min-width: 0;
}
.app-shell .compact-text-mode :where(.lead-form input, .lead-form select, .lead-form textarea, .partner-form input, .partner-form select, .partner-form textarea, .evaluation-form input, .evaluation-form select, .enrollment-panel input, .enrollment-panel select, .contract-modal-fields input, .contract-modal-fields select, .portal-access-fields input) {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
.app-shell .compact-text-mode :where(strong, p, span, small, li, h2, h3, select) {
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .training-emotion-board,
.app-shell .compact-text-mode .schedule-layout,
.app-shell .compact-text-mode .enrollment-action {
  height: auto;
  min-height: 0;
  grid-template-columns: minmax(0, 1fr) minmax(300px, .88fr);
  gap: 12px;
}
.app-shell .compact-text-mode .training-emotion-scene,
.app-shell .compact-text-mode .training-emotion-stats,
.app-shell .compact-text-mode .training-emotion-road,
.app-shell .compact-text-mode .schedule-road,
.app-shell .compact-text-mode .contract-preview-wrap,
.app-shell .compact-text-mode .motivation-gallery,
.app-shell .compact-text-mode .visual-band,
.app-shell .compact-text-mode .source-band,
.app-shell .compact-text-mode .faq-section {
  display: none;
}
.app-shell .compact-text-mode .training-emotion-pass,
.app-shell .compact-text-mode .schedule-main-card,
.app-shell .compact-text-mode .schedule-side-card,
.app-shell .compact-text-mode .enrollment-result,
.app-shell .compact-text-mode .enrollment-panel {
  min-height: 0;
  padding: 12px;
  overflow: auto;
}
.app-shell .compact-text-mode .enrollment-panel {
  grid-template-columns: 1fr;
  align-content: start;
}
.app-shell .compact-text-mode .payment-direct-head {
  grid-template-columns: 1fr;
  gap: 8px;
}
.app-shell .compact-text-mode .contract-extra-fields {
  display: none;
}
.app-shell .compact-text-mode .enrollment-boost {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
}
.app-shell .compact-text-mode .payment-direct-head {
  margin-bottom: 8px;
}
.app-shell .compact-text-mode .payment-direct-head h2 {
  font-size: clamp(23px, 2.4vw, 32px);
}
.app-shell .compact-text-mode .payment-direct-head p:last-child,
.app-shell .compact-text-mode .payment-direct-strip {
  display: none;
}
.app-shell .compact-text-mode .enrollment-boost .eyebrow {
  margin-bottom: 4px;
}
.app-shell .compact-text-mode .enrollment-action {
  height: auto;
  min-height: 0;
  margin-top: 0;
  align-self: stretch;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .82fr);
  gap: 10px;
  overflow: hidden;
}
.app-shell .compact-text-mode .schedule-data-grid {
  grid-template-columns: repeat(2, minmax(120px, 1fr));
}
.app-shell .compact-text-mode .schedule-data-grid strong {
  font-size: 16px;
  line-height: 1.08;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode :where(.payoff-grid strong, .desire-grid strong, .selection-service-grid strong, .selection-rate-grid strong, .partner-tier-grid strong, .awards-grid strong, .awards-ranking strong, .portal-module-grid strong, .livret-track-grid strong, .evaluation-result strong) {
  font-size: clamp(16px, 1.55vw, 22px);
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode :where(.training-pass-top strong, .schedule-main-top strong, .schedule-side-card strong, .monitor-scorecard strong, .monitor-profile-hero strong, .monitor-space strong, .recruitment-split strong, .partner-hero-card strong) {
  max-width: none;
  font-size: clamp(18px, 1.9vw, 28px);
  line-height: 1.05;
  text-align: left;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode :where(.payoff-grid p, .desire-grid p, .selection-service-grid p, .selection-rate-grid p, .partner-tier-grid p, .awards-grid p, .awards-ranking p, .partner-tier-note, .selection-camaraderie p, .portal-module-grid p, .livret-track-grid p) {
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .enrollment-panel {
  min-height: 0;
  padding: 10px;
  gap: 8px;
  overflow: auto;
}
.app-shell .compact-text-mode .enrollment-panel label {
  gap: 4px;
  font-size: 11px;
}
.app-shell .compact-text-mode .enrollment-panel select,
.app-shell .compact-text-mode .enrollment-panel input {
  min-height: 34px;
  padding: 6px 8px;
  border-radius: 7px;
  font-size: 12px;
}
.app-shell .compact-text-mode .contract-consent {
  padding: 8px;
}
.app-shell .compact-text-mode .contract-consent input {
  width: 16px;
  height: 16px;
}
.app-shell .compact-text-mode .enrollment-result {
  display: grid;
  grid-template-rows: auto auto auto minmax(0, auto) auto auto;
  min-height: 0;
  padding: 12px;
  overflow: hidden;
  border: 1px solid #d6e4e2;
  background: #fff;
  color: var(--ink);
  box-shadow: none;
}
.app-shell .compact-text-mode .enrollment-result > span {
  padding: 5px 7px;
  font-size: 10px;
}
.app-shell .compact-text-mode .enrollment-result h3 {
  margin: 8px 0 5px;
  font-size: clamp(20px, 2.1vw, 27px);
}
.app-shell .compact-text-mode .enrollment-result p {
  font-size: 12px;
  line-height: 1.25;
}
.app-shell .compact-text-mode .enrollment-result ul {
  max-height: 74px;
  margin: 8px 0 10px;
  gap: 5px;
  overflow: auto;
}
.app-shell .compact-text-mode .enrollment-result li {
  padding-left: 14px;
  font-size: 12px;
  line-height: 1.25;
}
.app-shell .compact-text-mode .enrollment-result li::before {
  top: 7px;
  width: 6px;
  height: 6px;
}
.app-shell .compact-text-mode .payment-method-row {
  gap: 6px;
  margin-bottom: 8px;
}
.app-shell .compact-text-mode .payment-method-row button {
  min-height: 31px;
  padding: 6px 8px;
  font-size: 11px;
}
.app-shell .compact-text-mode .enrollment-result a,
.app-shell .compact-text-mode .enrollment-result .post-payment-trigger {
  width: 100%;
  justify-content: center;
}
.app-shell .compact-text-mode .enrollment-result .post-payment-trigger {
  margin-top: 6px;
}
.app-shell .compact-text-mode .payment-note {
  display: none;
}
.app-shell .compact-details-body:not(.has-active-panel) > section:first-of-type {
  display: block !important;
  pointer-events: auto;
}
.app-shell .compact-details-body:not(.has-active-panel) > section:not(:first-of-type),
.app-shell .compact-details-body.has-active-panel > section:not(.is-app-active) {
  display: none !important;
  pointer-events: none;
}
.app-shell .compact-details-body.has-active-panel > section.is-app-active {
  display: block !important;
  pointer-events: auto;
}
.app-shell .compact-details-body.has-active-panel > section.is-app-active.exam-projection {
  display: grid !important;
}
.app-shell .compact-details-body > section.partner-momentum,
.app-shell .compact-details-body > section.customer-momentum,
.app-shell .compact-details-body > section.recruitment-payoff,
.app-shell .compact-details-body > section.monitor-ops {
  background: #101820;
  color: #fff;
  border-color: rgba(255,255,255,.16);
}
.app-shell .compact-details-body > section.customer-momentum,
.app-shell .compact-details-body > section.recruitment-payoff {
  background: #151b20;
}
.app-shell .compact-text-mode .partner-momentum {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(260px, .78fr);
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
  overflow: auto;
}
.app-shell .compact-text-mode .partner-momentum-copy h2,
.app-shell .compact-text-mode .momentum-copy h2 {
  margin-bottom: 8px;
  color: #fff;
  font-size: clamp(24px, 2.5vw, 34px);
}
.app-shell .compact-text-mode .partner-momentum-copy p,
.app-shell .compact-text-mode .momentum-copy p,
.app-shell .compact-text-mode .recruitment-payoff .section-head p,
.app-shell .compact-text-mode .monitor-ops .section-head p {
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.35;
}
.app-shell .compact-text-mode .partner-momentum-actions,
.app-shell .compact-text-mode .momentum-actions {
  margin-top: 10px;
}
.app-shell .compact-text-mode .partner-momentum-grid,
.app-shell .compact-text-mode .momentum-path {
  grid-column: 1 / -1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.app-shell .compact-text-mode .partner-momentum-grid article,
.app-shell .compact-text-mode .momentum-step,
.app-shell .compact-text-mode .payoff-grid article,
.app-shell .compact-text-mode .ops-card,
.app-shell .compact-text-mode .quick-reply-kit {
  min-height: 0;
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.07);
  color: #fff;
}
.app-shell .compact-text-mode .partner-momentum-grid article,
.app-shell .compact-text-mode .momentum-step {
  padding: 12px;
}
.app-shell .compact-text-mode .partner-momentum-grid strong,
.app-shell .compact-text-mode .momentum-step strong {
  margin: 10px 0 6px;
  color: #fff;
  font-size: 18px;
}
.app-shell .compact-text-mode .partner-momentum-grid p,
.app-shell .compact-text-mode .momentum-step p,
.app-shell .compact-text-mode .payoff-grid p,
.app-shell .compact-text-mode .ops-card p,
.app-shell .compact-text-mode .ops-card li,
.app-shell .compact-text-mode .quick-reply-card p {
  color: rgba(255,255,255,.78);
}
.app-shell .compact-text-mode .partner-momentum .emotion-selected-action,
.app-shell .compact-text-mode .partner-momentum .emotion-selected-action :where(strong, p, li, small) {
  color: var(--ink);
}
.app-shell .compact-text-mode .partner-momentum > .emotion-selected-action {
  grid-template-columns: 1fr;
  align-items: stretch;
}
.app-shell .compact-text-mode .partner-momentum .emotion-selected-meta {
  width: 100%;
}
.app-shell .compact-text-mode .partner-momentum [data-emotion-badge],
.app-shell .compact-text-mode .partner-momentum [data-emotion-title],
.app-shell .compact-text-mode .partner-momentum [data-emotion-meta] {
  max-width: 100%;
  overflow-wrap: normal;
  word-break: normal;
}
.app-shell .compact-text-mode .partner-momentum .emotion-selected-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.app-shell .compact-text-mode .partner-momentum .emotion-selected-action p,
.app-shell .compact-text-mode .partner-momentum .emotion-selected-action li {
  color: var(--muted);
}
.app-shell .compact-text-mode .partner-momentum .emotion-selected-action .btn.outline {
  color: var(--ink);
  border-color: #d8e3e1;
  background: #fff;
}
.app-shell .compact-text-mode .recruitment-payoff,
.app-shell .compact-text-mode .monitor-selection,
.app-shell .compact-text-mode .apporteur-management,
.app-shell .compact-text-mode .awards-panel,
.app-shell .compact-text-mode .monitor-ops {
  overflow: auto;
}
.app-shell .compact-text-mode .recruitment-payoff .section-head h2,
.app-shell .compact-text-mode .monitor-ops .section-head h2 {
  color: #fff;
}
.app-shell .compact-text-mode .payoff-grid,
.app-shell .compact-text-mode .selection-service-grid,
.app-shell .compact-text-mode .selection-rate-grid,
.app-shell .compact-text-mode .partner-tier-grid,
.app-shell .compact-text-mode .awards-grid,
.app-shell .compact-text-mode .awards-ranking ul,
.app-shell .compact-text-mode .mobility-grid,
.app-shell .compact-text-mode .partner-monetization-grid,
.app-shell .compact-text-mode .notification-grid,
.app-shell .compact-text-mode .ops-layout,
.app-shell .compact-text-mode .quick-reply-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.app-shell .compact-text-mode .payoff-grid article,
.app-shell .compact-text-mode .selection-service-grid article,
.app-shell .compact-text-mode .selection-rate-grid article,
.app-shell .compact-text-mode .partner-tier-grid article,
.app-shell .compact-text-mode .awards-grid article,
.app-shell .compact-text-mode .mobility-grid article,
.app-shell .compact-text-mode .partner-monetization-grid article,
.app-shell .compact-text-mode .notification-grid article,
.app-shell .compact-text-mode .ops-card,
.app-shell .compact-text-mode .quick-reply-card {
  padding: 12px;
}
.app-shell .compact-text-mode .payoff-grid span,
.app-shell .compact-text-mode .ops-card span {
  color: #ffcb58;
}
.app-shell .compact-text-mode .finance-panel,
.app-shell .compact-text-mode .recruitment-split article {
  background: #fff;
  color: var(--ink);
}
.app-shell .compact-text-mode .finance-panel p,
.app-shell .compact-text-mode .recruitment-split li {
  color: var(--muted);
}
.app-shell .essential-workflow {
  grid-column: 3;
  grid-row: 2;
  height: 100%;
  min-height: 0;
  padding: 14px !important;
  border: 1px solid #d8e3e1;
  border-radius: 10px;
  background: #fff;
  overflow: auto;
}
.app-shell .essential-head {
  display: block;
  margin-bottom: 10px;
}
.app-shell .essential-head h2 {
  font-size: clamp(22px, 2.2vw, 30px);
  line-height: 1.05;
}
.app-shell .essential-head p {
  display: block;
  margin-top: 6px;
  font-size: 12px;
}
.app-shell .essential-grid {
  height: auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.app-shell .essential-card:not(:first-child) {
  display: block;
}
.app-shell .essential-card {
  min-height: 0;
  padding: 12px;
}
.app-shell .essential-card h3 {
  margin: 8px 0 5px;
  font-size: 20px;
}
.app-shell .essential-card p,
.app-shell .essential-card li {
  font-size: 12px;
}
.app-shell .site-footer,
.app-shell .action-assistant {
  display: none;
}
.app-shell.portal-page:not(:has(.client-essential)) main {
  grid-template-rows: minmax(0, 1fr);
}
.app-shell.portal-page:not(:has(.client-essential)) .page-hero {
  grid-column: 1;
  grid-row: 1;
}
.app-shell.portal-page:not(:has(.client-essential)) main > .portal-overview,
.app-shell.portal-page:not(:has(.client-essential)) main > .simple-access {
  grid-column: 2;
  grid-row: 1;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  padding: 14px !important;
  border: 1px solid #d8e3e1;
  border-radius: 10px;
  background: #fff;
}
.app-shell.portal-page:not(:has(.client-essential)) main > .portal-overview {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(250px, .82fr);
  gap: 10px;
}
.app-shell.portal-page:not(:has(.client-essential)) main > .simple-access {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-head {
  margin-bottom: 10px;
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-head h2 {
  margin: 2px 0 4px;
  font-size: clamp(24px, 3.2vw, 42px);
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-head p {
  max-width: 460px;
  font-size: 13px;
  line-height: 1.25;
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-grid {
  align-content: start;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  overflow: visible;
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-card {
  width: auto;
  min-width: 0;
  min-height: 118px;
  padding: 14px;
  overflow: hidden;
  justify-content: space-between;
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-card span {
  font-size: 11px;
  letter-spacing: .04em;
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-card strong {
  margin: 8px 0;
  font-size: clamp(20px, 2.2vw, 30px);
  line-height: 1.02;
}
.app-shell.portal-page:not(:has(.client-essential)) .simple-access-card small {
  font-size: 14px;
  line-height: 1.15;
}
.app-shell.portal-page:not(:has(.client-essential)) .compact-details {
  grid-column: 3;
  grid-row: 1;
  height: 100%;
  min-height: 0;
}
.app-shell.portal-page:not(:has(.client-essential)) .compact-details-body > section {
  padding: 12px;
}
.app-shell.portal-page:not(:has(.client-essential)) .portal-switcher,
.app-shell.portal-page:not(:has(.client-essential)) .access-help,
.app-shell.portal-page:not(:has(.client-essential)) .pilot-command,
.app-shell.portal-page:not(:has(.client-essential)) .livret-followup,
.app-shell.portal-page:not(:has(.client-essential)) .portal-modules,
.app-shell.portal-page:not(:has(.client-essential)) .portal-next {
  height: 100%;
  min-height: 0;
  overflow: auto;
}
.app-shell.portal-page:not(:has(.client-essential)) .portal-switcher,
.app-shell.portal-page:not(:has(.client-essential)) .access-help {
  grid-template-columns: 1fr;
  gap: 10px;
}
.app-shell.portal-page:not(:has(.client-essential)) .portal-switch-grid,
.app-shell.portal-page:not(:has(.client-essential)) .access-help-grid {
  grid-template-columns: 1fr;
}
.app-shell.portal-page .client-essential {
  display: block;
}
.app-shell .compact-text-mode .client-space-app,
.app-shell .compact-text-mode .client-training-film,
.app-shell .compact-text-mode .client-quick-modules {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}
.app-shell .compact-text-mode .client-space-app {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.app-shell .compact-details-body > section.client-space-app:first-of-type,
.app-shell .compact-details-body.has-active-panel > section.client-space-app.is-app-active {
  display: grid;
}
.app-shell .compact-text-mode .client-space-head,
.app-shell .compact-text-mode .client-film-copy {
  margin-bottom: 10px;
}
.app-shell .compact-text-mode .client-space-head h2,
.app-shell .compact-text-mode .client-film-copy h2 {
  font-size: clamp(22px, 2.6vw, 34px);
}
.app-shell .compact-text-mode .client-space-head p,
.app-shell .compact-text-mode .client-film-copy p {
  font-size: 13px;
  line-height: 1.35;
}
.app-shell .compact-text-mode .client-space-layout {
  min-height: 0;
  height: auto;
  grid-template-columns: minmax(0, 1fr) minmax(260px, .72fr);
  gap: 10px;
  overflow: hidden;
}
.app-shell .compact-text-mode .client-journey-card,
.app-shell .compact-text-mode .client-login-card {
  min-height: 0;
  padding: 12px;
  overflow: auto;
}
.app-shell .compact-text-mode .client-journey-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}
.app-shell .compact-text-mode .client-journey-top strong {
  font-size: clamp(22px, 2.4vw, 31px);
}
.app-shell .compact-text-mode .client-journey-top p {
  font-size: 13px;
}
.app-shell .compact-text-mode .client-status-grid {
  min-height: 0;
  overflow: auto;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}
.app-shell .compact-text-mode .client-status-grid article {
  min-height: 92px;
  padding: 10px;
}
.app-shell .compact-text-mode .client-status-grid strong {
  font-size: 18px;
}
.app-shell .compact-text-mode .client-action-row {
  gap: 6px;
}
.app-shell .compact-text-mode .client-login-card h3 {
  font-size: clamp(21px, 2.2vw, 28px);
}
.app-shell .compact-text-mode .client-login-form {
  gap: 7px;
  margin: 10px 0 8px;
}
.app-shell .compact-text-mode .client-login-actions {
  gap: 6px;
}
.app-shell .compact-text-mode .client-login-form input {
  min-height: 34px;
  padding: 7px 8px;
}
.app-shell .compact-text-mode .client-training-film,
.app-shell .compact-text-mode .client-quick-modules {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.app-shell .compact-text-mode .client-film-steps,
.app-shell .compact-text-mode .client-module-grid {
  min-height: 0;
  overflow: auto;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.app-shell .compact-text-mode .client-film-steps article,
.app-shell .compact-text-mode .client-module-grid article {
  min-height: 0;
  padding: 12px;
}

@media (max-width: 980px) {
  .app-shell .site-header {
    height: 54px;
    min-height: 54px;
    padding: 7px 10px;
  }
  .app-shell .brand small,
  .app-shell .header-call,
  .app-shell .site-nav {
    display: none;
  }
  .app-shell .site-nav.open {
    position: absolute;
    left: 10px;
    right: 10px;
    top: 58px;
    z-index: 120;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: #fff;
    box-shadow: var(--shadow);
  }
  .app-shell main {
    height: calc(100dvh - 54px - 47px);
    grid-template-columns: 1fr !important;
    grid-template-rows: auto minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
  }
  .app-shell .hero,
  .app-shell .page-hero,
  .app-shell .essential-workflow {
    display: none;
  }
  .app-shell.portal-page .client-essential {
    display: none;
  }
  .app-shell.portal-page:not(:has(.client-essential)) main {
    grid-template-rows: minmax(0, 1fr);
  }
  .app-shell.portal-page:not(:has(.client-essential)) main > .portal-overview,
  .app-shell.portal-page:not(:has(.client-essential)) main > .simple-access {
    grid-column: 1;
    grid-row: 1;
  }
  .app-shell.portal-page:not(:has(.client-essential)) .compact-details {
    display: none;
  }
  .app-shell.portal-page:not(:has(.client-essential)) .portal-entry-actions,
  .app-shell.portal-page:not(:has(.client-essential)) .mobile-cta a[href^="#"] {
    display: none;
  }
  .app-shell .fast-conversion-bar {
    grid-column: 1;
    grid-row: 1;
    grid-template-columns: 1fr;
    padding: 7px !important;
  }
  .app-shell .fast-conversion-bar > div {
    display: none;
  }
  .app-shell .fast-conversion-bar nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .app-shell .fast-action-link {
    min-width: 0;
    padding: 7px 5px;
    font-size: 11px;
    white-space: normal;
  }
  .app-shell .compact-details {
    grid-column: 1;
    grid-row: 2;
  }
  .app-shell .compact-details-body > section {
    padding: 10px;
  }
  .app-shell .compact-text-mode .section-head h2,
  .app-shell .compact-text-mode .projection-head h2,
  .app-shell .compact-text-mode h2 {
    font-size: clamp(22px, 7vw, 34px);
  }
  .app-shell .compact-text-mode .projection-head p {
    display: none;
  }
  .app-shell .compact-text-mode .projection-stage,
  .app-shell .compact-text-mode .training-emotion-board,
  .app-shell .compact-text-mode .schedule-layout,
  .app-shell .compact-text-mode .monitor-handoff,
  .app-shell .compact-text-mode .enrollment-action,
  .app-shell .compact-text-mode .enrollment-panel {
    grid-template-columns: 1fr;
  }
  .app-shell .compact-text-mode .enrollment-action {
    overflow: auto;
    padding-bottom: 8px;
  }
  .app-shell .compact-text-mode .enrollment-result {
    order: -1;
  }
  .app-shell .compact-text-mode .enrollment-panel {
    order: 2;
  }
  .app-shell .compact-text-mode .projection-stage {
    height: 100%;
    grid-template-rows: minmax(0, 1fr);
  }
  .app-shell .compact-text-mode .projection-result {
    display: none;
  }
  .app-shell .compact-text-mode .projection-date-zone {
    height: 100%;
    display: grid;
    grid-template-rows: auto auto auto auto auto;
    gap: 8px;
    overflow: auto;
  }
  .app-shell .compact-text-mode .projection-date-video-card {
    display: grid;
    grid-template-columns: 120px minmax(0, 1fr);
    height: auto;
    min-height: 102px;
    margin-top: 0;
    background: #151b20;
    overflow: hidden;
  }
  .app-shell .compact-text-mode .projection-date-video-card .projection-video-trigger {
    min-height: 84px;
    aspect-ratio: 16 / 9;
  }
  .app-shell .compact-text-mode .projection-date-video-card .projection-video-trigger::after {
    width: 38px;
    height: 38px;
  }
  .app-shell .compact-text-mode .projection-date-video-card .projection-video-trigger span {
    border-top-width: 8px;
    border-bottom-width: 8px;
    border-left-width: 13px;
  }
  .app-shell .compact-text-mode .projection-zone-head {
    gap: 4px;
  }
  .app-shell .compact-text-mode .projection-zone-head small {
    display: none;
  }
  .app-shell .compact-text-mode .projection-zone-head strong {
    font-size: 17px;
  }
  .app-shell .compact-text-mode .projection-date-grid {
    height: auto;
    min-height: 0;
    max-height: 230px;
    grid-template-columns: 1fr;
    overflow: auto;
  }
  .app-shell .compact-text-mode .projection-date-card {
    min-height: 94px;
    gap: 5px;
    overflow: hidden;
  }
  .app-shell .compact-text-mode .projection-date-card em {
    display: none;
  }
  .app-shell .compact-text-mode .projection-date-card.active::after {
    display: none;
  }
  .app-shell .compact-text-mode .projection-date-card strong {
    font-size: 20px;
    line-height: 1;
  }
  .app-shell .compact-text-mode .projection-date-card small {
    line-height: 1.12;
  }
  .app-shell .compact-text-mode .projection-selected-action {
    grid-template-columns: minmax(0, 1fr);
    gap: 6px;
    padding: 8px;
    overflow: visible;
  }
  .app-shell .compact-text-mode .projection-selected-action span {
    display: none;
  }
  .app-shell .compact-text-mode .projection-selected-action strong {
    font-size: 13px;
    -webkit-line-clamp: 2;
  }
  .app-shell .compact-text-mode .projection-selected-actions {
    width: 100%;
    min-width: 0;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .app-shell .compact-text-mode .projection-selected-actions .btn {
    min-height: 30px;
    padding: 6px;
    font-size: 11px;
  }
  .app-shell .compact-text-mode .evaluation-layout {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr);
    overflow: hidden;
  }
  .app-shell .compact-text-mode .evaluation-form {
    width: 100%;
    min-width: 0;
  }
  .app-shell .compact-text-mode .evaluation-result {
    display: none;
  }
  .app-shell .compact-text-mode .client-space-layout,
  .app-shell .compact-text-mode .client-status-grid,
  .app-shell .compact-text-mode .client-film-steps,
  .app-shell .compact-text-mode .client-module-grid {
    grid-template-columns: 1fr;
  }
  .app-shell .compact-text-mode .client-space-layout {
    overflow: auto;
  }
  .app-shell .compact-text-mode :where(.lead-form, .partner-form, .evaluation-form, .form-optional-grid, .enrollment-panel, .contract-modal-fields, .portal-access-fields) {
    grid-template-columns: 1fr !important;
    grid-auto-flow: row;
    align-content: start;
  }
  .app-shell .compact-text-mode :where(.lead-form, .partner-form) {
    gap: 8px;
  }
  .app-shell .compact-text-mode :where(.lead-form label, .partner-form label, .evaluation-form label) {
    min-width: 0;
  }
  .app-shell .compact-text-mode :where(.lead-form input, .lead-form select, .lead-form textarea, .partner-form input, .partner-form select, .partner-form textarea) {
    min-height: 40px;
    max-width: 100%;
  }
  .app-shell .compact-text-mode .form-actions {
    grid-template-columns: 1fr;
    width: 100%;
  }
  .app-shell .compact-text-mode .form-actions .btn {
    width: 100%;
  }
  .app-shell .compact-text-mode .conditions-before-action {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 10px;
  }
  .app-shell .compact-text-mode .conditions-before-action .btn {
    width: 100%;
  }
  .app-shell .compact-text-mode .enrollment-boost {
    grid-template-rows: minmax(0, 1fr);
  }
  .app-shell .compact-text-mode .enrollment-action {
    height: 100%;
    grid-template-columns: 1fr;
    align-content: start;
    overflow: auto;
  }
  .app-shell .compact-text-mode .enrollment-panel {
    display: none;
  }
  .app-shell .compact-text-mode .enrollment-result {
    order: 0;
    max-height: none;
    overflow: auto;
  }
  .app-shell .compact-text-mode .enrollment-result ul {
    max-height: none;
  }
  .app-shell .compact-text-mode .partner-momentum,
  .app-shell .compact-text-mode .customer-momentum {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto minmax(0, 1fr);
    overflow: auto;
  }
  .app-shell .compact-text-mode .partner-momentum > .emotion-selected-action {
    width: 100%;
  }
  .app-shell .compact-text-mode .partner-momentum-grid,
  .app-shell .compact-text-mode .momentum-path,
  .app-shell .compact-text-mode .payoff-grid,
  .app-shell .compact-text-mode .selection-service-grid,
  .app-shell .compact-text-mode .selection-rate-grid,
  .app-shell .compact-text-mode .partner-tier-grid,
  .app-shell .compact-text-mode .awards-grid,
  .app-shell .compact-text-mode .awards-ranking ul,
  .app-shell .compact-text-mode .notification-grid,
  .app-shell .compact-text-mode .ops-layout,
  .app-shell .compact-text-mode .quick-reply-grid {
    grid-template-columns: 1fr;
  }
}

/* ESR app-video direction: clean white screens, clear steps, red action. */
:root {
  --ink: #111418;
  --muted: #5d6670;
  --line: #dfe4e8;
  --paper: #ffffff;
  --soft: #f7f7f6;
  --cream: #f4eee7;
  --red: #ee1d12;
  --red-dark: #a41322;
  --teal: #0f6d70;
  --gold: #f0a400;
  --shadow: 0 18px 46px rgba(18, 24, 32, .10);
}
body {
  background: #f4eee7;
}
.brand-mark {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  width: 66px;
  min-width: 66px;
  background: transparent;
  color: var(--ink);
  border-radius: 0;
  font-size: 28px;
  letter-spacing: -0.03em;
}
.brand-mark::after {
  content: "";
  position: absolute;
  right: 2px;
  top: 8px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
}
.btn.primary,
.fast-action-link.primary,
.source-actions a.primary,
.source-actions a.pay,
.mobile-cta a:first-child {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}
.btn.primary:hover,
.fast-action-link.primary:hover {
  background: #d8170e;
}
.btn.outline,
.btn.ghost,
.fast-action-link.outline,
.fast-action-link.ghost {
  border-color: var(--line);
  background: #fff;
  color: var(--ink);
}
.app-demo-card {
  display: grid;
  gap: 9px;
  margin-top: 14px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(18, 24, 32, .08);
}
.app-demo-card video {
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid #eceff1;
  border-radius: 9px;
  background: #111;
  object-fit: cover;
}
.app-demo-card span {
  display: inline-block;
  color: var(--red);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.app-demo-card strong {
  display: block;
  margin-top: 2px;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.12;
}
.app-demo-card.compact {
  margin-top: 12px;
  box-shadow: none;
}
.site-header,
.app-shell .site-header {
  background: rgba(255,255,255,.97);
  border-bottom-color: #e2e4e7;
}
.app-shell main {
  background:
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(255,255,255,0) 42%),
    #f4eee7;
}
.app-shell .hero,
.app-shell .page-hero,
.app-shell .fast-conversion-bar,
.app-shell .compact-details-body > section,
.app-shell .essential-workflow,
.app-shell.portal-page:not(:has(.client-essential)) main > .portal-overview,
.app-shell.portal-page:not(:has(.client-essential)) main > .simple-access {
  border-color: #e0e4e7;
  border-radius: 16px;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 18px 46px rgba(18, 24, 32, .08);
}
.app-shell .compact-details-body > section.is-app-active,
.app-shell .compact-details-body.has-active-panel > section.is-app-active {
  border-color: #e0e4e7 !important;
  box-shadow: 0 18px 46px rgba(18, 24, 32, .08);
}
.app-shell .compact-details-body > section:focus {
  outline: none;
}
.app-shell .compact-details-body > section:focus-visible {
  outline: 2px solid rgba(238, 29, 18, .28);
  outline-offset: -2px;
}
.app-shell .hero,
.app-shell .page-hero {
  padding: 16px;
  overflow-x: hidden;
}
.app-shell .quick-panel,
.app-shell .app-demo-card,
.app-shell .hero-actions,
.app-shell .quick-panel .btn,
.app-shell .quick-whatsapp {
  min-width: 0;
  max-width: 100%;
}
.app-shell .quick-panel .btn,
.app-shell .quick-whatsapp {
  width: 100%;
  white-space: normal;
  overflow-wrap: anywhere;
}
.app-shell .hero h1,
.app-shell .page-hero h1,
.app-shell h1 {
  letter-spacing: 0;
}
.app-shell .hero .eyebrow,
.app-shell .page-hero .eyebrow,
.app-shell .compact-text-mode .eyebrow,
.projection-head .eyebrow,
.section-head .eyebrow {
  color: var(--red);
}
.app-shell .fast-conversion-bar {
  grid-template-columns: minmax(180px, .34fr) minmax(0, 1fr);
}
.app-shell .fast-conversion-bar strong {
  color: var(--ink);
}
.app-shell .fast-conversion-bar nav {
  gap: 10px;
}
.app-shell .fast-action-link {
  min-height: 42px;
  border-radius: 10px;
  background: #fff;
  box-shadow: inset 0 0 0 1px #edf0f2;
}
.app-shell .fast-action-link.active:not(.primary) {
  border-color: var(--red);
  background: #fff;
  color: var(--red-dark);
  box-shadow: inset 0 0 0 2px rgba(238, 29, 18, .22);
}
.app-shell.page-recrutement-moniteurs .compact-details,
.app-shell.page-apporteurs-affaires .compact-details,
.app-shell.page-apporteurs-affaires-recrutement-moniteurs .compact-details {
  grid-column: 2 / 4;
}
.app-shell.page-recrutement-moniteurs .compact-details-body > section,
.app-shell.page-apporteurs-affaires .compact-details-body > section,
.app-shell.page-apporteurs-affaires-recrutement-moniteurs .compact-details-body > section {
  padding-left: clamp(18px, 3vw, 34px);
  padding-right: clamp(18px, 3vw, 34px);
}
.app-shell .compact-details-body > section::before {
  content: "Etape ESR";
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  margin-bottom: 8px;
  padding: 4px 9px;
  border-radius: 999px;
  background: #fff3f2;
  color: var(--red);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.app-shell .compact-details-body > section.case-router::before,
.app-shell .compact-details-body > section.tariff-chooser::before {
  content: "Etape 1 sur 3";
}
.app-shell .compact-details-body > section.exam-projection::before {
  content: "Etape 2 sur 3";
}
.app-shell .compact-details-body > section.enrollment-boost::before {
  content: "Etape 3 sur 3";
}
.app-shell .compact-text-mode .projection-head h2,
.app-shell .compact-text-mode .section-head h2 {
  max-width: 760px;
}
.app-shell .compact-text-mode .exam-projection {
  grid-template-rows: auto auto minmax(0, 1fr) !important;
  gap: 8px;
}
.app-shell .compact-text-mode .projection-head {
  min-height: 0;
  margin-bottom: 0;
}
.app-shell .compact-text-mode .projection-head h2 {
  max-width: 620px;
  font-size: clamp(22px, 2.1vw, 30px);
  line-height: 1.02;
}
.app-shell .compact-text-mode .compact-details-body > section :where(h1, h2, h3),
.app-shell .compact-text-mode .essential-workflow :where(h2, h3),
.app-shell .compact-text-mode .client-space-app :where(h2, h3) {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.03;
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .compact-details-body > section :where(.projection-date-card h3, .case-card h3, .enrollment-result h3) {
  display: block;
}
.app-shell .compact-text-mode .compact-details-body > section :where(p, li, small) {
  overflow-wrap: anywhere;
}
.app-shell .compact-text-mode .projection-head p {
  display: none;
}
.app-shell .compact-text-mode .projection-stage {
  min-height: 0;
  height: 100%;
}
.projection-date-card,
.case-card,
.tariff-situation,
.tariff-offer-card,
.projection-offer-chip,
.essential-date-pill,
.simple-access-card,
.portal-switch-card,
.client-status-grid article,
.client-film-steps article,
.client-module-grid article,
.partner-momentum-grid article,
.momentum-step,
.payoff-grid article,
.ops-card,
.quick-reply-card {
  border-radius: 12px;
}
.projection-date-card {
  border-color: #dfe4e8;
  background: #fff;
  text-align: center;
}
.projection-date-card span {
  background: #fff3f2;
  color: var(--red-dark);
}
.projection-date-card strong {
  color: var(--ink);
}
.projection-date-card:hover,
.projection-date-card.active {
  border-color: var(--red);
  background: var(--red);
  color: #fff;
  box-shadow: 0 14px 34px rgba(238,29,18,.18);
}
.projection-date-card.active span,
.projection-date-card:hover span,
.projection-date-card.active strong,
.projection-date-card:hover strong,
.projection-date-card.active small,
.projection-date-card:hover small,
.projection-date-card.active em,
.projection-date-card:hover em {
  color: #fff;
}
.projection-date-card.active span,
.projection-date-card:hover span {
  background: rgba(255,255,255,.16);
}
.app-shell .compact-text-mode .projection-date-grid {
  max-height: none;
}
.projection-selected-action,
.formula-selected-action,
.emotion-selected-action {
  border-radius: 14px;
  border-color: #e0e4e7;
  background: #fff;
}
.projection-result {
  border-color: #e0e4e7;
  background: #fff;
  color: var(--ink);
}
.projection-result > span,
.projection-day-scene span,
.projection-payment-preview span,
.projection-after-payment span,
.projection-day-video-card span {
  color: var(--red);
}
.projection-result h3,
.projection-hero-date strong,
.projection-day-scene strong,
.projection-payment-preview strong,
.projection-after-payment strong,
.projection-day-video-card strong,
.projection-buying-strip strong {
  color: var(--ink);
}
.projection-result p,
.projection-result li,
.projection-day-scene small,
.projection-payment-preview p,
.projection-after-payment p,
.projection-day-video-card p {
  color: var(--muted);
}
.projection-day-scene article,
.projection-countdown article,
.projection-payment-preview,
.projection-after-payment article,
.projection-buying-strip article,
.projection-day-video-card {
  border-color: #e0e4e7;
  background: #fff;
}
.reservation-model-card {
  align-items: center;
}
.reservation-model-video {
  width: 100%;
  min-width: 0;
  aspect-ratio: 16 / 9;
  border: 1px solid #edf0f2;
  border-radius: 16px;
  background: #111418;
  object-fit: cover;
  box-shadow: 0 10px 24px rgba(18, 24, 32, .10);
}
.reservation-model-card span {
  color: var(--red);
}
.reservation-model-card strong {
  color: var(--ink);
}
.reservation-model-card p {
  color: var(--muted);
}
.reservation-flow-card {
  display: grid;
  gap: 10px;
  margin-top: 8px;
  padding: 12px;
  border: 1px solid rgba(17, 20, 24, .08);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(207, 31, 50, .10), rgba(14, 85, 92, .08)),
    #fff;
  box-shadow: 0 16px 36px rgba(18, 24, 32, .08);
}
.reservation-flow-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.reservation-flow-head span {
  display: inline-flex;
  padding: 6px 9px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.reservation-flow-head strong {
  color: var(--ink);
  font-size: clamp(16px, 1.7vw, 23px);
  line-height: 1.05;
  text-align: right;
}
.reservation-flow-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.reservation-flow-step {
  min-height: 92px;
  padding: 10px;
  border: 1px solid #dce7e7;
  border-radius: 16px;
  background: rgba(255,255,255,.82);
  color: inherit;
  text-align: left;
  font: inherit;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.reservation-flow-step:hover,
.reservation-flow-step.active,
.reservation-flow-step.is-step-focus {
  border-color: var(--red);
  background: #fff7f8;
  box-shadow: inset 0 0 0 1px rgba(207,31,50,.12);
}
.reservation-flow-step:hover,
.reservation-flow-step.is-step-focus {
  transform: translateY(-1px);
}
.reservation-flow-step span {
  display: inline-flex;
  margin-bottom: 7px;
  color: var(--red-dark);
  font-size: 13px;
  font-weight: 950;
}
.reservation-flow-step strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.05;
}
.reservation-flow-step p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.2;
}
.projection-result li::before {
  background: var(--red);
}
.projection-actions .btn.ghost,
.customer-momentum .btn.outline,
.partner-momentum .btn.outline,
.essential-pay .btn.outline {
  color: var(--ink);
  border-color: var(--line);
  background: #fff;
}
.case-card:hover,
.case-card.active,
.case-card.is-selected,
.tariff-situation:hover,
.tariff-situation.is-selected,
.projection-offer-chip.active,
.projection-offer-chip:hover {
  border-color: var(--red);
  background: #fff8f7;
  box-shadow: inset 0 0 0 2px rgba(238,29,18,.18);
}
.case-card em,
.tariff-situation em,
.tariff-offer-card em {
  color: var(--red-dark);
}
.essential-pay,
.client-journey-card,
.customer-momentum,
.partner-momentum,
.recruitment-payoff,
.monitor-ops,
.app-shell .compact-details-body > section.partner-momentum,
.app-shell .compact-details-body > section.customer-momentum,
.app-shell .compact-details-body > section.recruitment-payoff,
.app-shell .compact-details-body > section.monitor-ops {
  background: #fff !important;
  color: var(--ink);
  border-color: #e0e4e7;
}
.essential-pay > span,
.enrollment-steps span,
.partner-step-grid span,
.portal-access-flow span,
.partner-momentum-grid span,
.momentum-step span {
  background: var(--red);
  color: #fff;
}
.essential-pay h3,
.essential-pay > strong,
.client-journey-top strong,
.client-status-grid strong,
.customer-momentum .section-head h2,
.customer-momentum h2,
.partner-momentum h2,
.partner-momentum-grid strong,
.momentum-step strong,
.recruitment-payoff .section-head h2,
.monitor-ops .section-head h2 {
  color: var(--ink) !important;
}
.essential-founder {
  background: #fff !important;
  color: var(--ink);
}
.app-shell .essential-founder {
  padding: 0 !important;
}
.app-shell .essential-founder img {
  height: 96px;
}
.app-shell .essential-founder div {
  padding: 9px;
}
.app-shell .essential-founder h3 {
  margin: 0 0 5px;
  font-size: clamp(16px, 1.7vw, 21px);
}
.essential-pay p,
.client-journey-top p,
.client-status-grid small,
.customer-momentum p,
.partner-momentum p,
.partner-momentum-grid p,
.momentum-step p,
.recruitment-payoff p,
.monitor-ops p,
.monitor-ops li,
.quick-reply-card p {
  color: var(--muted) !important;
}
.client-status-grid article,
.partner-momentum-grid article,
.momentum-step,
.payoff-grid article,
.ops-card,
.quick-reply-kit {
  border-color: #e0e4e7 !important;
  background: #fff !important;
  color: var(--ink) !important;
}
.enrollment-result,
.enrollment-panel,
.training-emotion-pass,
.schedule-main-card,
.schedule-side-card,
.client-login-card,
.portal-login-panel,
.partner-form,
.lead-form,
.evaluation-form,
.evaluation-result {
  border-radius: 14px;
  border-color: #e0e4e7;
  background: #fff;
}
.enrollment-panel input,
.enrollment-panel select,
.lead-form input,
.lead-form select,
.lead-form textarea,
.partner-form input,
.partner-form select,
.partner-form textarea,
.evaluation-form input,
.evaluation-form select,
.client-login-form input,
.portal-access-fields input {
  border-radius: 10px;
  border-color: #dfe4e8;
}
.payment-method-row button {
  border-radius: 10px;
  background: #fff;
  color: var(--ink);
}
.payment-method-row button:hover {
  border-color: var(--red);
  background: #fff3f2;
  color: var(--red-dark);
}
@media (min-width: 981px) {
  .app-shell .compact-text-mode .exam-projection {
    gap: 10px;
  }
  .app-shell .compact-text-mode .projection-stage {
    grid-template-columns: minmax(0, 1fr) minmax(280px, .72fr);
  }
  .app-shell .compact-text-mode .enrollment-action {
    grid-template-columns: minmax(360px, .72fr) minmax(0, 1fr);
    align-items: stretch;
  }
  .app-shell .compact-text-mode .enrollment-result {
    order: -1;
    padding: 16px;
  }
  .app-shell .compact-text-mode .enrollment-result h3 {
    font-size: clamp(24px, 2.4vw, 34px);
  }
  .app-shell .compact-text-mode .enrollment-panel {
    order: 2;
    opacity: .9;
  }
  .app-shell .compact-text-mode .contract-preview-wrap {
    display: none;
  }
  .app-shell .compact-text-mode .projection-date-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  }
  .app-shell .compact-text-mode .projection-date-card {
    min-height: 82px;
  }
}
@media (max-width: 980px) {
  .app-shell main {
    background: #f4eee7;
  }
  .app-shell .compact-details-body > section {
    border-radius: 14px;
  }
  .app-shell.page-recrutement-moniteurs .compact-details,
  .app-shell.page-apporteurs-affaires .compact-details,
  .app-shell.page-apporteurs-affaires-recrutement-moniteurs .compact-details {
    grid-column: 1 !important;
    grid-row: 2;
    min-width: 0;
    overflow: hidden;
  }
  .app-shell.page-recrutement-moniteurs .compact-details-body > section,
  .app-shell.page-apporteurs-affaires .compact-details-body > section,
  .app-shell.page-apporteurs-affaires-recrutement-moniteurs .compact-details-body > section {
    padding-left: 10px;
    padding-right: 10px;
  }
  .app-shell .compact-text-mode .projection-date-video-card {
    background: #fff;
  }
  .app-shell .compact-text-mode .partner-momentum,
  .app-shell .compact-text-mode .customer-momentum {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto minmax(0, 1fr);
    overflow: auto;
  }
  .app-shell .compact-text-mode .partner-momentum-actions,
  .app-shell .compact-text-mode .momentum-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    width: 100%;
  }
  .app-shell .compact-text-mode .partner-momentum-actions .btn,
  .app-shell .compact-text-mode .momentum-actions .btn {
    width: 100%;
  }
  .app-shell .compact-text-mode .partner-momentum-grid,
  .app-shell .compact-text-mode .momentum-path,
  .app-shell .compact-text-mode .payoff-grid,
  .app-shell .compact-text-mode .mobility-grid,
  .app-shell .compact-text-mode .partner-monetization-grid,
  .app-shell .compact-text-mode .notification-grid,
  .app-shell .compact-text-mode .ops-layout,
  .app-shell .compact-text-mode .quick-reply-grid {
    grid-template-columns: 1fr !important;
  }
  .app-shell .compact-text-mode .contract-preview-wrap {
    display: none;
  }
  .app-shell .compact-details-body {
    padding-bottom: 64px;
  }
  .app-demo-card {
    display: none;
  }
}

/* App-video closer: when the user enters a workflow, the screen becomes one focused app surface. */
@media (min-width: 981px) {
  .app-shell main:has(.compact-details-body.has-active-panel) {
    grid-template-rows: auto minmax(0, 1fr);
    grid-template-columns: minmax(0, 1fr);
    gap: 12px;
    padding: 14px clamp(16px, 2.2vw, 34px);
    background:
      radial-gradient(circle at 50% 0%, rgba(238, 29, 18, .08), transparent 34%),
      linear-gradient(180deg, #f7f0e8 0%, #f4eee7 100%);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) > :where(.hero, .page-hero, .essential-workflow) {
    display: none !important;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-conversion-bar {
    grid-column: 1;
    grid-row: 1;
    grid-template-columns: 1fr !important;
    width: min(1180px, 100%);
    margin: 0 auto;
    padding: 9px !important;
    border-radius: 24px;
    border-color: rgba(238, 29, 18, .10);
    background: rgba(255, 255, 255, .96) !important;
    box-shadow: 0 18px 44px rgba(18, 24, 32, .09);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-conversion-bar strong {
    max-width: 360px;
    color: var(--red-dark);
    font-size: clamp(22px, 2.4vw, 34px);
    line-height: .92;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-conversion-bar span {
    display: none;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-conversion-bar nav {
    grid-column: 1 / -1;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-action-link {
    min-height: 58px;
    border-radius: 18px;
    font-size: 17px;
    box-shadow: inset 0 0 0 1px #edf0f2;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-action-link.primary,
  .app-shell main:has(.compact-details-body.has-active-panel) .fast-action-link.active {
    background: var(--red);
    border-color: var(--red);
    color: #fff;
    box-shadow: 0 14px 30px rgba(238, 29, 18, .20);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details {
    grid-column: 1 !important;
    grid-row: 2;
    width: min(1180px, 100%);
    min-height: 0;
    margin: 0 auto;
    padding: 0 !important;
    background: transparent;
    overflow: hidden;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details > details {
    height: 100% !important;
    max-height: none;
    display: grid;
    grid-template-rows: 0 minmax(0, 1fr);
    border: 0;
    background: transparent;
    box-shadow: none;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details > details > summary {
    display: none;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body {
    padding: 0;
    overflow: hidden;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section {
    padding: 22px !important;
    border-radius: 30px !important;
    border: 1px solid rgba(238, 29, 18, .10) !important;
    background: rgba(255, 255, 255, .98) !important;
    box-shadow: 0 28px 70px rgba(18, 24, 32, .12) !important;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section::before {
    min-height: 30px;
    margin-bottom: 12px;
    padding: 7px 12px;
    border-radius: 12px;
    background: #fff3f2;
    font-size: 13px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-head h2,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .section-head h2 {
    max-width: 820px;
    font-size: clamp(34px, 3.8vw, 58px);
    line-height: .92;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-stage {
    grid-template-columns: minmax(0, .98fr) minmax(360px, .76fr);
    gap: 14px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-zone {
    display: grid;
    grid-template-rows: auto auto auto auto minmax(0, 1fr) auto auto;
    gap: 12px;
    overflow: hidden;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-zone-head {
    grid-template-columns: minmax(0, 1fr);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-zone-head strong {
    font-size: clamp(24px, 2.5vw, 36px);
    line-height: .95;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-selected-action {
    padding: 12px;
    border-radius: 20px;
    border-color: rgba(238, 29, 18, .16);
    background: #fff8f7;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-selected-action strong {
    font-size: clamp(18px, 1.55vw, 23px);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-selected-actions .btn {
    min-height: 48px;
    border-radius: 16px;
    font-size: 15px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-date-video-card {
    min-height: 124px;
    padding: 12px;
    border-radius: 22px;
    box-shadow: 0 12px 32px rgba(18,24,32,.08);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-date-video-card .projection-video-trigger {
    min-height: 100px;
    border-radius: 18px;
    overflow: hidden;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-card {
    grid-template-columns: minmax(340px, .72fr) minmax(0, 1fr);
    min-height: 186px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-video {
    min-height: 168px;
    border-radius: 18px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-flow-card {
    padding: 12px;
    border-radius: 22px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-flow-steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-flow-step {
    min-height: 86px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar {
    padding: 10px;
    border-radius: 22px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar-days {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    max-height: none;
    overflow: visible;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar-cell,
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar-day {
    min-height: 58px;
    border-radius: 13px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar-day strong {
    font-size: clamp(20px, 2vw, 28px);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar-day em {
    display: none;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .projection-date-video-card strong {
    font-size: clamp(20px, 1.8vw, 28px);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    height: auto;
    min-height: 160px;
    max-height: 240px;
    overflow: auto;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card {
    min-height: 116px;
    padding: 16px;
    border-radius: 22px;
    text-align: left;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card span {
    width: fit-content;
    padding: 6px 9px;
    border-radius: 10px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card strong {
    margin-top: 8px;
    font-size: clamp(29px, 2.8vw, 42px);
    line-height: .92;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card small {
    font-size: 15px;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-result,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .enrollment-result {
    border-radius: 26px;
    padding: 22px;
    box-shadow: inset 0 0 0 1px rgba(238, 29, 18, .08);
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-result h3,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-hero-date strong,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .enrollment-result h3 {
    font-size: clamp(26px, 2.8vw, 40px);
    line-height: .96;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .payment-method-row button,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .enrollment-result a,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .enrollment-result .post-payment-trigger {
    min-height: 48px;
    border-radius: 16px;
    font-size: 15px;
  }
}

@media (max-width: 980px) {
  .app-shell .site-header {
    min-height: 54px;
    padding: 6px 10px;
    box-shadow: 0 8px 24px rgba(18, 24, 32, .08);
  }
  .app-shell main {
    grid-template-rows: auto minmax(0, 1fr);
    gap: 10px;
    padding: 8px;
  }
  .app-shell .fast-conversion-bar {
    grid-template-columns: 1fr !important;
    border-radius: 18px;
    box-shadow: 0 14px 34px rgba(18,24,32,.09);
  }
  .app-shell .fast-conversion-bar > div {
    display: none;
  }
  .app-shell .fast-conversion-bar nav {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }
  .app-shell .fast-action-link {
    min-height: 44px;
    border-radius: 14px;
  }
  .app-shell .compact-details {
    padding: 0 !important;
    background: transparent;
  }
  .app-shell .compact-details > details {
    height: 100% !important;
    max-height: none;
    border: 0;
    background: transparent;
    box-shadow: none;
  }
  .app-shell .compact-details > details > summary {
    display: none;
  }
  .app-shell .compact-details-body {
    padding: 0 0 60px;
  }
  .app-shell .compact-details-body > section {
    padding: 16px 12px !important;
    border-radius: 22px !important;
    box-shadow: 0 18px 44px rgba(18,24,32,.10) !important;
  }
  .app-shell .compact-details-body > section::before {
    min-height: 28px;
    margin-bottom: 10px;
    padding: 7px 10px;
    border-radius: 11px;
  }
  .app-shell .compact-text-mode .projection-head h2,
  .app-shell .compact-text-mode .section-head h2,
  .app-shell .compact-text-mode h2 {
    font-size: clamp(26px, 8.2vw, 38px);
    line-height: .96;
  }
  .app-shell .compact-text-mode .projection-date-video-card {
    border-radius: 20px;
    box-shadow: 0 12px 30px rgba(18,24,32,.08);
  }
  .app-shell .compact-text-mode .reservation-model-card {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 10px;
  }
  .app-shell .compact-text-mode .reservation-model-video {
    min-height: 0;
    max-height: 210px;
    border-radius: 14px;
  }
  .app-shell .compact-text-mode .reservation-model-card p {
    display: block;
  }
  .app-shell .compact-text-mode .reservation-flow-card {
    gap: 8px;
    padding: 10px;
    border-radius: 20px;
  }
  .app-shell .compact-text-mode .reservation-flow-head {
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .app-shell .compact-text-mode .reservation-flow-head strong {
    text-align: right;
    font-size: 14px;
  }
  .app-shell .compact-text-mode .reservation-flow-steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
  }
  .app-shell .compact-text-mode .reservation-flow-step {
    min-height: 66px;
    padding: 7px;
    border-radius: 15px;
  }
  .app-shell .compact-text-mode .reservation-flow-step span {
    margin-bottom: 3px;
    font-size: 11px;
  }
  .app-shell .compact-text-mode .reservation-flow-step strong {
    font-size: 13px;
  }
  .app-shell .compact-text-mode .reservation-flow-step p {
    max-height: 26px;
    overflow: hidden;
    font-size: 10px;
  }
  .app-shell .compact-text-mode .projection-calendar {
    padding: 9px;
    border-radius: 18px;
  }
  .app-shell .compact-text-mode .projection-calendar-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 5px;
  }
  .app-shell .compact-text-mode .projection-calendar-head small {
    grid-column: 1 / -1;
    max-width: none;
    text-align: left;
    font-size: 12px;
  }
  .app-shell .compact-text-mode .projection-calendar-days {
    grid-template-columns: repeat(7, minmax(0, 1fr));
    max-height: none;
    overflow: visible;
  }
  .app-shell .compact-text-mode .projection-calendar-cell,
  .app-shell .compact-text-mode .projection-calendar-day {
    min-height: 48px;
    padding: 6px;
    border-radius: 10px;
  }
  .app-shell .compact-text-mode .projection-calendar-day strong {
    font-size: 19px;
  }
  .app-shell .compact-text-mode .projection-calendar-day span {
    display: none;
  }
  .app-shell .compact-text-mode .projection-calendar-day em {
    display: none;
  }
  .app-shell .compact-text-mode .projection-calendar-day::after {
    content: "";
    position: absolute;
    right: 7px;
    bottom: 7px;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: var(--red);
  }
  .app-shell .compact-text-mode .projection-date-card {
    border-radius: 19px;
    min-height: 104px;
    padding: 14px;
  }
  .app-shell .compact-text-mode .projection-date-card strong {
    font-size: 28px;
  }
  .app-shell .compact-text-mode .projection-date-card small {
    font-size: 14px;
  }
  .app-shell .compact-text-mode .projection-date-grid {
    height: auto !important;
    min-height: 160px !important;
    max-height: 240px;
  }
  .mobile-cta {
    border-top: 0;
    box-shadow: 0 -10px 26px rgba(18,24,32,.18);
  }
}

@media (max-width: 520px) {
  .app-shell .compact-text-mode .reservation-flow-head {
    display: grid;
  }
  .app-shell .compact-text-mode .reservation-flow-head strong {
    text-align: left;
  }
  .app-shell .compact-text-mode .reservation-flow-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .app-shell .compact-text-mode .reservation-flow-step {
    min-height: 68px;
  }
  .app-shell .compact-text-mode .projection-date-grid {
    height: auto !important;
    min-height: 160px !important;
    max-height: 240px;
  }
}

/* Reservation video flow: app-like booking surface inspired by the reference video. */
.exam-projection {
  background:
    radial-gradient(circle at 50% 0%, rgba(207, 31, 50, .10), transparent 36%),
    linear-gradient(180deg, #f8f2ea 0%, #f4eee7 100%);
}
.exam-projection .projection-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: end;
  max-width: 1180px;
}
.exam-projection .projection-head h2 {
  max-width: 760px;
  font-size: clamp(34px, 4vw, 58px);
}
.exam-projection .projection-head p:last-child {
  max-width: 620px;
  font-size: 16px;
}
.exam-projection .projection-stage {
  padding: 14px;
  border: 1px solid rgba(17, 20, 24, .08);
  border-radius: 30px;
  background:
    linear-gradient(135deg, rgba(17,20,24,.96), rgba(34,39,46,.92)),
    #111418;
  box-shadow: 0 30px 80px rgba(18,24,32,.18);
}
.exam-projection .projection-date-zone,
.exam-projection .projection-result {
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 24px;
  background: #fff;
  color: var(--ink);
  box-shadow: 0 18px 48px rgba(0,0,0,.12);
}
.exam-projection .projection-date-zone {
  gap: 10px;
}
.exam-projection .projection-zone-head {
  padding: 11px 12px;
  border: 1px solid #edf0f2;
  border-radius: 18px;
  background: #f7faf9;
  align-items: center;
}
.exam-projection .projection-zone-head strong {
  font-size: clamp(22px, 2vw, 30px);
}
.exam-projection .projection-zone-head small {
  max-width: 340px;
  font-size: 12px;
}
.exam-projection .reservation-model-card {
  grid-template-columns: minmax(170px, .42fr) minmax(0, 1fr);
  gap: 12px;
  min-height: 132px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  background:
    radial-gradient(circle at 10% 0%, rgba(255, 203, 88, .20), transparent 34%),
    #111418;
  color: #fff;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.06);
}
.exam-projection .reservation-model-video {
  min-height: 112px;
  border-radius: 16px;
  border-color: rgba(255,255,255,.16);
}
.exam-projection .reservation-model-card span {
  color: #ffcb58;
}
.exam-projection .reservation-model-card strong {
  color: #fff;
  font-size: clamp(18px, 1.7vw, 25px);
  line-height: 1.04;
}
.exam-projection .reservation-model-card > div {
  min-width: 0;
}
.exam-projection .reservation-model-card p {
  margin-top: 6px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
}
.exam-projection .reservation-flow-card {
  gap: 8px;
  margin-top: 0;
  padding: 10px;
  border: 1px solid #edf0f2;
  border-radius: 20px;
  background: #f7faf9;
  box-shadow: none;
}
.exam-projection .reservation-flow-head {
  align-items: center;
}
.exam-projection .reservation-flow-head span {
  background: #111418;
}
.exam-projection .reservation-flow-head strong {
  max-width: 460px;
  font-size: clamp(15px, 1.4vw, 20px);
}
.exam-projection .reservation-flow-steps {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.exam-projection .reservation-flow-step {
  min-height: 64px;
  padding: 9px;
  border-radius: 14px;
  background: #fff;
}
.exam-projection .reservation-flow-step p {
  display: none;
}
.exam-projection .reservation-flow-step span {
  margin-bottom: 4px;
}
.exam-projection .projection-calendar {
  gap: 8px;
  padding: 11px;
  border-radius: 20px;
  background: #fbfdfc;
  box-shadow: inset 0 0 0 1px #edf0f2;
}
.exam-projection .projection-calendar-head {
  grid-template-columns: minmax(0, 1fr) auto;
}
.exam-projection .projection-calendar-head small {
  grid-column: 1 / -1;
  max-width: none;
  text-align: left;
}
.exam-projection .projection-calendar-helper {
  display: none;
}
.exam-projection .projection-calendar-cell,
.exam-projection .projection-calendar-day {
  min-height: 50px;
  border-radius: 12px;
}
.exam-projection .projection-calendar-day strong {
  font-size: clamp(20px, 1.8vw, 26px);
}
.exam-projection .projection-calendar-day em {
  display: none;
}
.exam-projection .projection-date-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
  min-height: 106px;
  max-height: 138px;
  padding: 2px;
  overflow: auto;
}
.exam-projection .projection-date-card {
  min-height: 88px;
  padding: 12px;
  border-radius: 16px;
  box-shadow: none;
}
.exam-projection .projection-date-card span {
  padding: 4px 7px;
  font-size: 11px;
}
.exam-projection .projection-date-card strong {
  margin-top: 2px;
  font-size: clamp(21px, 2vw, 28px);
}
.exam-projection .projection-date-card small {
  font-size: 13px;
}
.exam-projection .projection-date-card em,
.exam-projection .projection-date-card.active::after {
  display: none;
}
.exam-projection .projection-selected-action {
  padding: 13px;
  border: 0;
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(207,31,50,.96), rgba(166,22,43,.96)),
    var(--red);
  color: #fff;
  box-shadow: 0 18px 38px rgba(166,22,43,.24);
}
.exam-projection .projection-selected-action span {
  background: rgba(255,255,255,.16);
  color: #fff;
}
.exam-projection .projection-selected-action strong {
  color: #fff;
  font-size: clamp(18px, 1.6vw, 24px);
}
.exam-projection .projection-selected-action p {
  max-width: 620px;
  color: rgba(255,255,255,.78);
  font-size: 13px;
}
.exam-projection .projection-selected-actions .btn.primary {
  background: #fff;
  color: var(--red-dark);
  border-color: #fff;
}
.exam-projection .projection-selected-actions .btn.outline {
  color: #fff;
  border-color: rgba(255,255,255,.42);
  background: transparent;
}
.exam-projection .projection-offer-zone {
  padding: 12px;
  border-radius: 18px;
  background: #f7faf9;
}
.exam-projection .projection-offer-grid {
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
}
.exam-projection .projection-offer-chip {
  min-height: 66px;
  border-radius: 14px;
}
.exam-projection .projection-result {
  position: sticky;
  top: 12px;
  gap: 10px;
  align-self: start;
  color: var(--ink);
}
.exam-projection .projection-result > span {
  background: #111418;
  color: #fff;
  border-radius: 999px;
}
.exam-projection .projection-result h3 {
  margin: 4px 0 0;
  color: var(--ink);
  font-size: clamp(22px, 2.2vw, 34px);
}
.exam-projection .projection-hero-date {
  margin-top: 0;
  border-color: rgba(207,31,50,.18);
  border-radius: 20px;
  background: #fff7f8;
}
.exam-projection .projection-hero-date strong {
  color: var(--red-dark);
  font-size: clamp(28px, 3vw, 42px);
}
.exam-projection .projection-hero-date small {
  color: var(--ink);
}
.exam-projection .projection-countdown {
  margin-top: 0;
}
.exam-projection .projection-countdown article {
  min-height: 70px;
  border: 1px solid #edf0f2;
  background: #fff;
  box-shadow: none;
}
.exam-projection .projection-center-focus {
  margin-top: 0;
  border-left: 0;
  border-radius: 18px;
  background: #f7faf9;
}
.exam-projection .projection-center-focus p,
.exam-projection .projection-day-video-card:not(.reservation-model-card),
.exam-projection .projection-meta,
.exam-projection .projection-result ul,
.exam-projection .projection-payment-preview p {
  display: none;
}
.exam-projection .projection-center-photo-card {
  min-height: 128px;
  border-radius: 20px;
}
.exam-projection .projection-day-scene {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.exam-projection .projection-day-scene article {
  padding: 11px;
  border-radius: 16px;
}
.exam-projection .projection-day-scene small {
  display: none;
}
.exam-projection .projection-after-payment {
  grid-template-columns: 1fr;
  gap: 8px;
}
.exam-projection .projection-after-payment article {
  padding: 11px;
  border-radius: 16px;
}
.exam-projection .projection-after-payment p {
  display: none;
}
.exam-projection .projection-buying-strip {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.exam-projection .projection-buying-strip article {
  min-height: 58px;
  padding: 10px;
  border-radius: 16px;
}
.exam-projection .projection-payment-preview {
  padding: 12px;
  border-radius: 18px;
  background: #111418;
}
.exam-projection .projection-payment-preview span,
.exam-projection .projection-payment-preview strong {
  color: #fff;
}
.exam-projection .projection-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin-top: 0;
}
.exam-projection .projection-actions a {
  min-height: 46px;
  border-radius: 16px;
}

@media (max-width: 980px) {
  .exam-projection .projection-head {
    grid-template-columns: 1fr;
  }
  .exam-projection .projection-stage {
    padding: 8px;
    border-radius: 24px;
  }
  .exam-projection .reservation-model-card {
    grid-template-columns: minmax(118px, .45fr) minmax(0, 1fr);
  }
  .exam-projection .reservation-model-video {
    min-height: 92px;
  }
  .exam-projection .reservation-flow-steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .exam-projection .reservation-flow-step {
    min-height: 56px;
    padding: 7px;
  }
  .exam-projection .projection-calendar-cell,
  .exam-projection .projection-calendar-day {
    min-height: 43px;
    padding: 5px;
  }
  .exam-projection .projection-calendar-day span,
  .exam-projection .projection-calendar-day em {
    display: none;
  }
  .exam-projection .projection-calendar-day::after {
    content: "";
    position: absolute;
    right: 6px;
    bottom: 6px;
    width: 6px;
    height: 6px;
    border-radius: 999px;
    background: var(--red);
  }
  .exam-projection .projection-selected-action {
    display: grid;
  }
  .exam-projection .projection-selected-actions {
    min-width: 0;
    justify-content: stretch;
  }
  .exam-projection .projection-selected-actions .btn {
    width: 100%;
  }
  .exam-projection .projection-result {
    position: static;
  }
}

@media (max-width: 520px) {
  .app-shell .compact-text-mode .exam-projection .projection-zone-head {
    padding: 8px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-zone-head strong {
    font-size: 19px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-zone-head small {
    display: none !important;
  }
  .exam-projection .reservation-model-card {
    grid-template-columns: 104px minmax(0, 1fr);
    min-height: 74px;
    align-items: center;
  }
  .app-shell .compact-text-mode .exam-projection .reservation-model-card {
    grid-template-columns: 104px minmax(0, 1fr) !important;
    height: 74px !important;
    min-height: 74px !important;
    max-height: 74px !important;
    padding: 8px !important;
    overflow: hidden !important;
    align-content: center !important;
  }
  .app-shell .compact-text-mode .exam-projection .reservation-model-video {
    width: 104px !important;
    height: 58px !important;
    min-height: 0 !important;
    max-height: 58px !important;
    aspect-ratio: auto;
    object-fit: cover;
  }
  .app-shell .compact-text-mode .exam-projection .reservation-model-card span {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .reservation-model-card strong {
    font-size: 14px !important;
    line-height: 1.08 !important;
  }
  .exam-projection .reservation-model-card p {
    display: none;
  }
  .app-shell .compact-text-mode .exam-projection .reservation-model-card p,
  .app-shell .compact-text-mode .exam-projection .reservation-flow-card {
    display: none !important;
  }
  .exam-projection .projection-calendar-head {
    grid-template-columns: 1fr auto;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-head small {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar {
    gap: 4px !important;
    padding: 7px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-nav button {
    width: 28px !important;
    height: 28px !important;
    font-size: 15px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-head strong {
    font-size: 18px !important;
  }
  .exam-projection .projection-calendar-weekdays,
  .exam-projection .projection-calendar-days {
    gap: 4px;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-weekdays span {
    font-size: 8px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-cell,
  .app-shell .compact-text-mode .exam-projection .projection-calendar-day {
    min-height: 22px !important;
    padding: 3px !important;
    border-radius: 7px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-day strong {
    font-size: 12px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-cell.is-muted strong {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-grid {
    grid-template-columns: 1fr;
    min-height: 70px !important;
    max-height: 78px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card {
    min-height: 66px !important;
    padding: 8px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card span,
  .app-shell .compact-text-mode .exam-projection .projection-date-card em {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action {
    padding: 8px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action span {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action strong {
    font-size: 14px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action p {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-actions .btn {
    min-height: 38px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-actions .btn.outline {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-offer-zone {
    display: none !important;
  }
  .exam-projection .projection-day-scene,
  .exam-projection .projection-buying-strip {
    grid-template-columns: 1fr;
  }
}

/* Reservation open flow: not a screen inside the page, but the page's main booking journey. */
.exam-projection {
  background:
    linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(247,250,249,.98) 42%, #f6f1ea 100%);
}
.exam-projection .projection-head {
  max-width: 1120px;
  margin-inline: auto;
}
.exam-projection .projection-head h2 {
  max-width: 920px;
  color: #12161b;
  font-size: clamp(34px, 4.2vw, 62px);
  letter-spacing: 0;
}
.exam-projection .projection-head p:last-child {
  max-width: 700px;
  color: #58616c;
  font-size: clamp(16px, 1.25vw, 20px);
}
.exam-projection .projection-stage,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-stage {
  gap: 18px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.exam-projection .projection-date-zone > .projection-zone-head { order: 1 !important; }
.exam-projection .projection-date-zone > .projection-selected-action { order: 2 !important; }
.exam-projection .projection-date-zone > .projection-calendar { order: 3 !important; }
.exam-projection .projection-date-zone > .projection-date-grid { order: 4 !important; }
.exam-projection .projection-date-zone > .reservation-model-card { order: 5 !important; }
.exam-projection .projection-date-zone > .projection-offer-zone { order: 6 !important; }
.exam-projection .projection-date-zone > .reservation-flow-card { order: 7 !important; }
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details > details,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body {
  overflow: auto !important;
}
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details > details {
  height: auto !important;
  min-height: 100%;
}
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.is-app-active.exam-projection {
  height: auto !important;
  min-height: auto !important;
  overflow: visible !important;
}
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-zone {
  grid-template-rows: none !important;
  height: auto !important;
  overflow: visible !important;
}
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.is-app-active.exam-projection,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.exam-projection {
  background:
    linear-gradient(180deg, #fff 0%, #f7faf9 54%, #f6f1ea 100%) !important;
  box-shadow: 0 18px 54px rgba(18,24,32,.10) !important;
}
.exam-projection .projection-date-zone,
.exam-projection .projection-result,
.app-shell .compact-text-mode .exam-projection .projection-date-zone,
.app-shell .compact-text-mode .exam-projection .projection-result {
  min-width: 0;
  padding: clamp(14px, 1.6vw, 22px) !important;
  border: 1px solid rgba(14,85,92,.16) !important;
  border-radius: 26px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(250,253,252,.96)) !important;
  color: var(--ink) !important;
  box-shadow: 0 22px 60px rgba(18,24,32,.10) !important;
}
.exam-projection .projection-date-zone,
.app-shell .compact-text-mode .exam-projection .projection-date-zone {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.exam-projection .projection-zone-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  padding: 0 0 4px;
  border: 0;
  background: transparent;
}
.exam-projection .projection-zone-head span,
.exam-projection .projection-calendar-head span,
.exam-projection .projection-offer-zone > span {
  color: var(--red-dark);
}
.exam-projection .projection-zone-head strong {
  max-width: 620px;
  font-size: clamp(24px, 2.5vw, 38px);
}
.exam-projection .projection-zone-head small {
  align-self: end;
  max-width: 280px;
  padding: 8px 10px;
  border-radius: 999px;
  background: #eef8f6;
  color: var(--teal);
  font-size: 12px;
  text-align: right;
}
.exam-projection .reservation-model-card,
.app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-card,
.app-shell .compact-text-mode .exam-projection .reservation-model-card {
  display: grid !important;
  grid-template-columns: minmax(180px, .38fr) minmax(0, 1fr) !important;
  align-items: start !important;
  min-height: 142px !important;
  height: auto !important;
  max-height: none !important;
  gap: 14px !important;
  padding: 12px !important;
  overflow: hidden !important;
  border: 1px solid #e7ecec !important;
  border-radius: 22px !important;
  background:
    linear-gradient(135deg, rgba(17,20,24,.04), rgba(14,85,92,.06)),
    #fff !important;
  color: var(--ink) !important;
  box-shadow: 0 14px 34px rgba(18,24,32,.07) !important;
}
.exam-projection .reservation-model-video,
.app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-video,
.app-shell .compact-text-mode .exam-projection .reservation-model-video {
  width: 100% !important;
  min-height: 104px !important;
  height: 104px !important;
  max-height: none !important;
  border: 2px solid #f1b42b !important;
  border-radius: 18px !important;
  object-fit: cover !important;
  box-shadow: 0 10px 24px rgba(18,24,32,.10) !important;
}
.exam-projection .reservation-model-card span,
.app-shell .compact-text-mode .exam-projection .reservation-model-card span {
  display: inline-flex !important;
  width: fit-content;
  margin-bottom: 6px;
  padding: 5px 8px;
  border-radius: 999px;
  background: #fff3d1;
  color: #9a6610 !important;
  font-size: 11px;
}
.exam-projection .reservation-model-card strong,
.app-shell .compact-text-mode .exam-projection .reservation-model-card strong {
  color: var(--ink) !important;
  font-size: clamp(18px, 1.8vw, 28px) !important;
  line-height: 1.05 !important;
}
.exam-projection .reservation-model-card p,
.app-shell .compact-text-mode .exam-projection .reservation-model-card p {
  display: block !important;
  margin-top: 6px;
  max-width: 720px;
  overflow: hidden;
  color: #58616c !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}
.exam-projection .reservation-flow-card {
  padding: 10px;
  border: 1px solid #e7ecec;
  border-radius: 22px;
  background: #f8fbfa;
}
.exam-projection .reservation-flow-head strong {
  max-width: none;
}
.exam-projection .reservation-flow-step {
  min-height: 58px;
  border: 1px solid #e7ecec;
  background: #fff;
}
.exam-projection .reservation-flow-step.active,
.exam-projection .reservation-flow-step:hover {
  border-color: rgba(207,31,50,.35);
  background: #fff7f8;
}
.exam-projection .projection-calendar,
.app-shell main:has(.compact-details-body.has-active-panel) .projection-calendar,
.app-shell .compact-text-mode .exam-projection .projection-calendar {
  padding: clamp(10px, 1.2vw, 16px) !important;
  border: 1px solid rgba(14,85,92,.16) !important;
  border-radius: 24px !important;
  background: #fff !important;
  box-shadow: inset 0 0 0 1px rgba(14,85,92,.04), 0 14px 34px rgba(18,24,32,.06) !important;
}
.exam-projection .projection-calendar-head {
  align-items: center;
}
.exam-projection .projection-calendar-day {
  background: #fbfdfc;
}
.exam-projection .projection-calendar-day:hover,
.exam-projection .projection-calendar-day.active {
  border-color: var(--red);
  background: #fff1f3;
  box-shadow: 0 12px 28px rgba(166,22,43,.13);
}
.exam-projection .projection-calendar-day span {
  color: var(--teal);
}
.exam-projection .projection-date-grid,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-grid,
.app-shell .compact-text-mode .exam-projection .projection-date-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)) !important;
  gap: 10px !important;
  min-height: 128px !important;
  height: auto !important;
  max-height: 280px !important;
  padding: 2px 2px 8px !important;
  overflow: auto !important;
}
.exam-projection .projection-date-card,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card,
.app-shell .compact-text-mode .exam-projection .projection-date-card {
  display: grid !important;
  position: relative;
  grid-template-columns: minmax(0, 1fr) auto;
  align-content: start;
  gap: 7px 10px;
  min-height: 132px !important;
  padding: 14px !important;
  border: 1px solid #dce7e7 !important;
  border-radius: 20px !important;
  background: #fff !important;
  color: var(--ink) !important;
  box-shadow: 0 14px 32px rgba(18,24,32,.07) !important;
}
.exam-projection .projection-date-card:hover,
.exam-projection .projection-date-card.active {
  border-color: var(--red) !important;
  background: #fff8f8 !important;
  box-shadow: 0 18px 38px rgba(166,22,43,.14) !important;
  transform: translateY(-1px);
}
.exam-projection .projection-date-card.is-calendar-hidden,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card.is-calendar-hidden,
.app-shell .compact-text-mode .exam-projection .projection-date-card.is-calendar-hidden {
  display: none !important;
}
.exam-projection .projection-date-card.active::after {
  content: "Réservé";
  top: 12px;
  right: 12px;
  background: var(--red);
}
.exam-projection .projection-date-card .slot-day,
.app-shell .compact-text-mode .exam-projection .projection-date-card .slot-day {
  display: inline-flex !important;
  grid-column: 1;
  justify-self: start;
  width: fit-content;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  background: #e8f5f3 !important;
  color: var(--teal) !important;
  font-size: 12px !important;
  font-weight: 950;
}
.exam-projection .projection-date-card strong,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card strong,
.app-shell .compact-text-mode .exam-projection .projection-date-card strong {
  grid-column: 1;
  margin: 0 !important;
  color: var(--red-dark) !important;
  font-size: clamp(32px, 3.2vw, 48px) !important;
  line-height: .88 !important;
}
.exam-projection .projection-date-card .slot-center,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-date-card .slot-center,
.app-shell .compact-text-mode .exam-projection .projection-date-card .slot-center {
  display: block !important;
  grid-column: 1 / -1;
  color: #172027 !important;
  font-size: clamp(17px, 1.35vw, 22px) !important;
  font-weight: 950 !important;
  line-height: 1.05 !important;
}
.exam-projection .projection-date-card em,
.app-shell .compact-text-mode .exam-projection .projection-date-card em {
  display: block !important;
  grid-column: 1 / -1;
  color: #5d6570 !important;
  font-size: 13px !important;
  font-style: normal;
  font-weight: 800;
  line-height: 1.2;
}
.exam-projection .projection-date-card .slot-places,
.app-shell .compact-text-mode .exam-projection .projection-date-card .slot-places {
  display: inline-flex !important;
  grid-column: 2;
  grid-row: 1 / 3;
  align-self: start;
  justify-self: end;
  width: auto;
  padding: 6px 8px !important;
  border-radius: 999px !important;
  background: #fff3d1 !important;
  color: #8a5e14 !important;
  font-size: 11px !important;
  font-weight: 950;
  white-space: nowrap;
}
.exam-projection .projection-selected-action,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-selected-action,
.app-shell .compact-text-mode .exam-projection .projection-selected-action {
  display: grid !important;
  position: relative !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  height: auto !important;
  min-height: 154px !important;
  max-height: none !important;
  padding: clamp(16px, 2vw, 24px) !important;
  overflow: hidden !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 92% 0, rgba(255,203,88,.38), transparent 34%),
    linear-gradient(135deg, #8f1226 0%, #cf1f32 62%, #e43839 100%) !important;
  color: #fff !important;
  box-shadow: 0 24px 58px rgba(166,22,43,.25) !important;
}
.exam-projection .projection-selected-action::after,
.app-shell .compact-text-mode .exam-projection .projection-selected-action::after {
  content: "";
  position: absolute;
  right: -38px;
  bottom: -54px;
  width: 150px;
  height: 150px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  pointer-events: none;
}
.exam-projection .projection-selected-action span,
.app-shell .compact-text-mode .exam-projection .projection-selected-action span {
  display: inline-flex !important;
  width: fit-content;
  margin-bottom: 7px;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.18) !important;
  color: #fff !important;
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.exam-projection .projection-selected-action strong,
.app-shell .compact-text-mode .exam-projection .projection-selected-action strong {
  color: #fff !important;
  font-size: clamp(30px, 3.2vw, 54px) !important;
  line-height: .92 !important;
}
.exam-projection .projection-selected-action p,
.app-shell .compact-text-mode .exam-projection .projection-selected-action p {
  display: block !important;
  max-width: 760px;
  max-height: none !important;
  margin-top: 8px;
  overflow: visible !important;
  color: rgba(255,255,255,.82) !important;
  font-size: clamp(13px, 1.15vw, 16px) !important;
  line-height: 1.35 !important;
}
.exam-projection .projection-selected-actions,
.app-shell .compact-text-mode .exam-projection .projection-selected-actions {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 9px;
}
.exam-projection .projection-selected-actions .btn.primary {
  background: #fff !important;
  color: var(--red-dark) !important;
  border-color: #fff !important;
  box-shadow: 0 14px 28px rgba(18,24,32,.18);
}
.exam-projection .projection-selected-actions .btn.outline {
  color: #fff !important;
  border-color: rgba(255,255,255,.42) !important;
}
.exam-projection .projection-result {
  position: sticky;
  top: 12px;
}
.exam-projection .projection-hero-date {
  background: linear-gradient(135deg, #fff8f8, #fff);
}
.exam-projection .projection-center-photo-card {
  min-height: 160px;
}

@media (max-width: 980px) {
  .exam-projection .projection-stage,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .projection-stage {
    grid-template-columns: 1fr !important;
  }
  .exam-projection .projection-zone-head {
    grid-template-columns: 1fr;
  }
  .exam-projection .projection-zone-head small {
    justify-self: start;
    text-align: left;
  }
  .exam-projection .reservation-model-card,
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-card,
  .app-shell .compact-text-mode .exam-projection .reservation-model-card {
    grid-template-columns: 132px minmax(0, 1fr) !important;
    min-height: 126px !important;
    align-items: start !important;
  }
  .exam-projection .reservation-model-card p,
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-card p,
  .app-shell .compact-text-mode .exam-projection .reservation-model-card p {
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    max-height: 38px;
    overflow: hidden !important;
  }
  .exam-projection .reservation-model-video,
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-video,
  .app-shell .compact-text-mode .exam-projection .reservation-model-video {
    height: 82px !important;
    min-height: 82px !important;
  }
  .exam-projection .projection-result {
    position: static;
  }
}

@media (max-width: 520px) {
  .app-shell main:has(.compact-details-body.has-active-panel) {
    max-width: 100vw !important;
    padding-inline: 6px !important;
    overflow-x: hidden !important;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details > details,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body,
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.is-app-active.exam-projection {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.is-app-active.exam-projection {
    padding-inline: 12px !important;
  }
  .exam-projection,
  .exam-projection * {
    min-width: 0;
    box-sizing: border-box;
  }
  .exam-projection :where(.projection-head, .projection-stage, .projection-date-zone, .projection-calendar, .projection-date-grid, .projection-selected-action, .reservation-model-card, .reservation-flow-card) {
    width: 100% !important;
    max-width: 100% !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-head {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 8px !important;
    overflow: visible !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-head .eyebrow,
  .app-shell .compact-text-mode .exam-projection .projection-head p:last-child {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-head h2 {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    font-size: clamp(24px, 7vw, 30px) !important;
    line-height: 1.02 !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-zone-head {
    padding: 0 !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-zone-head strong {
    font-size: 20px !important;
    line-height: 1.08 !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-zone-head small {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-zone {
    gap: 9px !important;
  }
  .exam-projection .reservation-model-card,
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-card,
  .app-shell .compact-text-mode .exam-projection .reservation-model-card {
    grid-template-columns: 96px minmax(0, 1fr) !important;
    min-height: 78px !important;
    padding: 8px !important;
  }
  .exam-projection .reservation-model-video,
  .app-shell main:has(.compact-details-body.has-active-panel) .reservation-model-video,
  .app-shell .compact-text-mode .exam-projection .reservation-model-video {
    height: 60px !important;
    min-height: 60px !important;
  }
  .exam-projection .reservation-model-card p,
  .app-shell .compact-text-mode .exam-projection .reservation-model-card p,
  .exam-projection .reservation-model-card span,
  .app-shell .compact-text-mode .exam-projection .reservation-model-card span {
    display: none !important;
  }
  .exam-projection .reservation-model-card strong,
  .app-shell .compact-text-mode .exam-projection .reservation-model-card strong {
    font-size: 14px !important;
  }
  .app-shell .compact-text-mode .exam-projection .reservation-flow-card {
    display: grid !important;
  }
  .exam-projection .reservation-flow-head {
    display: none;
  }
  .exam-projection .reservation-flow-steps {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  .exam-projection .reservation-flow-step {
    min-height: 42px !important;
    padding: 6px !important;
  }
  .exam-projection .reservation-flow-step span {
    display: none;
  }
  .exam-projection .reservation-flow-step strong {
    font-size: 12px;
  }
  .exam-projection .reservation-flow-step:last-child {
    display: none;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar {
    gap: 5px !important;
    padding: 7px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-head {
    gap: 4px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-nav button {
    width: 25px !important;
    height: 25px !important;
    font-size: 13px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-weekdays,
  .app-shell .compact-text-mode .exam-projection .projection-calendar-days {
    gap: 3px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-cell,
  .app-shell .compact-text-mode .exam-projection .projection-calendar-day {
    min-height: 24px !important;
    padding: 2px !important;
    border-radius: 8px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-day strong {
    font-size: 12px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-calendar-day span {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-grid {
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    gap: 12px !important;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .exam-projection .projection-date-grid {
    grid-template-columns: 1fr !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    gap: 12px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card {
    min-height: 132px !important;
    padding: 12px !important;
    overflow: visible !important;
  }
  .app-shell main:has(.compact-details-body.has-active-panel) .compact-text-mode .exam-projection .projection-date-card {
    min-height: 132px !important;
    padding: 12px !important;
    overflow: visible !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card strong {
    font-size: 30px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card .slot-center {
    font-size: 17px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card em {
    font-size: 12px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-date-card .slot-places {
    max-width: 96px;
    white-space: normal;
    text-align: center;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    min-height: 178px !important;
    padding: 14px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-actions .btn.outline {
    display: none !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action p {
    display: block !important;
    margin-top: 6px;
    font-size: 12px !important;
    line-height: 1.3 !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action span {
    display: inline-flex !important;
    margin-bottom: 6px;
    font-size: 9px !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-action strong {
    max-width: 100%;
    overflow: visible;
    white-space: normal;
    text-overflow: clip;
    font-size: clamp(28px, 9vw, 38px) !important;
    line-height: .94 !important;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-actions {
    min-width: 0;
    justify-content: stretch;
    grid-template-columns: 1fr;
  }
  .app-shell .compact-text-mode .exam-projection .projection-selected-actions .btn {
    width: 100%;
    min-height: 40px !important;
    padding-inline: 10px !important;
    font-size: 13px !important;
  }
}

/* Conversational home command surface. */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.ai-home-hero {
  min-height: calc(100dvh - 58px);
  background:
    radial-gradient(circle at 50% 12%, rgba(207,31,50,.09), transparent 32%),
    linear-gradient(180deg, #fff 0%, #f7fbfa 58%, #f5eee6 100%);
  border-bottom: 0;
  color: var(--ink);
}
.ai-home-hero .hero-content {
  width: min(760px, 94vw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  align-items: center;
  justify-items: center;
  color: var(--ink);
}
.ai-home-hero .eyebrow {
  color: var(--red);
}
.ai-home-hero h1 {
  color: var(--ink);
  font-size: clamp(32px, 4.7vw, 56px);
  text-align: center;
}
.ai-home-hero .hero-lead {
  max-width: 520px;
  color: #58616c;
  font-size: clamp(16px, 1.45vw, 20px);
}
.ai-command-surface {
  display: grid;
  gap: 14px;
  width: min(720px, 100%);
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
.ai-command-welcome {
  display: grid;
  gap: 7px;
  margin-bottom: 0;
  text-align: center;
}
.ai-command-welcome .eyebrow {
  margin: 0;
}
.ai-home-hero.has-ai-conversation .ai-command-welcome {
  display: none;
}
.ai-command-welcome p:last-child {
  max-width: 520px;
  margin: 0 auto;
  color: #58616c;
  font-size: 14px;
  line-height: 1.35;
  font-weight: 760;
}
.ai-chat-log {
  display: grid;
  gap: 9px;
  max-height: none;
  min-height: 0;
  overflow: visible;
  padding: 0 3px;
  scroll-behavior: smooth;
}
.ai-chat-log:empty {
  display: none;
}
.ai-chat-message {
  display: grid;
  gap: 4px;
  max-width: min(94%, 590px);
}
.ai-chat-message.assistant {
  max-width: min(100%, 640px);
}
.ai-chat-message span {
  color: #6a737d;
  font-size: 10px;
  font-weight: 760;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.ai-chat-message p {
  margin: 0;
  padding: 12px 14px;
  border-radius: 20px;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
  font-weight: 560;
  white-space: pre-line;
  overflow-wrap: anywhere;
}
.ai-chat-message.assistant {
  justify-self: start;
}
.ai-chat-message.assistant p {
  border: 0;
  padding: 4px 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #1f2732;
  font-size: clamp(14px, 1.15vw, 16px);
  line-height: 1.42;
  font-weight: 500;
}
.ai-chat-message.user {
  justify-self: end;
}
.ai-chat-message.user span {
  text-align: right;
}
.ai-chat-message.user p {
  border-bottom-right-radius: 6px;
  background: var(--red);
  color: #fff;
  font-weight: 650;
}
.ai-command-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 7px;
  border: 1px solid rgba(18,24,32,.10);
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 18px 45px rgba(18,24,32,.12);
}
.ai-command-form input {
  width: 100%;
  min-height: 46px;
  border: 0;
  outline: 0;
  padding: 0 14px;
  background: transparent;
  color: var(--ink);
  font: inherit;
  font-weight: 850;
}
.ai-command-form input::placeholder {
  color: #77818c;
  font-weight: 750;
}
.ai-command-form button,
.ai-command-chips button {
  border: 0;
  cursor: pointer;
  font: inherit;
  font-weight: 950;
}
.ai-command-form button {
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  background: var(--red);
  color: #fff;
}
.ai-command-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  justify-content: center;
}
.ai-command-chips button {
  min-height: 32px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.78);
  color: var(--red-dark);
  box-shadow: inset 0 0 0 1px rgba(18,24,32,.10);
}
.ai-command-chips button:hover {
  box-shadow: inset 0 0 0 2px rgba(207,31,50,.24);
}
.ai-command-answer {
  display: none;
  gap: 6px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.ai-command-answer.is-active {
  display: grid;
  animation: actionPop .22s ease-out;
}
.ai-command-answer span,
.ai-command-answer strong,
.ai-command-answer p {
  display: none;
}
.ai-command-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 0;
}
.ai-command-actions .btn {
  min-height: 38px;
  border-radius: 999px;
}
.app-shell.page-accueil main {
  grid-template-rows: minmax(0, 1fr) auto;
  padding: 0 !important;
  background:
    radial-gradient(circle at 50% 14%, rgba(207,31,50,.07), transparent 31%),
    linear-gradient(180deg, #fff 0%, #f7fbfa 58%, #f5eee6 100%) !important;
}
.app-shell.page-accueil .ai-home-hero {
  display: flex !important;
  grid-column: 1 !important;
  grid-row: 1 !important;
  min-height: calc(100dvh - 58px);
  overflow: hidden;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.app-shell.page-accueil .fast-conversion-bar,
.app-shell.page-accueil .essential-workflow,
.app-shell.page-accueil .compact-details {
  display: none !important;
}
.app-shell.page-accueil .ai-home-hero .hero-content {
  grid-template-columns: minmax(0, 1fr);
  width: min(760px, 100%);
  padding: 22px clamp(16px, 4vw, 38px);
}
.app-shell.page-accueil .ai-home-hero h1 {
  font-size: clamp(30px, 3.8vw, 54px);
}
.app-shell.page-accueil main:has(.compact-details-body.has-active-panel) {
  grid-template-rows: auto minmax(0, 1fr) auto;
}
.app-shell.page-accueil main:has(.compact-details-body.has-active-panel) .ai-home-hero {
  display: none !important;
}
.app-shell.page-accueil main:has(.compact-details-body.has-active-panel) .compact-details {
  display: block !important;
  grid-column: 1 !important;
  grid-row: 2 !important;
}
.app-shell.page-accueil .ai-home-hero .hero-lead {
  font-size: 13px;
  line-height: 1.28;
}
.app-shell.page-accueil .ai-command-form input {
  min-height: 38px;
  font-size: 13px;
}
.app-shell.page-accueil .ai-command-form button {
  min-height: 38px;
  padding-inline: 13px;
  font-size: 13px;
}
.app-shell.page-accueil .ai-command-chips {
  gap: 6px;
}
.app-shell.page-accueil .ai-command-chips button {
  min-height: 29px;
  padding: 6px 9px;
  font-size: 12px;
}
.app-shell.page-accueil .ai-command-answer {
  padding: 10px;
}
@media (max-width: 900px) {
  .app-shell.page-accueil main {
    grid-template-rows: minmax(0, 1fr) auto !important;
  }
  .app-shell.page-accueil .ai-home-hero {
    display: flex !important;
    grid-column: 1 !important;
    grid-row: 1 !important;
    min-height: calc(100dvh - 54px - 47px) !important;
    border-radius: 22px;
    overflow: auto !important;
  }
  .app-shell.page-accueil .fast-conversion-bar,
  .app-shell.page-accueil .essential-workflow {
    display: none !important;
  }
  .ai-home-hero .hero-content {
    grid-template-columns: minmax(0, 1fr);
  }
  .ai-chat-log {
    max-height: none;
    min-height: 0;
    overflow: visible;
  }
}

@media (max-width: 620px) {
  .app-shell.page-accueil main {
    grid-template-rows: minmax(0, 1fr) auto !important;
  }
  .app-shell.page-accueil .ai-home-hero {
    min-height: calc(100dvh - 54px - 47px) !important;
  }
  .app-shell.page-accueil .ai-home-hero .hero-content,
  .ai-home-hero .hero-content {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 14px 12px;
  }
  .ai-home-hero h1 {
    font-size: clamp(27px, 7.4vw, 38px);
  }
  .ai-command-form {
    grid-template-columns: 1fr auto;
    padding: 6px;
  }
  .ai-command-welcome p:last-child {
    font-size: 12px;
  }
  .ai-chat-log {
    max-height: none;
    min-height: 0;
    overflow: visible;
    gap: 7px;
  }
  .ai-chat-message {
    max-width: 96%;
  }
  .ai-chat-message p {
    padding: 9px 10px;
    font-size: 12px;
  }
  .ai-chat-message.assistant p {
    padding: 3px 0;
    font-size: 14px;
    line-height: 1.4;
  }
  .ai-command-form input {
    min-height: 38px;
    padding-inline: 10px;
    font-size: 13px;
  }
  .ai-command-form button {
    min-height: 38px;
    padding-inline: 12px;
    font-size: 12px;
  }
  .ai-command-chips {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
  }
  .ai-command-chips button {
    min-width: 0;
    min-height: 32px;
    padding: 6px 5px;
    font-size: 11px;
    white-space: normal;
  }
  .ai-command-answer {
    padding: 0;
  }
  .ai-command-actions .btn {
    flex: 1 1 120px;
    min-height: 34px;
    padding: 7px 8px;
    font-size: 12px;
  }
}

/* Final booking surface: no decorative backplate behind the reservation journey. */
.exam-projection button.reservation-model-video,
.app-shell main:has(.compact-details-body.has-active-panel) button.reservation-model-video,
.app-shell .compact-text-mode .exam-projection button.reservation-model-video {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 104px !important;
  height: 104px !important;
  padding: 0 !important;
  overflow: hidden !important;
  border: 2px solid #f1b42b !important;
  border-radius: 18px !important;
  background: #080b0d !important;
  cursor: pointer !important;
  box-shadow: 0 10px 24px rgba(18,24,32,.10) !important;
}
.exam-projection button.reservation-model-video img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  filter: saturate(1.05) contrast(1.03) brightness(.72) !important;
}
.exam-projection button.reservation-model-video::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(0,0,0,.06), rgba(0,0,0,.62)) !important;
}
.exam-projection button.reservation-model-video::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  width: 44px !important;
  height: 44px !important;
  transform: translate(-50%, -50%) !important;
  border-radius: 50% !important;
  background: var(--red) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.28) !important;
}
.exam-projection button.reservation-model-video span,
.app-shell .compact-text-mode .exam-projection button.reservation-model-video span {
  position: absolute !important;
  left: 10px !important;
  right: 10px !important;
  bottom: 9px !important;
  z-index: 2 !important;
  display: block !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  line-height: 1.1 !important;
  letter-spacing: 0 !important;
  text-align: center !important;
  text-transform: none !important;
}
body.has-video-modal {
  overflow: hidden !important;
}
.jour-j-video-modal {
  place-items: stretch !important;
  padding: 0 !important;
  background: rgba(3, 5, 7, .94) !important;
  backdrop-filter: blur(12px) !important;
}
.jour-j-video-shell {
  position: relative !important;
  display: grid !important;
  grid-template-rows: auto minmax(0, 1fr) auto !important;
  align-items: center !important;
  justify-items: center !important;
  gap: 12px !important;
  width: 100vw !important;
  height: 100dvh !important;
  max-height: 100dvh !important;
  padding: max(14px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(14px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left)) !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: #050708 !important;
  box-shadow: none !important;
}
.jour-j-video-title {
  max-width: min(760px, calc(100vw - 120px)) !important;
  color: #fff !important;
  font-size: clamp(15px, 2vw, 22px) !important;
  line-height: 1.1 !important;
  text-align: center !important;
}
.jour-j-video-shell video {
  width: min(100%, calc((100dvh - 118px) * 16 / 9)) !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: calc(100dvh - 118px) !important;
  border-radius: 10px !important;
  background: #000 !important;
  object-fit: contain !important;
  box-shadow: 0 24px 80px rgba(0,0,0,.36) !important;
}
.jour-j-video-shell p {
  max-width: min(760px, calc(100vw - 40px)) !important;
  margin: 0 !important;
  color: rgba(255,255,255,.78) !important;
  font-size: clamp(12px, 1.6vw, 15px) !important;
  font-weight: 750 !important;
  line-height: 1.3 !important;
  text-align: center !important;
}
.jour-j-video-close {
  position: absolute !important;
  top: max(12px, env(safe-area-inset-top)) !important;
  right: max(12px, env(safe-area-inset-right)) !important;
  z-index: 3 !important;
  min-height: 38px !important;
  border-color: rgba(255,255,255,.2) !important;
  background: rgba(255,255,255,.08) !important;
}
@media (orientation: portrait) {
  .jour-j-video-shell {
    grid-template-rows: auto minmax(0, 1fr) auto !important;
  }
  .jour-j-video-shell video {
    width: 100% !important;
    height: calc(100dvh - 118px) !important;
    max-height: calc(100dvh - 118px) !important;
  }
}
@media (max-width: 520px) {
  .exam-projection button.reservation-model-video,
  .app-shell main:has(.compact-details-body.has-active-panel) button.reservation-model-video,
  .app-shell .compact-text-mode .exam-projection button.reservation-model-video {
    height: 60px !important;
    min-height: 60px !important;
    border-radius: 14px !important;
  }
  .exam-projection button.reservation-model-video::after {
    width: 34px !important;
    height: 34px !important;
  }
  .exam-projection button.reservation-model-video span,
  .app-shell .compact-text-mode .exam-projection button.reservation-model-video span {
    display: none !important;
  }
  .jour-j-video-title {
    padding-right: 70px !important;
    max-width: 100% !important;
    text-align: left !important;
    justify-self: stretch !important;
  }
  .jour-j-video-shell {
    gap: 8px !important;
  }
}
.exam-projection,
.app-shell .compact-details-body > section.exam-projection,
.app-shell .compact-details-body.has-active-panel > section.is-app-active.exam-projection,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.is-app-active.exam-projection,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.exam-projection {
  border-color: transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}
.app-shell .compact-details-body > section.exam-projection::before,
.app-shell main:has(.compact-details-body.has-active-panel) .compact-details-body > section.exam-projection::before {
  content: none !important;
  display: none !important;
}
