/* screens.css — hub + session styling */
/* ===== Groove-Station (DMGrooveStation) ===== */
/* picker (same pattern as the effect picker) */
.gstation-pick { position: fixed; inset: 0; z-index: 1; background: var(--bg); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: clamp(14px,3vh,28px); padding: clamp(16px,4vmin,40px); overflow: hidden; }
.gstation-head { text-align: center; max-width: 760px; }
.gstation-title { margin: 0; font-family: var(--f-head); font-weight: 800; color: var(--text); font-size: clamp(24px,3.4vw,38px); }
.gstation-sub { margin: 6px 0 0; color: var(--text-muted); font-size: clamp(14px,1.9vw,19px); line-height: 1.4; }
.gstation-setgrid { display: grid; grid-template-columns: repeat(2, minmax(220px,1fr)); gap: clamp(10px,1.6vw,18px); width: min(840px,94vw); }
.gset-tile { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; min-height: clamp(120px,22vh,180px); padding: clamp(12px,2vmin,22px); border-radius: var(--radius-lg); background: var(--surface-2); border: 2px solid var(--border); color: var(--text); cursor: pointer; text-align: center; transition: transform .08s ease, border-color .12s ease; }
.gset-tile:hover { border-color: var(--accent); transform: translateY(-2px); }
.gset-ic { width: 64px; height: 64px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--cat,var(--accent)) 18%, transparent); color: var(--cat,var(--accent)); }
.gset-tile.cat-rhythmus { --cat: #e8302e; } .gset-tile.cat-melodie { --cat: #f5b300; } .gset-tile.cat-klang { --cat: #6cbfe2; }
.gset-name { font-family: var(--f-head); font-weight: 800; font-size: clamp(17px,2.1vw,23px); }
.gset-meta { font-size: clamp(12px,1.5vw,16px); color: var(--text-muted); }
.gstation-pick .gstation-back, .gstation-page .gstation-back { z-index: 6; }

/* live mixer */
.gstation-page { position: fixed; inset: 0; z-index: 1; background: var(--bg); display: flex; flex-direction: column; overflow: hidden; padding: clamp(10px,2vmin,18px); }
.gstation-page[data-cat="klang"] { background: color-mix(in srgb, #6cbfe2 10%, var(--bg)); }
.gstation-bar { flex: 0 0 auto; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: center; padding-bottom: 8px; }
.gstation-switch { display: inline-flex; align-items: center; gap: 10px; min-height: var(--tap); padding: 0 22px; border-radius: 999px; font-family: var(--f-head); font-weight: 800; font-size: clamp(15px,1.9vw,20px); color: var(--text); background: var(--surface-2); border: 1.5px solid var(--border-strong); }
.gstation-switch-hint { font-size: .72em; font-weight: 700; color: var(--accent); border: 1.5px solid var(--accent); border-radius: 999px; padding: 2px 10px; }
.gstation-beats { display: flex; gap: 8px; }
.gbeat { width: 16px; height: 16px; border-radius: 50%; background: var(--border-strong); transition: transform .08s ease, background .08s ease; }
.gbeat.on { background: var(--accent); transform: scale(1.35); }
.gstation-info { color: var(--text-muted); font-size: clamp(13px,1.6vw,17px); }
.gstation-clear { display: inline-flex; align-items: center; gap: 8px; min-height: var(--tap); padding: 0 18px; border-radius: 999px; font-family: var(--f-head); font-weight: 700; font-size: clamp(14px,1.7vw,18px); color: var(--text); background: var(--surface-2); border: 1.5px solid var(--border); }
.gstation-net { display: inline-flex; align-items: center; gap: 8px; min-height: var(--tap); padding: 0 18px; border-radius: 999px; font-family: var(--f-head); font-weight: 800; font-size: clamp(14px,1.7vw,18px); color: var(--text); background: var(--surface-2); border: 1.5px solid var(--border-strong); }
.gstation-net.on { background: var(--ok); color: #fff; border-color: var(--ok); }
.gstation-netbanner { flex: 0 0 auto; text-align: center; color: var(--text); background: color-mix(in srgb, var(--ok) 16%, transparent); border: 1px solid color-mix(in srgb, var(--ok) 45%, transparent); border-radius: 999px; margin: 0 auto 6px; padding: 6px 18px; font-size: clamp(13px,1.7vw,17px); }
.gstation-netpanel { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 7; display: flex; flex-direction: column; align-items: center; gap: 12px; padding: clamp(18px,3vmin,28px); border-radius: var(--radius-lg); background: var(--surface-flat); border: 2px solid var(--border-strong); box-shadow: var(--shadow); min-width: min(420px,90vw); }
.gstation-netttl { margin: 0; font-family: var(--f-head); font-weight: 800; color: var(--text); font-size: clamp(20px,2.6vw,26px); }
.gstation-netor { color: var(--text-muted); font-size: clamp(13px,1.6vw,16px); }
.gstation-netjoin { display: flex; align-items: center; gap: 8px; }
.gstation-netinput { min-height: var(--tap); width: clamp(120px,30vw,180px); text-align: center; font-size: clamp(18px,2.4vw,26px); letter-spacing: .12em; text-transform: uppercase; border-radius: var(--radius); border: 2px solid var(--border-strong); background: var(--surface-2); color: var(--text); padding: 0 12px; }
.gstation-hint { flex: 0 0 auto; text-align: center; color: var(--text-muted); font-size: clamp(13px,1.7vw,17px); padding: 2px 0 10px; }
.gstation-grid { flex: 1 1 auto; display: grid; grid-template-columns: repeat(3, 1fr); grid-template-rows: repeat(2, 1fr); gap: clamp(8px,1.4vw,16px); min-height: 0; padding-bottom: calc(var(--ctl-min) + 50px); }
.glayer { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; border-radius: var(--radius-lg); border: 2px solid color-mix(in srgb, var(--c) 45%, var(--border)); background: var(--surface-2); color: var(--text); cursor: pointer; transition: transform .07s ease, box-shadow .12s ease, background .12s ease; min-height: 0; opacity: .82; }
.glayer:hover { border-color: var(--c); transform: translateY(-2px); }
.glayer.on { opacity: 1; background: color-mix(in srgb, var(--c) 22%, var(--surface-2)); box-shadow: inset 0 0 0 3px color-mix(in srgb, var(--c) 70%, transparent), 0 0 30px color-mix(in srgb, var(--c) 35%, transparent); }
.glayer-ic { width: 64px; height: 64px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--c) 28%, transparent); color: color-mix(in srgb, var(--c) 78%, var(--text)); }
.glayer-name { font-family: var(--f-head); font-weight: 800; font-size: clamp(16px,2vw,24px); }
.glayer-state { font-size: clamp(12px,1.5vw,16px); color: var(--text-muted); font-family: var(--f-mono); }
.glayer.on .glayer-state { color: color-mix(in srgb, var(--c) 80%, var(--text)); }
.gstation-overlay { position: absolute; inset: 0; z-index: 5; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; background: rgba(10,10,26,.55); color: #fff; font-family: var(--f-head); font-weight: 700; }

/* ===== Spaß-Pad (DMFunPad) ===== */
.funpad-page { position: fixed; inset: 0; z-index: 1; background: var(--bg); display: flex; flex-direction: column; overflow: hidden; padding: clamp(10px,2vmin,20px); }
.funpad-head { text-align: center; flex: 0 0 auto; padding: 4px 0 10px; }
.funpad-head .head { margin: 0; font-family: var(--f-head); font-weight: 800; color: var(--text); font-size: clamp(22px,3vw,34px); }
.funpad-head p { margin: 2px 0 0; color: var(--text-muted); font-size: clamp(13px,1.7vw,18px); }
.funpad-grid { flex: 1 1 auto; display: grid; grid-template-columns: repeat(4, 1fr); grid-template-rows: repeat(3, 1fr); gap: clamp(8px,1.4vw,16px); min-height: 0; padding-bottom: calc(var(--ctl-min) + 50px); }
.fun-tile { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; border-radius: var(--radius-lg); border: 2px solid color-mix(in srgb, var(--c) 55%, var(--border)); background: color-mix(in srgb, var(--c) 16%, var(--surface-2)); color: var(--text); cursor: pointer; transition: transform .07s ease, box-shadow .1s ease, background .1s ease; min-height: 0; }
.fun-tile:hover { border-color: var(--c); transform: translateY(-2px); }
.fun-tile.is-hit { transform: scale(.96); background: color-mix(in srgb, var(--c) 52%, var(--surface-2)); box-shadow: 0 0 0 4px color-mix(in srgb, var(--c) 60%, transparent), 0 0 40px color-mix(in srgb, var(--c) 45%, transparent); }
.fun-ic { width: 68px; height: 68px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--c) 30%, transparent); color: color-mix(in srgb, var(--c) 75%, var(--text)); }
.fun-name { font-family: var(--f-head); font-weight: 800; font-size: clamp(15px,2vw,24px); }
.funpad-page .funpad-back { position: fixed; left: 16px; bottom: 16px; z-index: 6; }

/* shared minimum size for fullscreen controls ≈ one 10×6 grid cell (no button smaller than 1×1) */
:root { --ctl-min: clamp(92px, 14.8vh, 118px); }

/* ===== First-run onboarding ===== */
.onb-scrim { position: fixed; inset: 0; z-index: 400; display: flex; align-items: center; justify-content: center; padding: 24px;
  background: color-mix(in srgb, var(--bg) 78%, transparent); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.onb-card { width: 100%; max-width: 680px; max-height: 92vh; overflow-y: auto; display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: 14px; padding: clamp(20px, 4vh, 40px) clamp(20px, 4vw, 48px); border-radius: var(--radius-lg);
  background: var(--card); border: 1.5px solid var(--border-strong); box-shadow: var(--shadow); }
.onb-logo { opacity: .95; }
.onb-icon { width: 88px; height: 88px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--accent); background: var(--accent-glow); }
.onb-title { font-family: var(--f-head); font-weight: 800; font-size: clamp(24px, 3.4vw, 34px); line-height: 1.12; }
.onb-text { font-size: clamp(17px, 2vw, 22px); line-height: 1.45; color: var(--text-dim); max-width: 30em; }
.onb-dots { display: flex; gap: 10px; margin: 4px 0 6px; }
.onb-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--surface-3); transition: background .2s, transform .2s; }
.onb-dot.on { background: var(--accent); transform: scale(1.3); }
.onb-actions { display: flex; gap: 12px; align-items: center; justify-content: center; flex-wrap: wrap; width: 100%; }
.onb-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 72px; padding: 0 30px; border-radius: 999px;
  font-family: var(--f-head); font-weight: 800; font-size: clamp(18px, 2.2vw, 23px); color: var(--text); background: var(--surface-2); border: 2px solid var(--border); }
