/* ============================================================
   Baghikian Law Firm: Midnight Navy + Antique Gold, classic serif
   Display: Lora | Body: Source Serif 4
   ============================================================ */

:root {
  /* Type scale */
  --text-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.8125rem);
  --text-sm: clamp(0.875rem, 0.8rem + 0.35vw, 0.95rem);
  --text-base: clamp(1rem, 0.95rem + 0.25vw, 1.0625rem);
  --text-lg: clamp(1.125rem, 1rem + 0.6vw, 1.375rem);
  --text-xl: clamp(1.5rem, 1.2rem + 1.25vw, 2.125rem);
  --text-2xl: clamp(2rem, 1.3rem + 2.4vw, 3.25rem);
  --text-3xl: clamp(2.6rem, 1.4rem + 4.2vw, 4.75rem);

  /* Spacing */
  --space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem;
  --space-5: 1.25rem; --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem;
  --space-12: 3rem; --space-16: 4rem; --space-20: 5rem; --space-24: 6rem; --space-32: 8rem;

  /* Surfaces: warm cream / off-white (kept light, per brand) */
  --color-bg: #f7f4ed;
  --color-surface: #fcfaf5;
  --color-surface-2: #ffffff;
  --color-surface-offset: #eef0f5;
  --color-border: #d8dce4;
  --color-divider: #e4e7ee;

  /* Midnight navy + text */
  --color-ink: #0c1c33;          /* midnight navy: headings / dark sections */
  --color-ink-2: #14294a;
  --color-text: #1f2b40;
  --color-text-muted: #51607a;
  --color-text-faint: #8590a4;
  --color-text-inverse: #f7f4ed;

  /* Accent: antique brass-gold, used sparingly */
  --color-accent: #9c7a3a;
  --color-accent-hover: #806230;
  --color-accent-soft: #c8a25a;

  --radius-sm: 0.25rem; --radius-md: 0.5rem; --radius-lg: 0.875rem; --radius-full: 9999px;
  --transition: 200ms cubic-bezier(0.16, 1, 0.3, 1);
  --shadow-sm: 0 1px 3px rgba(12,28,51,0.07);
  --shadow-md: 0 6px 20px rgba(12,28,51,0.10);
  --shadow-lg: 0 18px 48px rgba(12,28,51,0.16);

  --content-narrow: 680px;
  --content-default: 1000px;
  --content-wide: 1200px;

  --font-display: 'Lora', Georgia, 'Times New Roman', serif;
  --font-body: 'Source Serif 4', Georgia, 'Times New Roman', serif;
}

/* Base reset */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility; scroll-behavior: smooth;
  scroll-padding-top: 6rem;
}
body {
  min-height: 100dvh; line-height: 1.65; font-family: var(--font-body);
  font-size: var(--text-base); color: var(--color-text); background: var(--color-bg);
}
img,picture,video,svg { display: block; max-width: 100%; height: auto; }
ul[role='list'] { list-style: none; }
input,button,textarea,select { font: inherit; color: inherit; }
h1,h2,h3,h4 { font-family: var(--font-display); line-height: 1.12; text-wrap: balance; color: var(--color-ink); font-weight: 600; }
p,li { text-wrap: pretty; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; background: none; border: none; }
::selection { background: rgba(154,107,47,0.22); }
:focus-visible { outline: 2px solid var(--color-accent); outline-offset: 3px; border-radius: var(--radius-sm); }
a,button { transition: color var(--transition), background var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition); }
@media (prefers-reduced-motion: reduce) { *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; scroll-behavior:auto!important; } }

.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; }
.skip-link { position:absolute; left:-999px; top:0; background:var(--color-ink); color:#fff; padding:var(--space-3) var(--space-4); z-index:200; }
.skip-link:focus { left:var(--space-4); top:var(--space-4); }

/* Layout helpers */
.container { width:100%; max-width: var(--content-wide); margin-inline:auto; padding-inline: clamp(1.25rem, 4vw, 3rem); }
.container--narrow { max-width: var(--content-narrow); }
.container--default { max-width: var(--content-default); }
.section { padding-block: clamp(var(--space-16), 8vw, var(--space-32)); }
.section--tight { padding-block: clamp(var(--space-12), 6vw, var(--space-20)); }

.eyebrow {
  font-family: var(--font-body); font-size: var(--text-xs); font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-accent);
  display: inline-block;
}

