/* ============================================================
   MARCO LINGENTI — PORTFOLIO DESIGN SYSTEM
   Shared styles for index.html + billea.html
   ============================================================ */

/* ---------- RESET ---------- */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ---------- TOKENS ---------- */
:root {
  --orange: #E8956B;
  --orange-dark: #D9925F;
  --orange-deep: #B8694A;
  --charcoal: #2C2C2C;
  --graphite: #5C5C5C;
  --stone: #878178;
  --cream: #FBF8F3;
  --cloud: #F2EFE9;
  --mist: #E0DDD6;
  --white: #FFFFFF;

  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;

  --shadow-sm: 0 2px 8px rgba(44, 44, 44, 0.04);
  --shadow-md: 0 4px 12px rgba(44, 44, 44, 0.06);
  --shadow-lg: 0 8px 24px rgba(44, 44, 44, 0.08);

  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --dur: 220ms;
}

/* ---------- BASE ---------- */
html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--charcoal);
  background-color: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4 {
  font-family: 'Prata', 'Playfair Display', Georgia, serif;
  font-weight: 400;
  color: var(--charcoal);
  line-height: 1.2;
  letter-spacing: -0.012em;
}

p {
  color: var(--graphite);
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--dur) var(--ease);
}

img, svg {
  max-width: 100%;
  display: block;
}

ul { list-style: none; }

/* ---------- LAYOUT ---------- */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}

.container--narrow {
  max-width: 900px;
}

.section {
  padding: 100px 0;
}

.section--sm {
  padding: 80px 0;
}

/* ---------- NAVIGATION ---------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background-color: rgba(251, 248, 243, 0.88);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--ease);
}

.nav--scrolled {
  border-bottom-color: var(--mist);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
}

.nav__logo {
  font-family: 'Prata', Georgia, serif;
  font-size: 22px;
  color: var(--charcoal);
  letter-spacing: -0.012em;
  line-height: 1;
  white-space: nowrap;
  transition: color var(--dur) var(--ease);
}
.nav__logo:hover { color: var(--orange); }

.nav__menu {
  display: flex;
  gap: 40px;
  align-items: center;
}

.nav__link {
  font-size: 15px;
  color: var(--charcoal);
  font-weight: 400;
  position: relative;
}
.nav__link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -4px;
  height: 1px;
  width: 0;
  background-color: var(--orange);
  transition: width var(--dur) var(--ease);
}
.nav__link:hover { color: var(--orange); }
.nav__link:hover::after { width: 100%; }
.nav__link--active { color: var(--orange); }
.nav__link--active::after { width: 100%; }

/* ---------- LANGUAGE TOGGLE ---------- */
.nav__lang {
  font-family: inherit;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--charcoal);
  background-color: transparent;
  border: 1px solid rgba(44, 44, 44, 0.18);
  border-radius: 999px;
  padding: 6px 12px;
  cursor: pointer;
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background-color var(--dur) var(--ease);
  line-height: 1;
  min-width: 40px;
  text-align: center;
}
.nav__lang:hover {
  color: var(--orange);
  border-color: var(--orange);
}
.nav__lang:focus-visible {
  outline: 2px solid var(--orange);
  outline-offset: 2px;
}

/* Theme overrides */
.nav--navy .nav__lang {
  color: var(--cm-cream-muted);
  border-color: rgba(251, 248, 243, 0.22);
}
.nav--navy .nav__lang:hover {
  color: var(--cm-gold);
  border-color: var(--cm-gold);
}

.theme-briefr .nav__lang {
  color: var(--br-graphite);
  border-color: rgba(11, 15, 25, 0.18);
}
.theme-briefr .nav__lang:hover {
  color: var(--br-ink);
  border-color: var(--br-ink);
}

.nav--accor .nav__lang {
  color: var(--ac-cream-muted);
  border-color: rgba(251, 248, 243, 0.22);
}
.nav--accor .nav__lang:hover {
  color: var(--ac-gold-bright);
  border-color: var(--ac-gold);
}

.nav--frederick .nav__lang {
  color: var(--fr-graphite);
  border-color: var(--fr-border);
}
.nav--frederick .nav__lang:hover {
  color: var(--fr-red-deep);
  border-color: var(--fr-red-deep);
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 500;
  padding: 14px 26px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--dur) var(--ease);
  line-height: 1;
}

.btn--primary {
  background-color: var(--orange);
  color: var(--white);
}
.btn--primary:hover {
  background-color: var(--orange-dark);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(232, 149, 107, 0.3);
}

.btn--outline {
  background-color: transparent;
  color: var(--charcoal);
  border-color: var(--mist);
}
.btn--outline:hover {
  border-color: var(--orange);
  color: var(--orange);
  transform: translateY(-1px);
}

.btn--outline-light {
  background-color: transparent;
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.35);
}
.btn--outline-light:hover {
  border-color: var(--white);
  color: var(--white);
  background-color: rgba(255, 255, 255, 0.08);
  transform: translateY(-1px);
}

.btn--large {
  padding: 16px 30px;
  font-size: 16px;
}

/* ---------- HERO (Homepage) ---------- */
.hero-home {
  background-color: var(--cream);
  padding: 120px 0 80px;
  text-align: center;
}

.hero-home__title {
  font-size: 72px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--charcoal);
  margin-bottom: 16px;
}

.hero-home__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 400;
  color: var(--graphite);
  margin-bottom: 20px;
}

.hero-home__desc {
  font-size: 16px;
  color: var(--graphite);
  max-width: 520px;
  margin: 0 auto;
  line-height: 1.7;
}

.hero-home__accent {
  width: 40px;
  height: 3px;
  background-color: var(--orange);
  margin: 40px auto 0;
  border-radius: 2px;
}

.hero-home__indicators {
  margin: 28px auto 0;
  max-width: 720px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--graphite);
  line-height: 1.7;
  text-align: center;
  opacity: 0.85;
}

/* ---------- PROJECTS GRID (Homepage) ---------- */
.projects {
  background-color: var(--cream);
  padding: 60px 0 100px;
}

.projects__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 48px;
}

.projects__title {
  font-size: 48px;
  color: var(--charcoal);
}

.projects__kicker {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--stone);
}

.projects__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.project-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--mist);
  background-color: var(--white);
  transition: all var(--dur) var(--ease);
  display: flex;
  flex-direction: column;
  min-height: 380px;
  text-decoration: none;
  color: var(--charcoal);
}
.project-card:hover {
  transform: translateY(-4px);
  border-color: var(--orange);
  box-shadow: var(--shadow-lg);
  color: var(--charcoal);
}

.project-card__visual {
  height: 200px;
  background: linear-gradient(180deg, #E8956B 0%, #F2C6A8 55%, #FBF8F3 100%);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.project-card__wordmark {
  font-family: 'Prata', Georgia, serif;
  font-size: 52px;
  color: var(--charcoal);
  letter-spacing: -0.018em;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  line-height: 1;
  text-align: center;
}

.project-card__wordmark small {
  font-family: 'Prata', Georgia, serif;
  font-style: italic;
  font-size: 17px;
  color: var(--orange-deep);
  letter-spacing: 0.005em;
  font-weight: 400;
  line-height: 1.3;
}

.project-card__badge {
  position: absolute;
  top: 14px;
  left: 14px;
  background-color: var(--charcoal);
  color: var(--cream);
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
}

/* Fiction badge (Billea) — sits top-right, lighter tone */
.project-card__badge--fiction {
  left: auto;
  right: 14px;
  background-color: transparent;
  color: var(--cream);
  border: 1px solid rgba(251, 248, 243, 0.55);
  font-weight: 500;
  letter-spacing: 0.1em;
}

/* Billea card · tagline in the darker orange of the palette */
.project-card--billea .project-card__tagline {
  color: var(--orange-deep);
}

.project-card__body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.project-card__title {
  font-family: 'Prata', serif;
  font-size: 24px;
  color: var(--charcoal);
  margin-bottom: 8px;
}

.project-card__desc {
  font-size: 14px;
  color: var(--graphite);
  line-height: 1.6;
  margin-bottom: 16px;
  flex: 1;
}

.project-card__tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.tag {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: var(--graphite);
  padding: 4px 10px;
  background-color: var(--cloud);
  border-radius: 100px;
  letter-spacing: 0.02em;
}

.project-card--placeholder {
  background-color: var(--cloud);
  opacity: 0.55;
  cursor: default;
  pointer-events: none;
}
.project-card--placeholder:hover {
  transform: none;
  border-color: var(--mist);
  box-shadow: none;
}

.project-card--placeholder .project-card__visual {
  background: var(--cloud);
}

.project-card--placeholder .project-card__wordmark {
  font-size: 60px;
  color: var(--stone);
  font-weight: 300;
}

.project-card--placeholder .project-card__title {
  color: var(--stone);
}

/* ---------- ABOUT ---------- */
.about {
  background-color: var(--white);
  padding: 100px 0;
}

.about__title {
  font-size: 48px;
  text-align: center;
  margin-bottom: 48px;
  color: var(--charcoal);
}

/* ----- Two-column layout: portrait + bio (left) / skills + certs (right) ----- */
.about__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
  max-width: 1040px;
  margin: 0 auto;
}

.about__col {
  display: flex;
  flex-direction: column;
}

.about__col--left {
  align-items: center;
  text-align: center;
}

.about__bio {
  margin-top: 8px;
  font-size: 16px;
  line-height: 1.8;
  color: var(--graphite);
  max-width: 440px;
}

.about__bio p {
  margin: 0;
}

.about__block {
  padding: 24px 0;
  border-top: 1px solid rgba(44, 44, 44, 0.10);
}

.about__block:first-child {
  padding-top: 0;
  border-top: none;
}

