/* ---------- Tokens (scoped to konfigurator widget) ---------- */
.aluvio-konfigurator {
  --bg: #FAFAF7;
  --bg-elev: #FFFFFF;
  --bg-panel: #F3F3EE;
  --bg-inset: #EDEDE6;
  --ink: #101014;
  --ink-muted: #3D3D47;
  --ink-subtle: #8E8E87;
  --line: #E4E4DD;
  --line-strong: #CFCFC6;
  --accent: #C8FF00;
  --accent-ink: #101014;
  --danger: #E0563A;
  --warning-bg: #FDF5D3;
  --warning-ink: #7A5B12;
  --preview-bg: #F0EFE9;
  --preview-bg-2: #E6E5DE;
  --shadow-sm: 0 1px 2px rgba(10, 10, 10, 0.04);
  --shadow-md: 0 6px 24px -12px rgba(10, 10, 10, 0.14), 0 2px 6px rgba(10, 10, 10, 0.04);
  --shadow-lg: 0 24px 48px -24px rgba(10, 10, 10, 0.18);
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-pill: 999px;
  --font-display: "Manrope", system-ui, sans-serif;
  --font-ui: "Manrope", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;
}

[data-theme="dark"] {
  --bg: #0C0C0B;
  --bg-elev: #161614;
  --bg-panel: #121210;
  --bg-inset: #1C1C1A;
  --ink: #F5F5EE;
  --ink-muted: #A0A098;
  --ink-subtle: #6E6E66;
  --line: #26261F;
  --line-strong: #33332B;
  --preview-bg: #1A1A17;
  --preview-bg-2: #121210;
  --warning-bg: #2A220A;
  --warning-ink: #E5C879;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.4);
  --shadow-md: 0 8px 28px -12px rgba(0, 0, 0, 0.6), 0 2px 6px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 24px 60px -24px rgba(0, 0, 0, 0.7);
}

.aluvio-konfigurator * { box-sizing: border-box; }
.aluvio-konfigurator { font-family: var(--font-ui); color: var(--ink); -webkit-font-smoothing: antialiased; line-height: 1.4; }
.aluvio-konfigurator button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
.aluvio-konfigurator input, .aluvio-konfigurator select, .aluvio-konfigurator textarea { font-family: inherit; }

/* ---------- Mock site chrome ---------- */

.mock-topbar {
  background: #0A0A0A;
  color: #F5F5EE;
  font-size: 12px;
  padding: 9px 24px;
  display: flex;
  gap: 24px;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.01em;
}
.mock-topbar .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent); display: inline-block; }
.mock-topbar .pill { display: inline-flex; align-items: center; gap: 8px; }
.mock-topbar .muted { color: #A0A098; }

.mock-header {
  max-width: 1380px;
  margin: 0 auto;
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.mock-brand { display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: -0.01em; }
.mock-brand .mark {
  width: 34px; height: 34px; border-radius: 9px;
  background: var(--ink); color: var(--bg);
  display: grid; place-items: center;
  font-family: var(--font-display); font-size: 22px;
}
.mock-brand .name { font-size: 15px; letter-spacing: 0.08em; }
.mock-brand .tag { font-size: 11px; color: var(--ink-subtle); font-weight: 500; margin-left: 2px; }

.mock-nav { display: flex; gap: 28px; font-size: 14px; color: var(--ink-muted); }
.mock-nav a { cursor: pointer; display: inline-flex; align-items: center; gap: 6px; }
.mock-nav a:hover { color: var(--ink); }
.mock-nav a.active { color: var(--ink); font-weight: 500; }
.mock-nav .badge {
  background: var(--accent); color: var(--accent-ink);
  font-size: 9px; font-weight: 700; font-style: normal;
  letter-spacing: 0.08em;
  padding: 3px 6px; border-radius: 4px;
}
.mock-header-actions { display: flex; align-items: center; gap: 8px; }
.icon-btn-sm {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--line);
  display: grid; place-items: center;
  color: var(--ink);
  transition: background 0.15s;
}
.icon-btn-sm:hover { background: var(--bg-inset); }
.icon-btn-sm svg { width: 15px; height: 15px; }
.pill-btn {
  border: 1px solid var(--ink);
  border-radius: var(--radius-pill);
  padding: 8px 18px;
  font-size: 14px;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.pill-btn .badge-circle {
  background: var(--accent); color: var(--accent-ink);
  width: 20px; height: 20px; border-radius: 50%;
  font-size: 11px; font-weight: 700;
  display: grid; place-items: center;
}

/* ---------- Hero ---------- */

.home-hero {
  max-width: 1380px;
  margin: 0 auto;
  padding: 24px 32px 64px;
}
.home-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: start;
}
.hero-side {
  padding: 40px 8px 24px;
}
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--ink-muted);
  margin-bottom: 18px;
}
.hero-title {
  font-family: var(--font-display);
  font-size: 76px;
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin: 0 0 24px;
  font-weight: 400;
}
.hero-title em { font-style: italic; color: var(--ink-muted); font-weight: 400; }
.hero-title .accent-hl {
  background: var(--accent);
  color: var(--accent-ink);
  padding: 0 10px;
  border-radius: 6px;
  font-style: italic;
  display: inline-block;
  line-height: 1;
}
.hero-lede {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-muted);
  max-width: 460px;
  margin: 0 0 32px;
}
.hero-facts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 220px));
  gap: 18px 32px;
  padding: 24px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 20px;
}
.hero-fact .n {
  font-family: var(--font-display);
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.hero-fact .l {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-subtle);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 6px;
}
.hero-trust {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--ink-muted);
}

