/* =============================================================
   FemMosaik e.V. — Sharepic Generator
   Design tokens (from femmosaik design system) + editor chrome.
   ============================================================= */

@import url("https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&display=swap");

@font-face { font-family:"Work Sans"; font-weight:300; font-style:normal; font-display:swap; src:url("assets/fonts/WorkSans-Light.ttf") format("truetype"); }
@font-face { font-family:"Work Sans"; font-weight:400; font-style:normal; font-display:swap; src:url("assets/fonts/WorkSans-Regular.ttf") format("truetype"); }
@font-face { font-family:"Work Sans"; font-weight:900; font-style:normal; font-display:swap; src:url("assets/fonts/WorkSans-Black.ttf") format("truetype"); }
@font-face { font-family:"Inter"; font-weight:400; font-style:normal; font-display:swap; src:url("assets/fonts/Inter-Regular.ttf") format("truetype"); }
@font-face { font-family:"Inter"; font-weight:400; font-style:italic; font-display:swap; src:url("assets/fonts/Inter-Italic.ttf") format("truetype"); }
@font-face { font-family:"Inter"; font-weight:500; font-style:normal; font-display:swap; src:url("assets/fonts/Inter-Medium.ttf") format("truetype"); }
@font-face { font-family:"Inter"; font-weight:700; font-style:normal; font-display:swap; src:url("assets/fonts/Inter-Bold.ttf") format("truetype"); }

:root {
  /* Brand palette */
  --lobster-pink:   #C65D67;
  --crimson-violet: #622447;
  --powder-blush:   #FEC1B5;
  --burnt-rose:     #8A3F3C;
  --deep-purple:    #532153;

  /* Mosaic tiles */
  --blush-50:  #FFF1EC;
  --blush-100: #FEDFD5;
  --blush-200: #FEC1B5;
  --blush-300: #F69E92;
  --rose-400:  #DC7B7A;
  --rose-500:  #C65D67;
  --rose-600:  #A94852;
  --rose-700:  #8A3F3C;
  --rose-800:  #6A2F2E;
  --plum-500:  #7A2E5A;
  --plum-600:  #622447;
  --plum-700:  #532153;
  --plum-800:  #3B1738;
  --plum-900:  #260E25;

  /* Neutrals */
  --paper:    #FBF6F2;
  --paper-2:  #F4EAE3;
  --ink-900:  #2B1421;
  --ink-700:  #4A2738;
  --ink-500:  #6E4459;
  --ink-300:  #A98699;
  --hairline:   rgba(83,33,83,0.16);
  --hairline-2: rgba(83,33,83,0.08);

  /* Semantic */
  --fg-1: var(--ink-900);
  --fg-2: var(--ink-700);
  --fg-3: var(--ink-500);
  --fg-mute: var(--ink-300);
  --fg-onDark: var(--paper);
  --bg: var(--paper);
  --bg-card: #FFFFFF;
  --accent: var(--plum-700);
  --accent-hover: var(--plum-800);
  --accent-press: var(--plum-900);
  --accent-fg: var(--paper);
  --accent-2: var(--rose-500);
  --accent-2-hover: var(--rose-600);

  /* Gradients */
  --gradient-mosaic: linear-gradient(135deg, #532153 0%, #622447 28%, #8A3F3C 58%, #C65D67 82%, #FEC1B5 100%);
  --gradient-warm:   linear-gradient(180deg, #FEC1B5 0%, #C65D67 60%, #8A3F3C 100%);
  --gradient-deep:   linear-gradient(180deg, #622447 0%, #532153 100%);

  --radius-xs: 4px; --radius-sm: 8px; --radius-md: 14px; --radius-lg: 22px; --radius-xl: 32px; --radius-pill: 999px;
  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px; --space-5: 24px; --space-6: 32px; --space-7: 48px; --space-8: 64px; --space-9: 96px;

  --shadow-sm: 0 1px 2px rgba(83,33,83,0.08), 0 1px 1px rgba(83,33,83,0.04);
  --shadow-md: 0 4px 10px rgba(83,33,83,0.08), 0 2px 4px rgba(83,33,83,0.06);
  --shadow-lg: 0 18px 40px -12px rgba(83,33,83,0.22), 0 6px 14px rgba(138,63,60,0.10);
  --shadow-glow: 0 0 0 4px rgba(198,93,103,0.20);

  --font-display: "Work Sans", "Helvetica Neue", Arial, sans-serif;
  --font-body:    "Inter", "Helvetica Neue", Arial, sans-serif;
  --font-mono:    "DM Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
}

/* =============================================================
   APP CHROME
   ============================================================= */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin:0; padding:0; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--fg-1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.app-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 28px;
  border-bottom: 1px solid var(--hairline-2);
  background: rgba(251,246,242,0.85);
  backdrop-filter: blur(14px);
  position: sticky; top: 0; z-index: 10;
}
.header-left { display: flex; align-items: center; gap: 18px; }
.back-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; border: 1.5px solid var(--hairline);
  font-family: var(--font-display); font-weight: 900;
  font-size: 13px; letter-spacing: 0.02em;
  color: var(--plum-700);
  cursor: pointer; padding: 7px 14px 7px 12px;
  border-radius: 999px;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.back-btn:hover { background: var(--blush-50); border-color: var(--plum-700); }
.back-btn:active { transform: scale(0.97); }
.brand { display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--fg-1); }
.brand img { border-radius: 50%; box-shadow: var(--shadow-sm); }
.brand-text { display:flex; flex-direction:column; line-height: 1.1; }
.brand-name { font-family: var(--font-display); font-weight: 900; font-size: 18px; letter-spacing: -0.01em; }
.brand-sub { font-family: var(--font-body); font-weight: 500; font-size: 12px; color: var(--fg-3); }
.app-eyebrow {
  font-family: var(--font-display); font-weight: 900; font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-2);
}

