/*
 * Fișier concatenat — un singur request HTTP pentru CSS.
 * Surse: tokens, base, layout, components, pages, enhancements.
 * După modificări în acele fișiere, rulează: scripts/build-css.sh
 */

/* --- tokens.css --- */
/**
 * Motion Clinic — paletă finală (bleumarin + albastru medical, gradiente clare).
 * Text alb pe toate suprafețele cu gradient CTA.
 */
:root {
  --color-primary: #050b33;
  --color-primary-hover: #0a2b58;

  --color-secondary: #05267b;
  --color-secondary-hover: #0c3166;

  --color-white: #ffffff;

  /* Gradient principal + hover (trecere clară de ton) */
  --gradient-primary: linear-gradient(135deg, #050b33 0%, #05267b 100%);
  --gradient-primary-hover: linear-gradient(135deg, #050b33 0%, #0c3166 100%);

  /* Gradient secundar (footer / CTA premium pe fundal închis) */
  --gradient-secondary: linear-gradient(135deg, #0a2b58 0%, #05267b 100%);
  --gradient-secondary-hover: linear-gradient(135deg, #05267b 0%, #0c3166 100%);

  /* Gradient foarte dark / sobru */
  --gradient-dark: linear-gradient(135deg, #050b33 0%, #0a2b58 100%);
  --gradient-dark-hover: linear-gradient(135deg, #050b33 0%, #0c3166 100%);

  /* Gradient „medical” (mai puțin black-navy) — carduri accent / icon bg */
  --gradient-alt: linear-gradient(135deg, #0a2b58 0%, #05267b 100%);

  /* Text: titluri #050b33; paragrafe — neutru ușor de citit */
  --color-text: #243040;
  --color-text-secondary: #0a2b58;
  --color-text-light: rgba(10, 43, 88, 0.55);

  --color-surface-soft: #f4f8ff;
  --color-border: #e5eaf3;
  --color-border-input: #cfd8e8;

  --color-footer-link: #ffffff;
  --color-footer-link-hover: #d7e4ff;
  --color-footer-divider: rgba(255, 255, 255, 0.15);
  --color-footer-muted: rgba(255, 255, 255, 0.82);

  --shadow-card: 0 8px 24px rgba(5, 11, 51, 0.08);
  --shadow-card-hover: 0 12px 32px rgba(5, 11, 51, 0.12);
  --shadow-cta: 0 10px 28px rgba(5, 11, 51, 0.22);

  --ring-focus: rgba(5, 38, 123, 0.15);

  /* Alias legacy */
  --color-accent: var(--color-secondary);
  --color-accent-soft: var(--color-surface-soft);
  --color-accent-dark: var(--color-primary-hover);
  --color-accent-alt: var(--color-secondary-hover);
  --gradient-soft: var(--color-white);
  --gradient-hero: var(--color-white);

  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --space-xs: 0.5rem;
  --space-sm: 0.75rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --font-sans: system-ui, -apple-system, "Segoe UI", Roboto, Ubuntu, "Helvetica Neue", sans-serif;

  /* Tipografie fluidă: mobil → tablet → desktop → 4K (fără salturi bruște). */
  --text-fluid-hero: clamp(1.55rem, 2.4vw + 1rem, 3.75rem);
  --text-fluid-h2: clamp(1.2rem, 1.35vw + 0.82rem, 2.35rem);
  --text-fluid-h3: clamp(1.05rem, 0.65vw + 0.88rem, 1.45rem);
  /* Corp + paragrafe: interval mai larg ca pe ecrane mari să nu rămână „mic”. */
  --text-fluid-body: clamp(0.9375rem, 0.22vw + 0.86rem, 1.1875rem);
  --text-fluid-lead: clamp(1rem, 0.42vw + 0.88rem, 1.28rem);
  --text-fluid-nav: clamp(0.8125rem, 0.2vw + 0.74rem, 1rem);
  --text-fluid-sm: clamp(0.8125rem, 0.16vw + 0.76rem, 0.9375rem);
  --text-fluid-xs: clamp(0.6875rem, 0.1vw + 0.66rem, 0.8125rem);
  /* Alias folosite în fișiere mai vechi */
  --text-sm: var(--text-fluid-sm);
  --text-xs: var(--text-fluid-xs);

  /* Layout: îngust pe telefon, scalează până la 4K fără „bandă” prea îngustă */
  --layout-max-width: 70rem;
  --layout-gutter-x: clamp(0.75rem, 2.5vw + 0.35rem, 2.75rem);
  /* Lățimi „proză” / blocuri centrate — aceeași coloană vizuală pe tot site-ul */
  --layout-prose: 42rem;
  --layout-prose-wide: 44rem;
  /* Hartă, tabele late, embed-uri */
  --layout-media: 48rem;
  /* Card pe o singură coloană (înainte de breakpoint-uri multi-col) */
  --home-card-single-max: min(22rem, 100%);
  --header-sticky-offset: 3.5rem;
}

/* QHD / ultrawide / 4K — conținut rămâne lizibil, nu bloc îngust pe mijloc */
@media (min-width: 90rem) {
  :root {
    --layout-max-width: 78rem;
  }
}

@media (min-width: 120rem) {
  :root {
    --layout-max-width: 88rem;
  }
}

@media (min-width: 160rem) {
  :root {
    --layout-max-width: min(96rem, 92vw);
  }
}

/* Ultra-wide / 4K+: limite superioare ușor mai mari (titluri + corp). */
@media (min-width: 100rem) {
  :root {
    --text-fluid-hero: clamp(1.85rem, 2.2vw + 1.05rem, 4.25rem);
    --text-fluid-h2: clamp(1.28rem, 1.1vw + 0.95rem, 2.6rem);
    --text-fluid-body: clamp(0.95rem, 0.18vw + 0.88rem, 1.22rem);
    --text-fluid-lead: clamp(1.02rem, 0.35vw + 0.9rem, 1.32rem);
  }
}


/* --- base.css --- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  /* overflow-x pe html/body rupe position: sticky pe header — lăsăm vizibil, clip pe main/footer. */
  overflow-x: visible;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

body {
  margin: 0;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: var(--text-fluid-body, 1rem);
  line-height: 1.62;
  color: var(--color-text);
  background: var(--color-white);
  overflow-x: visible;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Linkuri: normal secondary, hover secondary-hover */
a {
  color: var(--color-secondary);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}

a:hover {
  color: var(--color-secondary-hover);
}

a:active {
  color: var(--color-primary);
}

:focus-visible {
  outline: 2px solid var(--color-secondary);
  outline-offset: 2px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* --- layout.css --- */
/* Stiluri header (sticky, fundal) — în enhancements.css */

.site-header__inner {
  position: relative;
  width: 100%;
  max-width: var(--layout-max-width);
  margin-inline: auto;
  padding-left: max(var(--layout-gutter-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--layout-gutter-x), env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding-block: var(--space-xs);
}

/* Desktop: logo + meniu centrate ca grup (fără „întins” pe tot viewport-ul). */
@media (min-width: 901px) {
  .site-header__inner {
    justify-content: center;
    gap: clamp(1rem, 2.2vw, 2.35rem);
    padding-block: 0.35rem;
  }

  .site-nav {
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-sm) clamp(0.65rem, 1.2vw, 1.1rem);
  }
}

/* Ecrane late / 4K: header mai discret; meniul rămâne fluid (nu fix în rem). */
@media (min-width: 90rem) {
  .site-logo {
    max-width: min(9.5rem, 18vw);
  }

  .site-logo__img {
    max-height: clamp(1.45rem, 1.45vw, 2.15rem);
  }
}

.site-logo {
  display: inline-flex;
  align-items: center;
  flex: 0 1 auto;
  min-width: 0;
  max-width: min(11.5rem, 46vw);
  font-weight: 700;
  font-size: var(--text-fluid-h3);
  color: var(--color-primary);
  text-decoration: none;
  line-height: 0;
}

.site-logo:hover {
  color: var(--color-secondary);
}

.site-logo picture {
  display: block;
  line-height: 0;
  max-width: 100%;
}

.site-logo__img {
  display: block;
  width: 100%;
  height: auto;
  max-height: clamp(1.65rem, 3.8vw, 2.6rem);
  object-fit: contain;
}

.site-logo:hover .site-logo__img {
  opacity: 0.92;
}

.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm) var(--space-lg);
  align-items: center;
}

.site-nav a {
  color: var(--color-primary);
  font-weight: 500;
  text-decoration: none;
  font-size: var(--text-fluid-nav);
}

.site-nav a:hover {
  color: var(--color-secondary);
  text-decoration-color: var(--color-secondary);
  text-decoration-line: underline;
  text-underline-offset: 4px;
}

.site-nav a[aria-current="page"] {
  color: var(--color-primary);
  text-decoration-line: underline;
  text-decoration-color: var(--color-secondary);
  text-underline-offset: 4px;
}

.nav-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-xs) var(--space-sm);
  color: var(--color-primary);
  font-size: var(--text-fluid-sm);
  cursor: pointer;
}

@media (max-width: 900px) {
  .nav-toggle {
    display: inline-flex;
    min-width: 2.75rem;
    min-height: 2.75rem;
    align-items: center;
    justify-content: center;
  }

  .site-nav {
    display: none;
    position: absolute;
    inset-inline: 0;
    top: 100%;
    z-index: 210;
    flex-direction: column;
    background: var(--color-white);
    border-bottom: 1px solid var(--color-border);
    padding: var(--space-md);
    box-shadow: var(--shadow-card);
  }

  .site-nav.is-open {
    display: flex;
  }

  /* Ținte tactil mai generoase în meniul mobil (WCAG ~44px) */
  .site-nav a {
    display: flex;
    align-items: center;
    min-height: 2.75rem;
    padding: 0.5rem 0.35rem;
    border-radius: var(--radius-sm);
  }
}

.site-main {
  min-height: 50vh;
  max-width: 100%;
  /* overflow pe main/footer, nu pe body — altfel pierzi position:sticky pe header. */
  overflow-x: hidden;
}

.site-footer {
  background: var(--color-primary);
  color: var(--color-white);
  margin-top: var(--space-2xl);
  padding: var(--space-xl) 0;
  max-width: 100%;
  overflow-x: hidden;
}

.site-footer a {
  color: var(--color-footer-link);
}

.site-footer a:hover {
  color: var(--color-footer-link-hover);
}

.site-footer__inner {
  width: 100%;
  max-width: var(--layout-max-width);
  margin-inline: auto;
  padding-left: max(var(--layout-gutter-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--layout-gutter-x), env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  gap: var(--space-xl) var(--space-2xl);
  text-align: center;
}

.site-footer__inner > div {
  flex: 1 1 14rem;
  max-width: 24rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.site-footer .footer-nav {
  align-items: center;
  width: 100%;
  max-width: 18rem;
}

.site-footer .footer-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  max-width: 100%;
  margin: 0.2rem 0;
  padding: 0.35rem 0.9rem;
  border-radius: 999px;
  font-size: var(--text-fluid-sm);
  font-weight: 500;
  text-decoration: none;
  color: var(--color-footer-link);
  border: 1px solid var(--color-footer-divider);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.site-footer .footer-nav a:hover {
  color: var(--color-primary);
  background: var(--color-white);
  border-color: rgba(255, 255, 255, 0.85);
}

.site-footer .notice--footer {
  margin-top: 1rem;
  text-align: center;
  background: transparent;
  border: 1px solid var(--color-footer-divider);
  color: var(--color-footer-muted);
}

.site-footer .footer-cta {
  display: flex;
  justify-content: center;
  width: 100%;
}

.site-footer__copyright {
  width: 100%;
  max-width: var(--layout-max-width);
  margin: var(--space-lg) auto 0;
  padding-left: max(var(--layout-gutter-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--layout-gutter-x), env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-footer-divider);
  font-size: var(--text-xs);
  color: var(--color-footer-muted);
  text-align: center;
}

.container {
  width: 100%;
  max-width: var(--layout-max-width);
  margin-inline: auto;
  padding-left: max(var(--layout-gutter-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--layout-gutter-x), env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  padding-block: var(--space-xl);
}

/* Hero: fundal alb (gradientele rămân pe CTA) */
.hero {
  background: var(--color-white);
  padding-block: clamp(2rem, 7vw, 4rem);
}

.hero__inner {
  width: 100%;
  max-width: var(--layout-max-width);
  margin-inline: auto;
  padding-left: max(var(--layout-gutter-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--layout-gutter-x), env(safe-area-inset-right, 0px));
  box-sizing: border-box;
  text-align: center;
}

@media (min-width: 768px) {
  .hero__inner {
    text-align: start;
  }
}

.hero .page-title {
  color: var(--color-primary);
}

.hero .hero-lead {
  color: var(--color-text-secondary);
  max-width: var(--layout-prose);
  margin-inline: auto;
  font-size: var(--text-fluid-lead);
  line-height: 1.65;
}

@media (min-width: 768px) {
  .hero .hero-lead {
    margin-inline: 0;
  }
}

/* --- components.css --- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xs);
  min-height: 44px;
  padding: 0.6rem 1.25rem;
  border-radius: var(--radius-sm);
  font-size: var(--text-fluid-sm);
  font-weight: 600;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, box-shadow 0.2s, transform 0.2s, filter 0.2s;
}

/* CTA principal: gradient clar → hover schimbă nuanța (text mereu alb) */
.btn--primary,
.btn--gradient {
  background: var(--gradient-primary);
  color: var(--color-white);
  border: none;
}

.btn--primary:hover,
.btn--primary:focus-visible,
.btn--gradient:hover,
.btn--gradient:focus-visible {
  background: var(--gradient-primary-hover);
  color: var(--color-white);
  box-shadow: var(--shadow-cta);
  transform: translateY(-1px);
}

.btn--primary:active,
.btn--gradient:active {
  transform: translateY(0);
  filter: brightness(0.98);
}

/* CTA footer / premium pe fundal închis */
.btn--secondary-premium {
  background: var(--gradient-secondary);
  color: var(--color-white);
  border: none;
}

.btn--secondary-premium:hover,
.btn--secondary-premium:focus-visible {
  background: var(--gradient-secondary-hover);
  color: var(--color-white);
  box-shadow: var(--shadow-cta);
  transform: translateY(-1px);
}

.btn--secondary-premium:active {
  transform: translateY(0);
}

/* Varianta foarte dark / sobru */
.btn--gradient-dark {
  background: var(--gradient-dark);
  color: var(--color-white);
  border: none;
}

.btn--gradient-dark:hover,
.btn--gradient-dark:focus-visible {
  background: var(--gradient-dark-hover);
  color: var(--color-white);
  box-shadow: var(--shadow-cta);
  transform: translateY(-1px);
}

.btn--gradient-dark:active {
  transform: translateY(0);
}

/* Buton secundar: alb + border accent; hover = fill accent + text alb */
.btn--secondary {
  background: var(--color-white);
  color: var(--color-primary);
  border: 2px solid var(--color-secondary);
}

.btn--secondary:hover,
.btn--secondary:focus-visible {
  background: var(--color-secondary);
  color: var(--color-white);
  border-color: var(--color-secondary);
}

.btn--secondary:active {
  background: var(--color-secondary-hover);
  border-color: var(--color-secondary-hover);
  color: var(--color-white);
}

.btn--lg {
  min-height: 48px;
  padding: 0.75rem 1.75rem;
  font-size: var(--text-fluid-lead);
}

/* Link secundar tip „pill” (carduri, FAQ, secțiuni) */
.link-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  overflow-wrap: anywhere;
  padding: 0.5rem 1.1rem;
  border-radius: 999px;
  font-size: var(--text-fluid-sm);
  font-weight: 600;
  line-height: 1.25;
  text-align: center;
  text-decoration: none;
  color: var(--color-secondary);
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.link-pill:hover {
  color: var(--color-white);
  background: var(--color-secondary);
  border-color: var(--color-secondary);
  box-shadow: 0 4px 14px rgba(5, 38, 123, 0.2);
}

.link-pill:focus-visible {
  outline: 2px solid var(--color-secondary);
  outline-offset: 2px;
}

.link-pill--compact {
  padding: 0.35rem 0.75rem;
  font-size: var(--text-fluid-xs);
}

/* Ecrane tactil: zone apăsabilă mai sigură pentru pill-uri (fără a umfla desktop-ul) */
@media (pointer: coarse) {
  .link-pill {
    min-height: 2.75rem;
    padding-top: 0.45rem;
    padding-bottom: 0.45rem;
  }

  .link-pill--compact {
    min-height: 2.5rem;
    padding-top: 0.4rem;
    padding-bottom: 0.4rem;
  }
}

/* Rând de pill-uri centrate (ex. De ce Motion Clinic) */
.inline-pills {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-sm);
}

.container > .page-title + .inline-pills {
  margin-top: var(--space-sm);
}

.card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-card);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.card:hover {
  border-color: var(--color-secondary);
  box-shadow: var(--shadow-card-hover);
}

.card--narrow {
  width: 100%;
  max-width: 32rem;
  margin-inline: auto;
}

.card-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.card-list__link {
  color: var(--color-primary);
  text-decoration: none;
  font-size: var(--text-fluid-h3);
  font-weight: 700;
}

.card-list__link:hover {
  color: var(--color-secondary);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.card-list__excerpt {
  margin: var(--space-sm) 0 0;
  color: var(--color-text);
  font-size: var(--text-fluid-sm);
}

.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.2rem 0.75rem;
  border-radius: 999px;
  font-size: var(--text-fluid-sm);
  font-weight: 600;
  line-height: 1.3;
  background: var(--color-surface-soft);
  color: var(--color-secondary);
  border: 1px solid var(--color-border);
}

.pill--outline {
  background: var(--color-white);
  color: var(--color-primary);
}

.meta {
  margin: 0 0 var(--space-sm);
  color: var(--color-text-secondary);
  font-size: var(--text-fluid-sm);
}

.meta + .notice {
  margin-top: var(--space-md);
}

.article-body {
  margin-top: var(--space-xl);
}

.form-actions {
  margin-top: var(--space-md);
}

.footer-nav {
  margin-top: var(--space-sm);
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.footer-cta {
  margin-top: var(--space-md);
}

.breadcrumbs {
  font-size: var(--text-fluid-sm);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-md);
}

.breadcrumbs--flush {
  padding-bottom: 0;
}

.breadcrumbs ol {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
}

.breadcrumbs li:not(:last-child)::after {
  content: "/";
  margin-left: var(--space-xs);
  color: var(--color-text-light);
}

.breadcrumbs a {
  color: var(--color-secondary);
}

.breadcrumbs a:hover {
  color: var(--color-secondary-hover);
}

.page-title {
  margin: 0 0 var(--space-md);
  font-size: var(--text-fluid-hero);
  color: var(--color-primary);
  line-height: 1.2;
  text-wrap: balance;
}

.container > .page-title,
.container > article > .page-title {
  text-align: center;
}

.container > .page-title + .notice {
  margin-top: var(--space-md);
  max-width: var(--layout-prose-wide);
  margin-inline: auto;
  text-align: center;
}

.container > .notice + .home-grid,
.container > .notice + .card-list {
  margin-top: var(--space-xl);
}

/* Titluri secundare (H2 secțiuni) */
.section-title {
  margin: 0 0 var(--space-md);
  font-size: var(--text-fluid-h2);
  color: var(--color-text-secondary);
  text-wrap: balance;
}

.notice {
  background: var(--color-surface-soft);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  color: var(--color-text-secondary);
}

.notice--tight {
  margin-top: 0;
}

/* Formulare */
input.form-control,
select.form-control,
textarea.form-control {
  width: 100%;
  padding: 0.5rem 0.65rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-input);
  background: var(--color-white);
  color: var(--color-text);
  font: inherit;
}

input.form-control::placeholder,
textarea.form-control::placeholder {
  color: var(--color-text-secondary);
  opacity: 0.45;
}

input.form-control:focus,
select.form-control:focus,
textarea.form-control:focus {
  outline: none;
  border-color: var(--color-secondary);
  box-shadow: 0 0 0 3px var(--ring-focus);
}

label.form-label {
  display: block;
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: 0.25rem;
}

.form-row-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-sm);
}

.form-row-inline .form-control {
  flex: 1 1 12rem;
  min-width: 0;
}

.pagination-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
}

.pagination-nav__status {
  font-size: var(--text-fluid-sm);
  color: var(--color-text-secondary);
}

/* --- pages.css --- */
/* Spațiu între blocuri generice */
.page-block + .page-block {
  margin-top: var(--space-2xl);
}

/* ——— Homepage (docs/structura-site-motion-clinic.md) ——— */
body.page-home .site-main > .breadcrumbs,
body.page-preturi .site-main > .breadcrumbs {
  display: none;
}

/* Hero pagină principală + Prețuri: titlu + lead centrate (inclusiv desktop), ca index */
body.page-home .hero__inner,
body.page-preturi .hero__inner {
  text-align: center;
}

@media (min-width: 768px) {
  body.page-home .hero__inner,
  body.page-preturi .hero__inner {
    text-align: center;
  }

  body.page-home .hero .hero-lead,
  body.page-preturi .hero .hero-lead {
    margin-inline: auto;
  }
}

/* Prețuri: linie discretă între ultimul tabel (ex. Kinetoterapie) și „Pachete recomandate” */
body.page-preturi .preturi-section-rule {
  display: block;
  width: min(18rem, 72%);
  margin: var(--space-xl) auto var(--space-md);
  border: 0;
  border-top: 1px solid rgba(5, 38, 123, 0.14);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
}

/* Hero: acțiuni centrate la toate lățimile (aliniat cu cardurile) */
.home-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
  justify-content: center;
}

.home-lead--placeholder {
  color: var(--color-text-light);
  font-style: italic;
}

.home-cms-body {
  margin-top: var(--space-xl);
}

.home-section {
  padding-block: clamp(2rem, 6vw, 3.5rem);
}

/* Evită dublarea padding-ului vertical (.container are padding-block global) */
.home-section .container {
  padding-block: 0;
}

.home-section--soft {
  background: var(--color-surface-soft);
}

/* Titluri și intro: centrate (inclusiv desktop / 4K) */
.home-section .section-title,
.home-section-intro {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.home-section-intro {
  max-width: var(--layout-prose);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-lg);
  font-size: var(--text-fluid-lead);
  line-height: 1.65;
}

.home-section-footer {
  margin-top: var(--space-lg);
  margin-bottom: 0;
  text-align: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

/*
 * Rânduri de carduri: flex + justify-content center → ultimul rând incomplet
 * (1–2 carduri) rămâne centrat automat.
 */
.home-grid {
  --home-grid-gap: var(--space-md);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  max-width: 100%;
  margin-inline: 0;
  gap: var(--home-grid-gap);
}

.home-grid > * {
  box-sizing: border-box;
}

/*
 * Servicii: 1 col (foarte îngust) → 2 → 3; la viewport foarte lat (~4K) max 4.
 * Exact 5 carduri + 4 coloane = 4+1 (evitat); la 4K păstrăm 3 coloane → 3+2.
 */
.home-grid--services > * {
  flex: 0 1 100%;
  width: 100%;
  max-width: var(--home-card-single-max);
  margin-inline: auto;
}

@media (min-width: 480px) {
  .home-grid--services > * {
    margin-inline: 0;
    flex: 0 1 calc((100% - var(--home-grid-gap)) / 2);
    max-width: calc((100% - var(--home-grid-gap)) / 2);
  }
}

@media (min-width: 800px) {
  .home-grid--services > * {
    flex: 0 1 calc((100% - 2 * var(--home-grid-gap)) / 3);
    max-width: calc((100% - 2 * var(--home-grid-gap)) / 3);
  }
}

/* ~4K / ultrawide lat: până la 4 pe rând (sub această lățime rămân max 3). */
@media (min-width: 2400px) {
  .home-grid--services > * {
    flex: 0 1 calc((100% - 3 * var(--home-grid-gap)) / 4);
    max-width: calc((100% - 3 * var(--home-grid-gap)) / 4);
  }

  /* 5 carduri: 3 + 2, nu 4 + 1 */
  .home-grid--services:has(> :nth-child(5):last-child) > * {
    flex: 0 1 calc((100% - 2 * var(--home-grid-gap)) / 3);
    max-width: calc((100% - 2 * var(--home-grid-gap)) / 3);
  }
}

/* Situații frecvente: aceeași lățime de bandă ca serviciile (fără coloană separată mai îngustă). */
.home-grid--topics {
  max-width: 100%;
  margin-inline: 0;
}

.home-grid--topics > * {
  flex: 0 1 100%;
  width: 100%;
  max-width: var(--home-card-single-max);
  margin-inline: auto;
}

@media (min-width: 480px) {
  .home-grid--topics > * {
    margin-inline: 0;
    flex: 0 1 calc((100% - var(--home-grid-gap)) / 2);
    max-width: calc((100% - var(--home-grid-gap)) / 2);
  }
}

@media (min-width: 900px) {
  .home-grid--topics > * {
    flex: 0 1 calc((100% - 2 * var(--home-grid-gap)) / 3);
    max-width: calc((100% - 2 * var(--home-grid-gap)) / 3);
  }
}

/* Rezumat 3 carduri: 1 → 2 → 3 (max 3 pe rând). */
.home-grid--3 > * {
  flex: 0 1 100%;
  width: 100%;
  max-width: var(--home-card-single-max);
  margin-inline: auto;
}

@media (min-width: 480px) {
  .home-grid--3 > * {
    margin-inline: 0;
    flex: 0 1 calc((100% - var(--home-grid-gap)) / 2);
    max-width: calc((100% - var(--home-grid-gap)) / 2);
  }
}

@media (min-width: 840px) {
  .home-grid--3 > * {
    flex: 0 1 calc((100% - 2 * var(--home-grid-gap)) / 3);
    max-width: calc((100% - 2 * var(--home-grid-gap)) / 3);
  }
}

/* Două carduri: 1 → 2 pe rând. */
.home-grid--2 > * {
  flex: 0 1 100%;
  width: 100%;
  max-width: var(--home-card-single-max);
  margin-inline: auto;
}

@media (min-width: 480px) {
  .home-grid--2 > * {
    margin-inline: 0;
    flex: 0 1 calc((100% - var(--home-grid-gap)) / 2);
    max-width: calc((100% - var(--home-grid-gap)) / 2);
  }
}

/* Card servicii / afecțiuni: conținut centrat, înălțime egală pe rând */
.home-service-card,
.home-condition-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  height: 100%;
  min-height: 100%;
  gap: var(--space-xs);
}

.home-service-card .home-card-text,
.home-condition-card .home-card-text {
  flex: 1 1 auto;
}

.home-service-card .home-card-title,
.home-service-card .home-card-text,
.home-condition-card .home-card-title,
.home-condition-card .home-card-text {
  width: 100%;
  text-align: center;
}

.home-grid--services .home-card-link {
  align-self: center;
  text-align: center;
}

.home-grid--services .home-card-link.link-pill {
  margin-top: auto;
}

.home-condition-card .home-card-link.link-pill {
  margin-top: 0;
}

.home-condition-card .home-card-btn {
  margin-top: auto;
}

.home-grid--3 .home-card-link.link-pill {
  margin-top: auto;
}

.home-card-title {
  margin: 0 0 var(--space-sm);
  font-size: var(--text-fluid-h3);
  color: var(--color-primary);
}

.home-card-title a {
  color: inherit;
  text-decoration: none;
}

.home-card-title a:hover {
  color: var(--color-secondary);
}

.home-card-text {
  margin: 0 0 var(--space-md);
  color: var(--color-text);
  font-size: var(--text-fluid-sm);
  max-width: 36ch;
}

.home-card-link {
  font-weight: 600;
  margin-top: auto;
}

.home-card-btn {
  width: 100%;
  max-width: 16rem;
  justify-content: center;
  margin-top: auto;
}

/* Rezumat recuperare: același ritm vizual ca serviciile (text centrat în card) */
.home-grid--3 > .card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.home-grid--3 > .card .home-card-text {
  flex: 1 1 auto;
  max-width: 36ch;
}

/* Listă generică (fără icon) */
.home-list {
  margin: 0 auto var(--space-md);
  padding-left: 1.25rem;
  max-width: var(--layout-prose);
  color: var(--color-text);
  text-align: start;
}

.home-list li {
  margin-bottom: var(--space-xs);
}

/* „De ce”: bloc centrat, rânduri cu icon + text aliniat natural */
.home-list-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-bottom: var(--space-md);
}