/* ---------- Configurator widget ---------- */

.configurator {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 720px;
}

.configurator-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 22px 24px 16px;
  gap: 16px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.configurator-eyebrow {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-subtle);
  margin-bottom: 4px;
}
.configurator-title {
  font-family: var(--font-display);
  font-size: 30px;
  line-height: 1;
  letter-spacing: -0.01em;
  margin: 0;
  font-weight: 400;
}
.configurator-title em { font-style: italic; color: var(--ink-muted); font-weight: 400; }
.configurator-sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-subtle);
  letter-spacing: 0.04em;
  margin-top: 8px;
}
.configurator-head-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.theme-btn { flex-shrink: 0; }

.view-toggle {
  display: inline-flex;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 3px;
}
.view-toggle button {
  padding: 6px 12px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-muted);
  display: inline-flex; align-items: center; gap: 6px;
  transition: all 0.15s;
}
.view-toggle button.active {
  background: var(--ink); color: var(--bg);
}
.view-toggle button svg { width: 13px; height: 13px; }

.warnings {
  background: var(--warning-bg);
  padding: 10px 24px;
  border-bottom: 1px solid var(--line);
}
.warning {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--warning-ink);
  font-weight: 500;
}
.warning + .warning { margin-top: 4px; display: flex; }

.configurator-body {
  display: grid;
  grid-template-columns: 1fr 340px;
  flex: 1;
  min-height: 0;
}

/* Stage embed */
.stage-embed {
  position: relative;
  background: radial-gradient(ellipse at 50% 40%, var(--preview-bg) 0%, var(--preview-bg-2) 100%);
  display: flex;
  flex-direction: column;
  min-height: 420px;
}
.stage-canvas-embed {
  flex: 1;
  padding: 28px 28px 72px;
  min-height: 340px;
  max-height: 640px;
  height: 600px;
  position: relative;
}
.stage-facts {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 1fr;
  padding: 18px 24px;
  border-top: 1px solid var(--line);
  background: var(--bg-elev);
  margin-top: auto;
}
.stage-facts .fact {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-subtle);
  font-family: var(--font-mono);
}
.stage-facts .fact b {
  display: block;
  font-family: var(--font-ui);
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-transform: none;
  font-weight: 600;
  margin-top: 3px;
}

