  /* Plovoucí ovládací sloupce nad plátnem */
  .controls-col {
    position: fixed; top: 0; z-index: 10;
    display: flex; flex-direction: column; gap: 7px;
    width: 270px; max-height: 100vh; max-height: 100dvh; overflow-y: auto; overflow-x: visible;
    padding: 6px 8px 14px;
    /* Oblackove menu (styly-menu): zaklad dost nepruhledny pro citelnost i bez
       blur; @supping nize ho zesklovi (frosted glass). Blur je jen na sloupci
       (2 vrstvy), ne na kazde palete -> setrne k iOS GPU. */
    background: rgba(10,11,15,0.72);
    scrollbar-width: none; /* posuvník nezobrazovat; scroll kolečkem/touch zůstává */
    transition: transform 0.9s cubic-bezier(0.22, 0.61, 0.36, 1); /* klidná dynamika jako rozbalování palet */
  }
  .controls-col::-webkit-scrollbar { display: none; }
  /* Frosted glass jen tam, kde to prohlizec umi; jinak zustane nepruhledne pozadi vyse. */
  @supports ((backdrop-filter: blur(2px)) or (-webkit-backdrop-filter: blur(2px))) {
    .controls-col {
      background: rgba(10,11,15,0.46);
      -webkit-backdrop-filter: blur(16px) saturate(1.15);
      backdrop-filter: blur(16px) saturate(1.15);
    }
  }
  #controls-left  { left: 40px; border-right: 1px solid rgba(255,255,255,0.10); border-radius: 0 16px 16px 0; box-shadow: 6px 0 22px rgba(0,0,0,0.38), 2px 0 6px rgba(0,0,0,0.30); }
  #controls-right { right: 40px; border-left: 1px solid rgba(255,255,255,0.10); border-radius: 16px 0 0 16px; box-shadow: -6px 0 22px rgba(0,0,0,0.38), -2px 0 6px rgba(0,0,0,0.30); }
  #controls-left.hidden  { transform: translateX(calc(-100% - 30px)); }
  #controls-right.hidden { transform: translateX(calc(100% + 30px)); }

  /* overflow-x:hidden na panelu by vynutilo overflow-y:auto (scroll u každé sekce) — nepoužívat */
  /* Oblackove palety: mekce zaoblene, polopruhledne (skrz prosviti zesklenny
     sloupec), vrstveny mekky stin = "obláčkový" dojem. Vlastni backdrop-filter
     ZAMERNE nemaji (blur resi sloupec) -> mene GPU vrstev na mobilu. */
  .panel {
    border: 1px solid rgba(255,255,255,0.10); border-radius: 12px; padding: 6px 8px; overflow: visible;
    box-shadow: 0 1px 2px rgba(0,0,0,.22), 0 6px 16px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.05);
  }
  #tipPoolA, #tipPoolB { overflow: visible; max-height: none; }
  .panel-title {
    color: #999; font-size: 10px; letter-spacing: 2px;
    text-transform: uppercase; margin-bottom: 4px;
    padding-bottom: 3px; border-bottom: 1px solid #222;
    display: flex; align-items: center; gap: 4px; flex-wrap: nowrap;
    position: relative;
  }
  .panel-fold-toggle {
    flex-shrink: 0; margin: 0; padding: 0 3px; min-width: 14px; height: 14px; line-height: 1;
    border: none; background: transparent; color: #c8a050; cursor: pointer;
    font-family: 'Courier New', monospace; font-size: 11px; font-weight: 700;
    text-align: center; border-radius: 2px;
  }
  .panel-fold-toggle:hover { color: #f0c868; background: rgba(232,160,64,0.12); }
  .panel:not(.collapsed) .panel-fold-toggle { font-size: 13px; letter-spacing: -1px; }
  .panel-title-text { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .panel-title span { color: #e8a040; }
  .panel-title .side { color: #6a8aaa; }
  .panel.collapsed .title-auto-row,
  .panel.collapsed .title-tools { display: none !important; }
  .panel.collapsed .panel-title { margin-bottom: 0; border-bottom-color: transparent; padding-bottom: 2px; }
  /* Klidné, "dřevěné" rozbalování/zabalování těla palety. Trik grid 1fr<->0fr
     animuje skutečnou výšku obsahu (žádná pevná max-height = žádné prázdné
     dojíždění). Obsah je v .panel-body-inner s overflow:hidden. */
  .panel-body {
    display: grid;
    grid-template-rows: 1fr;
    transition: grid-template-rows 0.9s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .panel.collapsed .panel-body { grid-template-rows: 0fr; }
  .panel-body-inner { overflow: hidden; min-height: 0; }
  /* Zabalená paleta s náhodností — indikátor auto-random vpravo v záhlaví */
  .panel-rand-lentilka {
    display: none;
    width: 11px; height: 7px; border-radius: 50%;
    margin-left: auto; flex-shrink: 0; pointer-events: none;
    background: radial-gradient(circle at 34% 30%, #5ee068 0%, #2a9840 45%, #1a6028 78%, #0c3014 100%);
    box-shadow: 0 0 5px rgba(70,200,90,0.28);
    transition: filter 0.14s ease, box-shadow 0.14s ease, background 0.2s ease, transform 0.12s ease;
  }
  /* Na zabalenem panelu je lentilka klikaci = zap/vyp randomizace panelu bez rozbaleni. */
  .panel.collapsed .panel-rand-lentilka {
    display: block; position: relative;
    pointer-events: auto; cursor: pointer;
  }
  /* Zvetseny neviditelny dotykovy/mysi terc (viditelna pilulka je jen 11x7 px). */
  .panel.collapsed .panel-rand-lentilka::before {
    content: ''; position: absolute; inset: -8px -10px -8px -4px;
  }
  .panel.collapsed .panel-rand-lentilka:hover { transform: scale(1.22); }
  .panel.collapsed .panel-rand-lentilka:focus-visible { outline: 2px solid #6fb8ff; outline-offset: 2px; }
  /* Hover-rozbalení: najetí myší na zabalenou paletu (vč. záhlaví) ji dočasně
     rozbalí, výjezd myši ji zase zabalí. Fixní stav (tlačítko V/>) nedotčen. */
  .panel.collapsed.hover-open .panel-body,
  .panel.collapsed.hover-open .title-auto-row { display: block !important; }
  .panel.collapsed.hover-open .title-tools { display: flex !important; }
  .panel.collapsed.hover-open .panel-title { margin-bottom: 4px; border-bottom-color: #222; padding-bottom: 3px; }
  .panel.collapsed.hover-open .panel-rand-lentilka { display: none; }
  .panel-rand-lentilka.off {
    box-shadow: none;
    filter: none;
    background: radial-gradient(circle at 34% 30%, #60b8e8 0%, #2060b0 50%, #0d3070 100%);
  }
  /* Resetovací „lentilky" v titulku sekce (vpravo) */
  .title-tools { margin-left: auto; flex-shrink: 0; display: flex; gap: 3px; align-items: center; }
  .title-auto-row { margin-bottom: 4px; padding-bottom: 2px; border-bottom: 1px solid #1a1a1a; }
  .title-auto-row .row { margin-bottom: 0; }
  /* Ikonky záhlaví — plné SVG v kuličce (ui-modernizace). Glyf v tlačítku
     skryt (font-size:0); ikona přes background-image, barva kuličky dle typu. */
  .sec-reset {
    width: 18px; height: 18px; min-width: 18px; padding: 0; border-radius: 50%;
    background-color: #18261a; border: 1px solid #3a6a3a;
    background-repeat: no-repeat; background-position: center; background-size: 11px 11px;
    font-size: 0; color: transparent; line-height: 0;
    display: inline-flex; align-items: center; justify-content: center; cursor: pointer;
    box-shadow: inset 0 1px 1px rgba(255,255,255,.12), 0 1px 2px rgba(0,0,0,.55);
    transition: background-color .12s ease, box-shadow .12s ease, filter .12s ease, border-color .3s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23bfeabf' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 12a9 9 0 1 0 3-6.7L3 8'/%3E%3Cpath d='M3 4v4h4'/%3E%3C/svg%3E");
  }
  .sec-reset:hover { background-color: #284a28; filter: brightness(1.18); }
  /* Random — kostka (zlatá kulička) */
  .sec-reset.sec-random,
  .sec-reset[data-pool$="Rand"] {
    background-color: #2a2210; border-color: #6a5a20;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23f0d890'%3E%3Ccircle cx='7' cy='7' r='2.4'/%3E%3Ccircle cx='17' cy='17' r='2.4'/%3E%3Ccircle cx='17' cy='7' r='2.4'/%3E%3Ccircle cx='7' cy='17' r='2.4'/%3E%3C/svg%3E");
  }
  .sec-reset.sec-random:hover,
  .sec-reset[data-pool$="Rand"]:hover { background-color: #4a3818; filter: brightness(1.15); }
  /* Vybrat vše — fajfka (zelená kulička) */
  .sec-reset[data-pool$="All"] {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d6f5d6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 12l5 5L20 6'/%3E%3C/svg%3E");
  }
  /* Vybrat žádný / smazat presety — křížek (červená kulička) */
  .sec-reset.red,
  .sec-reset[data-pool$="None"] {
    background-color: #2a1414; border-color: #7a3a3a;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffc6c6' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M6 6l12 12M18 6L6 18'/%3E%3C/svg%3E");
  }
  .sec-reset.red:hover,
  .sec-reset[data-pool$="None"]:hover { background-color: #4a2020; filter: brightness(1.15); }
  .controls-col.glow .sec-reset.red { border-color: #7a3a3a; } /* červená reset zůstává červená i při svícení */
  /* fyzika-granular: per-faktor kostka v řadě efektu — drobná zlatá kulička vpravo */
  .phys-factor-rand {
    width: 14px; height: 14px; min-width: 14px; background-size: 9px 9px;
    margin-left: auto; opacity: 0.42;
  }
  .phys-factor-rand:hover { opacity: 1; }

  .row { display: flex; align-items: center; gap: 3px; margin-bottom: 3px; min-width: 0; }
  label { color: #aaa; }
  /* Popisek vlevo u posuvníku: zkrátí se výpustkou, aby .val neujel mimo panel */
  .row > label:first-child {
    flex: 0 1 72px; min-width: 0; max-width: 48%;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  /* Popisek u checkboxu/radia (za inputem): může zalomenout na více řádků */
  .row > input[type=checkbox] + label,
  .row > input[type=radio] + label {
    flex: 1 1 auto; min-width: 0; max-width: none;
    overflow: visible; text-overflow: clip; white-space: normal;
  }
  input[type=range] {
    height: 3px; cursor: pointer;
    flex: 1 1 40px; min-width: 28px;
    -webkit-appearance: none; appearance: none;
    background: linear-gradient(to right, #2a2010, #6a5028);
    border-radius: 2px;
  }
  input[type=range]::-webkit-slider-thumb {
    -webkit-appearance: none; appearance: none;
    width: 8px; height: 8px; margin-top: 0; border: none; border-radius: 50%;
    background: radial-gradient(circle at 32% 28%, #ffe8a8 0%, #e8a040 38%, #9a6018 72%, #4a3010 100%);
    box-shadow: 0 1px 2px rgba(0,0,0,0.55), inset 0 -2px 3px rgba(0,0,0,0.35), inset 0 1px 1px rgba(255,255,255,0.35);
    cursor: pointer;
  }
  input[type=range]::-moz-range-track {
    height: 3px; border: none; border-radius: 2px;
    background: linear-gradient(to right, #2a2010, #6a5028);
  }
  input[type=range]::-moz-range-thumb {
    width: 8px; height: 8px; border: none; border-radius: 50%;
    background: radial-gradient(circle at 32% 28%, #ffe8a8 0%, #e8a040 38%, #9a6018 72%, #4a3010 100%);
    box-shadow: 0 1px 2px rgba(0,0,0,0.55), inset 0 -2px 3px rgba(0,0,0,0.35), inset 0 1px 1px rgba(255,255,255,0.35);
    cursor: pointer;
  }
  .val { color: #e8a040; min-width: 30px; text-align: right; font-size: 10px; flex-shrink: 0; }
  /* Roletky: vlastní šipka v rezervovaném prostoru vpravo (padding-right) →
     text akce a šipka se nikdy nepřekreslují. Vlastní appearance:none + SVG šipka
     kvůli jednotnému vykreslení napříč OS (Windows/macOS/Safari/Linux). */
  select {
    background-color: #111; color: #ccc; border: 1px solid #333;
    border-radius: 2px; padding: 1px 17px 1px 4px; font-size: 10px;
    cursor: pointer; flex: 1; min-width: 0;
    -webkit-appearance: none; -moz-appearance: none; appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%23999' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 5px center; background-size: 8px 5px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  /* Zlatý 3D checkbox — globálně místo bílých systémových (ui-modernizace) */
  input[type=checkbox] {
    -webkit-appearance: none; appearance: none;
    width: 15px; height: 15px; min-width: 15px; flex-shrink: 0; margin: 0 1px 0 0;
    border-radius: 4px; cursor: pointer; position: relative; vertical-align: middle;
    background: linear-gradient(145deg, #3a2c12, #1a1208);
    border: 1px solid #4a3a18;
    box-shadow: inset 0 2px 3px rgba(0,0,0,.7), inset 0 -1px 1px rgba(255,220,150,.10), 0 1px 2px rgba(0,0,0,.5);
    transition: background .12s ease, box-shadow .12s ease, border-color .12s ease;
  }
  input[type=checkbox]:hover { border-color: #6a5424; }
  input[type=checkbox]:checked {
    background: linear-gradient(145deg, #ffe8a8, #c8902e 60%, #8a5e18);
    border-color: #5a4018;
    box-shadow: inset 0 1px 1px rgba(255,255,255,.5), inset 0 -2px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.6);
  }
  input[type=checkbox]:checked::after {
    content: ''; position: absolute; left: 4px; top: 1px;
    width: 4px; height: 8px; border: solid #2a1c08; border-width: 0 2px 2px 0;
    transform: rotate(45deg);
  }
  input[type=checkbox]:disabled { opacity: .4; cursor: default; }
  input[type=radio] { accent-color: #e8a040; cursor: pointer; }
  button {
    background: #161616; color: #999; border: 1px solid #1c2a1c;
    border-radius: 2px; padding: 1px 5px; font-size: 10px;
    cursor: pointer; font-family: 'Courier New', monospace;
    transition: border-color 0.3s ease;
  }
  /* Rozsvícení rámečků: per-tlačítko gradient dle vzdálenosti od myši řídí JS
     (_applyMenuGlow v 12-pools-rot.js) inline border-color. Dřív tu byl plošný
     `.controls-col.glow button { border-color:#5fe05f }` — nahrazeno gradientem. */
  /* Nápovědné texty: stejně zeleně jako rámečky, ale slaběji; navíc podmínka — myš PŘÍMO nad panelem */
  .controls-col.glow .panel:hover .note { color: #5fe05f; opacity: 0.60; }
  body.nocursor, body.nocursor * { cursor: none !important; } /* skrytí kurzoru po nečinnosti */
  button:hover { background: #222; color: #bbb; }
  .step-btn { padding: 0 2px !important; min-width: 13px !important; font-size: 9px !important; flex-shrink: 0; }
  .sep { border-top: 1px solid #1e1e1e; margin: 4px 0 3px; }
  .note { color: #666; font-size: 9px; line-height: 1.4; margin-top: 2px; opacity: 1; transition: color 1s ease, opacity 1s ease; }
  #controls-left.menu-hints-off .panel .note,
  #controls-right.menu-hints-off .panel .note { display: none; }
  /* Úchyty pro škálování menu (na vnitřních hranách směrem ke středu):
     zlatý proužek 9 px; jas = původní − 50 (na škále 0–100, min 0): 100→50, 10→0 */
  /* Úchyty — absolutně ve sloupci (jedou se slide/zoom menu), ale JS je vertikálně připne
     k viditelnému oknu (top=scrollTop, height=clientHeight v _layoutColGrips), takže
     NErolují s obsahem a dají se uchopit i z dolních partií dlouhého menu.
     top/bottom:0 níže slouží jen jako výchozí hodnota, než JS nastaví inline top+height. */
  .controls-col .res-grip {
    position: absolute; top: 0; bottom: 0; width: 9px; z-index: 11; cursor: ew-resize;
    box-sizing: border-box; touch-action: none; /* dotyk: tažení úchytu nesmí scrollovat */
  }
  #controls-left .res-grip-out { left: -4.5px; }
  #controls-left .res-grip:not(.res-grip-out) { right: -4.5px; }
  #controls-right .res-grip-out { right: -4.5px; }
  #controls-right .res-grip:not(.res-grip-out) { left: -4.5px; }
  .res-grip::before { content:''; position:absolute; inset:0;
    background:linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(218,165,32,0.50) 50%, rgba(0,0,0,1) 100%);
    transition:filter 0.3s ease; }
  .res-grip:hover::before { filter:brightness(1.25); }
  /* Vnější proužek u okraje okna — jen vizuál, symetricky k vnitřnímu (−4.5 px od hrany panelu) */
  .res-grip-out { pointer-events:none; cursor:default; }
  .res-grip-out:hover::before { filter:none; }
  .unit { color: #777; margin-left: 1px; }

  /* Tři odlišná modrá podbarvení: strom A (tyrkysová) / strom B (indigová) / společné (oceánská modř) */
  .panel.apanel { background:rgba(12,54,64,0.60); border-color:#2a6878; }
  .panel.apanel .panel-title { border-bottom-color:#285865; }
  .panel.bpanel { background:rgba(20,27,70,0.60); border-color:#33459a; }
  .panel.bpanel .panel-title { border-bottom-color:#2c3d80; }
  .panel.bpanel .panel-title .side { color:#90aae0; }
  .panel.cpanel { background:rgba(18,58,94,0.58); border-color:#2e5e90; }
  .panel.cpanel .panel-title { border-bottom-color:#285478; }
  .panel.cpanel.audio-panel .panel-title span { color:#70d070; }
  .panel.cpanel.reset-panel .panel-title span { color:#d07070; }

  /* ---- Z-Lab (Faze 1): velky vizualizer, barevne prepinace, historie, zalozky ---- */
  #zlabPanel .zlab-cbtn {
    padding: 2px 8px; font-size: 9px; border-radius: 3px; cursor: pointer;
    background: #0e2538; color: #5a86a6; border: 1px solid #244a68; transition: all .15s ease;
  }
  #zlabPanel .zlab-cbtn:hover { color: #9cc8e8; border-color: #3a6a92; }
  #zlabPanel .zlab-cbtn.active { background: #1f5078; color: #cfeaff; border-color: #4a8ec0; }
  #zlabPanel .zlab-hist-pill {
    padding: 1px 5px; font-size: 9px; border-radius: 8px; white-space: nowrap;
    background: #0e2538; color: #6aa0c8; border: 1px solid #234a68;
    font-family: 'Courier New', monospace; letter-spacing: .02em;
  }
  #zlabPanel .zlab-hist-pill.recent { background: #1a4368; color: #b8e0ff; border-color: #3a78a8; }
  #zlabPanel .zlab-tab {
    flex: 1; padding: 4px 2px; font-size: 9px; cursor: pointer; text-align: center;
    background: transparent; color: #5a86a6; border: none; border-bottom: 2px solid transparent;
    transition: all .15s ease;
  }
  #zlabPanel .zlab-tab:hover { color: #9cc8e8; }
  #zlabPanel .zlab-tab.active { color: #cfeaff; border-bottom-color: #4a8ec0; }
  #zlabPanel .zlab-tabpane { padding: 6px 2px; }
  #zlabPanel .zlab-soon {
    color: #4a6e8e; font-size: 10px; font-style: italic; line-height: 1.5;
    background: #0a1820; border: 1px dashed #234a60; border-radius: 4px; padding: 8px;
  }
  /* ---- Z-Lab (Faze 2): mapping engine — radky mapovani, cile, monitor ---- */
  #zlabPanel .zlab-maphdr { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; color: #5a86a6; font-size: 10px; }
  #zlabPanel .zlab-maprow { display: flex; align-items: center; gap: 3px; margin-bottom: 4px; padding: 4px; background: #0a1820; border-radius: 3px; flex-wrap: wrap; }
  #zlabPanel .zlab-maprow select { background-color: #0e2538; color: #9cc8e8; border: 1px solid #244a68; border-radius: 3px; font-size: 9px; padding: 1px 16px 1px 4px; max-width: 80px; }
  #zlabPanel .zlab-maprow input[type=range] { flex: 1; min-width: 40px; }
  #zlabPanel .zlab-arrow { color: #406080; font-size: 10px; }
  #zlabPanel .zlab-rm { cursor: pointer; color: #a05858; font-size: 11px; padding: 0 3px; background: none; border: none; }
  #zlabPanel .zlab-rm:hover { color: #e07070; }
  #zlabPanel .zlab-tgt { margin-bottom: 6px; padding: 5px 6px; background: #0a1820; border-radius: 3px; }
  #zlabPanel .zlab-tgt-h { display: flex; justify-content: space-between; align-items: center; color: #80b0d0; font-size: 10px; margin-bottom: 3px; }
  #zlabPanel .zlab-tbar-row { display: flex; align-items: center; gap: 5px; font-size: 8px; color: #507898; margin-top: 2px; }
  #zlabPanel .zlab-tbar-row label { min-width: 44px; }
  #zlabPanel .zlab-tbar-track { flex: 1; height: 7px; background: #08131c; border-radius: 3px; overflow: hidden; }
  #zlabPanel .zlab-tbar-fill { height: 100%; width: 0; background: linear-gradient(90deg, #1f5078, #60c8f0); transition: width .05s linear; }
  /* ---- Skin-Lab (Faze A): karty consumeru, nahled skinu ---- */
  #skinlabPanel .skinlab-card { margin-bottom: 6px; padding: 5px 7px; background: #150a1f; border: 1px solid #3a2a5a; border-radius: 4px; }
  #skinlabPanel .skinlab-head { display: flex; align-items: center; }
  #skinlabPanel .skinlab-name { color: #cba8ec; font-size: 11px; cursor: pointer; display: flex; align-items: center; gap: 5px; }
  #skinlabPanel .skinlab-body { margin-top: 5px; }
  #skinlabPanel .skinlab-row { display: flex; align-items: center; gap: 5px; margin-bottom: 4px; font-size: 9px; color: #9878b8; }
  #skinlabPanel .skinlab-row.skinlab-check { cursor: pointer; }
  #skinlabPanel .skinlab-lab { min-width: 40px; color: #80609a; }
  #skinlabPanel .skinlab-row select { background-color: #1c1030; color: #cba8ec; border: 1px solid #3a2a5a; border-radius: 3px; font-size: 9px; padding: 1px 16px 1px 4px; flex: 1; }
  #skinlabPanel .skinlab-row input[type=range] { flex: 1; min-width: 40px; accent-color: #b890e0; }
  #skinlabPanel .skinlab-val { min-width: 28px; text-align: right; color: #b890e0; font-family: 'Courier New', monospace; }
  #skinlabPanel .skinlab-preview { display: block; width: 100%; height: auto; margin-top: 5px; border-radius: 3px; border: 1px solid #3a2a5a; background: #06101a; image-rendering: auto; }
  #skinlabPanel .skinlab-soon { color: #6e4a8e; font-size: 10px; font-style: italic; line-height: 1.5; background: #120a1c; border: 1px dashed #3a2a5a; border-radius: 4px; padding: 8px; }
  /* Reset: ✛ Kříž vpravo na řádku s titulkem Reset */
  .reset-panel-head { justify-content: space-between; gap: 8px; }
  .reset-panel-head > span:first-child { flex: 0 1 auto; }
  .cross-mode-inline {
    flex: 0 0 auto; margin-left: auto;
    display: inline-flex; align-items: center; gap: 4px;
    min-width: 0; color: #d8a0e8; font-size: 9px; letter-spacing: 0.5px;
    text-transform: none; cursor: pointer; white-space: nowrap;
  }
  .cross-mode-inline input[type=checkbox] { flex-shrink: 0; margin: 0; }
  .cross-mode-inline span { color: #d8a0e8; overflow: hidden; text-overflow: ellipsis; }
  /* Reset paleta — solitaire „wow" záblesk po kliknutí (jen tlačítka v .reset-panel) */
  .reset-panel button {
    transition: border-color 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease, transform 0.15s ease;
    overflow: hidden;
  }
  .reset-panel button.reset-btn-wow {
    animation: resetBtnWow 0.72s cubic-bezier(0.22, 1, 0.36, 1);
    z-index: 2;
  }
  @keyframes resetBtnWow {
    0%   { transform: scale(1);    filter: brightness(1);    box-shadow: 0 0 0 0 rgba(255,210,80,0);   border-color: #444; }
    12%  { transform: scale(1.045); filter: brightness(1.45); box-shadow: 0 0 14px 3px rgba(255,210,80,0.85), 0 0 22px 5px rgba(120,200,255,0.45); border-color: #ffd060; }
    28%  { transform: scale(1.03);  filter: brightness(1.35); box-shadow: 0 0 12px 2px rgba(200,120,255,0.75), 0 0 18px 4px rgba(100,230,170,0.5);  border-color: #c878ff; }
    44%  { transform: scale(1.02);  filter: brightness(1.28); box-shadow: 0 0 10px 2px rgba(100,230,170,0.65), 0 0 16px 3px rgba(255,160,90,0.45);  border-color: #60e0a8; }
    62%  { transform: scale(1.01);  filter: brightness(1.15); box-shadow: 0 0 8px 1px rgba(255,160,90,0.4);  border-color: #e8a040; }
    100% { transform: scale(1);    filter: brightness(1);    box-shadow: none; border-color: #444; }
  }

  .panel:has(#sceneType){ background:rgba(16,58,74,0.58); border-color:#2e6a82; }   /* Scéna — teal */
  .panel:has(#exerciseOn){ background:rgba(26,35,80,0.60); border-color:#3a4690; }  /* Tanečník — indigo */
  .panel.apanel:has(#aRandLen){ background:rgba(15,66,78,0.58); }                   /* Náhodnost A — světlejší teal */
  .panel.apanel:has(#autoRotA){ background:rgba(10,46,55,0.60); }                   /* Auto-rotace A — tmavší teal */
  .panel:has(#gravity){ background:rgba(15,61,100,0.58); border-color:#356aa0; }     /* Fyzika — jasná oceán */
  .panel:has(#dist){ background:rgba(28,43,82,0.60); border-color:#3a4d96; }        /* Společné — modroindigo */
  .panel#panelHud { background:rgba(21,34,56,0.60); border-color:#3a5078; }
  .panel#panelHud .panel-title { border-bottom-color:#2a4060; }
  .panel#panelHud .panel-title span { color:#88c8e8; }
  .panel:has(#overlapCheck){ background:rgba(15,56,72,0.58); border-color:#2f6480; }/* Překryv — teal */
  .panel:has(#presetBtns){ background:rgba(24,36,78,0.60); border-color:#37458e; }  /* Presety — indigo */
  /* Editace hard presetu — zvýraznění editovaného tlačítka */
  #presetBtns button.hp-editing {
    box-shadow: 0 0 0 2px #ffaa00, 0 0 8px rgba(255,170,0,0.55);
    filter: brightness(1.9);
    outline: none;
  }
  .panel.bpanel:has(#bRandLen){ background:rgba(26,34,86,0.60); }                   /* Náhodnost B — světlejší indigo */
  .panel.bpanel:has(#autoRotB){ background:rgba(16,21,58,0.62); }                   /* Auto-rotace B — tmavší indigo */
  .panel:has(#souvislostiOn){ background:rgba(34,26,72,0.60); border-color:#5046a0; }/* Souvislosti — fialová (mapování napříč režimy) */
  .panel.audio-panel{ background:rgba(18,58,82,0.58); border-color:#2f5e84; }       /* Zvuk — oceán (zelený titul) */
  .panel:has(#btnExport){ background:rgba(26,36,80,0.60); border-color:#39479a; }   /* Uložení — indigo */
  .panel:has(#angPresetBtns),
  .panel:has(#angPresetBtnsA){ background:rgba(13,42,24,0.60); border-color:#1e5830; }/* Předvolby úhlů — tmavě zelená */

  /* Předvolby úhlů — barevné dlaždice */
  .ang-btn{
    flex:0 0 calc(25% - 3px); padding:3px 2px; border-radius:3px; border:none; cursor:pointer;
    font-size:8px; color:#fff; text-shadow:0 1px 2px rgba(0,0,0,.75);
    font-family:'Courier New',monospace; line-height:1.3; text-align:center;
    transition:opacity .12s,transform .08s; box-shadow:0 1px 3px rgba(0,0,0,.45);
  }
  .ang-btn:hover{ opacity:.80; transform:scale(1.05); }
  .ang-btn:active{ opacity:.60; transform:scale(.96); }
  .ang-name{ display:block; font-weight:bold; font-size:9px; }
  .ang-vals{ display:block; font-size:7px; opacity:.85; }

  /* Sloupcový meter pro tóny */
  #audioMeter { margin-top: 6px; }
  .meter-bars { display: flex; gap: 3px; align-items: flex-end; height: 26px; }
  .note-col { flex: 1; position: relative; height: 100%; overflow: hidden; }
  .note-bar { position: absolute; left: 0; right: 0; bottom: 0; height: 0; }
  .note-peak { position: absolute; left: 0; right: 0; height: 2px; bottom: 0; background: rgba(255,255,255,0.6); opacity: 0; }
  .meter-side { font-size: 8px; color: #8aa; letter-spacing: 1px; margin: 4px 0 1px; }
  .meter-labels { display: flex; gap: 3px; font-size: 8px; color: #555; margin-top: 2px; }
  .meter-labels span { flex: 1; text-align: center; }

  /* ===== SKINY MENU (ui-modernizace) — přepínač v panelu HUD =====
     Výchozí = "current" (žádné přepisy → ponechává teal/indigo/oceán per sekce).
     !important nutné, protože per-sekční barvy jdou přes .panel:has(#id) (vyšší specificita). */
  /* Zlaté balení — prodejní „premium" look */
  body[data-skin="gold"] .controls-col .panel { background: #1c1810 !important; border-color: #5a4a28 !important; }
  body[data-skin="gold"] .controls-col .panel-title { border-bottom-color: #4a3a20 !important; }
  body[data-skin="gold"] .controls-col .panel-title span,
  body[data-skin="gold"] .controls-col .panel-title .side { color: #e8c87a !important; }
  body[data-skin="gold"] .controls-col { background: rgba(14,11,6,0.92); }
  /* Čakrový — neutrální tmavé panely, fialové tituly, duhová hrana sloupce (7 čaker) */
  body[data-skin="chakra"] .controls-col .panel { background: #130f17 !important; border-color: #2a2233 !important; }
  body[data-skin="chakra"] .controls-col .panel-title { border-bottom-color: #332a40 !important; }
  body[data-skin="chakra"] .controls-col .panel-title span,
  body[data-skin="chakra"] .controls-col .panel-title .side { color: #c89ad8 !important; }
  body[data-skin="chakra"] #controls-left { border-right: 3px solid; border-image: linear-gradient(#e0506a,#e88030,#f0d040,#50c070,#4090d0,#5060c0,#9a70d0) 1; }
  body[data-skin="chakra"] #controls-right { border-left: 3px solid; border-image: linear-gradient(#9a70d0,#5060c0,#4090d0,#50c070,#f0d040,#e88030,#e0506a) 1; }
  /* Pastelový — měkká fialovo-růžová */
  body[data-skin="pastel"] .controls-col .panel { background: #2a2630 !important; border-color: #6a5a7a !important; }
  body[data-skin="pastel"] .controls-col .panel-title { border-bottom-color: #5a4a6a !important; }
  body[data-skin="pastel"] .controls-col .panel-title span,
  body[data-skin="pastel"] .controls-col .panel-title .side { color: #e8c8d8 !important; }
  body[data-skin="pastel"] .controls-col { background: rgba(30,26,36,0.92); }

  /* ===== Oblackove menu (styly-menu): ohleduplnost k pohybu =====
     prefers-reduced-motion: nevypina vse, jen zkrati/zrusi dlouhe pohyby
     (slide sloupce, dlouhe rozbalovani palet, "wow" zablesk resetu). */
  @media (prefers-reduced-motion: reduce) {
    .controls-col { transition: none; }
    .panel-body { transition: grid-template-rows 0.12s linear; }
    .reset-panel button.reset-btn-wow { animation-duration: 0.2s; }
  }

  /* ===== Zjevovaci bublina popisku menu (menu-tips, Faze 1) =====
     Plovouci, nad menu; pointer-events:none -> nikdy nezacloni ovladani. Odhali
     cely orezany popisek + kratky popis (k cemu to je). Bez scrollbaru. */
  #tmc-tip {
    position: fixed; z-index: 99990; pointer-events: none;
    max-width: 270px; padding: 6px 9px;
    background: rgba(13,19,25,0.97); border: 1px solid #2c4a5a; border-radius: 5px;
    box-shadow: 0 4px 18px rgba(0,0,0,0.55);
    color: #cfe2ee; font: 11px/1.45 'Courier New', monospace;
    opacity: 0; transform: translateY(3px);
    transition: opacity 0.14s ease, transform 0.14s ease;
    -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  }
  #tmc-tip.on { opacity: 1; transform: translateY(0); }
  #tmc-tip .tmc-tip-title { color: #e8a040; font-weight: 700; white-space: normal; }
  #tmc-tip .tmc-tip-desc  { color: #9fb6c4; white-space: pre-line; margin-top: 2px; }
  #tmc-tip .tmc-tip-title:empty, #tmc-tip .tmc-tip-desc:empty { display: none; }
  @media (prefers-reduced-motion: reduce) {
    #tmc-tip { transition: opacity 0.1s linear; transform: none; }
    #tmc-tip.on { transform: none; }
  }

  /* ── Dotykova plovouci lista [ − ☰ + ] (P1-A menu toggle + P1-B zoom) ──
     Element vytvari JS jen na dotykovem zarizeni (hover:none + pointer:coarse);
     na desktopu vubec neexistuje, takze tyto styly se uplatni jen na dotyku. */
  #touchCtlBar {
    position: fixed; left: 50%; bottom: 12px; transform: translateX(-50%);
    z-index: 9300; display: flex; gap: 12px;
    pointer-events: none;                 /* mezery propousti tah na platno (posun obrazu) */
  }
  #touchCtlBar .touch-ctl-btn {
    pointer-events: auto;
    width: 54px; height: 54px; border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.22);
    background: rgba(12,14,20,0.80);
    color: #f0e6c8; font-size: 27px; line-height: 1; font-weight: 600;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 3px 14px rgba(0,0,0,0.48);
    -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
    cursor: pointer; -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;           /* bez 300ms delay a double-tap zoomu na tlacitku */
    -webkit-user-select: none; user-select: none;
  }
  #touchCtlBar .touch-ctl-btn:active { background: rgba(40,44,56,0.94); transform: scale(0.94); }

  /* ── Dotykova horni lista [ rezim v ] [ i ] (P2-1 prepinac rezimu + P2-3 info) ──
     Take touch-only, vytvari ji stejny JS blok jako #touchCtlBar. */
  #touchTopBar {
    position: fixed; left: 50%; top: 8px; transform: translateX(-50%);
    z-index: 9300; display: flex; gap: 10px; align-items: center;
    pointer-events: none;
  }
  #touchTopBar > * { pointer-events: auto; }
  #touchModeSel {
    min-height: 44px; padding: 6px 12px; border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.22);
    background: rgba(12,14,20,0.82); color: #f0e6c8;
    font-size: 16px; font-weight: 600;
    -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
    -webkit-tap-highlight-color: transparent; touch-action: manipulation;
    box-shadow: 0 3px 14px rgba(0,0,0,0.48);
  }
  #touchTopBar #touchInfoBtn { width: 44px; height: 44px; font-size: 22px; font-style: italic; }
  /* Licencni odznak NEAKTIVOVANO (full-build, neaktivovano) je top-center stejne jako tato lista
     -> kdyz svit, posun listu pod nej, aby se neprekryvaly (audit re2 2026-06-28).
     Lite zadny odznak nema -> trida se nenastavi -> bez efektu. */
  body.tmc-lic-badge-on #touchTopBar { top: 72px; }