.home-list--checks {
  list-style: none;
  padding: 0;
  margin: 0;
  max-width: var(--layout-prose);
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.home-list--checks li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-sm);
  margin: 0;
  text-align: start;
  color: var(--color-text);
  line-height: 1.55;
}

.home-list__icon {
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  margin-top: 0.12rem;
  color: var(--color-secondary);
}

.home-list__icon svg {
  display: block;
  width: 100%;
  height: 100%;
}

.home-list__text {
  flex: 1 1 auto;
}

.home-de-ce-links {
  margin: 0;
  text-align: center;
}

.faq-item__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  margin: var(--space-sm) 0 0;
}

.home-highlight {
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-secondary);
  border-radius: var(--radius-md);
  padding: clamp(var(--space-md), 4vw, var(--space-xl));
  background: var(--color-white);
  box-shadow: var(--shadow-card);
  text-align: center;
}

@media (min-width: 640px) {
  .home-highlight {
    text-align: center;
  }
}

.home-highlight-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  margin: var(--space-md) 0 0;
  justify-content: center;
}

.home-split {
  display: grid;
  gap: var(--space-xl);
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
}

@media (min-width: 640px) {
  .home-split {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    text-align: center;
    justify-items: center;
  }
}

.home-address {
  font-style: normal;
  margin: 0 auto var(--space-md);
  max-width: var(--layout-prose);
  color: var(--color-text-secondary);
  text-align: center;
}

