:root{
  --bg:#0f1115; --fg:#e8ebf0; --muted:#9aa3b2; 
  --brand:#4aa3ff; 
  --accent: var(--brand);
  --warn:#ffb74d; --danger:#ff6b6b; --card:#151a21; --border:#232a35;
  --shadow: 0 6px 18px rgba(0,0,0,.25);
}

/* Reset & base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font:16px/1.45 system-ui,Segoe UI,Roboto,Helvetica,Arial;
  background:var(--bg);
  color:var(--fg);
}

/* ===== Sidebar (header) + global layout ===== */
body{ display:flex; }

/* Lewy panel jako stały sidebar — BEZ ROZMYCIA, z ładnym scrollem i rynną na scrollbar */
header{
  position:fixed;
  left:0;
  top: var(--topbar-h);      /* pod topbarem */
  bottom:0;
  width:220px;
  padding:16px;
  border-right:1px solid var(--border);
  background: var(--card);   /* jednolite tło */
  display:flex;
  flex-direction:column;
  gap:12px;
  z-index:2000;              /* poniżej topbara */
  overflow-y:auto;           /* własny scroll, niezależny od strony */
  overflow-x:hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable both-edges; /* rezerwuje miejsce na scrollbar po prawej */
}

/* estetyczny scrollbar w sidebarze */
header::-webkit-scrollbar{ width: 10px; }
header::-webkit-scrollbar-track{
  background:#0b0e13;
  border-left:1px solid var(--border);
}
header::-webkit-scrollbar-thumb{
  background:#2a3342;
  border-radius:8px;
  border:2px solid #0b0e13; /* żeby nie „wchodził” na przyciski */
}
header::-webkit-scrollbar-thumb:hover{ background:#3a4558; }
header{ scrollbar-width: thin; scrollbar-color:#2a3342 #0b0e13; } /* Firefox */

header h1{ margin:0 0 8px; font-size:1.2rem; text-align:center }

/* Nawigacja pionowa w headerze */
header nav, header .nav{
  display:flex;
  flex-direction:column;
  gap:10px;
}
header nav a, header .nav a{
  color:var(--fg);
  text-decoration:none;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:8px;
  text-align:center;
  background:#121722;
  transition: border-color .15s ease, transform .05s ease, background .15s ease;
}
header nav a:hover, header .nav a:hover{ border-color:var(--brand); background:#161c28 }
header nav a.active, header .nav a.active{ outline:2px solid var(--brand) }

/* „Hamburger” na pasku */
header nav .navbtn{
  appearance:none; border:1px solid var(--border); border-radius:8px; background:#121722; color:var(--fg);
  padding:12px 16px;
  cursor:pointer; text-align:center; width:100%;
  font-size:0.95rem;
}
header nav .navbtn:hover{ border-color:var(--brand); background:#161c28; }

/* Stopka wewnątrz lewego paska */
.sidebar-footer{
  margin-top:auto;
  border-top:1px solid var(--border);
  color:var(--muted);
  font-size:.85rem;
  text-align:center;
  padding:8px 0 0;
}

/* Główna kolumna po prawej od sidebaru */
main{
  flex:1;
  padding:16px 24px;
  margin-left:220px; /* miejsce na sidebar */
  min-width:0;
  margin-right:360px; /* rezerwa miejsca na prawy panel */
}

/* Headings */
h1,h2,h3{margin:8px 0 12px}

/* Steps / routes */
.step, .route{
  display:none; background:var(--card); padding:16px; border:1px solid var(--border);
  border-radius:10px; max-width:1100px; margin:0 auto 20px; box-shadow:var(--shadow);
}
.step.active, .route.active{ display:block }
.hidden{display:none !important}

/* Layout grids */
.grid{
  display:grid; grid-template-columns:repeat(2,minmax(240px,1fr)); gap:12px;
}
@media (max-width:900px){
  .grid{ grid-template-columns:1fr }
}

/* Form controls */
label{display:block; color:var(--muted); margin-bottom:6px}
input, textarea, select,
label input, label textarea{
  width:100%; padding:10px; border:1px solid var(--border); border-radius:8px;
  background:#0b0e13; color:var(--fg); outline:none;
}
textarea{min-height:110px; resize:vertical}

/* Buttons / actions */
.actions, .nav{
  margin-top:16px;display:flex;gap:12px;flex-wrap:wrap
}
button, .buttonlike{
  padding:10px 14px; border:1px solid var(--border); border-radius:8px;
  background:#121722; color:var(--fg); cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; justify-content:center;
  transition:transform .05s ease, border-color .15s ease;
}
button:hover,.buttonlike:hover{border-color:var(--brand)}
button:active{ transform: translateY(1px) }
button.secondary,.buttonlike.secondary{background:#10151d}
button.toggle.active{outline:2px solid var(--brand)}

/* przycisk-ikona (kosz) */
button.icon{
  width:28px; height:28px; padding:0; display:grid; place-items:center; border-radius:8px;
}
button.icon svg{ display:block; width:16px; height:16px; }

/* === KROK 2: lista rysunków z grubością === */
#drawingsList{
  list-style:none;
  padding:0;
  margin:10px 0;
  display:block;              /* zamiast gridu kart */
}

/* jeden wiersz: 1/3 nazwa + 2/3 pola */
#drawingsList li{
  border:1px dashed var(--border);
  border-radius:8px;
  padding:8px;
  background:#0c1016;

  display:grid;
  grid-template-columns:2fr 1fr;  /* 1/3 : 2/3 */
  align-items:center;
  gap:12px;
}

/* select z jednostkami nie rozciąga się */
#drawingsList li select{
  width: auto;         /* realna szerokość nada mu skrypt – = szerokości przycisku */
  flex: 0 0 auto;      /* nie rośnie */
}

/* prawa część w jednej linii */
#drawingsList li > div:last-child{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
}

/* input na grubość */
#drawingsList li input[type="number"]{
  width:80px;
  text-align:right;
}

#drawingsList img{max-width:100%;display:block}

/* Toolbar & canvas / SVG */
.selector{margin:10px 0}
.toolbar{display:flex;gap:8px;margin:8px 0 12px;flex-wrap:wrap}

/* --- PODGLĄD --- */
#canvasWrap{
  border:1px solid var(--border);
  border-radius:8px;
  padding:8px;
  background:#0c1016;
  height:600px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

#svgContainer{
  background:#0b0f16;
  border-radius:8px;
  height:100%;
  overflow:hidden;
  display:block;
}

/* SVG rozciąga się do rozmiaru kontenera */
#svgContainer svg{
  width:100%;
  height:100%;
  display:block;
}

/* Picklists */
.picklist{ list-style:none; margin:8px 0 12px; padding:0; display:grid; gap:8px }
.picklist li{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:10px 12px; background:#111722; border:1px solid var(--border); border-radius:10px;
  font-variant-numeric: tabular-nums;
}
.picklist li.active{ outline: 2px solid var(--brand); }
.picklist .name{ cursor:pointer }
.picklist .name:hover{ text-decoration:underline }
.picklist .del:hover{ color:var(--danger) }

