/* ================================================================
   BERGE.NG — Master Stylesheet  v2.0
   Brand: Navy Blue · Gold · White
   Light mode + Dark mode (data-theme="dark")
   Zero inline styles — all layout via classes
   ================================================================ */

/* ── 1. TOKENS ────────────────────────────────────────────────── */
:root {
  --blue-dark:    #0d2b6b;
  --blue-mid:     #1a4db8;
  --blue-light:   #2e6ee6;
  --gold:         #c9a84c;
  --gold-pale:    #fdf3d8;
  --gold-light:   #f0d98a;

  /* Surfaces — light mode */
  --bg:           #ffffff;
  --bg-alt:       #f7f8fc;
  --bg-card:      #ffffff;
  --ink:          #0d1b3e;
  --muted:        #5a6b8a;
  --line:         rgba(13,43,107,0.12);

  /* Always-dark contexts */
  --hero-start:   #0d2b6b;
  --hero-end:     #0a2258;
  --footer-bg:    #0d2b6b;

  /* Nav */
  --nav-bg:       rgba(255,255,255,0.96);
  --nav-shadow:   0 1px 24px rgba(13,43,107,0.07);
  --nav-h:        72px;

  /* Motion */
  --ease:         0.22s ease;

  /* Layout */
  --container:    1200px;
  --gap:          2px;
  --radius:       0px;
}

/* ── 2. DARK MODE ─────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg:           #0b1629;
  --bg-alt:       #0f1e38;
  --bg-card:      #132040;
  --ink:          #e8edf8;
  --muted:        #8da0c0;
  --line:         rgba(255,255,255,0.08);
  --nav-bg:       rgba(11,22,41,0.96);
  --nav-shadow:   0 1px 24px rgba(0,0,0,0.35);
  --gold-pale:    rgba(201,168,76,0.12);
}

/* ── 3. RESET ─────────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html  { scroll-behavior:smooth; font-size:16px; -webkit-text-size-adjust:100%; }
body  {
  font-family:'DM Sans',sans-serif;
  background:var(--bg); color:var(--ink);
  transition:background var(--ease), color var(--ease);
  overflow-x:hidden; line-height:1.6;
}
img   { display:block; max-width:100%; height:auto; }
a     { color:inherit; text-decoration:none; }
ul    { list-style:none; }
address { font-style:normal; }

/* ── 4. ACCESSIBILITY ─────────────────────────────────────────── */
.skip-link {
  position:absolute; top:-100%; left:16px; z-index:9999;
  background:var(--blue-mid); color:#fff;
  padding:8px 16px; font-size:14px; font-weight:500;
  transition:top 0.2s;
}
.skip-link:focus { top:8px; }
:focus-visible {
  outline:3px solid var(--gold); outline-offset:3px;
}

/* ── 5. CONTAINER ─────────────────────────────────────────────── */
.container       { width:100%; max-width:var(--container); margin:0 auto; padding:0 64px; }
.container--narrow { max-width:860px; }
.container--wide   { max-width:1400px; }

/* ── 6. TYPOGRAPHY ────────────────────────────────────────────── */
.section-tag {
  display:block; font-size:11px; letter-spacing:0.18em;
  text-transform:uppercase; font-weight:600; color:var(--blue-mid); margin-bottom:14px;
}
[data-theme="dark"] .section-tag { color:var(--gold); }
.section--dark .section-tag { color:var(--gold); }

.section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(30px,3.2vw,46px); font-weight:400;
  line-height:1.15; color:var(--ink); margin-bottom:20px;
}
.section--dark .section-title { color:#fff; }

.section-body   { font-size:16px; line-height:1.82; color:var(--muted); margin-bottom:18px; }
.section--dark .section-body { color:rgba(255,255,255,0.6); }

/* ── 7. NAVIGATION ────────────────────────────────────────────── */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  height:var(--nav-h); padding:0 64px;
  background:var(--nav-bg); backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line); box-shadow:var(--nav-shadow);
  transition:height var(--ease), background var(--ease), box-shadow var(--ease);
}
.nav.scrolled { height:60px; }

/* Logo */
.nav__logo {
  display:flex; align-items:center; gap:10px;
  font-family:'Cormorant Garamond',serif;
  font-size:24px; font-weight:700; color:var(--blue-dark);
  transition:color var(--ease);
}
[data-theme="dark"] .nav__logo { color:var(--ink); }
.nav__logo em   { color:var(--gold); font-style:normal; }
.nav__logo-text { line-height:1; }