.home-quote {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  height: 100%;
}

.home-quote p {
  margin: 0 0 var(--space-sm);
  color: var(--color-text);
  max-width: 38ch;
}

.home-quote footer {
  font-size: var(--text-fluid-sm);
  color: var(--color-text-secondary);
  margin-top: auto;
}

/* FAQ acordeon (+ → deschis) */
.faq-accordion {
  max-width: var(--layout-prose);
  margin: var(--space-lg) auto 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.faq-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-white);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.faq-item__summary {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg);
  cursor: pointer;
  font-weight: 700;
  color: var(--color-primary);
  list-style: none;
  text-align: center;
}

.faq-item__summary::-webkit-details-marker {
  display: none;
}

.faq-item__summary:hover {
  background: var(--color-surface-soft);
}

.faq-item__q {
  flex: 0 1 auto;
  width: 100%;
  max-width: var(--layout-prose);
  margin: 0;
  text-align: center;
  padding: 0;
  text-wrap: balance;
}

.faq-item__icon {
  flex-shrink: 0;
  order: -1;
  width: 2.125rem;
  height: 2.125rem;
  border-radius: 50%;
  border: 2px solid var(--color-secondary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.05rem, 1.1vw + 0.85rem, 1.45rem);
  font-weight: 400;
  line-height: 1;
  color: var(--color-secondary);
  transition: transform 0.22s ease, background 0.22s ease, color 0.22s ease, border-color 0.22s ease;
}