.onb-btn:hover { border-color: var(--accent); color: var(--accent); }
.onb-btn.primary { background: var(--accent); color: var(--on-accent); border-color: var(--accent); padding: 0 40px; }
[data-theme="paper"] .onb-btn.primary { color: #fff; }
.onb-btn.ghost { background: transparent; color: var(--text-muted); }

/* ===== Guided tour (interactive onboarding) ===== */
.tour-scrim { position: fixed; inset: 0; z-index: 500; pointer-events: auto; }
.tour-scrim:not(.has-hole) { background: color-mix(in srgb, var(--bg) 62%, transparent); -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px); }
.tour-hole { position: fixed; border-radius: 16px; box-shadow: 0 0 0 4px var(--accent), 0 0 0 9999px rgba(10,10,26,.66); pointer-events: none; transition: all .25s ease; }
.tour-pop { position: fixed; width: min(420px, 92vw); z-index: 501; display: flex; flex-direction: column; gap: 10px; padding: 22px 24px;
  border-radius: var(--radius-lg); background: var(--card); border: 1.5px solid var(--border-strong); box-shadow: var(--shadow); }
.tour-step { font-size: 13px; font-weight: 700; letter-spacing: .04em; color: var(--accent); text-transform: uppercase; }
.tour-title { font-family: var(--f-head); font-weight: 800; font-size: clamp(20px, 2.6vw, 26px); line-height: 1.12; }
.tour-text { font-size: clamp(15px, 1.8vw, 18px); line-height: 1.4; color: var(--text-dim); }
.tour-dots { display: flex; gap: 8px; margin: 2px 0 4px; }
.tour-actions { display: flex; gap: 10px; align-items: center; justify-content: space-between; }
.tour-actions .onb-btn { min-height: 60px; padding: 0 22px; font-size: clamp(16px,1.9vw,20px); }

/* ============ HUB ============ */
.hub { height: 100%; display: flex; flex-direction: column; position: relative; z-index: 1; }
.hub-top { display: flex; align-items: center; justify-content: space-between; padding: 16px 22px; }
.hub-brand { display: flex; align-items: center; gap: 14px; }
.hub-mark { width: 52px; height: 52px; border-radius: 14px; background: var(--accent-glow); border: 1px solid var(--border-strong); display: flex; align-items: center; justify-content: center; color: var(--accent); }
[data-theme="paper"] .hub-mark { border-radius: 6px; }
.hub-kicker { display: block; }
.hub-word { font-size: clamp(26px, 4vw, 40px); margin: 0; line-height: 1; }
[data-theme="paper"] .hub-word { font-family: var(--f-display); font-style: italic; font-weight: 900; }

.hub-scroll { flex: 1; overflow-y: auto; padding: 0 22px 28px; }

.hub-hero { position: relative; text-align: center; padding: 30px 16px 36px; }
.hub-hero-title { font-size: clamp(34px, 7vw, 68px); margin: 6px 0 14px; line-height: 1; font-weight: 700; }
[data-theme="paper"] .hub-hero-title { font-family: var(--f-display); font-style: italic; font-weight: 900; }
.hub-hero-title em { color: var(--accent); font-style: normal; }
[data-theme="paper"] .hub-hero-title em { font-style: italic; }
.hub-hero-sub { max-width: 540px; margin: 0 auto; color: var(--text-dim); font-size: clamp(15px, 2vw, 19px); line-height: 1.5; }
.hub-tags { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-top: 20px; }
.htag { display: inline-flex; align-items: center; gap: 7px; padding: 8px 16px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--border); color: var(--text-dim); font-size: 13px; font-weight: 600; }

.eq { display: flex; gap: 5px; justify-content: center; align-items: flex-end; height: 46px; margin-bottom: 6px; }
.eq-bar { width: 7px; height: 100%; border-radius: 4px; transform-origin: bottom; animation: eqp 1.1s ease-in-out infinite; opacity: .9; }
@keyframes eqp { 0%,100%{transform:scaleY(.35)} 50%{transform:scaleY(1)} }