.about__block-title {
  font-family: 'Prata', 'Fraunces', serif;
  font-size: 20px;
  line-height: 1.2;
  color: var(--charcoal);
  margin: 0 0 10px;
  font-weight: 500;
  letter-spacing: 0.005em;
}

.about__block-body {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: var(--graphite);
  margin: 0;
}

@media (max-width: 900px) {
  .about__grid {
    grid-template-columns: 1fr;
    gap: 56px;
    max-width: 560px;
  }
  .about__col--left { max-width: 100%; }
  .about__bio { margin-left: auto; margin-right: auto; }
}

/* ---------- CONTACT ---------- */
.contact {
  background-color: var(--charcoal);
  color: var(--cream);
  padding: 100px 0;
  text-align: center;
}

.contact__title {
  font-size: 48px;
  color: var(--white);
  margin-bottom: 16px;
}

.contact__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: rgba(251, 248, 243, 0.8);
  margin-bottom: 36px;
  max-width: 540px;
  margin-left: auto;
  margin-right: auto;
}

.contact__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ---------- FOOTER ---------- */
.footer {
  background-color: var(--charcoal);
  color: rgba(251, 248, 243, 0.7);
  padding: 24px 32px;
  text-align: center;
  font-size: 13px;
  border-top: 1px solid rgba(251, 248, 243, 0.08);
}

/* ============================================================
   BILLEA PROJECT PAGE
   ============================================================ */

/* ---------- PROJECT HERO ---------- */
.proj-hero {
  background: linear-gradient(180deg, #E8956B 0%, #F2C6A8 40%, #FBF8F3 100%);
  padding: 120px 0 140px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.proj-hero__badge {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--graphite);
  display: inline-block;
  padding: 6px 14px;
  border: 1px solid rgba(44, 44, 44, 0.18);
  border-radius: 100px;
  margin-bottom: 28px;
  background-color: rgba(251, 248, 243, 0.3);
}

.proj-hero__title {
  font-family: 'Prata', serif;
  font-size: 96px;
  color: var(--charcoal);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: 20px;
}

.proj-hero__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 22px;
  font-weight: 400;
  color: var(--charcoal);
  margin-bottom: 16px;
}

.proj-hero__desc {
  font-size: 16px;
  color: var(--graphite);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ---------- SECTION HEADERS ---------- */
.section-title {
  font-size: 48px;
  color: var(--charcoal);
  text-align: center;
  margin-bottom: 16px;
}

.section-kicker {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--orange);
  text-align: center;
  margin-bottom: 12px;
  font-weight: 500;
}

.section-intro {
  font-size: 16px;
  color: var(--graphite);
  text-align: center;
  max-width: 720px;
  margin: 16px auto 56px;
  line-height: 1.7;
}

/* ---------- OVERVIEW STATS ---------- */
.overview {
  background-color: var(--cream);
}

.overview__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 20px;
}

.stat-card {
  background-color: var(--cloud);
  border-radius: var(--radius-md);
  padding: 32px 24px;
  text-align: center;
  border: 1px solid transparent;
  transition: all var(--dur) var(--ease);
}
.stat-card:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
}

.stat-card__number {
  font-family: 'Prata', serif;
  font-size: 56px;
  color: var(--orange);
  line-height: 1;
  margin-bottom: 12px;
}

.stat-card__label {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--graphite);
  font-weight: 500;
  letter-spacing: 0.01em;
}

/* ---------- THREE-ITEM GRID ---------- */
.strategy {
  background-color: var(--white);
}

.three-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.content-card {
  background-color: var(--cloud);
  border-radius: var(--radius-md);
  padding: 32px;
  border: 1px solid transparent;
  transition: all var(--dur) var(--ease);
}
.content-card:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.content-card__title {
  font-family: 'Prata', serif;
  font-size: 22px;
  color: var(--charcoal);
  margin-bottom: 14px;
  font-weight: 400;
}

.content-card__body {
  font-size: 15px;
  line-height: 1.7;
  color: var(--graphite);
}

.content-card__body em {
  color: var(--charcoal);
  font-style: italic;
}

/* ---------- BRAND IDENTITY ---------- */
.brand {
  background-color: var(--cream);
}

.brand__group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  margin-bottom: 32px;
}

.brand__card {
  background-color: var(--white);
  border: 1px solid var(--mist);
  border-radius: var(--radius-md);
  padding: 32px;
}

.brand__card-title {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--orange);
  margin-bottom: 20px;
}

.color-swatches {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.color-swatch {
  text-align: left;
}

.color-swatch__chip {
  height: 100px;
  border-radius: var(--radius-sm);
  margin-bottom: 10px;
  border: 1px solid var(--mist);
}

.color-swatch__name {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--charcoal);
  display: block;
}

.color-swatch__hex {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--stone);
  letter-spacing: 0.02em;
}

.typo-sample {
  padding: 16px 0;
  border-bottom: 1px solid var(--mist);
}
.typo-sample:last-child { border-bottom: 0; }

.typo-sample__display {
  font-family: 'Prata', serif;
  font-size: 32px;
  color: var(--charcoal);
  line-height: 1.1;
  margin-bottom: 8px;
}

.typo-sample__display--inter {
  font-family: 'Inter', sans-serif;
  font-size: 18px;
  font-weight: 400;
}

.typo-sample__meta {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--graphite);
  line-height: 1.6;
}

.logo-showcase {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 20px;
}

.logo-showcase__item {
  border-radius: var(--radius-sm);
  padding: 28px 16px;
  text-align: center;
  font-family: 'Prata', serif;
  font-size: 36px;
  letter-spacing: -0.012em;
  border: 1px solid var(--mist);
}

.logo-showcase__item--charcoal { background-color: var(--cream); color: var(--charcoal); }
.logo-showcase__item--orange { background-color: var(--cream); color: var(--orange); }
.logo-showcase__item--cream { background-color: var(--charcoal); color: var(--cream); border-color: var(--charcoal); }

.logo-showcase__caption {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 500;
  color: var(--graphite);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-top: 8px;
  display: block;
}

/* ---------- DELIVERABLES (Content) ---------- */
.deliverables {
  background-color: var(--white);
}

.deliverable-card {
  background-color: var(--cloud);
  border-radius: var(--radius-md);
  padding: 32px;
  border: 1px solid transparent;
  transition: all var(--dur) var(--ease);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.deliverable-card:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.deliverable-card__icon {
  font-size: 32px;
  margin-bottom: 16px;
  line-height: 1;
}

.deliverable-card__title {
  font-family: 'Prata', serif;
  font-size: 22px;
  color: var(--charcoal);
  margin-bottom: 12px;
}

.deliverable-card__desc {
  font-size: 14px;
  color: var(--graphite);
  margin-bottom: 16px;
  font-weight: 500;
}

.deliverable-card__list {
  padding-left: 0;
  margin-bottom: 20px;
  flex: 1;
}

.deliverable-card__list li {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--graphite);
  line-height: 1.6;
  padding-left: 16px;
  position: relative;
  margin-bottom: 8px;
}
.deliverable-card__list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--orange);
  font-weight: 700;
}

.deliverable-card__footer {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--orange);
  border-top: 1px solid var(--mist);
  padding-top: 16px;
  margin-top: auto;
}

/* ---------- METRICS ---------- */
.metrics {
  background-color: var(--cream);
}

.metrics__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

.metrics-card {
  background-color: var(--white);
  border: 1px solid var(--mist);
  border-radius: var(--radius-md);
  padding: 40px;
  transition: all var(--dur) var(--ease);
}
.metrics-card:hover {
  border-color: var(--orange);
  box-shadow: var(--shadow-md);
}

.metrics-card__title {
  font-family: 'Prata', serif;
  font-size: 22px;
  color: var(--charcoal);
  margin-bottom: 20px;
}

.metrics-card__list li {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  color: var(--charcoal);
  padding: 12px 0 12px 30px;
  border-bottom: 1px solid var(--mist);
  position: relative;
}
.metrics-card__list li:last-child { border-bottom: 0; }
.metrics-card__list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 12px;
  color: var(--orange);
  font-weight: 700;
  font-size: 16px;
}

/* ---------- DEMONSTRATES ---------- */
.demonstrates {
  background-color: var(--white);
}

.demonstrates__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.demo-item {
  background-color: var(--cloud);
  border-radius: var(--radius-md);
  padding: 32px;
  display: flex;
  gap: 20px;
  align-items: flex-start;
  border: 1px solid transparent;
  transition: all var(--dur) var(--ease);
}
.demo-item:hover {
  border-color: var(--orange);
  transform: translateY(-2px);
}

.demo-item__check {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background-color: rgba(232, 149, 107, 0.15);
  color: var(--orange);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 18px;
  font-weight: 700;
}

.demo-item__title {
  font-family: 'Prata', serif;
  font-size: 20px;
  color: var(--charcoal);
  margin-bottom: 8px;
}

.demo-item__desc {
  font-size: 14px;
  line-height: 1.6;
  color: var(--graphite);
}

/* ---------- PROJECT FINAL CTA ---------- */
.proj-cta {
  background-color: var(--charcoal);
  padding: 100px 0;
  text-align: center;
  color: var(--cream);
}

.proj-cta__title {
  font-size: 48px;
  color: var(--white);
  margin-bottom: 16px;
}

.proj-cta__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: rgba(251, 248, 243, 0.8);
  margin-bottom: 36px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.proj-cta__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   ADDITIONS — Tagline, Portrait, Prominent CTAs
   ============================================================ */

/* ---------- PROJECT CARD TAGLINE (Homepage) ---------- */
.project-card__tagline {
  font-family: 'Prata', serif;
  font-size: 15px;
  font-style: italic;
  color: var(--orange);
  margin-bottom: 10px;
  letter-spacing: -0.005em;
  line-height: 1.3;
}

/* ---------- PROJECT HERO TAGLINE (Billea page) ---------- */
.proj-hero__tagline {
  font-family: 'Prata', serif;
  font-size: 28px;
  font-style: italic;
  color: var(--orange-deep);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
}

