:root {
  --fr-blue: #000091;
  --fr-red: #E1000F;
  --ink: #161616;
  --muted: #666666;
  --white: #ffffff;
  --paper: #ffffff;
  --soft-bg: #f7f7f7;
  --bg: #f7f7f7;
  --navy: #07123F;
  --deep-navy: #06111F;
  --blue: #000091;
  --red: #E1000F;
  --deep-blue: #07123F;
  --border: #dddddd;
  --line: #dddddd;
  --soft-blue: var(--soft-bg);
  --success: #0B6B2D;
  --success-ink: var(--success);
  --success-bg: #FFFFFF;
  --warning: #A15C00;
  --danger: #E1000F;
  --danger-ink: var(--danger);
  --danger-bg: #FFFFFF;
  --danger-border: rgba(225, 0, 15, 0.22);
  --green: var(--success);
  --shadow: 0 10px 24px rgba(0, 0, 145, 0.08);
  --shadow-soft: 0 16px 42px rgba(7, 18, 63, 0.07);
  --shadow-hover: 0 22px 54px rgba(7, 18, 63, 0.12);
  --container-max: 1180px;
  --section-y: clamp(72px, 8vw, 112px);
  --section-y-compact: clamp(56px, 6vw, 88px);
  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 22px;
  --radius-xl: 24px;
  --radius-pill: 999px;
  --tricolor-bar: linear-gradient(90deg, var(--fr-blue) 0 33.333%, var(--white) 33.333% 66.666%, var(--fr-red) 66.666% 100%);
  --tricolor-bar-light: linear-gradient(90deg, var(--fr-blue) 0 33.333%, var(--soft-bg) 33.333% 66.666%, var(--fr-red) 66.666% 100%);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  overflow-x: hidden;
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
  background: var(--bg);
  line-height: 1.55;
}

body.admin-page {
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid rgba(226, 0, 26, 0.55);
  outline-offset: 3px;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

img {
  display: block;
  width: 100%;
}

.tricolor-bar,
.tricolor-kicker {
  display: block;
  border-radius: 999px;
  background: var(--tricolor-bar);
  box-shadow: 0 8px 24px rgba(0, 0, 145, 0.12);
}

.tricolor-bar {
  width: 100%;
  height: 4px;
}

.tricolor-bar.on-light,
.tricolor-kicker {
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
}

.tricolor-kicker {
  width: 72px;
  height: 4px;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 12px clamp(18px, 5vw, 72px);
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 1px 0 rgba(7, 18, 63, 0.05);
  backdrop-filter: blur(14px);
  transition: padding 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.site-header::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: var(--tricolor-bar);
  box-shadow: 0 1px 0 rgba(7, 18, 63, 0.08);
}

.site-header.is-scrolled {
  padding-top: 9px;
  padding-bottom: 9px;
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 16px 42px rgba(7, 18, 63, 0.08);
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  max-width: 320px;
  flex-shrink: 0;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  color: var(--blue);
  font-weight: 900;
  background: #fff;
  border-radius: var(--radius-md);
  border: 1px solid rgba(0, 0, 145, 0.14);
  box-shadow: 0 10px 24px rgba(0, 0, 145, 0.12);
  text-shadow: none;
  overflow: hidden;
}

.brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.brand strong,
.brand small {
  display: block;
}

.brand strong {
  color: #171717;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
  text-transform: none;
}

.brand strong span {
  color: var(--red);
}

.brand small {
  color: var(--muted);
  max-width: 250px;
  font-size: clamp(9px, 0.7vw, 10.5px);
  font-weight: 800;
  line-height: 1.2;
  white-space: nowrap;
}

.site-nav {
  display: flex;
  justify-content: center;
  gap: clamp(12px, 2vw, 26px);
  color: var(--ink);
  font-size: 14px;
  font-weight: 800;
}

.site-nav a {
  position: relative;
  padding: 8px 0;
}

.site-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
  height: 3px;
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: var(--radius-pill);
  background: var(--tricolor-bar-light);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 0.18s ease;
}

.site-nav a:hover::after,
.site-nav a[aria-current="page"]::after {
  transform: scaleX(1);
}

.site-nav a[aria-current="page"] {
  color: var(--navy);
}

.site-nav a:hover {
  color: var(--fr-blue);
}

.contact-cta:hover,
.client-cta:hover,
.header-cta:hover {
  color: var(--red);
}

.header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  white-space: nowrap;
}

.contact-cta,
.client-cta,
.header-cta {
  min-height: 42px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--navy);
  font-weight: 900;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
}

.client-cta {
  border-color: rgba(0, 0, 145, 0.24);
  background: #fff;
}

.header-cta {
  color: #fff;
  background: var(--fr-red);
  border-color: var(--fr-red);
  box-shadow: 0 12px 28px rgba(0, 0, 145, 0.14);
}

.header-cta:hover,
.header-cta:focus-visible,
.header-cta:active,
.header-cta:visited {
  color: #fff;
  background: var(--fr-red);
  border-color: var(--fr-red);
}

.header-cta:hover {
  box-shadow: 0 14px 30px rgba(225, 0, 15, 0.18);
}

.client-page .header-cta {
  color: var(--navy);
  background: #fff;
  border-color: var(--line);
}

.client-page .header-cta:hover {
  color: var(--red);
  background: #fff;
  border-color: rgba(226, 0, 26, 0.28);
}

.nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  padding: 0;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
}

.nav-toggle span {
  display: block;
  width: 18px;
  height: 2px;
  margin: 4px auto;
  background: var(--navy);
}

.hero {
  display: grid;
  grid-template-columns: minmax(0, 760px) 1fr;
  gap: clamp(18px, 5vw, 72px);
  align-items: center;
  min-height: clamp(620px, 78vh, 760px);
  padding: clamp(46px, 7vw, 78px) clamp(18px, 5vw, 72px) clamp(34px, 5vw, 52px);
  background:
    linear-gradient(90deg, rgba(5, 18, 38, 0.94), rgba(5, 18, 38, 0.62) 48%, rgba(5, 18, 38, 0.18)),
    var(--hero-image, url("/assets/images/home/hero-juridex-paris-office.png")) center right / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
  border-bottom: 0;
  position: relative;
  overflow: hidden;
}

.hero::after {
  content: none;
  display: none;
}

.hero-copy {
  position: relative;
  z-index: 1;
  min-width: 0;
  max-width: 760px;
  color: #fff;
}

.hero .notice {
  margin-bottom: 14px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 14px;
  font-weight: 800;
  text-transform: none;
}

.france-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding: 7px 11px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  background: rgba(0, 0, 0, 0.34);
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 4px;
}

.france-chip::before,
.audience-grid article::before,
.timing-panel::before,
.consultation-cards article::before,
.legal-limit-grid article::before {
  content: "";
  display: inline-block;
  width: 26px;
  height: 16px;
  flex: 0 0 auto;
  background: var(--tricolor-bar);
  border: 1px solid rgba(0, 0, 0, 0.18);
  border-radius: 2px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.16);
}

.brand-service-chip {
  color: var(--navy);
  background: rgba(255, 255, 255, 0.94);
  border-color: rgba(255, 255, 255, 0.72);
}

.brand-service-chip::before {
  width: 28px;
  height: 28px;
  background: url("/assets/brand/juridex-logo.png") center / contain no-repeat;
  border: 0;
  border-radius: 8px;
  box-shadow: none;
}

.brand-service-icon {
  display: grid;
  width: 58px;
  height: 58px;
  margin-bottom: 16px;
  place-items: center;
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.14);
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(7, 18, 63, 0.1);
}

.brand-service-icon img {
  display: block;
  width: 38px;
  height: 38px;
  object-fit: contain;
}

.brand-service-icon-cta {
  margin-bottom: 18px;
}

.notice,
.eyebrow,
.section-heading p {
  margin: 0 0 12px;
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  min-width: 0;
  max-width: 980px;
  margin-bottom: 16px;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02;
  overflow-wrap: normal;
}

.hero h1 {
  max-width: 900px;
  font-size: clamp(40px, 4.05vw, 54px);
}

.hero-title-line {
  display: block;
  width: max-content;
  max-width: 100%;
  white-space: nowrap;
}

h2 {
  margin-bottom: 14px;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.05;
}

h3 {
  margin-bottom: 10px;
  font-size: 21px;
}

.hero-text {
  max-width: 690px;
  color: rgba(255, 255, 255, 0.9);
  font-size: 18px;
}

.hero-actions,
.document-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.hero-premium-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 780px;
  margin-top: 24px;
}

.hero-premium-grid article {
  position: relative;
  min-width: 0;
  padding: 16px 18px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.14);
  backdrop-filter: blur(10px);
}

.hero-premium-grid article::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: var(--tricolor-bar);
}

.hero-premium-grid strong,
.hero-premium-grid span {
  display: block;
  color: #fff;
}

.hero-premium-grid strong {
  margin-bottom: 5px;
  font-size: 0.92rem;
  font-weight: 950;
  line-height: 1.2;
}

.hero-premium-grid span {
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.82rem;
  line-height: 1.42;
}

.hero-reassurance-line {
  margin: 18px 0 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0;
}

.hero-mini-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  max-width: 720px;
  margin-top: 22px;
}

.hero-mini-proof {
  min-width: 0;
  padding: 16px 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.09);
  backdrop-filter: blur(10px);
}

.hero-mini-proof strong {
  display: block;
  margin-bottom: 5px;
  color: var(--navy);
  font-size: 15px;
  font-weight: 950;
  line-height: 1.2;
}

.hero-mini-proof span {
  display: block;
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  line-height: 1.45;
}

.button,
.price-card a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 20px;
  border: 1px solid transparent;
  border-radius: var(--radius-pill);
  font-weight: 900;
  text-align: center;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.button.primary,
.price-card.featured a {
  color: #fff;
  background: var(--blue);
  box-shadow: none;
}

.button.primary:hover,
.button.primary:focus-visible,
.button.primary:active,
.button.primary:visited,
.price-card.featured a:hover {
  color: #fff;
  background: var(--navy);
}

#accueil .hero .button.primary,
#accueil .final-cta-section .button.primary {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

#accueil .hero .button.primary:hover,
#accueil .hero .button.primary:focus-visible,
#accueil .hero .button.primary:active,
#accueil .hero .button.primary:visited,
#accueil .final-cta-section .button.primary:hover,
#accueil .final-cta-section .button.primary:focus-visible,
#accueil .final-cta-section .button.primary:active,
#accueil .final-cta-section .button.primary:visited {
  color: #fff;
  background: var(--fr-red);
  border-color: var(--fr-red);
}

.button.secondary,
.price-card a {
  color: var(--navy);
  background: #fff;
  border-color: var(--blue);
}

.button.danger {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.button.danger:hover {
  background: var(--fr-red);
  border-color: var(--fr-red);
}

.inline-link {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  color: var(--navy);
  font-weight: 900;
  border-bottom: 2px solid rgba(0, 0, 145, 0.18);
  transition: color 0.18s ease, border-color 0.18s ease;
}

.inline-link:hover {
  color: var(--red);
  border-color: var(--red);
}

.metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 26px;
}

.metrics span {
  min-width: 158px;
  max-width: 238px;
  padding: 12px 14px;
  color: #fff;
  font-size: 13px;
  line-height: 1.32;
  background: rgba(255, 255, 255, 0.085);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 4px;
  box-shadow: inset 4px 0 0 var(--red);
}

.metrics strong {
  display: block;
  color: #fff;
  margin-bottom: 3px;
  font-size: 13px;
  line-height: 1.15;
  text-transform: uppercase;
}

.hero-panel,
.booking-form,
.automation-form,
.automation-result,
.client-console {
  padding: 24px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 4px;
  box-shadow: var(--shadow);
}

.hero-panel {
  border-top: 5px solid transparent;
}

.panel-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.panel-top span {
  color: var(--blue);
  font-weight: 900;
}

label {
  display: grid;
  gap: 7px;
  margin-bottom: 14px;
  color: var(--ink);
  font-size: 14px;
  font-weight: 900;
}

label small {
  color: var(--muted);
  font-weight: 700;
}

fieldset {
  min-width: 0;
  margin: 0 0 18px;
  padding: 0;
  border: 0;
}

.dossier-fieldset {
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
}

.dossier-fieldset legend {
  padding: 0 0 12px;
  color: var(--navy);
  font-weight: 900;
}

.form-grid.compact {
  gap: 12px;
}

input,
select,
textarea {
  width: 100%;
  min-height: 46px;
  padding: 11px 12px;
  color: var(--ink);
  background: #fff;
  border: 1px solid #b8b8b8;
  border-radius: 4px;
}

textarea {
  resize: vertical;
}

.recommendation {
  margin: 18px 0;
  padding: 16px;
  background: var(--soft-blue);
  border: 1px solid var(--border);
  border-left: 1px solid var(--border);
  border-radius: 4px;
}

.recommendation span {
  display: block;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.recommendation strong {
  display: block;
  margin: 4px 0 5px;
}

.recommendation p,
.panel-note {
  margin-bottom: 0;
  color: var(--muted);
  font-size: 14px;
}

.section {
  padding: clamp(62px, 7vw, 88px) clamp(18px, 5vw, 72px);
}

.page-hero {
  padding: clamp(58px, 8vw, 108px) clamp(18px, 5vw, 72px);
  color: #fff;
  background:
    linear-gradient(90deg, rgba(4, 12, 24, 0.9), rgba(4, 12, 24, 0.68)),
    var(--hero-image, url("/assets/images/home/hero-juridex-paris-office.png")) center / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
  border-bottom: 6px solid transparent;
}

.page-hero h1 {
  max-width: 980px;
}

.page-hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 19px;
}

.page-hero--image {
  min-height: clamp(460px, 58vh, 620px);
  display: grid;
  align-content: center;
  background:
    linear-gradient(90deg, rgba(6, 17, 31, 0.94), rgba(6, 17, 31, 0.7), rgba(6, 17, 31, 0.22)),
    var(--page-hero-image, url("/assets/images/home/hero-juridex-paris-office.png")) center right / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
}

.page-hero--consultations,
.page-hero--tarifs {
  --page-hero-image: url("/assets/images/home/consultations-juridex-client.png");
}

.page-hero--faq,
.page-hero--security {
  --page-hero-image: url("/assets/images/home/questions-frequentes-juridex.png");
}

.page-hero--demarches,
.page-hero--process,
.page-hero--diagnostic {
  --page-hero-image: url("/assets/images/home/comment-ca-marche-juridex.png");
}

.page-hero--zones {
  --page-hero-image: url("/assets/images/home/zones-ile-de-france-paris.png");
}

.page-hero--reviews {
  --page-hero-image: url("/assets/images/home/avis-clients-juridex.png");
}

.page-hero--contact {
  --page-hero-image: url("/assets/images/home/questions-frequentes-juridex.png");
}

.page-hero .hero-actions {
  margin-top: 24px;
}

.page-hero .button.primary {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.page-hero .button.primary:hover {
  background: var(--fr-red);
  border-color: var(--fr-red);
}

.page-hero .button.secondary {
  color: var(--navy);
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(255, 255, 255, 0.88);
}

.page-hero .hero-reassurance-line {
  margin-top: 18px;
  color: rgba(255, 255, 255, 0.84);
}

.section-header,
.section-heading {
  max-width: 760px;
}

.section-title,
.section-heading h2 {
  color: var(--navy);
}

.section-subtitle,
.section-intro {
  color: var(--muted);
}

.tricolor-kicker {
  display: block;
  width: 72px;
  height: 4px;
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: var(--radius-pill);
  box-shadow: 0 8px 24px rgba(0, 0, 145, 0.1);
}

.premium-card,
.premium-form {
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.11);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.contact-page-hero {
  min-height: clamp(520px, 68vh, 680px);
  display: grid;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(6, 17, 31, 0.95), rgba(6, 17, 31, 0.72), rgba(6, 17, 31, 0.24)),
    url("/assets/images/home/questions-frequentes-juridex.png") center right / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
}

.contact-hero-copy {
  max-width: 760px;
}

.contact-hero-subtitle {
  margin-top: 8px;
  margin-bottom: 12px;
  color: #fff !important;
  font-size: clamp(22px, 3vw, 32px) !important;
  font-weight: 900;
  line-height: 1.15;
}

.contact-page-hero .hero-actions {
  margin-top: 24px;
}

.contact-page-hero .button.primary {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.contact-page-hero .button.secondary {
  color: var(--navy);
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(255, 255, 255, 0.86);
}

.contact-page-hero .hero-reassurance-line {
  margin-top: 18px;
  color: rgba(255, 255, 255, 0.84);
}

.contact-method-section,
.contact-faq-section {
  background: #fff;
}

.contact-form-section,
.contact-upsell-section {
  background: var(--soft-bg);
}

.contact-method-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.contact-method-grid article,
.contact-advice-card,
.contact-form,
.contact-upsell-card {
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.11);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.contact-method-grid article {
  position: relative;
  padding: 24px;
  overflow: hidden;
}

.contact-method-grid article::before {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-bottom: 18px;
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: var(--radius-pill);
}

.contact-method-grid strong,
.contact-advice-card h2,
.contact-upsell-card h2 {
  color: var(--navy);
}

.contact-method-grid p,
.contact-advice-card p,
.contact-upsell-card p,
.form-helper {
  color: var(--muted);
}

.contact-form-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(24px, 4vw, 52px);
  align-items: start;
}

.contact-advice-card {
  position: sticky;
  top: 96px;
  padding: 28px;
}

.contact-advice-card > span,
.contact-upsell-card span {
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.contact-page .booking-form {
  max-width: none;
}

.contact-form {
  padding: clamp(22px, 3vw, 32px);
}

.form-helper {
  margin: 0 0 18px;
  font-weight: 800;
}

.form-helper.compact {
  margin-top: 12px;
  margin-bottom: 12px;
  font-size: 14px;
  font-weight: 700;
}

.contact-payment-required {
  margin: 18px 0;
  padding: 22px;
  border: 1px solid rgba(225, 0, 15, 0.22);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(247, 247, 247, 0.94)),
    #fff;
  box-shadow: 0 18px 42px rgba(7, 18, 63, 0.10);
}

.contact-payment-required span {
  color: var(--red);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.contact-payment-required h3 {
  margin: 8px 0 10px;
  color: var(--navy);
}

.contact-payment-required p {
  margin: 0 0 16px;
  color: var(--muted);
  font-weight: 700;
}

.consent-line {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 14px;
  color: var(--ink);
  font-weight: 800;
}

.consent-line input {
  width: auto;
  min-height: 0;
  margin-top: 5px;
  accent-color: var(--blue);
}

.contact-upsell-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: clamp(24px, 4vw, 38px);
}

.contact-upsell-card p {
  max-width: 680px;
}

.contact-final-cta {
  background:
    linear-gradient(135deg, rgba(7, 18, 63, 0.96), rgba(0, 0, 145, 0.9)),
    var(--navy);
}

.contact-final-cta h2,
.contact-final-cta p {
  color: #fff;
}

.contact-final-cta p {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.82);
}

.contact-final-cta .button.primary {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.contact-final-cta .button.secondary {
  color: var(--navy);
  background: #fff;
  border-color: #fff;
}

.legal-notice-hero {
  background:
    linear-gradient(90deg, rgba(6, 17, 31, 0.94), rgba(6, 17, 31, 0.7), rgba(6, 17, 31, 0.28)),
    url("/assets/images/home/questions-frequentes-juridex.png") center right / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
}

.legal-notice-section {
  display: grid;
  grid-template-columns: minmax(260px, 0.34fr) minmax(0, 1fr);
  gap: clamp(24px, 4vw, 54px);
  align-items: start;
  background: var(--soft-bg);
}

.legal-summary-card,
.legal-block {
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.11);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.legal-summary-card {
  position: sticky;
  top: 96px;
  padding: 24px;
}

.legal-summary-card strong {
  display: block;
  color: var(--navy);
  font-size: 22px;
}

.legal-summary-card p {
  color: var(--muted);
}

.legal-summary-card nav {
  display: grid;
  gap: 8px;
  margin-top: 18px;
}

.legal-summary-card a {
  padding: 10px 12px;
  color: var(--navy);
  font-weight: 900;
  background: var(--soft-bg);
  border: 1px solid rgba(0, 0, 145, 0.08);
  border-radius: var(--radius-sm);
}

.legal-notice-content {
  display: grid;
  gap: 18px;
}

.legal-block {
  padding: clamp(22px, 3vw, 34px);
}

.legal-block h2 {
  margin-bottom: 14px;
  color: var(--navy);
  font-size: clamp(24px, 3vw, 34px);
}

.legal-block p {
  color: var(--ink);
}

.legal-data-list {
  display: grid;
  gap: 10px;
  margin: 18px 0;
}

.legal-data-list div {
  display: grid;
  grid-template-columns: minmax(150px, 0.32fr) minmax(0, 1fr);
  gap: 12px;
  padding: 12px 14px;
  background: var(--soft-bg);
  border: 1px solid rgba(0, 0, 145, 0.08);
  border-radius: var(--radius-md);
}

.legal-data-list dt {
  color: var(--muted);
  font-weight: 900;
}

.legal-data-list dd {
  margin: 0;
  color: var(--navy);
  font-weight: 900;
}

@media (max-width: 860px) {
  .contact-page-hero {
    min-height: auto;
    padding-top: 88px;
    padding-bottom: 72px;
    background-position: center;
  }

  .contact-method-grid,
  .contact-form-layout {
    grid-template-columns: 1fr;
  }

  .contact-advice-card {
    position: static;
  }

  .contact-upsell-card,
  .contact-final-cta {
    flex-direction: column;
    align-items: flex-start;
  }

  .legal-notice-section,
  .legal-data-list div {
    grid-template-columns: 1fr;
  }

  .legal-summary-card {
    position: static;
  }
}

.homepage-diagnostic-preview,
.homepage-booking-preview {
  background: #fff;
}

.preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.preview-grid article,
.booking-preview-panel {
  padding: 22px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 5px solid transparent;
  border-radius: 4px;
}

.preview-grid article:nth-child(2) {
  border-top-color: transparent;
}

.preview-grid strong,
.booking-preview-panel strong {
  display: block;
  color: var(--navy);
  font-size: 20px;
}

.preview-grid p,
.booking-preview-panel p {
  margin: 8px 0 0;
  color: var(--muted);
}

.preview-actions,
.booking-preview-panel {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  margin-top: 22px;
}

.trust-bar {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  padding: 0 clamp(18px, 5vw, 72px);
  color: var(--navy);
  background: #fff;
  border-top: 1px solid rgba(5, 18, 38, 0.1);
  border-bottom: 1px solid rgba(5, 18, 38, 0.12);
  box-shadow: 0 14px 28px rgba(5, 18, 38, 0.12);
}

.trust-bar span {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-content: center;
  row-gap: 3px;
  min-height: 82px;
  padding: 16px clamp(16px, 2.5vw, 28px);
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.trust-bar span:nth-child(1) {
  color: #fff;
  background: linear-gradient(135deg, var(--fr-blue) 0%, var(--navy) 100%);
}

.trust-bar span:nth-child(2) {
  color: var(--navy);
  background: linear-gradient(135deg, #ffffff 0%, var(--soft-bg) 100%);
}

.trust-bar span:nth-child(3) {
  color: #fff;
  background: linear-gradient(135deg, var(--fr-red) 0%, var(--fr-red) 100%);
}

.trust-bar span::before {
  content: none;
}

.trust-bar span:nth-child(2)::before {
  content: none;
}

.trust-bar span:hover {
  transform: none;
  box-shadow: none;
}

.trust-bar strong,
.trust-bar small {
  display: block;
  min-width: 0;
}

.trust-bar strong {
  font-size: 13px;
  font-weight: 950;
  line-height: 1.15;
}

.trust-bar small {
  color: rgba(255, 255, 255, 0.84);
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
}

.trust-bar span:nth-child(2) strong {
  color: var(--navy);
}

.trust-bar span:nth-child(2) small {
  color: rgba(5, 18, 38, 0.72);
}

.client-stats-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  padding: 0 clamp(18px, 5vw, 72px) 1px;
  background: var(--border);
}

.client-stats-strip article {
  padding: 22px 18px;
  background: #fff;
  border-bottom: 4px solid transparent;
  border-image: var(--tricolor-bar-light) 1;
}

.client-stats-strip article:nth-child(even) {
  border-bottom-color: transparent;
}

.client-stats-strip strong {
  display: block;
  color: var(--navy);
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1;
}

.client-stats-strip span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-weight: 900;
}

.audience-section {
  background: #fff;
}

.audience-grid,
.legal-limit-grid,
.consultation-cards,
.comparison-grid,
.solution-card-grid,
.client-value-grid,
.zone-overview-grid {
  display: grid;
  gap: 18px;
}

.audience-grid,
.client-value-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.solution-card-grid,
.zone-overview-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-feature-photo {
  display: block;
  overflow: hidden;
  margin: 28px 0 30px;
  background: var(--navy);
  border-radius: 24px;
  box-shadow: 0 24px 70px rgba(5, 18, 38, 0.18);
}

.home-feature-photo img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 300px;
  max-height: 420px;
  object-fit: cover;
}