.faq-item[open] .faq-item__icon {
  transform: rotate(45deg);
  background: var(--color-secondary);
  color: var(--color-white);
  border-color: var(--color-secondary);
}

.faq-item__body {
  padding: 0 var(--space-md) var(--space-lg);
  border-top: 1px solid var(--color-border);
  color: var(--color-text);
  text-align: center;
}

.faq-item__body p {
  margin: var(--space-sm) auto 0;
  max-width: var(--layout-prose);
  text-wrap: pretty;
}

.faq-item__body p:first-child {
  margin-top: var(--space-md);
}

/* Locație: tot blocul centrat + hartă */
.home-location {
  text-align: center;
}

.home-location__tel,
.home-location__note,
.home-location__cta {
  margin: var(--space-sm) 0 0;
}

.home-location__note {
  margin-inline: auto;
  max-width: var(--layout-prose);
}

.home-location__cta {
  margin-top: var(--space-md);
}

.home-map {
  margin-top: var(--space-xl);
  margin-inline: auto;
  max-width: min(var(--layout-media), 100%);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  background: var(--color-border);
}

.home-map__frame {
  display: block;
  width: 100%;
  height: min(22rem, 55vw);
  border: 0;
}

.home-cta-final {
  padding-block: clamp(2.25rem, 7vw, 3.5rem);
  padding-left: max(var(--layout-gutter-x), env(safe-area-inset-left, 0px));
  padding-right: max(var(--layout-gutter-x), env(safe-area-inset-right, 0px));
  background: var(--gradient-primary);
  color: var(--color-white);
}