/* Logo image swap */
.nav__logo-img          { width:32px; height:32px; object-fit:contain; flex-shrink:0; }
.nav__logo-img--dark    { display:none; }
[data-theme="dark"] .nav__logo-img--light { display:none; }
[data-theme="dark"] .nav__logo-img--dark  { display:block; }

/* Nav links */
.nav__links {
  display:flex; gap:32px; align-items:center;
}
.nav__links a {
  font-size:14px; font-weight:500; color:var(--ink); letter-spacing:0.03em;
  opacity:0.62; position:relative; padding-bottom:3px;
  transition:opacity var(--ease), color var(--ease);
}
.nav__links a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--gold);
  transition:width var(--ease);
}
.nav__links a:hover,
.nav__links a.active { opacity:1; color:var(--blue-mid); }
[data-theme="dark"] .nav__links a:hover,
[data-theme="dark"] .nav__links a.active { color:var(--gold); }
.nav__links a:hover::after,
.nav__links a.active::after { width:100%; }

/* Nav actions */
.nav__actions { display:flex; align-items:center; gap:10px; }

/* Theme toggle */
.nav__theme-toggle {
  background:none; border:1px solid var(--line);
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:16px; transition:background var(--ease);
  flex-shrink:0;
}
.nav__theme-toggle:hover { background:var(--gold-pale); border-color:var(--gold); }
.icon-sun  { display:none; }
.icon-moon { display:block; }
[data-theme="dark"] .icon-sun  { display:block; }
[data-theme="dark"] .icon-moon { display:none; }

/* Burger */
.nav__burger {
  display:none; background:none; border:none; cursor:pointer;
  flex-direction:column; gap:5px; padding:6px;
}
.nav__burger span {
  display:block; width:24px; height:2px;
  background:var(--ink); transition:all 0.3s; border-radius:1px;
}
.nav__burger[aria-expanded="true"] span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav__burger[aria-expanded="true"] span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu */
.nav__mobile {
  display:none; position:fixed;
  top:var(--nav-h); left:0; right:0; z-index:199;
  background:var(--nav-bg); backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
  padding:24px 32px 32px;
  transform:translateY(-110%); opacity:0;
  transition:transform 0.3s ease, opacity 0.3s ease;
  pointer-events:none;
}
.nav__mobile.open {
  transform:translateY(0); opacity:1; pointer-events:auto;
}
.nav__mobile li a {
  display:block; padding:13px 0; font-size:17px; font-weight:500;
  color:var(--ink); border-bottom:1px solid var(--line);
  transition:color var(--ease);
}
.nav__mobile li a:hover { color:var(--gold); }
.nav__mobile-cta {
  display:block; margin-top:20px; padding:14px;
  background:var(--blue-mid); color:#fff;
  text-align:center; font-size:14px; letter-spacing:0.05em; font-weight:500;
  transition:background var(--ease);
}
.nav__mobile-cta:hover { background:var(--gold); color:var(--ink); }

/* ── 8. BUTTONS ───────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:'DM Sans',sans-serif; font-size:14px; font-weight:500;
  letter-spacing:0.05em; padding:14px 32px; cursor:pointer; border:none;
  transition:background var(--ease), color var(--ease), transform var(--ease);
  text-decoration:none; line-height:1;
}
.btn:hover { transform:translateY(-2px); }
.btn--primary { background:var(--blue-mid); color:#fff; }
.btn--primary:hover { background:var(--gold); color:var(--ink); }
.btn--gold    { background:var(--gold); color:var(--ink); }
.btn--gold:hover { background:#fff; color:var(--ink); }
.btn--outline { background:transparent; color:var(--ink); border:1px solid var(--line); }
.btn--outline:hover { border-color:var(--gold); color:var(--gold); }
.btn--ghost   {
  background:transparent; padding:0; border-radius:0;
  color:var(--muted); border-bottom:1px solid var(--line);
  font-size:13px; letter-spacing:0.06em;
}
.btn--ghost:hover { color:var(--gold); border-color:var(--gold); transform:none; }
.btn--sm   { padding:10px 22px; font-size:13px; }
.btn--full { width:100%; justify-content:center; }
.nav__cta  { background:var(--blue-mid); color:#fff !important; }
.nav__cta:hover { background:var(--gold) !important; color:var(--ink) !important; }

/* ── 9. SECTIONS ──────────────────────────────────────────────── */
.section     { padding:100px 0; }
.section--sm { padding:60px 0; }
.section--lg { padding:140px 0; }
.section--alt  { background:var(--bg-alt); }
.section--dark {
  background:linear-gradient(135deg,var(--hero-start) 0%,var(--hero-end) 100%);
  position:relative; overflow:hidden;
}
.section--dark::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 60% at 90% 20%, rgba(201,168,76,0.1) 0%, transparent 60%);
  pointer-events:none;
}
.section--dark .feature-item__name  { color:#fff; }
.section--dark .feature-item__desc  { color:rgba(255,255,255,0.5); }
.section--dark .feature-item        { border-top-color:rgba(255,255,255,0.1); }
.section--border-top { border-top:1px solid var(--line); }

/* ── 10. GRIDS ────────────────────────────────────────────────── */
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--gap); }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); }