.home-feature-photo-consultations img {
  object-position: center center;
}

.offer-intro-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(320px, 0.72fr);
  gap: 28px;
  align-items: center;
  margin-bottom: 30px;
}

.offer-intro-copy {
  display: grid;
  align-content: center;
}

.offer-intro-layout .section-heading {
  margin-bottom: 0;
}

.offer-intro-layout .section-intro {
  margin-top: 4px;
  margin-bottom: 0;
}

.offer-intro-layout .home-feature-photo {
  height: 100%;
  min-height: 320px;
  margin: 0;
}

.offer-intro-layout .home-feature-photo img {
  min-height: 300px;
  max-height: 360px;
}

.client-secure-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.92fr) minmax(0, 1fr);
  gap: 22px;
  align-items: stretch;
}

.client-secure-layout .home-feature-photo {
  height: 100%;
  min-height: 100%;
  margin: 0;
}

.client-secure-layout .home-feature-photo img {
  min-height: 100%;
  max-height: 420px;
}

.client-secure-layout .client-value-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-split-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}

.home-split-section.reverse {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1fr);
}

.home-split-section.reverse .section-media {
  order: 1;
}

.home-split-section.reverse .section-copy {
  order: 2;
}

.section-copy {
  min-width: 0;
}

.section-copy .section-heading {
  margin-bottom: 20px;
}

.section-media {
  display: block;
  overflow: hidden;
  margin: 0;
  background: var(--navy);
  border-radius: 24px;
  box-shadow: 0 24px 70px rgba(5, 18, 38, 0.18);
}

.section-media img {
  width: 100%;
  height: clamp(300px, 30vw, 420px);
  object-fit: cover;
  object-position: center center;
}

.home-split-section .audience-grid,
.home-split-section .process-grid,
.home-split-section .comparison-grid,
.home-split-section .legal-limit-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-split-section .legal-limit-grid {
  margin-top: 18px;
}

.home-split-section .preview-actions {
  justify-content: flex-start;
}

.faq-section .home-split-section {
  align-items: start;
}

.faq-section .section-media img {
  height: clamp(300px, 30vw, 430px);
  object-position: left center;
}

.section-vector {
  position: relative;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  margin: 0 0 14px;
  background: var(--visual-soft, #F7F7F7);
  border: 1px solid rgba(0, 0, 145, 0.08);
  border-radius: 16px;
}

.section-vector svg {
  display: block;
  width: 42px;
  height: 32px;
}

.audience-grid article:has(.section-vector)::before,
.legal-limit-grid article:has(.section-vector)::before {
  display: none;
}

.audience-grid article,
.legal-limit-grid article,
.comparison-grid article,
.client-value-grid article,
.zone-overview-grid article,
.price-card,
.task-grid article {
  overflow: hidden;
}

.zone-overview-grid article {
  display: grid;
  gap: 14px;
  overflow: hidden;
}

.zone-overview-media {
  display: block;
  position: relative;
  overflow: hidden;
  width: calc(100% + 48px);
  margin: -24px -24px 2px;
  aspect-ratio: 16 / 9;
  background: var(--navy);
}

.zone-overview-media::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(180deg, rgba(5, 18, 38, 0.02), rgba(5, 18, 38, 0.24));
}

.zone-overview-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.audience-grid article,
.legal-limit-grid article,
.consultation-cards article,
.comparison-grid article,
.solution-card-grid article,
.client-value-grid article,
.zone-overview-grid article,
.timing-panel {
  padding: 24px;
  background: linear-gradient(180deg, #fff, #FFFFFF);
  border: 1px solid rgba(0, 0, 145, 0.11);
  border-radius: 6px;
  box-shadow: var(--shadow-soft);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.audience-grid article {
  border-top: 5px solid transparent;
}

.audience-grid article:nth-child(even) {
  border-top-color: transparent;
}

.audience-grid article::before,
.legal-limit-grid article::before,
.consultation-cards article::before {
  margin-bottom: 16px;
}

.audience-grid strong,
.audience-grid h3,
.timing-panel strong,
.legal-limit-grid strong,
.client-value-grid h3,
.solution-card-grid strong,
.client-value-grid strong,
.zone-overview-grid strong {
  display: block;
  color: var(--navy);
  font-size: 19px;
}

.audience-grid h3,
.client-value-grid h3 {
  margin-bottom: 8px;
  line-height: 1.12;
}

.audience-grid p,
.timing-panel p,
.legal-limit-grid p,
.comparison-grid p,
.solution-card-grid p,
.client-value-grid p,
.zone-overview-grid p {
  margin: 8px 0 0;
  color: var(--muted);
}

.audience-grid a,
.formality-card em {
  display: inline-flex;
  margin-top: 12px;
  color: var(--blue);
  font-style: normal;
  font-weight: 900;
}

@media (hover: hover) {
  .audience-grid article:hover,
  .legal-limit-grid article:hover,
  .consultation-cards article:hover,
  .comparison-grid article:hover,
  .solution-card-grid article:hover,
  .client-value-grid article:hover,
  .zone-overview-grid article:hover,
  .process-grid article:hover,
  .price-card:hover,
  .locations-grid article:hover,
  .faq-list details:hover {
    transform: translateY(-3px);
    border-color: rgba(0, 0, 145, 0.22);
    box-shadow: var(--shadow-hover);
  }

  .button:hover,
  .price-card a:hover {
    transform: translateY(-1px);
  }
}

.timing-section,
.comparison-section,
.zones-preview-section {
  background: var(--soft-blue);
}

.solution-section,
.final-cta-section {
  background: #fff;
}

.timing-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.55fr);
  gap: 22px;
  align-items: stretch;
}

.timing-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.timing-list span {
  display: flex;
  align-items: center;
  min-height: 58px;
  padding: 12px 14px;
  color: var(--navy);
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
  box-shadow: var(--shadow-soft);
}

.timing-list span:nth-child(3n + 1) {
  border-left-color: var(--line);
}

.compact-list {
  margin-top: 22px;
}

#accueil .timing-list.compact-list {
  display: grid;
  grid-column: 1 / -1;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0;
  width: 100%;
  margin-top: 2px;
  overflow: hidden;
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: var(--radius-lg);
  box-shadow: 0 16px 34px rgba(7, 18, 63, 0.1);
}

#accueil .timing-list.compact-list span {
  justify-content: center;
  min-height: 52px;
  padding: 12px 14px;
  text-align: center;
  white-space: nowrap;
  background: rgba(255, 255, 255, 0.94);
  border: 0;
  border-right: 1px solid rgba(7, 18, 63, 0.1);
  border-radius: 0;
  box-shadow: none;
}

#accueil .timing-list.compact-list span:last-child {
  border-right: 0;
}

.timing-panel {
  display: grid;
  align-content: center;
  gap: 12px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(0, 0, 145, 0.93), rgba(2, 13, 44, 0.93)),
    url("/assets/brand/juridex-logo.png") right 18px center / 120px no-repeat,
    var(--blue);
  border-color: transparent;
}

.timing-panel strong,
.timing-panel p {
  color: #fff;
}

.section-heading {
  max-width: 760px;
  margin-bottom: 28px;
}

.section-heading::after {
  content: "";
  display: block;
  width: 72px;
  height: 4px;
  margin-top: 14px;
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(0, 0, 145, 0.1);
}

.automation-section {
  background: #fff;
  border-top: 6px solid transparent;
}

.automation-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.55fr);
  gap: 22px;
  align-items: start;
}

.automation-form,
.automation-result {
  box-shadow: none;
}

.automation-result {
  position: sticky;
  top: 96px;
  border-top: 5px solid transparent;
}

.analysis-ribbon {
  margin: -24px -24px 22px;
  padding: 12px 18px;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  background: var(--blue);
}

.analysis-ribbon.red {
  background: var(--red);
}

.upsell-list {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}

.upsell-list label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
}

.upsell-list p {
  margin: 0;
  padding: 12px;
  color: var(--muted);
  font-weight: 800;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
}

.upsell-list .preanalysis-inline-pay,
.upsell-list .dossier-inline-pay {
  width: fit-content;
  min-height: 46px;
  padding: 0 18px;
}

.upsell-list input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
}

.score-box,
.offer-box {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.score-box {
  margin-bottom: 14px;
}

.score-box span,
.offer-box span,
.console-head span,
.task-grid span,
.checkout-summary span {
  display: block;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.score-box strong,
.offer-box strong {
  display: block;
  margin: 6px 0 10px;
  font-size: 30px;
}

meter {
  width: 100%;
  height: 14px;
}

.offer-box {
  margin-bottom: 16px;
  border-left: 1px solid var(--line);
}

.offer-box p {
  color: var(--muted);
}

.generated-list {
  display: grid;
  gap: 8px;
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
}

.generated-list li {
  padding: 10px 12px;
  background: var(--soft-blue);
  border-left: 1px solid var(--line);
}

.prefecture-brief {
  margin-bottom: 18px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
}

.prefecture-brief span,
.source-note {
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.prefecture-brief p {
  margin: 6px 0 12px;
  color: var(--muted);
}

.official-links,
.prefecture-card div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.official-links a,
.prefecture-card a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 10px;
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--blue);
  border-radius: 4px;
}

.document-group-list {
  display: grid;
  gap: 10px;
  margin: 0 0 16px;
}

.document-group-list article,
.official-source-panel {
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.document-group-list article {
  border-left: 1px solid var(--line);
}

.document-group-list article:nth-child(even) {
  border-left-color: var(--line);
}

.document-group-list span,
.official-source-panel span {
  display: block;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.document-group-list h4,
.official-source-panel strong {
  display: block;
  margin: 4px 0 8px;
  color: var(--navy);
}

.document-group-list ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 14px;
}

.document-alerts {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
}

.document-alerts p {
  margin: 0;
  padding: 10px 12px;
  color: var(--red);
  font-size: 13px;
  font-weight: 800;
  background: var(--danger-bg);
  border: 1px solid var(--danger-border);
  border-left: 4px solid var(--red);
  border-radius: 4px;
}

.official-source-panel {
  margin-bottom: 18px;
  border-left: 1px solid var(--line);
}

.official-source-panel p {
  color: var(--muted);
  font-size: 13px;
}

.official-source-panel div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.official-source-panel a {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 10px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  background: var(--navy);
  border-radius: 4px;
}

.zone-alert {
  display: inline-flex;
  max-width: 760px;
  padding: 10px 12px;
  color: var(--red);
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--red);
  border-radius: 4px;
}

.formalities-grid,
.process-grid,
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.locations-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.google-map-panel {
  position: relative;
  margin-top: 24px;
  overflow: hidden;
  min-height: 360px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
}

.google-map {
  width: 100%;
  min-height: 360px;
}

.map-fallback {
  display: grid;
  align-content: center;
  gap: 10px;
  min-height: 360px;
  padding: 28px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.94), rgba(255, 255, 255, 0.82)),
    url("/assets/brand/juridex-logo.png") right 28px center / 180px no-repeat,
    #f8f9fb;
}

.map-fallback strong {
  color: var(--blue);
  font-size: 26px;
}

.map-fallback p {
  max-width: 560px;
  color: var(--muted);
  font-weight: 800;
}

.map-fallback a {
  width: fit-content;
  padding: 10px 14px;
  color: #fff;
  font-weight: 900;
  background: var(--red);
  border-radius: var(--radius-pill);
}

.coverage-map-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.65fr);
  gap: 24px;
  align-items: stretch;
}

.zone-search-form,
.zone-search-result {
  display: grid;
  gap: 14px;
}

.zone-search-form {
  padding: 24px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.zone-search-form label,
.form-field-wide {
  display: grid;
  gap: 8px;
}

.form-field-wide {
  grid-column: 1 / -1;
}

.form-field-wide small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.5;
}

.zone-search-result {
  padding: 16px;
  color: var(--ink);
  background: var(--soft-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.zone-search-result p {
  margin: 0;
  color: var(--muted);
}

.client-prefecture-card article {
  gap: 8px;
}

.client-prefecture-card a {
  width: fit-content;
  margin-top: 8px;
}

.map-fallback-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 720px;
}

.map-fallback-list span {
  padding: 7px 10px;
  color: var(--navy);
  font-size: 0.86rem;
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
}

.homepage-coverage-map,
.homepage-coverage-map .google-map,
.homepage-coverage-map .map-fallback {
  min-height: 300px;
}

@media (max-width: 860px) {
  .coverage-map-layout {
    grid-template-columns: 1fr;
  }

  .google-map-panel,
  .google-map,
  .map-fallback {
    min-height: 280px;
  }
}

.document-intelligence-section {
  background: #fff;
  border-top: 6px solid transparent;
}

.document-intelligence-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.72fr);
  gap: 34px;
  align-items: center;
}

.document-intelligence-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 26px;
}

.document-intelligence-cards article {
  padding: 20px;
  background: var(--soft-blue);
  border: 1px solid var(--border);
  border-top: 5px solid transparent;
  border-radius: 4px;
}

.document-intelligence-cards article:nth-child(even) {
  border-top-color: transparent;
}

.document-intelligence-cards p,
.document-source-note {
  color: var(--muted);
}

.document-source-note {
  margin-top: 18px;
  padding: 14px 16px;
  font-size: 14px;
  font-weight: 800;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
}

.document-photo-stack {
  position: relative;
  min-height: 440px;
}

.document-photo-stack img {
  position: absolute;
  object-fit: cover;
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 4px;
  box-shadow: var(--shadow);
}

.document-photo-main {
  inset: 0 46px 64px 0;
  width: calc(100% - 46px);
  height: calc(100% - 64px);
}

.document-photo-secondary {
  right: 0;
  bottom: 0;
  width: 48%;
  height: 210px;
}

.formality-card,
.process-grid article,
.price-card,
.locations-grid article {
  min-height: 100%;
  padding: 24px;
  text-align: left;
  background: linear-gradient(180deg, #fff, #FFFFFF);
  border: 1px solid rgba(0, 0, 145, 0.11);
  border-radius: 6px;
  box-shadow: var(--shadow-soft);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.formality-card {
  display: grid;
  gap: 9px;
  color: inherit;
}

.process-grid article {
  display: grid;
  gap: 10px;
}

.process-card-media {
  position: relative;
  overflow: hidden;
  width: calc(100% + 48px);
  margin: -24px -24px 4px;
  aspect-ratio: 16 / 9;
  background: var(--navy);
}

.process-card-media::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(180deg, rgba(5, 18, 38, 0.04), rgba(5, 18, 38, 0.26));
}

.process-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.formality-card.is-active {
  border-color: var(--blue);
  box-shadow: inset 0 5px 0 var(--red);
}

.formality-card span,
.process-grid span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  color: #fff;
  font-weight: 900;
  background: var(--navy);
  border-radius: 4px;
}

.process-grid .section-vector {
  margin-bottom: 2px;
}

.formality-card small,
.process-grid p,
.price-card p,
.locations-grid p,
.client-value-grid p,
.zone-overview-grid p,
.expert-copy p,
.faq-list p,
.site-footer p {
  color: var(--muted);
}

.final-cta-section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border-top: 6px solid transparent;
}

.final-cta-section h2 {
  max-width: 760px;
}

.process-section {
  background: #fff;
}

.offer-section,
.why-section {
  background: #fff;
}

.section-intro {
  max-width: 680px;
  color: var(--muted);
  font-size: 17px;
}

.trust-section,
.aftercare-section {
  background: #fff;
}

.trust-stats,
.trust-grid,
.workflow-grid,
.aftercare-grid {
  display: grid;
  gap: 16px;
}

.trust-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 24px 0;
}

.trust-stats article,
.trust-grid article,
.workflow-grid article,
.aftercare-grid article {
  padding: 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.trust-stats article {
  border-left: 1px solid var(--line);
}

.trust-stats strong {
  display: block;
  color: var(--blue);
  font-size: 32px;
}

.trust-stats span {
  color: var(--muted);
  font-weight: 900;
}

.trust-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.trust-grid article,
.aftercare-grid article {
  border-top: 5px solid transparent;
}

.trust-grid article:nth-child(even),
.aftercare-grid article:nth-child(even) {
  border-top-color: transparent;
}

.workflow-section {
  background: var(--soft-blue);
  border-top: 6px solid transparent;
}

.workflow-grid {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.workflow-grid article {
  display: grid;
  gap: 8px;
  align-content: start;
}

.workflow-grid span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  color: #fff;
  font-weight: 900;
  background: var(--blue);
  border-radius: 4px;
}

.workflow-grid article:nth-child(3n) span {
  background: var(--red);
}

.workflow-grid p,
.trust-grid p,
.aftercare-grid p {
  margin-bottom: 0;
  color: var(--muted);
}

.aftercare-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.people-stories-section {
  background: var(--bg);
}

.people-stories-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 28px;
}

.people-story-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
}

.people-photo-wrap {
  position: relative;
  min-height: 280px;
}

.people-photo-wrap img {
  height: 280px;
  object-fit: cover;
}

.residence-card-demo {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  display: grid;
  gap: 3px;
  max-width: 260px;
  padding: 14px;
  color: var(--blue);
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--line);
  border-left: 1px solid var(--line);
  border-radius: 4px;
  box-shadow: 0 10px 24px rgba(0, 0, 145, 0.14);
}

.residence-card-demo span,
.residence-card-demo small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.residence-card-demo strong {
  font-size: 20px;
}

.people-story-card > div:last-child {
  padding: 20px;
}

.people-story-card p {
  color: var(--muted);
}

.prefecture-section {
  background: #fff;
  border-top: 6px solid transparent;
}

.prefecture-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.prefecture-card {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 5px solid transparent;
  border-radius: 4px;
}

.prefecture-card:nth-child(3n) {
  border-top-color: transparent;
}

.prefecture-card span {
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.prefecture-card h3,
.prefecture-card p {
  margin-bottom: 0;
}

.prefecture-card strong {
  color: var(--ink);
}

.prefecture-card small {
  display: block;
  color: var(--muted);
}

.source-note {
  margin: 20px 0 0;
  color: var(--red);
}

.process-grid article:nth-child(2) span {
  background: var(--blue);
}

.process-grid article:nth-child(3) span {
  background: var(--red);
}

.process-grid article:nth-child(4) span {
  color: #fff;
  background: var(--blue);
}

.expert-section {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: center;
  padding: clamp(58px, 8vw, 96px) clamp(18px, 5vw, 72px);
  background: var(--blue);
  color: #fff;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
}

.expert-image img {
  height: min(560px, 70vh);
  object-fit: cover;
  border-radius: 4px;
}

.expert-copy p,
.expert-copy .eyebrow {
  color: #d6e1f2;
}

.check-list {
  display: grid;
  gap: 12px;
  padding: 0;
  margin: 24px 0 0;
  list-style: none;
}

.check-list li {
  padding: 13px 14px;
  color: var(--ink);
  background: #fff;
  border-left: 1px solid var(--line);
  border-radius: 4px;
}

.price-card strong,
.price-value {
  display: block;
  margin: 12px 0;
  color: var(--navy);
  font-size: clamp(34px, 4vw, 46px);
  line-height: 0.95;
}

.price-card span {
  color: var(--blue);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.price-card {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.price-card a {
  margin-top: auto;
}

.price-card .section-vector {
  margin-bottom: 8px;
}

.price-card.featured .section-vector {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.2);
}

.price-card.featured .section-vector svg {
  filter: brightness(0) invert(1);
}

.price-for {
  margin-bottom: 12px;
  color: var(--ink);
  font-weight: 900;
}

.price-includes {
  display: grid;
  gap: 8px;
  margin: 16px 0 18px;
  padding: 0;
  list-style: none;
}

.price-includes li {
  padding-left: 18px;
  color: var(--muted);
  font-weight: 800;
  position: relative;
}

.price-includes li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 7px;
  height: 7px;
  background: var(--red);
  border-radius: 50%;
}

.price-card.featured {
  color: #fff;
  background: var(--blue);
  border-color: var(--blue);
  box-shadow: var(--shadow-soft);
}

.price-card.featured .price-value,
.price-card.featured p {
  color: #d6e1f2;
}

.price-card.featured .price-for,
.price-card.featured .price-includes li,
.price-card.featured span {
  color: #fff;
}

.price-card.featured .price-value {
  color: #fff;
}

.price-card.featured a {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.price-card.featured a:hover {
  background: var(--fr-red);
  border-color: var(--fr-red);
}

.consultation-cards {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 26px 0 28px;
}

.consultation-cards article {
  position: relative;
  overflow: hidden;
  border-top: 5px solid transparent;
}

.consultation-cards article:nth-child(2) {
  border-top-color: transparent;
}

.consultation-cards article:nth-child(3) {
  border-top-color: transparent;
}

.consultation-cards span {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.consultation-price {
  display: block;
  margin: 0 0 10px;
  color: var(--navy);
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1;
}

.consultation-cards p {
  color: var(--muted);
}

.consultation-cards a {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
  margin-top: 8px;
  padding: 0 12px;
  color: #fff;
  font-weight: 900;
  background: var(--blue);
  border-radius: 4px;
}

.comparison-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.comparison-grid article {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: start;
  min-height: 0;
  border-top: 5px solid transparent;
}

.comparison-grid article:last-child {
  color: #fff;
  background: var(--navy);
  border-top-color: transparent;
}

.comparison-grid article:last-child p {
  color: rgba(255, 255, 255, 0.84);
}

.comparison-grid span {
  display: block;
  margin-bottom: 10px;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
}

.comparison-card-media {
  position: relative;
  overflow: hidden;
  width: calc(100% + 48px);
  margin: -24px -24px 2px;
  aspect-ratio: 16 / 8;
  background: var(--navy);
}

.comparison-card-media::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(180deg, rgba(5, 18, 38, 0.02), rgba(5, 18, 38, 0.24));
}

.comparison-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.legal-limit-section {
  background: #fff;
  border-top: 6px solid transparent;
}

.legal-limit-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.compact-legal-grid {
  margin-top: 18px;
}

.compact-note {
  margin-top: 18px;
  margin-bottom: 18px;
}

.reviews-section,
.reviews-page-section {
  background: #fff;
}

.reviews-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 28px;
  margin: -10px 0 22px;
  color: var(--muted);
  font-weight: 800;
}

.reviews-summary strong {
  color: var(--navy);
  font-family: var(--serif);
  font-size: 26px;
  line-height: 1;
}

.reviews-home-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1fr);
  gap: clamp(28px, 4vw, 56px);
  align-items: center;
}