.lead { font-size: var(--text-lg); color: var(--color-text-muted); max-width: 60ch; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2);
  font-family: var(--font-body); font-size: var(--text-sm); font-weight:600; letter-spacing:.02em;
  line-height:1; padding: 0.875rem var(--space-6); border-radius: var(--radius-sm); white-space:nowrap; }
.btn--primary { background: var(--color-ink); color: var(--color-text-inverse); }
.btn--primary:hover { background: var(--color-ink-2); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--accent { background: var(--color-accent); color:#fff; }
.btn--accent:hover { background: var(--color-accent-hover); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--ghost { border:1px solid var(--color-border); color: var(--color-ink); background: transparent; }
.btn--ghost:hover { border-color: var(--color-ink); background: var(--color-surface-2); }
.btn--inverse-ghost { border:1px solid rgba(246,243,236,0.35); color: var(--color-text-inverse); }
.btn--inverse-ghost:hover { border-color:#fff; background: rgba(246,243,236,0.08); }

/* ---------- Header ---------- */
.header { position: sticky; top:0; z-index:100;
  background: rgba(246,243,236,0.88); backdrop-filter: blur(14px) saturate(1.1);
  border-top: 3px solid var(--color-accent);
  border-bottom: 1px solid transparent; transition: box-shadow var(--transition), border-color var(--transition); }
.header--scrolled { box-shadow: var(--shadow-sm); border-bottom-color: var(--color-divider); }
.header__inner { display:flex; align-items:center; justify-content:space-between; gap: clamp(var(--space-4), 3vw, var(--space-8));
  padding-block: var(--space-2); }
.brand { display:flex; align-items:center; color: var(--color-ink); flex-shrink:0; }
.brand__logo { width: auto; height: clamp(64px, 7.2vw, 104px); flex-shrink:0; display:block; }

.nav { display:flex; align-items:center; }
.nav__list { display:flex; align-items:center; gap: clamp(var(--space-5), 2.4vw, var(--space-8)); list-style:none; }
.nav__link { font-size: var(--text-sm); font-weight:500; letter-spacing:.005em; color: var(--color-text); position:relative; padding-block: var(--space-2); white-space:nowrap; }
.nav__link:hover { color: var(--color-accent); }
.nav__item { position: relative; }
.nav__item--has-menu > .nav__link::after { content:'▾'; font-size:.62em; margin-left:6px; position:relative; top:-1px; color: var(--color-text-muted); transition: color var(--transition); }
.nav__item--has-menu:hover > .nav__link::after { color: var(--color-accent); }
.dropdown { position:absolute; top:100%; left:50%; transform: translateX(-50%) translateY(8px);
  background: var(--color-surface-2); border:1px solid var(--color-divider); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg); min-width: 250px; padding: var(--space-3); opacity:0; visibility:hidden;
  transition: opacity var(--transition), transform var(--transition); }
.nav__item--has-menu:hover .dropdown,
.nav__item--has-menu:focus-within .dropdown { opacity:1; visibility:visible; transform: translateX(-50%) translateY(6px); }
.dropdown a { display:block; padding: var(--space-3) var(--space-3); border-radius: var(--radius-sm); font-size: var(--text-sm); color: var(--color-text); }
.dropdown a:hover { background: var(--color-surface-offset); color: var(--color-accent); }
.header__cta { display:flex; align-items:center; gap: clamp(var(--space-3), 1.6vw, var(--space-5)); }
.header__phone { font-size: var(--text-sm); font-weight:600; color: var(--color-ink); display:inline-flex; align-items:center; gap:6px; white-space:nowrap; }
.header__phone svg { flex-shrink:0; }
.header__phone:hover { color: var(--color-accent); }

.menu-toggle { display:none; width:44px; height:44px; align-items:center; justify-content:center; color: var(--color-ink); }
.mobile-nav { display:none; }

@media (max-width: 1180px) {
  .header__phone { display:none; }
}
@media (max-width: 980px) {
  .nav { display:none; }
  .menu-toggle { display:flex; }
  .mobile-nav { display:block; position:fixed; inset:0 0 0 auto; width:min(86vw, 360px); z-index:150;
    background: var(--color-surface); box-shadow: var(--shadow-lg); transform: translateX(100%);
    transition: transform var(--transition); overflow-y:auto; padding: var(--space-20) var(--space-6) var(--space-8); }
  .mobile-nav.open { transform: translateX(0); }
  .mobile-nav a { display:block; padding: var(--space-3) 0; font-size: var(--text-lg); font-family: var(--font-display);
    color: var(--color-ink); border-bottom:1px solid var(--color-divider); }
  .mobile-nav .sub a { font-family: var(--font-body); font-size: var(--text-base); padding-left: var(--space-4); color: var(--color-text-muted); border:0; }
  .mobile-nav__close { position:absolute; top: var(--space-5); right: var(--space-5); width:40px; height:40px; }
  .scrim { position:fixed; inset:0; background: rgba(22,31,51,0.45); z-index:140; opacity:0; visibility:hidden; transition: opacity var(--transition); }
  .scrim.open { opacity:1; visibility:visible; }
}

/* ---------- Hero ---------- */
.hero { position:relative; overflow:hidden; }
.hero__grid { display:grid; grid-template-columns: 1.05fr 0.95fr; align-items:center; gap: clamp(2rem, 5vw, 5rem);
  padding-block: clamp(var(--space-16), 9vw, var(--space-32)); }
.hero__eyebrow { margin-bottom: var(--space-5); }
.hero__title { font-size: var(--text-3xl); font-weight:600; color: var(--color-ink); line-height:1.05; margin-bottom: var(--space-6); letter-spacing:-0.015em; }
.hero__title em { font-style: italic; color: var(--color-accent); }
.hero__copy { font-size: var(--text-lg); color: var(--color-text-muted); line-height:1.6; max-width: 46ch; margin-bottom: var(--space-8); }
.hero__actions { display:flex; flex-wrap:wrap; gap: var(--space-3); margin-bottom: var(--space-12); }
.hero__media { position:relative; }
.hero__media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); aspect-ratio: 4/5; object-fit:cover; width:100%; }
.hero__badge { position:absolute; bottom: -22px; left: -22px; background: var(--color-ink); color: var(--color-text-inverse);
  padding: var(--space-4) var(--space-5); border-radius: var(--radius-md); box-shadow: var(--shadow-lg); max-width: 260px; }
.hero__badge strong { font-family: var(--font-display); display:block; font-size:1.18rem; margin-bottom:3px; white-space:nowrap; }
.hero__badge span { font-size: var(--text-xs); color: rgba(246,243,236,0.7); }

.stats { display:grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); border-top:1px solid var(--color-border); padding-top: var(--space-8); }
.stat__num { font-family: var(--font-display); font-size: var(--text-xl); color: var(--color-accent); font-weight:600; line-height:1; }
.stat__label { font-size: var(--text-xs); letter-spacing:.12em; text-transform:uppercase; color: var(--color-text-muted); margin-top: var(--space-2); }