/* Cards & price box */
.card{border:1px solid var(--border);border-radius:10px;padding:12px;background:#111722;margin-top:12px; box-shadow:var(--shadow)}
.price{ margin-top:16px; font-size:18px; display:flex; align-items:center; gap:12px;
  background:#10151d; border:1px solid var(--border); border-radius:10px; padding:12px 14px;
}
.price strong{ font-size:22px }

/* SVG highlight feedback */
.highlight{ filter: drop-shadow(0 0 6px rgba(88,214,141,.85)); stroke: var(--accent) !important }

/* ==== Responsywność sidebaru ==== */
@media (max-width: 860px){
  header{ width: 180px; padding:12px; }
  main{ margin-left:180px }
}
/* Przy 640px NIE zmieniamy już sidebara na sticky — nadal jest fixed */
@media (max-width: 640px){
  main{ margin-left:0; margin-right:0; } /* możesz chcieć nadpisać niżej; zostawiam jak było */
}

/* ==== KROK 3: scena ==== */
.stage3{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
  align-items: start;
}

/* ==== PRAWY PANEL ==== */
.sidepane-fixed {
  position: fixed;
  top: calc(var(--topbar-h) + 16px);   /* pod topbarem */
  right: 0;
  width: 340px;

  background: #111722;
  border-left: 1px solid var(--border);
  border-radius: 10px 0 0 10px;
  box-shadow: -3px 0 12px rgba(0,0,0,0.3);
  padding: 10px;

  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 50;

  /* Klucz: wysokość zależna od zawartości, ale z limitem = wysokość okna */
  max-height: calc(100vh - var(--topbar-h) - 32px);
  overflow-y: auto;
}


/* akordeon */
.acc-item{
  border:1px solid var(--border);
  border-radius:10px;
  background:#111722;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.acc-btn{
  width:100%;
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:12px 14px; 
  background:#121722; 
  border:0; 
  border-bottom:1px solid var(--border);
  cursor:pointer; 
  font-weight:600;
  
    /* tu dochodzi animacja */
  transition:
    background-color 0.25s ease,
    color 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}
.acc-btn:hover{ border-color:var(--brand) }
.acc-caret{ font-size:14px; opacity:.9 }
.acc-panel{ display:none; padding:10px 12px; }
.acc-item.acc-open .acc-panel{ display:block }
.acc-panel .picklist{ margin:8px 0 10px }

/* Nagłówek aktywnej (rozwiniętej) sekcji */
.acc-item.acc-open > .acc-btn{
  background-color:#182335;                 /* trochę jaśniejsze tło */
  box-shadow:0 0 0 1px #2e3b55 inset;       /* delikatna obwódka */
  color:#ffffff;
}


/* Scrollbar dla list – stała wysokość, bez zależności od vh */
#cutsList.picklist,
#drillsList.picklist{
  max-height: 320px;          /* ~5–6 pozycji, możesz zmienić np. na 280/360 */
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: #354158 #0b0e13;
}

#cutsList.picklist::-webkit-scrollbar,
#drillsList.picklist::-webkit-scrollbar{ width: 8px; }
#cutsList.picklist::-webkit-scrollbar-track,
#drillsList.picklist::-webkit-scrollbar-track{
  background: #0b0e13;
  border-left: 1px solid var(--border);
}
#cutsList.picklist::-webkit-scrollbar-thumb,
#drillsList.picklist::-webkit-scrollbar-thumb{
  background: #2a3342;
  border-radius: 8px;
  border: 1px solid #0b0e13;
}
#cutsList.picklist::-webkit-scrollbar-thumb:hover,
#drillsList.picklist::-webkit-scrollbar-thumb:hover{
  background: #354158;
}

/* Na węższych ekranach panel pod treścią */
@media (max-width: 900px){
  .sidepane-fixed{
    position: static; width: 100%;
    border-left: none; border-radius: 0; box-shadow: none; margin-top: 10px; max-height: none;
  }
  main{ margin-right:0; }
}

/* LIGHT THEME */
.theme-light{
  --bg:#f7f8fa; --fg:#0c1220; --muted:#5e6b7f; 
  --brand:#0b63ff; 
  --accent: var(--brand);
  --warn:#f39c12; --danger:#e74c3c; --card:#ffffff; --border:#dfe6ef;
}

/* Modal */
.modal{ position:fixed; inset:0; display:grid; place-items:center; background:rgba(0,0,0,.5); z-index:9999; }
.modal.hidden{ display:none !important; }
.modal-card{
  width:min(720px, 92vw);
  background:var(--card);
  color:var(--fg);
  border:1px solid var(--border);
  border-radius:12px;
  box-shadow: 0 12px 40px rgba(0,0,0,.25);
  padding:16px;
}
.modal-card h3{ margin:0 0 12px; }
.modal-card .grid{
  display:grid;
  grid-template-columns: 1fr; 
  gap:12px;
}
.modal-card .actions{ display:flex; gap:8px; justify-content:flex-end; margin-top:8px; }
.modal-card button.secondary{ background:transparent; border:1px solid var(--border); }

.upload-buttons {
  display: flex;
  gap: 16px;
  margin-top: 8px;
}

.btn-primary,
.btn-secondary {
  font-size: 1rem;
  padding: 10px 18px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.3s;
}

.btn-primary {
  background-color: #007bff;
  color: white;
}

.btn-primary:hover {
  background-color: #005fcc;
}

.btn-secondary {
  background-color: #555;
  color: white;
}

.btn-secondary:hover {
  background-color: #333;
}

.no-spin::-webkit-outer-spin-button,
.no-spin::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.no-spin {
  -moz-appearance: textfield;
}

/* ===== Okno operacji (draggable, 5 zakładek, sticky foot) ===== */
.op-dialog {
  position: fixed;
  left: 50%;
  top: 15vh;                 /* 1/4 wysokości ekranu od góry */
  transform: translateX(-50%); /* centrowanie w poziomie */
  z-index: 99999;
  width: min(900px, 92vw);
  max-height: 92vh;              /* okno mieści się w viewport */
  overflow: auto;                /* ewentualny scroll całego okna */  
  background: var(--card); color: var(--fg);
  border: 1px solid var(--border); border-radius: 12px;
  box-shadow:
     0 18px 55px rgba(0,0,0,.55),
     0 0 0 2px rgba(255,255,255,.03),
     0 0 28px rgba(80,160,255,.25); /* jaśniejszy glow */
  pointer-events: auto;
}

