/* ─────────────────────────────────────────────────────────────
   Seasons Labs — shared site styles
   Built on the Seasons Design System (colors_and_type.css)
   Enterprise infrastructure register: white surfaces, restrained
   purple, green-as-punctuation, generous whitespace.
   ───────────────────────────────────────────────────────────── */

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg-page);
  color: var(--text-primary);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; }
img { max-width: 100%; display: block; }
::selection { background: rgba(84,30,246,0.16); }

/* ─── DARK THEME ─────────────────────────────────────────────
   Base #1A1626. Purple is the dominant accent (~80%), lime-green
   is the punctuation accent (~20%): status, positive deltas, success. */
:root {
  /* accent hooks (Tweaks override --sl-accent) */
  --sl-accent: var(--purple-500);          /* #7A20F9 — fills: buttons, chips, chart, dots */
  --sl-accent-ink: #A98CFF;                /* lighter lilac — purple TEXT on dark (WCAG AA) */
  --sl-accent-soft: rgba(122,32,249,0.16);

  /* surfaces — elevation scale on #1A1626 */
  --bg-page:        #1A1626;
  --bg-surface:     #221C33;   /* cards, windows, footer panels */
  --bg-surface-alt: #2A2340;   /* lifted / nested data cards, inputs, tinted */
  --bg-surface-soft:#1E1830;   /* window bars, table rows, insets */
  --bg-muted:       #2F2747;
  --bg-footer:      #140F1D;   /* deep footer band */
  --bg-elevated:    #221C33;
  --bg-tag-purple:  rgba(122,32,249,0.20);
  --bg-tag-green:   rgba(141,250,68,0.15);

  /* text */
  --text-primary:   #ECEAF6;
  --text-secondary: #ABA4C2;
  --text-tertiary:  #9690AE;
  --text-nav:       #ABA4C2;
  --text-link:      var(--purple-500);

  /* borders — light-on-dark hairlines */
  --border-default: rgba(255,255,255,0.09);
  --border-soft:    rgba(255,255,255,0.055);
  --border-pill:    rgba(255,255,255,0.15);
  --border-strong:  rgba(255,255,255,0.26);

  /* purple tints used as chip/icon backgrounds */
  --purple-050: rgba(122,32,249,0.16);
  --purple-025: rgba(122,32,249,0.10);
  --green-100:  rgba(141,250,68,0.14);

  color-scheme: dark;
}

/* ─── Layout primitives ──────────────────────────────────────── */
.wrap { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
.wrap-narrow { max-width: 820px; margin: 0 auto; padding: 0 40px; }

.section { padding-block: 104px; position: relative; }
.section.tight { padding-block: 72px; }
body.compact .section { padding-block: 72px; }
body.compact .section.tight { padding-block: 52px; }

.divider { height: 1px; background: var(--border-soft); border: 0; margin: 0; }

/* Ambient glow — extremely subtle, infra-calm */
.ambient { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.ambient::before {
  content: ""; position: absolute; top: -240px; left: 50%; transform: translateX(-60%);
  width: 900px; height: 620px; border-radius: 999px;
  background: radial-gradient(closest-side, rgba(122,32,249,0.22), rgba(122,32,249,0));
  filter: blur(40px);
}

/* ─── Type helpers ───────────────────────────────────────────── */
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font: var(--fw-bold) 12px/1 var(--font-body);
  letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--sl-accent-ink);
}
.eyebrow .tick { width: 6px; height: 6px; border-radius: 999px; background: var(--accent-secondary); }
.eyebrow.muted { color: var(--text-tertiary); }

.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.lead { font: var(--fw-regular) 19px/1.55 var(--font-body); color: var(--text-secondary); }
.lead-sm { font: var(--fw-regular) 16px/1.6 var(--font-body); color: var(--text-secondary); }

h1.display {
  font: var(--fw-medium) clamp(40px, 5.2vw, 64px)/1.02 var(--font-display);
  letter-spacing: -1.6px; margin: 0;
}
h1.display .em, h2 .em { color: var(--sl-accent-ink); font-weight: var(--fw-bold); }

.sec-head { max-width: 720px; }
.sec-head.center { margin: 0 auto; text-align: center; }
.sec-head h2 {
  font: var(--fw-medium) clamp(30px, 3.4vw, 42px)/1.05 var(--font-display);
  letter-spacing: -1px; margin: 16px 0 0;
}
.sec-head .lead, .sec-head .lead-sm { margin-top: 18px; }

