:root {
  --ink: #122333;
  --ink-soft: #3e5364;
  --paper: #fffdf8;
  --surface: #ffffff;
  --surface-alt: #eef8f6;
  --teal: #087f72;
  --teal-dark: #05675e;
  --gold: #f2b544;
  --coral: #e36a52;
  --line: #d9e3e5;
  --shadow: 0 16px 50px rgba(18, 35, 51, 0.11);
  --radius: 24px;
  --max: 1180px;
}

* { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  background: var(--paper);
}

body {
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 10% 8%, rgba(242,181,68,.16), transparent 28rem),
    radial-gradient(circle at 92% 16%, rgba(8,127,114,.14), transparent 30rem),
    var(--paper);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
}

img, svg { max-width: 100%; }
a { color: inherit; }
button, input, textarea, select { font: inherit; }

.skip-link {
  position: fixed;
  left: 1rem;
  top: -5rem;
  z-index: 9999;
  padding: .75rem 1rem;
  border-radius: .7rem;
  background: var(--ink);
  color: #fff;
  text-decoration: none;
}
.skip-link:focus { top: 1rem; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  border-bottom: 1px solid rgba(217,227,229,.8);
  background: rgba(255,253,248,.9);
  backdrop-filter: blur(14px);
}

.nav-wrap {
  width: min(calc(100% - 2rem), var(--max));
  margin: 0 auto;
  min-height: 76px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: .8rem;
  font-weight: 900;
  text-decoration: none;
  letter-spacing: -.03em;
  font-size: 1.22rem;
}

.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: var(--ink);
  color: #fff;
  box-shadow: 0 8px 24px rgba(18,35,51,.18);
}

.brand-mark svg { width: 26px; height: 26px; }

.site-nav {
  display: flex;
  align-items: center;
  gap: .35rem;
}

.site-nav a,
.lang-toggle,
.menu-toggle {
  border: 0;
  background: transparent;
  border-radius: 999px;
  padding: .65rem .9rem;
  color: var(--ink-soft);
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
}

.site-nav a:hover,
.site-nav a:focus-visible,
.lang-toggle:hover,
.lang-toggle:focus-visible,
.menu-toggle:hover,
.menu-toggle:focus-visible {
  background: #fff;
  color: var(--ink);
  outline: 3px solid rgba(8,127,114,.18);
}

.site-nav a[aria-current="page"] {
  color: var(--teal-dark);
  background: rgba(8,127,114,.09);
}

.lang-toggle {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
}

.menu-toggle { display: none; }

main { overflow: hidden; }

.container {
  width: min(calc(100% - 2rem), var(--max));
  margin: 0 auto;
}

.hero {
  padding: clamp(4.5rem, 8vw, 8rem) 0 4.5rem;
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.12fr .88fr;
  align-items: center;
  gap: clamp(2rem, 6vw, 5.5rem);
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin: 0 0 1rem;
  border-radius: 999px;
  padding: .45rem .75rem;
  background: rgba(8,127,114,.1);
  color: var(--teal-dark);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .77rem;
}

.eyebrow::before {
  content: "";
  width: .55rem;
  height: .55rem;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 6px rgba(242,181,68,.18);
}

h1, h2, h3 {
  margin-top: 0;
  line-height: 1.08;
  letter-spacing: -.04em;
}

h1 {
  margin-bottom: 1.3rem;
  font-size: clamp(3rem, 7vw, 6.7rem);
  max-width: 12ch;
}

h2 {
  margin-bottom: 1rem;
  font-size: clamp(2.1rem, 4.6vw, 4.1rem);
  max-width: 14ch;
}

h3 { font-size: clamp(1.35rem, 2.1vw, 1.8rem); }

.hero .lead,
.section-intro,
.page-hero p {
  max-width: 66ch;
  color: var(--ink-soft);
  font-size: clamp(1.08rem, 1.7vw, 1.35rem);
}

.hero-actions,
.card-actions,
.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  margin-top: 1.75rem;
}

.button {
  min-height: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  border-radius: 999px;
  padding: .78rem 1.15rem;
  border: 2px solid transparent;
  background: var(--teal);
  color: #fff;
  font-weight: 900;
  text-decoration: none;
  box-shadow: 0 9px 24px rgba(8,127,114,.22);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.button:hover,
.button:focus-visible {
  transform: translateY(-2px);
  background: var(--teal-dark);
  box-shadow: 0 13px 30px rgba(8,127,114,.28);
  outline: 3px solid rgba(8,127,114,.19);
}

.button.secondary {
  background: #fff;
  color: var(--ink);
  border-color: var(--line);
  box-shadow: none;
}

.button.secondary:hover,
.button.secondary:focus-visible { border-color: var(--teal); }

.button.gold {
  background: var(--gold);
  color: #2b210f;
  box-shadow: 0 9px 24px rgba(242,181,68,.25);
}

.hero-visual {
  min-height: 480px;
  position: relative;
  display: grid;
  place-items: center;
}

.visual-orbit {
  position: relative;
  width: min(100%, 500px);
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, #fff 0 27%, transparent 28%),
    conic-gradient(from 45deg, rgba(8,127,114,.12), rgba(242,181,68,.22), rgba(227,106,82,.13), rgba(8,127,114,.12));
  border: 1px solid rgba(8,127,114,.12);
}

.visual-core {
  position: absolute;
  inset: 33%;
  border-radius: 34px;
  display: grid;
  place-items: center;
  text-align: center;
  background: var(--ink);
  color: #fff;
  box-shadow: var(--shadow);
  transform: rotate(-4deg);
}

.visual-core strong { font-size: clamp(1.4rem, 4vw, 2.1rem); line-height: 1.05; }
.visual-core span { display: block; color: #cfe7e4; font-size: .82rem; margin-top: .45rem; }

.float-card {
  position: absolute;
  width: min(220px, 45%);
  border-radius: 20px;
  padding: 1rem;
  background: rgba(255,255,255,.95);
  box-shadow: 0 18px 46px rgba(18,35,51,.15);
  border: 1px solid rgba(217,227,229,.85);
}
.float-card strong { display: block; line-height: 1.15; }
.float-card span { display: block; margin-top: .35rem; color: var(--ink-soft); font-size: .86rem; }
.float-card.one { top: 7%; left: 0; transform: rotate(-5deg); }
.float-card.two { top: 19%; right: -2%; transform: rotate(4deg); }
.float-card.three { left: 8%; bottom: 8%; transform: rotate(3deg); }
.float-card.four { right: 3%; bottom: 2%; transform: rotate(-4deg); }

.stat-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 3rem;
}
.stat {
  padding: 1.2rem;
  border-radius: 20px;
  background: rgba(255,255,255,.78);
  border: 1px solid var(--line);
}
.stat strong { display: block; font-size: 1.18rem; }
.stat span { color: var(--ink-soft); font-size: .92rem; }

.section {
  padding: clamp(4.5rem, 8vw, 7.5rem) 0;
}

.section.alt {
  background: linear-gradient(180deg, rgba(238,248,246,.88), rgba(255,255,255,.7));
  border-top: 1px solid rgba(217,227,229,.65);
  border-bottom: 1px solid rgba(217,227,229,.65);
}

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: 2rem;
}
.section-head p { max-width: 54ch; color: var(--ink-soft); }