.app {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 0;
  flex: 1;
  min-height: 0;
}

/* View toggle */
[hidden] { display: none !important; }

/* =============================================================
   LANDING VIEW — gallery of all templates
   ============================================================= */
.view-landing {
  flex: 1;
  padding: 32px 28px 64px;
  background:
    radial-gradient(circle at 18% 0%, rgba(254,193,181,0.40), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(83,33,83,0.10), transparent 50%),
    var(--paper);
  overflow-y: auto;
  min-height: calc(100vh - 65px);
}
.landing-inner {
  max-width: 1240px;
  margin: 0 auto;
  width: 100%;
}
.landing-hero {
  text-align: center;
  padding: 56px 0 60px;
  max-width: 760px;
  margin: 0 auto;
}
.landing-eyebrow {
  font-family: var(--font-display); font-weight: 900;
  font-size: 13px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--rose-500);
}
.landing-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(40px, 6.5vw, 68px);
  line-height: 1.0; letter-spacing: -0.02em;
  margin: 14px 0 18px;
  color: var(--ink-900);
  text-wrap: balance;
}
.landing-sub {
  font-family: var(--font-body); font-weight: 400;
  font-size: 18px; line-height: 1.55;
  color: var(--fg-2);
  margin: 0; text-wrap: pretty;
}
.landing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 22px;
}
.landing-card {
  cursor: pointer;
  background: var(--bg-card);
  border: 1.5px solid var(--hairline-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  font-family: inherit; text-align: left; padding: 0;
  transition: transform .18s cubic-bezier(.2,.7,.2,1),
              box-shadow .18s ease,
              border-color .18s ease;
}
.landing-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-lg);
  border-color: var(--plum-700);
}
.landing-card:focus-visible {
  outline: none;
  box-shadow: var(--shadow-glow);
  border-color: var(--plum-700);
}
.landing-card-thumb {
  aspect-ratio: 1;
  position: relative; overflow: hidden;
  border-bottom: 1px solid var(--hairline-2);
  background: var(--paper-2);
}
.landing-card-thumb-inner { position: absolute; inset: 0; }
.landing-card-body {
  padding: 16px 18px 20px;
  display: flex; flex-direction: column; gap: 6px;
}
.landing-card-name {
  font-family: var(--font-display); font-weight: 900;
  font-size: 18px; letter-spacing: -0.01em;
  color: var(--ink-900);
}
.landing-card-desc {
  font-family: var(--font-body); font-weight: 400;
  font-size: 13.5px; line-height: 1.45;
  color: var(--fg-2);
  text-wrap: pretty;
}
.landing-footer {
  text-align: center;
  margin-top: 64px;
  font-family: var(--font-body);
  font-size: 13px; color: var(--fg-3);
}
.landing-footer p { margin: 0; }

/* ----- SIDEBAR ----- */
.sidebar {
  background: var(--paper);
  border-right: 1px solid var(--hairline-2);
  padding: 24px 20px 32px;
  overflow-y: auto;
  height: calc(100vh - 65px);
  position: sticky; top: 65px;
}
.sidebar::-webkit-scrollbar { width: 10px; }
.sidebar::-webkit-scrollbar-thumb { background: var(--hairline); border-radius: 999px; }

.panel + .panel { margin-top: 22px; padding-top: 22px; border-top: 1px solid var(--hairline-2); }
.panel-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-3); margin: 0 0 12px;
}

/* Current template indicator (replaces full grid in editor) */
.current-template-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  background: var(--bg-card);
  border: 1.5px solid var(--hairline-2);
  border-radius: var(--radius-md);
  padding: 10px 12px 10px 14px;
}
.current-template-name {
  font-family: var(--font-display); font-weight: 900;
  font-size: 16px; letter-spacing: -0.005em;
  color: var(--ink-900);
}
#changeTemplateBtn { padding: 4px 0; }