.reviews-home-media {
  margin: 0;
}

.reviews-home-media img {
  display: block;
  width: 100%;
  height: clamp(320px, 34vw, 460px);
  object-fit: cover;
  object-position: center;
  border-radius: 24px;
  box-shadow: 0 24px 70px rgba(5, 18, 38, 0.18);
}

.reviews-home-content {
  min-width: 0;
}

.reviews-home-layout .reviews-grid {
  grid-template-columns: 1fr;
}

.reviews-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.review-card,
.review-empty-card {
  display: grid;
  align-content: start;
  gap: 14px;
  min-height: 100%;
  padding: 22px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 5px solid transparent;
  border-radius: 8px;
  box-shadow: 0 18px 48px rgba(5, 18, 38, 0.08);
}

.review-card:nth-child(3n),
.review-empty-card {
  border-top-color: transparent;
}

.review-card-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.review-stars {
  color: var(--fr-red);
  font-size: 16px;
  letter-spacing: 0;
}

.review-badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  background: rgba(0, 0, 145, 0.07);
  border-radius: 999px;
}

.review-card strong,
.review-empty-card strong {
  color: var(--navy);
  font-size: 18px;
}

.review-card p,
.review-empty-card p,
.review-card small {
  color: var(--muted);
}

.review-card blockquote {
  margin: 0;
  padding: 12px 14px;
  color: var(--navy);
  font-weight: 800;
  background: rgba(5, 18, 38, 0.04);
  border-left: 1px solid var(--line);
  border-radius: 6px;
}

.review-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 22px;
}

.review-filters button {
  min-height: 40px;
  padding: 0 14px;
  color: var(--navy);
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  cursor: pointer;
}

.review-filters button.is-active {
  color: #fff;
  background: var(--blue);
  border-color: var(--blue);
}

.review-card-admin-preview {
  box-shadow: none;
}

.booking-section {
  background: #fff;
}

.client-automation,
.client-dashboard-section {
  background: var(--bg);
}

.client-entry {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1fr);
  gap: 28px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
}

.client-entry-image {
  height: 360px;
  object-fit: cover;
}

.client-entry-copy {
  padding: 28px;
}

.client-entry-copy p {
  color: var(--muted);
  font-size: 18px;
}

.client-console {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 22px;
  padding: 0;
  overflow: hidden;
  box-shadow: none;
}

.client-console aside {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 22px;
  color: #fff;
  background: var(--blue);
}

.status-pill {
  display: inline-flex;
  width: fit-content;
  padding: 6px 8px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  background: #fff;
  border-radius: 4px;
}

.console-tab {
  min-height: 42px;
  color: #fff;
  text-align: left;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.38);
  border-radius: 4px;
  transition: background 0.16s ease, border-color 0.16s ease, transform 0.16s ease;
}

.console-tab.is-active {
  color: var(--blue);
  background: #fff;
}

.console-tab:hover {
  transform: translateX(2px);
  border-color: #fff;
}

.console-main {
  padding: 22px;
}

.console-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 20px;
}

.console-head h3 {
  margin-bottom: 0;
}

.progress-track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 18px;
}

.progress-track span {
  padding: 10px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.progress-track .done {
  color: #fff;
  background: var(--blue);
  border-color: var(--blue);
}

.progress-track .active {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.client-overview-panel,
.client-case-summary {
  scroll-margin-top: 92px;
}

.client-overview-panel {
  display: grid;
  gap: 14px;
}

.client-view-hidden {
  display: none !important;
}

.client-action-required,
.client-profile-completion,
.client-case-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  border: 1px solid rgba(2, 34, 78, 0.1);
  border-radius: 8px;
  background: linear-gradient(135deg, #fff, #f8fafc);
}

.client-action-required {
  position: relative;
  overflow: hidden;
  border-left: 5px solid var(--blue);
}

.client-action-required[data-tone="warning"],
.client-action-required[data-tone="danger"] {
  border-left-color: var(--red);
  background: linear-gradient(135deg, rgba(197, 34, 53, 0.08), #fff 44%);
}

.client-action-required[data-tone="success"] {
  border-left-color: var(--success);
}

.client-action-required::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  width: var(--profile-progress, 0%);
  height: 4px;
  background: var(--tricolor-bar-light);
}

.client-cases-view {
  align-items: stretch;
  flex-direction: column;
}

.client-case-list {
  display: grid;
  gap: 12px;
}

.client-case-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.client-case-list article {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.client-case-list article.is-active {
  border-color: rgba(2, 34, 78, 0.28);
  box-shadow: 0 12px 30px rgba(2, 34, 78, 0.1);
}

.client-case-list article strong,
.client-case-list article small {
  display: block;
}

.client-case-list article p {
  margin: 6px 0 0;
}

.client-action-required span,
.client-profile-completion span,
.client-case-summary span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.client-action-required strong,
.client-profile-completion strong,
.client-case-summary strong {
  display: block;
  margin-top: 3px;
  color: var(--blue);
  font-size: 18px;
}

.client-action-required p,
.client-profile-completion p,
.client-case-summary p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
}

.client-action-required button,
.client-profile-completion button,
.client-case-summary button {
  flex: 0 0 auto;
  border: 0;
  border-radius: 5px;
  padding: 10px 13px;
  color: #fff;
  background: var(--red);
  font-weight: 950;
  cursor: pointer;
}

.client-profile-completion {
  position: relative;
  overflow: hidden;
}

.client-profile-completion::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 4px;
  width: var(--profile-progress, 0%);
  background: var(--blue);
}

.task-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.client-case-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 12px 0 6px;
}

.client-case-details small {
  display: grid;
  gap: 2px;
  padding: 9px 10px;
  color: var(--ink);
  font-weight: 850;
  background: #f8fafc;
  border: 1px solid rgba(2, 34, 78, 0.08);
  border-radius: 5px;
}

.client-case-details b {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
}

.is-empty-dashboard-panel {
  display: none !important;
}

.task-grid article {
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  border-top: 4px solid transparent;
  box-shadow: 0 10px 22px rgba(7, 18, 63, 0.04);
}

.checkout-summary {
  margin-bottom: 20px;
  padding: 18px;
  background: var(--soft-blue);
  border: 1px solid var(--border);
  border-left: 1px solid var(--border);
}

.checkout-summary strong {
  display: block;
  margin: 4px 0;
  color: var(--blue);
  font-size: 34px;
}

.checkout-summary p {
  margin-bottom: 0;
  color: var(--muted);
}

.preanalysis-review {
  margin: 0 0 20px;
  padding: 18px;
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.14);
  border-left: 1px solid rgba(0, 0, 145, 0.14);
  border-radius: 4px;
  box-shadow: var(--shadow-soft);
}

.preanalysis-review span {
  display: block;
  margin-bottom: 8px;
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.preanalysis-review ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
}

.checkout-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  max-width: 920px;
  margin: 0 0 18px;
}

.checkout-steps span {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 10px;
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.checkout-steps span:nth-child(3) {
  color: #fff;
  background: var(--red);
  border-color: var(--red);
}

.checkout-consents {
  display: grid;
  gap: 10px;
  margin: 0 0 18px;
  padding: 18px;
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.14);
  border-left: 1px solid rgba(0, 0, 145, 0.14);
  border-radius: 4px;
}

.checkout-consents label {
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 10px;
  margin: 0;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.45;
}

.checkout-consents input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
  accent-color: var(--red);
}

.checkout-consents p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.is-invalid {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(225, 0, 15, 0.12) !important;
}

.booking-form {
  max-width: 920px;
}

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.form-success {
  min-height: 24px;
  margin-top: 14px;
  color: var(--blue);
  font-weight: 900;
}

.locations-grid article {
  padding: 0;
  overflow: hidden;
}

.locations-grid img {
  height: 190px;
  object-fit: cover;
}

.locations-grid h3,
.locations-grid p {
  padding: 0 20px;
}

.locations-grid h3 {
  margin-top: 18px;
}

.locations-grid p {
  padding-bottom: 22px;
}

.faq-list {
  display: grid;
  gap: 12px;
  max-width: 900px;
}

.faq-list details {
  padding: 18px 20px;
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.11);
  border-radius: 6px;
  box-shadow: var(--shadow-soft);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.faq-list summary {
  cursor: pointer;
  color: var(--navy);
  font-size: 18px;
  font-weight: 900;
  line-height: 1.25;
}

.faq-list p {
  margin: 12px 0 0;
}

.site-footer {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(260px, 1.5fr) repeat(2, minmax(150px, 0.7fr)) minmax(210px, 0.9fr);
  gap: clamp(22px, 3vw, 44px);
  padding: 54px clamp(18px, 5vw, 72px) 28px;
  color: #fff;
  background:
    radial-gradient(circle at top right, rgba(225, 0, 15, 0.08), transparent 34%),
    linear-gradient(135deg, var(--deep-navy), var(--navy) 56%, var(--deep-navy));
  border-top: 0;
}

.site-footer::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: var(--tricolor-bar);
  opacity: 0.96;
}

.site-footer::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: url("/assets/patterns/juridex-republican-watermark.svg") right 7% center / min(420px, 42vw) no-repeat;
  opacity: 0.045;
}

.site-footer > * {
  position: relative;
  z-index: 1;
}

.site-footer p {
  max-width: 640px;
  margin: 8px 0 0;
  color: #c5cfdd;
  font-size: 14px;
}

.footer-brand {
  display: grid;
  gap: 14px;
}

.footer-brand-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: fit-content;
}

.footer-brand-mark {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  padding: 4px;
  background: #fff;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-md);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
  overflow: hidden;
}

.footer-brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.footer-brand-link strong,
.footer-brand-link small {
  display: block;
}

.footer-brand-link strong {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 0;
}

.footer-brand-link small {
  color: #c5cfdd;
  font-size: 11.5px;
  font-weight: 800;
}

.footer-independence {
  max-width: 560px;
  padding-left: 14px;
  border-left: 3px solid rgba(225, 0, 15, 0.82);
}

.footer-trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 620px;
}

.footer-trust-badges span {
  min-height: 30px;
  padding: 6px 10px;
  color: #f8fbff;
  font-size: 12px;
  font-weight: 900;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
}

.footer-column {
  display: grid;
  align-content: start;
  gap: 10px;
}

.footer-heading {
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.site-footer a {
  color: #dce5f2;
  font-size: 14px;
  font-weight: 900;
  transition: color 0.16s ease;
}

.site-footer a:hover {
  color: #fff;
}

.footer-services,
.footer-resources,
.footer-legal {
  display: grid;
  gap: 8px;
}

.footer-contact-links {
  display: grid;
  gap: 9px;
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.footer-contact-links span {
  color: #c5cfdd;
  font-size: 13px;
  font-weight: 800;
}

.footer-bottom {
  grid-column: 1 / -1;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding-top: 22px;
  margin-top: 8px;
  color: #aebbd0;
  font-size: 13px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.cookie-banner {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 40;
  width: min(360px, calc(100vw - 40px));
  padding: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  box-shadow: var(--shadow);
}

.cookie-banner.is-hidden {
  display: none;
}

.cookie-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 30px;
  height: 30px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.cookie-banner p {
  color: var(--muted);
  font-size: 14px;
}

.cookie-banner div {
  display: flex;
  gap: 10px;
}

.client-page {
  background: #f7f8fb;
}

.client-page.client-auth-checking .client-auth-hero,
.client-page.client-auth-checking .client-dashboard-section,
.client-page.client-auth-checking .client-auth-footer,
.client-page.is-client-authenticated .client-auth-hero,
.client-page.is-client-authenticated .client-auth-footer,
.client-page.is-client-guest .client-dashboard-section {
  display: none;
}

.client-auth-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.48fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: center;
  min-height: 660px;
  padding: clamp(54px, 7vw, 92px) clamp(18px, 5vw, 72px);
  background:
    linear-gradient(90deg, rgba(6, 17, 31, 0.94), rgba(6, 17, 31, 0.72), rgba(6, 17, 31, 0.28)),
    var(--client-hero-image, url("/assets/images/home/espace-client-securise.png")) center right / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
  border-bottom: 6px solid transparent;
}

.client-auth-copy h1 {
  max-width: 820px;
  color: #fff;
}

.client-auth-copy p:not(.notice):not(.france-chip):not(.hero-reassurance-line) {
  max-width: 680px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 19px;
}

.client-auth-copy .hero-reassurance-line {
  margin-top: 18px;
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 15px !important;
}

.auth-panel {
  padding: 24px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 5px solid transparent;
  border-radius: 4px;
  box-shadow: var(--shadow-hover);
}

.auth-tabs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 18px;
}

.auth-tab {
  min-height: 44px;
  color: var(--blue);
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--blue);
  border-radius: 4px;
}

.auth-tab.is-active {
  color: #fff;
  background: var(--blue);
}