/* ─── Buttons ────────────────────────────────────────────────── */
.btn {
  font: var(--fw-bold) 14px/1 var(--font-body);
  border-radius: var(--radius-pill); border: 1px solid transparent; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px 20px; text-decoration: none; white-space: nowrap;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out), transform var(--dur-fast) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.btn svg { width: 16px; height: 16px; }
.btn.primary { background: var(--sl-accent); color: #fff; box-shadow: var(--shadow-button-primary); }
.btn.primary:hover { background: var(--accent-primary-hover); }
.btn.primary:active { transform: scale(0.985); }
.btn.ghost { background: transparent; color: var(--text-primary); border-color: var(--border-pill); }
.btn.ghost:hover { border-color: var(--border-strong); background: rgba(255,255,255,0.05); }
.btn.subtle { background: var(--bg-surface-soft); color: var(--text-primary); }
.btn.subtle:hover { background: var(--bg-muted); }
.btn.lg { padding: 15px 26px; font-size: 15px; }
.btn .dot { width: 7px; height: 7px; border-radius: 999px; background: var(--accent-secondary); }
.btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.textlink {
  display: inline-flex; align-items: center; gap: 6px; text-decoration: none;
  font: var(--fw-bold) 14px/1 var(--font-body); color: var(--sl-accent-ink);
}
.textlink svg { width: 15px; height: 15px; transition: transform var(--dur-base) var(--ease-out); }
.textlink:hover svg { transform: translate(2px, -2px); }

/* ─── Floating nav ───────────────────────────────────────────── */
.nav-wrap { position: sticky; top: 16px; z-index: 100; padding: 16px 16px 0; }
.nav {
  max-width: 1200px; margin: 0 auto;
  background: rgba(28,22,42,0.72);
  backdrop-filter: blur(20px) saturate(140%); -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-nav);
  box-shadow: var(--shadow-nav);
  padding: 9px 9px 9px 20px;
  display: flex; align-items: center; gap: 14px;
}
.brand { display: flex; align-items: center; gap: 9px; flex-shrink: 0; text-decoration: none; }
.brand img { width: 28px; height: 28px; border-radius: 8px; }
.brand .brand-logo { width: auto; height: 31px; border-radius: 0; }
.brand .name { font: var(--fw-bold) 18px/1 var(--font-display); color: var(--text-primary); letter-spacing: -0.3px; }
.brand .bar { width: 1px; height: 17px; background: var(--border-pill); }
.brand .labs { font: var(--fw-bold) 11px/1 var(--font-body); letter-spacing: 2px; color: var(--text-tertiary); }
.nav-links { display: flex; gap: 4px; margin: 0 auto; }
.nav-links a {
  text-decoration: none; color: var(--text-nav);
  font: var(--fw-medium) 14px/1 var(--font-body);
  padding: 9px 13px; border-radius: var(--radius-pill);
  transition: color var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out);
}
.nav-links a:hover { color: var(--text-primary); background: rgba(122,32,249,0.18); }
.nav-links a.active { color: var(--sl-accent-ink); font-weight: var(--fw-bold); }
.nav-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.nav-burger {
  display: none; width: 42px; height: 42px; border-radius: 999px; border: 1px solid var(--border-pill);
  background: transparent; cursor: pointer; align-items: center; justify-content: center;
}
.nav-burger svg { width: 20px; height: 20px; color: var(--text-primary); }

/* mobile menu */
.mobile-menu {
  display: none; position: fixed; inset: 0; z-index: 99; background: rgba(20,15,29,0.98);
  backdrop-filter: blur(16px); padding: 96px 32px 32px; flex-direction: column; gap: 6px;
}
.mobile-menu.open { display: flex; }
.mobile-menu a { text-decoration: none; color: var(--text-primary); font: var(--fw-medium) 24px/1 var(--font-display); padding: 16px 0; border-bottom: 1px solid var(--border-soft); }
.mobile-menu .btn { margin-top: 20px; }

/* ─── Hero ───────────────────────────────────────────────────── */
.page { position: relative; z-index: 1; }
.hero { padding-top: 88px; position: relative; }
.hero .lead { margin-top: 22px; max-width: 560px; }
.hero .cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.hero-glow {
  position: absolute; top: 50%; right: 0;
  height: 300%; width: auto; max-width: none;
  transform: translate(calc(50% - 250px), -50%);
  object-fit: contain; object-position: center;
  pointer-events: none; z-index: 0; user-select: none;
}
.hero > *:not(.hero-glow),
.page-hero > *:not(.hero-glow) { position: relative; z-index: 1; }

.page-hero { padding-top: 96px; padding-bottom: 24px; position: relative; }
.page-hero .eyebrow { margin-bottom: 18px; }
.page-hero .lead { margin-top: 20px; max-width: 620px; }

