/* ── Tokens (mirrored from olliemicek.com) ──────────────────────── */
:root {
  --ink:    #0b0b09;
  --paper:  #f1ece0;
  --dim:    #e8e2d2;
  --muted:  #857e72;
  --acc:    oklch(0.52 0.22 25);
  --acc-fb: #c2461d;
  --err:    #c2461d;
  --mono:   'Space Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --bb:     'Bebas Neue', Impact, sans-serif;
  --sans:   'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { overflow-x: hidden; }
body {
  font: 400 13px/1.45 var(--sans);
  background: var(--paper);
  color: var(--ink);
  display: flex;
  height: 100vh;
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
}
::selection { background: var(--acc-fb); color: var(--paper); }

/* Signature grain overlay */
body::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 9990;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='250' height='250'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='250' height='250' filter='url(%23g)' opacity='0.06'/%3E%3C/svg%3E");
  background-size: 220px 220px;
  mix-blend-mode: overlay;
}

/* ── LAYOUT ─────────────────────────────────────────────────────── */
#panel {
  width: 340px; flex: none;
  background: var(--paper);
  border-right: 1px solid var(--ink);
  overflow-y: auto;
  padding: 22px 20px 110px;
  transition: transform 0.3s ease;
  position: relative; z-index: 2;
  counter-reset: grp;
  scrollbar-width: thin;
  scrollbar-color: var(--ink) transparent;
}
#panel::-webkit-scrollbar { width: 8px; }
#panel::-webkit-scrollbar-thumb { background: var(--ink); }

#stage {
  flex: 1; position: relative;
  display: flex; align-items: center; justify-content: center;
  padding: 32px;
  background:
    linear-gradient(rgba(11,11,9,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,11,9,.05) 1px, transparent 1px),
    var(--dim);
  background-size: 48px 48px, 48px 48px, 100% 100%;
}
#stage::after {
  content: '01 / OUTPUT';
  position: absolute; top: 14px; left: 18px;
  font: 700 10px/1 var(--mono);
  letter-spacing: .14em;
  color: var(--muted);
}
#stage.drag-over::before {
  content: 'DROP TO LOAD';
  position: absolute; inset: 14px;
  border: 2px dashed var(--acc-fb);
  display: flex; align-items: center; justify-content: center;
  font: 400 36px/1 var(--bb);
  letter-spacing: .08em;
  color: var(--acc-fb);
  background: rgba(241,236,224,.7);
  z-index: 3;
  pointer-events: none;
}
canvas {
  max-width: 100%; max-height: 100%;
  box-shadow: 4px 4px 0 0 var(--ink), 0 0 0 1px var(--ink);
  background: var(--paper);
  touch-action: none;
  cursor: grab;
  transition: transform 0.1s ease-out;
}

canvas:active {
  cursor: grabbing;
}

canvas.grabbing {
  cursor: grabbing;
}

/* Safe-area insets for canvas in fullscreen */
body:fullscreen #stage,
body:-webkit-full-screen #stage,
body:-moz-full-screen #stage {
  padding:
    env(safe-area-inset-top, 18px)
    env(safe-area-inset-right, 18px)
    env(safe-area-inset-bottom, 70px)
    env(safe-area-inset-left, 18px);
}

body.zen-mode:fullscreen #stage,
body.zen-mode:-webkit-full-screen #stage,
body.zen-mode:-moz-full-screen #stage {
  padding: 0;
}
canvas.has-media + .stage-empty,
.stage-empty.hidden { display: none; }