.home-cta-final a:not(.btn) {
  color: var(--color-white);
  text-decoration: underline;
}

.home-cta-final-inner {
  text-align: center;
  max-width: var(--layout-prose);
  margin-inline: auto;
}

.home-cta-final-title {
  margin: 0 0 var(--space-sm);
  font-size: var(--text-fluid-h2);
  color: var(--color-white);
}

.home-cta-final-text {
  margin: 0 0 var(--space-lg);
  font-size: var(--text-fluid-lead);
  opacity: 0.95;
}

.home-cta-final .btn--secondary {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
}

.home-cta-final .btn--secondary:hover {
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
}

/* Tabele prețuri în secțiuni home (aceleași ritmuri ca index) */
.home-section .price-table-wrap {
  margin-top: var(--space-md);
  max-width: min(var(--layout-media), 100%);
  margin-inline: auto;
}

.price-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.price-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.price-table th,
.price-table td {
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.price-table th {
  font-weight: 600;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--color-surface-alt);
}

.price-table tr:last-child td {
  border-bottom: none;
}

.price-table__service {
  width: 70%;
}

.price-table__price {
  width: 30%;
  text-align: right;
  font-weight: 600;
  white-space: nowrap;
}

/* --- enhancements.css --- */
/**
 * Header sticky, bară flotantă, micro-animații.
 * Respectă prefers-reduced-motion.
 */