/* trust strip / stat row */
.statrow { display: flex; flex-wrap: wrap; gap: 56px; margin-top: 56px; }
.statrow .stat .v { font: var(--fw-medium) 34px/1 var(--font-display); letter-spacing: -1px; color: var(--text-primary); }
.statrow .stat .v .sub { color: var(--sl-accent-ink); }
.statrow .stat .l { font: var(--fw-medium) 12px/1 var(--font-body); letter-spacing: 0.6px; text-transform: uppercase; color: var(--text-tertiary); margin-top: 9px; }

/* ─── Cards ──────────────────────────────────────────────────── */
.grid { display: grid; gap: 20px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-5 { grid-template-columns: repeat(5, 1fr); }

.card {
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-card); padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out);
}
.card.tinted { background: var(--bg-surface-alt); }
.card.hover:hover { box-shadow: var(--shadow-stats); transform: translateY(-2px); border-color: var(--border-soft); }
.card h3 { font: var(--fw-bold) 19px/1.2 var(--font-display); }
.card p { font: var(--fw-regular) 14.5px/1.6 var(--font-body); color: var(--text-secondary); }

.icon-box {
  width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0;
  background: var(--purple-050); color: var(--green-500);
  display: flex; align-items: center; justify-content: center;
}
.icon-box svg { width: 22px; height: 22px; stroke-width: 1.6; }
.icon-box.green { background: var(--green-100); color: var(--green-700); }

.pill {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--bg-tag-purple); color: var(--sl-accent-ink);
  padding: 6px 11px; border-radius: var(--radius-pill);
  font: var(--fw-bold) 11px/1 var(--font-body); letter-spacing: 0.3px;
}
.pill.green { background: var(--bg-tag-green); color: var(--green-700); }
.pill.neutral { background: var(--bg-surface-soft); color: var(--text-secondary); }
.pill .dot { width: 6px; height: 6px; border-radius: 999px; background: currentColor; }
.pill.live .dot { background: var(--accent-secondary); }

/* capability list */
.cap-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0; }
.cap-list li {
  display: flex; align-items: center; gap: 12px;
  font: var(--fw-medium) 14.5px/1 var(--font-body); color: var(--text-primary);
  padding: 13px 0; border-bottom: 1px solid var(--border-soft);
}
.cap-list li:last-child { border-bottom: 0; }
.cap-list li .mk { width: 16px; height: 16px; flex-shrink: 0; color: var(--green-500); }

/* feature row (alternating) */
.feature-row { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.feature-row.reverse .fr-media { order: -1; }
.feature-row + .feature-row { margin-top: 96px; }
body.compact .feature-row + .feature-row { margin-top: 64px; }
.fr-copy h3 { font: var(--fw-medium) clamp(26px,2.6vw,32px)/1.1 var(--font-display); letter-spacing: -0.6px; }
.fr-copy .lead-sm { margin-top: 16px; }
.fr-copy .cap-list { margin-top: 22px; }
.fr-actions { margin-top: 26px; display: flex; gap: 14px; align-items: center; }

/* principle grid */
.principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--border-default); border-radius: var(--radius-card); overflow: hidden; background: var(--bg-surface); }
.principle { padding: 32px; border-right: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); }
.principle .n { font: var(--fw-medium) 12px/1 var(--font-mono); color: var(--sl-accent-ink); letter-spacing: 1px; }
.principle h4 { font: var(--fw-bold) 19px/1.2 var(--font-display); margin: 16px 0 8px; }
.principle p { font: var(--fw-regular) 14px/1.55 var(--font-body); color: var(--text-secondary); }
.principles.cols-3 .principle:nth-child(3n) { border-right: 0; }
.principles.cols-3 .principle:nth-last-child(-n+3) { border-bottom: 0; }

/* ─── App-window product mockup ──────────────────────────────── */
.window {
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-lg); overflow: hidden;
  box-shadow: var(--shadow-stats);
}
.window-bar {
  display: flex; align-items: center; gap: 8px; padding: 13px 16px;
  border-bottom: 1px solid var(--border-soft); background: var(--bg-surface-soft);
}
.window-bar .dots { display: flex; gap: 6px; }
.window-bar .dots i { width: 10px; height: 10px; border-radius: 999px; background: var(--ink-200); display: block; }
.window-bar .addr {
  margin-left: 10px; flex: 1; font: var(--fw-medium) 12px/1 var(--font-mono); color: var(--text-tertiary);
  background: var(--bg-surface); border: 1px solid var(--border-soft); border-radius: 999px;
  padding: 7px 14px; display: flex; align-items: center; gap: 7px; max-width: 320px;
}
.window-bar .addr svg { width: 12px; height: 12px; color: var(--green-700); }