.proj-hero__actions {
  margin-top: 36px;
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ---------- DELIVERABLE CARD CTA ---------- */
.deliverable-card__cta {
  margin-top: 16px;
  width: 100%;
  padding: 14px 20px;
  font-size: 14px;
}

/* ---------- ABOUT PORTRAIT ---------- */
.about__portrait {
  display: flex;
  justify-content: center;
  margin: 0 auto 40px;
}

.about__portrait-ring {
  width: 160px;
  height: 160px;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  background-color: var(--cloud);
  border: 2px solid var(--mist);
  box-shadow: 0 8px 24px rgba(44, 44, 44, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.about__portrait-ring:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(44, 44, 44, 0.12);
}

.about__portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.about__portrait-fallback {
  display: none;
  position: absolute;
  inset: 0;
  align-items: center;
  justify-content: center;
  font-family: 'Prata', serif;
  font-size: 56px;
  color: var(--orange);
  letter-spacing: -0.02em;
  background-color: var(--cloud);
}

/* Mobile portrait size */
@media (max-width: 768px) {
  .about__portrait-ring {
    width: 128px;
    height: 128px;
  }
  .about__portrait-fallback { font-size: 44px; }
  .proj-hero__tagline { font-size: 22px; }
  .project-card__tagline { font-size: 14px; }
}

/* ============================================================
   CLUB MED — NAVY THEME (clubmed.html)
   ============================================================ */

body.theme-navy {
  --cm-navy: #0F1B4C;
  --cm-navy-deep: #0A1338;
  --cm-navy-mid: #162759;
  --cm-cream: #FBF8F3;
  --cm-cream-muted: rgba(251, 248, 243, 0.72);
  --cm-cream-dim: rgba(251, 248, 243, 0.45);
  --cm-gold: #D4B671;
  --cm-border: rgba(251, 248, 243, 0.14);

  background-color: var(--cm-navy);
  color: var(--cm-cream);
}

body.theme-navy h1,
body.theme-navy h2,
body.theme-navy h3,
body.theme-navy h4 {
  color: var(--cm-cream);
}

body.theme-navy p {
  color: var(--cm-cream-muted);
}

body.theme-navy a {
  color: var(--cm-cream);
}
body.theme-navy a:hover {
  color: var(--cm-gold);
}

/* Nav variant for dark pages */
.nav--navy {
  background-color: rgba(15, 27, 76, 0.86);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
}

.nav--navy .nav__logo {
  color: var(--cm-cream);
}
.nav--navy .nav__logo:hover {
  color: var(--cm-gold);
}

.nav--navy .nav__link {
  color: var(--cm-cream-muted);
}
.nav--navy .nav__link:hover {
  color: var(--cm-gold);
}
.nav--navy .nav__link::after {
  background-color: var(--cm-gold);
}
.nav--navy .nav__link--active {
  color: var(--cm-cream);
}
.nav--navy .nav__link--active::after { width: 100%; background-color: var(--cm-gold); }

.nav--navy.nav--scrolled {
  border-bottom-color: rgba(251, 248, 243, 0.1);
}

/* Footer override on navy pages */
body.theme-navy .footer {
  background-color: var(--cm-navy-deep);
  color: rgba(251, 248, 243, 0.55);
  border-top-color: var(--cm-border);
}

/* ---------- CM HERO ---------- */
.cm-hero {
  background-color: var(--cm-navy);
  padding: 140px 0 100px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cm-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(212, 182, 113, 0.08) 0%, transparent 60%),
    radial-gradient(ellipse at 20% 80%, rgba(212, 182, 113, 0.04) 0%, transparent 50%);
  pointer-events: none;
}

.cm-hero > .container {
  position: relative;
  z-index: 1;
}

.cm-hero__logo {
  width: 180px;
  height: auto;
  margin: 0 auto 48px;
  filter: brightness(0) invert(1);
  opacity: 0.95;
}

.cm-hero__badge {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--cm-gold);
  padding: 6px 16px;
  border: 1px solid var(--cm-border);
  border-radius: 100px;
  margin-bottom: 28px;
}

.cm-hero__title {
  font-family: 'Prata', serif;
  font-size: 96px;
  line-height: 1;
  letter-spacing: -0.018em;
  color: var(--cm-cream);
  margin-bottom: 20px;
}

.cm-hero__tagline {
  font-family: 'Prata', serif;
  font-size: 28px;
  font-style: italic;
  color: var(--cm-gold);
  margin-bottom: 24px;
  letter-spacing: 0.005em;
}

.cm-hero__desc {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.7;
  color: var(--cm-cream-muted);
  max-width: 640px;
  margin: 0 auto;
}

.cm-hero__actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 32px;
}

/* ---------- CM SECTION ---------- */
.cm-section {
  padding: 100px 0;
  background-color: var(--cm-navy);
  position: relative;
}

.cm-section--deep {
  background-color: var(--cm-navy-deep);
}

.cm-kicker {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--cm-gold);
  text-align: center;
  margin-bottom: 16px;
}

.cm-section-title {
  font-family: 'Prata', serif;
  font-size: 44px;
  line-height: 1.2;
  color: var(--cm-cream);
  text-align: center;
  margin-bottom: 48px;
  letter-spacing: -0.012em;
}

.cm-prose {
  max-width: 720px;
  margin: 0 auto;
  font-size: 17px;
  line-height: 1.8;
  color: var(--cm-cream-muted);
  text-align: center;
}

.cm-prose p + p { margin-top: 20px; }

.cm-prose__muted {
  color: var(--cm-cream-dim) !important;
  font-size: 15px;
  font-style: italic;
}

/* ---------- CM BRIEFS ---------- */
.cm-brief__head {
  text-align: center;
  margin-bottom: 56px;
}

.cm-brief__number {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cm-gold);
  margin-bottom: 14px;
}

.cm-brief__head .cm-section-title {
  margin-bottom: 8px;
}

.cm-brief__kicker-line {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  color: var(--cm-cream-muted);
  margin-top: 8px;
}
.cm-brief__kicker-line em {
  color: var(--cm-gold);
  font-style: italic;
  font-family: 'Prata', serif;
  font-size: 17px;
}

.cm-brief__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  max-width: 960px;
  margin: 0 auto 48px;
}

.cm-brief__block {
  padding: 28px;
  background-color: var(--cm-navy-mid);
  border: 1px solid var(--cm-border);
  border-radius: 8px;
}

.cm-brief__label {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--cm-gold);
  margin-bottom: 12px;
}

.cm-brief__block p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--cm-cream-muted);
}

.cm-brief__block em {
  color: var(--cm-cream);
  font-style: italic;
}

/* ---------- CM GALLERY ---------- */
.cm-gallery__caption {
  text-align: center;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--cm-cream-dim);
  max-width: 700px;
  margin: 0 auto 40px;
  font-style: italic;
  line-height: 1.6;
}

.cm-gallery {
  display: grid;
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

.cm-gallery--brief1 {
  grid-template-columns: 1fr 1fr 1fr;
  align-items: start;
}

.cm-gallery--brief2 {
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "wide1 portrait"
    "wide2 portrait";
}
.cm-gallery--brief2 .cm-media--wide:nth-of-type(1) { grid-area: wide1; }
.cm-gallery--brief2 .cm-media--wide:nth-of-type(2) { grid-area: wide2; }
.cm-gallery--brief2 .cm-media--portrait { grid-area: portrait; }

.cm-media {
  background-color: var(--cm-navy-mid);
  border: 1px solid var(--cm-border);
  border-radius: 8px;
  overflow: hidden;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  margin: 0;
}
.cm-media:hover {
  transform: translateY(-4px);
  border-color: var(--cm-gold);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
}

.cm-media img {
  width: 100%;
  height: auto;
  display: block;
}

.cm-media figcaption {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--cm-cream-dim);
  padding: 12px 16px;
  letter-spacing: 0.04em;
  border-top: 1px solid var(--cm-border);
  line-height: 1.5;
}

.cm-media--square img { aspect-ratio: 1 / 1; object-fit: cover; }
.cm-media--portrait img { aspect-ratio: 4 / 5; object-fit: cover; }
.cm-media--story img { aspect-ratio: 9 / 16; object-fit: cover; }
.cm-media--wide img { aspect-ratio: 16 / 9; object-fit: cover; }

/* ---------- CM LEARNINGS ---------- */
.cm-learnings {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 960px;
  margin: 0 auto;
}

.cm-learning {
  background-color: var(--cm-navy-mid);
  border: 1px solid var(--cm-border);
  border-radius: 8px;
  padding: 32px;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.cm-learning:hover {
  transform: translateY(-3px);
  border-color: var(--cm-gold);
}

.cm-learning__mark {
  font-family: 'Prata', serif;
  font-size: 28px;
  color: var(--cm-gold);
  display: block;
  margin-bottom: 16px;
  letter-spacing: -0.01em;
}

.cm-learning__title {
  font-family: 'Prata', serif;
  font-size: 22px;
  color: var(--cm-cream);
  margin-bottom: 12px;
  line-height: 1.3;
}

.cm-learning p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--cm-cream-muted);
}

/* ---------- CM FINAL CTA ---------- */
.cm-cta {
  background-color: var(--cm-navy-deep);
  background-image: radial-gradient(ellipse at 50% 50%, rgba(212, 182, 113, 0.08) 0%, transparent 60%);
  padding: 100px 0;
  text-align: center;
  border-top: 1px solid var(--cm-border);
}

.cm-cta__title {
  font-family: 'Prata', serif;
  font-size: 44px;
  color: var(--cm-cream);
  margin-bottom: 16px;
  letter-spacing: -0.012em;
}

.cm-cta__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: var(--cm-cream-muted);
  margin-bottom: 36px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.cm-cta__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