.op-head {
  cursor: move; user-select: none;
  display:flex; align-items:center; gap:8px;
  padding: 10px 12px; border-bottom:1px solid var(--border); background:#121722;
  border-radius:12px 12px 0 0;
}
.op-head h3 { margin:0; font-size:16px }
.op-actions{ margin-left:auto; display:flex; gap:8px; }
.op-body { padding: 10px 12px 12px; /* bez sztywnego max-height */ }.op-tabs { display:flex; gap:8px; border-bottom:1px solid var(--border); padding-bottom:8px; margin-bottom:8px; flex-wrap:wrap }
.op-tab { padding:6px 10px; border:1px solid var(--border); border-raius:8px; background:#10151d; cursor:pointer; }
.op-tab[aria-selected="true"] { outline:2px solid var(--brand) }
.op-panel { display:none }
.op-panel.active { display:block }
/* przyciski w nagłówku */
.op-actions .save   { background:#ffe600; color:#111; border-color:#d4c400; cursor:pointer; }
.op-actions .gen    { background:#4a90e2; color:#fff; border-color:#3f7cc2; cursor:pointer; }
.op-actions .cancel { background:#f7d7c8; color:#2b100a; border-color:#e8c1af; cursor:pointer; }

/* małe detale dla formularza */
.op-body .grid { display:grid; grid-template-columns: 1fr 1fr; gap:10px }
.op-body .grid.onecol { grid-template-columns: 1fr; }
@media (max-width: 780px){ .op-body .grid { grid-template-columns: 1fr } }

/* pole opisowe */
.field { display:flex; flex-direction:column; gap:4px }
.field small { opacity:.65; font-style:italic }
.row { display:flex; align-items:center; gap:10px; flex-wrap:wrap }
.grow { flex:1 1 200px }
input[type="number"], input[type="text"], select {
  width: 100%; padding:8px 10px; background:#0f141c; color:var(--fg);
  border:1px solid var(--border); border-radius:6px;
}
/* zielone przyciski wyboru (pojedynczy wybór w grupie) */
.choice-group { display:flex; gap:8px; flex-wrap:wrap }
.choice{
  padding:6px 12px;
  border:1px solid #355a8a;    /* niebieskawa ramka */
  background:#1b2a42;          /* ciemny, niebieskawy „idle” */
  color:#eaf1ff;
  border-radius:6px;
  cursor:pointer; user-select:none;
}
.choice:hover{
  border-color: var(--brand);
  background:#213352;
}
.choice[aria-pressed="true"]{
  background: var(--brand);     /* aktywny = brand */
  color:#fff;
  border-color: var(--brand);
}


.choice[disabled] { opacity:.45; cursor:not-allowed }
/* prawy panel z parametrami narzędzia */
.tool-summary { min-width: 220px; border:1px dashed var(--border); border-radius:8px; padding:10px 12px; }
.tool-summary dt { opacity:.7 }
.tool-summary dd { margin:0 0 6px 0 }

/* ładne scrollbary tylko w oknie operacji */
.op-body::-webkit-scrollbar { width: 12px }
.op-body::-webkit-scrollbar-thumb { background:#2a3444; border-radius:10px }
.op-body::-webkit-scrollbar-track { background:transparent }


/* ——— Ujednolicenie pól w oknie operacji — naprawa łamania ——— */
:root{ --op-num-width: 160px; }

/* liczby: stała, wąska szerokość jak RPM, ale bez wymuszania szerokiego flex-basis */
.op-dialog .op-panel .row input[type="number"]{
  width: var(--op-num-width) !important;
  flex: 0 0 auto !important;   /* było: 0 0 var(--op-num-width) → robiło twarde „min” */
}

/* tekst/textarea/select: pozwól rosnąć, ale bez 240px minimalnej szerokości */
.op-dialog .op-panel .row input[type="text"],
.op-dialog .op-panel .row textarea,
.op-dialog .op-panel .row select{
  width: 100% !important;
  flex: 1 1 0% !important;     /* było: 1 1 240px — to podnosiło wysokość wierszy */
  min-width: 0 !important;     /* zapobiega wymuszonym zawijaniom w flexboxie */
}

/* CV/CCV obok RPM – niech zajmują tylko swoją naturalną szerokość + przesunięcie 16px */
.op-dialog .op-panel .row .choice-group{
  flex: 0 0 auto !important;
  white-space: nowrap;      /* nie rozpychaj wiersza */
  margin-left: 26px !important;  /* <<< przesunięcie w prawo */
}


/* na wszelki wypadek, zostaw „gap” wierszy jak wcześniej */
.op-dialog .op-panel .row{ gap:10px; }  /* w obu plikach było 10px */



/* ===== Tryb pełnoekranowy obszaru roboczego (pseudo-FS w obrębie strony) ===== */
.fs-mode header{ display:none !important; }
.fs-mode main{ margin-left:0 !important; margin-right:0 !important; padding:8px !important; }
.fs-mode .sidepane-fixed{ z-index:1000; } /* panel zawsze nad obszarem roboczym */

.fs-mode #canvasWrap{
  position: fixed !important;
  inset: 8px var(--fs-right, 360px) 8px 8px;  /* miejsce na prawy panel */
  height: auto !important;
  z-index: 500;  /* pod panelem, nad tłem */
}

@media (max-width: 900px){
  /* na wąskich – panel i tak robi się „nie-fixed”; w FS wymuszamy pełny ekran pod panelem */
  .fs-mode #canvasWrap{ inset: 8px 8px 8px 8px; }
}

/* Pływający, okrągły przycisk w prawym dolnym rogu obszaru roboczego */
#canvasWrap .fs-btn{
  position: absolute;
  right: 14px; bottom: 14px;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: #121722;
  color: var(--fg);
  box-shadow: var(--shadow);
  cursor: pointer;
  user-select: none;
}
#canvasWrap .fs-btn:hover{ border-color: var(--brand); }

/* (komentarz funkcyjny pozostawiony z poprzedniej wersji pliku)
W oknie głónym z lewej strony w tym panelu bocznym, po Krok 3 a przed Wycena, powinien być przycisk "Parametry" ...
*/

/* === Przyciski w krokach formularza === */
button,
input[type="button"],
input[type="submit"] {
  background-color: #1a1f2a;         /* ciemny granat, pasuje do tła */
  color: #ddd;                       /* jasny tekst */
  border: 1px solid #2b3240;         /* delikatna ramka */
  padding: 6px 14px;
  border-radius: 4px;
  transition: all 0.2s ease;
  cursor: pointer;
}

button:hover,
input[type="button"]:hover,
input[type="submit"]:hover {
  background-color: #2b3240;         /* trochę jaśniejszy przy najechaniu */
  color: #fff;
  border-color: #3a4354;
}

button:active,
input[type="button"]:active,
input[type="submit"]:active {
  background-color: #394253;         /* ciut ciemniejszy klik */
}

/* Dodatkowy kolor akcentu dla ważnych akcji */
button.primary,
input[type="submit"].primary {
  background-color: #2d5cff;         /* delikatny niebieski akcent */
  color: white;
  border: none;
}
button.primary:hover,
input[type="submit"].primary:hover {
  background-color: #4d7dff;
}

/* === Delikatne niebieskie podświetlenie wybranych przycisków === */
#openQuoteBtn,
#openQuoteConfirm,
a.buttonlike[href="#/step2"] {
  background-color: #1e2a44;       /* ciemny niebiesko-szary */
  color: #eaf1ff;                  /* lekko błękitny tekst */
  border: 1px solid #355a8a;       /* niebieskawe obramowanie */
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}

#openQuoteBtn:hover,
#openQuoteConfirm:hover,
a.buttonlike[href="#/step2"]:hover {
  background-color: #2d5cff;       /* jasny, delikatny niebieski */
  border-color: #3a6fff;
  color: #fff;
}

/* ===== Topbar ===== */
#topbar{
  position: fixed;                  /* <<< NA STAŁE U GÓRY */
  top: 0; 
  left: 0;                          /* <<< pełna szerokość od lewej */
  right: 0;                         /* <<< pełna szerokość do prawej */
  width: 100%;                      /* <<< bezwzględnie 100% */
  z-index: 3000;                    /* nad sidebarami i treścią */
  display:flex; align-items:center; justify-content:space-between;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,0));
  backdrop-filter: blur(6px);
  box-shadow: 0 6px 14px rgba(0,0,0,.25);
  margin-left: 0;                   /* <<< nic nie przesuwa topbara */
}

/* na wąskim układzie topbar pozostaje fixed na pełną szerokość */
@media (max-width: 640px){
  #topbar{ position: fixed; top: 0; left: 0; right: 0; width:100%; }
}

#topbar .tb-left, #topbar .tb-right{ display:flex; align-items:center; gap:8px; }

#topbar .tb-logo{
  display:inline-flex; align-items:center; gap:0px;  /* mniejsza przerwa między ikoną a tekstem */
  border:0px solid var(--border); border-radius:8px;
  padding:0px 0px;                                   /* to zwęża i obniża przycisk */
  background:#121722; color:var(--fg); cursor:pointer;
}

#topbar .tb-logo svg{
  /* większa zawartość: logo + napis */
  display:block;
  height:40px;              /* powiększony środek */
  width:120px;
}


#topbar .tb-btn{
  display:flex; align-items:center; gap:0px;
  padding:8px 12px; border:1px solid var(--border); border-radius:999px;
  background:#121722; color:var(--fg); cursor:pointer;
  transition: border-color .15s ease, background .15s ease, transform .05s ease;
}
#topbar .tb-btn:hover{ border-color: var(--brand); background:#161c28; }
#topbar .tb-btn:active{ transform: translateY(1px); }
#topbar .tb-btn svg{ width:16px; height:16px; fill:currentColor; opacity:.95 }