/* (legacy template chooser — kept for any other usage) */
.template-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.template-card {
  cursor: pointer; border: 1.5px solid var(--hairline-2); background: var(--bg-card);
  border-radius: var(--radius-md); padding: 0; overflow: hidden;
  font-family: var(--font-body); text-align: left;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.template-card:hover { border-color: var(--plum-700); box-shadow: var(--shadow-md); }
.template-card.is-active { border-color: var(--plum-700); box-shadow: var(--shadow-glow); }
.template-thumb { aspect-ratio: 1; position: relative; overflow: hidden; }
.template-thumb-inner { position: absolute; inset: 0; }
.template-name {
  display:block; font-family: var(--font-display); font-weight: 900;
  font-size: 12px; padding: 8px 10px; color: var(--fg-1);
  border-top: 1px solid var(--hairline-2);
}

/* Segmented control (format) */
.seg { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
.seg-item {
  cursor: pointer; background: var(--bg-card); border: 1.5px solid var(--hairline-2);
  border-radius: var(--radius-md); padding: 10px 6px;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  transition: border-color .15s ease, box-shadow .15s ease;
  font-family: var(--font-body);
}
.seg-item:hover { border-color: var(--plum-700); }
.seg-item.is-active { border-color: var(--plum-700); box-shadow: var(--shadow-glow); }
.seg-icon { width: 28px; height: 28px; display: grid; place-items: center; }
.ratio { background: var(--plum-700); border-radius: 3px; display:block; }
.ratio.r-1-1  { width: 22px; height: 22px; }
.ratio.r-9-16 { width: 14px; height: 24px; }
.ratio.r-16-9 { width: 24px; height: 14px; }
.seg-label { font-family: var(--font-display); font-weight: 900; font-size: 12px; color: var(--fg-1); }
.seg-sub   { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); }

/* Scheme chooser */
.scheme-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
@media (min-width: 1280px) { .scheme-grid { grid-template-columns: 1fr 1fr 1fr; } }
.scheme-card {
  cursor: pointer; border: 1.5px solid var(--hairline-2); background: var(--bg-card);
  border-radius: var(--radius-md); padding: 8px;
  display: flex; flex-direction: column; gap: 6px; align-items: stretch;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.scheme-card:hover { border-color: var(--plum-700); }
.scheme-card.is-active { border-color: var(--plum-700); box-shadow: var(--shadow-glow); }
.scheme-swatch { height: 28px; border-radius: var(--radius-sm); position: relative; overflow: hidden; }
.scheme-name { font-family: var(--font-display); font-weight: 900; font-size: 11px; color: var(--fg-1); text-align: center; letter-spacing: 0.04em; }

/* Fields */
.field-list { display: flex; flex-direction: column; gap: 12px; }
.field { display: flex; flex-direction: column; gap: 5px; }
.field-label {
  font-family: var(--font-display); font-weight: 900; font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-3);
}
.field-input, .field-textarea {
  font-family: var(--font-body); font-size: 14px; color: var(--fg-1);
  background: var(--bg-card); border: 1.5px solid var(--hairline-2);
  border-radius: var(--radius-sm); padding: 9px 12px; resize: vertical;
  width: 100%; line-height: 1.5;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.field-input:focus, .field-textarea:focus {
  outline: none; border-color: var(--plum-700); box-shadow: var(--shadow-glow);
}
.field-textarea { min-height: 64px; }
.field-counter { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); text-align: right; }

/* Dropzone */
.dropzone {
  display: block; cursor: pointer; border: 1.5px dashed var(--hairline);
  border-radius: var(--radius-md); padding: 18px; text-align: center;
  background: var(--bg-card); transition: border-color .15s ease, background .15s ease;
}
.dropzone:hover, .dropzone.is-drag { border-color: var(--plum-700); background: var(--blush-50); }
.dropzone-title { display: block; font-family: var(--font-display); font-weight: 900; font-size: 13px; color: var(--fg-1); }
.dropzone-sub   { display: block; font-family: var(--font-body); font-size: 12px; color: var(--fg-3); margin-top: 4px; }
.photo-actions  { display: flex; gap: 8px; margin-top: 10px; }

/* Toggle */
.toggle { display: flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; }
.toggle input { display: none; }
.toggle-track { width: 36px; height: 22px; background: var(--hairline); border-radius: 999px; position: relative; transition: background .15s ease; }
.toggle-knob { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: var(--paper); border-radius: 50%; box-shadow: var(--shadow-sm); transition: transform .15s ease; }
.toggle input:checked + .toggle-track { background: var(--plum-700); }
.toggle input:checked + .toggle-track .toggle-knob { transform: translateX(14px); }
.toggle-label { font-family: var(--font-body); font-size: 14px; color: var(--fg-1); }

/* Buttons */
.btn {
  font-family: var(--font-display); font-weight: 900; font-size: 14px;
  letter-spacing: 0.02em; border: 0; border-radius: var(--radius-pill);
  padding: 12px 20px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  transition: background .15s ease, box-shadow .15s ease, color .15s ease, transform .15s ease;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-primary { background: var(--accent); color: var(--accent-fg); box-shadow: var(--shadow-md); width: 100%; }
.btn-primary:hover:not(:disabled) { background: var(--accent-hover); box-shadow: var(--shadow-lg); }
.btn-primary:active:not(:disabled) { background: var(--accent-press); box-shadow: var(--shadow-sm); transform: scale(0.98); }
.btn-ghost { background: transparent; color: var(--plum-700); border: 1.5px solid var(--plum-700); width: 100%; }
.btn-ghost:hover:not(:disabled) { background: var(--blush-50); }
.btn-text { background: transparent; color: var(--plum-700); padding: 6px 0; text-decoration: underline; text-decoration-color: var(--rose-500); text-underline-offset: 3px; }
.btn-sm   { padding: 8px 14px; font-size: 12px; }
.panel.actions { display: flex; flex-direction: column; gap: 10px; }

/* ----- STAGE ----- */
.stage {
  display: flex; flex-direction: column;
  background:
    radial-gradient(circle at 20% 0%, rgba(254,193,181,0.35), transparent 60%),
    radial-gradient(circle at 100% 100%, rgba(83,33,83,0.10), transparent 50%),
    var(--paper-2);
  padding: 24px 32px 32px;
  min-height: calc(100vh - 65px);
  overflow: hidden;
}
.stage-bar {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 16px;
}
.stage-label { font-family: var(--font-display); font-weight: 900; font-size: 16px; color: var(--fg-1); }
.stage-dim   { font-family: var(--font-mono); font-size: 12px; color: var(--fg-3); }
.stage-frame {
  flex: 1; display: grid; place-items: center;
  min-height: 0; min-width: 0;
}
.stage-note { font-family: var(--font-body); font-size: 12px; color: var(--fg-3); text-align: center; margin: 14px 0 0; }

/* Canvas */
.canvas-wrap {
  /* sized in JS to match scaled canvas footprint */
  position: relative;
  filter: drop-shadow(0 30px 60px rgba(83,33,83,0.18));
}
.canvas {
  position: relative;
  background: var(--paper);
  overflow: hidden;
  transform-origin: top left;
  /* exact pixel dimensions set inline via JS */
}

/* =============================================================
   TEMPLATE STYLES — applied via [data-template] on .canvas
   Canvas reads --canvas-w / --canvas-h vars to scale spacing.
   All sizing relative to canvas height (or shorter side) so it
   reflows gracefully across 1:1, 9:16, 16:9.
   ============================================================= */

.canvas {
  --pad: calc(var(--unit) * 5);
  --gap: calc(var(--unit) * 2);
  color: var(--c-fg);
}

/* Per-scheme color tokens — set on the canvas via [data-scheme] */
.canvas[data-scheme="tief"] {
  --c-bg: var(--plum-700);
  --c-bg-2: var(--plum-800);
  --c-fg: var(--paper);
  --c-fg-soft: var(--blush-100);
  --c-accent: var(--rose-500);
  --c-accent-fg: var(--paper);
  --c-eyebrow: var(--blush-200);
}
.canvas[data-scheme="warm"] {
  --c-bg: var(--rose-700);
  --c-bg-2: var(--rose-800);
  --c-fg: var(--paper);
  --c-fg-soft: var(--blush-100);
  --c-accent: var(--blush-200);
  --c-accent-fg: var(--plum-800);
  --c-eyebrow: var(--blush-200);
}
.canvas[data-scheme="hell"] {
  --c-bg: var(--paper);
  --c-bg-2: var(--paper-2);
  --c-fg: var(--ink-900);
  --c-fg-soft: var(--fg-2);
  --c-accent: var(--plum-700);
  --c-accent-fg: var(--paper);
  --c-eyebrow: var(--rose-500);
}
.canvas[data-scheme="nacht"] {
  --c-bg: var(--plum-900);
  --c-bg-2: var(--plum-800);
  --c-fg: var(--paper);
  --c-fg-soft: var(--blush-100);
  --c-accent: var(--rose-500);
  --c-accent-fg: var(--paper);
  --c-eyebrow: var(--rose-400);
}
.canvas[data-scheme="rose"] {
  --c-bg: var(--rose-500);
  --c-bg-2: var(--rose-600);
  --c-fg: var(--paper);
  --c-fg-soft: var(--blush-100);
  --c-accent: var(--plum-700);
  --c-accent-fg: var(--paper);
  --c-eyebrow: var(--blush-200);
}
.canvas[data-scheme="blush"] {
  --c-bg: var(--blush-100);
  --c-bg-2: var(--blush-50);
  --c-fg: var(--plum-800);
  --c-fg-soft: var(--ink-700);
  --c-accent: var(--plum-700);
  --c-accent-fg: var(--paper);
  --c-eyebrow: var(--rose-600);
}
.canvas[data-scheme="sand"] {
  --c-bg: var(--paper-2);
  --c-bg-2: var(--blush-50);
  --c-fg: var(--ink-900);
  --c-fg-soft: var(--ink-700);
  --c-accent: var(--rose-700);
  --c-accent-fg: var(--paper);
  --c-eyebrow: var(--rose-700);
}
.canvas[data-scheme="pflaume"] {
  --c-bg: var(--plum-600);
  --c-bg-2: var(--plum-700);
  --c-fg: var(--paper);
  --c-fg-soft: var(--blush-100);
  --c-accent: var(--blush-200);
  --c-accent-fg: var(--plum-800);
  --c-eyebrow: var(--blush-300);
}
.canvas[data-scheme="mosaik"] {
  --c-bg: var(--gradient-mosaic);
  --c-bg-2: var(--plum-700);
  --c-fg: var(--paper);
  --c-fg-soft: var(--blush-100);
  --c-accent: var(--paper);
  --c-accent-fg: var(--plum-800);
  --c-eyebrow: var(--blush-100);
}

/* Common template scaffolding */
.tpl {
  width: 100%; height: 100%;
  display: flex; flex-direction: column;
  padding: var(--pad);
  background: var(--c-bg);
  color: var(--c-fg);
  position: relative;
}
.tpl-eyebrow {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.5);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--c-eyebrow);
}
.tpl-headline {
  font-family: var(--font-display); font-weight: 900;
  font-size: var(--fs-headline);
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-wrap: balance;
  color: var(--c-fg);
  margin: 0;
}
.tpl-body {
  font-family: var(--font-body); font-weight: 400;
  font-size: calc(var(--unit) * 1.8);
  line-height: 1.45;
  color: var(--c-fg-soft);
  text-wrap: pretty;
  margin: 0;
}
.tpl-cta {
  display: inline-flex; align-items: center; gap: calc(var(--unit) * 0.8);
  background: var(--c-accent); color: var(--c-accent-fg);
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.7);
  padding: calc(var(--unit) * 1.3) calc(var(--unit) * 2.6);
  border-radius: 999px;
  align-self: flex-start;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