/* ── 11. DIVIDER ──────────────────────────────────────────────── */
.divider { display:flex; align-items:center; gap:24px; }
.divider hr { flex:1; border:none; border-top:1px solid var(--line); }
.divider__label {
  font-size:11px; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--muted); white-space:nowrap;
}
.divider--padded { margin:40px 0 0; }

/* ── 12. PAGE HEADER ──────────────────────────────────────────── */
.page-header {
  padding:calc(var(--nav-h) + 80px) 0 80px;
  background:linear-gradient(135deg,var(--hero-start) 0%,var(--hero-end) 100%);
  position:relative; overflow:hidden;
}
.page-header::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 60% at 80% 50%, rgba(201,168,76,0.1) 0%, transparent 60%);
}
.page-header__grid {
  position:absolute; inset:0; opacity:0.03;
  background-image:
    linear-gradient(rgba(255,255,255,0.5) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.5) 1px,transparent 1px);
  background-size:60px 60px;
}
.page-header .container { position:relative; z-index:2; }
.breadcrumb {
  font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:rgba(255,255,255,0.4); margin-bottom:24px;
}
.breadcrumb a { color:var(--gold); }
.breadcrumb a:hover { text-decoration:underline; }
.page-header__title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(40px,5.5vw,70px);
  font-weight:300; line-height:1.08; color:#fff; max-width:740px;
}
.page-header__title em { font-style:italic; color:var(--gold); font-weight:600; }
.page-header__sub  { font-size:17px; color:rgba(255,255,255,0.6); margin-top:18px; max-width:500px; line-height:1.72; }
.page-header__meta { font-size:13px; color:rgba(255,255,255,0.38); margin-top:14px; }

/* ── 13. HERO (index only) ────────────────────────────────────── */
.hero {
  /* Full viewport, always dark navy — independent of body theme */
  width:100%;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:calc(var(--nav-h) + 60px) 0 160px; /* bottom padding makes room for abs-positioned stats */
  background:#0d2b6b;
  background:linear-gradient(135deg,#0d2b6b 0%,#0a2258 55%,#0d2b6b 100%);
  position:relative;
  overflow:hidden;
  /* Ensure it's never overridden by dark-mode body bg */
  isolation:isolate;
}

/* Radial colour blobs */
.hero__overlay {
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 70% 60% at 75% 40%, rgba(201,168,76,.13) 0%, transparent 65%),
    radial-gradient(ellipse 50% 70% at 10% 90%, rgba(46,110,230,.18) 0%, transparent 50%);
}

/* Subtle grid lines */
.hero__grid {
  position:absolute; inset:0; opacity:.035; pointer-events:none; z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.5) 1px, transparent 1px);
  background-size:60px 60px;
}

/* Main text block */
.hero__content {
  position:relative;
  z-index:2;
  width:100%;
}

.hero__eyebrow {
  display:block;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin-bottom:28px; font-weight:600;
}

.hero__title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(46px,6.5vw,88px);
  font-weight:300; line-height:1.06;
  color:#ffffff;
  max-width:820px; margin-bottom:28px;
}
.hero__title em { font-style:italic; color:var(--gold); font-weight:700; }