/* delikatny wariant */
#topbar .tb-btn.soft{ background:#10151d; }

/* dropdown */
.tb-dropdown{ position:relative; }
.tb-menu{
  position:absolute; right:0; top: calc(100% + 6px);
  min-width: 220px;
  background: var(--card); border:1px solid var(--border); border-radius:10px;
  box-shadow: var(--shadow); padding:6px; display:none;
}
.tb-dropdown[aria-open="true"] .tb-menu{ display:block; }
.tb-item{
  width:100%; text-align:left; padding:8px 10px;
  background:transparent; color:var(--fg);
  border:1px solid transparent; border-radius:8px; cursor:pointer;
}
.tb-item:hover{ background:#121722; border-color:var(--border); }
.tb-item.danger{ color: var(--danger); }

/* topbar + fixed right panel spacing still OK */
body > main{ margin-top: 8px; }

/* ==== Layout z konfigurowalną szerokością lewego paska ==== */
:root { --sidebar-w: 220px; --topbar-h: 56px; }

/* ujednolicamy szerokość sidebara i margines main */
header{ width: var(--sidebar-w); }
main{ margin-left: var(--sidebar-w); }

/* TOPBAR – zawsze na górze i na całą szerokość */
#topbar{
  position: fixed;
  top: 0; 
  left: 0;                 /* <<< pełna szerokość */
  right: 0;
  height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 8px 12px;
  background: linear-gradient(180deg, rgba(16,21,30,.9), rgba(16,21,30,.75));
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(6px);
  z-index: 3000;
}
body{ padding-top: var(--topbar-h); }  /* zrób miejsce na topbar pod spodem */

/* przyciski/rozwijane w topbarze */
#topbar .tb-left, #topbar .tb-right{ display:flex; align-items:center; gap:8px; }
#topbar .tb-btn{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--border); border-radius:8px; padding:8px 10px;
  background:#121722; color:var(--fg); cursor:pointer;
}
#topbar .tb-btn.soft{ background:#10151d; }
#topbar .tb-btn:hover{ border-color: var(--brand); }
#topbar .tb-dropdown{ position:relative; }
#topbar .tb-menu{
  position:absolute; top:100%; right:0;
  min-width: 220px;
  background:#0f141e; border:1px solid var(--border); border-radius:10px;
  box-shadow: var(--shadow); padding:6px; display:none;
  font-size: 16px; text-align: left;               /* (6) większa czcionka + wyrównanie do lewej */
}
#topbar .tb-dropdown[aria-open="true"] .tb-menu{ display:block; }
#topbar .tb-item{
  width:100%; text-align:left; padding:8px 10px; border-radius:8px; border:1px solid transparent;
}
#topbar .tb-item:hover{ border-color: var(--brand); background:#161c28; }

/* ====== Zwinięcie lewego paska (4) ====== */
body.sidebar-collapsed{ --sidebar-w: 64px; }
body.sidebar-collapsed header h1 { display:none; }
body.sidebar-collapsed #navParamsList { display:none !important; }
body.sidebar-collapsed header nav a,
body.sidebar-collapsed header nav .navbtn{
  font-size: 0; padding: 10px; text-align:center;
}
body.sidebar-collapsed header nav a::before,
body.sidebar-collapsed header nav .navbtn::before{
  content: attr(data-icon);
  font-size: 18px; line-height: 1; display:inline-block;
}
/* topbar NIE przesuwa się przy zwinięciu paska */
body.sidebar-collapsed #topbar{ left: 0; }

/* (pozostawiony komentarz – w poprzedniej wersji był tu blok JS, który nie powinien być w CSS) */

/* Widok zwinięty – teksty znikają, zostaje ikonka z data-icon */
body.sidebar-collapsed header{
  width: var(--sidebar-w-collapsed) !important;
}
body.sidebar-collapsed main{
  margin-left: var(--sidebar-w-collapsed) !important;
}

/* Każdy .navbtn z atrybutem data-icon pokaże samą ikonkę */
header .navbtn[data-icon]::before{
  content: attr(data-icon);
  margin-right: 8px;
}
body.sidebar-collapsed header .navbtn span{
  display: none !important;       /* chowamy napisy */
}
body.sidebar-collapsed header .navbtn{
  text-align: center;
  padding: 10px;
}
body.sidebar-collapsed header .navbtn[data-icon]::before{
  margin-right: 0;                 /* ikonka wyśrodkowana */
  display: inline-block;
  font-size: 18px;
}

/* Szerokości w trybie normalnym */
header{ width: var(--sidebar-w); }
main{ margin-left: var(--sidebar-w); }

.vh{
  position:absolute!important; width:1px!important; height:1px!important;
  padding:0!important; margin:-1px!important; overflow:hidden!important;
  clip:rect(0,0,0,0)!important; white-space:nowrap!important; border:0!important;
}

/* Wymuś układ dwukolumnowy także na małych szerokościach
   i utrzymaj stały, przyklejony sidebar po lewej */
@media (max-width: 640px){
  body{ flex-direction: row !important; }
  header{
    position: fixed !important;
    left: 0 !important;
    top: var(--topbar-h) !important; 
    bottom: 0 !important;
    width: var(--sidebar-w) !important;
    border-right: 1px solid var(--border);
    border-bottom: 0 !important;
    overflow-y: auto !important;      /* niezależny scroll */
  }
  body.sidebar-collapsed header{ width: var(--sidebar-w-collapsed) !important; }
  main{
    margin-left: var(--sidebar-w) !important;
    margin-right: 0 !important;
  }
  body.sidebar-collapsed main{ margin-left: var(--sidebar-w-collapsed) !important; }
}
/* === [PATCH] 1) Usuń napis "CUTOR" na lewym pasku === */
/* Pokrywamy kilka możliwych wariantów znacznika/klasy */
header h1,
header .logo,
header .brand,
header .logo-text{
  display: none !important;
}

/* === [PATCH] 2) Przyciski w kolumnie – jednakowa szerokość (także po zwinięciu) === */
header nav a,
header .nav a,
header .navbtn,
header nav .navbtn{
  display: block !important;
  width: 100% !important;      /* wszystkie identyczna szerokość */
  box-sizing: border-box !important;
}

/* W trybie zwiniętym – wszystkie tylko ikonka, wyśrodkowane i tej samej szerokości */
body.sidebar-collapsed header nav a,
body.sidebar-collapsed header .nav a,
body.sidebar-collapsed header .navbtn,
body.sidebar-collapsed header nav .navbtn{
  font-size: 0 !important;     /* chowa tekst */
  text-align: center !important;
  padding: 10px !important;
  min-width: 0 !important;     /* brak „rozpychania” */
}
body.sidebar-collapsed header nav a::before,
body.sidebar-collapsed header .nav a::before,
body.sidebar-collapsed header .navbtn::before,
body.sidebar-collapsed header nav .navbtn::before{
  content: attr(data-icon);
  display: inline-block;
  font-size: 18px;
  line-height: 1;
  margin: 0;
}

/* === [PATCH] 3) Panel: układ nad stopką + ukrycie duplikatu z różowej ramki === */
/* Ustawiamy kolejność w kolumnie: najpierw nawigacja, potem #toggleRightPanel, na końcu stopka */
header{ display: flex !important; flex-direction: column !important; }
header nav{ order: 1; }
#toggleRightPanel{ order: 2; margin-top: 12px; margin-bottom: 8px; }
.sidebar-footer{ order: 3; }