/* Logo lockup */
.tpl-logo {
  display: flex; align-items: center; gap: calc(var(--unit) * 1);
}
.tpl-logo img {
  width: calc(var(--unit) * 3.6); height: calc(var(--unit) * 3.6);
  border-radius: 50%;
  flex-shrink: 0;
}
.tpl-logo-text {
  display: flex; flex-direction: column; line-height: 1.05;
}
.tpl-logo-name {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.45);
  letter-spacing: -0.005em;
  color: var(--c-fg);
}
.tpl-logo-sub {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 0.78);
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--c-eyebrow);
  margin-top: calc(var(--unit) * 0.3);
}

/* =============================================================
   TEMPLATE: manifest
   Big bold statement on solid color, eyebrow + headline + body + CTA.
   Layout: eyebrow at top, body-stack pushed to bottom via margin-top:auto,
   logo below it, then a mosaic stripe at the very bottom.
   ============================================================= */
.canvas[data-template="manifest"] .tpl {
  gap: calc(var(--unit) * 1.5);
  padding-bottom: calc(var(--pad) + var(--unit) * 1.2);
}
.canvas[data-template="manifest"] .tpl-headline {
  font-size: var(--fs-headline-xl);
}
.canvas[data-template="manifest"] .tpl-strip {
  position: absolute; left: 0; right: 0; bottom: 0; height: calc(var(--unit) * 1);
  background: var(--gradient-mosaic);
}
.canvas[data-template="manifest"] .tpl-body-stack {
  display: flex; flex-direction: column; gap: var(--gap);
  max-width: 92%;
  margin-top: auto;
}
.canvas[data-template="manifest"] .tpl-logo {
  margin-top: calc(var(--unit) * 2);
}