body.theme-navy .btn--primary {
  background-color: var(--cm-gold);
  color: var(--cm-navy-deep);
}
body.theme-navy .btn--primary:hover {
  background-color: #E6CB8C;
  color: var(--cm-navy-deep);
  box-shadow: 0 6px 16px rgba(212, 182, 113, 0.25);
}

body.theme-navy .btn--outline-light {
  color: var(--cm-cream);
  border-color: rgba(251, 248, 243, 0.3);
}
body.theme-navy .btn--outline-light:hover {
  background-color: rgba(251, 248, 243, 0.05);
  border-color: var(--cm-cream);
  color: var(--cm-cream);
}

/* ---------- CLUB MED PROJECT CARD (Homepage) ---------- */
.project-card--clubmed .project-card__visual {
  background-color: #0F1B4C;
  background-image:
    radial-gradient(ellipse at 30% 20%, rgba(212, 182, 113, 0.15) 0%, transparent 55%),
    radial-gradient(ellipse at 70% 80%, rgba(212, 182, 113, 0.08) 0%, transparent 55%),
    linear-gradient(180deg, #0F1B4C 0%, #0A1338 100%);
  color: var(--cream);
}

.project-card--clubmed .project-card__wordmark {
  font-family: 'Prata', serif;
  font-size: 44px;
  color: #FBF8F3;
  letter-spacing: -0.01em;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  line-height: 1;
}

.project-card--clubmed .project-card__wordmark small {
  font-family: 'Prata', serif;
  font-style: italic;
  font-size: 16px;
  color: #D4B671;
  letter-spacing: 0.005em;
  font-weight: 400;
}

.project-card--clubmed .project-card__badge {
  background-color: #D4B671;
  color: #0A1338;
}

.project-card--clubmed .project-card__tagline {
  color: #B8994F;
}

.project-card--clubmed .project-card__logo {
  width: 260px;
  max-width: 62%;
  height: auto;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.25));
}

/* ---------- RESPONSIVE (Club Med) ---------- */
@media (max-width: 1024px) {
  .cm-hero__title { font-size: 72px; }
  .cm-section-title, .cm-cta__title { font-size: 36px; }
  .cm-gallery--brief2 {
    grid-template-columns: 1fr;
    grid-template-areas:
      "wide1"
      "wide2"
      "portrait";
  }
}

@media (max-width: 768px) {
  .cm-hero { padding: 100px 0 70px; }
  .cm-hero__logo { width: 140px; margin-bottom: 32px; }
  .cm-hero__title { font-size: 56px; }
  .cm-hero__tagline { font-size: 22px; }
  .cm-hero__desc { font-size: 16px; }

  .cm-section, .cm-cta { padding: 60px 0; }
  .cm-section-title, .cm-cta__title { font-size: 30px; }

  .cm-brief__grid { grid-template-columns: 1fr; gap: 20px; }
  .cm-gallery--brief1 { grid-template-columns: 1fr; }
  .cm-learnings { grid-template-columns: 1fr; }

  .cm-cta__actions { flex-direction: column; align-items: center; }
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
  .hero-home__title { font-size: 56px; }
  .proj-hero__title { font-size: 72px; }
  .projects__title, .section-title, .about__title, .contact__title, .proj-cta__title { font-size: 40px; }
  .stat-card__number { font-size: 44px; }
  .projects__grid, .three-grid { grid-template-columns: repeat(2, 1fr); }
  .overview__grid { grid-template-columns: repeat(2, 1fr); }
  .color-swatches { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .container { padding: 0 20px; }
  .section, .section--sm, .hero-home, .about, .contact, .overview, .strategy, .brand, .deliverables, .metrics, .demonstrates, .proj-cta { padding: 60px 0; }
  .hero-home { padding: 80px 0 40px; }
  .proj-hero { padding: 90px 0 80px; }

  .nav__menu { gap: 20px; }
  .nav__link { font-size: 14px; }

  .hero-home__title { font-size: 42px; }
  .hero-home__subtitle { font-size: 18px; }
  .proj-hero__title { font-size: 56px; }
  .proj-hero__subtitle { font-size: 18px; }

  .projects__title, .section-title, .about__title, .contact__title, .proj-cta__title { font-size: 32px; }

  .projects__grid, .three-grid, .brand__group, .metrics__grid, .demonstrates__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .overview__grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .stat-card { padding: 24px 16px; }
  .stat-card__number { font-size: 36px; }

  .color-swatches { grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .color-swatch__chip { height: 70px; }

  .logo-showcase__item { font-size: 28px; padding: 20px 12px; }

  .btn { width: 100%; max-width: 360px; }
  .contact__actions, .proj-cta__actions { flex-direction: column; align-items: center; }
}

/* ============================================================
   ACCOR — NAVY ELECTRIC THEME (accor.html)
   ============================================================ */

body.theme-accor {
  --ac-navy: #0A1240;
  --ac-navy-deep: #050927;
  --ac-navy-mid: #131B58;
  --ac-cream: #FBF8F3;
  --ac-cream-muted: rgba(251, 248, 243, 0.74);
  --ac-cream-dim: rgba(251, 248, 243, 0.45);
  --ac-gold: #C9A25B;
  --ac-gold-bright: #DDB773;
  --ac-border: rgba(251, 248, 243, 0.13);

  background-color: var(--ac-navy);
  color: var(--ac-cream);
}

body.theme-accor h1,
body.theme-accor h2,
body.theme-accor h3,
body.theme-accor h4 {
  color: var(--ac-cream);
}

body.theme-accor p {
  color: var(--ac-cream-muted);
}

body.theme-accor a {
  color: var(--ac-cream);
}
body.theme-accor a:hover {
  color: var(--ac-gold-bright);
}

/* Nav variant pour pages Accor (reprend la mécanique navy mais teinte propre) */
.nav--accor {
  background-color: rgba(10, 18, 64, 0.88);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
}
.nav--accor .nav__logo { color: var(--ac-cream); }
.nav--accor .nav__logo:hover { color: var(--ac-gold-bright); }
.nav--accor .nav__link { color: var(--ac-cream-muted); }
.nav--accor .nav__link:hover { color: var(--ac-gold-bright); }
.nav--accor .nav__link::after { background-color: var(--ac-gold); }
.nav--accor .nav__link--active { color: var(--ac-cream); }
.nav--accor .nav__link--active::after { width: 100%; background-color: var(--ac-gold); }
.nav--accor.nav--scrolled { border-bottom-color: rgba(251, 248, 243, 0.1); }

body.theme-accor .footer {
  background-color: var(--ac-navy-deep);
  color: rgba(251, 248, 243, 0.55);
  border-top-color: var(--ac-border);
}

/* ---------- AC HERO ---------- */
.ac-hero {
  background-color: var(--ac-navy);
  padding: 140px 0 110px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Vagues dorées en background · clin d'œil aux slides Swissôtel */
.ac-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(201, 162, 91, 0.10) 0%, transparent 58%),
    radial-gradient(ellipse at 15% 85%, rgba(201, 162, 91, 0.05) 0%, transparent 50%);
  pointer-events: none;
}

.ac-hero__waves {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 220px;
  opacity: 0.35;
  pointer-events: none;
  z-index: 0;
}

.ac-hero > .container {
  position: relative;
  z-index: 1;
}

.ac-hero__logo {
  width: 180px;
  height: auto;
  margin: 0 auto 48px;
  display: block;
  opacity: 0.98;
}

.ac-hero__badge {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ac-gold);
  padding: 6px 16px;
  border: 1px solid var(--ac-border);
  border-radius: 100px;
  margin-bottom: 28px;
}

.ac-hero__title {
  font-family: 'Prata', serif;
  font-size: 96px;
  line-height: 1;
  letter-spacing: -0.018em;
  color: var(--ac-cream);
  margin-bottom: 20px;
}

.ac-hero__tagline {
  font-family: 'Prata', serif;
  font-size: 28px;
  font-style: italic;
  color: var(--ac-gold);
  margin-bottom: 24px;
  letter-spacing: 0.005em;
}

.ac-hero__desc {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.7;
  color: var(--ac-cream-muted);
  max-width: 680px;
  margin: 0 auto;
}

.ac-hero__meta {
  margin-top: 40px;
  display: flex;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}

.ac-hero__meta-item {
  text-align: left;
}

.ac-hero__meta-label {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ac-cream-dim);
  margin-bottom: 6px;
}

.ac-hero__meta-value {
  font-family: 'Prata', serif;
  font-size: 18px;
  font-style: italic;
  color: var(--ac-cream);
  letter-spacing: 0.005em;
}

/* ---------- AC SECTION ---------- */
.ac-section {
  padding: 100px 0;
  background-color: var(--ac-navy);
  position: relative;
}

.ac-section--deep {
  background-color: var(--ac-navy-deep);
}

.ac-kicker {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ac-gold);
  text-align: center;
  margin-bottom: 16px;
}

.ac-section-title {
  font-family: 'Prata', serif;
  font-size: 44px;
  line-height: 1.2;
  color: var(--ac-cream);
  text-align: center;
  margin-bottom: 48px;
  letter-spacing: -0.012em;
}

.ac-section-title em {
  font-style: italic;
  color: var(--ac-gold);
}

.ac-prose {
  max-width: 720px;
  margin: 0 auto;
  font-size: 17px;
  line-height: 1.8;
  color: var(--ac-cream-muted);
  text-align: center;
}

.ac-prose p + p { margin-top: 20px; }

.ac-prose__muted {
  color: var(--ac-cream-dim) !important;
  font-size: 15px;
  font-style: italic;
}

/* ---------- AC CAROUSEL BLOCK ---------- */
.ac-carousel__head {
  text-align: center;
  margin-bottom: 48px;
}

.ac-carousel__number {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ac-gold);
  margin-bottom: 14px;
}