.stage-empty {
  position: absolute;
  text-align: center;
  color: var(--ink);
  max-width: 440px;
  padding: 28px 32px;
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 6px 6px 0 0 var(--ink);
}
.stage-empty .empty-mark {
  font: 700 11px/1 var(--mono);
  letter-spacing: .14em;
  color: var(--acc-fb);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.stage-empty .empty-head {
  font: 400 44px/1 var(--bb);
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-bottom: 12px;
}
.stage-empty .empty-sub {
  font: 400 12px/1.55 var(--mono);
  color: var(--ink);
  letter-spacing: .04em;
  margin-bottom: 16px;
}
.stage-empty .empty-sub b { color: var(--acc-fb); font-weight: 700; }
.stage-actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  margin: 18px 0 14px;
}
.stage-webcam-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 14px 22px;
  font-size: 12px;
  letter-spacing: .12em;
  background: var(--ink);
  color: var(--paper);
  box-shadow: 4px 4px 0 0 var(--acc-fb);
  transition: background .12s, color .12s, box-shadow .12s, transform .08s;
}
.stage-webcam-btn:hover {
  background: var(--acc-fb);
  border-color: var(--acc-fb);
  color: var(--paper);
  box-shadow: 4px 4px 0 0 var(--ink);
}
.stage-webcam-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0 0 var(--acc-fb);
}
.stage-upload-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 18px;
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--ink);
  font-size: 10px;
  letter-spacing: .1em;
  transition: background .12s, color .12s;
}
.stage-upload-btn:hover {
  background: var(--ink);
  color: var(--paper);
}
.stage-empty .empty-tip {
  font: 700 10px/1.4 var(--mono);
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .12em;
  padding-top: 14px;
  border-top: 1px solid var(--ink);
}
.camera-request {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 4;
  width: min(360px, calc(100vw - 40px));
  padding: 22px 24px;
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 6px 6px 0 0 var(--ink);
  text-align: center;
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, calc(-50% + 8px));
  transition: opacity .16s, transform .16s;
}
.camera-request.show {
  opacity: 1;
  transform: translate(-50%, -50%);
}
.camera-request .request-mark {
  margin-bottom: 10px;
  color: var(--acc-fb);
  font: 700 10px/1 var(--mono);
  letter-spacing: .14em;
  text-transform: uppercase;
}
.camera-request .request-head {
  margin-bottom: 8px;
  font: 400 30px/1 var(--bb);
  letter-spacing: .04em;
  text-transform: uppercase;
}
.camera-request .request-sub {
  color: var(--muted);
  font: 700 10px/1.45 var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
}
@media (max-width: 768px) {
  .stage-empty {
    max-width: 360px;
    width: calc(100vw - 32px);
    padding: 26px 22px 22px;
  }
  .stage-empty .empty-head { font-size: 38px; margin-bottom: 10px; }
  .stage-empty .empty-sub { margin-bottom: 18px; }
  .stage-empty .empty-tip { display: none; }
  .stage-actions { margin: 4px 0 6px; gap: 10px; }
  .stage-webcam-btn {
    width: 100%;
    min-height: 56px;
    padding: 18px 20px;
    font-size: 13px;
    letter-spacing: .14em;
    box-shadow: 5px 5px 0 0 var(--acc-fb);
  }
  .stage-webcam-btn:active {
    box-shadow: 2px 2px 0 0 var(--acc-fb);
  }
  .stage-upload-btn {
    width: 100%;
    min-height: 48px;
    padding: 14px 20px;
    font-size: 11px;
  }
  .camera-request { width: min(320px, calc(100vw - 32px)); padding: 20px; }
  .camera-request .request-head { font-size: 26px; }
}

/* ── HEADER ─────────────────────────────────────────────────────── */
h1 {
  font: 400 28px/1 var(--bb);
  letter-spacing: .04em;
  text-transform: uppercase;
  margin: 0 0 20px;
  display: flex; align-items: baseline; gap: 10px;
}
h1::before {
  content: '[~/]';
  font: 700 11px/1 var(--mono);
  color: var(--acc-fb);
  letter-spacing: 0;
  align-self: center;
}

/* ── GROUPS ─────────────────────────────────────────────────────── */
.grp {
  border-top: 1px solid var(--ink);
  padding: 14px 0 14px;
  margin: 0;
}
.grp:first-of-type { border-top: none; padding-top: 0; }

.grp h2 {
  font: 700 10px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--ink);
  margin: 0 0 14px;
  display: flex; align-items: center; gap: 8px;
  counter-increment: grp;
}
.grp h2::before {
  content: '[' counter(grp, decimal-leading-zero) ']';
  color: var(--muted);
  font-weight: 400;
}