.auth-reassurance {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.auth-helper-text {
  margin: 0 0 16px;
  color: var(--muted);
  line-height: 1.55;
}

.auth-forgot-link {
  display: inline-flex;
  margin-top: 12px;
  color: var(--blue);
  font-size: 14px;
  font-weight: 900;
  border-bottom: 1px solid rgba(0, 0, 145, 0.22);
}

.auth-forgot-link:hover {
  color: var(--red);
  border-color: var(--red);
}

.auth-name-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.auth-consent-stack {
  display: grid;
  gap: 10px;
  margin: 12px 0 14px;
  padding: 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.auth-consent-stack label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 9px;
  align-items: start;
  margin: 0;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

.auth-back-button {
  width: 100%;
  margin-top: 10px;
}

.field-error {
  display: block;
  margin-top: 6px;
  color: var(--red);
  font-size: 12px;
  font-weight: 900;
}

[aria-invalid="true"] {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(226, 0, 26, 0.12);
}

.client-payment-notice {
  margin-bottom: 14px;
  padding: 12px 14px;
  font-weight: 800;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  background: #f8f9fb;
}

.client-payment-notice.success {
  color: var(--success-ink);
  border-left-color: var(--success);
  background: var(--success-bg);
}

.client-payment-notice.info {
  color: var(--navy);
  border-left-color: var(--blue);
  background: var(--soft-bg);
}

.client-payment-notice.error {
  color: var(--danger-ink);
  border-left-color: var(--red);
  background: var(--danger-bg);
}

.client-dashboard-section {
  padding: clamp(58px, 8vw, 96px) clamp(18px, 5vw, 72px);
  background:
    linear-gradient(180deg, #fff 0, #f7f8fb 160px),
    #f7f8fb;
}

.client-dashboard-shell {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 22px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.client-dashboard-shell aside {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 22px;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 140px),
    var(--blue);
}

.client-dashboard-shell aside strong {
  line-height: 1.25;
}

.client-logout-button {
  min-height: 40px;
  padding: 0 14px;
  white-space: nowrap;
}

.client-documents {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 18px;
  margin-top: 18px;
  padding: 18px;
  background: linear-gradient(135deg, var(--soft-bg), #fff);
  border: 1px solid rgba(0, 0, 145, 0.12);
  border-radius: 8px;
  scroll-margin-top: 92px;
}

.client-documents img {
  height: 190px;
  object-fit: cover;
  border-radius: 6px;
}

.client-documents ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.client-documents li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  background: #fff;
  border-left: 1px solid var(--line);
  border-radius: 6px;
}

.client-documents li span {
  color: var(--red);
  font-weight: 900;
}

.client-documents li button {
  min-width: 64px;
  border: 1px solid var(--blue);
  border-radius: 4px;
  padding: 7px 10px;
  color: var(--blue);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.client-documents .client-document-card {
  display: grid;
  align-items: stretch;
  justify-content: stretch;
  gap: 10px;
  border-left-color: var(--blue);
}

.client-document-card[data-status="warning"] {
  border-left-color: var(--red);
}

.client-document-card[data-status="success"] {
  border-left-color: var(--success);
}

.client-document-card[data-status="pending"] {
  border-left-color: var(--warning);
}

.client-document-card[data-action-required="true"] {
  background: linear-gradient(90deg, rgba(197, 34, 53, 0.06), #fff 34%);
}

.client-document-card.is-highlighted {
  animation: client-document-focus 1.8s ease;
}

@keyframes client-document-focus {
  0%,
  100% {
    box-shadow: 0 0 0 rgba(197, 34, 53, 0);
  }
  20%,
  70% {
    box-shadow: 0 0 0 4px rgba(197, 34, 53, 0.16);
  }
}

.client-document-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.client-document-card-head strong,
.client-document-card-head span {
  display: block;
}

.client-document-card-head span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.client-document-badges {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 6px;
}

.client-document-badges b,
.client-document-badges em {
  padding: 6px 8px;
  color: var(--blue);
  font-size: 12px;
  font-style: normal;
  white-space: nowrap;
  background: var(--soft-blue);
  border-radius: 999px;
}

.client-document-badges em {
  color: #fff;
  background: var(--red);
}

.client-document-card p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.client-document-alert {
  color: var(--red) !important;
  font-weight: 900 !important;
}

.client-document-correction {
  padding: 9px 10px;
  border: 1px solid rgba(13, 75, 118, 0.14);
  border-radius: 6px;
  color: var(--blue) !important;
  background: var(--soft-blue);
}

.client-document-actions {
  display: grid;
  gap: 8px;
}

.client-inline-upload {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 8px;
}

.client-inline-upload label {
  display: grid;
  gap: 5px;
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.client-inline-upload small {
  grid-column: 1 / -1;
  color: var(--muted);
  font-weight: 800;
}

.client-upload-form,
.client-message-form {
  display: grid;
  gap: 10px;
  margin-top: 14px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
}

.client-profile-center {
  align-items: start;
}

.client-profile-form {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
}

.client-profile-form details {
  border: 1px solid rgba(2, 34, 78, 0.1);
  border-radius: 6px;
  background: #f8fafc;
}

.client-profile-form summary {
  cursor: pointer;
  padding: 12px;
  color: var(--blue);
  font-weight: 950;
  text-transform: uppercase;
}

.client-profile-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 0 12px 12px;
}

.client-profile-form p {
  min-height: 20px;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.client-profile-lock-notice {
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgba(0, 0, 145, 0.16);
  border-left: 4px solid var(--fr-blue, #000091);
  border-radius: 6px;
  background: #f7f7f7;
}

.client-profile-lock-notice strong {
  display: block;
  color: var(--blue);
  font-weight: 950;
}

.client-profile-lock-notice p {
  margin: 6px 0 0;
  color: var(--muted);
}

.is-locked-profile-field {
  opacity: 0.78;
}

.is-locked-profile-field input {
  background: #f2f4f7;
  cursor: not-allowed;
}

.client-upload-form h4,
.client-message-center h4 {
  margin: 0;
  color: var(--blue);
  font-size: 14px;
  text-transform: uppercase;
}

.client-upload-form p,
.client-message-form p {
  min-height: 20px;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.client-live-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  gap: 14px;
  margin-top: 18px;
}

.client-live-grid section {
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
  scroll-margin-top: 92px;
}

.client-live-grid h4 {
  margin: 0 0 12px;
  color: var(--blue);
  font-size: 14px;
  text-transform: uppercase;
}

.client-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.client-section-title h4 {
  margin: 0;
}

.client-section-title button {
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 6px 9px;
  color: var(--blue);
  background: #fff;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.client-section-title button:disabled {
  color: var(--muted);
  cursor: not-allowed;
  opacity: .65;
}

.client-timeline,
.client-notifications,
.client-downloads {
  display: grid;
  gap: 10px;
}

.client-timeline article {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 10px;
}

.client-timeline article > span {
  width: 14px;
  height: 14px;
  margin-top: 4px;
  background: #cbd5e1;
  border-radius: 50%;
}

.client-timeline article.done > span {
  background: var(--blue);
}

.client-timeline article.active > span {
  background: var(--red);
}

.client-timeline p,
.client-notifications p {
  margin: 2px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.client-notifications article,
.client-downloads article {
  padding: 11px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 6px;
}

.client-notifications article[data-tone="warning"] {
  border-left-color: var(--red);
}

.client-notifications article[data-tone="success"] {
  border-left-color: var(--success);
}

.client-notifications article[data-status="read"] {
  opacity: 0.72;
}

.client-notification-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin-top: 8px;
  border: 1px solid rgba(13, 75, 118, 0.16);
  padding: 7px 9px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  background: var(--soft-blue);
  border-radius: 4px;
}

.client-notifications button.client-notification-action {
  border-color: var(--blue);
  color: #fff;
  background: var(--blue);
}

.client-notifications button {
  margin-top: 8px;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 7px 10px;
  color: var(--blue);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.client-downloads article {
  display: grid;
  gap: 3px;
}

.client-downloads span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.client-downloads small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.client-downloads button {
  justify-self: start;
  margin-top: 8px;
  border: 1px solid var(--blue);
  border-radius: 4px;
  padding: 7px 10px;
  color: var(--blue);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.client-support-tickets article[data-status="resolu"],
.client-support-tickets article[data-status="resolved"],
.client-support-tickets article[data-status="ferme"],
.client-support-tickets article[data-status="closed"] {
  border-left-color: var(--success);
}

.client-support-tickets article[data-status="en_traitement"],
.client-support-tickets article[data-status="in_progress"] {
  border-left-color: var(--red);
}

.client-support-tickets p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.client-support-replies {
  display: grid;
  gap: 8px;
  margin-top: 12px;
  padding: 10px;
  border: 1px solid rgba(2, 34, 78, 0.1);
  border-radius: 6px;
  background: #f8fafc;
}

.client-support-replies > span {
  color: var(--blue);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.client-support-replies div {
  display: grid;
  gap: 3px;
  padding-top: 8px;
  border-top: 1px solid rgba(2, 34, 78, 0.08);
}

.client-support-replies div:first-of-type {
  border-top: 0;
  padding-top: 0;
}

.client-support-replies strong {
  font-size: 13px;
}

.client-support-replies small {
  color: var(--muted);
  font-size: 11px;
}

.client-support-replies p {
  color: var(--ink);
  font-weight: 750;
}

.client-consultation-card {
  gap: 9px;
}

.client-consultation-card > p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.client-consultation-progress {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 5px;
  margin: 4px 0;
  padding: 0;
  list-style: none;
}

.client-consultation-progress li {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  align-items: center;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.client-consultation-progress li > span {
  width: 9px;
  height: 9px;
  background: #cbd5e1;
  border-radius: 999px;
}

.client-consultation-progress li[data-state="done"] {
  color: var(--blue);
}

.client-consultation-progress li[data-state="done"] > span {
  background: var(--blue);
}

.client-consultation-progress li[data-state="active"] {
  color: var(--red);
}

.client-consultation-progress li[data-state="active"] > span {
  background: var(--red);
}

.client-consultation-response {
  display: grid;
  gap: 6px;
  padding: 10px;
  background: #fff;
  border: 1px solid rgba(13, 75, 118, 0.14);
  border-radius: 4px;
}

.client-consultation-response strong {
  color: var(--blue);
}

.client-consultation-response p {
  max-height: 160px;
  overflow: auto;
  margin: 0;
  color: var(--ink);
  font-size: 13px;
  line-height: 1.55;
}

.client-consultation-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.client-consultation-actions a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 10px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  background: var(--red);
  border-radius: 4px;
}

.client-consultation-actions a + a {
  color: var(--blue);
  background: #fff;
  border: 1px solid var(--line);
}

.client-appointment-booking {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.client-appointment-booking label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.client-appointment-booking select {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 8px 10px;
  color: var(--ink);
  background: #fff;
  font: inherit;
}

.client-appointment-booking small {
  min-height: 16px;
}

.client-signature-form {
  display: grid;
  gap: 9px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.client-signature-document {
  margin-top: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--soft-bg);
}

.client-signature-document summary {
  cursor: pointer;
  color: var(--fr-blue);
  font-size: 13px;
  font-weight: 900;
}

.client-signature-document p {
  margin: 10px 0 0;
  white-space: pre-wrap;
}

.client-signature-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.client-signature-form input[type="text"] {
  width: 100%;
  min-height: 38px;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 8px 10px;
  color: var(--ink);
  background: #fff;
  font: inherit;
}

.client-signature-form .checkbox-row {
  display: grid;
  grid-template-columns: 18px 1fr;
  align-items: start;
  color: var(--ink);
  font-weight: 800;
}

.client-signature-form small {
  min-height: 16px;
}

.client-message-center {
  display: grid;
  grid-template-columns: 1fr minmax(280px, .7fr);
  gap: 16px;
  margin-top: 18px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  scroll-margin-top: 92px;
}

.client-documents.is-panel-highlighted,
.client-overview-panel.is-panel-highlighted,
.client-case-summary.is-panel-highlighted,
.client-live-grid section.is-panel-highlighted,
.client-message-center.is-panel-highlighted {
  animation: client-panel-focus 1.5s ease;
}

@keyframes client-panel-focus {
  0%,
  100% {
    box-shadow: 0 0 0 rgba(225, 0, 15, 0);
  }
  25%,
  70% {
    box-shadow: 0 0 0 4px rgba(225, 0, 15, 0.12), var(--shadow-soft);
  }
}

.client-communication-center p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.client-consent-line {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  font-weight: 800;
}

.client-consent-line input {
  width: auto;
}

.consultation-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(320px, 1.15fr);
  gap: clamp(22px, 4vw, 48px);
  align-items: start;
}

.consultation-copy {
  padding: 22px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.consultation-copy p {
  color: var(--muted);
  font-size: 17px;
}

.consultation-form {
  margin-top: 0;
}

.consultation-checkout-summary {
  margin: 18px 0 14px;
}

.message-preview {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.message-preview article {
  max-width: 86%;
  padding: 10px 12px;
  background: #f8f9fb;
  border-left: 4px solid var(--blue);
}

.message-preview article[data-direction="client_to_admin"] {
  justify-self: end;
  border-left-color: var(--red);
  background: var(--danger-bg);
}

.message-preview span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.message-preview p {
  margin: 0;
  margin-top: 3px;
}

.message-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.message-preview button {
  justify-self: start;
  margin-top: 8px;
  border: 1px solid var(--blue);
  border-radius: 4px;
  padding: 7px 10px;
  color: var(--blue);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.admin-page {
  background: #eef2f7;
}

.is-hidden {
  display: none !important;
}

.install-body {
  min-height: 100vh;
  background:
    linear-gradient(90deg, rgba(244, 246, 249, .96), rgba(244, 246, 249, .88)),
    url("/assets/brand/juridex-logo.png") right 8% center / min(360px, 36vw) no-repeat,
    #f4f6f9;
}

.install-shell {
  display: grid;
  gap: 18px;
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 34px 0;
}

.install-hero,
.install-status,
.install-card,
.install-actions {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.install-hero {
  padding: 28px;
  border-left: 5px solid var(--blue);
}

.install-hero span {
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.install-hero h1 {
  margin: 8px 0;
  font-size: 38px;
}

.install-hero p,
.install-card p,
.install-status span,
.install-actions p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

.install-status {
  display: grid;
  gap: 4px;
  padding: 16px 18px;
  border-left: 5px solid var(--blue);
}

.install-checks {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.install-checks:empty {
  display: none;
}

.install-checks article {
  display: grid;
  gap: 5px;
  min-height: 84px;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 4px solid var(--success);
  border-radius: 4px;
}

.install-checks article[data-ok="false"] {
  border-left-color: var(--warning);
}

.install-checks strong {
  color: var(--ink);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.install-checks span {
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}

.install-checks small {
  color: var(--muted);
  font-weight: 800;
  overflow-wrap: anywhere;
}

.install-status[data-tone="success"] {
  border-left-color: var(--success);
}

.install-status[data-tone="warning"] {
  border-left-color: var(--warning);
}

.install-status[data-tone="danger"] {
  border-left-color: var(--red);
}

.install-form {
  display: grid;
  gap: 16px;
}

.install-card {
  display: grid;
  gap: 16px;
  padding: 18px;
}

.install-card-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.install-card-head > span {
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  color: #fff;
  font-weight: 900;
  background: var(--blue);
  border-radius: 4px;
}

.install-card h2 {
  margin: 0 0 4px;
  font-size: 22px;
}

.install-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.install-grid label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.install-grid input,
.install-grid select {
  width: 100%;
  background: #f8f9fb;
}

.install-grid-wide {
  grid-column: 1 / -1;
}

.install-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
}

.install-checkbox {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 4px 10px;
  align-items: center;
  color: var(--ink);
  font-size: 13px;
  font-weight: 900;
}

.install-checkbox input {
  grid-row: span 2;
  width: 18px;
  height: 18px;
}

.install-checkbox small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 700;
}

.install-actions p[data-tone="success"] {
  color: var(--success);
}

.install-actions p[data-tone="error"] {
  color: var(--red);
}

.is-permission-hidden {
  display: none !important;
}

.admin-login-screen {
  display: grid;
  place-items: center;
  min-height: 100vh;
  padding: 24px;
  background:
    linear-gradient(90deg, rgba(244, 246, 249, 0.94), rgba(244, 246, 249, 0.82)),
    url("/assets/brand/juridex-logo.png") right 8% center / min(360px, 36vw) no-repeat,
    #f4f6f9;
}

.admin-login-card {
  width: min(460px, 100%);
  padding: 30px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 5px solid var(--blue);
  border-radius: 4px;
  box-shadow: 0 18px 48px rgba(0, 0, 145, 0.16);
}

.admin-login-card h1 {
  margin-top: 28px;
  font-size: 34px;
}

.admin-login-card p {
  color: var(--muted);
}

.admin-login-help {
  min-height: 22px;
  color: var(--red);
  font-weight: 900;
}

.admin-login-help[data-tone="success"] {
  color: var(--success);
}

.admin-login-help[data-tone="error"] {
  color: var(--red);
}

.admin-permission-note {
  margin: 0;
  color: var(--red);
  font-size: 13px;
  font-weight: 900;
}

button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  cursor: not-allowed;
  opacity: .58;
}

.admin-shell {
  display: grid;
  grid-template-columns: 304px 1fr;
  min-height: 100vh;
}

.admin-sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  padding: 16px;
  color: #fff;
  background: #111827;
  border-right: 1px solid #263244;
}

.admin-sidebar .brand {
  min-width: 0;
  margin-bottom: 20px;
}

.admin-sidebar .brand small {
  color: #d7dce6;
}

.admin-sidebar-status {
  display: grid;
  gap: 4px;
  margin-bottom: 18px;
  padding: 14px;
  background: #1f2937;
  border: 1px solid #374151;
  border-left: 5px solid var(--red);
  border-radius: 4px;
}

.admin-sidebar-status span {
  color: #dce5f2;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-sidebar-status strong {
  font-size: 14px;
}

.admin-sidebar-status small {
  color: #cbd5e1;
}

.admin-search {
  margin-bottom: 18px;
  color: #fff;
  background: #1f2937;
  border-color: #374151;
}

.admin-nav-group {
  display: grid;
  gap: 6px;
  margin-bottom: 16px;
}

.admin-nav-group > .admin-nav-section-title {
  display: flex;
  align-items: center;
  min-height: 32px;
  padding: 8px 10px;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  background: var(--red);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 6px;
  box-shadow: 0 8px 18px rgba(225, 0, 15, .16);
}

.admin-nav-group a {
  display: flex;
  align-items: center;
  min-height: 36px;
  padding: 8px 10px 8px 14px;
  color: #f9fafb;
  font-size: 13px;
  font-weight: 800;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease;
}

.admin-nav-group a:hover {
  background: rgba(255, 255, 255, .08);
  border-color: rgba(255, 255, 255, .1);
}

.admin-nav-group a.is-active {
  color: #fff;
  background: var(--blue);
  border-color: rgba(255, 255, 255, .18);
  box-shadow: 0 10px 22px rgba(0, 0, 145, .24);
}

.admin-main {
  padding: 22px;
}

.admin-workspace-head {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  margin-bottom: 18px;
  padding: 20px 22px;
  background: #fff;
  border: 1px solid var(--line);
}

.admin-workspace-kicker {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-workspace-head h2 {
  margin-bottom: 6px;
  font-size: 26px;
}

.admin-workspace-head p {
  margin-bottom: 0;
  color: var(--muted);
}

.admin-inline-feedback {
  min-height: 24px;
  margin: -8px 0 18px;
  color: var(--blue);
  font-weight: 900;
}

.admin-inline-feedback[data-tone="success"],
.admin-save-status[data-tone="success"] {
  color: var(--success);
}

.admin-inline-feedback[data-tone="error"],
.admin-save-status[data-tone="error"] {
  color: var(--red);
}

.admin-topbar {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  margin-bottom: 22px;
  padding: 22px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
}

.admin-topbar h1 {
  margin-bottom: 6px;
  font-size: 28px;
}

.admin-topbar p {
  margin-bottom: 0;
  color: var(--muted);
}

.admin-sync-pill {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 9px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  background: var(--blue);
  border-radius: 4px;
}

.admin-user {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 900;
}

.admin-profile-trigger {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 4px 10px 4px 4px;
  color: var(--ink);
  font: inherit;
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.admin-profile-trigger:hover,
.admin-profile-trigger:focus-visible {
  border-color: rgba(0, 0, 145, .34);
  box-shadow: 0 10px 24px rgba(7, 18, 63, .12);
  transform: translateY(-1px);
}

.admin-user img {
  width: 42px;
  height: 42px;
  object-fit: cover;
  border: 2px solid var(--line);
  border-radius: 50%;
}

.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 22px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
}

.admin-actions.compact {
  margin-top: 14px;
  margin-bottom: 0;
  padding: 0;
  border: 0;
}

.admin-save-status {
  align-self: center;
  color: var(--blue);
  font-weight: 900;
}

.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 22px;
}

.admin-filter-card {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 190px 190px auto auto;
  gap: 12px;
  align-items: end;
  margin-bottom: 18px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-filter-card > div {
  display: grid;
  gap: 4px;
}

.admin-filter-card > div span {
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-filter-card > div strong {
  font-size: 18px;
}

.admin-filter-card label {
  margin-bottom: 0;
}

.admin-global-search-panel {
  margin-bottom: 18px;
}

.admin-global-search {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 220px auto;
  gap: 12px;
  align-items: end;
  margin-bottom: 14px;
}

.admin-global-search input,
.admin-global-search select {
  min-height: 44px;
}

.admin-export-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.admin-global-search-results {
  display: grid;
  gap: 12px;
}

.admin-search-group {
  border: 1px solid var(--line);
  border-radius: 4px;
  overflow: hidden;
}

.admin-search-group header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  background: #f8f9fb;
  border-bottom: 1px solid var(--line);
}

.admin-search-group header strong {
  font-size: 14px;
}

.admin-search-group header span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-search-result {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  width: 100%;
  padding: 12px;
  text-align: left;
  background: #fff;
  border: 0;
  border-bottom: 1px solid var(--line);
}

.admin-search-result:hover {
  background: #f8f9fb;
}

.admin-search-result.is-ai-result {
  border-left: 4px solid var(--blue);
}

.admin-search-result:last-child {
  border-bottom: 0;
}

.admin-search-result strong,
.admin-search-result span,
.admin-search-result small {
  display: block;
}

.admin-search-result span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
}

.admin-search-result-main {
  min-width: 0;
}

.admin-search-result-type {
  margin: 0 0 5px;
  color: var(--blue);
  font-size: 10px;
  font-weight: 950;
  text-transform: uppercase;
}

.admin-search-result em {
  display: block;
  margin-top: 6px;
  color: var(--ink);
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.admin-search-result small {
  align-self: center;
  padding: 5px 8px;
  color: var(--blue);
  font-size: 11px;
  font-weight: 900;
  background: var(--soft-bg);
  border-radius: 4px;
}

.admin-search-empty {
  padding: 14px;
  color: var(--muted);
  background: #fff;
  border: 1px dashed var(--line);
  border-radius: 4px;
}

.admin-gdpr-card {
  border-left: 5px solid var(--red);
}

.admin-gdpr-card p {
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 13px;
}

.admin-gdpr-card small {
  display: block;
  margin-top: 10px;
  color: var(--muted);
  font-weight: 800;
}

.admin-rgpd-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-rgpd-policy-panel {
  border-top: 5px solid var(--red);
}

.admin-rgpd-policy-panel .panel-title p {
  margin: 4px 0 0;
  color: var(--muted);
}

.admin-rgpd-policy-summary {
  margin-top: 16px;
}

.admin-panel-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.admin-reminders-panel {
  border-top: 5px solid var(--blue);
}

.admin-reminders-panel .panel-title p {
  margin: 4px 0 0;
  color: var(--muted);
}

.admin-reminder-summary {
  margin-top: 16px;
}

.admin-reminder-settings-form {
  display: grid;
  gap: 14px;
  margin-top: 16px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: #fbfcfd;
}

.admin-reminder-settings-head,
.admin-reminder-settings-footer,
.admin-reminder-history-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.admin-reminder-settings-head div,
.admin-reminder-history-head {
  min-width: 0;
}

.admin-reminder-settings-head strong,
.admin-reminder-history-head strong {
  display: block;
  color: var(--ink);
  font-size: 14px;
}

.admin-reminder-settings-head span,
.admin-reminder-settings-footer small,
.admin-reminder-history-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.45;
}

.admin-reminder-settings-grid {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.admin-reminder-settings-grid label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-reminder-settings-grid input,
.admin-reminder-settings-grid select {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 9px 10px;
  background: #fff;
  color: var(--ink);
  font: inherit;
}

.admin-switch-field {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.admin-switch-field input {
  inline-size: 18px;
  block-size: 18px;
  accent-color: var(--blue);
}

.admin-switch-field-inline {
  align-self: end;
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: #fff;
}

.admin-reminder-candidates {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.admin-reminder-candidates > p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.admin-reminder-candidates-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.admin-reminder-candidates-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-reminder-candidate-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.admin-reminder-candidate-list article {
  display: grid;
  gap: 6px;
  padding: 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
}

.admin-reminder-candidate-list article[data-severity="critical"] {
  border-left-color: var(--red);
}

.admin-reminder-candidate-list span,
.admin-reminder-candidate-list small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-reminder-candidate-list p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.admin-reminder-candidate-list strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
}

.admin-reminder-history {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.admin-reminder-history-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.admin-reminder-history-list article {
  display: grid;
  gap: 5px;
  padding: 11px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--green);
  border-radius: 4px;
  background: #fff;
}

.admin-reminder-history-list article[data-status="failed"] {
  border-left-color: var(--red);
}

.admin-reminder-history-list span,
.admin-reminder-history-list small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.4;
}

.admin-reminder-history-list strong {
  color: var(--ink);
  font-size: 13px;
}

.admin-jobs-panel {
  border-top: 5px solid #334155;
}

.admin-jobs-panel .panel-title p {
  margin: 4px 0 0;
  color: var(--muted);
}

.admin-jobs-filters {
  grid-template-columns: 1.5fr minmax(150px, 0.8fr) minmax(170px, 1fr);
  margin-top: 16px;
}

.admin-jobs-summary {
  margin-top: 16px;
}

.admin-jobs-table td {
  vertical-align: top;
}

.admin-jobs-table small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.admin-email-panel {
  border-top: 5px solid var(--green);
}

.admin-email-panel .panel-title p {
  margin: 4px 0 0;
  color: var(--muted);
}

.admin-email-smtp-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0 16px;
}

.admin-email-smtp-summary article {
  display: grid;
  gap: 5px;
  padding: 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-email-smtp-summary span,
.admin-email-variables {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-email-smtp-summary strong {
  color: var(--ink);
  font-size: 14px;
  overflow-wrap: anywhere;
}

.admin-email-variables {
  margin-top: 10px;
}

.admin-email-variables code {
  display: inline-block;
  margin: 4px 5px 0 0;
  padding: 4px 7px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
  color: var(--ink);
}

.admin-external-panel {
  border-top: 5px solid var(--blue);
}

.admin-external-panel .panel-title p {
  margin: 4px 0 0;
  color: var(--muted);
}

.admin-external-grid,
.admin-external-test-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.admin-external-test-row {
  grid-template-columns: minmax(140px, .45fr) minmax(180px, .7fr) minmax(260px, 1.4fr);
}

.admin-external-grid fieldset {
  display: grid;
  gap: 10px;
  margin: 0;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: #f8f9fb;
}

.admin-external-grid legend {
  padding: 0 6px;
  color: var(--ink);
  font-weight: 900;
}

.admin-outbound-log {
  display: grid;
  gap: 9px;
  margin-top: 16px;
}

.admin-outbound-log article {
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
  background: #fff;
}

.admin-outbound-log article[data-status="failed"],
.admin-outbound-log article[data-status="blocked"] {
  border-left-color: var(--warning);
}

.admin-outbound-log article[data-status="sent"],
.admin-outbound-log article[data-status="test_sent"] {
  border-left-color: var(--green);
}

.admin-outbound-log div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.admin-outbound-log span,
.admin-outbound-log small,
.admin-outbound-log p {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-outbound-log strong {
  color: var(--ink);
}

.admin-rgpd-candidates {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}

.admin-rgpd-candidates > p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.admin-rgpd-candidates-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.admin-rgpd-candidates-head strong {
  color: var(--ink);
}

.admin-rgpd-candidates-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-rgpd-candidate-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.admin-rgpd-candidate-list article {
  display: grid;
  gap: 6px;
  padding: 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 4px solid var(--red);
  border-radius: 4px;
}

.admin-rgpd-candidate-list span,
.admin-rgpd-candidate-list small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-rgpd-candidate-list strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.35;
}

.admin-backend-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 18px;
  margin-bottom: 18px;
}

.admin-module-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.admin-module-card,
.admin-module-grid > article {
  display: grid;
  gap: 7px;
  min-height: 112px;
  padding: 14px;
  text-align: left;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-module-card:nth-child(even),
.admin-module-grid > article:nth-child(even) {
  border-left-color: var(--red);
}

.admin-module-card span,
.admin-module-grid > article span,
.admin-control-summary span,
.admin-automation-list span,
.admin-role-list span,
.admin-log-list span {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-module-card strong,
.admin-module-grid > article strong {
  font-size: 17px;
}

.admin-module-card small,
.admin-module-grid > article small,
.admin-control-summary small,
.admin-automation-list small,
.admin-role-list small,
.admin-log-list small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.4;
}

.admin-control-summary,
.admin-automation-list,
.admin-role-list,
.admin-log-list {
  display: grid;
  gap: 10px;
}

.admin-control-summary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-business-statistics-filters {
  grid-template-columns: 1.4fr repeat(6, minmax(120px, 1fr)) auto auto;
}

.admin-production-filters {
  grid-template-columns: 1.4fr repeat(5, minmax(130px, 1fr)) auto auto;
}

.admin-today-head {
  grid-template-columns: 1fr auto auto;
  align-items: center;
}

.admin-today-layout {
  align-items: start;
}

.admin-today-list {
  display: grid;
  gap: 10px;
}

.admin-today-item,
.admin-today-empty {
  display: grid;
  gap: 10px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
  box-shadow: 0 10px 24px rgba(10, 25, 47, 0.06);
}

.admin-today-item[data-tone="warning"] {
  border-left-color: var(--warning);
}

.admin-today-item[data-tone="danger"] {
  border-left-color: var(--red);
}

.admin-today-item-main {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: start;
}

.admin-today-item-main strong {
  display: block;
  color: var(--night);
}

.admin-today-item-main small,
.admin-today-item-tags {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.admin-today-score {
  display: inline-flex;
  min-width: 42px;
  justify-content: center;
  padding: 6px 8px;
  color: #fff;
  background: var(--blue);
  border-radius: 4px;
  font-weight: 900;
}

.admin-today-score[data-tone="warning"] {
  background: var(--warning);
}

.admin-today-score[data-tone="danger"] {
  background: var(--red);
}

.admin-today-score[data-tone="neutral"] {
  background: #4b5563;
}

.admin-today-item-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.admin-intelligence-form {
  display: grid;
  grid-template-columns: 1.4fr repeat(3, minmax(130px, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.admin-intelligence-form label {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-intelligence-form textarea,
.admin-intelligence-form input,
.admin-intelligence-form select {
  width: 100%;
}

.admin-intelligence-wide,
.admin-intelligence-form button {
  grid-column: 1 / -1;
}

.admin-ai-result-card {
  display: grid;
  gap: 12px;
}

.admin-ai-result-card > span {
  display: inline-flex;
  padding: 8px 10px;
  color: var(--red);
  background: var(--danger-bg);
  border: 1px solid var(--danger-border);
  border-radius: 4px;
  font-weight: 900;
}

.admin-ai-result-card pre {
  max-height: 420px;
  overflow: auto;
  white-space: pre-wrap;
  padding: 14px;
  color: var(--night);
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
  font: 13px/1.55 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

.admin-ai-result-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.admin-ai-result-head > div:first-child {
  display: grid;
  gap: 6px;
}

.admin-ai-result-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.admin-ai-structured {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-ai-structured section,
.admin-ai-draft {
  min-width: 0;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
}

.admin-ai-structured h5,
.admin-ai-draft h5 {
  margin: 0 0 8px;
}

.admin-ai-structured p,
.admin-ai-structured ul {
  margin: 0;
  color: var(--muted);
}

.admin-ai-structured ul {
  padding-left: 18px;
}

.admin-ai-source-list {
  display: grid;
  gap: 10px;
}

.admin-ai-source-list article {
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
}

.admin-intelligence-indexer {
  grid-template-columns: 1.5fr minmax(220px, 0.8fr) auto;
  margin-top: 14px;
}

.admin-production-quickfilters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: -6px 0 14px;
}

.admin-production-quickfilters .button {
  min-height: 36px;
  padding: 8px 12px;
  font-size: 12px;
}

.admin-business-stats-secondary {
  margin-top: 12px;
}

.admin-production-main-panel {
  min-width: 0;
}

.admin-production-table td {
  vertical-align: top;
}

.admin-production-table small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.admin-production-score {
  display: inline-flex;
  min-width: 42px;
  justify-content: center;
  padding: 6px 8px;
  color: #fff;
  background: var(--blue);
  border-radius: 4px;
}

.admin-production-score[data-tone="warning"] {
  background: var(--warning);
}

.admin-production-score[data-tone="danger"] {
  background: var(--red);
}

.admin-production-score[data-tone="neutral"] {
  background: #4b5563;
}

.admin-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-table-actions button {
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 4px;
  font-weight: 900;
  cursor: pointer;
}

.admin-table-actions button:hover:not(:disabled) {
  border-color: var(--blue);
  color: var(--blue);
}

.admin-production-sla-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-production-sla-form button,
.admin-production-sla-form small {
  grid-column: 1 / -1;
}

.admin-production-sla-form small[data-status="success"] {
  color: var(--success);
}

.admin-production-sla-form small[data-status="error"] {
  color: var(--red);
}

.admin-control-summary article,
.admin-card-list > article,
.admin-automation-list article,
.admin-role-list article,
.admin-log-list article {
  display: grid;
  gap: 5px;
  padding: 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
}

.admin-automation-list article:nth-child(even),
.admin-role-list article:nth-child(even),
.admin-log-list article:nth-child(even) {
  border-left-color: var(--red);
}

.admin-control-summary strong,
.admin-card-list > article strong,
.admin-automation-list strong,
.admin-role-list strong,
.admin-log-list strong {
  line-height: 1.35;
}

.admin-card-list > article span,
.admin-card-list > article small {
  color: var(--muted);
  font-weight: 800;
}

.admin-rbac-panel {
  margin-top: 18px;
}

.admin-rbac-form {
  display: grid;
  gap: 14px;
}

.admin-rbac-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(160px, max-content) minmax(0, 1fr);
  gap: 12px;
  align-items: end;
}

.admin-rbac-toolbar select {
  width: 100%;
}

.admin-rbac-summary {
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-rbac-summary span,
.admin-rbac-summary small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-rbac-inherit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: #f8f9fb;
  color: var(--navy);
  font-size: 13px;
  font-weight: 900;
}

.admin-rbac-inherit input {
  width: 16px;
  height: 16px;
  accent-color: var(--navy);
}

.admin-rbac-matrix {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-rbac-module {
  display: grid;
  gap: 8px;
  min-width: 0;
  margin: 0;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-rbac-module legend {
  padding: 0 6px;
  color: var(--navy);
  font-weight: 900;
}

.admin-rbac-permission {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: start;
  padding: 8px;
  background: var(--soft);
  border-radius: 4px;
}

.admin-rbac-permission input {
  margin-top: 3px;
}

.admin-rbac-permission strong,
.admin-rbac-permission small {
  display: block;
}

.admin-rbac-permission small {
  color: var(--muted);
  font-size: 12px;
}

.admin-workload-panel {
  margin-top: 18px;
  border-top: 5px solid var(--green);
}

.admin-workload-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.admin-workload-summary article {
  display: grid;
  gap: 4px;
  padding: 12px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
}

.admin-workload-summary article:nth-child(even) {
  border-left-color: var(--red);
}

.admin-workload-summary span,
.admin-workload-summary small,
.admin-workload-filters label,
.admin-workload-agent-detail > div:first-child span,
.admin-workload-agent-metrics span,
.admin-workload-detail-grid h4 span,
.admin-workload-detail-grid li span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-workload-summary strong {
  color: var(--ink);
  font-size: 22px;
}

.admin-workload-filters {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  gap: 10px;
  align-items: end;
  margin-bottom: 14px;
}

.admin-workload-filters label {
  display: grid;
  gap: 6px;
  text-transform: uppercase;
}

.admin-workload-filters select,
.admin-workload-filters input {
  width: 100%;
  background: #f8f9fb;
}

#admin-workload-rows tr.is-active td {
  background: var(--soft-bg);
}

#admin-workload-rows button,
.admin-workload-detail-grid button {
  min-height: 34px;
  padding: 7px 10px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  cursor: pointer;
}

#admin-workload-rows button:hover,
.admin-workload-detail-grid button:hover {
  border-color: rgba(11, 67, 255, .32);
  box-shadow: 0 6px 16px rgba(20, 35, 63, .08);
}

.admin-workload-details {
  margin-top: 14px;
}

.admin-workload-agent-detail {
  display: grid;
  gap: 14px;
  padding: 14px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-workload-agent-detail h4 {
  margin: 2px 0;
  font-size: 20px;
}

.admin-workload-agent-detail p {
  margin: 0;
  color: var(--muted);
  font-weight: 800;
}

.admin-workload-agent-metrics,
.admin-workload-detail-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.admin-workload-agent-metrics article,
.admin-workload-detail-grid article {
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-workload-agent-metrics strong {
  display: block;
  margin-top: 4px;
  color: var(--ink);
  font-size: 20px;
}

.admin-workload-detail-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-workload-detail-grid h4 {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--navy);
  font-size: 15px;
}

.admin-workload-detail-grid ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.admin-workload-detail-grid li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 9px;
  background: var(--soft);
  border-radius: 4px;
}

.admin-workload-detail-grid li strong,
.admin-workload-detail-grid li span {
  display: block;
}

.admin-workload-detail-grid li span {
  margin-top: 2px;
  overflow-wrap: anywhere;
}

.admin-stats-grid article,
.admin-panel,
.admin-queue-list article {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-stats-grid article {
  position: relative;
  padding: 18px;
  border-top: 5px solid var(--blue);
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.admin-stats-grid article img {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.admin-stats-grid article:nth-child(2),
.admin-stats-grid article:nth-child(4) {
  border-top-color: var(--red);
}

.admin-stats-grid article[data-admin-view-link] {
  cursor: pointer;
}

.admin-stats-grid article[data-admin-view-link]:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.admin-stats-grid article[data-tone="danger"] {
  border-top-color: var(--red);
}

.admin-stats-grid article[data-tone="warning"] {
  border-top-color: var(--warning);
}

.admin-stats-grid article[data-tone="success"] {
  border-top-color: var(--success);
}

.admin-stats-grid article[data-tone="info"] {
  border-top-color: var(--blue);
}

.admin-stats-grid span,
.admin-queue-list span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-stats-grid strong {
  display: block;
  margin: 8px 0;
  font-size: 30px;
}

.admin-stats-grid small {
  display: inline-flex;
  max-width: 100%;
  padding: 4px 7px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  background: var(--soft-bg);
  border-radius: 4px;
}

.admin-view-stack {
  display: grid;
}

.admin-view {
  display: none;
  gap: 18px;
}

.admin-view.is-active {
  display: grid;
}

.admin-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.72fr);
  gap: 18px;
}

.admin-overview-grid > *,
.admin-dashboard-grid > *,
.admin-view-layout > * {
  min-width: 0;
}

.admin-view-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 18px;
}

.admin-case-layout {
  grid-template-columns: minmax(0, 0.82fr) minmax(480px, 1.18fr);
}

.admin-side-panel {
  align-self: start;
  position: sticky;
  top: 24px;
}

.admin-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 18px;
}

.admin-panel {
  min-width: 0;
  padding: 20px;
}

.admin-section-panel {
  scroll-margin-top: 24px;
}

.admin-section-flash {
  box-shadow: 0 0 0 3px rgba(0, 0, 145, 0.16);
}

.admin-crud-panel {
  margin-bottom: 18px;
  border-top: 5px solid var(--blue);
}

.admin-crud-head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: center;
}

.admin-crud-head-actions select {
  width: min(260px, 100%);
}

.admin-crud-shell {
  display: grid;
  grid-template-columns: minmax(320px, 0.8fr) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.admin-crud-form {
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-crud-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-crud-form-grid label:has(textarea) {
  grid-column: 1 / -1;
}

.admin-crud-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.admin-crud-list {
  display: grid;
  gap: 10px;
  max-height: 420px;
  overflow: auto;
}

.admin-crud-record {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 4px solid var(--blue);
  border-radius: 4px;
}

.admin-crud-record.is-active {
  border-left-color: var(--red);
  box-shadow: inset 0 0 0 1px rgba(225, 0, 15, 0.12);
}

.admin-crud-record > button:first-child {
  display: grid;
  gap: 3px;
  padding: 0;
  text-align: left;
  background: transparent;
  border: 0;
}

.admin-crud-record strong {
  color: var(--navy);
}

.admin-crud-record span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.admin-crud-delete {
  min-height: 34px;
  padding: 0 10px;
  color: var(--red);
  font-size: 12px;
  font-weight: 900;
  background: #fff;
  border: 1px solid var(--red);
  border-radius: 4px;
}

.admin-crud-details {
  margin-top: 18px;
}

.admin-crud-details:empty {
  display: none;
}

.admin-crud-detail-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.admin-crud-detail-card {
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-crud-detail-card h4 {
  margin-bottom: 10px;
  color: var(--navy);
}

.admin-crud-detail-card ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.admin-crud-detail-card li {
  padding: 9px;
  background: var(--soft);
  border-radius: 4px;
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
}

.admin-crud-timeline {
  display: grid;
  gap: 10px;
}

.admin-crud-timeline article {
  padding: 12px;
  border-left: 4px solid var(--blue);
  background: #fff;
  border-radius: 4px;
  box-shadow: var(--shadow-soft);
}

.admin-crud-timeline span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-crud-timeline strong {
  display: block;
  color: var(--navy);
}

.admin-collaborator-detail {
  display: grid;
  gap: 14px;
}

.admin-collaborator-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-collaborator-identity {
  display: flex;
  min-width: 0;
  align-items: center;
  gap: 12px;
}

.admin-collaborator-identity img {
  width: 54px;
  height: 54px;
  object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--line);
}

.admin-collaborator-identity span,
.admin-collaborator-identity p,
.admin-collaborator-card span,
.admin-collaborator-card small,
.admin-collaborator-permissions span,
.admin-collaborator-metrics span,
.admin-collaborator-metrics small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-collaborator-identity h3,
.admin-collaborator-identity p {
  margin: 0;
}

.admin-collaborator-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}

.admin-collaborator-metrics,
.admin-collaborator-grid,
.admin-collaborator-permissions > div {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.admin-collaborator-metrics article,
.admin-collaborator-card,
.admin-collaborator-permissions {
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-collaborator-metrics strong {
  display: block;
  margin-top: 4px;
  color: var(--navy);
  line-height: 1.35;
}

.admin-collaborator-permissions {
  display: grid;
  gap: 12px;
}

.admin-collaborator-permissions h4,
.admin-collaborator-card h4 {
  margin: 0;
  color: var(--navy);
  font-size: 15px;
}

.admin-collaborator-card h4 span {
  color: var(--muted);
  font-size: 12px;
}

.admin-collaborator-permissions article {
  display: grid;
  gap: 6px;
  padding: 10px;
  background: var(--soft);
  border-radius: 4px;
}

.admin-collaborator-permissions article div {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}

.admin-collaborator-card ul {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.admin-collaborator-card li {
  padding: 9px;
  background: var(--soft);
  border-radius: 4px;
  font-size: 13px;
  font-weight: 800;
}

.admin-collaborator-card li strong,
.admin-collaborator-card li span {
  display: block;
}

.admin-collaborator-timeline {
  grid-column: 1 / -1;
}

.admin-collaborator-timeline > div {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.admin-collaborator-timeline article {
  padding: 9px;
  background: var(--soft);
  border-radius: 4px;
}

.panel-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}

.panel-title h2 {
  margin-bottom: 0;
  font-size: 22px;
}

.panel-title a {
  color: var(--blue);
  font-weight: 900;
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-panel table {
  width: 100%;
  border-collapse: collapse;
}

.admin-panel th,
.admin-panel td {
  padding: 12px 10px;
  text-align: left;
  border-bottom: 1px solid var(--line);
}

.admin-panel th {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
}

.admin-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 16px;
}

.admin-filter-input {
  flex: 1 1 280px;
  min-width: 0;
  background: #f8f9fb;
}

.admin-clickable-row {
  cursor: pointer;
}

.admin-clickable-row:hover td {
  background: #f8f9fb;
}

.admin-clickable-card {
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.admin-clickable-card:hover {
  transform: translateY(-1px);
  border-color: rgba(0, 0, 145, 0.24);
  box-shadow: 0 8px 18px rgba(0, 0, 145, 0.08);
}

.priority-pill {
  display: inline-flex;
  padding: 5px 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  background: var(--red);
  border-radius: 4px;
}

.admin-queue-list {
  display: grid;
  gap: 10px;
}

.admin-queue-list article {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-left: 5px solid var(--blue);
}

.admin-queue-list strong {
  display: block;
  margin-top: 5px;
  font-size: 26px;
}

.admin-queue-list small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.admin-queue-list article[data-tone="danger"] {
  border-left-color: var(--red);
}

.admin-queue-list article[data-tone="warning"] {
  border-left-color: var(--warning);
}

.admin-queue-list article[data-tone="success"] {
  border-left-color: var(--success);
}

.admin-queue-list article[data-admin-view-link] {
  cursor: pointer;
}

.admin-queue-list article[data-admin-view-link]:hover,
.admin-queue-list article.admin-queue-action:hover {
  box-shadow: var(--shadow);
}

.admin-queue-list article.admin-queue-action strong {
  margin-top: 0;
  font-size: 16px;
  line-height: 1.35;
}

.admin-queue-list article.admin-queue-action .button {
  justify-self: start;
  margin-top: 4px;
  padding: 7px 10px;
  font-size: 12px;
}

.admin-panel-note {
  max-width: 920px;
  color: var(--muted);
  font-weight: 700;
}

.admin-connected-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.admin-connected-grid article {
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 190px;
  padding: 16px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-connected-grid article:first-child {
  border-left-color: var(--red);
}

.admin-connected-grid span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-connected-grid strong {
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}

.admin-connected-grid p {
  margin: 0;
  color: var(--muted);
  font-weight: 700;
}

.admin-connected-grid .button {
  justify-self: start;
  margin-top: auto;
}

.admin-control-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.admin-control-grid label {
  display: grid;
  gap: 8px;
  color: var(--ink);
  font-weight: 900;
}

.admin-control-grid input,
.admin-control-grid textarea {
  width: 100%;
  min-width: 0;
  color: var(--ink);
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-delete-zone {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.admin-json-editor {
  margin-top: 18px;
  padding: 14px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-json-editor summary {
  cursor: pointer;
  color: var(--blue);
  font-weight: 900;
}

.admin-json-editor textarea {
  width: 100%;
  margin: 12px 0;
  color: #111827;
  font-family: Consolas, monospace;
  font-size: 13px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

#admin-delete-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-delete-button {
  border-color: var(--danger-border);
}

.admin-sync-grid {
  grid-template-columns: minmax(0, 1fr) 390px;
}

.admin-source-list,
.admin-message-list,
.admin-client-list,
.admin-document-list,
.admin-photo-strip {
  display: grid;
  gap: 12px;
}

.admin-source-list {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-source-list-compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-source-list article {
  padding: 14px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-source-list span,
.admin-source-list small,
.admin-client-list span,
.admin-document-list span,
.admin-photo-strip span,
.admin-message-list small {
  color: var(--muted);
  font-weight: 800;
}

.admin-source-list strong {
  display: block;
  margin: 6px 0;
  font-size: 20px;
}

.admin-message-list article,
.admin-client-list article,
.admin-document-list article {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-message-list article {
  grid-template-columns: 44px minmax(0, 1fr) auto;
}

.admin-message-list img,
.admin-client-list img,
.admin-document-list img,
.admin-person img {
  width: 44px;
  height: 44px;
  object-fit: cover;
  border-radius: 50%;
}

.admin-document-list img {
  border-radius: 4px;
}

.admin-message-list p {
  margin: 3px 0;
  color: var(--muted);
  font-size: 14px;
}

.admin-message-kind {
  align-self: start;
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--blue);
  background: #fff;
  font-size: 11px;
  text-transform: uppercase;
}

.admin-message-detail-card {
  display: grid;
  gap: 14px;
}

.admin-message-thread-preview {
  padding: 12px;
  background: #f8f9fb;
  border-left: 4px solid var(--blue);
}

.admin-message-thread-preview span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-message-thread-preview p {
  margin: 5px 0 0;
}

.admin-support-replies {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.admin-support-replies > span,
.admin-support-replies > strong {
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.admin-support-replies article {
  display: grid;
  gap: 5px;
  padding: 10px;
  border-left: 3px solid var(--blue);
  background: #f8f9fb;
}

.admin-support-replies article span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.admin-support-replies article p {
  margin: 0;
  color: var(--ink);
}

.admin-reply-form {
  display: grid;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.admin-reply-form textarea {
  resize: vertical;
}

.admin-notification-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.case360-card .admin-notification-actions {
  justify-content: flex-end;
  padding-top: 0;
  border-top: 0;
}

.admin-notification-actions button {
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 7px 10px;
  color: var(--blue);
  background: #fff;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.admin-notification-actions button[data-notification-open],
.admin-table-actions button[data-notification-open] {
  border-color: var(--blue);
  color: #fff;
  background: var(--blue);
}

.admin-notification-actions button:disabled {
  opacity: .45;
  cursor: not-allowed;
}

.admin-notification-center-panel {
  border-top: 5px solid var(--success);
}

.admin-notification-center-panel .panel-title p {
  margin: 4px 0 0;
  color: var(--muted);
}

.admin-notification-filters {
  grid-template-columns: 1.5fr repeat(5, minmax(118px, 1fr));
  margin-top: 16px;
}

.admin-notification-table td {
  vertical-align: top;
}

.admin-notification-table small {
  color: var(--muted);
  font-weight: 800;
  line-height: 1.45;
}

.admin-person {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 900;
}

.admin-person img {
  width: 34px;
  height: 34px;
}

.admin-card-list,
.admin-visual-grid {
  display: grid;
  gap: 18px;
}

.admin-card-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.admin-directory-card,
.admin-review-card {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 14px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-directory-card img,
.admin-review-card img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 10px;
}

.admin-directory-card div,
.admin-review-card div {
  display: grid;
  gap: 4px;
}

.admin-directory-card span,
.admin-review-card span,
.admin-directory-card small,
.admin-review-card small {
  color: var(--muted);
}

.admin-directory-card b,
.admin-review-card b {
  color: var(--blue);
  font-size: 13px;
}

.admin-document-actions {
  display: flex !important;
  flex-wrap: wrap;
  gap: 6px !important;
  margin-top: 6px;
}

.admin-document-actions button {
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 7px 10px;
  color: var(--ink);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
}

.admin-document-actions button:nth-child(2) {
  border-color: rgba(13, 117, 62, 0.24);
  color: var(--success);
}

.admin-document-actions button:nth-child(3) {
  border-color: rgba(174, 35, 47, 0.24);
  color: var(--red);
}

.admin-document-actions button:disabled,
.client-documents li button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.admin-photo-strip article {
  overflow: hidden;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-photo-strip img {
  width: 100%;
  height: 116px;
  object-fit: cover;
}

.admin-photo-strip strong,
.admin-photo-strip span {
  display: block;
  padding: 0 10px;
}

.admin-photo-strip strong {
  padding-top: 10px;
}

.admin-photo-strip span {
  padding-bottom: 10px;
  font-size: 13px;
}

.status-badge {
  display: inline-flex;
  padding: 5px 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  background: var(--blue);
  border-radius: 4px;
}

.status-badge[data-tone="success"] {
  background: var(--success);
}

.status-badge[data-tone="warning"] {
  background: var(--warning);
}

.status-badge[data-tone="danger"] {
  background: var(--red);
}

.status-badge[data-tone="neutral"] {
  background: #4b5563;
}

.status-badge[data-tone="info"] {
  background: var(--soft-bg);
  color: var(--blue);
}

.status-badge[data-tone="muted"] {
  background: #f3f4f6;
  color: var(--muted);
}

.admin-bars {
  display: grid;
  grid-template-columns: repeat(6, minmax(44px, 1fr));
  align-items: stretch;
  gap: 10px;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  min-height: 260px;
  padding: 14px;
  overflow-x: auto;
  background: linear-gradient(180deg, #fff, #f8f9fb);
  border: 1px solid var(--line);
}

.admin-bar-button {
  display: grid;
  grid-template-rows: 1fr auto auto;
  align-items: end;
  width: 100%;
  min-height: 220px;
  padding: 8px 6px;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.admin-bar-fill {
  display: block;
  width: 100%;
  height: var(--bar);
  min-height: 24px;
  background: linear-gradient(180deg, var(--fr-blue), var(--navy));
  border-radius: 4px 4px 0 0;
}

.admin-bar-button:nth-child(even) .admin-bar-fill {
  background: linear-gradient(180deg, var(--fr-red), var(--fr-red));
}

.admin-bar-button:hover {
  border-color: rgba(11, 67, 255, .32);
  box-shadow: 0 12px 26px rgba(20, 35, 63, .09);
  transform: translateY(-2px);
}

.admin-bar-button strong,
.admin-bar-button small {
  display: block;
  width: 100%;
  text-align: center;
}

.admin-bar-button strong {
  margin-top: 8px;
  font-size: 12px;
  font-weight: 900;
}

.admin-bar-button small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.admin-detail-panel {
  margin-top: 18px;
}

.admin-detail-empty {
  color: var(--muted);
  font-weight: 700;
}

.admin-detail-card {
  padding: 16px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-detail-card h3 {
  margin-bottom: 14px;
  font-size: 22px;
}

.admin-detail-card h4 {
  margin-bottom: 14px;
  font-size: 20px;
}

.admin-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.admin-detail-grid article {
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-detail-grid span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-detail-grid strong {
  display: block;
  margin-top: 4px;
  line-height: 1.45;
}

.case360 {
  display: grid;
  gap: 16px;
}

.case360-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.case360-head span,
.case360-metrics span,
.case360-card h5 span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.case360-head h4 {
  margin: 3px 0;
}

.case360-head p {
  margin: 0;
  color: var(--muted);
}

.case360-head > strong {
  padding: 7px 10px;
  color: var(--blue);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  white-space: nowrap;
}

.case360-metrics,
.case360-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.case360-metrics article,
.case360-card,
.case360-actions form {
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.case360-metrics strong {
  display: block;
  margin-top: 4px;
}

.case360-metrics article.is-ok {
  border-color: rgba(11, 107, 45, 0.22);
  background: rgba(11, 107, 45, 0.05);
}

.case360-metrics article.is-warning {
  border-color: rgba(225, 0, 15, 0.25);
  background: rgba(225, 0, 15, 0.05);
}

.admin-warning {
  margin-top: 14px;
  padding: 14px 16px;
  border: 1px solid rgba(225, 0, 15, 0.22);
  border-radius: var(--radius-md);
  background: rgba(225, 0, 15, 0.06);
  color: var(--ink);
}

.admin-warning strong {
  display: block;
  margin-bottom: 8px;
  color: var(--navy);
}

.preanalysis-workflow-card {
  display: grid;
  grid-template-columns: minmax(220px, .7fr) minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  background: linear-gradient(135deg, #fff 0%, #f7faff 100%);
  border: 1px solid rgba(13, 75, 118, 0.18);
  border-left: 5px solid var(--red);
  border-radius: 4px;
}

.preanalysis-workflow-card > div > span {
  color: var(--red);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.preanalysis-workflow-card h5 {
  margin: 4px 0;
  color: var(--navy);
  font-size: 16px;
}

.preanalysis-workflow-card p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.preanalysis-step-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.preanalysis-step-list li {
  min-width: 0;
  padding: 10px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.preanalysis-step-list li[data-state="done"] {
  border-color: rgba(25, 135, 84, 0.28);
  background: var(--success-bg);
}

.preanalysis-step-list li[data-state="active"] {
  border-color: rgba(191, 26, 47, 0.32);
  background: var(--danger-bg);
}

.preanalysis-step-list strong,
.preanalysis-step-list span {
  display: block;
}

.preanalysis-step-list strong {
  color: var(--navy);
  font-size: 13px;
}

.preanalysis-step-list span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.consultation-step-list {
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}

.consultation-snapshot-card li {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  gap: 8px;
}

.consultation-snapshot-card li strong {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
}

.consultation-snapshot-card li span {
  overflow-wrap: anywhere;
}

.case360-prefecture-analysis {
  display: grid;
  gap: 12px;
  border-left: 5px solid var(--blue);
}

.case360-analysis-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.case360-analysis-head p {
  margin: 5px 0 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.case360-analysis-head > strong {
  max-width: 46%;
  padding: 7px 9px;
  color: var(--blue);
  background: var(--soft-blue);
  border: 1px solid rgba(35, 107, 217, 0.22);
  border-radius: 999px;
  font-size: 12px;
  text-align: right;
}

.case360-analysis-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.case360-analysis-metrics article {
  padding: 9px;
  background: var(--soft);
  border: 1px solid var(--line);
  border-radius: 4px;
}

.case360-analysis-metrics span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.case360-analysis-metrics strong {
  display: block;
  margin-top: 4px;
  color: var(--navy);
}

.case360-analysis-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.case360-analysis-columns section {
  min-width: 0;
}

.case360-analysis-columns h5 {
  margin-bottom: 8px;
}

.case360-analysis-action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}

.case360-analysis-action textarea {
  width: 100%;
}

.case360-analysis-columns li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.case360-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.case360-actions form {
  display: grid;
  gap: 8px;
}

.case360-actions .case360-danger-form {
  border-color: rgba(225, 0, 15, 0.24);
  background: linear-gradient(180deg, #fff, var(--danger-bg));
}

.case360-actions h5,
.case360-card h5 {
  margin: 0;
  color: var(--navy);
  font-size: 15px;
}

.case360-actions input,
.case360-actions select,
.case360-actions textarea {
  width: 100%;
}

.case360-form-hint {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.case360-actions .case360-checkbox {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  align-items: start;
  gap: 8px;
  color: var(--navy);
  font-size: 12px;
  font-weight: 900;
}

.case360-actions .case360-checkbox input {
  width: 18px;
  min-height: 18px;
  margin-top: 2px;
}

.case360-assignment-load {
  display: grid;
  gap: 8px;
}

.case360-assignment-load > span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.case360-assignment-load ul {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.case360-assignment-load li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
  padding: 8px;
  background: var(--soft);
  border: 1px solid transparent;
  border-radius: 4px;
}

.case360-assignment-load li.is-recommended {
  border-color: rgba(35, 107, 217, 0.35);
  background: var(--soft-bg);
}

.case360-assignment-load strong,
.case360-assignment-load span {
  display: block;
}

.case360-assignment-load b {
  padding: 5px 7px;
  color: var(--blue);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 11px;
  white-space: nowrap;
}

.case360-card ul {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.case360-card li {
  padding: 9px;
  background: var(--soft);
  border-radius: 4px;
  font-size: 13px;
  font-weight: 800;
}

.case360-documents li {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.case360-documents span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.case360-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.case360-inline-actions button {
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 6px 8px;
  background: #fff;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.case360-inline-actions a,
.case360-inline-actions span {
  display: inline-flex;
  align-items: center;
  min-height: 29px;
  padding: 0 8px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.case360-inline-actions button:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

.case360-timeline {
  grid-column: 1 / -1;
}

.case360-timeline > div {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.case360-timeline article {
  padding: 9px;
  background: var(--soft);
  border-radius: 4px;
}

.case360-timeline small {
  display: block;
  color: var(--muted);
}

.admin-summary-grid,
.admin-settings-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.admin-summary-grid article,
.admin-settings-grid article {
  padding: 14px;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-left: 5px solid var(--blue);
  border-radius: 4px;
}

.admin-summary-grid span,
.admin-settings-grid span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-summary-grid strong,
.admin-settings-grid strong {
  display: block;
  margin-top: 6px;
  line-height: 1.4;
}

.admin-action-list {
  display: grid;
  gap: 10px;
}

.admin-prefecture-hero {
  padding: 18px;
  background: linear-gradient(135deg, var(--soft-bg), #ffffff);
  border: 1px solid var(--border);
  border-left: 6px solid var(--red);
  border-radius: 4px;
}

.admin-prefecture-hero strong {
  display: block;
  margin-bottom: 8px;
  color: var(--blue);
}

.admin-prefecture-hero p {
  margin-bottom: 0;
  color: var(--muted);
}

.admin-map-shell {
  position: relative;
  min-height: 360px;
  overflow: hidden;
  background: #f8f9fb;
  border: 1px solid var(--line);
  border-radius: 4px;
}

.admin-map-canvas {
  width: 100%;
  min-height: 360px;
}

.admin-map-fallback {
  display: grid;
  place-items: center;
  min-height: 360px;
  padding: 24px;
  color: var(--muted);
  font-weight: 700;
  text-align: center;
}

.admin-region-focus {
  display: grid;
  gap: 18px;
}

.admin-region-focus > div {
  display: grid;
  gap: 10px;
}

.admin-region-focus > div > strong {
  color: var(--blue);
  font-size: 14px;
}

.admin-content-block {
  margin-top: 14px;
}

.admin-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.admin-chip {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 0 12px;
  color: var(--blue);
  font-weight: 900;
  background: var(--soft-bg);
  border: 1px solid var(--border);
  border-radius: 999px;
}

/* Public identity accents: decorative bars use the same French tricolor system. */
.metrics span,
.hero-panel,
.dossier-fieldset,
.recommendation,
.preview-grid article,
.audience-grid article,
.legal-limit-grid article,
.consultation-cards article,
.comparison-grid article,
.document-intelligence-cards article,
.trust-stats article,
.trust-grid article,
.aftercare-grid article,
.prefecture-card,
.price-card,
.locations-grid article,
.zone-overview-grid article,
.review-card,
.review-empty-card,
.auth-panel,
.task-grid article,
.review-card blockquote,
.residence-card-demo,
.document-source-note,
.prefecture-brief,
.offer-box,
.official-source-panel,
.checkout-summary,
.preanalysis-review,
.checkout-consents,
.generated-list li,
.client-documents li,
.document-group-list article,
.upsell-list label,
.upsell-list p,
.check-list li,
.timing-list span {
  position: relative;
  overflow: hidden;
}

.hero-panel,
.preview-grid article,
.audience-grid article,
.legal-limit-grid article,
.consultation-cards article,
.comparison-grid article,
.document-intelligence-cards article,
.trust-grid article,
.aftercare-grid article,
.prefecture-card,
.price-card,
.locations-grid article,
.zone-overview-grid article,
.review-card,
.review-empty-card,
.auth-panel {
  border-top-color: transparent;
}

.dossier-fieldset,
.recommendation,
.timing-list span,
.upsell-list label,
.upsell-list p,
.offer-box,
.generated-list li,
.prefecture-brief,
.document-group-list article,
.official-source-panel,
.document-source-note,
.trust-stats article,
.residence-card-demo,
.check-list li,
.review-card blockquote {
  border-left: 1px solid var(--line);
}

.metrics span {
  box-shadow: none;
}

.price-card.featured {
  box-shadow: var(--shadow-soft);
}

.metrics span::after,
.hero-panel::after,
.dossier-fieldset::after,
.recommendation::after,
.preview-grid article::after,
.audience-grid article::after,
.legal-limit-grid article::after,
.consultation-cards article::after,
.comparison-grid article::after,
.document-intelligence-cards article::after,
.trust-stats article::after,
.trust-grid article::after,
.aftercare-grid article::after,
.prefecture-card::after,
.price-card::after,
.locations-grid article::after,
.zone-overview-grid article::after,
.review-card::after,
.review-empty-card::after,
.auth-panel::after,
.task-grid article::after,
.review-card blockquote::after,
.residence-card-demo::after,
.document-source-note::after,
.prefecture-brief::after,
.offer-box::after,
.official-source-panel::after,
.checkout-summary::after,
.preanalysis-review::after,
.checkout-consents::after,
.generated-list li::after,
.client-documents li::after,
.document-group-list article::after,
.upsell-list label::after,
.upsell-list p::after,
.check-list li::after,
.timing-list span::after {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: var(--tricolor-bar-light);
  border-bottom: 1px solid rgba(22, 22, 22, 0.08);
}

.metrics span::after,
.price-card.featured::after {
  background: var(--tricolor-bar);
  border-bottom-color: rgba(255, 255, 255, 0.24);
}

.page-hero,
.automation-section,
.document-intelligence-section,
.legal-limit-section,
.workflow-section,
.prefecture-section,
.final-cta-section {
  border-top-color: transparent;
  border-image: var(--tricolor-bar-light) 1;
}

.page-hero {
  border-bottom-color: transparent;
  border-image: var(--tricolor-bar) 1;
}

.client-auth-hero {
  border-image: var(--tricolor-bar-light) 1;
}

.expert-section {
  border-top-color: transparent;
  border-bottom-color: transparent;
  border-image: var(--tricolor-bar) 1;
}

/* Public visual polish: one radius scale, compact brand, restrained French accents. */
#accueil .section-media,
#accueil .section-media img,
#accueil .reviews-home-media img,
#accueil .zone-overview-media,
#accueil .zone-overview-media img,
.page-hero img,
.document-photo-stack img {
  border-radius: var(--radius-xl);
}

#accueil .hero-panel,
#accueil .home-split-section,
#accueil .client-secure-layout,
#accueil .reviews-section,
#accueil .faq-section,
#accueil .final-cta-section,
#accueil .audience-grid article,
#accueil .legal-limit-grid article,
#accueil .consultation-cards article,
#accueil .comparison-grid article,
#accueil .client-value-grid article,
#accueil .zone-overview-grid article,
#accueil .price-card,
#accueil .review-card,
#accueil .review-empty-card,
#accueil .process-grid article,
#accueil .task-grid article,
#accueil .timing-panel {
  border-radius: var(--radius-lg);
}

#accueil .hero-mini-proof,
#accueil .metrics span,
#accueil .section-vector,
#accueil .process-grid span,
#accueil .formality-card span,
#accueil .review-badge,
.brand-mark,
.footer-brand-mark {
  border-radius: var(--radius-md);
}

#accueil .button,
#accueil .price-card a,
#accueil .audience-grid a,
#accueil .review-filters button,
.contact-cta,
.client-cta,
.header-cta {
  border-radius: var(--radius-pill);
}

#accueil .section-vector {
  width: 56px;
  height: 56px;
}

#accueil .section-vector svg {
  width: 36px;
  height: 32px;
}

#accueil .formality-card,
#accueil .locations-grid article,
.preview-grid article,
.trust-stats article,
.trust-grid article,
.aftercare-grid article,
.people-story-card,
.prefecture-card,
.offer-box,
.checkout-summary,
.preanalysis-review,
.checkout-consents,
.review-card,
.review-empty-card {
  border-radius: var(--radius-lg);
}

.france-chip,
.metrics span,
.dossier-fieldset,
.recommendation,
.timing-list span,
.residence-card-demo,
.review-card blockquote,
.generated-list li,
.document-group-list article,
.check-list li,
.console-tab,
.progress-track span {
  border-radius: var(--radius-md);
}

input,
select,
textarea {
  border-radius: var(--radius-sm);
}

#accueil .section-media img {
  height: clamp(300px, 30vw, 420px);
  object-fit: cover;
}

#accueil .faq-section .section-media img {
  height: clamp(300px, 30vw, 430px);
}

#accueil .price-includes li::before {
  background: var(--fr-red);
}

#accueil .inline-link:hover {
  color: var(--fr-blue);
  border-color: var(--fr-blue);
}

.mobile-cta {
  display: none;
}

@media (max-width: 980px) {
  .site-header {
    grid-template-columns: auto auto;
    gap: 12px;
  }

  .brand {
    min-width: 0;
  }

  .brand small {
    font-size: 10px;
  }

  .nav-toggle {
    display: block;
    justify-self: end;
  }

  .site-nav,
  .header-actions {
    display: none;
  }

  .site-nav.is-open {
    display: grid;
    grid-column: 1 / -1;
    justify-content: stretch;
    gap: 0;
  }

  .header-actions.is-open {
    display: grid;
    grid-column: 1 / -1;
    justify-content: stretch;
    gap: 8px;
  }

  .site-nav.is-open a {
    padding: 13px 4px;
    border-top: 1px solid var(--line);
  }

  .header-actions.is-open .client-cta,
  .header-actions.is-open .header-cta {
    width: 100%;
  }

  .hero,
  .expert-section,
  .client-auth-hero,
  .automation-layout,
  .consultation-layout {
    grid-template-columns: 1fr;
  }

  .hero {
    min-height: auto;
    padding-top: 110px;
    padding-bottom: 72px;
  }

  .hero-mini-proof-grid {
    grid-template-columns: 1fr;
    max-width: 420px;
  }

  .automation-result {
    position: static;
  }

  .formalities-grid,
  .process-grid,
  .people-stories-grid,
  .trust-bar,
  .client-stats-strip,
  .preview-grid,
  .solution-card-grid,
  .client-value-grid,
  .zone-overview-grid,
  .audience-grid,
  .timing-list,
  .consultation-cards,
  .comparison-grid,
  .legal-limit-grid,
  .reviews-grid,
  .checkout-steps,
  .document-intelligence-cards,
  .pricing-grid,
  .locations-grid,
  .task-grid,
  .prefecture-grid,
  .workflow-grid,
  .trust-grid,
  .aftercare-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .trust-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .client-entry,
  .home-split-section,
  .client-secure-layout,
  .timing-layout,
  .document-intelligence-layout,
  .client-dashboard-shell,
  .client-documents,
  .client-live-grid,
  .client-message-center,
  .admin-external-grid,
  .admin-external-test-row,
  .admin-shell,
  .admin-backend-layout,
  .admin-filter-card,
  .admin-global-search,
  .admin-overview-grid,
  .offer-intro-layout,
  .admin-view-layout,
  .admin-dashboard-grid,
  .admin-sync-grid,
  .admin-intelligence-form,
  .admin-intelligence-indexer,
  .admin-crud-shell,
  .admin-crud-detail-grid,
  .admin-visual-grid,
  .admin-production-sla-form {
    grid-template-columns: 1fr;
  }

  .home-split-section.reverse .section-media,
  .home-split-section.reverse .section-copy {
    order: initial;
  }

  .home-split-section .section-copy {
    order: 1;
  }

  .home-split-section .section-media {
    order: 2;
  }

  .section-media img {
    height: 260px;
  }

  .admin-sidebar {
    position: static;
    height: auto;
  }

  .admin-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-source-list,
  .admin-source-list-compact,
  .admin-summary-grid,
  .admin-settings-grid,
  .admin-module-grid,
  .admin-email-smtp-summary,
  .admin-reminder-settings-grid,
  .admin-reminder-candidate-list,
  .admin-reminder-history-list,
  .admin-rgpd-candidate-list,
  .admin-workload-filters,
  .admin-workload-summary,
  .admin-workload-agent-metrics,
  .admin-workload-detail-grid,
  .admin-rbac-matrix,
  .admin-control-summary,
  .admin-control-grid,
  .admin-connected-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-detail-grid {
    grid-template-columns: 1fr;
  }

  .case360-actions,
  .case360-grid,
  .case360-metrics,
  .case360-analysis-metrics,
  .case360-analysis-columns,
  .case360-analysis-action {
    grid-template-columns: 1fr;
  }

  .case360-analysis-head {
    display: grid;
  }

  .case360-analysis-head > strong {
    max-width: none;
    text-align: left;
  }
}

@media (max-width: 680px) {
  body {
    padding-bottom: 64px;
  }

  .auth-name-grid,
  .client-profile-grid,
  .client-case-details {
    grid-template-columns: 1fr;
  }

  .client-action-required,
  .client-profile-completion,
  .client-case-summary {
    display: grid;
  }

  .client-action-required button,
  .client-profile-completion button,
  .client-case-summary button {
    width: 100%;
  }

  .section {
    padding: 52px 18px;
  }

  .site-footer {
    grid-template-columns: 1fr;
    padding-bottom: 92px;
  }

  .footer-bottom {
    display: grid;
  }

  .hero {
    min-height: auto;
    padding: 44px 18px 34px;
    background:
      linear-gradient(90deg, rgba(5, 18, 38, 0.94), rgba(5, 18, 38, 0.7), rgba(5, 18, 38, 0.35)),
      var(--hero-image, url("/assets/images/home/hero-juridex-paris-office.png")) center / cover no-repeat,
      linear-gradient(135deg, var(--deep-navy), var(--navy));
  }

  .hero::after {
    display: none;
  }

  h1 {
    max-width: 330px;
    font-size: 30px;
    line-height: 1.04;
  }

  .hero h1 {
    max-width: min(100%, 430px);
    font-size: clamp(19px, 6.2vw, 30px);
    line-height: 1.06;
  }

  .hero-title-line {
    display: block;
    white-space: nowrap;
  }

  .hero-text,
  .hero .notice {
    max-width: 340px;
  }

  h2 {
    font-size: 28px;
  }

  .hero-text,
  .section-intro {
    font-size: 16px;
  }

  .hero-actions {
    gap: 8px;
  }

  .hero-actions .button {
    width: 100%;
  }

  .metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .metrics span {
    min-width: 0;
    padding: 10px;
  }

  .home-feature-photo img {
    min-height: 230px;
    max-height: 320px;
  }

  .section-media img,
  .faq-section .section-media img {
    height: 240px;
  }

  .client-secure-layout .client-value-grid {
    grid-template-columns: 1fr;
  }

  .final-cta-section {
    display: grid;
  }

  .install-shell {
    width: min(100% - 20px, 1120px);
    padding: 18px 0;
  }

  .install-hero {
    padding: 20px;
  }

  .install-hero h1 {
    font-size: 32px;
  }

  .install-grid,
  .install-checks,
  .install-actions {
    grid-template-columns: 1fr;
  }

  .install-grid {
    display: grid;
  }

  .install-actions {
    display: grid;
  }

  .hero-panel {
    padding: 18px;
  }

  .client-entry-image,
  .client-documents img {
    height: 230px;
  }

  .document-photo-stack {
    min-height: 320px;
  }

  .document-photo-secondary {
    width: 56%;
    height: 150px;
  }

  .formalities-grid,
  .process-grid,
  .trust-bar,
  .client-stats-strip,
  .preview-grid,
  .solution-card-grid,
  .client-value-grid,
  .zone-overview-grid,
  .audience-grid,
  .timing-layout,
  .timing-list,
  .consultation-cards,
  .comparison-grid,
  .legal-limit-grid,
  .reviews-all-grid,
  .checkout-steps,
  .document-intelligence-cards,
  .people-stories-grid,
  .pricing-grid,
  .locations-grid,
  .form-grid,
  .client-console,
  .client-dashboard-shell,
  .client-live-grid,
  .admin-stats-grid,
  .admin-backend-layout,
  .admin-filter-card,
  .admin-global-search,
  .admin-source-list,
  .admin-source-list-compact,
  .admin-card-list,
  .admin-summary-grid,
  .admin-settings-grid,
  .admin-module-grid,
  .admin-email-smtp-summary,
  .admin-reminder-settings-grid,
  .admin-reminder-candidate-list,
  .admin-reminder-history-list,
  .admin-rgpd-candidate-list,
  .admin-collaborator-metrics,
  .admin-collaborator-grid,
  .admin-collaborator-permissions > div,
  .admin-workload-summary,
  .admin-workload-filters,
  .admin-workload-agent-metrics,
  .admin-workload-detail-grid,
  .admin-rbac-toolbar,
  .admin-rbac-matrix,
  .admin-control-summary,
  .admin-control-grid,
  .admin-connected-grid,
  .admin-intelligence-form,
  .admin-intelligence-indexer,
  .progress-track,
  .task-grid,
  .prefecture-grid,
  .workflow-grid,
  .trust-grid,
  .trust-stats,
  .aftercare-grid {
    grid-template-columns: 1fr;
  }

  .trust-bar {
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    grid-auto-columns: auto;
    gap: 0;
    overflow: visible;
    padding: 0;
    scroll-snap-type: none;
  }

  .trust-bar span {
    min-height: 68px;
    padding: 14px 18px;
    scroll-snap-align: none;
  }

  .reviews-section .reviews-grid {
    grid-template-columns: none;
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 86vw);
    overflow-x: auto;
    padding-bottom: 8px;
    scroll-snap-type: x proximity;
  }

  .reviews-section .review-card,
  .reviews-section .review-empty-card {
    scroll-snap-align: start;
  }

  .reviews-home-layout {
    grid-template-columns: 1fr;
  }

  .reviews-home-media img {
    height: 260px;
  }

  .reviews-page-section .reviews-grid {
    grid-template-columns: 1fr;
  }

  .admin-workspace-head,
  .admin-toolbar,
  .admin-directory-card,
  .admin-review-card,
  .admin-reminder-settings-head,
  .admin-reminder-settings-footer,
  .admin-reminder-history-head {
    display: grid;
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .admin-crud-form-grid {
    grid-template-columns: 1fr;
  }

  .admin-workspace-head {
    display: grid;
  }

  .admin-directory-card,
  .admin-review-card {
    justify-items: start;
  }

  .site-footer {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .cookie-banner {
    bottom: 76px;
  }

  .mobile-cta {
    position: fixed;
    left: 14px;
    right: 14px;
    bottom: 12px;
    z-index: 35;
    display: grid;
    place-items: center;
    min-height: 50px;
    color: #fff;
    font-weight: 900;
    background: var(--red);
    border-radius: 4px;
    box-shadow: none;
  }

  .footer-brand,
  .footer-bottom {
    grid-column: 1 / -1;
  }
}

/* Homepage design system: shared rhythm, cards, media and French accents. */
.section-title {
  color: var(--navy);
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1.06;
}

.section-subtitle {
  max-width: 720px;
  color: var(--muted);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.7;
}

.premium-grid {
  display: grid;
  gap: 18px;
  align-items: stretch;
}

.premium-card {
  position: relative;
  overflow: hidden;
  padding: 24px;
  background: #fff;
  border: 1px solid rgba(7, 18, 63, 0.1);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

#accueil .section {
  padding: var(--section-y) clamp(18px, 5vw, 72px);
}

#accueil .section > :is(.section-heading, .home-split-section, .offer-intro-layout, .pricing-grid, .client-secure-layout, .zone-overview-grid, .section-intro, .preview-actions, .reviews-home-layout) {
  width: min(100%, var(--container-max));
  margin-left: auto;
  margin-right: auto;
}

#accueil .section-heading,
#accueil .section-copy .section-heading {
  max-width: 760px;
  margin-bottom: clamp(24px, 3vw, 34px);
}

#accueil .section-heading h2,
#accueil .final-cta-section h2 {
  color: var(--navy);
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 950;
  letter-spacing: 0;
  line-height: 1.06;
}

#accueil .section-heading p,
#accueil .section-intro {
  max-width: 720px;
  color: var(--muted);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.7;
  text-transform: none;
}

#accueil .section-heading::after {
  width: 72px;
  height: 4px;
  margin-top: 16px;
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: var(--radius-pill);
  box-shadow: 0 8px 24px rgba(0, 0, 145, 0.1);
}

#accueil .home-split-section,
#accueil .offer-intro-layout,
#accueil .client-secure-layout,
#accueil .reviews-home-layout {
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}

#accueil .home-split-section {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
}

#accueil .home-split-section.reverse {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1fr);
}

#accueil .offer-intro-layout {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.92fr);
  margin-bottom: clamp(30px, 4vw, 44px);
}

#accueil .client-secure-layout {
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1fr);
}

#accueil :is(.section-media, .home-feature-photo, .reviews-home-media) {
  overflow: hidden;
  margin-top: 0;
  margin-bottom: 0;
  background: var(--navy);
  border-radius: var(--radius-xl);
  box-shadow: 0 24px 70px rgba(5, 18, 38, 0.18);
}

#accueil :is(.section-media img, .home-feature-photo img, .reviews-home-media img) {
  width: 100%;
  height: clamp(300px, 30vw, 420px);
  min-height: 0;
  max-height: none;
  object-fit: cover;
  object-position: center center;
  border-radius: var(--radius-xl);
}

#accueil .faq-section .section-media img {
  height: clamp(300px, 30vw, 430px);
  object-position: left center;
}

#accueil :is(.audience-grid, .process-grid, .pricing-grid, .client-value-grid, .zone-overview-grid, .comparison-grid, .legal-limit-grid, .faq-list, .reviews-grid) {
  gap: 18px;
  align-items: stretch;
}

#accueil :is(.audience-grid article, .process-grid article, .client-value-grid article, .zone-overview-grid article, .comparison-grid article, .legal-limit-grid article, .price-card, .faq-list details, .review-card, .review-empty-card) {
  min-height: 100%;
  padding: 24px;
  background: #fff;
  border: 1px solid rgba(7, 18, 63, 0.1);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

#accueil .price-card.featured {
  color: #fff;
  background: var(--fr-blue);
  border-color: var(--fr-blue);
}

#accueil :is(.audience-grid article, .process-grid article, .client-value-grid article, .comparison-grid article, .legal-limit-grid article, .price-card, .faq-list details, .review-card, .review-empty-card)::after {
  height: 4px;
  background: var(--tricolor-bar-light);
  border-bottom: 1px solid rgba(22, 22, 22, 0.08);
}

#accueil .price-card.featured::after {
  background: var(--tricolor-bar);
  border-bottom-color: rgba(255, 255, 255, 0.24);
}

#accueil :is(.audience-grid h3, .client-value-grid h3, .zone-overview-grid strong, .comparison-grid span, .legal-limit-grid strong, .faq-list summary, .review-card strong, .review-empty-card strong) {
  color: var(--navy);
  font-weight: 950;
  line-height: 1.2;
}

#accueil :is(.audience-grid p, .process-grid p, .client-value-grid p, .zone-overview-grid p, .comparison-grid p, .legal-limit-grid p, .faq-list p, .review-card p, .review-empty-card p) {
  color: var(--muted);
  line-height: 1.6;
}

#accueil .section-vector {
  width: 56px;
  height: 56px;
  margin: 0 0 14px;
  border-radius: var(--radius-md);
}

#accueil .section-vector svg {
  width: 36px;
  height: 32px;
}

#accueil .pricing-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

#accueil .price-card {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

#accueil .price-card a {
  width: 100%;
  margin-top: auto;
}

#accueil .zone-overview-media {
  width: calc(100% + 48px);
  height: clamp(220px, 22vw, 300px);
  margin: -24px -24px 4px;
  aspect-ratio: auto;
  border-radius: var(--radius-lg) var(--radius-lg) var(--radius-sm) var(--radius-sm);
  box-shadow: none;
}

#accueil .zone-overview-media img {
  height: 100%;
  border-radius: inherit;
}

#accueil .zones-preview-section > .button {
  margin-left: max(0px, calc((100% - var(--container-max)) / 2));
}

#accueil .final-cta-section {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 680px) auto;
  justify-content: center;
  align-items: center;
  gap: clamp(24px, 5vw, 72px);
  color: #fff;
  background: var(--deep-navy);
  border-top: 0;
}

#accueil .final-cta-section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: var(--tricolor-bar);
}

#accueil .final-cta-section h2,
#accueil .final-cta-section p {
  color: #fff;
}

#accueil .final-cta-section p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.82);
}

#accueil .final-cta-section .hero-actions {
  margin-top: 0;
}

#accueil .final-cta-section .button.secondary {
  color: #fff;
  background: transparent;
  border-color: rgba(255, 255, 255, 0.64);
}

#accueil .final-cta-section .button.secondary:hover {
  border-color: #fff;
}

@media (max-width: 980px) {
  #accueil .home-split-section,
  #accueil .home-split-section.reverse,
  #accueil .offer-intro-layout,
  #accueil .client-secure-layout,
  #accueil .reviews-home-layout,
  #accueil .final-cta-section {
    grid-template-columns: 1fr;
  }

  #accueil .home-split-section.reverse .section-media,
  #accueil .home-split-section.reverse .section-copy {
    order: initial;
  }

  #accueil .home-split-section .section-copy {
    order: 1;
  }

  #accueil .home-split-section .section-media {
    order: 2;
  }

  #accueil .pricing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #accueil .final-cta-section {
    justify-content: stretch;
  }
}

@media (max-width: 680px) {
  #accueil .section {
    padding: 52px 18px;
  }

  #accueil :is(.section-media img, .home-feature-photo img, .reviews-home-media img, .faq-section .section-media img) {
    height: 240px;
  }

  #accueil .pricing-grid {
    grid-template-columns: 1fr;
  }

  #accueil .zones-preview-section > .button {
    margin-left: 0;
  }

  #accueil .final-cta-section .hero-actions {
    display: grid;
  }
}

/* Final public frontend harmonization: one visual system across public pages. */
body:not(.client-page):not(.admin-page) main > .section:not(.final-cta-section) > * {
  width: min(100%, var(--container-max));
  margin-right: auto;
  margin-left: auto;
}

body:not(.client-page):not(.admin-page) main > .section:not(.final-cta-section) {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}

body:not(.client-page):not(.admin-page) .page-hero {
  min-height: clamp(460px, 58vh, 620px);
  display: grid;
  align-content: center;
  border-bottom: 4px solid transparent;
  border-image: var(--tricolor-bar) 1;
}

body:not(.client-page):not(.admin-page) .page-hero h1 {
  color: #fff;
  font-weight: 950;
  letter-spacing: 0;
}

body:not(.client-page):not(.admin-page) .page-hero p {
  color: rgba(255, 255, 255, 0.88);
}

body:not(.client-page):not(.admin-page) :is(
  .preview-grid article,
  .consultation-cards article,
  .formalities-grid article,
  .process-grid article,
  .comparison-grid article,
  .legal-limit-grid article,
  .pricing-grid .price-card,
  .zone-overview-grid article,
  .faq-list details,
  .review-card,
  .review-empty-card,
  .contact-method-grid article,
  .contact-advice-card,
  .contact-form,
  .contact-upsell-card,
  .automation-form,
  .automation-result,
  .booking-form,
  .checkout-summary,
  .checkout-consents,
  .offer-box,
  .official-source-panel,
  .prefecture-brief
) {
  border: 1px solid rgba(7, 18, 63, 0.1);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

body:not(.client-page):not(.admin-page) :is(
  .preview-grid article,
  .consultation-cards article,
  .formalities-grid article,
  .process-grid article,
  .comparison-grid article,
  .legal-limit-grid article,
  .pricing-grid .price-card,
  .zone-overview-grid article,
  .faq-list details,
  .review-card,
  .review-empty-card,
  .contact-method-grid article
) {
  overflow: hidden;
  background: #fff;
}

body:not(.client-page):not(.admin-page) :is(
  .preview-grid article,
  .consultation-cards article,
  .formalities-grid article,
  .process-grid article,
  .comparison-grid article,
  .legal-limit-grid article,
  .pricing-grid .price-card,
  .zone-overview-grid article,
  .faq-list details,
  .review-card,
  .review-empty-card,
  .contact-method-grid article
):hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

body:not(.client-page):not(.admin-page) :is(.zone-overview-media, .home-feature-photo, .section-media, .reviews-home-media) {
  border-radius: var(--radius-xl);
  box-shadow: 0 24px 70px rgba(5, 18, 38, 0.18);
}

body:not(.client-page):not(.admin-page) :is(.zone-overview-media img, .home-feature-photo img, .section-media img, .reviews-home-media img) {
  border-radius: inherit;
  object-fit: cover;
  object-position: center center;
}

body:not(.client-page):not(.admin-page) .brand-service-icon {
  width: 58px;
  height: 58px;
  border-radius: var(--radius-md);
}

body:not(.client-page):not(.admin-page) .section-heading::after,
body:not(.client-page):not(.admin-page) .contact-method-grid article::before {
  background: var(--tricolor-bar-light);
  border: 1px solid rgba(22, 22, 22, 0.08);
  border-radius: var(--radius-pill);
}

body:not(.client-page):not(.admin-page) .final-cta-section {
  border-top: 0;
  background: var(--deep-navy);
}

body:not(.client-page):not(.admin-page) .final-cta-section::before {
  background: var(--tricolor-bar);
}

body:not(.client-page):not(.admin-page) :is(.hero-mini-proof, .trust-bar span) {
  border-radius: var(--radius-lg);
}

body.client-page :is(
  .auth-panel,
  .client-dashboard-shell,
  .client-action-required,
  .client-profile-completion,
  .client-case-summary,
  .client-cases-view,
  .client-documents,
  .client-message-center,
  .client-downloads article,
  .client-document-card,
  .client-profile-lock-notice,
  .client-payment-notice,
  .client-prefecture-card article,
  .client-reviews-list article
) {
  border-radius: var(--radius-lg);
}

body.client-page :is(
  .auth-tab,
  .console-tab,
  .status-pill,
  .client-case-details small,
  .client-document-card button,
  .client-inline-upload button,
  .client-message-form button,
  .client-upload-form button
) {
  border-radius: var(--radius-md);
}

@media (max-width: 680px) {
  body:not(.client-page):not(.admin-page) main > .section:not(.final-cta-section) {
    padding-top: 52px;
    padding-bottom: 52px;
  }
}

/* Final unified rule: every public page follows the same rhythm, contrast and section sizing. */
body:not(.client-page):not(.admin-page) {
  --public-section-y: 64px;
  --public-card-pad: 20px;
  --public-card-min: 140px;
  --public-title-size: clamp(28px, 3vw, 38px);
  --public-hero-title-size: clamp(38px, 5vw, 58px);
}

body:not(.client-page):not(.admin-page) main > .section:not(.final-cta-section) {
  padding-top: var(--public-section-y);
  padding-bottom: var(--public-section-y);
}

body:not(.client-page):not(.admin-page) .page-hero {
  min-height: clamp(430px, 54vh, 560px);
  padding-right: clamp(18px, 6vw, 80px);
  padding-left: clamp(18px, 6vw, 80px);
}

body:not(.client-page):not(.admin-page) .page-hero > * {
  width: min(100%, var(--container-max));
  margin-right: auto;
  margin-left: auto;
}

body:not(.client-page):not(.admin-page) .page-hero h1 {
  max-width: 980px;
  color: #fff;
  font-size: var(--public-hero-title-size);
  line-height: 1.02;
  white-space: nowrap;
}

body:not(.client-page):not(.admin-page) .page-hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.88);
}

body:not(.client-page):not(.admin-page) .section-heading {
  width: min(100%, var(--container-max));
  max-width: var(--container-max);
  margin-right: auto;
  margin-left: auto;
  margin-bottom: 22px;
}

body:not(.client-page):not(.admin-page) .section-heading h2,
body:not(.client-page):not(.admin-page) .final-cta-section h2 {
  color: var(--navy);
  font-size: var(--public-title-size);
  line-height: 1.08;
  letter-spacing: 0;
  white-space: nowrap;
}

body:not(.client-page):not(.admin-page) .section-heading p {
  max-width: 700px;
  color: var(--muted);
}

body:not(.client-page):not(.admin-page) :is(
  .preview-grid article,
  .consultation-cards article,
  .formalities-grid article,
  .process-grid article,
  .comparison-grid article,
  .legal-limit-grid article,
  .pricing-grid .price-card,
  .zone-overview-grid article,
  .faq-list details,
  .review-card,
  .review-empty-card,
  .contact-method-grid article,
  .contact-advice-card,
  .contact-form,
  .contact-upsell-card,
  .automation-form,
  .automation-result,
  .booking-form,
  .checkout-summary,
  .checkout-consents,
  .offer-box,
  .official-source-panel,
  .prefecture-brief
) {
  min-height: var(--public-card-min);
  padding: var(--public-card-pad);
  color: var(--ink);
  background: #fff;
  border-color: rgba(7, 18, 63, 0.1);
  border-radius: var(--radius-lg);
}

body:not(.client-page):not(.admin-page) :is(
  .preview-grid article,
  .consultation-cards article,
  .formalities-grid article,
  .process-grid article,
  .comparison-grid article,
  .legal-limit-grid article,
  .pricing-grid .price-card,
  .zone-overview-grid article,
  .faq-list details,
  .review-card,
  .review-empty-card,
  .contact-method-grid article,
  .contact-advice-card,
  .contact-form,
  .contact-upsell-card,
  .booking-form
) :is(h2, h3, strong, summary, label, legend, span) {
  color: var(--navy);
}

body:not(.client-page):not(.admin-page) :is(
  .preview-grid article,
  .consultation-cards article,
  .formalities-grid article,
  .process-grid article,
  .comparison-grid article,
  .legal-limit-grid article,
  .pricing-grid .price-card,
  .zone-overview-grid article,
  .faq-list details,
  .review-card,
  .review-empty-card,
  .contact-method-grid article,
  .contact-advice-card,
  .contact-form,
  .contact-upsell-card,
  .booking-form
) :is(p, li, small) {
  color: var(--muted);
}

body:not(.client-page):not(.admin-page) .brand-service-icon,
body:not(.client-page):not(.admin-page) .brand-service-icon-cta,
#accueil .brand-service-icon,
#accueil .brand-service-icon-cta {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  overflow: hidden;
  margin: 0 0 14px;
  background: #fff;
  border: 1px solid rgba(0, 0, 145, 0.14);
  border-radius: var(--radius-md);
  box-shadow: 0 14px 34px rgba(7, 18, 63, 0.1);
}