.hero__sub {
  font-size:17px; line-height:1.75;
  color:rgba(255,255,255,.65);
  max-width:520px; margin-bottom:52px;
}

.hero__actions {
  display:flex; gap:20px; align-items:center; flex-wrap:wrap;
}

.hero__ghost-btn {
  color:rgba(255,255,255,.75); font-size:14px; font-weight:500;
  letter-spacing:0.04em;
  border-bottom:1px solid rgba(255,255,255,.3); padding-bottom:2px;
  transition:color var(--ease), border-color var(--ease);
}
.hero__ghost-btn:hover { color:var(--gold); border-color:var(--gold); }

/* Stats — pinned bottom-right */
.hero__stats {
  position:absolute; right:64px; bottom:80px; z-index:2;
  display:flex; flex-direction:column; gap:28px; text-align:right;
}
.hero__stat-num {
  font-family:'Cormorant Garamond',serif;
  font-size:44px; font-weight:600; line-height:1; color:#ffffff;
}
.hero__stat-num em  { color:var(--gold); font-style:normal; }
.hero__stat-label   { font-size:12px; color:rgba(255,255,255,.4); letter-spacing:.08em; margin-top:4px; }

/* Scroll hint — pinned bottom-left */
.hero__scroll {
  position:absolute; bottom:40px; left:64px; z-index:2;
  display:flex; align-items:center; gap:12px;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.35);
}
.hero__scroll-line { width:48px; height:1px; background:rgba(255,255,255,.25); }

/* ── 14. STAT BLOCK ───────────────────────────────────────────── */
.stat-grid  { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); }
.stat-item  {
  background:var(--bg-alt); padding:32px 28px;
  border-top:3px solid transparent;
  transition:border-color var(--ease), background var(--ease);
}
.stat-item:hover { border-top-color:var(--gold); }
.stat-item__num  {
  font-family:'Cormorant Garamond',serif;
  font-size:52px; font-weight:600; line-height:1; color:var(--blue-dark);
  transition:color var(--ease);
}
[data-theme="dark"] .stat-item__num { color:var(--gold); }
.stat-item__num em    { color:var(--gold); font-style:normal; }
.stat-item__num--city { font-size:34px; line-height:1.4; }
.stat-item__label     { font-size:13px; color:var(--muted); margin-top:8px; line-height:1.45; }

/* ── 15. CARD ─────────────────────────────────────────────────── */
.card {
  background:var(--bg-card); border:1px solid var(--line);
  padding:40px; position:relative; overflow:hidden;
  transition:transform var(--ease), box-shadow var(--ease), border-color var(--ease);
}
.card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform 0.4s;
}
.card:hover::before { transform:scaleX(1); }
.card:hover {
  transform:translateY(-5px);
  box-shadow:0 16px 48px rgba(13,43,107,0.1); border-color:rgba(201,168,76,.3);
}
[data-theme="dark"] .card:hover { box-shadow:0 16px 48px rgba(0,0,0,.4); }

.card__img-wrap { height:180px; margin:-40px -40px 28px; overflow:hidden; }
.card__img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s; }
.card:hover .card__img-wrap img { transform:scale(1.04); }

.card__eyebrow {
  font-size:11px; letter-spacing:0.1em; text-transform:uppercase;
  color:var(--gold); font-weight:600; margin-bottom:10px;
  font-family:'Cormorant Garamond',serif;
}
.card__title  { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.card__domain { font-size:12px; color:var(--gold); letter-spacing:0.06em; margin-bottom:16px; }
.card__body   { font-size:14px; line-height:1.78; color:var(--muted); margin-bottom:28px; }
.card__link   {
  font-size:13px; font-weight:500; letter-spacing:0.05em; color:var(--blue-mid);
  display:inline-flex; align-items:center; gap:6px;
  border-bottom:1px solid rgba(26,77,184,.25); padding-bottom:2px;
  transition:color var(--ease), border-color var(--ease);
}
.card__link:hover { color:var(--gold); border-color:var(--gold); }
[data-theme="dark"] .card__link { color:var(--gold); border-color:rgba(201,168,76,.3); }

/* ── 16. FEATURES / VALUES ────────────────────────────────────── */
.features-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--gap); }
.feature-item  {
  padding:40px 32px;
  background:rgba(255,255,255,0.03);
  border-top:1px solid var(--line);
  transition:background var(--ease);
}
.feature-item:hover { background:rgba(201,168,76,0.04); }
.feature-item__num  {
  font-family:'Cormorant Garamond',serif;
  font-size:52px; font-weight:300; color:var(--gold);
  opacity:0.35; line-height:1; margin-bottom:20px;
}
.feature-item__name { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:600; margin-bottom:12px; color:var(--ink); }
.feature-item__desc { font-size:14px; line-height:1.72; color:var(--muted); }