/* =============================================================
   TEMPLATE: event
   Event card — paper background, mosaic stripes, plum text.
   ============================================================= */
.canvas[data-template="event"] .tpl {
  padding: 0;
  background: var(--c-bg);
}
.canvas[data-template="event"] .tpl-stripe-top,
.canvas[data-template="event"] .tpl-stripe-bot {
  height: calc(var(--unit) * 1.2);
  background: var(--gradient-mosaic);
  flex-shrink: 0;
}
.canvas[data-template="event"] .tpl-inner {
  flex: 1; padding: var(--pad);
  display: flex; flex-direction: column; justify-content: space-between;
  gap: var(--gap);
  min-height: 0;
}
.canvas[data-template="event"] .tpl-event-meta {
  display: inline-flex; align-items: center; gap: calc(var(--unit) * 1);
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.6);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--c-accent);
}
.canvas[data-template="event"] .tpl-event-meta::before {
  content: ""; width: calc(var(--unit) * 3); height: 2px; background: var(--c-accent);
}
.canvas[data-template="event"] .tpl-body-stack {
  display: flex; flex-direction: column; gap: var(--gap);
  max-width: 95%;
}

/* =============================================================
   TEMPLATE: quote
   Big pull quote on tinted bg with mosaic watermark.
   ============================================================= */
.canvas[data-template="quote"] .tpl {
  justify-content: center;
  text-align: left;
  background:
    radial-gradient(circle at 80% 90%, rgba(254,193,181,0.18), transparent 55%),
    var(--c-bg);
}
.canvas[data-template="quote"] .tpl-watermark {
  position: absolute; inset: auto auto calc(var(--unit) * -2) calc(var(--unit) * -2);
  width: 70%; aspect-ratio: 1;
  background-image: url("assets/img/mosaic-pattern.svg");
  background-size: contain; background-repeat: no-repeat;
  opacity: 0.10;
  pointer-events: none;
}
.canvas[data-template="quote"] .tpl-quote {
  font-family: var(--font-display); font-weight: 900;
  font-size: var(--fs-headline);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--c-accent);
  text-wrap: balance;
  margin: 0;
}
.canvas[data-template="quote"] .tpl-quote::before { content: "„"; }
.canvas[data-template="quote"] .tpl-quote::after  { content: "“"; }
.canvas[data-template="quote"] .tpl-attribution {
  font-family: var(--font-body); font-weight: 500;
  font-size: calc(var(--unit) * 1.8);
  color: var(--c-fg-soft);
  margin-top: calc(var(--unit) * 3);
}
.canvas[data-template="quote"] .tpl-quote-stack {
  display: flex; flex-direction: column;
  max-width: 96%;
}

/* =============================================================
   TEMPLATE: photo
   Full-bleed photo with bottom plum protection gradient + text.
   ============================================================= */
.canvas[data-template="photo"] .tpl {
  padding: 0;
  background: var(--c-bg-2);
}
.canvas[data-template="photo"] .tpl-photo {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  background-color: var(--c-bg-2);
}
.canvas[data-template="photo"] .tpl-photo.empty {
  background-image:
    linear-gradient(135deg, rgba(83,33,83,0.6), rgba(138,63,60,0.6)),
    url("assets/img/mosaic-pattern.svg");
  background-size: cover, 60%;
  background-position: center, center;
  background-repeat: no-repeat;
}
.canvas[data-template="photo"] .tpl-shade {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(38,14,37,0.85) 100%);
}
.canvas[data-template="photo"] .tpl-content {
  position: relative; z-index: 2;
  padding: var(--pad);
  display: flex; flex-direction: column; justify-content: flex-end;
  gap: calc(var(--unit) * 2);
  height: 100%;
}
.canvas[data-template="photo"] .tpl-content .tpl-headline,
.canvas[data-template="photo"] .tpl-content .tpl-body,
.canvas[data-template="photo"] .tpl-content .tpl-eyebrow,
.canvas[data-template="photo"] .tpl-content .tpl-logo-name {
  color: var(--paper);
}
.canvas[data-template="photo"] .tpl-content .tpl-body {
  color: var(--blush-100);
}
.canvas[data-template="photo"] .tpl-body-stack {
  display: flex; flex-direction: column; gap: var(--gap);
  max-width: 92%;
}
.canvas[data-template="photo"] .tpl-content > .tpl-logo {
  align-self: flex-end;
}

/* =============================================================
   TEMPLATE: mosaic
   Full mosaic gradient hero — big centered headline on color.
   ============================================================= */
.canvas[data-template="mosaic"] .tpl {
  background: var(--gradient-mosaic);
  justify-content: center; align-items: center; text-align: center;
  padding-bottom: calc(var(--pad) + var(--unit) * 6);
}
.canvas[data-template="mosaic"] .tpl-eyebrow,
.canvas[data-template="mosaic"] .tpl-headline,
.canvas[data-template="mosaic"] .tpl-body {
  color: var(--paper);
}
.canvas[data-template="mosaic"] .tpl-eyebrow { color: var(--blush-100); }
.canvas[data-template="mosaic"] .tpl-headline {
  font-size: var(--fs-headline-xl);
  text-shadow: 0 calc(var(--unit) * 0.4) calc(var(--unit) * 1.5) rgba(38,14,37,0.25);
}
.canvas[data-template="mosaic"] .tpl-body {
  color: rgba(251,246,242,0.92);
  max-width: 80%;
}
.canvas[data-template="mosaic"] .tpl-cta {
  background: var(--paper); color: var(--plum-800);
  align-self: center;
}
.canvas[data-template="mosaic"] .tpl-stack {
  display: flex; flex-direction: column; align-items: center;
  gap: calc(var(--unit) * 1.6);
  max-width: 92%;
}
.canvas[data-template="mosaic"] .tpl-logo {
  position: absolute; bottom: var(--pad); left: 50%; transform: translateX(-50%);
}