body:not(.client-page):not(.admin-page) .brand-service-icon img,
body:not(.client-page):not(.admin-page) .brand-service-icon-cta img,
#accueil .brand-service-icon img,
#accueil .brand-service-icon-cta img {
  width: 36px;
  height: 36px;
  display: block;
  object-fit: contain;
}

body:not(.client-page):not(.admin-page) .section-vector,
#accueil .section-vector {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  margin: 0 0 12px;
  border-radius: var(--radius-md);
}

body:not(.client-page):not(.admin-page) .section-vector svg,
#accueil .section-vector svg {
  width: 32px;
  height: 30px;
}

#accueil {
  --public-section-y: 62px;
  --public-card-pad: 18px;
  --public-card-min: 136px;
}

#accueil .section {
  padding-top: var(--public-section-y);
  padding-bottom: var(--public-section-y);
}

#accueil .section-heading,
#accueil .section-copy .section-heading {
  margin-bottom: 20px;
}

#accueil .section-heading h2,
#accueil .final-cta-section h2 {
  max-width: 100%;
  font-size: clamp(28px, 2.8vw, 36px);
  white-space: nowrap;
}

#accueil :is(.home-split-section, .offer-intro-layout, .client-secure-layout, .reviews-home-layout) {
  gap: clamp(24px, 4vw, 42px);
}