/* Jeśli w layoucie jest „drugi” (zbędny) przycisk panelu na samym dole,
   schowaj go niezależnie od dokładnej klasy/tekstu. Poniższe selektory
   trafią w najczęstsze warianty: */
header .navbtn[title*="'- -'"],
header .navbtn[data-extra="duplicate"],
header .navbtn.duplicate{
  display: none !important;
}

/* A na wszelki wypadek: jeżeli JAKIKOLWIEK przycisk z atrybutem data-dup jest w sidebarze – schowaj */
header .navbtn[data-dup="true"]{ display: none !important; }

/* ===== [FIX] Stabilna szerokość lewego paska + treść nigdy pod nim ===== */

/* 1) Model szerokości oparty o jedną zmienną */
:root{
  --sidebar-wide: 220px;   /* standard */
  --sidebar-wide-sm: 180px;/* dla średnich ekranów */
  --sidebar-narrow: 64px;  /* zwinięty */
  --sidebar-current: var(--sidebar-wide);
}

/* 2) Zastosuj tę samą wartość do sidebara i marginesu treści */
header{
  width: var(--sidebar-current) !important;
  min-width: var(--sidebar-current) !important;
  max-width: var(--sidebar-current) !important;
  box-sizing: border-box !important;
}
main{
  margin-left: var(--sidebar-current) !important;   /* treść zawsze obok paska */
}

/* 3) Tryb zwinięty – jedna linia zmienia wszystko */
body.sidebar-collapsed{ --sidebar-current: var(--sidebar-narrow); }

/* 4) Średnie ekrany: węższy, ale spójny sidebar, treść nadal obok */
@media (max-width: 980px){
  :root{ --sidebar-current: var(--sidebar-wide-sm); }
  body.sidebar-collapsed{ --sidebar-current: var(--sidebar-narrow); }
}

/* 5) Małe ekrany: trzy rzeczy
      - zachowaj układ w wierszu,
      - sidebar dalej fixed, o stałej szerokości,
      - treść odsunięta dokładnie o szerokość paska. */
@media (max-width: 640px){
  body{ flex-direction: row !important; }

  header{
    position: fixed !important;
    left: 0 !important;
    top: var(--topbar-h) !important;
    bottom: 0 !important;
    width: var(--sidebar-current) !important;
    min-width: var(--sidebar-current) !important;
    max-width: var(--sidebar-current) !important;
    border-right: 1px solid var(--border);
    border-bottom: 0 !important;
    overflow-y: auto !important;
  }

  main{
    margin-left: var(--sidebar-current) !important;
    margin-right: 0 !important;
  }
}

/* 6) Nic wewnątrz sidebara nie może go rozszerzać */
header *{ max-width: 100% !important; }
header .navbtn,
header nav a,
header .nav a{
  width: 100% !important;
  min-width: 0 !important;
  overflow: hidden;            /* np. długi tekst/ikona nie „rozpycha” */
  text-overflow: ellipsis;
}

/* 7) Drobna kosmetyka: gdy pasek zwinięty – ikonki wyśrodkowane, bez wpływu na szerokość */
body.sidebar-collapsed header .navbtn,
body.sidebar-collapsed header nav a,
body.sidebar-collapsed header .nav a{
  font-size: 0 !important;
  text-align: center !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}
body.sidebar-collapsed header .navbtn::before,
body.sidebar-collapsed header nav a::before,
body.sidebar-collapsed header .nav a::before{
  content: attr(data-icon);
  font-size: 18px;
  line-height: 1;
  display: inline-block;
  margin: 0;
}
/* === Patch: szerszy zwinięty sidebar, żeby scrollbar nie przycinał ikon === */
:root{
  --sbw: 2px;                 /* szacowana szerokość scrollbara (Windows/Chrome ~12px) */
}

/* zwinięty pasek: było 64px, dodajemy miejsce na scrollbar */
:root{
  --sidebar-narrow: calc(84px + var(--sbw));
}

/* upewnij się, że w trybie zwiniętym faktycznie używamy nowej szerokości */
body.sidebar-collapsed{ --sidebar-current: var(--sidebar-narrow); }

/* zachowaj „rynienkę” na scrollbar (żeby nie wchodził na treść w pasku) */
header{ scrollbar-gutter: stable both-edges; }

/* === FINAL PATCH: zwinięty pasek nie zachodzi na treść === */

/* 1) Szerokość scrollbara i szerokość paska w trybie zwiniętym */
:root{
  --sbw: 2px; /* typowa szerokość scrollbara na Windows/Chrome */
  --sidebar-narrow: calc(80px + var(--sbw)); /* 64px ikony + rynna na scrollbar */
  --sidebar-w-collapsed: var(--sidebar-narrow); /* alias dla starych reguł */
}

/* 2) W trybie zwiniętym używamy w całym layoucie jednej zmiennej */
body.sidebar-collapsed{
  --sidebar-current: var(--sidebar-narrow);
}

/* 3) Twardo nadpisz szerokość sidebara i odsunięcie treści (wygrywa z wcześniejszymi !important) */
body.sidebar-collapsed header{
  width: var(--sidebar-current) !important;
  min-width: var(--sidebar-current) !important;
  max-width: var(--sidebar-current) !important;
}
body.sidebar-collapsed main{S
  margin-left: var(--sidebar-current) !important;
}

/* 4) Scrollbar w pasku – rynna po prawej, żeby nie nachodził na przyciski */
header{ scrollbar-gutter: stable both-edges; }

/* === FIX: zwinięty lewy pasek – ikony nie są przycinane (także na dużym oknie) === */

/* 1) Jedno źródło prawdy dla szerokości w trybie zwiniętym + zapas na scrollbar */
:root{
  --sbw: 12px;                          /* typowa szerokość scrollbara Windows/Chrome */
  --sidebar-collapsed-base: 64px;       /* docelowa szerokość „ikonkowa” bez zapasu */
  --sidebar-narrow: calc(var(--sidebar-collapsed-base) + var(--sbw) + 8px);
  /* alias dla starszych reguł, gdyby gdzieś jeszcze były użyte */
  --sidebar-w-collapsed: var(--sidebar-narrow);
}

/* 2) W trybie zwiniętym wszędzie używamy tej samej wartości */
body.sidebar-collapsed{
  --sidebar-current: var(--sidebar-narrow);
  --sidebar-w: var(--sidebar-narrow);   /* dla starych reguł header/main, gdyby działały wcześniej */
}

/* 3) Twardo nadpisz width/padding sidebara i margines treści (żeby nic nie weszło pod pasek) */
body.sidebar-collapsed header{
  width: var(--sidebar-current) !important;
  min-width: var(--sidebar-current) !important;
  max-width: var(--sidebar-current) !important;
  padding-left: 8px !important;         /* mniej wewnętrznego marginesu = więcej miejsca na ikonę */
  padding-right: 8px !important;
}
body.sidebar-collapsed main{
  margin-left: var(--sidebar-current) !important;
}

/* 4) Scrollbar po prawej ma „rynienkę”, więc nie nachodzi na przyciski */
header{ scrollbar-gutter: stable both-edges; }

/* 5) [Hotfix literówki] – jeśli wcześniej w arkuszu pojawiło się 'body.sidebar-collapsed main{S',
      ta poprawna reguła je nadpisze i przywróci odsunięcie treści. */

#camSvgContainer{
  height: calc(100vh - 260px); /* wygodna wysokość pod Twój layout */
  min-height: 420px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #0b0f16;
  overflow: hidden;          /* nie wylewa się pod nawigację */
  position: relative;
}
#camSvgContainer{
  height: calc(100vh - 260px);
  min-height: 420px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #0b0f16;
  overflow: hidden;           /* trzyma rysunek w ramce */
  position: relative;         /* dla HUD-a */
}