/* Logo positions */
.tpl-logo--tl { position: absolute; top: var(--pad); left: var(--pad); }
.tpl-logo--tr { position: absolute; top: var(--pad); right: var(--pad); }
.tpl-logo--bl { position: absolute; bottom: var(--pad); left: var(--pad); }
.tpl-logo--br { position: absolute; bottom: var(--pad); right: var(--pad); }

/* =============================================================
   TEMPLATE: stat — giant number with caption + source
   ============================================================= */
.canvas[data-template="stat"] .tpl {
  justify-content: space-between;
}
.canvas[data-template="stat"] .tpl-stat-center {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: calc(var(--unit) * 2);
  margin: auto 0;
}
.canvas[data-template="stat"] .tpl-stat-number {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 14);
  line-height: 0.85;
  letter-spacing: -0.04em;
  color: var(--c-accent);
  text-shadow: 0 calc(var(--unit) * 0.3) calc(var(--unit) * 1.2) rgba(38,14,37,0.18);
}
.canvas[data-template="stat"] .tpl-stat-caption {
  font-family: var(--font-body); font-weight: 500;
  font-size: calc(var(--unit) * 2.4);
  line-height: 1.35;
  color: var(--c-fg);
  max-width: 86%;
  margin: 0;
  text-wrap: balance;
}
.canvas[data-template="stat"] .tpl-stat-source {
  font-family: var(--font-mono);
  font-size: calc(var(--unit) * 1.1);
  color: var(--c-fg-soft);
  opacity: 0.85;
}

/* =============================================================
   TEMPLATE: demands — numbered manifesto list
   ============================================================= */
.canvas[data-template="demands"] .tpl {
  gap: calc(var(--unit) * 2);
}
.canvas[data-template="demands"] .tpl-demands-header {
  display: flex; flex-direction: column; gap: calc(var(--unit) * 0.8);
}
.canvas[data-template="demands"] .tpl-headline {
  font-size: calc(var(--unit) * 3.4);
}
.canvas[data-template="demands"] .tpl-demands {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column;
  gap: calc(var(--unit) * 1.8);
  flex: 1;
}
.canvas[data-template="demands"] .tpl-demand {
  display: grid;
  grid-template-columns: calc(var(--unit) * 4) 1fr;
  gap: calc(var(--unit) * 1.5);
  align-items: baseline;
  padding-top: calc(var(--unit) * 1.4);
  border-top: 1px solid var(--c-fg-soft);
  opacity: 0.95;
}
.canvas[data-template="demands"] .tpl-demand-num {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 3.2);
  line-height: 1;
  color: var(--c-accent);
  letter-spacing: -0.02em;
}
.canvas[data-template="demands"] .tpl-demand-text {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 2.1);
  line-height: 1.18;
  color: var(--c-fg);
  letter-spacing: -0.01em;
  text-wrap: balance;
}
.canvas[data-template="demands"] .tpl-logo { margin-top: calc(var(--unit) * 1); }

/* =============================================================
   TEMPLATE: programm — multi-event date list
   ============================================================= */
.canvas[data-template="programm"] .tpl {
  gap: calc(var(--unit) * 1.5);
}
.canvas[data-template="programm"] .tpl-headline {
  font-size: calc(var(--unit) * 3.6);
}
.canvas[data-template="programm"] .tpl-programm {
  display: flex; flex-direction: column;
  flex: 1;
  margin-top: calc(var(--unit) * 1.2);
}
.canvas[data-template="programm"] .tpl-prog-row {
  display: grid;
  grid-template-columns: minmax(calc(var(--unit) * 9), auto) 1fr;
  gap: calc(var(--unit) * 2.4);
  align-items: baseline;
  padding: calc(var(--unit) * 1.6) 0;
  border-top: 1px solid var(--c-fg-soft);
}
.canvas[data-template="programm"] .tpl-prog-row:last-child {
  border-bottom: 1px solid var(--c-fg-soft);
}
.canvas[data-template="programm"] .tpl-prog-date {
  font-family: var(--font-mono); font-weight: 500;
  font-size: calc(var(--unit) * 1.9);
  color: var(--c-accent);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.canvas[data-template="programm"] .tpl-prog-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 2.0);
  line-height: 1.2;
  color: var(--c-fg);
  text-wrap: balance;
}

/* =============================================================
   TEMPLATE: carousel — slide N / total
   ============================================================= */
.canvas[data-template="carousel"] .tpl {
  justify-content: space-between;
}
.canvas[data-template="carousel"] .tpl-carousel-top {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: calc(var(--unit) * 2);
}
.canvas[data-template="carousel"] .tpl-slide-num {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.8);
  color: var(--c-fg-soft);
  background: transparent;
  border: 1.5px solid var(--c-fg-soft);
  border-radius: 999px;
  padding: calc(var(--unit) * 0.6) calc(var(--unit) * 1.4);
  letter-spacing: 0.04em;
  display: inline-flex; align-items: baseline; gap: calc(var(--unit) * 0.3);
  white-space: nowrap;
}
.canvas[data-template="carousel"] .tpl-slide-num-cur { color: var(--c-accent); }
.canvas[data-template="carousel"] .tpl-slide-num-sep { opacity: 0.5; }
.canvas[data-template="carousel"] .tpl-body-stack {
  display: flex; flex-direction: column; gap: var(--gap);
  margin: auto 0;
}
.canvas[data-template="carousel"] .tpl-headline {
  font-size: calc(var(--unit) * 4.0);
}
.canvas[data-template="carousel"] .tpl-carousel-bottom {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: calc(var(--unit) * 2);
}
.canvas[data-template="carousel"] .tpl-swipe {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.6);
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--c-accent);
}