.ac-carousel__title {
  font-family: 'Prata', serif;
  font-size: 42px;
  line-height: 1.2;
  color: var(--ac-cream);
  margin-bottom: 10px;
  letter-spacing: -0.012em;
}

.ac-carousel__hotel {
  font-family: 'Prata', serif;
  font-size: 20px;
  font-style: italic;
  color: var(--ac-gold);
  letter-spacing: 0.005em;
}

.ac-carousel__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  max-width: 960px;
  margin: 0 auto 56px;
}

.ac-carousel__block {
  padding: 28px;
  background-color: var(--ac-navy-mid);
  border: 1px solid var(--ac-border);
  border-radius: 8px;
}

.ac-carousel__label {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ac-gold);
  margin-bottom: 12px;
}

.ac-carousel__block p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--ac-cream-muted);
}

.ac-carousel__block em {
  color: var(--ac-cream);
  font-style: italic;
}

/* ---------- AC GALLERY (slides carousel) ---------- */
.ac-gallery__caption {
  text-align: center;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  color: var(--ac-cream-dim);
  max-width: 720px;
  margin: 0 auto 40px;
  font-style: italic;
  line-height: 1.6;
}

.ac-gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

.ac-gallery--five {
  grid-template-columns: repeat(3, 1fr);
}

.ac-slide {
  background-color: var(--ac-navy-mid);
  border: 1px solid var(--ac-border);
  border-radius: 8px;
  overflow: hidden;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  margin: 0;
  position: relative;
}

.ac-slide:hover {
  transform: translateY(-4px);
  border-color: var(--ac-gold);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
}

.ac-slide img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 4 / 5;
  object-fit: cover;
}

.ac-slide__num {
  position: absolute;
  top: 10px;
  left: 10px;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  color: var(--ac-cream);
  background-color: rgba(10, 18, 64, 0.72);
  padding: 4px 10px;
  border-radius: 100px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.ac-slide figcaption {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  color: var(--ac-cream-dim);
  padding: 10px 14px;
  letter-spacing: 0.04em;
  border-top: 1px solid var(--ac-border);
  line-height: 1.5;
}

/* ---------- AC LEARNINGS ---------- */
.ac-learnings {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}

.ac-learning {
  background-color: var(--ac-navy-mid);
  border: 1px solid var(--ac-border);
  border-radius: 8px;
  padding: 32px;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.ac-learning:hover {
  transform: translateY(-3px);
  border-color: var(--ac-gold);
}

.ac-learning__mark {
  font-family: 'Prata', serif;
  font-size: 28px;
  color: var(--ac-gold);
  display: block;
  margin-bottom: 16px;
  letter-spacing: -0.01em;
}

.ac-learning__title {
  font-family: 'Prata', serif;
  font-size: 22px;
  color: var(--ac-cream);
  margin-bottom: 12px;
  line-height: 1.3;
}

.ac-learning p {
  font-size: 15px;
  line-height: 1.7;
  color: var(--ac-cream-muted);
}

/* ---------- AC FINAL CTA ---------- */
.ac-cta {
  background-color: var(--ac-navy-deep);
  background-image: radial-gradient(ellipse at 50% 50%, rgba(201, 162, 91, 0.10) 0%, transparent 60%);
  padding: 100px 0;
  text-align: center;
  border-top: 1px solid var(--ac-border);
  position: relative;
  overflow: hidden;
}

.ac-cta__title {
  font-family: 'Prata', serif;
  font-size: 44px;
  color: var(--ac-cream);
  margin-bottom: 16px;
  letter-spacing: -0.012em;
}

.ac-cta__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  color: var(--ac-cream-muted);
  margin-bottom: 36px;
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.ac-cta__actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

body.theme-accor .btn--primary {
  background-color: var(--ac-gold);
  color: var(--ac-navy-deep);
}
body.theme-accor .btn--primary:hover {
  background-color: var(--ac-gold-bright);
  color: var(--ac-navy-deep);
  box-shadow: 0 6px 16px rgba(201, 162, 91, 0.28);
}

body.theme-accor .btn--outline-light {
  color: var(--ac-cream);
  border-color: rgba(251, 248, 243, 0.3);
}
body.theme-accor .btn--outline-light:hover {
  background-color: rgba(251, 248, 243, 0.05);
  border-color: var(--ac-cream);
  color: var(--ac-cream);
}

/* ---------- ACCOR PROJECT CARD (Homepage) ---------- */
.project-card--accor .project-card__visual {
  background-color: #0A1240;
  background-image:
    radial-gradient(ellipse at 28% 22%, rgba(201, 162, 91, 0.18) 0%, transparent 55%),
    radial-gradient(ellipse at 72% 82%, rgba(201, 162, 91, 0.08) 0%, transparent 55%),
    linear-gradient(180deg, #0A1240 0%, #050927 100%);
  color: var(--cream);
}

.project-card--accor .project-card__wordmark {
  font-family: 'Prata', serif;
  font-size: 48px;
  color: #DDB773;
  letter-spacing: 0.04em;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  line-height: 1;
}

.project-card--accor .project-card__wordmark small {
  font-family: 'Prata', serif;
  font-style: italic;
  font-size: 15px;
  color: #C9A25B;
  letter-spacing: 0.02em;
  font-weight: 400;
}

.project-card--accor .project-card__badge {
  background-color: #C9A25B;
  color: #050927;
}

.project-card--accor .project-card__tagline {
  color: #B08947;
}

.project-card--accor .project-card__logo {
  width: 180px;
  max-width: 48%;
  height: auto;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 2px 10px rgba(0, 0, 0, 0.3));
}

/* ---------- RESPONSIVE (Accor) ---------- */
@media (max-width: 1024px) {
  .ac-hero__title { font-size: 72px; }
  .ac-section-title, .ac-cta__title, .ac-carousel__title { font-size: 34px; }
  .ac-gallery, .ac-gallery--five { grid-template-columns: repeat(2, 1fr); }
  .ac-learnings { grid-template-columns: 1fr; }
  .ac-hero__meta { gap: 32px; }
}

@media (max-width: 768px) {
  .ac-hero { padding: 100px 0 70px; }
  .ac-hero__logo { width: 140px; margin-bottom: 32px; }
  .ac-hero__title { font-size: 56px; }
  .ac-hero__tagline { font-size: 22px; }
  .ac-hero__desc { font-size: 16px; }

  .ac-section, .ac-cta { padding: 60px 0; }
  .ac-section-title, .ac-cta__title { font-size: 28px; }
  .ac-carousel__title { font-size: 26px; }

  .ac-carousel__grid { grid-template-columns: 1fr; gap: 20px; }
  .ac-gallery, .ac-gallery--five { grid-template-columns: 1fr; gap: 16px; }
  .ac-learnings { gap: 16px; }

  .ac-cta__actions { flex-direction: column; align-items: center; }
  .ac-hero__meta { flex-direction: column; gap: 20px; text-align: center; }
  .ac-hero__meta-item { text-align: center; }
}

/* =====================================================
   BRIEFR — PAPER / INK THEME
   Brand: clarity before craft. Paper ivoire, Ink, Signed Green, Ochre éditorial.
   Fraunces (serif) + Inter (sans). Pas de gradients, pas de shadows Material.
   ===================================================== */

body.theme-briefr {
  --br-ink: #0E1116;
  --br-paper: #F5F1EA;
  --br-green: #4F7A4A;
  --br-ochre: #D4A24C;
  --br-graphite: #3C4047;
  --br-stone: #8A8F96;
  --br-fog: #CFC9BF;
  --br-mist: #EAE5DD;

  background-color: var(--br-paper);
  color: var(--br-ink);
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  -webkit-font-feature-settings: "cv11", "ss01";
          font-feature-settings: "cv11", "ss01";
}

/* Nav variant on Paper background */
.nav--briefr {
  background-color: rgba(245, 241, 234, 0.88);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid transparent;
}
.nav--briefr.nav--scrolled {
  border-bottom-color: var(--br-fog);
}
.theme-briefr .nav__logo {
  font-family: 'Fraunces', 'Prata', Georgia, serif;
  font-weight: 500;
  color: var(--br-ink);
  letter-spacing: -0.01em;
}
.theme-briefr .nav__link {
  color: var(--br-graphite);
}
.theme-briefr .nav__link:hover,
.theme-briefr .nav__link--active {
  color: var(--br-ink);
}

/* ---------- HERO ---------- */
.br-hero {
  padding: 140px 0 80px;
  background-color: var(--br-paper);
}
.br-hero__badge {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--br-graphite);
  border: 1px solid var(--br-fog);
  padding: 6px 12px;
  border-radius: 999px;
  margin-bottom: 40px;
}
.br-hero__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144, "wght" 500;
  font-size: 136px;
  line-height: 0.94;
  letter-spacing: -0.035em;
  color: var(--br-ink);
  margin: 0 0 28px;
}
.br-hero__tagline {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 48, "wght" 400;
  font-style: italic;
  font-size: 28px;
  line-height: 1.25;
  color: var(--br-graphite);
  max-width: 640px;
  margin: 0 0 28px;
}
.br-hero__subtitle {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--br-stone);
  margin: 0 0 28px;
}
.br-hero__desc {
  font-size: 18px;
  line-height: 1.65;
  color: var(--br-graphite);
  max-width: 640px;
  margin: 0 0 56px;
}
.br-hero__rule {
  width: 64px;
  height: 1px;
  background-color: var(--br-ink);
  position: relative;
}
.br-hero__rule::after {
  content: "";
  position: absolute;
  right: -14px;
  top: -5px;
  width: 16px;
  height: 11px;
  background-color: var(--br-ink);
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

/* ---------- SECTIONS ---------- */
.br-section {
  padding: 96px 0;
  background-color: var(--br-paper);
  border-top: 1px solid var(--br-fog);
}
.br-section--mist {
  background-color: var(--br-mist);
  border-top: 1px solid var(--br-fog);
}
.br-kicker {
  display: inline-block;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--br-ochre);
  margin-bottom: 20px;
}
.br-section-title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 100, "wght" 500;
  font-size: 52px;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--br-ink);
  margin: 0 0 20px;
  max-width: 820px;
}
.br-section-intro {
  font-size: 17px;
  line-height: 1.7;
  color: var(--br-graphite);
  max-width: 720px;
  margin: 0 0 56px;
}
.br-section-intro em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 500;
  color: var(--br-ink);
}