#accueil .home-split-section,
#accueil .offer-intro-layout {
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.88fr);
}

#accueil .home-split-section.reverse,
#accueil .client-secure-layout {
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1fr);
}

#accueil :is(.section-media img, .home-feature-photo img, .reviews-home-media img) {
  height: clamp(300px, 28vw, 390px);
}

#accueil :is(.audience-grid, .process-grid, .pricing-grid, .client-value-grid, .zone-overview-grid, .comparison-grid, .legal-limit-grid, .faq-list, .reviews-grid) {
  gap: 14px;
}

#accueil :is(.audience-grid article, .process-grid article, .client-value-grid article, .zone-overview-grid article, .comparison-grid article, .legal-limit-grid article, .price-card, .faq-list details, .review-card, .review-empty-card) {
  min-height: var(--public-card-min);
  padding: var(--public-card-pad);
}

#accueil .client-automation > .brand-service-icon {
  margin-right: auto;
  margin-left: auto;
}

#accueil .trust-bar {
  background: #fff;
}

#accueil .trust-bar span {
  color: #fff;
}

#accueil .trust-bar span:nth-child(1) {
  background: linear-gradient(135deg, var(--fr-blue) 0%, var(--navy) 100%);
}

#accueil .trust-bar span:nth-child(2) {
  color: var(--navy);
  background: #fff;
}