/* =============================================================
   TEMPLATE: spotlight — photo + quote
   1:1 / 16:9 → photo left half · text right half
   9:16     → photo top half · text bottom half
   ============================================================= */
.canvas[data-template="spotlight"] .tpl {
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr;
}
.canvas[data-template="spotlight"][data-format="9:16"] .tpl {
  grid-template-columns: 1fr;
  grid-template-rows: 1fr 1fr;
}
.canvas[data-template="spotlight"] .tpl-spot-photo {
  background-size: cover; background-position: center;
  background-color: var(--c-bg-2);
}
.canvas[data-template="spotlight"] .tpl-spot-photo.empty {
  background-image:
    linear-gradient(135deg, rgba(98,36,71,0.65), rgba(138,63,60,0.65)),
    url("assets/img/mosaic-pattern.svg");
  background-size: cover, 70%;
  background-position: center, center;
  background-repeat: no-repeat;
}
.canvas[data-template="spotlight"] .tpl-spot-content {
  padding: var(--pad);
  display: flex; flex-direction: column; justify-content: center;
  gap: calc(var(--unit) * 1.5);
  background: var(--c-bg);
}
.canvas[data-template="spotlight"] .tpl-quote {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 3.0);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--c-accent);
  margin: 0;
  text-wrap: balance;
}
.canvas[data-template="spotlight"] .tpl-quote::before { content: "„"; }
.canvas[data-template="spotlight"] .tpl-quote::after  { content: "“"; }
.canvas[data-template="spotlight"] .tpl-spot-attr {
  margin-top: calc(var(--unit) * 2);
}
.canvas[data-template="spotlight"] .tpl-spot-name {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.9);
  color: var(--c-fg);
  letter-spacing: -0.005em;
}
.canvas[data-template="spotlight"] .tpl-spot-role {
  font-family: var(--font-body); font-weight: 500;
  font-size: calc(var(--unit) * 1.3);
  color: var(--c-fg-soft);
  margin-top: calc(var(--unit) * 0.3);
}
.canvas[data-template="spotlight"] .tpl-logo {
  position: absolute; bottom: var(--pad); right: var(--pad);
}

/* =============================================================
   TEMPLATE: savethedate — massive Tag/Monat
   ============================================================= */
.canvas[data-template="savethedate"] .tpl {
  align-items: center; text-align: center;
  gap: calc(var(--unit) * 2);
}
.canvas[data-template="savethedate"] .tpl-std-date {
  display: flex; flex-direction: column; align-items: center;
  margin: auto 0;
}
.canvas[data-template="savethedate"] .tpl-std-day {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 16);
  line-height: 0.82;
  letter-spacing: -0.05em;
  color: var(--c-fg);
}
.canvas[data-template="savethedate"] .tpl-std-month {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 3.0);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-accent);
  margin-top: calc(var(--unit) * 0.6);
}
.canvas[data-template="savethedate"] .tpl-body-stack {
  display: flex; flex-direction: column; align-items: center;
  gap: calc(var(--unit) * 0.8);
  max-width: 92%;
}
.canvas[data-template="savethedate"] .tpl-headline {
  font-size: calc(var(--unit) * 3.0);
  text-align: center;
}
.canvas[data-template="savethedate"] .tpl-body {
  text-align: center;
  font-size: calc(var(--unit) * 1.6);
}

/* =============================================================
   TEMPLATE: factmyth — Mythos (durchgestrichen) vs Fakt
   ============================================================= */
.canvas[data-template="factmyth"] .tpl {
  gap: calc(var(--unit) * 2.5);
}
.canvas[data-template="factmyth"] .tpl-fm-grid {
  flex: 1;
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: calc(var(--unit) * 1.5);
}
.canvas[data-template="factmyth"][data-format="16:9"] .tpl-fm-grid {
  grid-template-rows: 1fr;
  grid-template-columns: 1fr 1fr;
}
.canvas[data-template="factmyth"] .tpl-fm-side {
  padding: calc(var(--unit) * 2.4);
  border-radius: var(--radius-md);
  display: flex; flex-direction: column;
  gap: calc(var(--unit) * 1);
  justify-content: center;
}
.canvas[data-template="factmyth"] .tpl-fm-myth {
  background: var(--blush-100);
  color: var(--rose-800);
}
.canvas[data-template="factmyth"] .tpl-fm-fakt {
  background: var(--c-accent);
  color: var(--c-accent-fg);
}
.canvas[data-template="factmyth"][data-scheme="hell"] .tpl-fm-fakt {
  background: var(--plum-700);
  color: var(--paper);
}
.canvas[data-template="factmyth"] .tpl-fm-label {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 1.4);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.canvas[data-template="factmyth"] .tpl-fm-myth .tpl-fm-label { color: var(--rose-600); }
.canvas[data-template="factmyth"] .tpl-fm-text {
  font-family: var(--font-display); font-weight: 900;
  font-size: calc(var(--unit) * 2.4);
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin: 0;
  text-wrap: balance;
}
.canvas[data-template="factmyth"] .tpl-fm-myth .tpl-fm-text {
  text-decoration: line-through;
  text-decoration-color: var(--rose-500);
  text-decoration-thickness: calc(var(--unit) * 0.25);
  opacity: 0.85;
}

/* =============================================================
   TEMPLATE: slogan — big slogan over mosaic pattern bg
   ============================================================= */