/* ---------- OVERVIEW STATS ---------- */
.br-overview__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--br-fog);
  border-bottom: 1px solid var(--br-fog);
}
.br-stat {
  padding: 36px 24px;
  border-right: 1px solid var(--br-fog);
  text-align: left;
}
.br-stat:last-child {
  border-right: none;
}
.br-stat__number {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 100, "wght" 500;
  font-size: 72px;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--br-ink);
  margin-bottom: 12px;
}
.br-stat__label {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--br-graphite);
  text-transform: uppercase;
}

/* ---------- 3-GRID CARDS ---------- */
.br-three-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.br-card {
  background-color: var(--br-paper);
  border: 1px solid var(--br-fog);
  border-radius: 2px;
  padding: 36px 32px;
  position: relative;
}
.br-section--mist .br-card {
  background-color: var(--br-paper);
}
.br-card__index {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 14, "wght" 400;
  font-style: italic;
  font-size: 14px;
  color: var(--br-ochre);
  letter-spacing: 0.05em;
  margin-bottom: 16px;
  display: block;
}
.br-card__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 48, "wght" 500;
  font-size: 26px;
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--br-ink);
  margin: 0 0 16px;
}
.br-card__body {
  font-size: 15px;
  line-height: 1.7;
  color: var(--br-graphite);
  margin: 0;
}
.br-card__body em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: var(--br-ink);
}

/* ---------- BRAND BLOCKS ---------- */
.br-brand__block {
  padding: 40px 0;
  border-top: 1px solid var(--br-fog);
}
.br-brand__block:first-of-type {
  border-top: none;
  padding-top: 0;
}
.br-brand__label {
  display: inline-block;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--br-graphite);
  margin-bottom: 10px;
}
.br-brand__principle {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 24, "wght" 400;
  font-style: italic;
  font-size: 19px;
  line-height: 1.5;
  color: var(--br-ink);
  max-width: 640px;
  margin: 0 0 32px;
}
.br-brand__note {
  font-size: 14px;
  line-height: 1.75;
  color: var(--br-graphite);
  max-width: 760px;
  margin: 24px 0 0;
}
.br-brand__note strong {
  color: var(--br-ink);
  font-weight: 500;
}

/* Palette swatches */
.br-swatches {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.br-swatch {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.br-swatch__chip {
  width: 100%;
  aspect-ratio: 3 / 2;
  border-radius: 2px;
  border: 1px solid var(--br-fog);
}
.br-swatch__chip--paper {
  border-color: var(--br-graphite);
}
.br-swatch__name {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 24, "wght" 500;
  font-size: 18px;
  color: var(--br-ink);
  margin-top: 6px;
}
.br-swatch__hex {
  font-family: 'Inter', monospace;
  font-size: 12px;
  color: var(--br-graphite);
  letter-spacing: 0.02em;
}
.br-swatch__role {
  font-size: 12px;
  color: var(--br-stone);
  letter-spacing: 0.02em;
}

/* Typography samples */
.br-typo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
.br-typo__sample {
  padding: 28px;
  background-color: var(--br-paper);
  border: 1px solid var(--br-fog);
  border-radius: 2px;
}
.br-typo__display {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 100, "wght" 500;
  font-size: 72px;
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--br-ink);
  margin-bottom: 16px;
}
.br-typo__display--inter {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  letter-spacing: -0.02em;
  font-variation-settings: normal;
}
.br-typo__meta {
  font-size: 13px;
  line-height: 1.7;
  color: var(--br-graphite);
  margin: 0;
}
.br-typo__meta strong {
  color: var(--br-ink);
  font-weight: 500;
}
.br-typo__meta em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: var(--br-ink);
}

/* Logo showcase */
.br-logo-showcase {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.br-logo-showcase__item {
  padding: 48px 32px;
  background-color: var(--br-paper);
  border: 1px solid var(--br-fog);
  border-radius: 2px;
  text-align: center;
}
.br-logo-showcase__item--dark {
  background-color: var(--br-ink);
  border-color: var(--br-ink);
}
.br-logo-showcase__caption {
  display: block;
  margin-top: 24px;
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--br-graphite);
  text-transform: uppercase;
}
.br-logo-showcase__item--dark .br-logo-showcase__caption {
  color: var(--br-mist);
}

/* Logo lockup (visual mockup of the briefr wordmark + signature mark) */
.br-logo-lockup {
  display: inline-flex;
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
}
.br-logo-lockup__wordmark {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144, "wght" 500;
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--br-ink);
}
.br-logo-lockup__mark {
  display: block;
  height: 4px;
  background-color: var(--br-ink);
  clip-path: polygon(0 0, 100% 0, calc(100% - 14px) 100%, 0 100%);
}
.br-logo-lockup--inverse .br-logo-lockup__wordmark {
  color: var(--br-paper);
}
.br-logo-lockup--inverse .br-logo-lockup__mark {
  background-color: var(--br-paper);
}
.br-logo-lockup--signed .br-logo-lockup__wordmark {
  color: var(--br-green);
}
.br-logo-lockup--signed .br-logo-lockup__mark {
  background-color: var(--br-green);
}

/* ---------- DELIVERABLES ---------- */
.br-deliv {
  background-color: var(--br-paper);
  border: 1px solid var(--br-fog);
  border-radius: 2px;
  padding: 36px 32px;
}
.br-deliv__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 48, "wght" 500;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--br-ink);
  margin: 0 0 14px;
}
.br-deliv__desc {
  font-size: 15px;
  line-height: 1.7;
  color: var(--br-graphite);
  margin: 0 0 18px;
}
.br-deliv__desc em {
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: var(--br-ink);
}
.br-deliv__list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--br-fog);
}
.br-deliv__list li {
  padding: 12px 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--br-graphite);
  border-bottom: 1px solid var(--br-fog);
  position: relative;
  padding-left: 18px;
}
.br-deliv__list li::before {
  content: "·";
  position: absolute;
  left: 4px;
  top: 10px;
  color: var(--br-green);
  font-weight: 700;
}
.br-deliv__list li:last-child {
  border-bottom: none;
}

.br-cta-line {
  margin-top: 48px;
  display: flex;
  justify-content: flex-start;
}

/* ---------- DEMONSTRATES ---------- */
.br-demo-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px 40px;
}
.br-demo-item {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 24px 0;
  border-top: 1px solid var(--br-fog);
}
.br-demo-item:nth-child(-n+2) {
  border-top: none;
  padding-top: 0;
}
.br-demo-item__mark {
  flex: 0 0 14px;
  width: 14px;
  height: 14px;
  margin-top: 8px;
  background-color: var(--br-green);
  clip-path: polygon(0 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
}
.br-demo-item__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 48, "wght" 500;
  font-size: 20px;
  line-height: 1.25;
  color: var(--br-ink);
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.br-demo-item__desc {
  font-size: 14px;
  line-height: 1.7;
  color: var(--br-graphite);
  margin: 0;
}

.br-footnote {
  margin-top: 24px;
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 14, "wght" 400;
  font-style: italic;
  font-size: 14px;
  color: var(--br-stone);
  text-align: center;
}

.br-credit {
  margin: 56px auto 0;
  padding-top: 32px;
  border-top: 1px solid var(--br-fog);
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 14, "wght" 400;
  font-style: italic;
  font-size: 14px;
  color: var(--br-graphite);
  text-align: center;
  max-width: 620px;
  line-height: 1.7;
}

/* ---------- BUTTONS ---------- */
.br-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 14px 22px;
  border-radius: 2px;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  border: 1px solid var(--br-ink);
}
.br-btn--primary {
  background-color: var(--br-ink);
  color: var(--br-paper);
}
.br-btn--primary:hover {
  background-color: var(--br-graphite);
  border-color: var(--br-graphite);
}
.br-btn--ghost {
  background-color: transparent;
  color: var(--br-ink);
}
.br-btn--ghost:hover {
  background-color: var(--br-ink);
  color: var(--br-paper);
}

/* ---------- FINAL CTA ---------- */
.br-cta {
  padding: 120px 0;
  background-color: var(--br-ink);
  color: var(--br-paper);
  text-align: center;
}
.br-cta__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 100, "wght" 500;
  font-size: 56px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--br-paper);
  margin: 0 0 16px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.br-cta__subtitle {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 24, "wght" 400;
  font-style: italic;
  font-size: 20px;
  color: var(--br-mist);
  margin: 0 0 40px;
}
.br-cta__actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}
.br-cta .br-btn {
  border-color: var(--br-paper);
}
.br-cta .br-btn--primary {
  background-color: var(--br-paper);
  color: var(--br-ink);
}
.br-cta .br-btn--primary:hover {
  background-color: var(--br-mist);
  border-color: var(--br-mist);
}
.br-cta .br-btn--ghost {
  color: var(--br-paper);
}
.br-cta .br-btn--ghost:hover {
  background-color: var(--br-paper);
  color: var(--br-ink);
}

/* Footer variant */
.footer--briefr {
  background-color: var(--br-ink);
  color: var(--br-mist);
}