/* ── LABELS / VALUES ───────────────────────────────────────────── */
label {
  display: block;
  margin: 12px 0 5px;
  color: var(--muted);
  font: 400 10px/1.4 var(--mono);
  letter-spacing: .1em;
  text-transform: uppercase;
}
.row { display: flex; align-items: center; gap: 8px; }
.row label { margin: 0; flex: 1; }
.val {
  font: 700 11px/1 var(--mono);
  font-variant-numeric: tabular-nums;
  min-width: 40px; text-align: right;
  color: var(--ink);
}

/* ── RANGE SLIDERS ─────────────────────────────────────────────── */
input[type=range] {
  -webkit-appearance: none; appearance: none;
  width: 100%; background: transparent; height: 18px;
  margin: 4px 0 2px;
}
input[type=range]::-webkit-slider-runnable-track { height: 1px; background: var(--ink); }
input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  height: 14px; width: 14px;
  background: var(--paper);
  border: 1.5px solid var(--ink);
  border-radius: 50%;
  margin-top: -7px;
  cursor: pointer;
  transition: background .14s, border-color .14s, transform .14s;
}
input[type=range]:hover::-webkit-slider-thumb { background: var(--acc-fb); border-color: var(--acc-fb); }
input[type=range]:active::-webkit-slider-thumb { transform: scale(1.1); }
input[type=range]::-moz-range-track { height: 1px; background: var(--ink); border: none; }
input[type=range]::-moz-range-thumb {
  height: 14px; width: 14px;
  background: var(--paper); border: 1.5px solid var(--ink); border-radius: 50%;
  cursor: pointer;
}

/* ── INPUTS ────────────────────────────────────────────────────── */
input[type=file] {
  width: 100%;
  font: 10px/1.2 var(--mono);
  color: var(--muted);
  letter-spacing: .04em;
}
input[type=file]::file-selector-button {
  background: var(--paper); color: var(--ink);
  border: 1px solid var(--ink); border-radius: 0;
  padding: 6px 10px; margin-right: 8px;
  font: 700 10px/1 var(--mono);
  text-transform: uppercase; letter-spacing: .08em;
  cursor: pointer;
  transition: background .12s, color .12s;
}
input[type=file]::file-selector-button:hover { background: var(--ink); color: var(--paper); }

input[type=color] {
  width: 28px; height: 26px; padding: 0;
  border: 1px solid var(--ink); background: none; border-radius: 0;
  cursor: pointer; flex: none;
}
input[type=text] {
  width: 100%; padding: 8px 10px;
  background: transparent; color: var(--ink);
  border: 1px solid var(--ink); border-radius: 0;
  font: 400 11px/1.2 var(--mono);
}
input[type=text]:focus { outline: none; border-color: var(--acc-fb); }
input[type=checkbox] { accent-color: var(--ink); cursor: pointer; }

/* ── SELECT / BUTTON ───────────────────────────────────────────── */
select, button {
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--ink);
  border-radius: 0;
  padding: 8px 10px;
  font: 700 10px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .1em;
  cursor: pointer;
  transition: background .12s, color .12s, transform .08s;
  -webkit-appearance: none; appearance: none;
}
select {
  background-image: linear-gradient(45deg, transparent 50%, var(--ink) 50%),
                    linear-gradient(135deg, var(--ink) 50%, transparent 50%);
  background-position: calc(100% - 12px) 50%, calc(100% - 8px) 50%;
  background-size: 4px 4px, 4px 4px;
  background-repeat: no-repeat;
  padding-right: 22px;
}
button:hover, select:hover {
  background-color: var(--ink);
  color: var(--paper);
}
select:hover {
  background-image: linear-gradient(45deg, transparent 50%, var(--paper) 50%),
                    linear-gradient(135deg, var(--paper) 50%, transparent 50%);
}
button:active { transform: translateY(1px); }
button:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  background: var(--paper);
  color: var(--ink);
  transform: none;
}
*:focus-visible { outline: 2px solid var(--acc-fb); outline-offset: 2px; }