.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.15rem;
}

.card {
  position: relative;
  min-height: 100%;
  border-radius: var(--radius);
  padding: 1.45rem;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.9);
  box-shadow: 0 8px 30px rgba(18,35,51,.06);
}
.card.featured { border-color: rgba(8,127,114,.42); box-shadow: var(--shadow); }
.card p { color: var(--ink-soft); }
.card ul { padding-left: 1.15rem; color: var(--ink-soft); }
.card li + li { margin-top: .45rem; }

.card-icon {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  margin-bottom: 1.25rem;
  border-radius: 18px;
  background: var(--surface-alt);
  color: var(--teal-dark);
  font-weight: 900;
  font-size: 1.25rem;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  margin-bottom: .8rem;
  padding: .28rem .55rem;
  border-radius: 999px;
  background: rgba(8,127,114,.1);
  color: var(--teal-dark);
  font-size: .78rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.badge.warm { background: rgba(242,181,68,.18); color: #6e4d0d; }
.badge.soft { background: rgba(227,106,82,.12); color: #8b3424; }

.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.quote-card {
  border-radius: 34px;
  padding: clamp(1.6rem, 4vw, 3.5rem);
  background: var(--ink);
  color: #fff;
  box-shadow: var(--shadow);
}
.quote-card p { font-size: clamp(1.45rem, 3vw, 2.5rem); line-height: 1.22; letter-spacing: -.03em; }
.quote-card small { color: #bcd5d2; }

.check-list {
  display: grid;
  gap: .85rem;
  padding: 0;
  list-style: none;
}
.check-list li {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: .75rem;
  align-items: start;
}
.check-list li::before {
  content: "✓";
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(8,127,114,.12);
  color: var(--teal-dark);
  font-weight: 900;
}

.cta-panel {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
  border-radius: 34px;
  padding: clamp(1.7rem, 5vw, 4rem);
  background: linear-gradient(135deg, var(--teal-dark), var(--teal));
  color: #fff;
  box-shadow: var(--shadow);
}
.cta-panel h2 { margin-bottom: .6rem; }
.cta-panel p { color: #d6efeb; max-width: 55ch; }
.cta-panel .button { background: #fff; color: var(--ink); box-shadow: none; }

.page-hero {
  padding: clamp(4rem, 8vw, 7rem) 0 3.2rem;
}
.page-hero h1 { max-width: 13ch; font-size: clamp(3rem, 6vw, 5.6rem); }

.project-stack {
  display: grid;
  gap: 1.25rem;
}
.project-row {
  display: grid;
  grid-template-columns: .8fr 1.2fr;
  gap: 2rem;
  padding: clamp(1.4rem, 4vw, 2.5rem);
  border-radius: 28px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 10px 30px rgba(18,35,51,.05);
}
.project-row:nth-child(even) { background: var(--surface-alt); }
.project-row p { color: var(--ink-soft); }

.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
}
.contact-card {
  border-radius: 28px;
  padding: clamp(1.5rem, 4vw, 2.5rem);
  background: #fff;
  border: 1px solid var(--line);
}
.contact-card.primary { background: var(--ink); color: #fff; }
.contact-card.primary p { color: #c8dedb; }
.contact-list {
  display: grid;
  gap: .8rem;
  margin-top: 1.4rem;
}
.contact-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  text-decoration: none;
  font-weight: 850;
}
.contact-list a:hover,
.contact-list a:focus-visible { background: rgba(255,255,255,.14); outline: 3px solid rgba(255,255,255,.2); }

.legal-copy {
  max-width: 820px;
  padding-bottom: 5rem;
}
.legal-copy h2 { font-size: 2rem; margin-top: 2.5rem; }
.legal-copy h3 { margin-top: 2rem; }
.notice {
  padding: 1rem 1.1rem;
  border-radius: 16px;
  background: #fff3cd;
  border: 1px solid #f3d37a;
  color: #5c4305;
}
.placeholder { background: #ffe5df; color: #842b1d; padding: .1rem .3rem; border-radius: .3rem; font-weight: 800; }

.site-footer {
  padding: 3rem 0 2rem;
  background: #0e1d29;
  color: #eaf2f3;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.25fr .75fr .75fr;
  gap: 2rem;
}
.site-footer p, .site-footer a { color: #b9cbd1; }
.site-footer a:hover, .site-footer a:focus-visible { color: #fff; }
.footer-links { display: grid; gap: .55rem; }
.footer-meta {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 2.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,.12);
  color: #95aab2;
  font-size: .9rem;
}

[data-lang="en"] .lang-es,
[data-lang="es"] .lang-en { display: none !important; }

@media (max-width: 900px) {
  .hero-grid,
  .two-col,
  .project-row,
  .contact-grid { grid-template-columns: 1fr; }
  .card-grid { grid-template-columns: 1fr 1fr; }
  .hero-visual { min-height: 430px; }
  .section-head { align-items: start; flex-direction: column; }
  .cta-panel { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 720px) {
  .menu-toggle { display: inline-flex; }
  .site-nav {
    position: absolute;
    left: 1rem;
    right: 1rem;
    top: 68px;
    display: none;
    align-items: stretch;
    flex-direction: column;
    padding: .75rem;
    border-radius: 20px;
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: var(--shadow);
  }
  .site-nav.open { display: flex; }
  .site-nav a, .lang-toggle { text-align: left; width: 100%; }
  .nav-actions { display: flex; align-items: center; gap: .35rem; }
  .hero { padding-top: 3.5rem; }
  .hero-grid { gap: 1.5rem; }
  .hero-visual { min-height: 360px; }
  .visual-orbit { width: 100%; }
  .float-card { font-size: .83rem; }
  .stat-strip,
  .card-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-meta { flex-direction: column; }
}

@media (max-width: 440px) {
  h1 { font-size: 2.75rem; }
  .hero-visual { min-height: 330px; }
  .float-card { width: 48%; padding: .75rem; }
  .float-card span { display: none; }
  .visual-core { inset: 31%; border-radius: 24px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    scroll-behavior: auto !important;
    transition: none !important;
    animation: none !important;
  }
}

/* ==========================================================
   SERVILINGUAL MODEL HOMEPAGE v2
   ========================================================== */
.model-home {
  --model-navy: #10283a;
  --model-navy-2: #17394f;
  --model-cream: #f7f2e8;
  --model-teal: #08a88a;
  --model-teal-dark: #087763;
  --model-gold: #f4bd4f;
  --model-coral: #ef735d;
  --model-blue: #5e83f2;
  --model-line: rgba(16, 40, 58, .14);
  --model-radius: 30px;
  background: var(--model-cream);
  color: var(--model-navy);
}
.model-home main { overflow: clip; }
.model-header { background: rgba(247, 242, 232, .91); border-color: rgba(16, 40, 58, .1); }
.model-nav-wrap { min-height: 82px; width: min(calc(100% - 2rem), 1320px); }
.model-home .brand-copy { display: grid; line-height: 1; gap: .28rem; }
.model-home .brand-copy strong { font-size: 1.19rem; }
.model-home .brand-copy small { color: var(--ink-soft); font-size: .62rem; letter-spacing: .08em; text-transform: uppercase; font-weight: 800; }
.model-home .brand-mark { background: var(--model-navy); }
.model-nav { gap: .15rem; }
.model-nav a, .model-nav .lang-toggle { font-size: .86rem; padding: .55rem .72rem; }
.model-nav .nav-portal { margin-left: .3rem; color: #fff; background: var(--model-navy); border-radius: 999px; padding: .65rem .9rem; display: inline-flex; gap: .4rem; }
.model-nav .nav-portal:hover, .model-nav .nav-portal:focus-visible { color: #fff; background: var(--model-teal-dark); }

.model-hero { position: relative; min-height: min(900px, calc(100vh - 82px)); padding: clamp(4.2rem, 7vw, 7.5rem) 0 0; background: var(--model-cream); isolation: isolate; }
.hero-noise { position: absolute; inset: 0; z-index: -2; opacity: .55; background-image: radial-gradient(rgba(16,40,58,.12) .7px, transparent .7px); background-size: 16px 16px; mask-image: linear-gradient(to bottom, #000, transparent 75%); }
.model-hero::before { content:""; position:absolute; width:52vw; height:52vw; max-width:760px; max-height:760px; border-radius:50%; right:-13vw; top:-20vw; background:radial-gradient(circle, rgba(8,168,138,.22), rgba(8,168,138,.08) 48%, transparent 71%); z-index:-1; }
.model-hero::after { content:""; position:absolute; width:42vw; height:42vw; max-width:620px; max-height:620px; border-radius:50%; left:-24vw; bottom:-24vw; background:radial-gradient(circle, rgba(244,189,79,.25), rgba(244,189,79,.08) 50%, transparent 72%); z-index:-1; }
.model-hero-grid { width:min(calc(100% - 2rem),1320px); display:grid; grid-template-columns: minmax(0,1.03fr) minmax(460px,.97fr); align-items:center; gap: clamp(2.5rem,6vw,7rem); padding-bottom:5.2rem; }
.model-kicker { display:inline-flex; align-items:center; gap:.7rem; margin:0 0 1.25rem; font-size:.78rem; font-weight:950; letter-spacing:.16em; text-transform:uppercase; }
.kicker-dot { width:10px; height:10px; border-radius:50%; background:var(--model-coral); box-shadow:0 0 0 7px rgba(239,115,93,.13); }
.model-hero h1 { max-width:11ch; font-size:clamp(4rem,8vw,8.2rem); margin:0 0 1.4rem; letter-spacing:-.07em; line-height:.88; }
.model-hero h1 em { color:var(--model-teal-dark); font-style:normal; position:relative; white-space:nowrap; }
.model-hero h1 em::after { content:""; position:absolute; left:2%; right:0; bottom:-.13em; height:.08em; border-radius:999px; background:var(--model-gold); transform:rotate(-1.2deg); }
.model-lead { max-width:58ch; margin:2rem 0 0; font-size:clamp(1.1rem,1.6vw,1.4rem); color:#425c6e; line-height:1.65; }
.model-actions { display:flex; flex-wrap:wrap; gap:.85rem; margin-top:2rem; }
.model-button { min-height:54px; padding:.82rem 1.18rem; display:inline-flex; align-items:center; justify-content:center; gap:.7rem; border-radius:999px; text-decoration:none; font-weight:900; transition:.2s ease; border:2px solid transparent; }
.model-button:hover,.model-button:focus-visible { transform:translateY(-3px); outline:none; }
.model-button.primary { background:var(--model-navy); color:#fff; box-shadow:0 15px 30px rgba(16,40,58,.2); }
.model-button.primary:hover { background:var(--model-teal-dark); box-shadow:0 18px 34px rgba(8,119,99,.24); }
.model-button.ghost { border-color:rgba(16,40,58,.18); background:rgba(255,255,255,.46); }
.model-button.ghost:hover { border-color:var(--model-navy); background:#fff; }
.hero-proof { display:flex; flex-wrap:wrap; gap:.65rem 1.1rem; margin-top:2.1rem; font-size:.84rem; color:#4e6576; font-weight:750; }
.hero-proof div { display:inline-flex; gap:.42rem; align-items:center; }
.proof-icon { display:grid; place-items:center; width:20px; height:20px; border-radius:50%; background:rgba(8,168,138,.14); color:var(--model-teal-dark); font-weight:950; }

.model-hero-stage { position:relative; min-height:580px; }
.stage-glow { position:absolute; inset:8% 4% 4% 6%; border-radius:50%; background:radial-gradient(circle, rgba(94,131,242,.25), rgba(8,168,138,.1) 40%, transparent 70%); filter:blur(12px); }
.stage-window { position:absolute; border:1px solid rgba(16,40,58,.13); background:rgba(255,255,255,.9); box-shadow:0 36px 100px rgba(16,40,58,.2); backdrop-filter:blur(14px); }
.main-window { width:78%; right:2%; top:13%; border-radius:30px; overflow:hidden; transform:rotate(2deg); }
.window-top { height:44px; padding:0 1rem; display:flex; align-items:center; gap:.38rem; border-bottom:1px solid rgba(16,40,58,.09); background:#fff; }
.window-top span { width:9px; height:9px; border-radius:50%; background:#dbe3e7; }
.window-top span:first-child { background:var(--model-coral); }.window-top span:nth-child(2){background:var(--model-gold)}.window-top span:nth-child(3){background:var(--model-teal)}
.window-top small { margin-left:auto; color:#718390; font-size:.67rem; font-weight:800; }
.window-body { padding:clamp(1.6rem,4vw,3.4rem); min-height:410px; background:linear-gradient(145deg,#fff 0 62%,#edf9f5 62%); }
.mini-label { display:inline-flex; border-radius:999px; padding:.35rem .62rem; background:rgba(8,168,138,.1); color:var(--model-teal-dark); font-size:.67rem; font-weight:950; letter-spacing:.1em; text-transform:uppercase; }
.mini-title { margin-top:1rem; font-size:clamp(2rem,4.3vw,3.8rem); font-weight:950; letter-spacing:-.06em; line-height:.92; }
.mini-path { display:grid; gap:.55rem; margin-top:2.1rem; max-width:300px; }
.mini-path div { display:grid; grid-template-columns:32px 1fr; align-items:center; gap:.5rem; padding:.55rem .65rem; border-radius:12px; background:rgba(255,255,255,.66); color:#6b7e8b; font-size:.76rem; font-weight:850; }
.mini-path .active { background:var(--model-navy); color:#fff; transform:translateX(12px); box-shadow:0 12px 24px rgba(16,40,58,.16); }
.mini-path b { color:var(--model-gold); }
.mini-wave { height:68px; display:flex; align-items:center; justify-content:flex-end; gap:5px; margin-top:1.2rem; }
.mini-wave i { display:block; width:5px; border-radius:99px; background:var(--model-teal); animation:wave 1.3s ease-in-out infinite; }
.mini-wave i:nth-child(1),.mini-wave i:nth-child(11){height:18px}.mini-wave i:nth-child(2),.mini-wave i:nth-child(10){height:28px}.mini-wave i:nth-child(3),.mini-wave i:nth-child(9){height:42px}.mini-wave i:nth-child(4),.mini-wave i:nth-child(8){height:22px}.mini-wave i:nth-child(5),.mini-wave i:nth-child(7){height:56px}.mini-wave i:nth-child(6){height:34px}
.mini-wave i:nth-child(2n){animation-delay:.12s}.mini-wave i:nth-child(3n){animation-delay:.24s}
@keyframes wave { 0%,100%{transform:scaleY(.55);opacity:.55}50%{transform:scaleY(1);opacity:1} }
.stage-card { position:absolute; z-index:2; display:grid; grid-template-columns:44px 1fr; grid-template-rows:auto auto; column-gap:.7rem; min-width:210px; padding:.9rem 1rem; border-radius:18px; background:#fff; border:1px solid rgba(16,40,58,.1); box-shadow:0 18px 42px rgba(16,40,58,.14); }
.stage-card>span { grid-row:1/3; width:44px; height:44px; display:grid; place-items:center; border-radius:14px; background:var(--model-cream); font-size:1.25rem; }
.stage-card strong { align-self:end; line-height:1.15; font-size:.88rem; }.stage-card small{color:#687b88;font-size:.7rem}
.stage-card.card-a { left:0; top:5%; transform:rotate(-6deg); }.stage-card.card-b { right:-2%; top:2%; transform:rotate(5deg); }.stage-card.card-c { left:5%; bottom:4%; transform:rotate(3deg); }
.stage-badge { position:absolute; right:4%; bottom:8%; z-index:3; display:inline-flex; align-items:center; gap:.5rem; padding:.55rem .75rem; border-radius:999px; background:var(--model-navy); color:#fff; font-size:.72rem; font-weight:900; box-shadow:0 13px 28px rgba(16,40,58,.22); }
.badge-pulse { width:8px; height:8px; border-radius:50%; background:#60e0b6; box-shadow:0 0 0 0 rgba(96,224,182,.45); animation:pulse 1.8s infinite; }
@keyframes pulse { 70%{box-shadow:0 0 0 9px rgba(96,224,182,0)}100%{box-shadow:0 0 0 0 rgba(96,224,182,0)} }
.hero-marquee { overflow:hidden; border-top:1px solid rgba(16,40,58,.1); border-bottom:1px solid rgba(16,40,58,.1); background:rgba(255,255,255,.46); }
.hero-marquee div { width:max-content; display:flex; align-items:center; gap:1.6rem; padding:.9rem 0; animation:marquee 38s linear infinite; color:#566d7b; font-size:.72rem; font-weight:950; letter-spacing:.13em; }
.hero-marquee i { color:var(--model-coral); font-style:normal; }
@keyframes marquee { to{transform:translateX(-35%)} }

.model-section { padding:clamp(5.5rem,9vw,9rem) 0; }
.model-section .container { width:min(calc(100% - 2rem),1320px); }
.model-section-head { display:grid; grid-template-columns:.4fr 1.6fr; gap:clamp(2rem,7vw,7rem); align-items:start; margin-bottom:3.5rem; }
.section-number { margin:0; font-size:.72rem; font-weight:950; letter-spacing:.14em; color:#647986; text-transform:uppercase; }
.section-number.light { color:rgba(255,255,255,.62); }
.model-section-head h2,.programmes-heading h2,.inclusion-copy h2,.organisation-copy h2,.support-copy h2,.contact-heading h2 { max-width:none; font-size:clamp(2.7rem,5.6vw,5.5rem); letter-spacing:-.06em; line-height:.96; }
.model-section-head p:not(.section-number) { max-width:62ch; color:#536a79; font-size:1.08rem; }
.audience-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.audience-card { position:relative; display:flex; flex-direction:column; min-height:530px; padding:clamp(1.5rem,3vw,2.4rem); border-radius:var(--model-radius); border:1px solid var(--model-line); overflow:hidden; transition:.25s ease; }
.audience-card:hover { transform:translateY(-7px); box-shadow:0 26px 65px rgba(16,40,58,.13); }
.audience-card::after { content:""; position:absolute; width:220px; height:220px; border-radius:50%; right:-110px; top:-110px; opacity:.2; }
.audience-card.family { background:#fff; }.audience-card.family::after{background:var(--model-gold)}
.audience-card.professional { background:#e9f8f3; }.audience-card.professional::after{background:var(--model-teal)}
.audience-card.organisation { background:#eaf0ff; }.audience-card.organisation::after{background:var(--model-blue)}
.audience-top { display:flex; justify-content:space-between; align-items:center; position:relative; z-index:1; }
.audience-icon { width:54px; height:54px; display:grid; place-items:center; border-radius:18px; background:rgba(255,255,255,.8); border:1px solid rgba(16,40,58,.09); font-size:1.4rem; font-weight:950; }
.audience-index { color:#6c7e8a; font-size:.72rem; font-weight:950; }
.audience-label { margin:2rem 0 .7rem; font-size:.69rem; letter-spacing:.14em; font-weight:950; }
.audience-card h3 { max-width:13ch; font-size:clamp(1.85rem,3vw,2.7rem); letter-spacing:-.05em; }
.audience-card>p:not(.audience-label) { color:#506777; }
.audience-card ul { list-style:none; padding:0; margin:1.4rem 0 2rem; display:grid; gap:.6rem; font-size:.88rem; font-weight:750; }
.audience-card li { display:flex; align-items:center; gap:.5rem; }.audience-card li::before{content:"+";color:var(--model-teal-dark);font-weight:950}
.text-link { margin-top:auto; display:inline-flex; justify-content:space-between; align-items:center; gap:1rem; padding-top:1rem; border-top:1px solid rgba(16,40,58,.12); text-decoration:none; font-weight:950; }

.programmes-section { background:var(--model-navy); color:#fff; }
.programmes-heading { display:flex; justify-content:space-between; gap:3rem; align-items:flex-start; margin-bottom:3.5rem; }
.programmes-heading h2 { margin:0; max-width:11ch; }.programmes-heading h2 em{font-style:normal;color:#79e0c6}
.programme-stack { border-top:1px solid rgba(255,255,255,.17); }
.programme-row { display:grid; grid-template-columns:42px 90px minmax(0,1fr) 64px; gap:clamp(1rem,3vw,2.2rem); align-items:center; padding:2.2rem 0; border-bottom:1px solid rgba(255,255,255,.17); }
.programme-number { color:rgba(255,255,255,.48); font-size:.72rem; font-weight:950; }
.programme-mark { width:82px; height:82px; border-radius:26px; display:grid; place-items:center; color:var(--model-navy); font-size:2.3rem; font-weight:950; transform:rotate(-4deg); }
.teal-mark{background:#79e0c6}.gold-mark{background:var(--model-gold);transform:rotate(4deg)}.coral-mark{background:#ff9c87}
.programme-content { display:grid; grid-template-columns:minmax(0,.85fr) minmax(280px,1.15fr); gap:.8rem 3rem; align-items:end; }
.programme-meta { grid-column:1/-1; display:flex; justify-content:space-between; gap:1rem; color:rgba(255,255,255,.55); font-size:.66rem; font-weight:950; letter-spacing:.12em; }
.status-dot { display:inline-flex; align-items:center; gap:.45rem; }.status-dot>span:first-child{width:7px;height:7px;border-radius:50%;background:var(--model-gold)}.status-dot.live>span:first-child{background:#79e0c6}
.programme-content h3 { margin:0; font-size:clamp(2rem,4vw,3.5rem); }
.programme-content p { margin:0; color:rgba(255,255,255,.7); max-width:62ch; }
.programme-tags { grid-column:1/-1; display:flex; flex-wrap:wrap; gap:.45rem; margin-top:.7rem; }.programme-tags>span{border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.32rem .55rem;font-size:.67rem;color:rgba(255,255,255,.7)}
.round-link { width:58px; height:58px; display:grid; place-items:center; border-radius:50%; border:1px solid rgba(255,255,255,.3); color:#fff; text-decoration:none; font-size:1.25rem; transition:.2s ease; }.round-link:hover{background:#fff;color:var(--model-navy);transform:rotate(8deg)}

.inclusion-section { background:#fff; }
.inclusion-grid { display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(3rem,8vw,8rem); align-items:center; }
.inclusion-copy h2 { margin:1.2rem 0; max-width:10ch; }.big-copy{color:#4f6675;font-size:clamp(1.1rem,1.6vw,1.35rem);max-width:52ch}.model-button.dark{background:var(--model-navy);color:#fff;margin-top:1.2rem}
.feature-lab { position:relative; padding:2.5rem 1.1rem 1rem; border-radius:34px; background:linear-gradient(145deg,#eef8f5,#e9efff); border:1px solid rgba(16,40,58,.1); min-height:500px; }
.lab-toolbar { position:absolute; top:0; left:0; right:0; height:48px; padding:0 1rem; display:flex; align-items:center; gap:.35rem; background:rgba(255,255,255,.68); border-bottom:1px solid rgba(16,40,58,.08); border-radius:34px 34px 0 0; }.lab-toolbar span{width:8px;height:8px;border-radius:50%;background:#d4dce0}.lab-toolbar b{margin-left:auto;font-size:.62rem;letter-spacing:.12em}
.lab-screen { margin:3.5rem 5% 1.2rem; padding:clamp(1.6rem,4vw,3rem); border-radius:28px; background:#fff; box-shadow:0 22px 55px rgba(16,40,58,.14); transform:rotate(-1deg); }
.lab-line { display:grid; gap:.25rem; font-size:clamp(1.7rem,3.2vw,3rem); letter-spacing:-.05em; line-height:1; }.lab-line span{color:var(--model-teal-dark)}
.lab-controls { display:flex; flex-wrap:wrap; gap:.45rem; margin:1.6rem 0; }.lab-controls button{border:1px solid rgba(16,40,58,.12);background:#f7f8f9;border-radius:999px;padding:.48rem .68rem;font-size:.68rem;font-weight:850;color:var(--model-navy)}
.lab-words { display:flex; flex-wrap:wrap; gap:.5rem; }.lab-words span{padding:.45rem .62rem;border-radius:10px;background:#edf8f5;color:var(--model-teal-dark);font-size:.74rem;font-weight:850}
.lab-progress { height:8px; border-radius:999px; background:#e5eaed; margin-top:2rem; overflow:hidden; }.lab-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--model-teal),var(--model-blue))}
.lab-footer { display:flex;justify-content:space-between;margin-top:.55rem;color:#6b7e8b}.lab-footer b{color:var(--model-navy)}
.lab-float { position:absolute; padding:.7rem .85rem; border-radius:15px; background:var(--model-navy); color:#fff; box-shadow:0 12px 28px rgba(16,40,58,.22); display:flex; align-items:center; gap:.5rem; font-size:.7rem; font-weight:900; }.lab-float b{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;background:rgba(255,255,255,.13)}.lab-float.one{left:0;top:24%;transform:rotate(-6deg)}.lab-float.two{right:-1%;top:14%;transform:rotate(5deg);background:var(--model-teal-dark)}.lab-float.three{right:2%;bottom:5%;transform:rotate(-3deg);background:var(--model-coral)}
.feature-grid { margin-top:5rem; display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }.feature-tile{padding:1.5rem;border-top:2px solid var(--model-navy);background:#f9f7f1;min-height:230px}.feature-tile>span{font-size:.7rem;font-weight:950;color:#7a8993}.feature-tile h3{margin:2rem 0 .7rem;font-size:1.35rem}.feature-tile p{color:#5a6e7b;font-size:.9rem}

.organisations-panel { background:#0a1f2e; color:#fff; }
.organisation-split { display:grid; grid-template-columns:1fr 1fr; min-height:650px; border-radius:36px; overflow:hidden; background:var(--model-navy-2); border:1px solid rgba(255,255,255,.12); }
.organisation-visual { position:relative; min-height:650px; overflow:hidden; background:linear-gradient(145deg,#183b52,#0d2738); }
.org-grid-lines { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);background-size:42px 42px; }
.org-word { position:absolute; left:-.04em; bottom:.1em; font-size:clamp(5rem,11vw,10.5rem); line-height:.75; font-weight:950; letter-spacing:-.09em; color:rgba(255,255,255,.06); transform:rotate(-90deg) translateY(100%); transform-origin:left bottom; }
.org-chip { position:absolute; padding:.6rem .8rem; border-radius:999px; font-size:.7rem; font-weight:950; letter-spacing:.09em; color:var(--model-navy); box-shadow:0 15px 30px rgba(0,0,0,.18); }.org-chip.one{left:15%;top:18%;background:var(--model-gold);transform:rotate(-6deg)}.org-chip.two{right:12%;top:32%;background:#79e0c6;transform:rotate(5deg)}.org-chip.three{left:28%;bottom:28%;background:#ff9c87;transform:rotate(4deg)}.org-chip.four{right:20%;bottom:12%;background:#b8c9ff;transform:rotate(-4deg)}
.organisation-copy { padding:clamp(2.5rem,6vw,5.5rem); display:flex; flex-direction:column; justify-content:center; }.organisation-copy h2{margin:1.2rem 0;max-width:10ch}.organisation-copy>p:not(.section-number){color:rgba(255,255,255,.68);font-size:1.08rem;max-width:50ch}.org-points{margin:2rem 0;display:grid;gap:.75rem}.org-points div{display:grid;grid-template-columns:38px 1fr;gap:.7rem;padding:.65rem 0;border-bottom:1px solid rgba(255,255,255,.12)}.org-points b{color:var(--model-gold)}.model-button.light-button{align-self:flex-start;background:#fff;color:var(--model-navy)}

.community-section { background:var(--model-cream); }
.community-grid { display:grid; grid-template-columns:1.2fr .8fr; gap:1rem; }.story-card{border-radius:28px;padding:2rem;background:#fff;border:1px solid var(--model-line);min-height:280px}.story-card.wide{grid-row:span 2;display:grid;grid-template-rows:240px 1fr;padding:0;overflow:hidden}.story-visual{display:grid;place-items:center;background:linear-gradient(135deg,var(--model-teal-dark),var(--model-blue));position:relative;overflow:hidden}.story-visual::before{content:"";position:absolute;width:330px;height:330px;border:70px solid rgba(255,255,255,.09);border-radius:50%;}.story-visual span{font-size:8rem;color:rgba(255,255,255,.75);font-family:Georgia,serif;line-height:1;z-index:1}.story-copy{padding:2rem}.story-label{font-size:.67rem;font-weight:950;letter-spacing:.13em;color:var(--model-teal-dark)}.story-copy blockquote{margin:.7rem 0 1.2rem;font-size:clamp(1.3rem,2.4vw,2rem);font-weight:800;line-height:1.35;letter-spacing:-.03em}.story-copy cite{font-style:normal;color:#637784;font-size:.83rem}.story-number{font-size:clamp(4rem,8vw,7rem);font-weight:950;line-height:.8;color:var(--model-coral);letter-spacing:-.08em}.story-card h3{margin:1.8rem 0 .7rem;font-size:1.65rem}.story-card p{color:#586e7c}.story-card.accent{background:var(--model-gold)}.story-card.accent p{color:#463815}.story-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:rgba(16,40,58,.1);font-size:1.3rem}

.support-section { background:var(--model-navy); padding-top:2rem; }
.support-card { position:relative; display:grid; grid-template-columns:1.4fr .6fr; gap:3rem; align-items:center; padding:clamp(2rem,6vw,5.5rem); border-radius:40px; background:linear-gradient(135deg,#183a50,#0b2535); border:1px solid rgba(255,255,255,.12); color:#fff; overflow:hidden; }.support-card::after{content:"";position:absolute;width:480px;height:480px;border-radius:50%;right:-230px;top:-230px;background:radial-gradient(circle,rgba(244,189,79,.22),transparent 70%)}.support-spark{position:absolute;right:6%;top:8%;font-size:4rem;color:var(--model-gold);opacity:.55}.support-copy h2{margin:1.2rem 0;max-width:13ch}.support-copy>p:not(.section-number){max-width:60ch;color:rgba(255,255,255,.7);font-size:1.08rem}.support-actions{display:flex;flex-wrap:wrap;align-items:center;gap:1.2rem;margin-top:2rem}.model-button.gold-button{background:var(--model-gold);color:var(--model-navy)}.simple-link{color:#fff;text-underline-offset:4px;font-weight:850}.support-metric{position:relative;z-index:1;text-align:center}.metric-ring{width:min(280px,80vw);aspect-ratio:1;margin:auto;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(255,255,255,.2);background:radial-gradient(circle at 36% 30%,rgba(255,255,255,.13),rgba(255,255,255,.03));box-shadow:inset 0 0 0 24px rgba(255,255,255,.03)}.metric-ring strong{display:block;font-size:6rem;line-height:.8;color:var(--model-gold);letter-spacing:-.09em}.metric-ring span{display:block;margin-top:.6rem;font-weight:900}.support-metric p{max-width:30ch;margin:1rem auto 0;color:rgba(255,255,255,.67);font-size:.86rem}

.contact-section { background:#fff; }
.contact-grid { display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,8vw,8rem);align-items:start}.contact-heading h2{margin:1.2rem 0;max-width:10ch}.contact-heading>p:not(.section-number){font-size:1.08rem;color:#586e7c;max-width:48ch}.contact-panel{display:grid;border-top:1px solid var(--model-line)}.contact-panel a{display:grid;grid-template-columns:52px 1fr auto;align-items:center;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--model-line);text-decoration:none;transition:.2s ease}.contact-panel a:hover{padding-left:.65rem;color:var(--model-teal-dark)}.contact-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:var(--model-cream);font-weight:950}.contact-panel small{display:block;color:#6a7c88}.contact-panel strong{display:block;font-size:clamp(1rem,2vw,1.35rem)}

.model-footer { background:#081a27;color:#fff;padding:4rem 0 1.4rem }.model-footer .container{width:min(calc(100% - 2rem),1320px)}.footer-main{display:grid;grid-template-columns:1.4fr repeat(3,.7fr);gap:2.5rem}.model-footer .brand{color:#fff}.model-footer .brand-copy small{color:rgba(255,255,255,.56)}.footer-brand p{max-width:35ch;color:rgba(255,255,255,.6);margin-top:1.2rem}.footer-column{display:grid;align-content:start;gap:.6rem}.footer-column strong{margin-bottom:.5rem}.footer-column a{color:rgba(255,255,255,.63);text-decoration:none;font-size:.88rem}.footer-column a:hover{color:#fff}.footer-bottom{display:flex;justify-content:space-between;gap:1rem;margin-top:3.5rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);font-size:.78rem}

.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.mini-wave i,.badge-pulse,.hero-marquee div{animation:none}.model-button,.audience-card,.contact-panel a{transition:none}}

@media (max-width:1180px){
  .model-nav a:not(.nav-portal){display:none}.model-nav .lang-toggle{display:inline-flex}.model-nav .nav-portal{display:inline-flex}
  .model-hero-grid{grid-template-columns:1fr 1fr}.model-hero h1{font-size:clamp(4rem,7vw,6rem)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .model-home .menu-toggle{display:inline-flex}.model-nav{position:absolute;top:calc(100% + .5rem);left:1rem;right:1rem;display:none;flex-direction:column;align-items:stretch;padding:1rem;background:#fff;border:1px solid var(--model-line);border-radius:22px;box-shadow:0 22px 60px rgba(16,40,58,.18)}.model-nav.open{display:flex}.model-nav a:not(.nav-portal){display:flex}.model-nav .nav-portal{justify-content:center;margin:.35rem 0 0}.model-nav .lang-toggle{align-self:flex-start}
  .model-hero{min-height:auto}.model-hero-grid,.inclusion-grid,.organisation-split,.contact-grid{grid-template-columns:1fr}.model-hero-stage{min-height:530px;max-width:680px;width:100%;margin:auto}.model-hero h1{font-size:clamp(4rem,12vw,7.3rem)}
  .model-section-head{grid-template-columns:1fr;gap:1.1rem}.audience-grid{grid-template-columns:1fr}.audience-card{min-height:auto}.programme-content{grid-template-columns:1fr}.programme-content p{grid-column:1}.programmes-heading{display:grid}.programme-row{grid-template-columns:34px 72px 1fr 52px}.programme-mark{width:68px;height:68px}.organisation-visual{min-height:450px}.community-grid{grid-template-columns:1fr}.story-card.wide{grid-row:auto}.support-card{grid-template-columns:1fr}.support-metric{margin-top:1rem}.footer-main{grid-template-columns:1.3fr 1fr 1fr}.footer-brand{grid-column:1/-1}
}
@media (max-width:620px){
  .model-nav-wrap{min-height:72px}.model-home .brand-copy small{display:none}.model-hero{padding-top:3.5rem}.model-hero-grid{gap:1.2rem}.model-hero h1{font-size:clamp(3.65rem,17vw,5rem);line-height:.88}.model-lead{font-size:1.05rem}.model-actions{display:grid}.model-button{width:100%}.hero-proof{display:grid}.model-hero-stage{min-height:435px}.main-window{width:92%;right:1%;top:12%}.window-body{min-height:320px;padding:1.55rem}.mini-title{font-size:2.25rem}.stage-card{min-width:175px;padding:.65rem}.stage-card.card-a{left:-2%;top:0}.stage-card.card-b{right:-3%;top:4%}.stage-card.card-c{left:0;bottom:0}.stage-badge{display:none}.model-section{padding:4.8rem 0}.model-section-head h2,.programmes-heading h2,.inclusion-copy h2,.organisation-copy h2,.support-copy h2,.contact-heading h2{font-size:clamp(2.55rem,12vw,4rem)}.audience-card{padding:1.4rem}.programme-row{grid-template-columns:28px 56px 1fr;gap:.7rem}.programme-mark{width:52px;height:52px;border-radius:17px;font-size:1.6rem}.round-link{grid-column:3;width:46px;height:46px}.programme-content{grid-column:3}.programme-meta{display:grid;justify-content:start}.feature-lab{min-height:430px;padding-inline:0}.lab-screen{margin:3.5rem .7rem 1rem}.lab-float.one{left:-.2rem}.lab-float.two{right:-.2rem}.lab-float.three{display:none}.feature-grid{grid-template-columns:1fr}.organisation-split{border-radius:28px}.organisation-visual{min-height:370px}.organisation-copy{padding:2rem 1.35rem}.community-grid{gap:.75rem}.story-card.wide{grid-template-rows:180px 1fr}.support-card{padding:2rem 1.3rem;border-radius:28px}.contact-panel a{grid-template-columns:46px 1fr auto}.contact-icon{width:42px;height:42px}.footer-main{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}.footer-bottom{display:grid}.model-footer{padding-top:3rem}
}


/* Populated content pages */
.portal-link { background: var(--ink); color:#fff !important; }
.portal-link:hover,.portal-link:focus-visible { background:var(--teal-dark) !important; color:#fff !important; }
.process-list { list-style:none; padding:0; margin:1.5rem 0 0; display:grid; gap:.75rem; }
.process-list li { display:grid; grid-template-columns:52px 1fr; gap:1rem; align-items:center; padding:1rem; border:1px solid var(--line); border-radius:18px; background:#fff; }
.process-list b { width:44px; height:44px; display:grid; place-items:center; border-radius:14px; background:var(--ink); color:#fff; }
.process-list strong,.process-list small { display:block; }
.process-list small { color:var(--ink-soft); margin-top:.2rem; }
.profile-grid { display:grid; grid-template-columns:.78fr 1.22fr; gap:clamp(2rem,6vw,6rem); align-items:start; }
.profile-card { position:sticky; top:110px; border-radius:34px; padding:clamp(1.5rem,4vw,3rem); background:linear-gradient(145deg,var(--ink),#1b455a); color:#fff; box-shadow:var(--shadow); }
.profile-monogram { width:150px; aspect-ratio:1; display:grid; place-items:center; border-radius:42px; margin-bottom:2rem; background:linear-gradient(135deg,var(--gold),#ffe4a2); color:var(--ink); font-size:3.6rem; font-weight:950; letter-spacing:-.08em; transform:rotate(-3deg); }
.profile-card h2 { margin:.3rem 0 .7rem; }
.profile-role { color:#c9dcdf; font-weight:700; }
.profile-copy { font-size:1.08rem; }
.profile-copy p { color:var(--ink-soft); }
.profile-facts { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:2rem 0; }
.profile-facts div { border-radius:22px; border:1px solid var(--line); padding:1.2rem; background:#fff; }
.profile-facts strong { display:block; color:var(--teal-dark); font-size:2.5rem; line-height:1; }
.profile-facts span { display:block; color:var(--ink-soft); margin-top:.55rem; font-size:.9rem; }
.method-grid { grid-template-columns:repeat(4,1fr); }
.testimonial-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.testimonial-card { min-height:100%; display:flex; flex-direction:column; border-radius:26px; padding:1.5rem; background:#fff; border:1px solid var(--line); box-shadow:0 10px 30px rgba(18,35,51,.06); }
.testimonial-card>span { font-family:Georgia,serif; font-size:4rem; line-height:.7; color:var(--gold); }
.testimonial-card blockquote { margin:1.2rem 0; font-size:1.12rem; line-height:1.55; font-weight:750; }
.testimonial-card cite { margin-top:auto; color:var(--ink-soft); font-style:normal; font-size:.84rem; }
.faq-list { display:grid; gap:.8rem; max-width:940px; }
.faq-list details { border:1px solid var(--line); border-radius:20px; background:#fff; overflow:hidden; }
.faq-list summary { cursor:pointer; padding:1.2rem 3rem 1.2rem 1.25rem; font-size:1.05rem; font-weight:900; list-style:none; position:relative; }
.faq-list summary::-webkit-details-marker { display:none; }
.faq-list summary::after { content:'+'; position:absolute; right:1.25rem; top:50%; transform:translateY(-50%); font-size:1.5rem; color:var(--teal-dark); }
.faq-list details[open] summary::after { content:'−'; }
.faq-list details>div { padding:0 1.25rem 1.25rem; color:var(--ink-soft); }
.faq-list details>div p { margin:.2rem 0; }
@media (max-width:1000px){.method-grid{grid-template-columns:1fr 1fr}.testimonial-grid{grid-template-columns:1fr}.profile-grid{grid-template-columns:1fr}.profile-card{position:relative;top:auto}.profile-monogram{width:120px}}
@media (max-width:620px){.method-grid,.profile-facts{grid-template-columns:1fr}.process-list li{grid-template-columns:44px 1fr}.profile-monogram{width:100px;border-radius:30px;font-size:2.7rem}}

.progress-72 { width:72%; }