/* ── 17. IMAGE + OVERLAY ──────────────────────────────────────── */
.img-card         { position:relative; overflow:hidden; }
.img-card img     { width:100%; height:100%; object-fit:cover; transition:transform 0.6s; }
.img-card:hover img { transform:scale(1.04); }
.img-card__overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(13,43,107,.85) 0%, transparent 55%);
}
.img-card__label  { position:absolute; bottom:0; left:0; right:0; padding:24px; }
.img-card__label h3 {
  font-family:'Cormorant Garamond',serif; font-size:20px;
  font-weight:600; color:#fff; margin-bottom:4px;
}
.img-card__label p { font-size:12px; color:rgba(255,255,255,.6); letter-spacing:0.05em; }
.img-card--tall   { height:280px; }

/* ── 18. ABOUT — group intro image ───────────────────────────── */
.about-img { height:460px; overflow:hidden; }
.about-img img { width:100%; height:100%; object-fit:cover; }

/* ── 19. TIMELINE ─────────────────────────────────────────────── */
.timeline      { position:relative; padding-left:40px; margin-top:48px; }
.timeline::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:linear-gradient(to bottom,var(--blue-mid),var(--gold));
}
.timeline__item { position:relative; padding-bottom:48px; }
.timeline__item::before {
  content:''; position:absolute; left:-45px; top:5px;
  width:12px; height:12px; background:var(--gold); border-radius:50%;
  border:2px solid var(--bg); box-shadow:0 0 0 3px rgba(201,168,76,.25);
}
.timeline__year  { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--blue-mid); font-weight:600; margin-bottom:8px; }
[data-theme="dark"] .timeline__year { color:var(--gold); }
.timeline__title { font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:600; color:var(--ink); margin-bottom:10px; }
.timeline__desc  { font-size:14px; line-height:1.75; color:var(--muted); max-width:580px; }

/* ── 20. SUBSIDIARY DETAIL ────────────────────────────────────── */
.sub-detail {
  display:grid; grid-template-columns:260px 1fr;
  gap:80px; padding:60px 0; border-top:1px solid var(--line); align-items:start;
}
.sub-detail:last-child { border-bottom:1px solid var(--line); }
.sub-left     { position:sticky; top:calc(var(--nav-h) + 20px); }
.sub-logo-box {
  width:80px; height:80px; margin-bottom:20px;
  background:linear-gradient(135deg,var(--blue-dark),var(--blue-mid));
  display:flex; align-items:center; justify-content:center;
  font-size:32px; box-shadow:0 8px 24px rgba(13,43,107,.2);
}
.sub-name     { font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:700; color:var(--ink); margin-bottom:6px; }
.sub-url      { font-size:13px; color:var(--gold); letter-spacing:.06em; font-weight:500; }
.sub-url:hover { text-decoration:underline; }
.sub-right h3 { font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:600; color:var(--ink); margin-bottom:16px; }
.sub-right p  { font-size:15px; line-height:1.82; color:var(--muted); margin-bottom:16px; }
.sub-tags     { display:flex; flex-wrap:wrap; gap:10px; margin:24px 0 32px; }
.sub-tag {
  font-size:12px; letter-spacing:.05em; text-transform:uppercase; font-weight:500;
  padding:8px 16px; background:var(--bg-alt); color:var(--blue-dark);
  border:1px solid var(--line);
  transition:background var(--ease), color var(--ease), border-color var(--ease);
}
.sub-tag:hover { background:var(--gold-pale); border-color:var(--gold); }
[data-theme="dark"] .sub-tag { color:var(--muted); }
.sub-actions  { display:flex; align-items:center; gap:20px; flex-wrap:wrap; }

/* ── 21. HIGHLIGHT BOX ────────────────────────────────────────── */
.highlight-box {
  background:var(--gold-pale); padding:20px 24px;
  border-left:4px solid var(--gold); margin:20px 0;
}
.highlight-box p { color:var(--ink); font-size:14px; line-height:1.72; margin:0; }