/* Panel embed */
.panel-embed {
  background: var(--bg-elev);
  border-left: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.panel-tabs {
  display: flex;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.panel-tab {
  flex: 1;
  padding: 14px 10px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-subtle);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: all 0.15s;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}
.panel-tab .num {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--bg-inset); color: var(--ink-subtle);
  font-family: var(--font-mono); font-size: 10px;
  display: grid; place-items: center;
}
.panel-tab.active { color: var(--ink); border-bottom-color: var(--accent); }
.panel-tab.active .num { background: var(--accent); color: var(--accent-ink); }

.panel-body-embed {
  flex: 1;
  overflow-y: auto;
  padding: 20px 22px 24px;
  scrollbar-width: thin;
  min-height: 0;
}
.panel-body-embed::-webkit-scrollbar { width: 5px; }
.panel-body-embed::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 3px; }

/* ---------- Stepper header ---------- */
.stepper-header {
  display: flex;
  align-items: stretch;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-elev);
  flex-shrink: 0;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.stepper-header::-webkit-scrollbar { display: none; }

.stepper-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 6px;
  color: var(--ink-subtle);
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: color 0.15s;
  background: none;
  border: 0;
}
.stepper-item .num {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg-inset);
  color: var(--ink-subtle);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  display: grid; place-items: center;
  flex-shrink: 0;
  border: 1px solid var(--line);
  transition: all 0.15s;
}
.stepper-item .label {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: -0.005em;
  white-space: nowrap;
}
.stepper-item .connector {
  width: 20px;
  height: 1px;
  background: var(--line-strong);
  margin: 0 2px 0 6px;
  flex-shrink: 0;
}
.stepper-item.active {
  color: var(--ink);
}
.stepper-item.active .num {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}
.stepper-item.done {
  color: var(--ink-muted);
}
.stepper-item.done .num {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.stepper-item:hover:not(.active) {
  color: var(--ink);
}

@media (max-width: 680px) {
  .stepper-header { padding: 10px 12px; }
  .stepper-item .label { display: none; }
  .stepper-item.active .label { display: inline; }
  .stepper-item .connector { width: 12px; margin: 0 0 0 4px; }
}

/* ---------- Step body + nav ---------- */
.step-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px 22px 10px;
  scrollbar-width: thin;
  min-height: 0;
}
.step-body::-webkit-scrollbar { width: 5px; }
.step-body::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 3px; }

.step-heading {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--line);
}
.step-kicker {
  font-size: 10px;
  font-family: var(--font-mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-subtle);
  margin-bottom: 4px;
}
.step-title {
  font-family: var(--font-display);
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 0;
  font-weight: 400;
}

.step-lede {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-muted);
  margin-bottom: 18px;
  max-width: 48ch;
}

.step-nav {
  display: flex;
  gap: 8px;
  padding: 12px 18px;
  border-top: 1px solid var(--line);
  background: var(--bg-elev);
  flex-shrink: 0;
}
.step-nav-btn {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 11px 14px;
  border-radius: 999px;
  font-size: 12.5px;
  font-weight: 500;
  font-family: var(--font-ui);
  cursor: pointer;
  transition: all 0.15s;
  border: 1px solid var(--line-strong);
}
.step-nav-btn.secondary {
  background: var(--bg);
  color: var(--ink-muted);
  max-width: 120px;
}
.step-nav-btn.secondary:hover:not(:disabled) {
  background: var(--bg-inset);
  color: var(--ink);
}
.step-nav-btn.secondary:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.step-nav-btn.primary {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
.step-nav-btn.primary:hover {
  background: var(--ink-muted);
}

/* ---------- Config sections ---------- */

.section { margin-bottom: 26px; }
.section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 12px;
}
.section-title {
  font-family: var(--font-display);
  font-size: 19px;
  letter-spacing: -0.01em;
  margin: 0;
  line-height: 1;
  font-weight: 400;
}
.section-sub {
  font-size: 10px;
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-subtle);
}

.field { margin-bottom: 14px; }
.field-label {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 6px;
  gap: 6px;
}
.field-label .name {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink);
}
.field-label .help {
  font-size: 10px;
  color: var(--ink-subtle);
  font-family: var(--font-mono);
  text-align: right;
}