.session-banner {
  display: flex; align-items: center; gap: 18px; width: 100%; text-align: left;
  padding: 22px 24px; border-radius: var(--radius-lg); margin: 8px 0 26px;
  background: linear-gradient(120deg, var(--accent-glow), transparent), var(--surface);
  border: 1.5px solid var(--border-strong); box-shadow: var(--shadow);
}
.session-banner:hover { transform: translateY(-2px); }
.sb-icon { width: 64px; height: 64px; border-radius: 18px; background: var(--accent); color: var(--on-accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
[data-theme="paper"] .sb-icon { color:#fff; border-radius: 8px; }
.sb-text { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.sb-text b { font-family: var(--f-head); font-size: clamp(19px,2.6vw,26px); }
.sb-text span { color: var(--text-dim); font-size: 14px; line-height: 1.4; }
.sb-go { color: var(--accent); flex-shrink: 0; }

.hub-sec-lbl { margin: 0 2px 14px; }
.inst-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(168px, 1fr)); gap: 16px; }
.inst-tile {
  position: relative; display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 20px 14px 16px; border-radius: var(--radius); background: var(--card);
  border: 1.5px solid var(--border); box-shadow: var(--shadow); transition: transform .14s, border-color .14s;
}
.inst-tile:hover { transform: translateY(-3px); border-color: var(--border-strong); }
.inst-tile.soon { opacity: .92; }
.inst-art { width: 96px; height: 80px; }
.inst-tile-name { font-size: 19px; font-weight: 600; margin-top: 6px; }
.inst-tile-desc { font-size: 13px; color: var(--text-muted); }
.soon-badge, .ready-badge { position: absolute; top: 10px; right: 10px; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 6px; font-family: var(--f-head); letter-spacing: .04em; display: inline-flex; align-items: center; gap: 4px; }
.soon-badge { background: var(--surface-3); color: var(--text-muted); }
.ready-badge { background: rgba(46,180,80,.16); color: var(--ok); border: 1px solid rgba(46,180,80,.4); }
[data-theme="dark"] .ready-badge { color: #5fd98a; }

.hub-foot { text-align: center; margin-top: 30px; color: var(--text-muted); font-size: 13px; }
.hub-foot strong { color: var(--accent); }
.hub-foot a { color: var(--accent); text-decoration: none; }

/* ============ SESSION ============ */
.sess { height: 100%; display: flex; flex-direction: column; position: relative; z-index: 1; }
.sess-top { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.sess-top h2 { flex: 1; font-size: clamp(18px,2.6vw,24px); }
.sess-body { flex: 1; overflow-y: auto; padding: 24px; display: flex; flex-direction: column; }

.sess-choose { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; max-width: 760px; margin: auto; width: 100%; }
.choose-card { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px; padding: 40px 28px; border-radius: var(--radius-lg); background: var(--card); border: 2px solid var(--border); box-shadow: var(--shadow); }
.choose-card:hover { transform: translateY(-3px); border-color: var(--accent); }
.cc-icon { width: 84px; height: 84px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.choose-card.host .cc-icon { background: var(--accent); color: var(--on-accent); }
[data-theme="paper"] .choose-card.host .cc-icon { color:#fff; }
.choose-card.join .cc-icon { background: var(--surface-3); color: var(--accent); }
.choose-card b { font-family: var(--f-head); font-size: 24px; }
.choose-card span { color: var(--text-dim); font-size: 14px; line-height: 1.45; }

.primary-cta { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: var(--tap); padding: 0 28px; margin-top: 22px; border-radius: var(--radius); background: var(--accent); color: var(--on-accent); font-family: var(--f-head); font-weight: 700; font-size: 18px; box-shadow: var(--shadow); align-self: center; }
[data-theme="paper"] .primary-cta { color: #fff; }
.primary-cta:disabled { opacity: .4; }
.primary-cta:active { transform: scale(.98); }

.setup-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; max-width: 820px; margin: 0 auto; width: 100%; }
.song-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 10px; }
.song-row { display: flex; align-items: center; gap: 12px; min-height: 72px; padding: 0 18px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); font-weight: 600; font-size: 17px; }
.song-row span { flex: 1; text-align: left; }
.song-row.on { border-color: var(--accent); background: var(--accent-glow); color: var(--accent); }
/* song search + category groups */
.song-search { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; padding: 0 14px; min-height: 64px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); }
.song-search > svg { color: var(--text-dim); flex: 0 0 auto; }
.song-search-input { flex: 1; min-width: 0; background: transparent; border: none; outline: none; color: var(--text); font-size: 17px; min-height: 48px; }
.song-search-clear { flex: 0 0 auto; display: flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: 50%; background: var(--surface-3); color: var(--text); }
.song-cat { margin-bottom: 16px; }
.song-cat .scale-group-lbl { margin-bottom: 8px; }
.instr-pick { display: flex; flex-wrap: wrap; gap: 10px; }
.instr-chip { display: inline-flex; align-items: center; gap: 9px; min-height: 64px; padding: 0 20px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); font-weight: 600; font-size: 15px; }
.ic-dot { width: 16px; height: 16px; border-radius: 50%; background: var(--c); }
.instr-chip.on { border-color: var(--c); background: color-mix(in srgb, var(--c) 16%, transparent); }

/* host code */
.host-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; max-width: 880px; margin: 0 auto; width: 100%; }
.code-card { display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 28px; border-radius: var(--radius-lg); background: var(--card); border: 1.5px solid var(--border-strong); box-shadow: var(--shadow); }
.cc-lbl { color: var(--text-muted); }
.big-code { font-size: clamp(40px, 7vw, 64px); font-weight: 700; letter-spacing: .08em; color: var(--accent); }
.qr { width: 154px; height: 154px; display: grid; grid-template-columns: repeat(11,1fr); grid-template-rows: repeat(11,1fr); gap: 2px; padding: 10px; background: #fff; border-radius: 8px; }
.qr span { background: transparent; border-radius: 1px; }
.qr span.on { background: #15151f; }
.cc-hint { font-size: 13px; color: var(--text-muted); text-align: center; }
.cc-hint b { color: var(--text-dim); }
.roster-card { display: flex; flex-direction: column; padding: 24px; border-radius: var(--radius-lg); background: var(--surface); border: 1px solid var(--border); }
.rc-head { display: flex; justify-content: space-between; align-items: baseline; }
.rc-head b { font-family: var(--f-head); font-size: 20px; }
.rc-head span { color: var(--text-muted); }
.rc-sub { color: var(--text-muted); font-size: 13px; margin: 4px 0 16px; }
.roster { flex: 1; display: flex; flex-direction: column; gap: 10px; }
.player-pill { display: flex; align-items: center; gap: 10px; min-height: 64px; padding: 0 16px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1px solid var(--border); font-weight: 600; opacity: 1; }
.player-pill.fresh { animation: popIn .3s ease; }
.player-pill small { margin-left: auto; color: var(--text-muted); font-weight: 500; }
.pp-orb { width: 14px; height: 14px; border-radius: 50%; background: var(--c); }
.player-pill.waiting { color: var(--text-muted); border-style: dashed; }
.pp-orb.pulse { background: var(--text-muted); animation: pulseRing 1.2s infinite; }

/* join keypad */
.join-wrap { max-width: 460px; margin: 0 auto; width: 100%; display: flex; flex-direction: column; align-items: center; }
.join-lead { color: var(--text-dim); margin-bottom: 14px; }
.code-display { font-size: 44px; font-weight: 700; letter-spacing: .12em; color: var(--accent); margin-bottom: 20px; }
.keypad { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; width: 100%; }
.kp { min-height: 64px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); font-size: 24px; font-weight: 700; display: flex; align-items: center; justify-content: center; color: var(--text); }
.kp:hover { border-color: var(--border-strong); }
.kp:active { transform: scale(.96); }
.kp.letters { grid-column: span 1; font-size: 13px; font-family: var(--f-head); }
.join-instr { width: 100%; margin-top: 22px; }

/* conductor */
.cond-wrap { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 24px; }
.conductor { position: relative; width: min(70vh, 90%); aspect-ratio: 1; }
.pulse-core { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 30%; aspect-ratio: 1; border-radius: 50%; background: var(--accent); color: var(--on-accent); display: flex; flex-direction: column; align-items: center; justify-content: center; z-index: 4; transition: transform .1s; }
[data-theme="paper"] .pulse-core { color:#fff; }
.pulse-core.down { transform: translate(-50%,-50%) scale(1.12); }
.pulse-core span { font-size: clamp(28px,5vw,46px); font-weight: 700; line-height: 1; }
.pulse-core small { font-size: 12px; opacity: .7; letter-spacing: .1em; }
.pulse-ring { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 30%; aspect-ratio: 1; border-radius: 50%; border: 2px solid var(--border-strong); }
.pulse-ring.on { border-color: var(--accent); box-shadow: 0 0 26px var(--accent-glow); }
.orbit-player { position: absolute; transform: translate(-50%,-50%); display: flex; flex-direction: column; align-items: center; gap: 2px; z-index: 5; transition: transform .12s; }
.orbit-player.play { transform: translate(-50%,-50%) scale(1.16); }
.op-orb { width: 54px; height: 54px; border-radius: 50%; background: var(--c); box-shadow: 0 0 0 4px var(--bg); }
.orbit-player.play .op-orb { box-shadow: 0 0 0 4px var(--bg), 0 0 26px var(--c); }
.orbit-player b { font-size: 14px; }
.orbit-player small { font-size: 11px; color: var(--text-muted); }
.cond-transport { display: flex; align-items: center; gap: 20px; }
.ct-tempo { display: flex; align-items: center; gap: 12px; font-size: 22px; font-weight: 700; }

/* player play */
.play-wrap { flex: 1; display: flex; flex-direction: column; gap: 18px; }
.shared-pulse { display: flex; align-items: center; justify-content: center; gap: 14px; padding: 12px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--border); align-self: center; }
.sp-pip { width: 16px; height: 16px; border-radius: 50%; background: var(--surface-3); }
.sp-pip.on { background: var(--accent); transform: scale(1.4); box-shadow: 0 0 14px var(--accent-glow); }
.sp-lbl { color: var(--text-muted); font-size: 13px; margin-left: 8px; }
.player-strip { flex: 1; display: flex; gap: 12px; }
.player-strip .k-strip { flex: 1; }
.play-hint { display: flex; align-items: center; gap: 8px; justify-content: center; color: var(--text-dim); font-size: 14px; }

@media (max-width: 720px) {
  .sess-choose, .setup-wrap, .host-wrap { grid-template-columns: 1fr; }
  .inst-grid { grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); }
}

/* ===== Band view (teacher ensemble) ===== */
.band-wrap { flex: 1; display: flex; flex-direction: column; gap: 12px; min-height: 0; overflow-y: auto; padding-bottom: 4px; }
.band-top { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; position: sticky; top: 0; z-index: 2; background: var(--bg); padding: 2px 0 6px; }
.band-pulse { display: flex; align-items: center; gap: 12px; padding: 8px 16px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--border); }
.band-top .ct-tempo { display: flex; align-items: center; gap: 12px; font-size: 20px; font-weight: 700; }
.band-top .ct-tempo small { font-size: 12px; color: var(--text-muted); }
.band-lanes { display: flex; flex-direction: column; gap: 10px; }
.band-lane { display: flex; align-items: center; gap: 14px; padding: 12px 16px; border-radius: var(--radius); background: var(--surface); border: 1px solid var(--border); border-left: 5px solid var(--c); transition: box-shadow .12s, transform .12s; }
.band-lane.on { box-shadow: 0 0 0 2px var(--c), 0 0 22px color-mix(in srgb, var(--c) 45%, transparent); transform: translateX(2px); }
.bl-head { display: flex; align-items: center; gap: 11px; min-width: 168px; }
.bl-orb { width: 32px; height: 32px; border-radius: 50%; background: var(--c); flex-shrink: 0; transition: box-shadow .12s; }
.band-lane.on .bl-orb { box-shadow: 0 0 16px var(--c); }
.bl-id b { display: block; font-size: 16px; }
.bl-id small { color: var(--text-muted); font-size: 12px; }
.bl-you { margin-left: auto; font-size: 11px; font-weight: 700; font-family: var(--f-head); padding: 3px 8px; border-radius: 5px; background: var(--accent); color: var(--on-accent); }
[data-theme="paper"] .bl-you { color: #fff; }
.bl-track { flex: 1; min-width: 0; }
.note-track { display: flex; gap: 8px; align-items: center; justify-content: flex-end; min-height: 40px; overflow: hidden; }
.nt-dot { width: 36px; height: 36px; border-radius: 9px; background: var(--c); display: flex; align-items: center; justify-content: center; font-family: var(--f-head); font-weight: 700; font-size: 15px; flex-shrink: 0; animation: popIn .25s ease; }
.nt-empty { color: var(--text-muted); font-size: 20px; }
.band-lane.teacher { flex-direction: column; align-items: stretch; gap: 10px; border-left-width: 6px; background: var(--card); box-shadow: var(--shadow); }
.band-lane.teacher .bl-head { min-width: 0; }
.teacher-strip { display: flex; gap: 10px; height: clamp(84px, 16vh, 130px); }
.teacher-strip .k-strip { flex: 1; }

/* ============ SUPERHUB ============ */
.shub { height: 100%; display: flex; flex-direction: column; position: relative; z-index: 1; padding: 14px 18px 8px; gap: 12px; }
.shub-top { display: grid; grid-template-columns: auto 1fr auto; align-items: start; gap: 14px; }
.chrome-col { display: flex; gap: 10px; }
.chrome-col.right { align-items: flex-start; }
.chrome-col.br { justify-content: flex-end; }
.chrome-tile {
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px;
  width: clamp(82px, 9vw, 104px); min-height: clamp(78px, 9vw, 100px);
  border-radius: var(--radius); background: var(--card); border: 1px solid var(--border);
  box-shadow: var(--shadow); color: var(--text); font-family: var(--f-head); font-weight: 600; font-size: 13px;
  transition: transform .14s, border-color .14s;
}
.chrome-tile:hover { transform: translateY(-2px); border-color: var(--accent); }
.chrome-tile.on { border-color: var(--accent); background: var(--accent-glow); color: var(--accent); }
.chrome-tile svg { color: var(--accent); }

.shub-brand { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 3px; padding-top: 4px; max-width: 520px; margin: 0 auto; }
.shub-word { font-size: clamp(30px, 4.6vw, 52px); margin: 0; line-height: 1.05; }
[data-theme="paper"] .shub-word { font-family: var(--f-display); font-style: italic; font-weight: 900; }
.shub-tag { font-size: clamp(13px, 1.6vw, 18px); color: var(--text-dim); margin: 6px 0 0; line-height: 1.3; }
[data-theme="paper"] .shub-tag { font-family: var(--f-display); font-style: italic; }
.shub-author { font-size: 12px; color: var(--text-muted); letter-spacing: .04em; margin: 5px 0 0; }
/* DigitalMusic app icon — plain (no button background), mirrors DigitalPainters' logo-right. */
.shub-logo { width: clamp(78px, 9vw, 100px); height: clamp(78px, 9vw, 100px); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.shub-logo img { width: 90%; height: 90%; object-fit: contain; border-radius: 22%; }
/* AssistUK wordmark cell — sits to the LEFT of the title (DigitalPainters logo-left).
   White-on-transparent asset → keep on dark theme, invert to dark on the light/paper theme. */
.shub-au-cell { display: flex; align-items: center; justify-content: center; }
.shub-au { height: clamp(30px, 5.6vh, 54px); width: auto; max-width: 100%; object-fit: contain; opacity: .9; }
[data-theme="paper"] .shub-au { filter: invert(1) brightness(.35); opacity: .85; }

.shub-grid { flex: 1; min-height: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; overflow-y: auto; align-content: start; padding: 2px; }

.cat-tile {
  position: relative; display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 14px 12px 12px; border-radius: var(--radius); background: var(--card);
  border: 1px solid var(--border); box-shadow: var(--shadow); min-height: 150px;
  transition: transform .14s, border-color .14s, box-shadow .14s;
}
.cat-tile:hover { transform: translateY(-3px); box-shadow: var(--shadow), 0 0 22px var(--accent-glow); }
.cat-tile.cat-melodie:hover { border-color: #f39c12; }
.cat-tile.cat-saiten:hover { border-color: var(--cat-saiten); box-shadow: var(--shadow), 0 0 22px rgba(200,137,58,.30); }
.cat-tile.cat-blaeser:hover { border-color: var(--cat-blaeser); box-shadow: var(--shadow), 0 0 22px rgba(26,165,160,.30); }
.cat-tile.cat-klang:hover { border-color: #6cbfe2; }
.cat-tile.cat-rhythmus:hover { border-color: #e8302e; }
.cat-tile.cat-session:hover { border-color: var(--accent); }
.cat-art { height: 76px; flex: none; display: flex; align-items: center; justify-content: center; width: 100%; margin: auto 0 2px; }
.cat-art svg { width: 86px; height: 76px; }
.cat-art img { width: auto; height: 100%; max-width: 100%; object-fit: contain; -webkit-user-drag: none; user-select: none; filter: drop-shadow(0 4px 12px rgba(0,0,0,0.28)); }
.cat-name { font-size: 19px; font-weight: 600; margin-top: 2px; line-height: 1.12; }
[data-theme="paper"] .cat-name { font-family: var(--f-display); font-style: italic; font-weight: 700; }
.cat-desc { font-size: 12.5px; color: var(--text-muted); text-align: center; line-height: 1.25; }
.folio { position: absolute; top: 8px; right: 8px; font-size: 11px; color: var(--text-muted); background: var(--surface-2); border: 1px solid var(--border); border-radius: 3px; padding: 1px 6px; letter-spacing: .02em; }

/* ── Vollflächige Recraft-Bild-Kacheln (nur SuperHub-Kategorien) ── */
.cat-tile.cover { background-size: cover; background-position: center; background-repeat: no-repeat; justify-content: flex-end; }
.cat-tile.cover .cat-scrim { position: absolute; inset: 0; z-index: 0; border-radius: inherit; background: linear-gradient(180deg, rgba(0,0,0,.12) 30%, rgba(0,0,0,.55) 72%, rgba(0,0,0,.82) 100%); }
.cat-tile.cover .cat-name, .cat-tile.cover .cat-desc { position: relative; z-index: 1; color: #fff; text-shadow: 0 2px 8px rgba(0,0,0,.9), 0 1px 2px rgba(0,0,0,.7); }
[data-theme="paper"] .cat-tile.cover .cat-name { color: #fff; }
.cat-tile.cover .folio { z-index: 1; background: rgba(0,0,0,.5); color: #fff; border-color: rgba(255,255,255,.3); }
.grid10 .cat-tile.cover { display: flex; flex-direction: column; justify-content: flex-end; align-items: center; padding: 12px 12px 14px; }

.shub-bottom { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; }
.shub-bc { grid-column: 2; display: flex; justify-content: center; }
.shub-bottom .chrome-col.br { grid-column: 3; }
.legal { text-align: center; font-size: 11px; color: var(--text-muted); padding: 4px 0 2px; }
.legal a { color: var(--accent); text-decoration: none; }

/* breadcrumb */
.crumb { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--border); }
.crumb-pill { display: inline-flex; align-items: center; gap: 7px; padding: 6px 14px; border-radius: 999px; color: var(--text-dim); font-weight: 600; font-size: 14px; }
.crumb-pill svg { color: var(--accent); }
.crumb-pill:not(:disabled):hover { background: var(--surface-3); color: var(--text); }
.crumb-pill.cur { color: var(--text); background: var(--accent-glow); }
.crumb-sep { color: var(--accent); font-size: 16px; }

/* centered modal */
/* full-page chrome (same as .sheet): centered body column + footer with grid-cell back + breadcrumb */
.modal-scrim { position: fixed; inset: 0; z-index: 300; background: var(--bg); display: flex; flex-direction: column; }
.modal { width: 100%; height: 100%; max-width: none; max-height: none; display: flex; flex-direction: column; background: var(--bg); border: none; border-radius: 0; box-shadow: none; overflow: hidden; animation: pageIn .18s ease; }
.modal-hd { padding: clamp(10px,2vh,18px) 22px clamp(8px,1.4vh,12px); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: center; gap: 14px; flex-shrink: 0; position: relative; }
.modal-hd h2 { font-size: clamp(22px, 3.2vw, 32px); font-family: var(--f-head); font-weight: 800; }
.modal-read { position: absolute; right: 22px; top: 50%; transform: translateY(-50%); }
.modal-read { display: inline-flex; align-items: center; gap: 8px; flex-shrink: 0; min-height: 44px; padding: 0 16px; border-radius: 999px; background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); font-family: var(--f-head); font-weight: 700; font-size: 15px; }
.modal-read:hover { background: var(--surface-3); border-color: var(--accent); color: var(--accent); }
[data-theme="paper"] .modal-hd h2 { font-family: var(--f-display); font-style: italic; color: var(--accent); }
.modal-bd { flex: 1; padding: clamp(10px,1.6vh,20px) 22px; overflow-y: auto; width: 100%; max-width: 1000px; margin: 0 auto; }
.modal-bd p { margin: 0 0 12px; line-height: 1.55; color: var(--text-dim); }
.modal-bd p b { color: var(--text); }
/* wide info/support modal (DigitalPainters-style cards) */
.modal.wide { width: min(980px, 96vw); max-height: 90vh; }
.info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 14px; }
/* Two-column layout: intro + note span full width, PayPal and SEPA sit side by side
   so the page fits without scrolling on wide screens; stacks on narrow screens. */
.support-wrap { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; align-content: start; }
.support-wrap > .info-card.accent, .support-wrap > .support-note { grid-column: 1 / -1; }
@media (max-width: 820px) { .support-wrap { grid-template-columns: 1fr; } }
.info-card { background: var(--surface-2); border: 1.5px solid var(--border); border-radius: var(--radius); padding: 16px 18px; }
.info-card.accent { border-color: var(--accent); background: var(--accent-glow); }
.info-card h3 { margin: 0 0 10px; font-family: var(--f-head); font-weight: 800; font-size: clamp(17px, 2.2vw, 21px); color: var(--text); }
.info-card p { margin: 0 0 9px; line-height: 1.5; color: var(--text-dim); }
.info-card p b { color: var(--text); }
.info-card ul { margin: 6px 0 0; padding-left: 20px; }
.info-card li { margin: 0 0 6px; line-height: 1.45; color: var(--text-dim); }
.info-card a { color: var(--accent); font-weight: 700; text-decoration: none; }
.info-card.person { display: flex; gap: 14px; align-items: flex-start; }
.info-photo { flex: 0 0 auto; width: clamp(76px, 14vw, 110px); height: clamp(76px, 14vw, 110px); border-radius: 14px; object-fit: cover; border: 2px solid var(--border); }
.info-person-txt { flex: 1; min-width: 0; }
.info-person-txt h3 { margin-bottom: 6px; }
/* PayPal QR grid */
.qr-row { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }
.qr-item { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 10px; border-radius: var(--radius-sm); background: var(--surface); border: 1.5px solid var(--border); text-decoration: none; min-width: 120px; }
.qr-item:hover { border-color: var(--accent); }
.qr-item img { width: clamp(84px, 12vw, 120px); height: clamp(84px, 12vw, 120px); border-radius: 8px; background: #fff; padding: 4px; }
.qr-amount { font-family: var(--f-head); font-weight: 800; font-size: 18px; color: var(--accent); }
.qr-label { font-size: 13px; color: var(--text-dim); text-align: center; }
.qr-hint { font-size: 13px; color: var(--text-muted); margin: 10px 0 0; }
/* SEPA */
.sepa-row { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.sepa-qr { width: clamp(96px, 16vw, 140px); height: clamp(96px, 16vw, 140px); border-radius: 8px; background: #fff; padding: 5px; flex: 0 0 auto; }
.sepa-txt { flex: 1; min-width: 200px; }
.sepa-txt p { margin: 0 0 8px; line-height: 1.6; color: var(--text); }
.support-note { font-size: 13px; color: var(--text-muted); line-height: 1.5; margin: 4px 2px 0; }
.set-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; font-weight: 600; }

/* ============ HUB (sub) ============ */
.hub2 { height: 100%; display: flex; flex-direction: column; position: relative; z-index: 1; }
.hub2-top { display: flex; align-items: flex-start; justify-content: space-between; padding: 20px 24px 8px; }
.hub2-kicker { display: block; }
.hub2-title h1 { font-size: clamp(26px, 4vw, 40px); margin: 2px 0; }
[data-theme="paper"] .hub2-title h1 { font-family: var(--f-display); font-style: italic; font-weight: 900; }
.hub2-title p { color: var(--text-dim); font-size: 15px; margin: 0; }
.hub2-body { flex: 1; overflow-y: auto; padding: 8px 24px 16px; }
.act-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 16px; align-content: start; }

/* ===== 10×6 grid pages (SuperHub + Hubs) ===== */
.grid-page { position: relative; height: 100%; z-index: 1; }
.grid10 { position: absolute; inset: 0 0 var(--footer-h) 0; display: grid; grid-template-columns: repeat(10, 1fr); grid-template-rows: repeat(6, 1fr); gap: 8px; padding: 10px; z-index: 1; }
.legal-footer { height: var(--footer-h); display: flex; align-items: center; justify-content: center; gap: 8px; flex-wrap: wrap; font-size: 11px; color: var(--text-muted); border-top: 1px solid var(--border); background: var(--bg); z-index: 2; position: relative; }
.grid-page .legal-footer { position: absolute; left: 0; right: 0; bottom: 0; }
/* ===== "Klang-Garten" generative ===== */
.gen-page { position: fixed; inset: 0; z-index: 1; background: var(--bg); display: flex; flex-direction: column; overflow: hidden; }
.gen-page[data-mood="ruhig"] { background: color-mix(in srgb, #4c5aa4 14%, var(--bg)); }
.gen-page[data-mood="traumhaft"] { background: color-mix(in srgb, #9e56a2 14%, var(--bg)); }
.gen-page[data-mood="froehlich"] { background: color-mix(in srgb, #f5b300 12%, var(--bg)); }
.gen-page[data-mood="geheimnisvoll"] { background: color-mix(in srgb, #7a5fa6 14%, var(--bg)); }
.gen-page[data-mood="fernoestlich"] { background: color-mix(in srgb, #1aa5a0 13%, var(--bg)); }
.gen-stage { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.gen-bloom { position: absolute; width: 22vmin; height: 22vmin; margin: -11vmin 0 0 -11vmin; border-radius: 50%; background: radial-gradient(circle, var(--c), transparent 70%); opacity: 0; filter: blur(8px); mix-blend-mode: screen; animation: genBloom 1.4s ease-out forwards; }
@keyframes genBloom { 0% { opacity: 0; transform: scale(.4); } 25% { opacity: .5; } 100% { opacity: 0; transform: scale(1.2); } }
.gen-title { position: relative; z-index: 2; text-align: center; padding: 22px 16px 6px; font-family: var(--f-head); font-weight: 800; font-size: clamp(22px,3vw,32px); color: var(--text); }
.gen-controls { position: relative; z-index: 2; margin-top: auto; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 12px; padding: 14px 16px 24px; }
.gen-group, .gen-stepper { display: inline-flex; align-items: center; gap: 8px; }
.gen-lbl { font-family: var(--f-head); font-weight: 700; color: var(--text-dim); font-size: clamp(14px,1.7vw,18px); margin-right: 2px; }
.gen-page .gen-back { position: fixed; left: 16px; bottom: 16px; top: auto; transform: none; z-index: 6; }

/* ===== "Einfach" one-surface play ===== */
.sp-pick { gap: 14px; }
.sp-dot { flex: 0 0 auto; width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; background: var(--c, var(--accent)); box-shadow: 0 0 14px color-mix(in srgb, var(--c, var(--accent)) 60%, transparent); }
.sp-dot svg { width: 30px; height: 30px; }
.sp-pick-txt { display: flex; flex-direction: column; min-width: 0; }
.sp-pick-txt small { font-weight: 600; color: var(--text-dim); font-size: 13px; }
.sp-play { position: fixed; inset: 0; z-index: 1; overflow: hidden; display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--c, var(--accent)) 16%, var(--bg)); transition: background .4s; }
.sp-play[data-on="1"] { background: color-mix(in srgb, var(--c, var(--accent)) 30%, var(--bg)); }
.sp-surface { position: absolute; inset: 0; touch-action: none; cursor: pointer; }
.sp-label { position: relative; z-index: 2; text-align: center; pointer-events: none; padding: 0 20px; }
.sp-name { display: block; font-family: var(--f-head); font-weight: 800; font-size: clamp(34px,7vw,72px); color: var(--c, var(--accent)); }
.sp-hint { display: block; margin-top: 10px; font-size: clamp(16px,2.4vw,26px); color: var(--text-dim); }
.sp-play .sp-back { position: fixed; left: 16px; bottom: 16px; top: auto; transform: none; z-index: 6; }
.sp-ripple { position: absolute; width: 12px; height: 12px; margin: -6px 0 0 -6px; border-radius: 50%; background: var(--c, var(--accent)); pointer-events: none; opacity: .55; animation: spRip .75s ease-out forwards; }
@keyframes spRip { 0% { transform: scale(1); opacity: .55; } 100% { transform: scale(26); opacity: 0; } }
.reduce-anim .sp-ripple { animation-duration: .35s; }

/* ===== fullscreen Karaoke ===== */
.kar-page { position: fixed; inset: 0; z-index: 1; background: var(--bg); display: flex; flex-direction: column; overflow: hidden; }
.kar-topbar { position: relative; flex-shrink: 0; display: flex; align-items: center; justify-content: center; min-height: calc(var(--ctl-min) + 16px); padding: 12px 18px; }
/* Unified fullscreen back button: always bottom-left (matches hub/instrument convention), fixed to viewport */
.kar-backbtn { position: fixed; left: 16px; bottom: 16px; top: auto; transform: none; z-index: 6; display: inline-flex; align-items: center; gap: 10px; min-height: var(--ctl-min); min-width: var(--ctl-min); padding: 0 24px; border-radius: var(--radius); background: var(--surface-2); border: 2px solid var(--border-strong); color: var(--text); font-family: var(--f-head); font-weight: 800; font-size: clamp(17px,2vw,22px); }
.kar-backbtn:hover { border-color: var(--accent); color: var(--accent); }
.kar-head { text-align: center; }
.kar-head h1 { font-size: clamp(28px,5vw,46px); margin: 0; font-weight: 800; }
.kar-head p { color: var(--text-dim); margin: 4px 0 0; }
.kar-pick { flex: 1; overflow-y: auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(240px,1fr)); gap: 14px; align-content: start; padding: 12px 24px 32px; }
.kar-song { display: flex; align-items: center; gap: 12px; min-height: var(--ctl-min); padding: 0 20px; border-radius: var(--radius); background: var(--surface-2); border: 2px solid var(--border); color: var(--text); font-family: var(--f-head); font-weight: 700; font-size: clamp(17px,2vw,22px); text-align: left; transition: transform .08s ease, border-color .12s ease; }
.kar-song:hover { border-color: var(--accent); transform: translateY(-2px); }
.kar-song.load { border-style: dashed; color: var(--accent); grid-column: 1 / -1; justify-content: center; }
.kar-title { text-align: center; font-family: var(--f-head); font-weight: 800; font-size: clamp(22px,3vw,32px); color: var(--text); }
.kar-lyrics { flex: 1; min-height: 0; overflow-y: auto; display: flex; flex-wrap: wrap; align-content: center; justify-content: center; gap: 6px 12px; padding: 16px clamp(16px,6vw,120px); }
.kar-syl { font-family: var(--f-head); font-weight: 800; font-size: clamp(26px,5vw,56px); color: var(--text-muted); opacity: .5; transition: color .12s, transform .12s, opacity .12s; }
.kar-syl.done { color: var(--text-dim); opacity: .7; }
.kar-syl.on { color: var(--accent); opacity: 1; transform: scale(1.18); text-shadow: 0 0 18px var(--accent-glow); }
.kar-nolyric { color: var(--text-muted); font-family: var(--f-head); font-size: clamp(18px,3vw,28px); }
.kar-mic { flex-shrink: 0; height: 10px; margin: 0 24px 6px; border-radius: 999px; background: var(--surface-2); overflow: hidden; }
.kar-mic-bar { height: 100%; background: linear-gradient(90deg, var(--ok), #f5e622, #e8302e); transition: width .08s linear; }
.kar-controls { flex-shrink: 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 12px; padding: 12px 16px 22px; }
.kar-btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: var(--ctl-min); min-width: var(--ctl-min); padding: 0 26px; border-radius: 999px; font-family: var(--f-head); font-weight: 800; font-size: clamp(17px,2.1vw,23px); color: var(--text); background: var(--surface-2); border: 2px solid var(--border); }
.kar-btn.primary { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
[data-theme="paper"] .kar-btn.primary { color: #fff; }
.kar-btn.on { border-color: var(--accent); color: var(--accent); }
.kar-tempo { display: inline-flex; align-items: center; gap: 8px; }
.kar-step { min-width: var(--ctl-min); min-height: var(--ctl-min); border-radius: 14px; background: var(--surface-2); border: 2px solid var(--border); color: var(--text); display: inline-flex; align-items: center; justify-content: center; }
.kar-bpm { min-width: 56px; text-align: center; font-weight: 800; font-size: clamp(20px,2.4vw,28px); color: var(--accent); }

/* ===== fullscreen "Licht & Effekte" visualizer ===== */
.viz-page { position: fixed; inset: 0; z-index: 1; background: var(--bg); overflow: hidden; }
.viz-canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; touch-action: none; }
.viz-top { position: absolute; top: 0; left: 0; right: 0; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 12px 16px; flex-wrap: wrap; z-index: 2; }
.viz-modes { display: flex; gap: 8px; flex-wrap: wrap; }
.viz-mode { min-height: var(--ctl-min); min-width: var(--ctl-min); padding: 0 20px; border-radius: 999px; font-family: var(--f-head); font-weight: 700; font-size: clamp(15px,1.8vw,19px); color: var(--text); background: var(--surface-2); border: 1.5px solid var(--border); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.viz-mode.on { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
[data-theme="paper"] .viz-mode.on { color: #fff; }
.viz-mic { min-height: var(--ctl-min); min-width: var(--ctl-min); padding: 0 18px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-family: var(--f-head); font-weight: 700; font-size: clamp(15px,1.8vw,19px); color: var(--text); background: var(--surface-2); border: 1.5px solid var(--border); }
.viz-mic.on { background: var(--ok); color: #fff; border-color: var(--ok); }
/* compact "current effect → change" button (replaces the cramped mode row) */
.viz-mode-switch { min-height: var(--ctl-min); padding: 0 22px; border-radius: 999px; display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-head); font-weight: 800; font-size: clamp(15px,1.9vw,20px); color: var(--text); background: var(--surface-2); border: 1.5px solid var(--border-strong); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.viz-mode-switch .viz-switch-hint { font-size: .72em; font-weight: 700; color: var(--accent); border: 1.5px solid var(--accent); border-radius: 999px; padding: 2px 10px; }

/* ===== Effekt-Picker (paginiert, wie DigitalPainters) ===== */
.fxpick-page { position: fixed; inset: 0; z-index: 1; background: var(--bg); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: clamp(14px,3vh,28px); padding: clamp(16px,4vmin,40px); overflow: hidden; }
.fxpick-head { text-align: center; max-width: 760px; }
.fxpick-title { margin: 0; font-family: var(--f-head); font-weight: 800; color: var(--text); font-size: clamp(24px,3.4vw,38px); }
.fxpick-sub { margin: 6px 0 0; color: var(--text-muted); font-size: clamp(14px,1.9vw,19px); line-height: 1.4; }
.fxpick-grid { display: grid; grid-template-columns: repeat(3, minmax(180px, 1fr)); gap: clamp(10px,1.6vw,18px); width: min(1040px, 94vw); }
.fx-tile { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; min-height: clamp(120px, 22vh, 190px); padding: clamp(12px,2vmin,22px); border-radius: var(--radius-lg); background: var(--surface-2); border: 2px solid var(--border); color: var(--text); cursor: pointer; text-align: center; transition: transform .08s ease, border-color .12s ease; }
.fx-tile:hover { border-color: var(--accent); transform: translateY(-2px); }
.fx-tile.on { border-color: var(--accent); box-shadow: inset 0 0 0 2px var(--accent); }
.fx-tile-ic { width: 64px; height: 64px; border-radius: var(--radius); display: flex; align-items: center; justify-content: center; background: color-mix(in srgb, var(--cat, var(--accent)) 18%, transparent); color: var(--cat, var(--accent)); }
.fx-tile.cat-rhythmus { --cat: #e8302e; } .fx-tile.cat-melodie { --cat: #f5b300; } .fx-tile.cat-klang { --cat: #6cbfe2; } .fx-tile.cat-lieder { --cat: #7a5fa6; }
.fx-tile-name { font-family: var(--f-head); font-weight: 800; font-size: clamp(17px,2.1vw,23px); }
.fx-tile-desc { font-size: clamp(12px,1.5vw,16px); color: var(--text-muted); line-height: 1.3; }
.fxpick-pager { display: flex; align-items: center; gap: 16px; }
.fx-page { min-height: var(--tap); min-width: var(--tap); border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; background: var(--surface-2); border: 2px solid var(--border-strong); color: var(--text); cursor: pointer; }
.fx-page:disabled { opacity: .35; cursor: default; }
.fxpick-dots { display: flex; gap: 8px; }
.fxpick-dots .pagedot { width: 12px; height: 12px; border-radius: 50%; background: var(--border-strong); }
.fxpick-dots .pagedot.on { background: var(--accent); }
.viz-page .viz-back { position: fixed; left: 16px; bottom: 16px; top: auto; transform: none; z-index: 6; }
.viz-hint { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); z-index: 2; padding: 8px 18px; border-radius: 999px; background: var(--surface); border: 1px solid var(--border); color: var(--text-dim); font-size: clamp(13px,1.6vw,17px); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); pointer-events: none; }
.viz-scenes { position: absolute; bottom: 96px; left: 50%; transform: translateX(-50%); z-index: 2; display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; max-width: 88vw; }
.viz-scene { min-height: var(--ctl-min); min-width: var(--ctl-min); padding: 0 20px; border-radius: 999px; font-family: var(--f-head); font-weight: 700; font-size: clamp(14px,1.7vw,19px); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); }
.viz-scene.on { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
[data-theme="paper"] .viz-scene.on { color: #fff; }

/* ===== optional light effects ("Lichtorgel") — gentle, photosensitive-safe ===== */
#dm-fx { position: fixed; inset: 0; z-index: 60; pointer-events: none; overflow: hidden; }
.dm-fx-glow {
  position: absolute; width: var(--s, 30vmin); height: var(--s, 30vmin);
  margin: calc(var(--s, 30vmin) / -2) 0 0 calc(var(--s, 30vmin) / -2);
  border-radius: 50%; background: radial-gradient(circle, var(--c, #f39c12), transparent 70%);
  opacity: 0; filter: blur(7px); mix-blend-mode: screen;
  animation: dmFxBloom .95s ease-out forwards;
}
.dm-fx-glow.wave { animation: dmFxWave 1.3s ease-out forwards; filter: blur(9px); }
@keyframes dmFxBloom { 0% { opacity: 0; transform: scale(.4); } 22% { opacity: .5; } 100% { opacity: 0; transform: scale(1.15); } }
@keyframes dmFxWave  { 0% { opacity: 0; transform: scale(.2); } 18% { opacity: .42; } 100% { opacity: 0; transform: scale(2.2); } }
.reduce-anim #dm-fx { display: none !important; }

.legal-footer a { color: var(--accent); text-decoration: none; transition: text-shadow .15s, color .15s; }
.legal-footer a:hover { color: var(--accent); text-shadow: 0 0 9px var(--accent), 0 0 2px var(--accent); }

.grid10 .cat-tile { min-height: 0; height: 100%; padding: 10px 10px 8px; gap: 4px; overflow: hidden; display: grid; grid-template-rows: minmax(0, 1fr) auto auto; justify-items: center; align-content: center; }
.grid10 .cat-art { flex: none; height: 100%; min-height: 0; margin: 0; align-self: center; }
.grid10 .cat-art svg { width: auto; height: 100%; max-width: 100%; max-height: 72px; }
.grid10 .cat-art img { width: auto; height: 100%; max-width: 100%; max-height: clamp(80px, 15vh, 168px); }
.grid10 .cat-name, .grid10 .cat-desc { flex-shrink: 0; }
.grid10 .cat-name { font-size: clamp(14px, 1.6vw, 20px); }
.grid10 .cat-desc { font-size: clamp(10px, 1vw, 13px); }
.grid10 .chrome-tile { width: 100%; height: 100%; min-height: 0; }
.grid10 .shub-brand { height: 100%; justify-content: center; max-width: none; padding: 0; }
.grid10 .shub-logo { width: 100%; height: 100%; }
.grid10 .shub-au-cell { height: 100%; }
/* SuperHub pagination */
/* pagination as a big arrow tile in the grid (DigitalPainters style) */
.shub-arrow { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; background: var(--surface-2); border: 2px dashed var(--border-strong); border-radius: var(--radius-lg); color: var(--text); cursor: pointer; transition: transform .08s ease, border-color .12s ease, background .12s ease; }
.shub-arrow:hover { border-color: var(--accent); color: var(--accent); transform: translateY(-2px); background: var(--accent-glow); }
.shub-arrow .shub-arrow-ic { display: inline-flex; color: var(--accent); }
.shub-arrow .shub-arrow-ic.flip-x { transform: scaleX(-1); }
.shub-arrow .shub-arrow-lbl { font-family: var(--f-head); font-weight: 800; font-size: clamp(18px,2.2vw,28px); }
.shub-page { display: inline-flex; align-items: center; justify-content: center; gap: 10px; background: var(--surface-2); border: 1.5px solid var(--border); border-radius: var(--radius); color: var(--text); font-family: var(--f-head); font-weight: 800; font-size: clamp(15px,1.8vw,21px); }
.shub-page:hover { border-color: var(--accent); color: var(--accent); }
.shub-page .flip-x { display: inline-flex; transform: scaleX(-1); }
.shub-pagedots { position: absolute; left: 50%; bottom: 92px; transform: translateX(-50%); display: flex; align-items: center; justify-content: center; gap: 12px; pointer-events: none; z-index: 6; }
.pagedot { width: 13px; height: 13px; border-radius: 50%; background: var(--border-strong); }
.pagedot.on { background: var(--accent); box-shadow: 0 0 8px var(--accent-glow); }
.grid10 .hub2-title { height: 100%; display: flex; flex-direction: column; justify-content: center; }
/* breadcrumb spans the full row on every page so it centers on the screen midline;
   the container ignores pointer events so the Zurück button underneath stays clickable */
/* Breadcrumb pinned to a FIXED offset above the footer on every page (grid pages AND
   instrument pages use bottom:40px above the footer top) so it never jumps vertically
   when navigating SuperHub → Hub → Instrument. */
.grid10 .shub-bc { position: absolute; left: 50%; bottom: 30px; transform: translateX(-50%); width: auto; display: flex; align-items: center; justify-content: center; pointer-events: none; z-index: 5; }
.grid10 .shub-bc .crumb { pointer-events: auto; }
.grid10 .nav-back { width: 100%; height: 100%; }

.brand-card { display: flex; align-items: center; gap: 14px; padding: 0 18px; border-radius: var(--radius); background: var(--card); border: 1px solid var(--border); box-shadow: var(--shadow); }
.bc-mark { width: 48px; height: 48px; border-radius: 12px; background: var(--accent-glow); color: var(--accent); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
[data-theme="paper"] .bc-mark { border-radius: 6px; }
.bc-text b { display: block; font-size: clamp(13px, 1.4vw, 17px); }
[data-theme="paper"] .bc-text b { font-family: var(--f-display); font-style: italic; }
.bc-text span { font-size: 12px; color: var(--text-muted); }

/* ============ MULTITRACK (Band-Mischpult) ============ */
.mt-screen { height: 100%; display: flex; flex-direction: column; position: relative; z-index: 1; min-height: 0; }
.mt-bar { display: flex; align-items: center; gap: 14px; padding: 14px 20px; border-bottom: 1px solid var(--border); }
.mt-back { display: inline-flex; align-items: center; gap: 10px; min-height: var(--tap); padding: 0 22px; border-radius: var(--radius); background: var(--surface-2); border: 2px solid var(--border-strong); color: var(--text); font-family: var(--f-head); font-weight: 800; font-size: clamp(16px,1.9vw,21px); }
.mt-back:hover { border-color: var(--accent); color: var(--accent); }
.mt-title { flex: 1; font-size: clamp(18px, 2.6vw, 26px); font-family: var(--f-head); }
.mt-title small { color: var(--text-dim); font-weight: 600; font-size: .7em; }
[data-theme="paper"] .mt-title { font-family: var(--f-display); font-style: italic; }
.mt-theme { width: 52px; height: 52px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--accent); display: flex; align-items: center; justify-content: center; }

.mt-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; color: var(--text-muted); }
.mt-empty svg { color: var(--accent); opacity: .6; }

/* transport */
.mt-transport { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; padding: 14px 20px; border-bottom: 1px solid var(--border); }
.mt-play { display: inline-flex; align-items: center; gap: 12px; min-height: 60px; padding: 0 26px; border-radius: var(--radius); background: var(--accent); color: var(--on-accent); font-family: var(--f-head); font-weight: 700; font-size: 18px; box-shadow: var(--shadow); }
[data-theme="paper"] .mt-play { color: #fff; }
.mt-play.on { background: var(--danger); color: #fff; }
.mt-play:active { transform: scale(.98); }
.mt-tempo { display: flex; align-items: center; gap: 10px; }
.mt-tempo-btn { width: 64px; height: 64px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); display: flex; align-items: center; justify-content: center; }
.mt-tempo-btn:disabled { opacity: .4; }
.mt-tempo-val { font-size: 22px; font-weight: 700; min-width: 96px; text-align: center; }
.mt-tempo-val small { font-size: 13px; color: var(--text-muted); }
.mt-beat { display: flex; gap: 8px; align-items: center; }
.mt-beat-pip { width: 16px; height: 16px; border-radius: 50%; background: var(--surface-3); transition: transform .08s, background .08s; }
.mt-beat-pip.on { background: var(--accent); transform: scale(1.4); box-shadow: 0 0 14px var(--accent-glow); }

.mt-songpick { display: flex; gap: 8px; flex-wrap: wrap; margin-left: auto; }
.mt-song { display: inline-flex; align-items: center; gap: 7px; min-height: 60px; padding: 0 16px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); font-weight: 600; font-size: 14px; }
.mt-song svg { color: var(--accent); }
.mt-song.on { border-color: var(--accent); background: var(--accent-glow); color: var(--accent); }
.mt-song.xml { border-style: dashed; }
.mt-song-cat { font-size: 11px; font-weight: 600; color: var(--text-dim); background: var(--surface-3); padding: 2px 7px; border-radius: 999px; }
.mt-search { display: inline-flex; align-items: center; gap: 6px; min-height: 60px; padding: 0 14px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); }
.mt-search > svg { color: var(--text-dim); }
.mt-search-input { background: transparent; border: none; outline: none; color: var(--text); font-size: 14px; width: 110px; min-height: 44px; }

/* track tiles */
.mt-tiles { display: flex; gap: 10px; overflow-x: auto; padding: 8px 16px; flex-shrink: 0; }
.mt-tile { display: flex; flex-direction: column; gap: 5px; min-width: 150px; max-width: 184px; padding: 9px; border-radius: var(--radius); background: var(--surface); border: 1.5px solid var(--border); border-top: 5px solid var(--c); box-shadow: var(--shadow); transition: box-shadow .12s, transform .12s; }
.mt-tile.active { box-shadow: 0 0 0 2px var(--c), 0 0 22px color-mix(in srgb, var(--c) 45%, transparent); }
.mt-tile.pinned { border-color: var(--c); }
.mt-tile.muted { opacity: .6; }
.mt-tile-main { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 2px; border-radius: var(--radius-sm); background: transparent; color: var(--text); width: 100%; }
.mt-tile-art { width: 50px; height: 40px; display: flex; align-items: center; justify-content: center; }
.mt-tile-art img { width: auto; height: 100%; max-width: 100%; object-fit: contain; -webkit-user-drag: none; filter: drop-shadow(0 3px 8px rgba(0,0,0,.25)); }
.mt-tile-fallback { width: 56px; height: 56px; border-radius: 14px; display: block; }
.mt-tile-name { font-size: 16px; font-weight: 700; text-align: center; line-height: 1.1; }
.mt-tile-inst { font-size: 12px; color: var(--text-muted); }
.mt-pin { display: inline-flex; align-items: center; gap: 5px; margin-top: 4px; padding: 4px 10px; border-radius: 999px; background: var(--surface-3); color: var(--text-dim); font-size: 12px; font-weight: 700; }
.mt-pin.on { background: var(--c); color: var(--on-accent); }
.mt-tile-ctl { display: flex; gap: 8px; }
.mt-sm { flex: 1; display: inline-flex; flex-direction: row; align-items: center; justify-content: center; gap: 5px; min-height: 60px; padding: 4px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1.5px solid var(--border); color: var(--text); font-size: 12px; font-weight: 700; }
.mt-sm.solo.on { border-color: var(--warn); background: color-mix(in srgb, var(--warn) 18%, transparent); color: #c98a00; }
[data-theme="dark"] .mt-sm.solo.on { color: #f5d067; }
.mt-sm.mute.on { border-color: var(--danger); background: color-mix(in srgb, var(--danger) 16%, transparent); color: var(--danger); }

/* stacked notation */
.mt-stack { flex: 1; min-height: 0; overflow-y: auto; padding: 0 20px 16px; display: flex; flex-direction: column; gap: 8px; }
.mt-stack-hint { display: flex; align-items: center; gap: 10px; justify-content: center; padding: 30px; color: var(--text-muted); font-size: 15px; }
.mt-stack-hint svg { color: var(--accent); opacity: .7; }
.mt-row { flex-shrink: 0; border-radius: var(--radius); background: var(--surface); border: 1px solid var(--border); border-left: 5px solid var(--c); overflow: hidden; transition: box-shadow .12s; }
.mt-row.active { box-shadow: 0 0 0 2px var(--c), 0 0 20px color-mix(in srgb, var(--c) 40%, transparent); }
.mt-row-head { display: flex; align-items: center; gap: 10px; padding: 4px 12px; border-bottom: 1px solid var(--border); }
.mt-row-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--c); flex-shrink: 0; }
.mt-row-id b { display: block; font-size: 15px; }
.mt-row-id small { color: var(--text-muted); font-size: 12px; }
.mt-row-close { margin-left: auto; width: 60px; height: 60px; border-radius: var(--radius-sm); background: var(--surface-2); border: 1px solid var(--border); color: var(--text-dim); display: flex; align-items: center; justify-content: center; }
.mt-staff-scroll { overflow-x: auto; padding: 6px 4px; }
.mt-staff-svg { display: block; }
.mt-staff-line { stroke: var(--border-strong); stroke-width: 1; }
.mt-bar-line { stroke: var(--border); stroke-width: 1; opacity: .6; }
.mt-note-stem { stroke: var(--text-dim); stroke-width: 1.4; }
.mt-note.done .mt-note-stem { stroke: var(--c); }
.mt-accidental { fill: var(--text-dim); font-size: 13px; }
.mt-lyric { fill: var(--text); font-size: 12px; font-weight: 600; }
.mt-note.done + .mt-lyric, .mt-note.done .mt-lyric { fill: var(--c); }
.mt-playhead { stroke: var(--accent); stroke-width: 2; opacity: .9; }

@media (max-width: 720px) {
  .mt-songpick { margin-left: 0; }
}

/* phone: relax fixed grid to a scrollable 2-col flow */
@media (max-width: 720px) {
  .grid-page { overflow-y: auto; }
  .grid10 { position: static; height: auto; min-height: calc(100% - var(--footer-h)); grid-template-columns: repeat(2, 1fr); grid-auto-rows: minmax(118px, auto); grid-template-rows: none; overflow: visible; }
  .grid10 > * { grid-column: auto !important; grid-row: auto !important; }
  .grid10 .shub-brand, .grid10 .hub2-title, .grid10 .brand-card, .grid10 .shub-bc { grid-column: 1 / -1 !important; }
  .grid-page .legal-footer { position: static; }
  .cat-art svg { width: 70px; height: 64px; }
}