/* ── 22. CONTACT BLOCK ────────────────────────────────────────── */
.contact-block {
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:40px;
}
.contact-block__email {
  font-family:'Cormorant Garamond',serif; font-size:22px; color:var(--blue-mid);
  transition:color var(--ease);
}
.contact-block__email:hover { color:var(--gold); }
.contact-block__actions { display:flex; flex-direction:column; gap:16px; align-items:flex-end; }

/* ── 23. LEGAL LAYOUT ─────────────────────────────────────────── */
.legal-layout {
  display:grid; grid-template-columns:240px 1fr;
  max-width:1100px; margin:0 auto;
  padding:80px 64px; gap:80px; align-items:start;
}
.legal-toc { position:sticky; top:calc(var(--nav-h) + 20px); }
.toc-title { font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:500; color:var(--muted); margin-bottom:20px; }
.toc-list  { display:flex; flex-direction:column; gap:2px; }
.toc-list a {
  display:block; font-size:13px; color:var(--muted); padding:8px 12px;
  border-left:2px solid transparent; transition:color var(--ease), border-color var(--ease);
}
.toc-list a:hover,
.toc-list a.active { color:var(--blue-mid); border-color:var(--gold); }
[data-theme="dark"] .toc-list a:hover,
[data-theme="dark"] .toc-list a.active { color:var(--gold); }

.legal-content h2 {
  font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:600;
  color:var(--ink); margin:48px 0 16px; padding-top:20px;
}
.legal-content h2:first-child { margin-top:0; }
.legal-content h3 { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:600; color:var(--ink); margin:28px 0 12px; }
.legal-content p  { font-size:15px; line-height:1.85; color:var(--muted); margin-bottom:16px; }
.legal-content ul,
.legal-content ol { padding-left:24px; margin-bottom:16px; }
.legal-content li { font-size:15px; line-height:1.8; color:var(--muted); margin-bottom:8px; }
.legal-content a  { color:var(--blue-mid); }
.legal-content a:hover { color:var(--gold); text-decoration:underline; }
[data-theme="dark"] .legal-content a { color:var(--gold); }
.legal-divider { border:none; border-top:1px solid var(--line); margin:40px 0; }

.data-table { width:100%; border-collapse:collapse; margin:20px 0; }
.data-table th {
  font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  font-weight:600; color:#fff; text-align:left;
  padding:12px 16px; background:var(--blue-mid);
}
.data-table td {
  font-size:14px; color:var(--muted); padding:12px 16px;
  border-bottom:1px solid var(--line); vertical-align:top; line-height:1.6;
}
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:nth-child(even) td { background:var(--bg-alt); }

/* ── 24. FOOTER ───────────────────────────────────────────────── */
.footer            { background:var(--footer-bg); color:rgba(255,255,255,.5); padding:64px 0 0; }
.footer__inner     { display:flex; justify-content:space-between; align-items:flex-start; padding-bottom:48px; }
.footer__brand-col { max-width:280px; }
.footer__brand     {
  display:flex; align-items:center; gap:10px; margin-bottom:12px;
  font-family:'Cormorant Garamond',serif; font-size:28px;
  font-weight:700; color:#fff;
}
.footer__brand img { width:36px; height:36px; object-fit:contain; }
.footer__brand em  { color:var(--gold); font-style:normal; }
.footer__tagline   { font-size:13px; color:rgba(255,255,255,.35); line-height:1.65; margin-bottom:20px; }
.footer__address   { font-size:13px; line-height:1.8; }
.footer__address a { color:var(--gold); transition:opacity var(--ease); }
.footer__address a:hover { opacity:.8; }
.footer__address span { color:rgba(255,255,255,.35); }
.footer__cols      { display:flex; gap:72px; }
.footer__col h3    { font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.7); font-weight:500; margin-bottom:20px; font-family:'DM Sans',sans-serif; }
.footer__col li    { margin-bottom:10px; }
.footer__col a     { color:rgba(255,255,255,.4); font-size:13px; transition:color var(--ease); }
.footer__col a:hover { color:var(--gold); }
.footer__bottom    { display:flex; justify-content:space-between; align-items:center; padding:20px 0; border-top:1px solid rgba(255,255,255,.08); font-size:13px; }
.footer__legal     { display:flex; gap:24px; }
.footer__legal a   { color:rgba(255,255,255,.3); font-size:12px; transition:color var(--ease); }
.footer__legal a:hover { color:var(--gold); }