/* ── SEGMENTED ─────────────────────────────────────────────────── */
.seg { display: flex; }
.seg button { flex: 1; border-right: none; }
.seg button:last-child { border-right: 1px solid var(--ink); }
.seg button.on { background: var(--ink); color: var(--paper); }

/* ── SHAPE ROWS ────────────────────────────────────────────────── */
.svgrow { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; }
.svgrow span {
  width: 70px; flex: none;
  font: 700 9px/1.2 var(--mono);
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted);
}
.svgrow select { flex: 1; min-width: 0; font-size: 10px; padding: 7px 22px 7px 8px; letter-spacing: .06em; }

/* ── HINT ──────────────────────────────────────────────────────── */
.hint {
  color: var(--muted);
  font: 400 10px/1.55 var(--mono);
  margin-top: 8px;
  letter-spacing: .02em;
}
.hint em { color: var(--ink); font-style: normal; font-weight: 700; }

/* ── PRESET / EXPORT GRID ──────────────────────────────────────── */
.preset-grid button, .export-grid button { font-size: 9px; padding: 8px 6px; }

.random-preset-btn {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
  box-shadow: 3px 3px 0 0 var(--acc-fb);
  letter-spacing: .14em;
}
.random-preset-btn:hover {
  background: var(--acc-fb);
  border-color: var(--acc-fb);
  color: var(--paper);
  box-shadow: 3px 3px 0 0 var(--ink);
}
.random-preset-btn:active {
  transform: translate(1px, 1px);
  box-shadow: 2px 2px 0 0 var(--acc-fb);
}

/* ── TOAST ─────────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 24px; right: 24px;
  z-index: 10000;
  background: var(--ink); color: var(--paper);
  padding: 11px 16px;
  font: 700 11px/1.3 var(--mono);
  text-transform: uppercase; letter-spacing: .1em;
  opacity: 0; transform: translateY(10px);
  transition: opacity .2s, transform .2s;
  pointer-events: none;
  border: 1px solid var(--ink);
}
.toast.show { opacity: 1; transform: translateY(0); }
.toast.error { background: var(--acc-fb); border-color: var(--acc-fb); }

/* ── LOADING ───────────────────────────────────────────────────── */
.loading-overlay {
  position: fixed; inset: 0;
  background: rgba(241,236,224,.88);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.loading-overlay.show { opacity: 1; pointer-events: all; }
.spinner {
  width: 40px; height: 40px;
  border: 1.5px solid var(--ink);
  border-top-color: var(--acc-fb);
  border-radius: 50%;
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loading-text {
  margin-top: 16px;
  font: 700 11px/1 var(--mono);
  text-transform: uppercase; letter-spacing: .14em;
  color: var(--ink);
}

/* ── STATS ─────────────────────────────────────────────────────── */
.stats {
  position: fixed; top: 14px; right: 16px;
  font: 700 10px/1.2 var(--mono);
  color: var(--muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  pointer-events: none;
  z-index: 10;
}

/* ── MOBILE TOGGLE ─────────────────────────────────────────────── */
.mobile-toggle {
  position: fixed; top: 12px; left: 12px;
  z-index: 1001;
  display: none;
  background: var(--paper); color: var(--ink);
  border: 1px solid var(--ink); border-radius: 0;
  padding: 9px 14px;
  font: 700 11px/1 var(--mono);
  text-transform: uppercase; letter-spacing: .1em;
  cursor: pointer;
}

/* ── MOBILE CONTROLS BAR ───────────────────────────────────────────── */
.mobile-controls {
  position: fixed; bottom: 0; left: 0; right: 0;
  display: none;
  align-items: center; justify-content: space-between;
  padding:
    calc(env(safe-area-inset-bottom, 0px) + 12px)
    calc(env(safe-area-inset-left, 0px) + 12px)
    calc(env(safe-area-inset-bottom, 0px) + 12px)
    calc(env(safe-area-inset-right, 0px) + 12px);
  background: var(--paper);
  border-top: 1px solid var(--ink);
  z-index: 999;
  gap: 8px;
}

.mobile-controls button {
  flex: 1;
  min-height: 44px;
  padding: 10px 12px;
  font-size: 10px;
}

/* ── ZEN MODE ─────────────────────────────────────────────────────── */
body.zen-mode #panel,
body.zen-mode .mobile-toggle,
body.zen-mode .mobile-controls,
body.zen-mode footer.credit,
body.zen-mode .stats,
body.zen-mode .hire-card {
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s, transform .25s;
  transform: translateY(10px);
}

body.zen-mode #stage {
  padding: 0;
}

body.zen-mode #stage::after {
  display: none;
}

/* ── FULLSCREEN ────────────────────────────────────────────────────── */
body:fullscreen #stage,
body:-webkit-full-screen #stage,
body:-moz-full-screen #stage {
  padding: 0;
}