@media (max-width: 880px) {
  .hero__grid { grid-template-columns: 1fr; padding-block: var(--space-8); }
  .hero__media { order:2; max-width: 320px; margin-inline:auto; margin-top: var(--space-8); }
  .hero__media img { aspect-ratio: 1/1; }
  .hero__title { margin-bottom: var(--space-4); }
  .hero__copy { margin-bottom: var(--space-5); }
  .hero__actions { margin-bottom: var(--space-6); }
  .hero__badge { left: auto; right: -10px; bottom:-14px; padding: var(--space-3) var(--space-4); }
  .hero__badge strong { font-size:1rem; }
}
@media (max-width: 540px) {
  .hero__media { max-width: 240px; }
}

/* ---------- Section headers ---------- */
.section-head { max-width: 60ch; margin-bottom: clamp(var(--space-10), 5vw, var(--space-16)); }
.section-head--center { margin-inline:auto; text-align:center; }
.section-head h2 { font-size: var(--text-2xl); line-height:1.08; margin-block: var(--space-4) var(--space-5); }
.section-head p { color: var(--color-text-muted); font-size: var(--text-lg); line-height:1.6; }

/* ---------- Cards / practice grid ---------- */
.card-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: var(--space-6); }
.pcard { background: var(--color-surface-2); border:1px solid var(--color-divider); border-radius: var(--radius-lg);
  padding: var(--space-8); display:flex; flex-direction:column; gap: var(--space-3); position:relative; overflow:hidden; }