/* ── 25. ANIMATE ON SCROLL ────────────────────────────────────── */
.aos {
  opacity:0; transform:translateY(28px);
  transition:opacity 0.7s ease, transform 0.7s ease;
}
.aos.visible { opacity:1; transform:translateY(0); }
.aos--left  { transform:translateX(-28px); }
.aos--left.visible  { transform:translateX(0); }
.aos--right { transform:translateX(28px); }
.aos--right.visible { transform:translateX(0); }
.delay-1 { transition-delay:0.1s; }
.delay-2 { transition-delay:0.2s; }
.delay-3 { transition-delay:0.3s; }
.delay-4 { transition-delay:0.4s; }

/* ── 26. SECTIONS HEADER ROW ──────────────────────────────────── */
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:56px; flex-wrap:wrap; gap:20px; }

/* ── 27. TOAST ────────────────────────────────────────────────── */
.toast {
  position:fixed; bottom:32px; right:32px; z-index:9999;
  background:var(--blue-dark); color:#fff;
  padding:16px 24px; border-left:4px solid var(--gold);
  font-size:14px; max-width:320px; line-height:1.5;
  box-shadow:0 8px 32px rgba(0,0,0,.2);
  transform:translateY(100px); opacity:0;
  transition:transform 0.3s, opacity 0.3s;
}
.toast.show { transform:translateY(0); opacity:1; }

/* ── 28. RESPONSIVE ───────────────────────────────────────────── */
@media (max-width:1100px) {
  .container { padding:0 40px; }
  .legal-layout { padding:60px 40px; }
}

@media (max-width:900px) {
  :root { --nav-h:64px; }
  .nav  { padding:0 24px; }
  .nav__links, .nav__actions .nav__cta { display:none; }
  .nav__actions { gap:8px; }
  .nav__burger  { display:flex; }
  .nav__mobile  { display:block; }

  .container    { padding:0 24px; }

  .grid-2       { grid-template-columns:1fr; gap:40px; }
  .grid-3,
  .grid-4       { grid-template-columns:1fr; }
  .stat-grid    { grid-template-columns:1fr 1fr; }
  .features-grid { grid-template-columns:1fr 1fr; }

  .section      { padding:60px 0; }
  .section--lg  { padding:80px 0; }
  .page-header  { padding:calc(var(--nav-h) + 40px) 0 52px; }

  .hero__stats  { display:none; }
  .hero__scroll { display:none; }

  .about-img    { height:300px; }

  .sub-detail   { grid-template-columns:1fr; gap:32px; }
  .sub-left     { position:static; }

  .contact-block { flex-direction:column; align-items:flex-start; }
  .contact-block__actions { align-items:flex-start; }

  .legal-layout { grid-template-columns:1fr; padding:48px 24px; gap:40px; }
  .legal-toc    { display:none; }

  .footer       { padding:48px 0 0; }
  .footer__inner { flex-direction:column; gap:40px; }
  .footer__cols  { flex-direction:column; gap:32px; }
  .footer__bottom { flex-direction:column; gap:16px; text-align:center; }
}

@media (max-width:600px) {
  .stat-grid    { grid-template-columns:1fr; }
  .features-grid { grid-template-columns:1fr; }
  .hero__actions { flex-direction:column; align-items:flex-start; }
  .section-header { flex-direction:column; align-items:flex-start; }
}

/* ── 29. PRINT ────────────────────────────────────────────────── */
@media print {
  .nav, .nav__mobile, .footer, .skip-link, .btn, .nav__burger, .nav__theme-toggle { display:none !important; }
  body { background:#fff; color:#000; }
  a::after { content:" (" attr(href) ")"; font-size:0.8em; }
}

/* ── 30. UTILITIES (generated from PHP page needs) ────────────── */
.divider--spaced    { margin-bottom:52px; }
.section--divider-top { padding:56px 0 0; }
.section--centered  { text-align:center; }
.section--centered .section-body { margin-bottom:32px; }
.section--centered .btn-group {
  display:flex; gap:16px; justify-content:center; flex-wrap:wrap;
}