#accueil .trust-bar span:nth-child(3) {
  background: var(--fr-red);
}

#accueil .trust-bar :is(strong, small) {
  color: inherit;
}

#accueil .trust-bar small {
  color: rgba(255, 255, 255, 0.84);
}

#accueil .trust-bar span:nth-child(2) small {
  color: var(--muted);
}

body:not(.client-page):not(.admin-page) :is(.price-card.featured, .comparison-grid article:last-child),
#accueil :is(.price-card.featured, .comparison-grid article:last-child) {
  color: #fff;
  background: var(--fr-blue);
}

body:not(.client-page):not(.admin-page) :is(.price-card.featured, .comparison-grid article:last-child) :is(h2, h3, strong, summary, label, legend, span, p, li, small),
#accueil :is(.price-card.featured, .comparison-grid article:last-child) :is(h2, h3, strong, span, p, li, small) {
  color: inherit;
}

body:not(.client-page):not(.admin-page) .final-cta-section,
#accueil .final-cta-section {
  color: #fff;
  background: var(--deep-navy);
}

body:not(.client-page):not(.admin-page) .final-cta-section :is(h2, h3, strong, p, span, li, .eyebrow),
#accueil .final-cta-section :is(h2, h3, strong, p, span, li, .eyebrow) {
  color: inherit;
}

body:not(.client-page):not(.admin-page) .final-cta-section p,
#accueil .final-cta-section p {
  color: rgba(255, 255, 255, 0.84);
}

body:not(.client-page):not(.admin-page) :is(.map-fallback, .google-map-panel),
#accueil :is(.map-fallback, .google-map-panel) {
  color: var(--navy);
  background: #fff;
}

body:not(.client-page):not(.admin-page) :is(.map-fallback, .google-map-panel) :is(strong, p, a),
#accueil :is(.map-fallback, .google-map-panel) :is(strong, p, a) {
  color: inherit;
}

body:not(.client-page):not(.admin-page) :is(.form-success, .contact-payment-required) {
  color: var(--navy);
}

@media (max-width: 980px) {
  #accueil .timing-list.compact-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body:not(.client-page):not(.admin-page) .page-hero h1,
  body:not(.client-page):not(.admin-page) .section-heading h2,
  body:not(.client-page):not(.admin-page) .final-cta-section h2,
  #accueil .section-heading h2,
  #accueil .final-cta-section h2 {
    white-space: normal;
  }

  #accueil .home-split-section,
  #accueil .home-split-section.reverse,
  #accueil .offer-intro-layout,
  #accueil .client-secure-layout,
  #accueil .reviews-home-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 680px) {
  body:not(.client-page):not(.admin-page) {
    --public-section-y: 48px;
    --public-card-pad: 16px;
    --public-card-min: auto;
    --public-title-size: 26px;
    --public-hero-title-size: 34px;
  }

  #accueil :is(.section-media img, .home-feature-photo img, .reviews-home-media img, .faq-section .section-media img) {
    height: 230px;
  }

  #accueil .timing-list.compact-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #accueil .timing-list.compact-list span {
    min-height: 48px;
    white-space: normal;
  }
}

/* Contact hero: keep the full introduction aligned to the left. */
.contact-page-hero {
  justify-items: start;
  text-align: left;
}

.contact-page-hero > .contact-hero-copy {
  width: min(100%, 760px);
  margin-right: auto;
  margin-left: 0;
  text-align: left;
}

.contact-page-hero :is(.france-chip, h1, p, .hero-reassurance-line) {
  margin-left: 0;
  text-align: left;
}

.contact-page-hero .hero-actions {
  justify-content: flex-start;
}

/* Secondary public pages: one hero grammar everywhere. */
body:not(.client-page):not(.admin-page) .page-hero {
  min-height: clamp(500px, 58vh, 600px);
  padding: clamp(72px, 8vw, 96px) clamp(24px, 6vw, 72px);
  align-content: center;
  justify-items: start;
  text-align: left;
}

body:not(.client-page):not(.admin-page) .page-hero > *,
body:not(.client-page):not(.admin-page) .page-hero > .contact-hero-copy {
  width: min(100%, 820px);
  max-width: 820px;
  margin-right: 0;
  margin-left: 0;
  text-align: left;
}