/* ---------- PROJECT CARD — Briefr (Homepage) ---------- */
.project-card--briefr .project-card__visual {
  background: var(--br-paper, #F5F1EA);
  background-image: none;
  color: var(--br-ink, #0E1116);
  border: 1px solid var(--br-fog, #CFC9BF);
}
.project-card--briefr .project-card__wordmark {
  font-family: 'Fraunces', 'Prata', serif;
  font-variation-settings: "opsz" 144, "wght" 500;
  font-size: 68px;
  letter-spacing: -0.03em;
  color: var(--br-ink, #0E1116);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  line-height: 1;
}
.project-card--briefr .project-card__wordmark small {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-variation-settings: "opsz" 14, "wght" 400;
  font-size: 15px;
  color: var(--br-graphite, #3C4047);
  letter-spacing: 0.02em;
  font-weight: 400;
}
.project-card--briefr .project-card__badge {
  background-color: var(--br-ink, #0E1116);
  color: var(--br-paper, #F5F1EA);
}
.project-card--briefr .project-card__tagline {
  color: var(--br-graphite, #3C4047);
}

/* ---------- Project card variant · The Frederick's ---------- */
.project-card--frederick .project-card__visual {
  background: #F9EEF0;
  background-image:
    radial-gradient(ellipse at 50% 10%, rgba(252, 214, 232, 0.55) 0%, transparent 60%),
    linear-gradient(160deg, #FAF3EC 0%, #F9EEF0 55%, #fcd6e8 100%);
  color: #2A0810;
  border: 1px solid rgba(196, 26, 36, 0.18);
}
.project-card--frederick .project-card__wordmark {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  line-height: 1;
  color: #c41a24;
}
.project-card--frederick .project-card__wordmark small {
  font-family: 'Playfair Display', 'Prata', serif;
  font-style: italic;
  font-size: 14px;
  color: #c41a24;
  letter-spacing: 0.08em;
  font-weight: 400;
  text-align: center;
}
.project-card--frederick .project-card__logo {
  display: block;
  width: 100%;
  max-width: 320px;
  height: auto;
  /* Logo blanc recoloré en red-deep via filter */
  filter:
    brightness(0) saturate(100%)
    invert(14%) sepia(88%) saturate(4200%)
    hue-rotate(348deg) brightness(92%) contrast(94%)
    drop-shadow(0 2px 14px rgba(196, 26, 36, 0.22));
}
.project-card--frederick .project-card__badge {
  background-color: #c41a24;
  color: #FAF3EC;
}
.project-card--frederick .project-card__tagline {
  color: #c41a24;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
  .br-hero__title { font-size: 96px; }
  .br-section-title { font-size: 42px; }
  .br-three-grid { grid-template-columns: 1fr; gap: 20px; }
  .br-overview__grid { grid-template-columns: repeat(2, 1fr); }
  .br-stat:nth-child(2n) { border-right: none; }
  .br-stat:nth-child(-n+2) { border-bottom: 1px solid var(--br-fog); }
  .br-swatches { grid-template-columns: repeat(2, 1fr); }
  .br-typo { grid-template-columns: 1fr; }
  .br-logo-showcase { grid-template-columns: 1fr; }
  .br-demo-grid { grid-template-columns: 1fr; }
  .br-demo-item { border-top: 1px solid var(--br-fog); padding-top: 24px; }
  .br-demo-item:first-child { border-top: none; padding-top: 0; }
  .br-cta__title { font-size: 40px; }
}

@media (max-width: 640px) {
  .br-hero { padding: 100px 0 60px; }
  .br-hero__title { font-size: 68px; }
  .br-hero__tagline { font-size: 22px; }
  .br-section { padding: 64px 0; }
  .br-section-title { font-size: 32px; }
  .br-overview__grid { grid-template-columns: 1fr; }
  .br-stat { border-right: none; border-bottom: 1px solid var(--br-fog); }
  .br-stat:last-child { border-bottom: none; }
  .br-swatches { grid-template-columns: 1fr; }
  .br-stat__number { font-size: 56px; }
  .br-typo__display { font-size: 48px; }
  .br-cta__title { font-size: 32px; }
  .br-cta__actions { flex-direction: column; align-items: stretch; }
}

/* =====================================================================
   FREDERICK'S THEME (pink & red glamour · Berlin)
   Tokens: --fr-*   ·   BEM prefix: fr-*
   ===================================================================== */
body.theme-frederick {
  /* Brand officielle · rouge #ee232f + rose #fcd6e8 + crème conservé */
  --fr-red: #ee232f;
  --fr-red-deep: #c41a24;
  --fr-red-ink: #8a1119;
  --fr-pink: #fcd6e8;
  --fr-pink-soft: #fde4ef;
  --fr-pink-deep: #f9b8d2;
  --fr-pink-pale: #F9EEF0;
  --fr-cream: #FAF3EC;
  --fr-ivory: #F4E8DD;
  --fr-gold: #C99862;
  --fr-gold-bright: #E0B87F;
  --fr-ink: #2A0810;
  --fr-graphite: #6E4A4E;
  --fr-graphite-soft: rgba(42, 8, 16, 0.62);
  --fr-border: rgba(42, 8, 16, 0.12);
  --fr-border-light: rgba(250, 243, 236, 0.20);

  background-color: var(--fr-cream);
  color: var(--fr-ink);
  font-family: 'Inter', system-ui, sans-serif;
}

body.theme-frederick h1,
body.theme-frederick h2,
body.theme-frederick h3,
body.theme-frederick h4 {
  color: var(--fr-ink);
  font-family: 'Playfair Display', 'Prata', serif;
  letter-spacing: 0.01em;
}

body.theme-frederick p { color: var(--fr-graphite); }
body.theme-frederick a { color: var(--fr-red); }
body.theme-frederick a:hover { color: var(--fr-red); }

/* ----- Nav variant ----- */
.nav--frederick {
  background-color: rgba(250, 243, 236, 0.88);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
}
.nav--frederick .nav__logo { color: var(--fr-ink); font-family: 'Playfair Display', serif; font-style: italic; font-weight: 500; }
.nav--frederick .nav__logo:hover { color: var(--fr-red); }
.nav--frederick .nav__link { color: var(--fr-graphite); }
.nav--frederick .nav__link:hover { color: var(--fr-red); }
.nav--frederick .nav__link::after { background-color: var(--fr-red); }
.nav--frederick .nav__link--active { color: var(--fr-ink); }
.nav--frederick .nav__link--active::after { width: 100%; background-color: var(--fr-red); }
.nav--frederick.nav--scrolled { border-bottom-color: var(--fr-border); }

body.theme-frederick .footer {
  background-color: var(--fr-red-ink);
  color: rgba(250, 243, 236, 0.70);
  border-top-color: var(--fr-border-light);
}

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

/* ----- Kickers & titles ----- */
.fr-kicker {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--fr-red-deep);
  margin-bottom: 18px;
}
.fr-kicker--light { color: var(--fr-red-deep); }

.fr-section-title {
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  font-size: 54px;
  line-height: 1.08;
  letter-spacing: -0.005em;
  color: var(--fr-ink);
  margin: 0 0 28px;
  max-width: 780px;
}
.fr-section-title--light { color: var(--fr-ink); }

.fr-section-intro {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.75;
  color: var(--fr-graphite);
  max-width: 720px;
  margin: 0 0 56px;
}
.fr-section-intro--light { color: var(--fr-graphite); }

/* =========================================================
   HERO
   ========================================================= */
.fr-hero {
  position: relative;
  padding: 160px 0 130px;
  background:
    radial-gradient(ellipse at 50% 8%, rgba(252, 214, 232, 0.45) 0%, transparent 60%),
    linear-gradient(180deg, var(--fr-cream) 0%, var(--fr-pink-pale) 100%);
  color: var(--fr-ink);
  overflow: hidden;
  text-align: center;
}

.fr-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 90%, rgba(252, 214, 232, 0.25) 0%, transparent 42%),
    radial-gradient(circle at 85% 85%, rgba(249, 184, 210, 0.22) 0%, transparent 45%);
  pointer-events: none;
}

/* Ornements art-deco aux coins */
.fr-hero__ornament {
  position: absolute;
  width: 110px;
  height: 110px;
  border: 1px solid rgba(224, 184, 127, 0.35);
  pointer-events: none;
}
.fr-hero__ornament--tl {
  top: 90px; left: 48px;
  border-right: none;
  border-bottom: none;
}
.fr-hero__ornament--br {
  bottom: 60px; right: 48px;
  border-left: none;
  border-top: none;
}
.fr-hero__ornament::before,
.fr-hero__ornament::after {
  content: '';
  position: absolute;
  background-color: var(--fr-gold);
}
.fr-hero__ornament--tl::before { top: -1px; left: -1px; width: 22px; height: 1px; }
.fr-hero__ornament--tl::after  { top: -1px; left: -1px; width: 1px; height: 22px; }
.fr-hero__ornament--br::before { bottom: -1px; right: -1px; width: 22px; height: 1px; }
.fr-hero__ornament--br::after  { bottom: -1px; right: -1px; width: 1px; height: 22px; }

.fr-hero__inner { position: relative; z-index: 1; }

.fr-hero__eyebrow {
  display: inline-block;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--fr-red-deep);
  padding: 6px 16px;
  border: 1px solid rgba(196, 26, 36, 0.30);
  border-radius: 999px;
  margin-bottom: 44px;
}

.fr-hero__title {
  margin: 0 auto 30px;
  max-width: 820px;
}

.fr-hero__wordmark {
  display: block;
  width: 100%;
  max-width: 720px;
  height: auto;
  margin: 0 auto;
  /* Logo blanc recolor\u00e9 en red-deep via filter (source: logo-white.png) */
  filter:
    brightness(0) saturate(100%)
    invert(14%) sepia(88%) saturate(4200%)
    hue-rotate(348deg) brightness(92%) contrast(94%)
    drop-shadow(0 2px 16px rgba(196, 26, 36, 0.18));
}

.fr-hero__tagline {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 26px;
  line-height: 1.4;
  color: var(--fr-red-deep);
  margin: 0 0 36px;
  letter-spacing: 0.01em;
}

.fr-hero__meta {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 14px;
  margin-bottom: 32px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fr-ink);
}
.fr-hero__meta-item { font-weight: 500; }
.fr-hero__meta-sep { color: var(--fr-red-deep); }

.fr-hero__desc {
  max-width: 620px;
  margin: 0 auto;
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.75;
  color: var(--fr-graphite);
}

/* =========================================================
   SECTIONS
   ========================================================= */
.fr-section {
  padding: 110px 0;
  background-color: var(--fr-cream);
}
.fr-section--cream { background-color: var(--fr-ivory); }
.fr-section--blush { background-color: var(--fr-pink); }
.fr-section--wine  {
  background-color: var(--fr-pink-pale);
  color: var(--fr-ink);
  position: relative;
  overflow: hidden;
}
.fr-section--wine > .container { position: relative; z-index: 1; }

/* =========================================================
   OVERVIEW STATS
   ========================================================= */
.fr-overview__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 24px;
  border-top: 1px solid var(--fr-border);
  border-bottom: 1px solid var(--fr-border);
}
.fr-stat {
  padding: 36px 24px;
  border-right: 1px solid var(--fr-border);
  text-align: left;
}
.fr-stat:last-child { border-right: none; }
.fr-stat__number {
  display: block;
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  font-size: 44px;
  line-height: 1.05;
  color: var(--fr-red);
  letter-spacing: -0.005em;
  margin-bottom: 10px;
}
.fr-stat__label {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  line-height: 1.5;
  color: var(--fr-graphite);
  letter-spacing: 0.02em;
}

/* =========================================================
   MENUS GRID
   ========================================================= */
.fr-menus-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.fr-menu-card {
  margin: 0;
  background-color: var(--fr-cream);
  border: 1px solid var(--fr-border);
  border-radius: 4px;
  overflow: hidden;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.fr-menu-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -30px rgba(138, 17, 25, 0.30);
}
.fr-menu-card__frame {
  overflow: hidden;
  background-color: #f3ebe0;
}
.fr-menu-card__frame img {
  width: 100%;
  height: auto;
  display: block;
}
.fr-menu-card__caption {
  padding: 20px 22px;
  display: flex;
  align-items: baseline;
  gap: 14px;
  border-top: 1px solid var(--fr-border);
}
.fr-menu-card__lang {
  font-family: 'Playfair Display', serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.18em;
  color: var(--fr-red);
}
.fr-menu-card__type {
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--fr-graphite);
  letter-spacing: 0.02em;
}

/* =========================================================
   COCKTAILS
   ========================================================= */
.fr-cocktails {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.fr-cocktail {
  margin: 0;
  position: relative;
  overflow: hidden;
  border-radius: 4px;
  background-color: var(--fr-red-deep);
}
.fr-cocktail img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.6s ease;
}
.fr-cocktail:hover img { transform: scale(1.03); }
.fr-cocktail figcaption {
  padding: 22px 24px 26px;
  border-top: 1px solid rgba(224, 184, 127, 0.22);
  background-color: rgba(42, 8, 16, 0.55);
}
.fr-cocktail__name {
  display: block;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  color: var(--fr-cream);
  margin-bottom: 4px;
}
.fr-cocktail__note {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fr-gold-bright);
}

/* =========================================================
   POSTERS
   ========================================================= */
.fr-posters {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 32px;
  flex-wrap: wrap;
}
.fr-poster {
  margin: 0;
  background-color: var(--fr-cream);
  border: 1px solid var(--fr-border);
  overflow: hidden;
  border-radius: 4px;
  max-width: 320px;
  flex: 0 1 320px;
}
.fr-poster--tall img {
  width: 100%;
  height: auto;
  display: block;
}
/* Flyer-aperitivo a un aspect ratio plus étroit (0.50 vs 0.71 pour les deux autres).
   À 320px de large il serait ~641px de haut : on le réduit à 226px pour aligner
   les hauteurs visibles des 3 cartes (226 × 1600/799 ≈ 453px, identique aux autres). */
.fr-poster--narrow {
  max-width: 226px;
  flex: 0 1 226px;
}
.fr-poster figcaption {
  padding: 18px 22px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  color: var(--fr-graphite);
  letter-spacing: 0.02em;
  border-top: 1px solid var(--fr-border);
}

/* =========================================================
   REELS
   ========================================================= */
.fr-reels {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.fr-reel {
  margin: 0;
  overflow: hidden;
  border-radius: 4px;
  background-color: var(--fr-pink-deep);
  transition: transform 0.4s ease;
}
.fr-reel:hover { transform: translateY(-3px); }
.fr-reel img {
  width: 100%;
  height: auto;
  display: block;
}
.fr-reels__cta {
  margin-top: 48px;
  text-align: center;
}
.fr-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 10px;
  line-height: 0;
}

/* =========================================================
   TAKEAWAYS (CV / demonstrates)
   ========================================================= */
.fr-takeaways {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 56px;
  margin-top: 12px;
}
.fr-takeaway {
  position: relative;
  padding-top: 28px;
  border-top: 1px solid var(--fr-border);
}
.fr-takeaway__num {
  display: block;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 15px;
  color: var(--fr-red-deep);
  margin-bottom: 14px;
  letter-spacing: 0.08em;
}
.fr-takeaway__title {
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  font-size: 24px;
  line-height: 1.25;
  color: var(--fr-ink);
  margin: 0 0 12px;
}
.fr-takeaway__desc {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: var(--fr-graphite);
  margin: 0;
}

/* =========================================================
   CTA
   ========================================================= */
.fr-cta {
  position: relative;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(252, 214, 232, 0.45) 0%, transparent 65%),
    linear-gradient(180deg, var(--fr-pink-pale) 0%, var(--fr-cream) 100%);
  color: var(--fr-ink);
  padding: 130px 0;
  text-align: center;
  overflow: hidden;
}
.fr-cta > .container { position: relative; z-index: 1; }