.pcard::before { content:''; position:absolute; top:0; left:0; width:100%; height:3px; background: var(--color-accent); transform: scaleX(0); transform-origin:left; transition: transform var(--transition); }
.pcard:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-color: var(--color-border); }
.pcard:hover::before { transform: scaleX(1); }
.pcard__icon { width:46px; height:46px; color: var(--color-accent); margin-bottom: var(--space-2); }
.pcard h3 { font-size: var(--text-lg); }
.pcard p { color: var(--color-text-muted); font-size: var(--text-sm); }
.pcard__link { margin-top:auto; font-size: var(--text-sm); font-weight:600; color: var(--color-ink); display:inline-flex; align-items:center; gap:6px; }
.pcard__link:hover { color: var(--color-accent); gap:10px; }

/* ---------- Split / about ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4.5rem); align-items:center; }
.split--reverse .split__media { order:2; }
.split__media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); object-fit:cover; width:100%; }
.split__body h2 { font-size: var(--text-2xl); margin-bottom: var(--space-5); }
.split__body p { color: var(--color-text-muted); margin-bottom: var(--space-4); }
.checklist { list-style:none; display:grid; gap: var(--space-3); margin-block: var(--space-5); }
.checklist li { display:flex; gap: var(--space-3); font-size: var(--text-base); }
.checklist li::before { content:''; flex-shrink:0; width:22px; height:22px; margin-top:2px; border-radius:var(--radius-full);
  background: rgba(154,107,47,0.14) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239a6b2f' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/14px no-repeat; }
@media (max-width: 820px) { .split { grid-template-columns:1fr; } .split--reverse .split__media { order:0; } }

/* ---------- Dark band ---------- */
.band { background: var(--color-ink); color: var(--color-text-inverse); }
.band h2,.band h3 { color: var(--color-text-inverse); }
.band .lead, .band p { color: rgba(246,243,236,0.72); }
.band .eyebrow { color: var(--color-accent-soft); }
.band .stat__num { color: var(--color-accent-soft); }
.band .stat__label { color: rgba(246,243,236,0.6); }
.band .stats { border-top-color: rgba(246,243,236,0.18); }

/* ---------- Areas served ---------- */
.cities { display:flex; flex-wrap:wrap; gap: var(--space-3); }
.cities a { font-size: var(--text-sm); padding: var(--space-2) var(--space-4); border:1px solid var(--color-border);
  border-radius: var(--radius-full); color: var(--color-text); background: var(--color-surface-2); }
.cities a:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* ---------- Founder ---------- */
.founder { display:grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(2rem,5vw,4rem); align-items:center; }
.founder__media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); aspect-ratio:4/5; object-fit:cover; }
.founder__name { font-size: var(--text-xl); margin-block: var(--space-4) var(--space-1); }
.founder__role { font-size: var(--text-sm); letter-spacing:.1em; text-transform:uppercase; color: var(--color-accent); margin-bottom: var(--space-5); }
.founder__body p { color: rgba(246,243,236,0.8); margin-bottom: var(--space-4); }
@media (max-width:760px){ .founder { grid-template-columns:1fr; } .founder__media { max-width:340px; } }

/* ---------- FAQ ---------- */
.faq { display:grid; gap: var(--space-3); max-width: var(--content-narrow); margin-inline:auto; }
.faq__item { border:1px solid var(--color-divider); border-radius: var(--radius-md); background: var(--color-surface-2); overflow:hidden; }
.faq__q { width:100%; text-align:left; display:flex; justify-content:space-between; align-items:center; gap:var(--space-4);
  padding: var(--space-5) var(--space-6); font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-ink); }
.faq__q span { flex-shrink:0; width:24px; height:24px; transition: transform var(--transition); color: var(--color-accent); }
.faq__item[open] .faq__q span { transform: rotate(45deg); }
.faq__a { padding: 0 var(--space-6) var(--space-5); color: var(--color-text-muted); font-size: var(--text-base); }
.faq__item summary { list-style:none; } .faq__item summary::-webkit-details-marker { display:none; }