/* dashboard interior */
.dash { display: grid; grid-template-columns: 184px 1fr; min-height: 420px; }
.dash-side { border-right: 1px solid var(--border-soft); padding: 18px 14px; background: var(--bg-page); }
.dash-side .org { display: flex; align-items: center; gap: 9px; padding: 6px 8px 16px; }
.dash-side .org img { width: 22px; height: 22px; border-radius: 6px; }
.dash-side .org .nm { font: var(--fw-bold) 14px/1 var(--font-display); }
.dash-side .org .tg { font: var(--fw-bold) 8px/1 var(--font-body); letter-spacing: 1.5px; color: var(--text-tertiary); }
.dash-nav { display: flex; flex-direction: column; gap: 2px; }
.dash-nav a { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 9px; font: var(--fw-medium) 13px/1 var(--font-body); color: var(--text-nav); text-decoration: none; cursor: pointer; }
.dash-nav a svg { width: 16px; height: 16px; opacity: 0.85; color: var(--green-500); }
.dash-nav a.active { background: var(--purple-050); color: var(--sl-accent-ink); }
.dash-nav a.active svg { opacity: 1; }
.dash-main { padding: 22px; }
.dash-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
.dash-head .ttl { font: var(--fw-bold) 17px/1.1 var(--font-display); }
.dash-head .sub { font: var(--fw-regular) 12px/1 var(--font-body); color: var(--text-tertiary); margin-top: 6px; }
.kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 16px; }
.kpi { border: 1px solid var(--border-soft); border-radius: 12px; padding: 14px; background: var(--bg-surface-alt); }
.kpi .l { font: var(--fw-medium) 10.5px/1 var(--font-body); letter-spacing: 0.4px; text-transform: uppercase; color: var(--text-tertiary); }
.kpi .v { font: var(--fw-bold) 22px/1 var(--font-display); margin-top: 9px; letter-spacing: -0.5px; }
.kpi .d { font: var(--fw-medium) 11px/1 var(--font-body); color: var(--green-700); margin-top: 7px; display: flex; align-items: center; gap: 4px; }
.kpi .d.flat { color: var(--text-tertiary); }
.chart-card { border: 1px solid var(--border-soft); border-radius: 12px; padding: 16px; background: var(--bg-surface-alt); }
.chart-card .ch-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.chart-card .ch-head .t { font: var(--fw-bold) 13px/1 var(--font-display); }
.chart-card .ch-head .legend { display: flex; gap: 12px; }
.chart-card .ch-head .legend span { display: flex; align-items: center; gap: 5px; font: var(--fw-medium) 10.5px/1 var(--font-body); color: var(--text-tertiary); }
.chart-card .ch-head .legend i { width: 8px; height: 8px; border-radius: 2px; display: block; }

/* ─── Footer ─────────────────────────────────────────────────── */
.footer-wrap { padding: 96px 16px 0; position: relative; z-index: 1; }
body.compact .footer-wrap { padding-top: 64px; }
.footer {
  max-width: 1200px; margin: 0 auto; background: var(--bg-footer);
  border-radius: 40px 40px 0 0; padding: 56px 56px 0;
}
.footer-top { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 48px; }
.footer .brand-col .row { display: flex; align-items: center; gap: 9px; }
.footer .brand-col .row img { width: 30px; height: 30px; border-radius: 9px; }
.footer .brand-col .row img.brand-logo { width: auto; height: 39px; border-radius: 0; }
.footer .brand-col .row .n { font: var(--fw-bold) 21px/1 var(--font-display); letter-spacing: -0.3px; }
.footer .brand-col .row .labs { font: var(--fw-bold) 11px/1 var(--font-body); letter-spacing: 2px; color: var(--text-tertiary); border-left: 1px solid var(--border-pill); padding-left: 9px; }
.footer .brand-col .tag { font: var(--fw-regular) 14px/1.6 var(--font-body); color: var(--text-secondary); margin-top: 16px; max-width: 290px; }
.footer .brand-col .reg { font: var(--fw-regular) 12px/1.5 var(--font-mono); color: var(--text-tertiary); margin-top: 18px; }
.footer h4 { font: var(--fw-bold) 11px/1 var(--font-body); letter-spacing: 1px; text-transform: uppercase; color: var(--text-primary); margin: 0 0 16px; }
.footer .col a { display: block; font: var(--fw-regular) 14px/1 var(--font-body); color: var(--text-secondary); text-decoration: none; padding: 8px 0; transition: color var(--dur-base) var(--ease-out); }
.footer .col a:hover { color: var(--sl-accent-ink); }
.footer-bot {
  max-width: 1200px; margin: 0 auto; background: var(--bg-footer);
  border-radius: 0 0 0 0; padding: 22px 56px 36px;
  display: flex; justify-content: space-between; align-items: center; gap: 20px;
  border-top: 1px solid rgba(255,255,255,0.08); flex-wrap: wrap;
}
.footer-bot .c { font: var(--fw-regular) 12.5px/1.4 var(--font-body); color: var(--text-tertiary); }
.footer-bot .tagline { font: var(--fw-bold) 11px/1 var(--font-body); letter-spacing: 1.5px; color: var(--ink-350); }