body:not(.client-page):not(.admin-page) .page-hero .france-chip {
  width: fit-content;
  max-width: max-content;
  min-height: 46px;
  margin-bottom: 24px;
  padding: 8px 16px 8px 10px;
  color: var(--navy);
  font-size: 0.78rem;
  line-height: 1;
  letter-spacing: 0;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: var(--radius-pill);
  box-shadow: 0 16px 36px rgba(6, 17, 31, 0.18);
}

body:not(.client-page):not(.admin-page) .page-hero .brand-service-chip::before,
body:not(.client-page):not(.admin-page) .page-hero .france-chip::before {
  width: 28px;
  height: 28px;
  background: url("/assets/brand/juridex-logo.png") center / contain no-repeat;
  border: 0;
  border-radius: var(--radius-sm);
  box-shadow: none;
}

body:not(.client-page):not(.admin-page) .page-hero h1 {
  width: min(100%, 1120px);
  max-width: 1120px;
  margin: 0 0 22px;
  font-size: clamp(52px, 4.8vw, 68px);
  line-height: 1.02;
  text-align: left;
  white-space: nowrap;
}

body:not(.client-page):not(.admin-page) .page-hero p,
body:not(.client-page):not(.admin-page) .contact-page-hero p,
body:not(.client-page):not(.admin-page) .contact-page-hero .contact-hero-subtitle {
  max-width: 780px;
  margin-right: 0;
  margin-left: 0;
  color: rgba(255, 255, 255, 0.88) !important;
  font-size: 1.14rem !important;
  font-weight: 500 !important;
  line-height: 1.62;
  text-align: left;
}

body:not(.client-page):not(.admin-page) .contact-page-hero .contact-hero-subtitle {
  margin-top: 0;
  margin-bottom: 8px;
  font-size: 1.34rem !important;
  font-weight: 800 !important;
  line-height: 1.35;
}

body:not(.client-page):not(.admin-page) .page-hero .hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 12px;
  width: min(100%, 820px);
  margin-top: 28px;
}

body:not(.client-page):not(.admin-page) .page-hero .hero-actions .button {
  min-height: 58px;
  padding: 0 28px;
  font-size: 1rem;
  white-space: nowrap;
}

body:not(.client-page):not(.admin-page) .page-hero .hero-reassurance-line {
  width: min(100%, 820px);
  margin-top: 22px;
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 1rem !important;
  font-weight: 800 !important;
  line-height: 1.5;
  text-align: left;
}

/* Hard reset for homepage urgency chips: no inherited card bars or tricolor fills. */
#accueil .timing-list.compact-list {
  width: min(100%, var(--container-max)) !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin: 26px auto 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

#accueil .timing-list.compact-list span {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 0 !important;
  min-height: 48px !important;
  padding: 12px 16px !important;
  color: var(--navy) !important;
  font-size: 0.92rem !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
  text-align: center !important;
  white-space: normal !important;
  background: #fff !important;
  border: 1px solid rgba(0, 0, 145, 0.18) !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: 0 12px 28px rgba(7, 18, 63, 0.08) !important;
}

#accueil .timing-list.compact-list span::after,
#accueil .timing-list.compact-list span::before {
  display: none !important;
  content: none !important;
}

@media (max-width: 980px) {
  #accueil .timing-list.compact-list {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  body:not(.client-page):not(.admin-page) .page-hero h1 {
    white-space: normal;
  }
}

@media (max-width: 680px) {
  #accueil .timing-list.compact-list {
    grid-template-columns: 1fr !important;
  }

  body:not(.client-page):not(.admin-page) .page-hero {
    min-height: auto;
    padding-top: 96px;
    padding-bottom: 64px;
  }

  body:not(.client-page):not(.admin-page) .page-hero h1 {
    font-size: 2.35rem;
  }

  body:not(.client-page):not(.admin-page) .page-hero .hero-actions .button {
    width: 100%;
  }
}

/* Homepage repair pass: compact, uniform sections after visual QA. */
#accueil .offer-intro-copy,
#accueil .section-copy {
  min-width: 0;
}

#accueil .offer-section .section-heading h2 {
  max-width: 640px;
}

#accueil .section-heading::before {
  content: "";
  display: block;
  width: 56px;
  height: 56px;
  margin: 0 0 18px;
  background: #fff url("/assets/brand/juridex-logo.png") center / 36px 36px no-repeat;
  border: 1px solid rgba(0, 0, 145, 0.14);
  border-radius: var(--radius-md);
  box-shadow: 0 14px 34px rgba(7, 18, 63, 0.1);
}

#accueil .section-heading,
#accueil .section-copy .section-heading,
#accueil > .section > .section-heading {
  text-align: left !important;
}

#accueil .section-heading h2,
#accueil .section-heading p,
#accueil .section-intro {
  margin-right: auto !important;
  margin-left: 0 !important;
  text-align: left !important;
}

#accueil .section-heading::before,
#accueil .section-heading::after {
  margin-right: auto !important;
  margin-left: 0 !important;
}

#accueil .offer-section .offer-intro-copy {
  margin-left: auto !important;
}

#accueil .offer-section .section-heading {
  display: block;
  margin-left: 0 !important;
  text-align: left !important;
}

#accueil .offer-section .section-heading::before {
  margin: 0 0 18px !important;
}

#accueil .offer-section .section-heading h2,
#accueil .offer-section .section-heading p {
  margin-right: auto !important;
  margin-left: 0 !important;
  text-align: left !important;
}

#accueil .offer-section .section-heading::after {
  margin-right: auto !important;
  margin-left: 0 !important;
}

#accueil .offer-section .section-intro {
  margin-right: auto !important;
  margin-left: 0 !important;
  text-align: left !important;
}

#accueil .audience-grid article a {
  display: none;
}

#accueil .timing-list.compact-list {
  width: min(100%, var(--container-max));
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(205px, 1fr));
  gap: 10px;
  margin: 24px auto 0;
}

#accueil .timing-list.compact-list span {
  min-width: 0;
  min-height: 52px;
  padding: 11px 14px;
  color: var(--navy);
  font-size: 0.92rem;
  line-height: 1.2;
  text-align: center;
  white-space: normal;
}

#accueil .process-grid article {
  min-height: 0;
  align-content: start;
  gap: 9px;
}

#accueil .process-grid span {
  width: 30px;
  height: 30px;
  color: #fff !important;
  font-size: 0.84rem;
  line-height: 1;
  background: var(--fr-blue);
  border-radius: var(--radius-pill);
}

#accueil .faq-list details {
  min-height: 0;
  padding: 18px 20px;
}

#accueil .faq-list summary {
  min-height: 0;
  line-height: 1.25;
}

#accueil .faq-list details:not([open]) p {
  display: none;
}

#accueil .client-automation > .brand-service-icon,
#accueil .why-section .brand-service-icon {
  display: none;
}

#accueil > .section > .section-heading,
#accueil .client-automation > .section-heading,
#accueil .zones-preview-section > .section-heading,
#accueil .reviews-section > .section-heading {
  width: min(100%, var(--container-max));
  max-width: var(--container-max);
  margin-right: auto;
  margin-left: auto;
  text-align: left;
}

#accueil > .section > .section-heading::after,
#accueil .client-automation > .section-heading::after,
#accueil .zones-preview-section > .section-heading::after,
#accueil .reviews-section > .section-heading::after {
  margin-left: 0;
}

#accueil .client-value-grid article,
#accueil .comparison-grid article,
#accueil .legal-limit-grid article {
  min-height: 0;
}

#accueil .zone-overview-grid article small {
  display: none;
}

#accueil .google-map-panel.homepage-coverage-map {
  width: min(100%, var(--container-max));
  min-height: 0;
  margin: 22px auto 0;
  padding: 24px;
}

#accueil .homepage-coverage-map .map-fallback {
  min-height: 0;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

#accueil .homepage-coverage-map .map-fallback a {
  display: none;
}

#accueil .zones-preview-section .compact-note {
  width: min(100%, 760px);
  margin-top: 22px;
  margin-bottom: 0;
  text-align: center;
}

#accueil .zones-preview-section > .button {
  display: flex !important;
  width: fit-content !important;
  min-width: 220px;
  max-width: max-content;
  margin: 16px auto 0 !important;
  padding-right: 24px;
  padding-left: 24px;
  justify-content: center;
}

#accueil .final-cta-section {
  width: min(calc(100% - 36px), var(--container-max));
  margin: 0 auto var(--section-y);
  padding: clamp(34px, 4vw, 50px);
  border-radius: var(--radius-lg);
  border-image: none;
  overflow: hidden;
}

#accueil .final-cta-section::before {
  height: 3px;
}

#accueil .final-cta-section .brand-service-icon-cta {
  width: 52px;
  height: 52px;
}

#accueil .final-cta-section .brand-service-icon-cta img {
  width: 34px;
  height: 34px;
}

#accueil .final-cta-section h2 {
  font-size: clamp(28px, 2.8vw, 40px);
}

body:not(.client-page):not(.admin-page) .page-hero .france-chip {
  width: fit-content;
  max-width: calc(100vw - 48px);
}

.contact-final-cta {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 680px) auto;
  justify-content: center;
  align-items: center;
  gap: clamp(24px, 5vw, 72px);
  width: min(calc(100% - 36px), var(--container-max));
  margin: 0 auto var(--section-y);
  padding: clamp(34px, 4vw, 50px);
  overflow: hidden;
  color: #fff;
  background: var(--deep-navy);
  border-radius: var(--radius-lg);
  border-image: none;
}

.contact-final-cta::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: var(--tricolor-bar);
}

.contact-final-cta h2,
.contact-final-cta p {
  color: #fff;
}

.contact-final-cta p {
  margin-bottom: 0;
  color: rgba(255, 255, 255, 0.84);
}

.contact-final-cta .brand-service-icon-cta {
  display: none;
}

.contact-final-cta .hero-actions {
  margin-top: 0;
}

.contact-final-cta .button.secondary {
  color: #fff;
  background: transparent;
  border-color: rgba(255, 255, 255, 0.64);
}

.contact-final-cta .button.secondary:hover,
.contact-final-cta .button.secondary:focus-visible,
.contact-final-cta .button.secondary:active,
.contact-final-cta .button.secondary:visited {
  color: #fff;
  background: transparent;
  border-color: #fff;
}

.referrer-page {
  background: #f7f8fb;
}

.referrer-page .site-header {
  grid-template-columns: auto auto;
  justify-content: space-between;
}

.referrer-page .header-cta {
  width: auto;
  max-width: max-content;
  padding-right: 18px;
  padding-left: 18px;
  white-space: nowrap;
}

.referrer-auth-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.42fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
  min-height: 680px;
  padding: clamp(54px, 7vw, 96px) clamp(18px, 5vw, 72px);
  background:
    linear-gradient(90deg, rgba(6, 17, 31, 0.96), rgba(6, 17, 31, 0.78), rgba(6, 17, 31, 0.34)),
    url("/assets/images/home/consultations-juridex-client.png") center right / cover no-repeat,
    linear-gradient(135deg, var(--deep-navy), var(--navy));
}

.referrer-auth-copy {
  min-width: 0;
  max-width: 820px;
}

.referrer-auth-copy h1 {
  margin: 22px 0 16px;
  color: #fff;
  font-size: clamp(42px, 5.8vw, 82px);
  line-height: 0.98;
  overflow-wrap: normal;
}

.referrer-auth-copy p:not(.france-chip) {
  max-width: 700px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 19px;
}

.referrer-auth-points {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.referrer-auth-points span {
  padding: 9px 13px;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  background: rgba(255, 255, 255, 0.11);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--radius-pill);
}

.referrer-auth-panel {
  display: grid;
  gap: 14px;
  width: min(100%, 430px);
  min-width: 0;
  max-width: 100%;
  padding: 26px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 4px solid var(--fr-blue);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-hover);
}

.referrer-auth-panel .brand-mark {
  width: 58px;
  height: 58px;
}

.referrer-auth-panel h2,
.referrer-auth-panel p {
  margin: 0;
}

.referrer-auth-panel h2 {
  color: var(--navy);
  font-size: 28px;
}

.referrer-auth-panel p {
  max-width: 100%;
  color: var(--muted);
  font-weight: 700;
  overflow-wrap: normal;
}

.referrer-auth-panel .auth-reassurance[data-status="error"] {
  color: var(--red);
}

.referrer-auth-panel .auth-reassurance[data-status="info"] {
  color: var(--blue);
}

.referrer-dashboard-section {
  padding: clamp(58px, 8vw, 96px) clamp(18px, 5vw, 72px);
  background:
    linear-gradient(180deg, #fff 0, #f7f8fb 180px),
    #f7f8fb;
}

.referrer-dashboard-shell {
  display: grid;
  grid-template-columns: 272px minmax(0, 1fr);
  gap: 22px;
  width: min(100%, 1380px);
  margin: 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
}

.referrer-sidebar {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 22px;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), transparent 160px),
    var(--blue);
}

.referrer-sidebar .brand-mark {
  width: 54px;
  height: 54px;
}

.referrer-sidebar strong {
  line-height: 1.25;
}

.referrer-sidebar .status-pill {
  justify-self: start;
  margin-bottom: 8px;
  color: var(--blue);
  background: #fff;
}

.referrer-console-main {
  min-width: 0;
  padding: 24px;
}

.referrer-panel {
  display: grid;
  gap: 20px;
}

.referrer-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-top: 8px;
}

.referrer-section-head h2,
.referrer-section-head p {
  margin: 0;
}

.referrer-section-head h2 {
  color: var(--navy);
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.08;
}

.referrer-section-head p {
  margin-top: 6px;
  color: var(--muted);
  font-weight: 800;
}

.referrer-metrics {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.referrer-metrics article {
  display: grid;
  gap: 6px;
  min-height: 132px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-top: 4px solid var(--blue);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
}

.referrer-metrics span,
.referrer-metrics small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.referrer-metrics strong {
  color: var(--navy);
  font-size: 24px;
  line-height: 1.05;
}

.referrer-grid-two,
.referrer-compliance-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.referrer-card {
  display: grid;
  align-content: start;
  gap: 14px;
  border-radius: var(--radius-lg);
}

.referrer-card h3,
.referrer-resource-card h3 {
  margin: 0;
  color: var(--navy);
}

.referrer-card ul {
  display: grid;
  gap: 9px;
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-weight: 800;
}

.referrer-card.is-warning {
  border-color: rgba(225, 0, 15, 0.26);
  border-top: 4px solid var(--red);
}

.referrer-list {
  display: grid;
  gap: 10px;
}

.referrer-list-item {
  display: grid;
  gap: 4px;
  padding: 13px;
  background: var(--soft-bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}

.referrer-list-item.with-action {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}

.referrer-list-item strong,
.referrer-list-item span,
.referrer-list-item small {
  min-width: 0;
  overflow-wrap: anywhere;
}

.referrer-list-item strong {
  color: var(--navy);
}

.referrer-list-item span,
.referrer-list-item small,
.referrer-empty {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.referrer-copy-button,
.referrer-refresh {
  min-height: 40px;
  padding: 0 14px;
}

.referrer-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: #fff;
  box-shadow: var(--shadow-soft);
}

.referrer-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.referrer-table th,
.referrer-table td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid var(--line);
}

.referrer-table th {
  color: var(--navy);
  font-size: 12px;
  text-transform: uppercase;
  background: var(--soft-bg);
}

.referrer-table td {
  color: var(--muted);
  font-weight: 800;
}

.referrer-resource-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.referrer-resource-card {
  display: grid;
  gap: 10px;
  border-radius: var(--radius-lg);
}

.referrer-resource-card > span {
  justify-self: start;
  padding: 6px 9px;
  color: var(--blue);
  font-size: 12px;
  font-weight: 900;
  background: var(--soft-bg);
  border: 1px solid rgba(0, 0, 145, 0.16);
  border-radius: var(--radius-pill);
}

.referrer-resource-card p {
  margin: 0;
  color: var(--muted);
  font-weight: 700;
}

.referrer-resource-card strong {
  color: var(--navy);
  font-size: 13px;
}

@media (max-width: 980px) {
  #accueil .offer-section .offer-intro-copy,
  #accueil .offer-section .section-heading,
  #accueil .offer-section .section-heading h2,
  #accueil .offer-section .section-heading p,
  #accueil .offer-section .section-intro {
    margin-left: 0 !important;
    text-align: left !important;
  }

  #accueil .offer-section .section-heading {
    grid-template-columns: 1fr;
  }

  #accueil .offer-section .section-heading h2,
  #accueil .offer-section .section-heading p,
  #accueil .offer-section .section-heading::after {
    grid-column: 1;
  }

  #accueil .offer-section .section-heading::before,
  #accueil .offer-section .section-heading::after {
    margin-right: auto !important;
    margin-left: 0 !important;
  }

  .hero-premium-grid {
    grid-template-columns: 1fr;
    max-width: 560px;
  }

  .contact-final-cta {
    grid-template-columns: 1fr;
    justify-content: stretch;
  }

  .referrer-auth-section,
  .referrer-dashboard-shell {
    grid-template-columns: 1fr;
  }

  .referrer-dashboard-shell {
    gap: 0;
  }

  .referrer-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .referrer-sidebar .brand-mark,
  .referrer-sidebar strong,
  .referrer-sidebar .status-pill {
    grid-column: 1 / -1;
  }

  .referrer-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .referrer-grid-two,
  .referrer-compliance-grid,
  .referrer-resource-grid {
    grid-template-columns: 1fr;
  }

  #accueil .timing-list.compact-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  #accueil .timing-list.compact-list {
    grid-template-columns: 1fr;
  }

  #accueil .final-cta-section {
    width: calc(100% - 36px);
    margin-bottom: 48px;
  }

  .referrer-auth-section,
  .referrer-dashboard-section {
    padding-right: 18px;
    padding-left: 18px;
  }

  .referrer-page .site-header {
    grid-template-columns: minmax(0, auto) auto;
    gap: 10px;
  }

  .referrer-page .brand {
    max-width: 190px;
  }

  .referrer-page .header-cta {
    display: none;
  }

  .referrer-auth-copy h1 {
    max-width: 340px;
    font-size: 38px;
    line-height: 1.08;
  }

  .referrer-auth-copy p:not(.france-chip) {
    max-width: 340px;
    font-size: 17px;
  }

  .referrer-auth-panel,
  .referrer-console-main {
    padding: 18px;
  }

  .referrer-auth-panel {
    width: calc(100vw - 36px);
  }

  .referrer-auth-panel p {
    max-width: 300px;
  }

  .referrer-sidebar {
    grid-template-columns: 1fr;
  }

  .referrer-section-head,
  .referrer-list-item.with-action {
    grid-template-columns: 1fr;
  }

  .referrer-section-head {
    display: grid;
  }

  .referrer-metrics {
    grid-template-columns: 1fr;
  }

  .referrer-copy-button,
  .referrer-refresh {
    width: 100%;
  }
}

@media (max-width: 680px) {
  #accueil .hero-copy {
    width: 100%;
    max-width: 100%;
  }

  #accueil .hero h1 {
    max-width: 340px;
    font-size: 38px;
    line-height: 1.08;
  }

  #accueil .hero-title-line {
    width: auto;
    max-width: 100%;
    white-space: normal;
  }

  #accueil .hero-actions {
    width: 100%;
    max-width: 340px;
  }

  #accueil .hero-actions .button {
    width: 100%;
    min-height: 46px;
    padding: 0 14px;
    font-size: 15px;
    line-height: 1.15;
    white-space: normal;
  }

  #accueil .hero-reassurance-line {
    max-width: 340px;
    font-size: 15px;
    line-height: 1.35;
  }

  .cookie-banner {
    right: 12px;
    bottom: 12px;
    left: 12px;
    width: auto;
    padding: 14px;
  }

  .cookie-banner p {
    padding-right: 28px;
    font-size: 13px;
  }

  .cookie-banner div {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .cookie-banner .button {
    min-height: 44px;
    padding: 0 12px;
    font-size: 14px;
  }

body.cookie-consent-visible .mobile-cta {
    display: none;
  }
}

.partner-page {
  background: #f6f7fb;
  color: #172033;
}

.partner-shell {
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 42px 0 64px;
}

.partner-auth {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 420px);
  gap: 28px;
  align-items: stretch;
}

.partner-auth-copy,
.partner-auth-panel,
.partner-sidebar,
.partner-main,
.partner-alert,
.partner-metric,
.partner-list-item {
  border: 1px solid rgba(32, 45, 72, 0.12);
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(25, 36, 58, 0.08);
}

.partner-auth-copy,
.partner-auth-panel {
  border-radius: 8px;
  padding: 28px;
}

.partner-auth-copy h1 {
  margin: 12px 0;
  max-width: 760px;
  font-size: clamp(2rem, 4vw, 4.2rem);
  line-height: 1;
  letter-spacing: 0;
}

.partner-auth-copy p {
  max-width: 680px;
  color: #536074;
  font-size: 1.05rem;
}

.partner-auth-panel,
.partner-work-form {
  display: grid;
  gap: 14px;
}

.partner-auth-panel label,
.partner-work-form label {
  display: grid;
  gap: 7px;
  color: #39475f;
  font-weight: 700;
}

.partner-auth-panel input,
.partner-work-form input,
.partner-work-form textarea {
  width: 100%;
  border: 1px solid rgba(32, 45, 72, 0.18);
  border-radius: 8px;
  padding: 12px 13px;
  font: inherit;
  color: #172033;
  background: #fbfcff;
}

.partner-dashboard {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 20px;
}

.partner-sidebar,
.partner-main {
  border-radius: 8px;
}

.partner-sidebar {
  align-self: start;
  display: grid;
  gap: 10px;
  padding: 18px;
  position: sticky;
  top: 16px;
}

.partner-sidebar .brand-mark {
  width: 48px;
  height: 48px;
}

.partner-main {
  padding: 20px;
}

.partner-panel {
  display: none;
}

.partner-panel.is-active {
  display: grid;
  gap: 18px;
}

.partner-metrics {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.partner-metric {
  border-radius: 8px;
  padding: 16px;
}

.partner-metric strong {
  display: block;
  font-size: 1.8rem;
  line-height: 1;
  color: #13213a;
}

.partner-metric span,
.partner-muted,
.partner-empty {
  color: #69758a;
}

.partner-grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.partner-section-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: end;
}

.partner-section-head p {
  color: #657287;
  margin: 0;
}

.partner-list {
  display: grid;
  gap: 10px;
}

.partner-list-item {
  border-radius: 8px;
  padding: 14px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
}

.partner-list-item p {
  margin: 8px 0 0;
  color: #536074;
}

.partner-list-item span,
.partner-list-item small {
  color: #6b778b;
}

.partner-item-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.partner-alert {
  border-radius: 8px;
  padding: 14px 16px;
  margin-bottom: 18px;
  border-color: rgba(194, 93, 43, 0.28);
  background: #fff8f1;
  color: #613616;
}

.partner-alert strong,
.partner-alert span {
  display: block;
}

.partner-logout-button {
  margin-top: 8px;
}

@media (max-width: 920px) {
  .partner-auth,
  .partner-dashboard,
  .partner-grid-two,
  .partner-metrics {
    grid-template-columns: 1fr;
  }

  .partner-sidebar {
    position: static;
  }

  .partner-list-item,
  .partner-section-head {
    display: grid;
  }
}