/* ---------- Form ---------- */
.contact-grid { display:grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem,5vw,4rem); align-items:start; }
.form { background: var(--color-surface-2); border:1px solid var(--color-divider); border-radius: var(--radius-lg); padding: clamp(1.5rem,4vw,2.5rem); box-shadow: var(--shadow-sm); }
.field { margin-bottom: var(--space-5); }
.field label { display:block; font-size: var(--text-sm); font-weight:600; margin-bottom: var(--space-2); color: var(--color-ink); }
.field input, .field textarea, .field select { width:100%; padding: var(--space-3) var(--space-4); border:1px solid var(--color-border);
  border-radius: var(--radius-sm); background: var(--color-surface); font-size: var(--text-base); }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(154,107,47,0.12); }
.field textarea { min-height: 130px; resize: vertical; }
.consent { display:flex; gap: var(--space-3); align-items:flex-start; font-size: var(--text-sm); color: var(--color-text-muted); }
.consent input { width:18px; height:18px; margin-top:3px; flex-shrink:0; }
.form__note { font-size: var(--text-xs); color: var(--color-text-faint); margin-top: var(--space-4); text-align:center; }
.contact-info dt { font-size: var(--text-xs); letter-spacing:.12em; text-transform:uppercase; color: var(--color-accent); margin-bottom: var(--space-1); }
.contact-info dd { font-size: var(--text-lg); font-family: var(--font-display); color: var(--color-ink); margin-bottom: var(--space-6); }
.contact-info dd a:hover { color: var(--color-accent); }
@media (max-width:820px){ .contact-grid { grid-template-columns:1fr; } }

/* ---------- Article / prose ---------- */
.prose { max-width: 70ch; }
.prose h2 { font-size: var(--text-xl); margin-block: var(--space-10) var(--space-4); }
.prose h3 { font-size: var(--text-lg); margin-block: var(--space-8) var(--space-3); }
.prose p { margin-bottom: var(--space-5); color: var(--color-text); }
.prose ul { margin-block: var(--space-4); padding-left: var(--space-6); }
.prose li { margin-bottom: var(--space-2); }
.prose a { color: var(--color-accent); text-decoration: underline; text-underline-offset: 3px; }
.callout { border-left: 3px solid var(--color-accent); background: var(--color-surface-2); padding: var(--space-5) var(--space-6);
  border-radius: 0 var(--radius-md) var(--radius-md) 0; margin-block: var(--space-8); }
.callout p { margin:0; }

/* Page hero (interior) */
.page-hero { position:relative; background: var(--color-ink); color: var(--color-text-inverse); padding-block: clamp(var(--space-16), 8vw, var(--space-24)); overflow:hidden; }
.page-hero--img { background:#0c1c33; }
.page-hero--img::before { content:''; position:absolute; inset:0; z-index:0;
  background-image: var(--hero-img); background-size: cover; background-position: center;
  opacity: 1; }
.page-hero--img::after { content:''; position:absolute; inset:0; z-index:1;
  background: linear-gradient(110deg, rgba(12,28,51,0.92) 0%, rgba(12,28,51,0.78) 42%, rgba(12,28,51,0.42) 100%); }
.page-hero > .container { position:relative; z-index:2; }
.page-hero h1 { color: var(--color-text-inverse); font-size: var(--text-2xl); margin-block: var(--space-4) var(--space-4); }
.page-hero p { color: rgba(246,243,236,0.78); font-size: var(--text-lg); max-width: 60ch; }
.page-hero .eyebrow { color: var(--color-accent-soft); }
.breadcrumb { font-size: var(--text-xs); color: rgba(246,243,236,0.6); margin-bottom: var(--space-5); }
.breadcrumb a:hover { color:#fff; } .breadcrumb span { margin-inline: var(--space-2); }

/* Blog cards */
.post-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(300px,1fr)); gap: var(--space-8); }
.post-card { display:flex; flex-direction:column; gap: var(--space-3); background:var(--color-surface-2); border:1px solid var(--color-divider); border-radius: var(--radius-lg); overflow:hidden; }
.post-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.post-card__img { aspect-ratio:16/10; object-fit:cover; width:100%; }
.post-card__body { padding: var(--space-6); display:flex; flex-direction:column; gap: var(--space-3); flex:1; }
.post-card__meta { font-size: var(--text-xs); letter-spacing:.08em; text-transform:uppercase; color: var(--color-accent); }
.post-card h3 { font-size: var(--text-lg); }
.post-card p { font-size: var(--text-sm); color: var(--color-text-muted); }