/* ─── Reveal on scroll ───────────────────────────────────────── */
[data-reveal] { opacity: 0; transform: translateY(14px); transition: opacity 600ms var(--ease-out), transform 600ms var(--ease-out); }
[data-reveal].in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none; }
  html { scroll-behavior: auto; }
}

/* ─── Contact form ───────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font: var(--fw-medium) 13.5px/1 var(--font-body); color: var(--text-primary); }
.field .req { color: var(--sl-accent-ink); }
.input, .textarea, .select {
  width: 100%; font: var(--fw-regular) 15px/1.4 var(--font-body); color: var(--text-primary);
  background: var(--bg-surface-alt); border: 1.5px solid var(--border-default); border-radius: var(--radius-md);
  padding: 13px 15px; transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.textarea { resize: vertical; min-height: 130px; }
.input::placeholder, .textarea::placeholder { color: var(--text-tertiary); }
.input:focus, .textarea:focus, .select:focus { outline: none; border-color: var(--sl-accent); box-shadow: var(--focus-ring); }
.field.error .input, .field.error .textarea, .field.error .select { border-color: var(--border-danger); }
.field .err-msg { font: var(--fw-medium) 12.5px/1.3 var(--font-body); color: var(--text-danger); display: none; }
.field.error .err-msg { display: block; }
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.cat-chip {
  border: 1.5px solid var(--border-default); border-radius: var(--radius-md); padding: 14px;
  cursor: pointer; background: var(--bg-surface); transition: all var(--dur-base) var(--ease-out);
  display: flex; flex-direction: column; gap: 6px;
}
.cat-chip:hover { border-color: var(--border-strong); }
.cat-chip.sel { border-color: var(--sl-accent); background: var(--purple-025); box-shadow: var(--focus-ring); }
.cat-chip .ct { font: var(--fw-bold) 14px/1.1 var(--font-display); }
.cat-chip .cd { font: var(--fw-regular) 12px/1.4 var(--font-body); color: var(--text-tertiary); }
.form-note { font: var(--fw-regular) 12.5px/1.5 var(--font-body); color: var(--text-tertiary); }
.success-card { background: var(--bg-surface-alt); border: 1px solid var(--border-default); border-radius: var(--radius-card); padding: 40px; text-align: center; }
.success-card .ic { width: 56px; height: 56px; border-radius: 999px; background: var(--green-100); color: var(--green-700); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.success-card .ic svg { width: 28px; height: 28px; }

/* ─── Responsive ─────────────────────────────────────────────── */
@media (max-width: 980px) {
  .nav-links, .nav-actions .btn { display: none; }
  .nav-actions { margin-left: auto; }
  .nav-burger { display: inline-flex; }
  .hero-glow { display: none; }
  .grid-3, .grid-5 { grid-template-columns: 1fr 1fr; }
  .principles { grid-template-columns: 1fr 1fr; }
  .feature-row { grid-template-columns: 1fr; gap: 32px; }
  .feature-row.reverse .fr-media { order: 0; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .dash { grid-template-columns: 1fr; }
  .dash-side { display: none; }
}
@media (max-width: 640px) {
  .wrap, .wrap-narrow, .page-hero { padding-left: 22px; padding-right: 22px; }
  .section { padding-block: 64px; }
  .grid-2, .grid-3, .grid-5 { grid-template-columns: 1fr; }
  .principles { grid-template-columns: 1fr; }
  .principles .principle { border-right: 0 !important; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer { padding: 40px 28px 0; }
  .footer-bot { padding: 22px 28px 32px; }
  .statrow { gap: 32px; }
  .cat-grid { grid-template-columns: 1fr; }
  .kpis { grid-template-columns: 1fr 1fr; }
}