.canvas[data-template="slogan"] .tpl {
  justify-content: center; align-items: center; text-align: center;
  background: var(--c-bg);
}
.canvas[data-template="slogan"] .tpl-slogan-pattern {
  position: absolute; inset: 0;
  background-image: url("assets/img/mosaic-pattern.svg");
  background-size: cover; background-position: center;
  opacity: 0.38;
}
.canvas[data-template="slogan"][data-scheme="hell"] .tpl-slogan-pattern {
  opacity: 0.18;
}
.canvas[data-template="slogan"] .tpl-slogan-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(83,33,83,0.45), rgba(38,14,37,0.65));
}
.canvas[data-template="slogan"][data-scheme="hell"] .tpl-slogan-overlay {
  background: linear-gradient(180deg, rgba(251,246,242,0.1), rgba(251,246,242,0.55));
}
.canvas[data-template="slogan"] .tpl-slogan-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; align-items: center;
  gap: calc(var(--unit) * 1.5);
  max-width: 92%;
}
.canvas[data-template="slogan"] .tpl-eyebrow {
  color: var(--c-eyebrow);
}
.canvas[data-template="slogan"] .tpl-headline {
  font-size: var(--fs-headline-xl);
  color: var(--c-fg);
  text-shadow: 0 calc(var(--unit) * 0.3) calc(var(--unit) * 1) rgba(38,14,37,0.25);
}
.canvas[data-template="slogan"][data-scheme="hell"] .tpl-headline {
  text-shadow: none;
}
.canvas[data-template="slogan"] .tpl-attribution {
  font-family: var(--font-body); font-weight: 500;
  font-size: calc(var(--unit) * 1.6);
  color: var(--c-fg-soft);
  margin-top: calc(var(--unit) * 1.2);
}
.canvas[data-template="slogan"] .tpl-logo {
  position: absolute; bottom: var(--pad); left: 50%; transform: translateX(-50%);
}

/* =============================================================
   FORMAT TUNING — adjusts default font sizes per aspect.
   These read --unit which is set inline by JS (unit = min(w,h) / 60).
   ============================================================= */
.canvas {
  --fs-headline:    calc(var(--unit) * 4.6);
  --fs-headline-xl: calc(var(--unit) * 5.6);
}
.canvas[data-format="9:16"] {
  --pad: calc(var(--unit) * 4.5);
  --fs-headline:    calc(var(--unit) * 5.0);
  --fs-headline-xl: calc(var(--unit) * 6.0);
}
.canvas[data-format="16:9"] {
  --pad: calc(var(--unit) * 4);
  --fs-headline:    calc(var(--unit) * 4.0);
  --fs-headline-xl: calc(var(--unit) * 4.8);
}

/* Hide logo */
.canvas.no-logo .tpl-logo { display: none; }

/* =============================================================
   PASSWORD GATE — fullscreen overlay shown until unlocked
   ============================================================= */
.gate {
  position: fixed; inset: 0;
  background:
    radial-gradient(circle at 20% 0%, rgba(254,193,181,0.30), transparent 55%),
    radial-gradient(circle at 100% 100%, rgba(83,33,83,0.30), transparent 50%),
    rgba(38,14,37,0.92);
  backdrop-filter: blur(18px);
  display: flex; align-items: center; justify-content: center;
  z-index: 1000;
  padding: 24px;
  animation: gate-fade-in 0.35s cubic-bezier(.2,.7,.2,1);
}
html[data-unlocked="1"] .gate { display: none; }
.gate.is-leaving {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}
@keyframes gate-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.gate-card {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 38px 36px 32px;
  max-width: 440px; width: 100%;
  box-shadow: var(--shadow-lg), 0 30px 80px rgba(38,14,37,0.4);
  text-align: center;
  border: 1px solid var(--hairline-2);
}
.gate-logo {
  border-radius: 50%;
  margin: 0 auto 18px;
  display: block;
  box-shadow: var(--shadow-md);
}
.gate-eyebrow {
  font-family: var(--font-display); font-weight: 900;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--rose-500);
}
.gate-title {
  font-family: var(--font-display); font-weight: 900;
  font-size: 22px; line-height: 1.15; letter-spacing: -0.01em;
  color: var(--ink-900);
  margin: 8px 0 6px;
}
.gate-sub {
  font-family: var(--font-body); font-weight: 400;
  font-size: 14px; line-height: 1.45; color: var(--fg-2);
  margin: 0 0 22px;
}
.gate-form { display: flex; flex-direction: column; gap: 12px; }
.gate-input {
  font-family: var(--font-body); font-size: 16px; font-weight: 500;
  background: var(--bg-card); border: 1.5px solid var(--hairline);
  border-radius: var(--radius-md); padding: 14px 16px;
  width: 100%; color: var(--ink-900);
  text-align: center;
  letter-spacing: 0.04em;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.gate-input:focus {
  outline: none; border-color: var(--plum-700); box-shadow: var(--shadow-glow);
}
.gate-error {
  font-family: var(--font-body); font-weight: 500;
  font-size: 13px; color: var(--rose-700);
  margin: 0; min-height: 1em;
}
.gate-submit { width: 100%; margin-top: 2px; }
.gate-card.shake {
  animation: gate-shake 0.45s cubic-bezier(.36,.07,.19,.97);
}
@keyframes gate-shake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(4px); }
  30%, 50%, 70% { transform: translateX(-8px); }
  40%, 60% { transform: translateX(8px); }
}
.visually-hidden {
  position: absolute; width: 1px; height: 1px;
  margin: -1px; padding: 0; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* =============================================================
   TOAST
   ============================================================= */
.toast {
  position: fixed; bottom: 28px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--plum-800); color: var(--paper);
  padding: 12px 22px; border-radius: 999px;
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  box-shadow: var(--shadow-lg);
  opacity: 0; pointer-events: none;
  transition: opacity .2s ease, transform .25s cubic-bezier(.2,.7,.2,1);
  z-index: 100;
}
.toast.is-show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* =============================================================
   RESPONSIVE
   ============================================================= */
@media (max-width: 960px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: static; height: auto; border-right: 0; border-bottom: 1px solid var(--hairline-2); }
  .stage { min-height: 60vh; }
}