.numinput {
  display: flex;
  align-items: stretch;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color 0.15s, background 0.15s;
}
.numinput:focus-within { border-color: var(--ink); background: var(--bg-elev); }
.numinput input {
  flex: 1; min-width: 0;
  background: transparent; border: 0; outline: 0;
  padding: 10px 12px;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.numinput .unit {
  padding: 0 12px;
  display: grid; place-items: center;
  font-size: 11px;
  color: var(--ink-subtle);
  font-family: var(--font-mono);
  border-left: 1px solid var(--line);
}
.numinput .stepper { display: flex; flex-direction: column; border-left: 1px solid var(--line); }
.numinput .stepper button {
  flex: 1; width: 28px;
  color: var(--ink-muted);
  display: grid; place-items: center;
  transition: background 0.12s;
}
.numinput .stepper button:hover { background: var(--bg-inset); color: var(--ink); }
.numinput .stepper button + button { border-top: 1px solid var(--line); }

.slider {
  -webkit-appearance: none; appearance: none;
  width: 100%;
  height: 4px;
  background: var(--line);
  border-radius: 2px;
  outline: 0;
  margin: 8px 0 4px;
}
.slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--ink);
  border: 3px solid var(--bg-elev);
  box-shadow: 0 0 0 1px var(--line-strong);
  cursor: grab;
}
.slider::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--ink);
  border: 3px solid var(--bg-elev);
  box-shadow: 0 0 0 1px var(--line-strong);
  cursor: grab;
}
.slider-bounds {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-subtle);
}

/* Profile grid */
.profile-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
}
.profile-chip {
  position: relative;
  padding: 10px 8px 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--bg-panel);
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  transition: all 0.15s;
  cursor: pointer;
}
.profile-chip:hover { border-color: var(--line-strong); background: var(--bg-elev); }
.profile-chip.active {
  border-color: var(--ink);
  background: var(--bg-elev);
  box-shadow: 0 0 0 1px var(--ink) inset;
}
.profile-chip.active::after {
  content: "";
  position: absolute; top: 5px; right: 5px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent);
}
.profile-chip .diag { display: grid; place-items: center; height: 28px; width: 100%; }
.profile-chip .diag .bar { background: var(--ink); border-radius: 1.5px; }
.profile-chip .label { font-family: var(--font-mono); font-size: 10.5px; font-weight: 500; color: var(--ink); }
.profile-chip .price { font-size: 9.5px; color: var(--ink-subtle); font-family: var(--font-mono); }

/* Segmented control */
.seg {
  display: inline-flex;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 3px;
  width: 100%;
}
.seg button {
  flex: 1;
  padding: 7px 10px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 500;
  color: var(--ink-muted);
  transition: all 0.15s;
}
.seg button.active { background: var(--bg-elev); color: var(--ink); box-shadow: var(--shadow-sm); }