/* HUD legend (stała w rogu, ponad SVG) */
.cam-hud-legend{
  position: absolute;
  left: 16px; top: 16px;
  font-size: 12px; color: #cbd5e1;
  line-height: 1.4;
  pointer-events: none;
  user-select: none;
}
.cam-hud-legend .it{
  display: flex; align-items: center; gap: 10px; margin: 4px 0;
}
.cam-hud-legend .sw{
  width: 60px; height: 0; border-top-width: 2px; border-top-style: solid;
}
.cam-hud-legend .in  { border-top-color: #6ee7a8; }
.cam-hud-legend .cut { border-top-color: #4aa3ff; }
.cam-hud-legend .out { border-top-color: #f7c34c; }
.cam-hud-legend .rap { border-top-color: #ff6b6b; border-top-style: dashed; }

.cam-pane{
  position:absolute; left:8px; top:8px; bottom:8px; width:280px;
  background:#0f172a; border:1px solid var(--border); border-radius:8px;
  padding:10px; overflow:auto; z-index:10;
}
.cam-modes label { display:block; margin-bottom:6px; }
.cam-modes button { margin-top:6px; }
.cam-summary{ margin:10px 0; padding:8px; background:#0b1222; border:1px solid var(--border); border-radius:6px; }
.cam-ops-header{ font-weight:700; margin:6px 0; }
.cam-op-card{
  border:1px solid var(--border); border-radius:6px; padding:8px; margin-bottom:8px; background:#0b1222;
}
.cam-op-card .op-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.cam-op-card small{ opacity:.75; }
.cam-op-card .op-actions button{ margin-right:6px; }
/* Małe, kwadratowe ikonki w kartach operacji */
.cam-op-card .op-actions .iconbtn{
  width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center;
  padding:0; border:1px solid var(--border); border-radius:6px; background:#121722; color:var(--fg); cursor:pointer;
}
.cam-op-card .op-actions .iconbtn + .iconbtn{ margin-left:6px; }
.cam-op-card .op-actions .iconbtn.danger{ color:var(--danger); border-color:#5a2d2d; }
.cam-group-title{ margin:10px 0 6px; font-weight:700; color:#9cd3ff; }

/* —— Nowy wygląd: jedna grupa operacji (shape1) —— */
.op-group{border:1px solid var(--border); border-radius:10px; background:#0b1222; padding:10px; margin:10px 0 12px;}
.opg-head{display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px;}
.opg-head .title{font-weight:700; color:#9cd3ff}
.opg-list{list-style:none; margin:0; padding:0; display:grid; gap:8px;}
.opg-item{display:flex; align-items:center; justify-content:space-between; gap:8px; padding:8px 10px; border:1px solid var(--border); border-radius:8px; background:#0f172a;}
.opg-label{white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width: 190px;}
.op-group .actions .btn{ padding:6px 10px; border:1px solid var(--border); border-radius:8px; background:#121722; color:var(--fg); cursor:pointer; }
.op-group .actions .btn:hover{ border-color: var(--brand); background:#161c28; }
.op-group .actions .btn.danger{ color:#ff6b6b; border-color:#5a2d2d; }

/* na wszelki wypadek: ukryj „plusy” jeśli jakiś stary renderer je wstawi */
.opg-item [data-act="add"],
.cam-op-card [data-act="add"]{ display:none !important; }


/* Belka aktywnej operacji (w pasku #camToolbar) */
.cam-opbar{
  display:flex; align-items:center; gap:10px;
  border:1px solid var(--border); border-radius:10px;
  padding:8px; background:#0b1222; margin-left:auto;
  max-width:min(640px, 100%); flex:1 1 380px;
}
.cam-opbar .name{
  flex:1; display:flex; align-items:center; gap:8px;
  padding:6px 10px; border:1px solid var(--border); border-radius:8px;
  background:#0f172a;
}
.cam-opbar .name input{
  flex:1; background:transparent; border:0; color:var(--fg); outline:none;
  font:600 14px/1.2 system-ui,Segoe UI,Roboto,Helvetica,Arial;
}
.cam-opbar .actions{ display:flex; gap:8px; }
.cam-opbar .actions .btn{ padding:8px 12px; border:1px solid var(--border); border-radius:8px; background:#121722; color:var(--fg); cursor:pointer; }
.cam-opbar .actions .btn:hover{ border-color:var(--brand); background:#161c28; }
.cam-opbar .actions .danger{ color:#ff6b6b; border-color:#5a2d2d; }
.cam-opbar .actions .save{
  padding:10px 18px; font-weight:700; border:0;
  background: var(--brand); color:#fff; border-radius:10px;
}
.cam-opbar .actions .save:hover{ filter: brightness(1.05); }

/* Panel CAM niech nie zasłania SVG — tylko siedzi z boku */
.camArea { display:flex; gap:12px; align-items:flex-start; }
.cam-pane { position:relative; flex:0 0 280px; }

/* Tryby jako buttony */
.cam-mode-btns { display:flex; gap:6px; margin-bottom:8px; }
.cam-mode-btns button {
  flex:1;
  padding:6px 8px;
  border:1px solid var(--border);
  border-radius:6px;
  background:#0b1222;
  color:#cbd5e1;
  cursor:pointer;
}
.cam-mode-btns button.active {
  background:#2563eb;
  color:#fff;
}

/* Legenda CAM */
.cam-legend {
  margin-top:6px;
  padding:6px 8px;
  border:1px solid var(--border);
  border-radius:6px;
  background:#0b1222;
  font-size:13px;
}
.cam-legend div {
  display:flex;
  align-items:center;
  gap:6px;
  margin-bottom:3px;
}
.cam-legend span {
  width:20px; height:2px; display:inline-block;
}
.cam-legend .lead-in  { background:#6ee7a8; }
.cam-legend .cut      { background:#4aa3ff; }
.cam-legend .lead-out { background:#f7c34c; }
.cam-legend .rapid    { background:#ff6b6b; }

/* Układ CAM: panel + duży viewer */
.camArea { display:flex; gap:16px; align-items:flex-start; }
.cam-pane { flex:0 0 300px; position:relative; }
.cam-view { flex:1 1 auto; min-width:0; }

/* === Przybornik Wiercenia obok przycisku "Wiercenia" w CAM === */

/* upewniamy się, że przycisk + przybornik stoją ładnie w jednym rzędzie */
.cam-mode-btns {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* same "pudełko" przybornika – baza */
.cam-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-left: 6px;          /* odstęp od przycisku Wiercenia */
  padding: 3px 6px;
  border-radius: 999px;
  font-size: 11px;
  line-height: 1.2;
  border: 1px solid var(--border, #333);
  background: rgba(0, 0, 0, 0.45); /* domyślnie coś sensownego pod dark mode */
}

.cam-toolbar--hidden {
  display: none;
}

/* przyciski w przyborniku */
.cam-toolbar__btn {
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 11px;
  line-height: 1.2;
  cursor: pointer;
  white-space: nowrap;
  border: 1px solid transparent;
  background: transparent;
  color: inherit;
}

/* trochę "klikowalności" */
.cam-toolbar__btn:hover {
  background: rgba(255, 255, 255, 0.06);
}

/* =========================================================
   MOTYW: CIEMNY  (setTheme = "dark")
   ========================================================= */
body[data-theme="dark"] .cam-toolbar,
body.theme-dark .cam-toolbar {
  background: #111822;
  border-color: var(--border, #333);
}

body[data-theme="dark"] .cam-toolbar__btn,
body.theme-dark .cam-toolbar__btn {
  color: #f5f7fb;
}

body[data-theme="dark"] .cam-toolbar__btn:hover,
body.theme-dark .cam-toolbar__btn:hover {
  background: rgba(255, 255, 255, 0.06);
}

/* =========================================================
   MOTYW: JASNY  (setTheme = "light")
   ========================================================= */
body[data-theme="light"] .cam-toolbar,
body.theme-light .cam-toolbar {
  background: #f5f7fb;
  border-color: var(--border, #ccc);
}

body[data-theme="light"] .cam-toolbar__btn,
body.theme-light .cam-toolbar__btn {
  color: #111827;
}

body[data-theme="light"] .cam-toolbar__btn:hover,
body.theme-light .cam-toolbar__btn:hover {
  background: rgba(0, 0, 0, 0.06);
}

/* =========================================================
   MOTYW: PREMIUM DARK MODE  (setTheme = "premium")
   ========================================================= */
body[data-theme="premium"] .cam-toolbar,
body.theme-premium .cam-toolbar {
  background: radial-gradient(circle at top left, #1d2738, #05070c);
  border-color: rgba(110, 168, 254, 0.5); /* pod var(--brand) */
}

body[data-theme="premium"] .cam-toolbar__btn,
body.theme-premium .cam-toolbar__btn {
  color: #e5edff;
  border-color: transparent;
}

body[data-theme="premium"] .cam-toolbar__btn:hover,
body.theme-premium .cam-toolbar__btn:hover {
  background: rgba(110, 168, 254, 0.16);
}



/* Pasek CAM jako elastyczny wiersz */
#camToolbar{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

#camToolbar{
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
}


#camSvgContainer {
  height: 74vh;               /* duży obszar roboczy */
  min-height: 520px;
  width: 100%;
  border:1px solid var(--border);
  border-radius:8px;
  background:#0b0f16;
  position:relative;
  overflow:hidden;            /* brak pasków */
}

/* niech wstrzyknięte <svg> wypełnia kontener */
#camSvgContainer svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Edycja operacji (karta) */
.cam-op-card .op-edit {
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:8px 10px;
  margin-top:6px;
}
.cam-op-card .op-edit label { font-size:12px; opacity:.85; display:block; }
.cam-op-card .op-edit input, .cam-op-card .op-edit select {
  width:100%; background:#0b1222; color:#cbd5e1; border:1px solid var(--border);
  border-radius:6px; padding:4px 6px;
}
.cam-op-card .op-actions button { margin-left:6px; }

/* Pływające okno Narzędzia */
.tools-window{
  position:fixed; top:6rem; right:2rem; width:420px; max-height:80vh;
  background:#fff; color:#0c1220; box-shadow:0 10px 30px rgba(0,0,0,.2);
  border-radius:8px; overflow:hidden; z-index:9999; display:none;
}
.tools-window header{
  display:flex; align-items:center; justify-content:space-between;
  padding:.6rem .8rem; font-weight:600; background:#f5f5f7; cursor:move;
}
.tools-window .body{ padding:.8rem; overflow:auto; max-height:calc(80vh - 46px); }
.tools-window .close{ border:0; background:transparent; font-size:1.2rem; }
.tools-window.show{ display:block; }   /* <<< to przełącza widoczność */

.seg-btn.active { background: var(--brand); color: #fff; }

 /* Dialog: bez natywnej ramki i z lekkim tłem */
 dialog { border: none; padding: 0; background: transparent; }
 dialog::backdrop { background: rgba(0,0,0,.45); }
 dialog .modal-card { max-width: 720px; }
 dialog .modal-body .grid label > input,
 dialog .modal-body .grid label > select { width: 100%; }
 
/* === CAM: belka aktywnej operacji – w środku #camToolbar === */
.cam-opbar{
  display:flex; align-items:center; gap:10px;
  border:1px solid var(--border); border-radius:10px;
  padding:8px; background:#0b1222; margin-left:auto;
  max-width:min(640px, 100%); flex:1 1 380px;
}
.cam-opbar .name{
  flex:1; display:flex; align-items:center; gap:8px;
  padding:6px 10px; border:1px solid var(--border); border-radius:8px;
  background:#0f172a;
}
.cam-opbar .name input{
  flex:1; background:transparent; border:0; color:var(--fg); outline:none;
  font:600 14px/1.2 system-ui,Segoe UI,Roboto,Helvetica,Arial;
}
.cam-opbar .actions{ display:flex; gap:8px; }
.cam-opbar .actions .btn{ padding:8px 12px; border:1px solid var(--border); border-radius:8px; background:#121722; color:var(--fg); cursor:pointer; }
.cam-opbar .actions .btn:hover{ border-color:var(--brand); background:#161c28; }
.cam-opbar .actions .danger{ color:#ff6b6b; border-color:#5a2d2d; }
.cam-opbar .actions .save{
  padding:10px 18px; font-weight:700; border:0;
  background: var(--brand); color:#fff; border-radius:10px;
}
.cam-opbar .actions .save:hover{ filter: brightness(1.05); }
 
 
/* Ukrywanie prawego panelu Toolbox + korekta marginesu main */
.rightpane-hidden #rightPanel3 { display: none !important; }
.rightpane-hidden main { margin-right: 0 !important; }


/* Lewy pasek zwinięty: w "Operacje" zostaw tylko trójkąt */
body.sidebar-collapsed #cadOpsShelf .hdr .title{
  font-size: 0 !important;          /* chowa tekst "Operacje" */
  justify-content: center !important;
}
body.sidebar-collapsed #cadOpsShelf .hdr .title .badge{
  display: none !important;          /* chowa licznik */
}
body.sidebar-collapsed #cadOpsShelf .hdr .title .toggle{
  /* jedyny widoczny element: trójkąt ▼/▲, który JS już przełącza */
  font-size: 18px !important;
  line-height: 1 !important;
  width: 28px !important;            /* stała szerokość jak wcześniej */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto !important;
}
/* odrobina ciaśniej przy zwiniętym pasku */
body.sidebar-collapsed #cadOpsShelf{
  padding: 6px !important;
}

/* ===== CAM Toolbox (prawy panel) ===== */
#camToolbox{ display:flex; flex-direction:column; gap:10px; }
.cam-tbx-group{ border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.cam-tbx-head{ display:flex; align-items:center; justify-content:space-between;
  gap:8px; padding:6px 10px; background: #0f1827; border-bottom:1px solid var(--border); }
.cam-tbx-head strong{ font-weight:600; }
.cam-tbx-list{ display:flex; flex-direction:column; }
.cam-tbx-item{ display:flex; align-items:center; gap:8px; padding:6px 10px;
  border-top:1px solid var(--border); }
.cam-tbx-item:first-child{ border-top:none; }
.cam-tbx-name{ flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cam-tbx-actions{ display:flex; gap:4px; }
.icon-ud{ width:auto; min-width:22px; padding:2px 6px; line-height:1; }
.icon-ud[disabled]{ opacity:.5; cursor:not-allowed; }
.icon-del{ padding:2px 6px; }



/* CAM: menu + pozycje wyrównane do lewej */
.tb-dropdown.align-left .tb-menu {
  left: 0 !important;
  right: auto !important;
  transform: none !important;
  text-align: left !important;   /* na wypadek, gdy .tb-item nie jest flexem */
}

/* jeśli pozycje są flexowane (często tak bywa w toolbarach) */
.tb-dropdown.align-left .tb-item {
  text-align: left !important;    /* gdy .tb-item ma display:block */
  justify-content: flex-start !important; /* gdy .tb-item ma display:flex */
  width: 100%;                    /* żeby klikalny obszar wypełniał wiersz */
}

/* czasem label/ikona są w wewnętrznym wrapie – też pchnij je w lewo */
.tb-dropdown.align-left .tb-item > *,
.tb-dropdown.align-left .tb-item .label {
  text-align: left !important;
  justify-content: flex-start !important;
}

/* CAM: wiersz "Aktywuj CAM" – wysokość / spacing */
#topbar .tb-menu .tb-item.cam-activate {
  min-height: 40px;     /* podbij wysokość pola */
  line-height: 1.2;     /* bez „ściśnięcia” tekstu */
  padding: 8px 10px;    /* możesz zmniejszyć np. do 6px 10px, jeśli trzeba */
}

/* (opcjonalnie) jeśli całe menu ma być „luźniejsze” */
#topbar .tb-menu .tb-item { 
  /* min-height: 36px;  */
  /* line-height: 1.25; */
}
/* CAM: wiersz "Aktywuj CAM" – wysokość / spacing */
#topbar .tb-menu .tb-item.cam-activate{
  min-height: 50px !important;
  line-height: 1.2 !important;
  padding: 10px 12px !important;
  display: flex !important;
  align-items: center !important;
}




/* Małe ikonowe przyciski pod listami */
.actions-small {
  display: flex;
  gap: 6px;
  margin: 6px 0 8px;
}

/* Baza dla wszystkich ikon – prostokątne, jak mini-kafle */
.icon-btn {
  min-width: 36px;
  height: 32px;
  padding: 0 10px;
  border-radius: 6px; /* zamiast 999px – prostokąt z lekkim zaokrągleniem */
  border: 1px solid var(--border, #1f2937);
  background: #020617;          /* ciemne tło zbliżone do strony */
  color: #e5e7eb;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  cursor: pointer;
  transition:
    background-color 0.15s ease,
    color 0.15s ease,
    border-color 0.15s ease,
    transform 0.12s ease,
    box-shadow 0.12s ease;
}

/* Warianty kolorów – tylko delikatny akcent na tle */
#selectAllCuts,
#selectAllDrills {
  background: rgba(129, 140, 248, 0.12);      /* fiolet/indigo */
  color: #c7d2fe;
  border-color: rgba(129, 140, 248, 0.6);
}

#deselectAllCuts,
#deselectAllDrills {
  background: rgba(248, 113, 113, 0.12);      /* czerwony */
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.6);
}

#clearAllCuts,
#clearAllDrills {
  background: rgba(148, 163, 184, 0.12);      /* szaro-niebieski */
  color: #e5e7eb;
  border-color: rgba(148, 163, 184, 0.7);
}

/* Hover – lekkie rozjaśnienie i cień */
.icon-btn:hover {
  transform: translateY(-1px);
  background: #02081a;
  box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.4),
              0 6px 14px rgba(15, 23, 42, 0.75);
}

/* Hover dla wariantów – podbicie koloru akcentu */
#selectAllCuts:hover,
#selectAllDrills:hover {
  background: rgba(129, 140, 248, 0.3);
}

#deselectAllCuts:hover,
#deselectAllDrills:hover {
  background: rgba(248, 113, 113, 0.3);
}

#clearAllCuts:hover,
#clearAllDrills:hover {
  background: rgba(148, 163, 184, 0.28);
}

/* Active – wrażenie „wciśnięcia” */
.icon-btn:active {
  transform: translateY(0);
  box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.5),
              0 2px 6px rgba(15, 23, 42, 0.95);
}

/* Focus (klawiatura) – wyraźny ring */
.icon-btn:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 1px #93c5fd,
    0 0 0 3px rgba(59, 130, 246, 0.6);
}

/* Disabled – przygaszone, bez interakcji */
.icon-btn:disabled {
  opacity: 0.4;
  cursor: default;
  transform: none;
  box-shadow: none;
}

/* Save – przyciski z plusem i sakiewką */
.save-btn {
  min-width: 44px;
  height: 32px;
  padding: 0 10px;
  border-radius: 6px;
  background: rgba(34, 197, 94, 0.18);              /* zielonkawy akcent */
  border-color: rgba(34, 197, 94, 0.7);
  color: #bbf7d0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;                                         /* odstęp między + i 💰 */
  font-size: 15px;
}

.save-btn .save-icon {
  display: inline-block;
  line-height: 1;
}

/* trochę mocniejszy efekt na hover – spójny z .icon-btn:hover */
.save-btn:hover {
  background: rgba(34, 197, 94, 0.32);
  box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.6),
              0 6px 14px rgba(15, 23, 42, 0.8);
}

/* aktywny klik – jak inne przyciski */
.save-btn:active {
  transform: translateY(0);
  box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.7),
              0 2px 6px rgba(15, 23, 42, 0.9);
}
/* Krok 1 – siatka formularza klienta:
   niech sama decyduje, czy 1, czy 2 kolumny,
   żeby nie wychodzić poza kartę przy węższych oknach */
#clientForm .grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
/* Krok 1 – siatka w okienku "Otwórz istniejącą wycenę" */
#openPanel .grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
/* ===== KROK 2 – lista rysunków: lepsze zawijanie prawej części ===== */

/* Sam wiersz niech będzie zawsze w 2 kolumnach,
   ale prawa kolumna nie może rozpychać całego wiersza */
#drawingsList li {
  grid-template-columns: minmax(0, 1fr) auto !important;
  box-sizing: border-box;
}

/* Prawa część (grubość, jednostka, przyciski) */
#drawingsList li > div:last-child {
  min-width: 0 !important;          /* zamiast max-content z JS */
  flex-wrap: wrap !important;       /* pozwól zawijać się do drugiej linii */
  justify-content: flex-end;
}

/* Przy bardzo wąskim środku – rozbij na 2 wiersze (info nad sterowaniem) */
@media (max-width: 1200px) {
  #drawingsList li {
    grid-template-columns: 1fr !important;  /* lewa nad prawą */
    row-gap: 8px;
  }

  #drawingsList li > div:last-child {
    justify-content: flex-start;
  }
}


/* CAM – toolbar dla wierceń */
.cam-toolbar--drill {
  /* upewniamy się, że zachowuje się jak wiersz pod przyciskami */
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-top: 6px;

  /* wyśrodkowanie przycisków */
  justify-content: center;
  gap: 8px;
}

.cam-toolbar--drill .cam-toolbar__btn {
  /* trochę większe i bardziej czytelne */
  padding: 6px 16px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 500;

  border: 1px solid rgba(148, 163, 184, 0.7);
  background: rgba(15, 23, 42, 0.95);
  color: #e5edff;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.85);

  white-space: nowrap;
}

/* CAM – kolory ścieżek i otworów wg data-kind
   (działa i dla <path>, i dla <circle>) */
#camSvgContainer [data-kind="lead-in"] {
  stroke: #6ee7a8;
  stroke-width: 1.5;
  fill: none;
}

#camSvgContainer [data-kind="cut"] {
  stroke: #4aa3ff;
  stroke-width: 1.5;
  fill: none;
}

#camSvgContainer [data-kind="lead-out"] {
  stroke: #f7c34c;
  stroke-width: 1.5;
  fill: none;
}

#camSvgContainer [data-kind="rapid"] {
  stroke: #ff6b6b;
  stroke-width: 1.5;
  stroke-dasharray: 6 6;
  fill: none;
}

/* CAM – wizualizacja otworów wiercenia (pełne, półprzezroczyste kółka) */
#camSvgContainer [data-kind="drill-hole"] {
  stroke: #38bdf8;                        /* niebieska obwódka */
  stroke-width: 1.4;
  fill: rgba(56, 189, 248, 0.22);         /* delikatnie niebieskie, półprzezroczyste */
}

/* po kliknięciu oczka – mocniejsze zaznaczenie */
#camSvgContainer g[data-op].focus [data-kind="drill-hole"] {
  stroke-width: 2.4;
  fill: rgba(56, 189, 248, 0.40);
}