/* ——— Sticky header (backdrop) ——— */
/* Sticky necesită ca html/body să nu aibă overflow-x: hidden (vezi base.css). */
.site-header {
  position: sticky;
  top: 0;
  z-index: 200;
  color: var(--color-primary);
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid var(--color-border);
  -webkit-backdrop-filter: saturate(160%) blur(10px);
  backdrop-filter: saturate(160%) blur(10px);
}

/* Ancore: nu ascunde titlul sub header lipicios */
html {
  scroll-padding-top: var(--header-sticky-offset, 4.5rem);
}

/* Bara flotantă stă PESTE layout (nu mai rezervăm bandă pe body — lățime completă până la margine) */

/* ——— Bară flotantă (Sus + Programare) ——— */
.floating-rail {
  position: fixed;
  z-index: 280;
  right: max(0.5rem, env(safe-area-inset-right, 0px));
  top: 75%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
  pointer-events: none;
}

.floating-rail > * {
  pointer-events: auto;
}

.floating-rail__item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 2.75rem;
  max-width: 3.25rem;
  padding: 0.85rem 0.5rem;
  border-radius: 999px;
  font-size: var(--text-fluid-xs);
  font-weight: 700;
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
  color: var(--color-primary);
  background: var(--color-white);
  border: 1px solid var(--color-border);
  box-shadow: 0 10px 28px rgba(5, 11, 51, 0.18), 0 2px 8px rgba(5, 11, 51, 0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
}