/* RAL */
.ral-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
.ral-chip {
  aspect-ratio: 1;
  border-radius: var(--radius-sm);
  position: relative; cursor: pointer;
  border: 1px solid var(--line);
  overflow: hidden;
  transition: transform 0.12s;
}
.ral-chip:hover { transform: translateY(-2px); }
.ral-chip.active { box-shadow: 0 0 0 2px var(--bg-elev), 0 0 0 4px var(--ink); }
.ral-chip .code {
  position: absolute; left: 5px; bottom: 5px;
  font-family: var(--font-mono);
  font-size: 9px; color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.ral-chip.light .code { color: #0A0A0A; text-shadow: none; }

.ral-search {
  margin-top: 10px;
  display: flex; align-items: center;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: 0 10px;
}
.ral-search svg { width: 13px; height: 13px; color: var(--ink-subtle); }
.ral-search input {
  flex: 1;
  background: transparent; border: 0; outline: 0;
  padding: 9px 8px;
  font-size: 12.5px;
  color: var(--ink);
}
.ral-dropdown {
  margin-top: 6px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  overflow: hidden;
  max-height: 220px;
  overflow-y: auto;
}
.ral-row {
  display: flex; align-items: center; gap: 10px;
  padding: 7px 10px;
  cursor: pointer;
  transition: background 0.12s;
  border-bottom: 1px solid var(--line);
}
.ral-row:last-child { border-bottom: 0; }
.ral-row:hover { background: var(--bg-panel); }
.ral-row .sw { width: 20px; height: 20px; border-radius: 5px; border: 1px solid var(--line); flex-shrink: 0; }
.ral-row .meta b { display: block; font-size: 12px; font-weight: 500; }
.ral-row .meta span { font-size: 10px; color: var(--ink-subtle); font-family: var(--font-mono); }

/* Counter */
.counter {
  display: inline-flex;
  align-items: center;
  background: var(--bg-panel);
  border: 1px solid var(--line);
  border-radius: var(--radius-pill);
  padding: 3px;
}
.counter button {
  width: 30px; height: 30px;
  border-radius: 50%;
  color: var(--ink-muted);
  display: grid; place-items: center;
  transition: background 0.12s;
}
.counter button:hover:not(:disabled) { background: var(--bg-elev); color: var(--ink); }
.counter button:disabled { opacity: 0.3; cursor: not-allowed; }
.counter .val {
  min-width: 36px;
  text-align: center;
  font-weight: 600;
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}

/* ---------- Summary footer ---------- */

.summary {
  border-top: 1px solid var(--line);
  background: var(--bg-elev);
  padding: 16px 22px 18px;
  flex-shrink: 0;
}
.summary-row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 3px;
}
.summary-row .lbl { font-size: 10px; color: var(--ink-muted); font-family: var(--font-mono); letter-spacing: 0.04em; text-transform: uppercase; }
.summary-row .val { font-size: 12px; color: var(--ink); font-variant-numeric: tabular-nums; }
.summary-total {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding-top: 12px; margin-top: 10px;
  border-top: 1px dashed var(--line);
  margin-bottom: 14px;
}
.summary-total .lbl { font-size: 10px; color: var(--ink-subtle); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); }
.summary-total .val {
  font-family: var(--font-display);
  font-size: 36px;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.summary-total .val .currency { font-size: 16px; color: var(--ink-muted); margin-left: 4px; font-family: var(--font-ui); }
.todo-note {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 9px;
  color: var(--ink-subtle);
  font-family: var(--font-mono);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin-top: 3px;
}
.todo-note .dot { width: 5px; height: 5px; border-radius: 50%; background: #E4B73A; box-shadow: 0 0 0 3px rgba(228, 183, 58, 0.15); }

.cta-row { display: flex; gap: 6px; }
.btn {
  padding: 12px 16px;
  border-radius: var(--radius-pill);
  font-size: 13px; font-weight: 500;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  transition: transform 0.1s, background 0.15s;
  border: 1px solid transparent;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--accent); color: var(--accent-ink); flex: 1; }
.btn-primary:hover { background: #C8E63D; }
.btn-secondary { background: transparent; border-color: var(--line-strong); color: var(--ink); }
.btn-secondary:hover { background: var(--bg-panel); }

/* Profile list (summary tab) */
.profile-list { display: flex; flex-direction: column; gap: 2px; }
.profile-list-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  background: var(--bg-panel);
  font-size: 12px;
  align-items: center;
}
.profile-list-row .name { color: var(--ink); }
.profile-list-row .qty { color: var(--ink-muted); font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
.profile-list-row .sub { color: var(--ink-subtle); font-family: var(--font-mono); font-size: 9.5px; }

/* Dim labels */
.dim-label {
  fill: #0A0A0A;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.02em;
  paint-order: stroke fill;
  stroke: #FAFAF7;
  stroke-width: 3.5px;
  stroke-linejoin: round;
}
.dim-line { stroke: #0A0A0A; stroke-width: 1.6; }
.dim-tick { stroke: #0A0A0A; stroke-width: 1.6; }

/* ---------- Bottom strip ---------- */
.home-strip {
  max-width: 1380px;
  margin: 0 auto;
  padding: 24px 32px 64px;
}
.strip-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.strip-card {
  padding: 20px 22px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--bg-elev);
}
.strip-k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-subtle); margin-bottom: 10px; }
.strip-v { font-family: var(--font-display); font-size: 24px; line-height: 1.05; letter-spacing: -0.01em; margin-bottom: 8px; font-weight: 400; }
.strip-s { font-size: 12.5px; color: var(--ink-muted); line-height: 1.45; }

/* ---------- Fade ---------- */
@keyframes fadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }
.fade { animation: fadeIn 0.3s ease-out; }