body:fullscreen .mobile-controls,
body:-webkit-full-screen .mobile-controls,
body:-moz-full-screen .mobile-controls {
  position: fixed;
  bottom: 0;
}

/* ── HELP ICON ─────────────────────────────────────────────────── */
.help-icon {
  display: inline-flex; width: 14px; height: 14px;
  margin-left: 6px;
  align-items: center; justify-content: center;
  background: var(--ink); color: var(--paper);
  border-radius: 50%;
  font: 700 9px/1 var(--mono);
  cursor: help;
}

/* ── MODAL ─────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(11,11,9,.55);
  display: flex; align-items: center; justify-content: center;
  z-index: 10000;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.modal-overlay.show { opacity: 1; pointer-events: all; }
.modal {
  background: var(--paper);
  border: 1px solid var(--ink);
  box-shadow: 6px 6px 0 0 var(--ink);
  padding: 26px 28px;
  max-width: 520px; max-height: 82vh;
  overflow-y: auto;
}
.modal h2 {
  margin: 0 0 18px;
  font: 400 24px/1 var(--bb);
  text-transform: uppercase; letter-spacing: .04em;
}
.modal p {
  margin: 0 0 9px;
  font: 400 11px/1.55 var(--mono);
  color: var(--ink);
  letter-spacing: .02em;
}
.modal kbd {
  display: inline-block;
  padding: 3px 8px;
  border: 1px solid var(--ink);
  background: var(--paper);
  font: 700 10px/1.2 var(--mono);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-right: 3px;
}

/* ── FOOTER ────────────────────────────────────────────────────── */
footer.credit {
  position: fixed; bottom: 12px; right: 18px;
  font: 700 10px/1 var(--mono);
  color: var(--muted);
  text-transform: uppercase; letter-spacing: .14em;
  z-index: 5;
  pointer-events: auto;
}
footer.credit a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 1px;
  transition: color .12s, border-color .12s;
}
footer.credit a:hover { color: var(--acc-fb); border-bottom-color: var(--acc-fb); }

/* ── HIRE CTA CARD ─────────────────────────────────────────────── */
.hire-card {
  position: absolute;
  bottom: 22px; right: 22px;
  width: 260px;
  background: var(--paper);
  color: var(--ink);
  border: 1px solid var(--ink);
  box-shadow: 5px 5px 0 0 var(--ink);
  padding: 16px 18px 14px;
  z-index: 6;
  transition: transform .18s, box-shadow .18s;
}
.hire-card:hover {
  transform: translate(-1px, -1px);
  box-shadow: 6px 6px 0 0 var(--ink);
}
.hire-card.dismissed { display: none; }
.hire-tag {
  font: 700 9px/1 var(--mono);
  letter-spacing: .18em;
  color: var(--acc-fb);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.hire-head {
  font: 400 26px/.95 var(--bb);
  text-transform: uppercase;
  letter-spacing: .03em;
  margin-bottom: 8px;
}
.hire-sub {
  font: 400 11px/1.45 var(--mono);
  color: var(--ink);
  letter-spacing: .02em;
  margin-bottom: 12px;
}
.hire-cta {
  display: inline-block;
  font: 700 11px/1 var(--mono);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--ink);
  text-decoration: none;
  padding: 8px 12px;
  border: 1px solid var(--ink);
  transition: background .12s, color .12s;
}
.hire-cta:hover { background: var(--ink); color: var(--paper); }
.hire-close {
  position: absolute; top: 4px; right: 4px;
  width: 22px; height: 22px;
  min-height: 0;
  background: transparent; border: none;
  font: 400 18px/1 var(--mono);
  color: var(--muted);
  padding: 0; cursor: pointer;
  letter-spacing: 0;
}
.hire-close:hover { background: transparent; color: var(--ink); }