/* ---------- Footer ---------- */
.footer { background: var(--color-ink); color: rgba(246,243,236,0.66); padding-block: clamp(var(--space-16), 6vw, var(--space-24)) var(--space-8); }
.footer__grid { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: clamp(var(--space-8), 4vw, var(--space-12)); margin-bottom: clamp(var(--space-12), 5vw, var(--space-16)); }
.footer h4 { color: rgba(246,243,236,0.5); font-family: var(--font-body); font-size: 0.72rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; margin-bottom: var(--space-5); }
.footer__brand .brand__name { color: var(--color-text-inverse); }
.footer__brandlink { display:inline-block; }
.footer__logo { width: auto; height: 72px; max-width: 100%; display:block; margin-bottom: var(--space-5); }
.footer ul { list-style:none; display:grid; gap: var(--space-4); }
.footer a { font-size: var(--text-sm); color: rgba(246,243,236,0.72); }
.footer a:hover { color:#fff; }
.footer__about { font-size: var(--text-sm); line-height:1.7; max-width: 40ch; margin-block: var(--space-5) var(--space-6); color: rgba(246,243,236,0.6); }
.footer__phone { display:inline-block; font-size: var(--text-base); font-weight:600; color: var(--color-text-inverse); }
.footer__phone:hover { color: var(--color-accent-soft); }
.footer__bottom { border-top:1px solid rgba(246,243,236,0.12); padding-top: var(--space-8); display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; gap: var(--space-4); font-size: var(--text-xs); color: rgba(246,243,236,0.5); }
.footer__disclaimer { max-width: 78ch; font-size: var(--text-xs); color: rgba(246,243,236,0.38); margin-top: var(--space-6); line-height:1.7; }
@media (max-width: 860px){ .footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-10) var(--space-8); } }
@media (max-width: 520px){ .footer__grid { grid-template-columns: 1fr; gap: var(--space-10); } .footer__bottom { flex-direction:column; align-items:flex-start; } }

/* ===== Trust badges ===== */
.trust-badges { display:flex; flex-wrap:wrap; gap: var(--space-4); }
.hero__trust { margin-top: var(--space-12); }
.trust-badge { display:flex; align-items:center; gap: var(--space-3); padding: var(--space-4) var(--space-5);
  border:1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-surface-2);
  text-decoration:none; transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition); }
a.trust-badge:hover { border-color: var(--color-accent); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.trust-badge__icon { color: var(--color-accent); display:flex; flex-shrink:0; }
.trust-badge__stars { color: var(--color-accent); display:inline-flex; gap:1px; flex-shrink:0; }
.trust-badge__text { display:flex; flex-direction:column; line-height:1.25; }
.trust-badge__text strong { font-family: var(--font-display); font-size: var(--text-base); color: var(--color-ink); white-space:nowrap; }
.trust-badge__text span { font-size: var(--text-xs); color: var(--color-text-muted); white-space:nowrap; }
/* Footer variant — on dark ground */
.footer .trust-badges { margin: var(--space-10) 0 var(--space-8); padding-top: var(--space-8); border-top:1px solid rgba(246,243,236,0.12); }
.footer .trust-badge { background: rgba(246,243,236,0.04); border-color: rgba(246,243,236,0.16); }
.footer a.trust-badge:hover { border-color: var(--color-accent-soft); box-shadow:none; }
.footer .trust-badge__icon, .footer .trust-badge__stars { color: var(--color-accent-soft); }
.footer .trust-badge__text strong { color: var(--color-text-inverse); }
.footer .trust-badge__text span { color: rgba(246,243,236,0.6); }
@media (max-width: 520px){ .trust-badge { flex: 1 1 100%; } }

/* Reveal on scroll — progressive enhancement: only hide when JS marks <html> as js-enabled */
.js .reveal { opacity:0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.js .reveal.in { opacity:1; transform:none; }