/* ---------- Responsive ---------- */

@media (max-width: 1280px) {
  .hero-title { font-size: 60px; }
}
@media (max-width: 1120px) {
  .home-hero-grid { grid-template-columns: 1fr; gap: 24px; }
  .hero-side { padding: 16px 0; }
  .hero-title { font-size: 54px; }
  .configurator { min-height: 680px; }
}
@media (max-width: 900px) {
  .hide-md { display: none !important; }
  .configurator-body { grid-template-columns: 1fr; }
  .stage-embed { min-height: 380px; }
  .stage-canvas-embed { height: 420px; max-height: 480px; }
  .panel-embed { border-left: 0; border-top: 1px solid var(--line); }
  .hero-title { font-size: 44px; }
  .strip-row { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .mock-header { padding: 14px 18px; }
  .home-hero { padding: 16px 18px 40px; }
  .home-strip { padding: 16px 18px 40px; }
  .hero-title { font-size: 36px; }
  .hero-facts { grid-template-columns: 1fr 1fr; gap: 14px; }
  .configurator-head { padding: 16px 18px 12px; flex-direction: column; align-items: stretch; }
  .configurator-title { font-size: 24px; }
  .stage-canvas-embed { padding: 16px 16px 0; }
  .stage-facts { grid-auto-flow: row; grid-template-columns: 1fr 1fr; gap: 8px; padding: 12px 16px; }
  .panel-body-embed { padding: 14px 16px; }
  .summary { padding: 12px 16px 14px; }
  .summary-total .val { font-size: 30px; }
  .ral-grid { grid-template-columns: repeat(4, 1fr); }
  .strip-row { grid-template-columns: 1fr; }
  .hide-xs { display: none !important; }
}

/* ═════════════════ MOBILE — wzmocnione reguły dla /konfigurator.html ═════════════════ */
@media (max-width: 900px) {
  /* Widget scrollowalny w ramach wrap, pełna szerokość na mobile */
  .aluvio-konfigurator .configurator {
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 24px -12px rgba(10,10,10,.1);
  }

  .configurator-head {
    padding: 14px 16px 10px !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  .configurator-eyebrow { font-size: 9px !important; }
  .configurator-title { font-size: 22px !important; letter-spacing: -.4px !important; }
  .configurator-sub { font-size: 11px !important; }
  .configurator-head-actions { justify-content: flex-end !important; }
  .view-toggle button { padding: 6px 10px !important; font-size: 11px !important; gap: 4px !important; }

  /* Stepper — ukryj teksty label, zostaw tylko numery */
  .stepper-header {
    padding: 10px 14px !important;
    gap: 3px !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
    flex-wrap: nowrap !important;
  }
  .stepper-header::-webkit-scrollbar { display: none; }
  .stepper-item { flex: 0 0 auto !important; font-size: 11px !important; }
  .stepper-item .label {
    display: none !important;
  }
  .stepper-item.active .label {
    display: inline !important;
    font-size: 11px !important;
    margin-left: 6px !important;
    font-weight: 600 !important;
  }
  .stepper-item .num {
    width: 24px !important;
    height: 24px !important;
    font-size: 11px !important;
  }
  .stepper-item .connector { width: 16px !important; }

  /* Step body — mniejszy padding, mniejsze fonty */
  .step-body { padding: 16px 16px 8px !important; }
  .step-heading { margin-bottom: 12px !important; }
  .step-kicker { font-size: 9px !important; }
  .step-title { font-size: 22px !important; letter-spacing: -.3px !important; margin-top: 2px !important; }
  .step-lede { font-size: 12px !important; line-height: 1.5 !important; margin-bottom: 16px !important; }

  /* Pola formularza */
  .field { margin-bottom: 14px !important; }
  .field-label { margin-bottom: 6px !important; }
  .field-label .name { font-size: 12px !important; }
  .field-label .help { font-size: 10px !important; }

  .numinput { padding: 2px !important; }
  .numinput input { font-size: 14px !important; padding: 8px 10px !important; }
  .numinput .unit { font-size: 10px !important; }
  .numinput .stepper button { width: 24px !important; height: 20px !important; }

  .slider { margin: 8px 0 4px !important; }
  .slider-bounds { font-size: 9px !important; }

  /* Segmented buttons (wymiary, tryb, pozycja słupków) */
  .seg button { padding: 7px 10px !important; font-size: 11px !important; min-width: 0 !important; }

  /* Counter */
  .counter button { width: 32px !important; height: 32px !important; }
  .counter .val { font-size: 16px !important; min-width: 40px !important; }

  /* Profile grid — 3 kolumny zamiast 5 */
  .profile-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 6px !important;
  }
  .profile-chip { padding: 8px 4px !important; }
  .profile-chip .label { font-size: 10px !important; }
  .profile-chip .price { font-size: 9px !important; }

  /* RAL grid — 5 kolumn */
  .ral-grid {
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 4px !important;
  }
  .ral-chip .code { font-size: 8px !important; padding: 2px 4px !important; }

  /* Step nav */
  .step-nav { padding: 10px 14px !important; gap: 8px !important; }
  .step-nav-btn { padding: 8px 12px !important; font-size: 11px !important; white-space: nowrap; }

  /* Summary footer */
  .summary { padding: 12px 16px 14px !important; }
  .summary-row { font-size: 11px !important; }
  .summary-total { padding: 12px 0 !important; }
  .summary-total .lbl { font-size: 11px !important; }
  .summary-total .val { font-size: 28px !important; }
  .summary-total .currency { font-size: 13px !important; }
  .cta-row { gap: 6px !important; }
  .cta-row .btn { padding: 12px 14px !important; font-size: 12px !important; }

  /* Profile list w SummaryStep */
  .profile-list-row {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
    padding: 10px 0 !important;
  }
  .profile-list-row .name { font-size: 12px !important; }
  .profile-list-row .sub { font-size: 10px !important; }
  .profile-list-row .qty { font-size: 11px !important; text-align: left !important; }

  /* Stage canvas — minimalna wysokość */
  .stage-embed { min-height: 280px !important; }
  .stage-canvas-embed {
    height: 320px !important;
    min-height: 260px !important;
    max-height: 380px !important;
    padding: 14px 14px 36px !important;
  }
  .stage-facts {
    padding: 10px 14px !important;
    grid-auto-flow: row !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 6px !important;
  }
  .stage-facts .fact { font-size: 8px !important; }
  .stage-facts .fact b { font-size: 11px !important; margin-top: 2px !important; }

  /* Warnings */
  .warnings { padding: 8px 14px !important; }
  .warning { font-size: 11px !important; padding: 8px 10px !important; }

  /* Fullscreen button — adjusted position */
  .konfig-cta-fullscreen { font-size: 11px !important; padding: 9px 14px !important; }
}

@media (max-width: 560px) {
  .configurator-title { font-size: 19px !important; }
  .step-title { font-size: 18px !important; }
  .stage-canvas-embed { height: 280px !important; padding: 10px 10px 32px !important; }
  .stage-facts { grid-template-columns: 1fr 1fr !important; gap: 6px !important; }
  .profile-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .ral-grid { grid-template-columns: repeat(4, 1fr) !important; }

  /* Ukryj label w stepperze nawet active — pokaż tylko numer krok X/5 */
  .stepper-item.active .label { display: none !important; }
  .step-kicker { font-size: 10px !important; }
}