.fr-cta__ornament {
  width: 42px;
  height: 2px;
  background-color: var(--fr-gold);
  margin: 0 auto 28px;
}

.fr-cta__title {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 500;
  font-size: 58px;
  line-height: 1.08;
  color: var(--fr-ink);
  margin: 0 0 20px;
}
.fr-cta__subtitle {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.7;
  color: var(--fr-graphite);
  max-width: 560px;
  margin: 0 auto 40px;
}
.fr-cta__actions {
  display: inline-flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}

.fr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 2px;
  transition: all 0.25s ease;
  cursor: pointer;
}
.fr-btn--primary {
  background-color: var(--fr-red-deep);
  color: var(--fr-cream);
  border: 1px solid var(--fr-red-deep);
}
.fr-btn--primary:hover {
  background-color: var(--fr-red-ink);
  border-color: var(--fr-red-ink);
  color: var(--fr-cream);
}
.fr-btn--ghost {
  background-color: transparent;
  color: var(--fr-ink);
  border: 1px solid rgba(42, 8, 16, 0.35);
}
.fr-btn--ghost:hover {
  border-color: var(--fr-red-deep);
  color: var(--fr-red-deep);
}

/* Override specificity: body.theme-frederick a (0,1,2) beats .fr-btn--primary (0,1,0).
   body-scoped selector raises button text rules to (0,2,1), wins cleanly. */
body.theme-frederick a.fr-btn--primary,
body.theme-frederick a.fr-btn--primary:hover,
body.theme-frederick a.fr-btn--primary:focus {
  color: var(--fr-cream);
}
body.theme-frederick a.fr-btn--ghost { color: var(--fr-ink); }
body.theme-frederick a.fr-btn--ghost:hover { color: var(--fr-red-deep); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
  .fr-hero { padding: 130px 0 100px; }
  .fr-hero__wordmark { max-width: 560px; }
  .fr-section-title { font-size: 42px; }
  .fr-overview__grid { grid-template-columns: repeat(2, 1fr); }
  .fr-stat:nth-child(2n) { border-right: none; }
  .fr-stat:nth-child(-n+2) { border-bottom: 1px solid var(--fr-border); }
  .fr-menus-grid { grid-template-columns: repeat(2, 1fr); }
  .fr-menu-card:last-child { grid-column: 1 / -1; max-width: 50%; justify-self: center; }
  .fr-cocktails { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
  .fr-posters { grid-template-columns: 1fr; }
  .fr-reels { grid-template-columns: repeat(2, 1fr); }
  .fr-takeaways { grid-template-columns: 1fr; gap: 32px; }
  .fr-cta__title { font-size: 44px; }
  .fr-hero__ornament { width: 80px; height: 80px; }
  .fr-hero__ornament--tl { top: 70px; left: 24px; }
  .fr-hero__ornament--br { bottom: 36px; right: 24px; }
}

@media (max-width: 640px) {
  .fr-hero { padding: 110px 0 80px; }
  .fr-hero__wordmark { max-width: 320px; }
  .fr-hero__tagline { font-size: 20px; }
  .fr-hero__meta { gap: 8px; font-size: 11px; }
  .fr-section { padding: 72px 0; }
  .fr-section-title { font-size: 32px; }
  .fr-overview__grid { grid-template-columns: 1fr; }
  .fr-stat { border-right: none; border-bottom: 1px solid var(--fr-border); }
  .fr-stat:last-child { border-bottom: none; }
  .fr-stat__number { font-size: 36px; }
  .fr-menus-grid { grid-template-columns: 1fr; }
  .fr-menu-card:last-child { max-width: 100%; }
  .fr-reels { grid-template-columns: 1fr; }
  .fr-cta { padding: 90px 0; }
  .fr-cta__title { font-size: 34px; }
  .fr-cta__actions { flex-direction: column; align-items: stretch; width: 100%; }
  .fr-hero__ornament { display: none; }
}