.floating-rail__item:hover,
.floating-rail__item:focus-visible {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
  box-shadow: var(--shadow-card-hover);
}

.floating-rail__item--accent {
  background: var(--gradient-primary);
  color: var(--color-white);
  border-color: transparent;
}

.floating-rail__item--accent:hover,
.floating-rail__item--accent:focus-visible {
  background: var(--gradient-primary-hover);
  color: var(--color-white);
}

.floating-rail__item:focus-visible {
  outline: 2px solid var(--color-secondary);
  outline-offset: 2px;
}

/* „Sus”: ascuns lângă începutul paginii, vizibil după scroll */
.floating-rail__item--back {
  transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s ease;
}

.floating-rail__item--back.is-collapsed {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: rotate(180deg) translateY(0.65rem) scale(0.94);
}

.floating-rail__item--back:not(.is-collapsed) {
  transform: rotate(180deg);
}

/* Mobil / tabletă: bară jos, orizontală, nu acoperă conținutul central */
@media (max-width: 900px) {
  body {
    padding-bottom: calc(4.25rem + env(safe-area-inset-bottom, 0px));
  }

  .floating-rail {
    top: auto;
    bottom: max(1rem, env(safe-area-inset-bottom, 0px));
    transform: none;
    flex-direction: row;
    justify-content: flex-end;
    right: max(0.65rem, env(safe-area-inset-right, 0px));
    left: auto;
  }

  .floating-rail__item {
    writing-mode: horizontal-tb;
    transform: none;
    min-width: auto;
    max-width: none;
    padding: 0.65rem 1rem;
    font-size: var(--text-fluid-sm);
  }

  .floating-rail__item--back {
    transition: opacity 0.2s ease, max-width 0.2s ease, padding 0.2s ease, margin 0.2s ease, visibility 0.2s ease;
  }

  .floating-rail__item--back.is-collapsed {
    transform: none;
    max-width: 0;
    min-width: 0;
    padding-left: 0;
    padding-right: 0;
    margin: 0;
    overflow: hidden;
    border-width: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  .floating-rail__item--back:not(.is-collapsed) {
    transform: none;
  }
}

/* ——— Animație la intrare în viewport ——— */
@media (prefers-reduced-motion: no-preference) {
  [data-reveal].is-revealed {
    animation: mc-reveal-in 0.65s ease both;
  }

  @keyframes mc-reveal-in {
    from {
      opacity: 0;
      transform: translateY(1.1rem);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }

  .card {
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
  }

  .card:hover {
    transform: translateY(-2px);
  }
}

@media (prefers-reduced-motion: reduce) {
  [data-reveal].is-revealed {
    animation: none;
  }

  .floating-rail__item {
    transition: none;
  }

  .floating-rail__item--back {
    transition: none;
  }

  .faq-item__icon {
    transition: none;
  }
}