/* Record button live styling */
button.recording {
  background: var(--acc-fb) !important;
  color: var(--paper) !important;
  border-color: var(--acc-fb) !important;
}

/* ── BACKDROP ─────────────────────────────────────────────────── */
.panel-backdrop {
  position: fixed; inset: 0;
  background: rgba(11,11,9,.6);
  z-index: 999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s;
  display: none;
}

/* ── RESPONSIVE ────────────────────────────────────────────────── */
@media (max-width: 768px) {
  body { font-size: 14px; }

  #panel {
    position: absolute; height: 100%;
    transform: translateX(-100%);
    z-index: 1000;
    width: 88vw; max-width: 360px;
    box-shadow: 4px 0 0 0 var(--ink);
    padding:
      calc(env(safe-area-inset-top, 0px) + 64px)
      calc(env(safe-area-inset-left, 0px) + 18px)
      calc(env(safe-area-inset-bottom, 0px) + 110px)
      calc(env(safe-area-inset-left, 0px) + 18px);
  }
  #panel.open { transform: translateX(0); }

  .panel-backdrop { display: block; }
  .panel-backdrop.show { opacity: 1; pointer-events: auto; }

  .mobile-toggle {
    display: flex;
    top: calc(env(safe-area-inset-top, 0px) + 12px);
    left: calc(env(safe-area-inset-left, 0px) + 12px);
    padding: 12px 16px;
    min-height: 44px;
    box-shadow: 2px 2px 0 0 var(--ink);
  }

  .mobile-controls {
    display: flex;
  }

  #stage {
    padding:
      calc(env(safe-area-inset-top, 0px) + 18px)
      calc(env(safe-area-inset-right, 0px) + 18px)
      calc(env(safe-area-inset-bottom, 0px) + 70px)
      calc(env(safe-area-inset-left, 0px) + 18px);
    background-size: 36px 36px, 36px 36px, 100% 100%;
  }
  #stage::after { display: none; }

  /* Touch-friendly controls */
  button, select { min-height: 44px; padding: 12px 12px; font-size: 11px; }
  .svgrow select { min-height: 40px; font-size: 11px; padding: 10px 24px 10px 10px; }
  .svgrow span { width: 60px; font-size: 9px; }
  .preset-grid button, .export-grid button { min-height: 44px; font-size: 10px; padding: 10px 4px; }

  input[type=range] { height: 40px; margin: 6px 0; }
  input[type=range]::-webkit-slider-thumb { height: 22px; width: 22px; margin-top: -11px; }
  input[type=range]::-moz-range-thumb { height: 22px; width: 22px; }

  input[type=color] { width: 44px; height: 44px; }
  input[type=text] { padding: 12px 12px; font-size: 14px; min-height: 44px; }
  input[type=checkbox] { width: 20px; height: 20px; }
  input[type=file]::file-selector-button { min-height: 38px; padding: 10px 12px; }

  /* Sticky bottom safe-area for footer */
  footer.credit {
    bottom: calc(env(safe-area-inset-bottom, 0px) + 12px);
    right: calc(env(safe-area-inset-right, 0px) + 16px);
  }

  .stats {
    top: calc(env(safe-area-inset-top, 0px) + 14px);
    right: calc(env(safe-area-inset-right, 0px) + 14px);
  }

  h1 { font-size: 26px; margin-bottom: 16px; }
  .grp { padding: 12px 0; }
  .grp h2 { font-size: 11px; margin-bottom: 12px; }
}

@media (max-width: 480px) {
  .preset-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .hire-card { width: calc(100vw - 24px); right: 12px; bottom: 12px; padding: 12px 14px; }
  .hire-head { font-size: 22px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0s !important;
  }
}
