:root{
  --bg:#0f1115; --fg:#e8ebf0; --muted:#9aa3b2; 
  --brand: #f4c400;
  --brand2: #ffda3a;
  --accent: var(--brand);
  --warn:#ffb74d; --danger:#ff6b6b; --card:#151a21; --border:#232a35;
  --shadow: 0 6px 18px rgba(0,0,0,.25);
}

/* ===== Konto: “hero” nagłówek w panelu (np. Technologia) ===== */
.acc-hero{
  border: 1px solid rgba(148,163,184,0.22);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(110,168,254,0.10), rgba(2,6,23,0.12));
  padding: 12px 14px;
  margin: 10px 0 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.acc-hero-title{
  font-size: 15px;
  letter-spacing: .2px;
}
.acc-hero-sub{
  margin-top: 4px;
  font-size: 12px;
  color: var(--muted);
}


/* ===== Konto: wygląd modalu ===== */
.acc-top{
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  margin-bottom: 6px;
}
.acc-title{ margin:0; font-size:18px; }
.acc-subtitle{ color: var(--muted); font-size: 13px; margin-top: 2px; }
.acc-pill{
  display:inline-block;
  padding:2px 8px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#10151d;
  font-size:12px;
}
.acc-x{
  width: 36px; height: 36px;
  border-radius: 10px;
  border:1px solid var(--border);
  background:#10151d;
  color: var(--fg);
  cursor:pointer;
}
.acc-x:hover{ border-color: var(--brand); }


/* ===== Konto: zakładki w modalu ===== */
.acc-tabs{
  display:flex;
  gap:8px;
  border-bottom:1px solid var(--border);
  padding-bottom:8px;
  margin: 6px 0 10px;
  flex-wrap:wrap;
}
.acc-tab{
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:10px;
  background:#10151d;
  color:var(--fg);
  cursor:pointer;
}
.acc-tab[aria-selected="true"]{
  outline:2px solid var(--brand);
}
.acc-panel{ display:none; }
.acc-panel.active{ display:block; }

/* scroll wewnątrz (ładny jak w aplikacji) */
.acc-scroll{
  /*
    Mobile fix: vh bywa "zawyżone" przez pasek adresu (Safari/Chrome),
    przez co dół modala (np. przycisk "Zapisz") potrafi się przyciąć.
    Minimalnie zmniejszamy wysokość i używamy dvh tam, gdzie dostępne.
  */
  max-height: calc(80vh - 210px);
  max-height: calc(80dvh - 210px);
  overflow-y: auto;
  padding-right: 6px; /* miejsce na scrollbar */
}
.acc-scroll::-webkit-scrollbar{ width: 10px; }
.acc-scroll::-webkit-scrollbar-track{
  background:#0b0e13;
  border-left:1px solid var(--border);
}
.acc-scroll::-webkit-scrollbar-thumb{
  background:#2a3342;
  border-radius:8px;
  border:2px solid #0b0e13;
}
.acc-scroll::-webkit-scrollbar-thumb:hover{ background:#3a4558; }
.acc-scroll{ scrollbar-width: thin; scrollbar-color:#2a3342 #0b0e13; }

/* sekcje + linie */
.acc-section{ margin: 10px 0 8px; }
.acc-section-head{ display:flex; align-items:baseline; justify-content:space-between; gap:10px; flex-wrap:wrap; }
.acc-section-title{ font-size: 14px; }
.acc-section-sub{ font-size: 12px; color: var(--muted); }
.acc-hr{
  height: 1px;
  bbackground: linear-gradient(90deg, transparent, rgba(110,168,254,0.40), transparent);
  margin-top: 8px;
}

/* ===== mocniejsze oddzielenie grup (Czasy/Koszty/…) ===== */
.acc-group{
  border: 1px solid rgba(148,163,184,0.16);
  border-radius: 14px;
  padding: 10px 12px 12px;
  background: rgba(2,6,23,0.10);
  margin: 10px 0 12px;
}

.acc-footer{
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(148,163,184,0.18);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.acc-hint{
  color: var(--muted);
  font-size: 12px;
}
.acc-actions{ margin-top: 0 !important; }
.acc-grid{ grid-template-columns: repeat(2, minmax(240px,1fr)); }
@media (max-width:900px){
  .acc-grid{ grid-template-columns: 1fr; }
}

/* technologia: “kafelki” pól */
.acc-tech-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(260px, 1fr));
  gap: 12px;
}
@media (max-width: 900px){
  .acc-tech-grid{ grid-template-columns: 1fr; }
}
.acc-field{
  border: 1px solid rgba(148,163,184,0.20);
  border-radius: 12px;
  background: rgba(2,6,23,0.15);
  padding: 10px 12px;
}
.acc-field-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 8px;
}
.acc-field-title b{
  letter-spacing: .15px;
}
.acc-field-title{
  margin-bottom: 6px;
}
.acc-field input{
  width: 100%;
}
.acc-field-hint{
  margin-top: 6px;
  font-size: 11px;
  color: rgba(154,163,178,0.75);
  font-variant-numeric: tabular-nums;
}

/* 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: block;
}

/* 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) }

/* TYLKO: Wycena + Zlecenia mają wyglądać jak .navbtn (ikonka + tekst) */
header nav a#navSummary,
header nav a#navOrders{
  /* jak .navbtn */
  padding: 12px 16px;
  font-size: 0.95rem;
  text-align: center;

  /* ikonka + tekst jak w Ustawieniach */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

/* ikonka przed tekstem (tylko dla tych dwóch linków) */
header nav a#navSummary::before,
header nav a#navOrders::before{
  content: attr(data-icon);
  display: inline-block;
  line-height: 1;
}



/* „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 – „© CUTOR” */
.sidebar-footer{
  margin-top:auto;
  border-top:1px solid var(--border);
  color:var(--muted);

  font-size:.75rem;          /* delikatnie mniejsza czcionka */
  text-align:left;           /* wyrównanie do lewej */
  padding:6px 10px 4px 10px; /* lekko „wjeżdża” w lewo */
}

/* 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;
  box-shadow: var(--shadow);
  /* NAJWAŻNIEJSZE: pełna szerokość, bez centrowania */
  max-width: none;
  width: 100%;
  margin: 0 0 20px;
}

.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:#182235; 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:#141c2b}
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);
  position:relative; /* może zostać, niczemu nie szkodzi */
}

/* Canvas = jedyny viewer w Kroku 3 */
#cadCanvas{
  background:#0b0f16;
  border-radius:8px;
  width:100%;
  height:100%;
  display:block;
}

/* Stary SVG w Kroku 3 chowamy – służy tylko jako źródło geometrii */
#svgContainer{
  display:none;
}



/* 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);
  box-shadow: 0 0 0 2px rgba(74,163,255,0.35), 0 0 14px rgba(74,163,255,0.20);
}

/* Kolory i glow per lista (Krok 3) */
#cutsList.picklist li.active{
  outline-color: #61d095;
  box-shadow: 0 0 0 2px rgba(97,208,149,0.55), 0 0 16px rgba(97,208,149,0.35);
  background: rgba(97,208,149,0.08);
}
#drillsList.picklist li.active{
  outline-color: #38bdf8;
  box-shadow: 0 0 0 2px rgba(56,189,248,0.55), 0 0 16px rgba(56,189,248,0.35);
  background: rgba(56,189,248,0.08);
}
.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);
  width:100%;           /* nowość – wypełnij całą sekcję */
  box-sizing:border-box;/* uwzględnij padding w szerokości */
}

.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;
  width:100%;           /* opcjonalnie też na full szerokość */
  box-sizing:border-box;
}

.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;
}


/* ===== "Moje konto" (Dane konta) – podniesienie okna na mobile =====
   Na telefonach dół bywa ucinany (vh + paski przeglądarki).
   Podnosimy całą kartę o ok. 1.5 wysokości przycisku (zapas sterowany clamp). */
:root{
  --acc-modal-lift: clamp(64px, 9vh, 96px);
}
@media (max-width: 700px){
  .modal.acc-modal{
    /* trochę oddechu od krawędzi + bezpieczny obszar iOS */
    padding: 12px 10px calc(12px + env(safe-area-inset-bottom));
  }
  .modal.acc-modal .modal-card.acc-modal-card{
    transform: translateY(calc(-1 * var(--acc-modal-lift)));
  }

  /* ✅ iOS/Safari: dół modala bywa "ucięty" przez pasek + safe-area.
     Dajemy zapas od dołu i ograniczamy wysokość karty, żeby footer (Zapisz) zawsze był w całości. */
  .modal.acc-modal .modal-card.acc-modal-card{
    padding-bottom: calc(16px + env(safe-area-inset-bottom));
    margin-bottom: calc(10px + env(safe-area-inset-bottom));
    max-height: calc(100dvh - 24px - env(safe-area-inset-bottom) - var(--acc-modal-lift)) !important;
  }

}

.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: var(--brand);
  color: #111;
  border-color: rgba(0,0,0,0.10);
  box-shadow: 0 0 0 4px rgba(244,196,0,0.18);
}


.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-radius: 8px;   /* było border-raius */
  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: var(--brand);          /* żółty */
  border-color: rgba(0,0,0,0.12);
  color: #111;
  box-shadow: 0 0 0 4px rgba(244,196,0,0.18);
}
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: #f4c400;       /* jasny, delikatny niebieski */
  border-color: #f4c400;
  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: 4px !important;
  padding-right: 4px !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;
  --sidebar-narrow: calc(90px + var(--sbw));  /* BYŁO 80px */
  --sidebar-w-collapsed: var(--sidebar-narrow);
}

/* 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{
  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: 4px !important;         /* mniej wewnętrznego marginesu = więcej miejsca na ikonę */
  padding-right: 4px !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;
  gap:8px;
  align-items:stretch;
  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; }

/* ==== OPERACJE (lewy pasek) – kafelek jak "Parametry" ==== */

/* cały shelf z Operacjami w lewym pasku */
#cadOpsShelf{
  margin-top: 10px;
}

/* nagłówek "Operacje" – wizualnie taki sam jak pozostałe przyciski w sidebarze */
#cadOpsShelf .hdr .title{
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 10px 12px;              /* jak inne przyciski */
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #121722;
  color: var(--fg);
  cursor: pointer;
  box-sizing: border-box;
  text-align: left;
  transition: border-color .15s ease, background .15s ease, transform .05s ease;
}

/* kontener Operacji w lewym pasku – bez ramki, bez paddingu */
header nav #cadOpsShelf{
  padding: 0;
  border: 0;
  background: transparent;
}


/* cały shelf z Operacjami w lewym pasku */
#cadOpsShelf{
  margin-top: 0;                    /* odstęp robi już gap:10px z header nav */
}

/* nagłówek "Operacje" – jak przycisk "Parametry" */
#cadOpsShelf .hdr .title{
  appearance: none;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 12px 16px;               /* jak .navbtn */
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #121722;
  color: var(--fg);
  cursor: pointer;
  box-sizing: border-box;
  text-align: left;
  font-size: 0.95rem;               /* jak .navbtn */
  font-weight: 400;                 /* żeby nie było „pogrubione” */
  font-family: system-ui, Segoe UI, Roboto, Helvetica, Arial;
  transition: border-color .15s ease, background .15s ease, transform .05s ease;
}

#cadOpsShelf .hdr .title:hover{
  border-color: var(--brand);
  background: #161c28;
}

/* trójkącik po lewej – „kolumna” jak zębatka przy Parametrach */
#cadOpsShelf .hdr .title .toggle{
  width: 1.2em;                     /* stała szerokość jak ikona */
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-size: 0.95rem;
  margin-right: 4px;                /* mała przerwa przed tekstem */
}

/* tekst "Operacje" – środek przycisku */
#cadOpsShelf .hdr .title .label{
  flex: 1 1 auto;
  font-size: 0.95rem;
}

/* licznik (badge) – gdy będzie użyty, siedzi przy prawej krawędzi */
#cadOpsShelf .hdr .title .badge{
  font-size: 0.8rem;
  opacity: 0.8;
  margin-left: 6px;
}



/* 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;
}

/* Lewy pasek zwinięty: "Operacje" ma taki sam kafelek jak reszta */
body.sidebar-collapsed #cadOpsShelf{
  padding: 0 !important;              /* bez dodatkowego marginesu w środku */
}

body.sidebar-collapsed #cadOpsShelf .hdr .title{
  padding: 10px !important;           /* dokładnie tyle samo co inne navbtn */
  font-size: 0 !important;            /* chowa tekst */
  justify-content: center !important;
}

body.sidebar-collapsed #cadOpsShelf .hdr .title .badge{
  display: none !important;
}

body.sidebar-collapsed #cadOpsShelf .hdr .title .toggle{
  font-size: 18px !important;
  line-height: 1 !important;
  width: 28px !important;             /* możesz zostawić lub lekko skorygować */
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto !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);
}

/* Stała wysokość przycisków "Ustawienia" i "Panel" */
#openSettings,
#collapseSidebar {
  display: inline-flex;        /* ładne wyśrodkowanie tekstu */
  align-items: center;
  justify-content: center;

  height: 36px;                /* wysokość jak przy full screen – dostosuj np. 40px */
  padding: 0 14px;             /* poziome odstępy, bez zmiany wysokości */

  flex-shrink: 0;              /* ❗ nie pozwalaj flexboxowi ich zgniatać */
  box-sizing: border-box;
}


/* CANVAS */

/* Canvas CAD – nie pokazujemy już ikonek +/×, ale logika zostaje */
svg#cutor-svg .pick-icon {
  display: none;
}

/* Ikony +/× w SVG chowamy – klikamy po canvasie */
svg#cutor-svg .pick-icon {
  display: none;
}


/*CAD2D */

/* === Tryb CAD – przełączanie lewego paska === */

#wizardNav,
#cadNav {
  transition: opacity .25s ease, transform .25s ease;
}

#cadNav {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-8px);
}

body.cad-mode #wizardNav {
  opacity: 0;
  pointer-events: none;
  transform: translateX(8px);
}

body.cad-mode #cadNav {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(0);
}

#cadNav .cad-btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #10151d;
  color: var(--fg);
  cursor: pointer;
  font-size: 0.85rem;
}

#cadNav .cad-btn + .cad-btn {
  margin-top: 4px;
}

#cadNav .cad-btn.active {
  border-color: var(--brand);
  box-shadow: 0 0 0 1px rgba(74,163,255,0.4);
}

/* === Tryb CAD – uproszczony widok kroku 3 === */

/* w trybie CAD chowamy pasek trybów (Cięcie/Wiercenie itd.) */
body.cad-mode #step3 .toolbar {
  display: none;
}

/* chowamy prawy panel z listą cięć / otworów */
body.cad-mode #rightPanel3 {
  display: none;
}

/* zostaje tylko wybór rysunku + canvas */
body.cad-mode #step3 .selector {
  margin-bottom: 10px;
}

/* nagłówek w trybie CAD może wyglądać trochę inaczej (opcjonalnie) */
body.cad-mode #step3 h2 {
  color: var(--brand);
}

/* w trybie CAD chowamy stary pasek skali i status */
body.cad-mode #cadUiBar,
body.cad-mode #cadStatusBar {
  display: none !important;
}

/* =========================================================
   FINAL FIX v2 – środkowy panel między lewym panelem
   a toolboxem (albo do krawędzi okna, gdy toolbox schowany)
   ========================================================= */

/* Umowna „szerokość” prawego panelu + marginesu */
:root{
  --rightpane-w: 360px;   /* 340px panel + trochę luzu */
}

/* Na dużych ekranach liczymy szerokość main z 100vw i zmiennych */
@media (min-width: 901px){

  /* główny środek aplikacji */
  #app-root main{
    box-sizing: border-box;

    /* nie chcemy już starego margin-right:360px */
    margin-left: var(--sidebar-current) !important;
    margin-right: 0 !important;

    /* szerokość = szerokość okna - lewy pasek - toolbox */
    width: calc(100vw - var(--sidebar-current) - var(--rightpane-w));
    max-width: calc(100vw - var(--sidebar-current) - var(--rightpane-w));
  }

  /* gdy toolbox schowany – dociągnij do prawej krawędzi okna */
  body.rightpane-hidden #app-root main{
    width: calc(100vw - var(--sidebar-current));
    max-width: calc(100vw - var(--sidebar-current));
  }

  /* sekcje kroków wypełniają cały main */
  #app-root main .step,
  #app-root main .route{
    max-width: none !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* karty / boxy cenowe też na całą szerokość sekcji */
  #app-root main .card,
  #app-root main .price{
    width: 100% !important;
    box-sizing: border-box;
  }
}

#summary #quoteName{
  font-weight:600;    /* 🔹 bold jak nagłówek */
  font-size:14px;     /* 🔹 taka sama czcionka jak reszta wiersza */
}

/* Parametry: grid ma się sam składać, gdy robi się za wąsko (np. przez prawy panel) */
#params .grid{
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
}

/* Dodatkowa ochrona przed “rozpychaniem” kolumn przez zawartość */
#params .grid > *{
  min-width: 0;
}


/* =========================================================
   ZLECENIE / OKNO WYCENY (Klient + Vendor) — nowy układ
   (layout jak na 2 screenie: Informacje Ogólne -> Porównanie -> Szczegóły -> Propozycja)
   ========================================================= */

#order.order-view{
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}

#order.order-view .order-title{
  font-size: 40px;
  letter-spacing: .2px;
  margin: 0 0 6px;
}

#order.order-view .order-meta{
  opacity: .9;
  margin: 0 0 14px;
}

#order.order-view .order-card{ margin-top: 14px; }

/* Niebieskie obramowanie "Informacje Ogólne" */
#order.order-view .order-general{
  border: 2px solid rgba(74,163,255,0.55);
  box-shadow:
    0 0 0 3px rgba(74,163,255,0.16),
    var(--shadow);
}

/* Ujednolicenie .btnrow (w wielu miejscach było inline) */
#order.order-view .btnrow{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

/* Porównanie cen */
#order.order-view .order-price-compare{
  display:flex;
  gap:14px;
  align-items:center;
  min-width: 0; /* ważne w flexboxie, żeby nie rozpychać rodzica */
}

#order.order-view .order-big-arrow{
  font-size: 56px;
  line-height: 1;
  padding: 8px 12px;
  color: #fb7185; /* różowo-czerwony jak strzałka na screenie */
  filter: drop-shadow(0 8px 18px rgba(0,0,0,0.35));
  user-select:none;
  animation: orderArrowGlow 1.6s ease-in-out infinite;
  transform-origin: center;
}
/* NOWY UKŁAD */
#order.order-view .order-price-compare-body{
  min-width: 0;
  width: 100%;
}

#order.order-view .order-price-title{
  font-size: 22px;
  font-weight: 800;
  letter-spacing: .2px;
  margin-bottom: 10px;
}

#order.order-view .order-price-block{
  display:flex;
  flex-direction: column;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(148,163,184,0.18);
  background: rgba(2,6,23,0.10);
}

#order.order-view .order-price-label{
  font-size: 14px;
  opacity: .95;
}

#order.order-view .order-price-value{
  font-size: 20px;
  letter-spacing: .2px;
}

#order.order-view .order-price-divider{
  height: 1px;
  margin: 10px 4px;
  background: linear-gradient(90deg, transparent, rgba(148,163,184,0.35), transparent);
}


@keyframes orderArrowGlow{
  0%, 100%{
    filter:
      drop-shadow(0 8px 18px rgba(0,0,0,0.35))
      drop-shadow(0 0 0 rgba(251,113,133,0.00));
    transform: translateY(0) scale(1);
  }
  50%{
    filter:
      drop-shadow(0 10px 22px rgba(0,0,0,0.38))
      drop-shadow(0 0 16px rgba(251,113,133,0.55))
      drop-shadow(0 0 34px rgba(251,113,133,0.25));
    transform: translateY(-1px) scale(1.03);
  }
}

/* jeżeli ktoś ma w systemie ograniczenie animacji */
@media (prefers-reduced-motion: reduce){
  #order.order-view .order-big-arrow{ animation: none; }
}

#order.order-view .order-price-line{
  font-size: 20px;
  display:flex;
  gap:10px;
  align-items:baseline;
  flex-wrap:wrap;
  min-width: 0;
  overflow-wrap: anywhere;   /* pozwól łamać długie fragmenty */
  word-break: break-word;
}

#order.order-view .order-price-sep{ opacity:.9; margin-inline: 6px; }

#order.order-view .order-price-labels{
  display:flex;
  justify-content:space-between;
  gap:16px;
  margin-top:6px;
  min-width: 0;
}

#order.order-view .order-price-labels > span{ white-space:nowrap; }


/* === MOBILE FIX: "Porównanie Wycen" nie może wychodzić poza kartę === */
@media (max-width: 520px){
  #order.order-view .order-price-compare{
    flex-direction: column;      /* strzałka nad tekstem */
    align-items: flex-start;
    gap: 8px;
  }
  #order.order-view .order-big-arrow{
    font-size: 44px;
    padding: 4px 6px;
  }
  #order.order-view .order-price-title{
    font-size: 20px;
  }
}

#order.order-view .order-diff-list{
  padding-top: 10px;
  border-top: 1px solid var(--border);
}

/* Dwie kolumny w "Szczegóły wersji" */
#order.order-view .order-two-cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 900px){
  #order.order-view .order-two-cols{ grid-template-columns: 1fr; }
}

#order.order-view .order-col h4{
  margin: 0 0 10px;
  font-size: 16px;
}

/* "Aktywny rysunek" jako pasek */
#order.order-view .order-active-drawing{
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(74,163,255,0.45);
  background: rgba(74,163,255,0.08);
  margin-bottom: 10px;
}

/* lista podsumowania */
#order.order-view .order-summary-list{
  margin: 0;
  padding-left: 18px;
  line-height: 1.65;
}
#order.order-view .order-summary-list li{ margin: 2px 0; }

/* Dolny kafelek "Twoja propozycja" */
#order.order-view .order-proposal-head{
  display:flex;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
}

#order.order-view .order-proposal-actions{
  justify-content:flex-end;
}

/* Cena (ręcznie) – przeniesione z inline */
#order.order-view .order-price-edit{
  margin-top: 8px;
}
#order.order-view .order-price-edit input{
  width: 260px;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(148,163,184,0.25);
  background: rgba(2,6,23,0.09);
  color: #e5e7eb;
  outline: none;
}
#order.order-view .order-price-edit input:focus{
  border-color: rgba(74,163,255,0.7);
  box-shadow: 0 0 0 3px rgba(74,163,255,0.16);
}

/* ===== ZLECENIA: tabela + ikonowe akcje ===== */
#ordersTable.orders-table{
  border-collapse: collapse;
}

#ordersTable.orders-table th,
#ordersTable.orders-table td{
  padding: 10px 12px;
  vertical-align: middle;
}

/* === Separatory wierszy: równa linia niezależnie od wysokości komórek === */
#ordersTable.orders-table tbody tr{
  border-bottom: 1px solid var(--border);
}
#ordersTable.orders-table tbody td{
  border-bottom: 0; /* linia jest na <tr>, nie na <td> */
}

/* === Status: stabilny układ 2-liniowy (Status + PO TERMINIE pod spodem) === */
#ordersTable td.cell-status{
  text-align: center;
  vertical-align: middle;
}
.status-stack{
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.status-stack .badge-warn{
  margin-left: 0 !important; /* wcześniej było 8px */
}



#ordersTable.orders-table thead tr:first-child th{
  background: #121722;
  position: sticky;
  top: 0;
  z-index: 2;
}

#ordersTable.orders-table thead tr:nth-child(2) th{
  background: #0f1521;
  position: sticky;
  top: 44px; /* wysokość pierwszego rzędu nagłówka */
  z-index: 1;
}

#ordersTable.orders-table tbody tr:hover{
  background: rgba(74,163,255,0.06);
}

#ordersTable .cell-name{
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#ordersTable .cell-info{
  max-width: 520px;
  white-space: normal;
  word-break: break-word;
}

#ordersTable .cell-actions{ white-space: nowrap; }

.orders-actions{
  display: flex;
  gap: 6px;
  align-items: center;
  justify-content: flex-end;
}

#ordersTable .order-open-program-btn{
  padding: 6px 10px;
  height: 32px;
  border-radius: 10px;
  font-size: 13px;
  line-height: 1;
}

/* ikonki w akcjach */
.o-ico{ width: 18px; height: 18px; display:block; }

/* drobny wariant icon-btn w tabeli */
#ordersTable .icon-btn.order-act{
  min-width: 34px;
  height: 32px;
  padding: 0 8px;
  border-radius: 10px;
}

#ordersTable .icon-btn.order-act.danger{
  background: rgba(248, 113, 113, 0.12);
  border-color: rgba(248, 113, 113, 0.65);
  color: #fecaca;
}
#ordersTable .icon-btn.order-act.danger:hover{
  background: rgba(248, 113, 113, 0.22);
}

/* status jako "pill" */
.status-pill{
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(148, 163, 184, 0.08);
  font-size: 12px;
  line-height: 1;
  white-space: nowrap;
}

.status-pill[data-status="Zakończono"]{
  background: rgba(34, 197, 94, 0.14);
  border-color: rgba(34, 197, 94, 0.55);
  color: #bbf7d0;
}
.status-pill[data-status="Oczekuje"]{
  background: rgba(245, 158, 11, 0.12);
  border-color: rgba(245, 158, 11, 0.55);
  color: #fde68a;
}
.status-pill[data-status="W realizacji"]{
  background: rgba(59, 130, 246, 0.12);
  border-color: rgba(59, 130, 246, 0.55);
  color: #bfdbfe;
}

.badge-warn{
  margin-left: 0;
  margin-top: 6px; /* pod statusem */
  padding: 3px 8px;
  border: 1px solid rgba(239, 68, 68, 0.75);     /* czerwony */
  background: rgba(239, 68, 68, 0.14);           /* czerwony */
  color: #ffffff;                                 /* czcionka biała */
  border-radius: 999px;
  font-size: 10px;
  line-height: 1;
  white-space: nowrap;
}

/* tooltip (dymek) dla elementów z data-tip */
[data-tip]{ position: relative; }
[data-tip]::after{
  content: attr(data-tip);
  position: absolute;
  left: 50%;
  top: calc(100% + 8px);
  transform: translateX(-50%) translateY(-2px);
  background: var(--tooltip-bg, rgba(2, 6, 23, 0.96));
  color: var(--tooltip-fg, #ffffff);
  border: 1px solid var(--tooltip-border, var(--border));
  padding: 6px 8px;
  border-radius: 10px;
  font-size: 12px;
  white-space: nowrap;
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity .12s ease, transform .12s ease;
  z-index: 10000;
}
[data-tip]::before{
  content: '';
  position: absolute;
  left: 50%;
  top: calc(100% + 4px);
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-bottom-color: rgba(2, 6, 23, 0.96);
  opacity: 0;
  pointer-events: none;
  transition: opacity .12s ease;
  z-index: 10000;
}
[data-tip]:hover::after,
[data-tip]:focus-visible::after{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
[data-tip]:hover::before,
[data-tip]:focus-visible::before{ opacity: 1; }

/* ===== ZLECENIA: przełącznik "Wszystkie / Tylko aktywne" ===== */
#activeOnlyWrap { display:inline-flex; align-items:center; }

.orders-active-toggle{
  display:inline-flex;
  align-items:center;
  cursor:pointer;
  user-select:none;
}

/* ===== ZLECENIA: (MOBILE) przełącznik "Widok pełny / Kompaktowy" (niebieski) ===== */
#compactViewWrap { display:none; }
.orders-compact-toggle{
  display:inline-flex;
  align-items:center;
  cursor:pointer;
  user-select:none;
}
.orders-compact-toggle input{
  position:absolute;
  opacity:0;
  width:1px; height:1px;
  pointer-events:none;
}
.orders-compact-toggle__ui{
  position:relative;
  display:flex;
  align-items:center;
  width: 230px;
  height: 34px;
  padding: 3px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(2,6,23,0.22);
  box-shadow: 0 0 0 1px rgba(148,163,184,0.18), 0 10px 24px rgba(0,0,0,0.25);
  overflow:hidden;
}
.orders-compact-toggle__txt{
  flex:1;
  text-align:center;
  font-size: 12px;
  line-height: 1;
  z-index:1;
  color: rgba(229,231,235,0.78);
  white-space:nowrap;
}
.orders-compact-toggle__txt--off{ color: #e5e7eb; }
.orders-compact-toggle__txt--on{ opacity:0.75; }
.orders-compact-toggle__knob{
  position:absolute;
  top:3px; left:3px;
  width: calc(50% - 3px);
  height: calc(100% - 6px);
  border-radius: 999px;
  background: rgba(148,163,184,0.12);
  border: 1px solid rgba(148,163,184,0.35);
  transition: transform .18s ease, background-color .18s ease, border-color .18s ease;
}

/* ZLECENIA: termin zmieniony przez vendora – podświetl do czasu akceptacji klienta */
#ordersTable td.due-pending{
  color: #fff;
  font-weight: 700;
}
#ordersTable td.due-pending::after{
  content: " •";
  color: rgba(110, 168, 254, 0.95); /* niebieski akcent */
}
#ordersTable td.due-pending{
  background: rgba(110, 168, 254, 0.10);
  border-radius: 10px;
}

/* checked = "Kompaktowy" (prawa strona) */
.orders-compact-toggle input:checked + .orders-compact-toggle__ui .orders-compact-toggle__knob{
  transform: translateX(100%);
  background: rgba(59,130,246,0.18);
  border-color: rgba(59,130,246,0.55);
}
.orders-compact-toggle input:checked + .orders-compact-toggle__ui .orders-compact-toggle__txt--on{
  color: #bfdbfe;
  opacity:1;
}
.orders-compact-toggle input:checked + .orders-compact-toggle__ui .orders-compact-toggle__txt--off{
  opacity:0.65;
  color: rgba(229,231,235,0.78);
}
.orders-compact-toggle input:focus-visible + .orders-compact-toggle__ui{
  box-shadow: 0 0 0 1px #93c5fd, 0 0 0 3px rgba(59,130,246,0.35);
}

.orders-active-toggle input{
  position:absolute;
  opacity:0;
  width:1px; height:1px;
  pointer-events:none;
}

.orders-active-toggle__ui{
  position:relative;
  display:flex;
  align-items:center;
  width: 230px;              /* szerszy, żeby mieścił tekst */
  height: 34px;
  padding: 3px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--orders-toggle-bg, rgba(2,6,23,0.22));
  box-shadow: 0 0 0 1px rgba(148,163,184,0.18), 0 10px 24px rgba(0,0,0,0.25);
  overflow:hidden;
}

.orders-active-toggle__txt{
  flex:1;
  text-align:center;
  font-size: 12px;
  line-height: 1;
  z-index:1;
  color: var(--orders-toggle-fg, rgba(229,231,235,0.78));
  white-space:nowrap;
}

.orders-active-toggle__txt--off{ color: var(--orders-toggle-fg-strong, #e5e7eb); }
.orders-active-toggle__txt--on{ opacity:0.75; }

.orders-active-toggle__knob{
  position:absolute;
  top:3px; left:3px;
  width: calc(50% - 3px);
  height: calc(100% - 6px);
  border-radius: 999px;
  background: rgba(148,163,184,0.12);
  border: 1px solid rgba(148,163,184,0.35);
  transition: transform .18s ease, background-color .18s ease, border-color .18s ease;
}

/* checked = "Tylko aktywne" (prawa strona) */
.orders-active-toggle input:checked + .orders-active-toggle__ui .orders-active-toggle__knob{
  transform: translateX(100%);
  background: rgba(34,197,94,0.16);
  border-color: rgba(34,197,94,0.45);
}
.orders-active-toggle input:checked + .orders-active-toggle__ui .orders-active-toggle__txt--on{
  color: #181818;
  opacity:1;
}
.orders-active-toggle input:checked + .orders-active-toggle__ui .orders-active-toggle__txt--off{
  opacity:0.65;
  color: rgba(41, 41, 41, 0.78);
}

/* focus ring (klawiatura) */
.orders-active-toggle input:focus-visible + .orders-active-toggle__ui{
  box-shadow: 0 0 0 1px #93c5fd, 0 0 0 3px rgba(59,130,246,0.35);
}

/* ===== ZLECENIA: brak poziomego scrolla + pełna wysokość + ładny scroll ===== */

/* 1) Sekcja Zleceń ma wypełniać wysokość ekranu (pod topbarem) */
/* UWAGA: #orders NIE może mieć display:flex zawsze, bo nadpisuje .route{display:none;}
   i wtedy Zlecenia "wpychają się" w inne kroki. */
#orders.route.active,
#orders.step.active{
  height: calc(100vh - var(--topbar-h) - 24px); /* lekki zapas na paddingi/marginesy */
  display: flex;
  flex-direction: column;
}

/* 2) Główna karta w środku też jako kolumna i ma się rozciągać */
#orders > .card{
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0; /* ważne, żeby scroll działał w środku */
}

/* 3) Wrapper tabeli: tylko pionowy scroll, bez poziomego */
#orders .orders-table-wrap{
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  border-radius: 10px;
  scrollbar-gutter: stable;
}

/* WAŻNE: nie włączamy poziomego scrolla w wrapie,
   bo ma być tylko jeden (dolny) scrollbar: .orders-hscroll */
#orders.orders-hscroll-on .orders-table-wrap{
  overflow-x: hidden;
}

/* ✅ Touch/mobile: pozwól przewijać tabelę gestem w bok,
   ale ukryj “drugi” scrollbar w wrapie (żeby widoczny był tylko dolny pasek). */
@media (pointer: coarse){
  #orders.orders-hscroll-on .orders-table-wrap{
    overflow-x: auto;                 /* gest L/R działa */
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;            /* Firefox: ukryj */
  }
  #orders.orders-hscroll-on .orders-table-wrap::-webkit-scrollbar{
    height: 0 !important;             /* WebKit: ukryj poziomy */
  }
}

/* ładny ciemny scrollbar jak w innych oknach */
#orders .orders-table-wrap::-webkit-scrollbar{ width: 12px; }
#orders .orders-table-wrap::-webkit-scrollbar-thumb{
  background:#2a3444;
  border-radius:10px;
  border: 3px solid rgba(0,0,0,0); /* optycznie cieńszy */
  background-clip: padding-box;
}
#orders .orders-table-wrap::-webkit-scrollbar-track{ background: transparent; }
#orders .orders-table-wrap{ scrollbar-width: thin; scrollbar-color:#2a3444 transparent; }

/* 4) Tabela: ma się zmieścić bez poziomego scrolla */
#ordersTable{
  width: 100% !important;
  table-layout: fixed;             /* klucz do braku rozjeżdżania */
}
/* ===== ZLECENIA: toolbar ma równo wrapować ===== */
#orders .btnrow{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
}



/* ZLECENIA – hint pod tabelą (mobile) */
.orders-swipe-hint{
  display:none;
  width: 100%;
  text-align: center;
}

/* ZLECENIA: klik w wiersz = Zobacz */
#ordersTable tbody tr[data-order-id]{
  cursor: pointer;
}
#ordersTable tbody tr[data-order-id]:hover{
  background: rgba(148,163,184,0.08);
}

/* żeby przyciski w Akcjach nadal wyglądały jak przyciski (nie “dziedziczą” cursor:pointer z wiersza) */
#ordersTable tbody tr[data-order-id] button{
  cursor: pointer;
}

/* ===== Dolny pasek przewijania (pokazujemy tylko gdy potrzeba) ===== */
.orders-hscroll{
  display:none;
  margin-top: 8px;
  height: 14px;              /* sam pasek */
  overflow-x: auto;
  overflow-y: hidden;
  border-radius: 10px;
  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
}
.orders-hscroll__inner{
  height: 1px;               /* tylko “wypełniacz” szerokości */
}

/* WebKit scrollbar (poziomy) */
.orders-hscroll::-webkit-scrollbar{ height: 12px; }
.orders-hscroll::-webkit-scrollbar-thumb{
  background:#2a3444;
  border-radius:10px;
  border: 3px solid rgba(0,0,0,0);
  background-clip: padding-box;
}
.orders-hscroll::-webkit-scrollbar-track{ background: transparent; }
.orders-hscroll{ scrollbar-width: thin; scrollbar-color:#2a3444 transparent; }

/* gdy JS wykryje przycinanie – włącz przewijanie + pokaż hint */
#orders.orders-hscroll-on .orders-hscroll{ display:block; }
#orders.orders-hscroll-on .orders-swipe-hint{ display:block; }

/* hint "Widok wykonawcy..." ma być zawsze w nowej linii (pod przełącznikami) */
#orders #ordersModeHint{
 flex-basis: 100%;
  width: 100%;
  order: 99;                 /* na końcu toolbara */
  margin-left: 0 !important; /* nadpisuje inline margin-left:auto */
  margin-top: 2px;
  line-height: 1.2;
}


/* ===== MOBILE: poziomy scroll tabeli + kompaktowy widok ===== */
@media (max-width: 900px){
  /* hint "Widok wykonawcy..." ma być w nowej linii (pod przełącznikami) */
  #orders #ordersModeHint{
    flex-basis: 100%;
    width: 100%;
    order: 99;           /* zawsze na końcu toolbara */
    margin-left: 0 !important;
    margin-top: 2px;
    line-height: 1.2;
  }
  /* pokaż przełącznik widoku tabeli tylko na mobile */
  #compactViewWrap{
    display:inline-flex !important;
    align-items:center;
  }

  /* NIE robimy poziomego scrolla na wrapie – ma być tylko dolny pasek */
  #orders .orders-table-wrap{
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-gutter: stable both-edges;
  }

  /* poziomy scrollbar (WebKit) */
  #orders .orders-table-wrap::-webkit-scrollbar{
    height: 12px; /* poziomy */
    width: 12px;  /* pionowy zostaje */
  }
  /* (opcjonalnie) zostawiamy tylko pionowy scrollbar w wrapie */
  #orders .orders-table-wrap::-webkit-scrollbar-thumb{
    background:#2a3444;
    border-radius:10px;
    border: 3px solid rgba(0,0,0,0);
    background-clip: padding-box;
  }
  #orders .orders-table-wrap::-webkit-scrollbar-track{ background: transparent; }

  /* na mobile nie wymuszaj "fixed", bo chcemy naturalną szerokość + scroll */
  #ordersTable{
    table-layout: auto !important;
    min-width: 980px;      /* wymusza sensowną szerokość do scrollowania */
  }

  .orders-swipe-hint{
    margin-top: 8px;
    font-size: 12px;
    opacity: .75;
    text-align: center;
    width: 100%;
    user-select: none;
  }


  /* ===== Kompaktowy widok: tylko "Nazwa wyceny" + "Akcje" ===== */
  #orders.orders-compact #ordersTable thead tr > th:not(:first-child):not(:last-child),
  #orders.orders-compact #ordersTable tbody tr > td:not(:first-child):not(:last-child){
    display:none !important;
  }

  /* KOMPAKT: bez scrolla – tabela ma się zmieścić w ekranie */
  #orders.orders-compact #ordersTable{
    min-width: 0 !important;
    width: 100% !important;
    table-layout: fixed !important;
  }

  /* w kompaktowym: akcje węższe */
  #orders.orders-compact #ordersTable th:last-child,
  #orders.orders-compact #ordersTable td:last-child{
    width: 128px;
    white-space: nowrap;
    vertical-align: middle;
  }

  /* w kompaktowym: nazwa ma się zmieścić bez scrolla – pozwól na zawijanie */
  #orders.orders-compact #ordersTable td.cell-name{
    white-space: normal !important;
    line-height: 1.2;
    padding-right: 6px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  /* kompakt: ciaśniejsze komórki */
  #orders.orders-compact #ordersTable th,
  #orders.orders-compact #ordersTable td{
    padding: 8px 8px;
  }

  /* kompakt: hint swipe niepotrzebny */
  #orders.orders-compact .orders-swipe-hint{ display:none; }
}

/* Vendor: ikonowy przycisk "Program" (gdy jest w kompaktowym) */
#orders.orders-compact .order-open-program-btn{
  width: 34px;
  height: 32px; /* wyrównaj do ikon-btn (u Ciebie mają 32px) */
  padding: 0;
  border-radius: 10px;
  display: inline-grid;
  place-items: center;
}
#orders.orders-compact .order-open-program-btn .prog-ico{
  font-size: 16px;
  line-height: 1;
}

/* zmniejsz trochę paddingi, żeby zrobić miejsce */
#ordersTable th, #ordersTable td{
  padding: 9px 10px;
}

/* ellipsis tylko tam gdzie faktycznie chcemy ucinać tekst */
#ordersTable td.cell-name,
#ordersTable td.cell-info{
  overflow: hidden;
  text-overflow: ellipsis;
}

/* (opcjonalnie) jeśli masz kolumnę klienta jako zwykłe <td> bez klasy,
   możesz ucinać ją selektorem kolumny – dopasuj numer jeśli u Ciebie jest inaczej */
#ordersTable td:nth-child(5){
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* kolumny daty i cena – niech nie puchną */
#ordersTable th:nth-child(2), #ordersTable td:nth-child(2),
#ordersTable th:nth-child(3), #ordersTable td:nth-child(3){
  width: 130px;
  white-space: nowrap;
}
#ordersTable th:nth-child(4), #ordersTable td:nth-child(4){
  width: 115px;
  white-space: nowrap;
}

/* 5) STATUS – zwężamy + centrujemy kolorowe pillki */
#ordersTable th:nth-child(6), #ordersTable td:nth-child(6){
  width: 130px;           /* tu jest zmiana, żeby zniknął poziomy scroll */
  white-space: normal;    /* pozwól układać w 2 linie (pill + PO TERMINIE) */
  text-align: center;     /* wyśrodkowanie */
  overflow: visible;      /* <-- ważne: bez ellipsis w statusie */
  text-overflow: clip;
}

/* Status w 2 liniach: status na górze, "PO TERMINIE" pod spodem */
#ordersTable tbody td:nth-child(6){
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
#ordersTable tbody td:nth-child(6) .status-pill,
#ordersTable tbody td:nth-child(6) .badge-warn{
  display: inline-flex;
  justify-content: center;
}

/* 6) Akcje – stała szerokość, żeby nie rozpychały */
#ordersTable th:last-child,
#ordersTable td:last-child{
  width: 210px;
  white-space: nowrap;
}

/* 7) Nazwa + Klient/Wykonawca – utnij ładnie (żeby nie wypychało tabeli) */
#ordersTable th:nth-child(1), #ordersTable td:nth-child(1){
  white-space: nowrap;
}
#ordersTable th:nth-child(5), #ordersTable td:nth-child(5){
  white-space: nowrap;
}

/* ===== Sortowanie kolumn w Zleceniach ===== */
#ordersTable thead th .th-sort{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: 0;
  color: inherit;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  padding: 0;
  text-align: left;
}

#ordersTable thead th .th-sort:focus-visible{
  outline: 0;
  box-shadow: 0 0 0 2px rgba(59,130,246,.45);
  border-radius: 10px;
}

#ordersTable thead th .th-sort-label{
  display: inline-block;
}

#ordersTable thead th .sort-ico{
  width: 14px;
  height: 14px;
  opacity: .55;
  transition: transform .14s ease, opacity .14s ease;
}

#ordersTable thead th .th-sort.active .sort-ico{
  opacity: 1;
}

#ordersTable thead th .th-sort[data-dir="desc"] .sort-ico{
  transform: rotate(180deg);
}

/* ===== Globalny tooltip (zawsze na wierzchu, nieuciany przez overflow) ===== */

/* gdy włączymy globalne tooltipy, wyłącz pseudo-elementowe dymki */
body.has-global-tooltips [data-tip]::before,
body.has-global-tooltips [data-tip]::after{
  display: none !important;
}

.global-tooltip{
  position: fixed;
  left: 0;
  top: 0;
  transform: translate(-50%, 0);
  background: var(--tooltip-bg, rgba(2, 6, 23, 0.96));
  color: var(--tooltip-fg, #ffffff);
  border: 1px solid var(--tooltip-border, var(--border));
  padding: 6px 8px;
  border-radius: 10px;
  font-size: 12px;
  white-space: nowrap;
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  opacity: 0;
  pointer-events: none;
  z-index: 999999;            /* NAD wszystkim */
  transition: opacity .12s ease, transform .12s ease;
}

.global-tooltip.show{
  opacity: 1;
}

.global-tooltip::before{
  content:'';
  position:absolute;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
}

/* strzałka gdy tooltip jest pod elementem */
.global-tooltip[data-pos="bottom"]::before{
  top: -12px;
  bborder-top-color: var(--tooltip-bg, rgba(2, 6, 23, 0.96));
}

/* strzałka gdy tooltip jest nad elementem */
.global-tooltip[data-pos="top"]::before{
  bottom: -12px;
  border-top-color: rgba(2, 6, 23, 0.96);
}

/* --- Date filter (Otrzymano/Realizacja) --- */
.datefilter{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:34px;
}

.datefilter-btn{
  width:34px;
  height:34px;
  border-radius:12px;
  border: 1px solid rgba(148,163,184,.25);
  background: rgba(2,6,23,.35);
  color:#e5e7eb;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}

.datefilter-btn:hover{
  background: rgba(2,6,23,.55);
}

.datefilter-label{
  font-size:12px;
  opacity:.9;
  white-space:nowrap;
}

/* Popover */
.orders-date-popover{
  position:fixed;
  z-index: 100000; /* zawsze nad tabelą */
  width: 320px;
  max-width: calc(100vw - 24px);
  border: 1px solid rgba(148,163,184,.25);
  background: rgba(15,23,42,.98);
  border-radius: 14px;
  box-shadow: 0 20px 70px rgba(0,0,0,.55);
  padding: 12px;
  display:none;
}

.orders-date-popover.open{ display:block; }

.orders-date-popover .head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}

.orders-date-popover .title{
  font-weight:700;
  font-size:13px;
}

.orders-date-popover .close{
  width:28px;
  height:28px;
  border-radius:10px;
  border: 1px solid rgba(148,163,184,.25);
  background: rgba(2,6,23,.35);
  color:#e5e7eb;
  cursor:pointer;
}

.orders-date-popover .tabs{
  display:flex;
  gap:8px;
  margin-bottom:10px;
}

.orders-date-popover .tab{
  flex:1;
  padding:8px 10px;
  border-radius: 12px;
  border: 1px solid rgba(148,163,184,.25);
  background: rgba(2,6,23,.25);
  color:#e5e7eb;
  cursor:pointer;
  font-size:12px;
}

.orders-date-popover .tab.active{
  background: rgba(59,130,246,.22);
  border-color: rgba(59,130,246,.45);
}

.orders-date-popover .row{
  display:grid;
  grid-template-columns: 1fr;
  gap:8px;
  margin-bottom:10px;
}

.orders-date-popover label{
  font-size:12px;
  opacity:.85;
}

.orders-date-popover input[type="date"]{
  width:100%;
  box-sizing:border-box;
  padding:10px 10px;
  border-radius: 12px;
  border:1px solid rgba(148,163,184,.25);
  background: rgba(2,6,23,.35);
  color:#e5e7eb;
  outline:none;
}

.orders-date-popover .range{
  display:grid;
  grid-template-columns: 1fr; /* Od + input, potem Do + input (pionowo) */
  gap:10px;
}

.orders-date-popover .actions{
  display:flex;
  justify-content:space-between;
  gap:8px;
  margin-top:8px;
}

.orders-date-popover .actions button{
  padding:9px 10px;
  border-radius:12px;
  border: 1px solid rgba(148,163,184,.25);
  background: rgba(2,6,23,.35);
  color:#e5e7eb;
  cursor:pointer;
  font-size:12px;
}

.orders-date-popover .actions .primary{
  background: rgba(59,130,246,.25);
  border-color: rgba(59,130,246,.55);
}
/* ===== Własna biała ikonka kalendarza (nie do zakrycia) ===== */
.date-ico-wrap{
  position: relative;
  display: block;
}

.date-ico-wrap input[type="date"]{
  padding-right: 44px; /* miejsce na ikonę */
}

/* biała ikonka nad inputem */
.date-ico-wrap::after{
  content: "";
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  pointer-events: none; /* klik nadal idzie w input */
  opacity: .95;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px 18px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
}


/* ===== Wymuszona biała ikonka kalendarza w input[type="date"] (dark UI) =====
   Uwaga: natywny picker potrafi przykrywać prawą część inputa, więc
   rysujemy ikonę jako background przesunięty w lewo, a natywną ikonkę ukrywamy. */
input[type="date"]{
  color-scheme: dark;
  padding-right: 58px !important; /* miejsce na tekst + klikalny obszar ikony
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-size: 18px 18px !important;
  /* umieść ikonę W ŚRODKU klikalnego obszaru pickera (po prawej) */
  background-position: right 16px center !important;
}

/* ukryj natywną ikonkę, ale zostaw klikany obszar po prawej */
input[type="date"]::-webkit-calendar-picker-indicator{
  opacity: 0 !important;
  width: 58px !important;  /* klikalny obszar obejmuje ikonę */
  height: 100% !important;
  cursor: pointer;
}
/* USER: nie pokazuj "Parametry" w lewym panelu */
body.role-user #navParamsToggle,
body.role-user #navParamsList {
  display: none !important;
}
/* USER: nie pokazuj "Operacje" w lewym panelu */
body.role-user #cadOpsShelf{
  display: none !important;
}


/* Wycena + Zlecenia: wygląd jak navbtn + odstęp ikonka–tekst */

header nav a#navSummary,
header nav a#navOrders{
  display: inline-flex !important;      /* przebija display:block !important z patchy */
  align-items: center;
  justify-content: center;
  text-align: center;
}

header nav a#navSummary::before,
header nav a#navOrders::before{
  content: attr(data-icon);
  display: inline-block;
  line-height: 1;
  margin-right: 10px;                  /* +2px względem 8px z navbtn */
}

/* na wszelki wypadek, żeby tekst nie robił "ramki"/bloków */
header nav a#navSummary > span,
header nav a#navOrders > span{
  display: inline;
}




/* Animacja zwijania paska + odsunięcia main */
header{
  transition: width .18s ease, min-width .18s ease, max-width .18s ease, padding .18s ease;
}
main{
  transition: margin-left .18s ease;
}


/* WYCENA/ZLECENIA – zachowanie jak navbtn + animacja tekstu */
header nav a#navSummary,
header nav a#navOrders{
  /* przebijamy patcha, który wymusza display:block !important */
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

/* ikonka ma płynnie zmieniać odstęp */
header nav a#navSummary::before,
header nav a#navOrders::before{
  content: attr(data-icon);
  display: inline-block;
  line-height: 1;
  margin-right: 10px;                 /* Twój odstęp */
  transition: margin-right .18s ease; /* animacja jak w navbtn */
}

/* tekst nie znika display:none – tylko się zwija i zanika */
header nav a#navSummary > span,
header nav a#navOrders > span{
  display: inline-block;
  white-space: nowrap;
  max-width: 200px;
  overflow: hidden;
  opacity: 1;
  transform: translateX(0);
  transition: opacity .18s ease, transform .18s ease, max-width .18s ease;
}

/* zwinięty pasek: ikonka zostaje, tekst płynnie znika */
body.sidebar-collapsed header nav a#navSummary::before,
body.sidebar-collapsed header nav a#navOrders::before{
  margin-right: 0;
}

body.sidebar-collapsed header nav a#navSummary > span,
body.sidebar-collapsed header nav a#navOrders > span{
  max-width: 0;
  opacity: 0;
  transform: translateX(-6px);
}
/* =========================
   NAV: Wycena – gold accent
   ========================= */
button.wycena,
.buttonlike.wycena{
  border-color: rgba(244,196,0,0.45);
}

button.wycena:hover,
.buttonlike.wycena:hover{
  background: rgba(244,196,0,0.18);
  border-color: rgba(244,196,0,0.85);
  color: #111;
  box-shadow: 0 0 0 3px rgba(244,196,0,0.18);
}

button.wycena.active,
.buttonlike.wycena.active{
  background: rgba(244,196,0,0.22);
  border-color: rgba(244,196,0,0.95);
  font-weight: 700;
}
/* =========================
   NAV: Zlecenia – slate / neutral
   ========================= */
button.zlecenia,
.buttonlike.zlecenia{
  border-color: rgba(148,163,184,0.55); /* slate */
}

button.zlecenia:hover,
.buttonlike.zlecenia:hover{
  background: rgba(148,163,184,0.14);
  border-color: rgba(148,163,184,0.85);
  color: var(--fg);
}

button.zlecenia.active,
.buttonlike.zlecenia.active{
  background: rgba(148,163,184,0.18);
  border-color: rgba(148,163,184,0.95);
  font-weight: 650;
}

/* ===== KROK 2: responsywna siatka + jasny przycisk "Przejdź do kroku 3" ===== */

/* Na średnich/węższych ekranach pola w Kroku 2 mają się układać jedno pod drugim */
@media (max-width: 1200px){
  #step2 #baseForm .grid{
    grid-template-columns: 1fr !important;
  }
}

/* Link "Przejdź do kroku 3" jako jasny/żółty przycisk */
#step2 #baseForm .actions a.buttonlike{
  background: #f5c400;
  border-color: #e0b000;
  color: #111;
  font-weight: 600;
}

#step2 #baseForm .actions a.buttonlike:hover{
  filter: brightness(0.98);
}

#step2 #baseForm .actions a.buttonlike:active{
  transform: translateY(1px);
}

/* KROK 1: żółty przycisk "Przejdź do kroku 2" */
#step1 .actions a.buttonlike[href="#/step2"]{
  background: #f5c400;
  border-color: #e0b000;
  color: #111;
  font-weight: 600;
}

#step1 .actions a.buttonlike[href="#/step2"]:hover{
  filter: brightness(0.98);
}


/* =========================================================
   KROK 3 – accordion grup (ładniej, wyżej, z ikonką)
   Nie dotyka akordeonu w prawym panelu (cięcia/wiercenia), bo scope = #step3ParamsContainer
   ========================================================= */

#step3ParamsContainer{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#step3ParamsContainer .acc-item{
  border-radius: 14px;
  transition: transform .12s ease, box-shadow .18s ease, border-color .18s ease;
}

#step3ParamsContainer .acc-btn{
  padding: 14px 16px;                /* minimalnie wyższe belki */
  font-weight: 800;
  letter-spacing: .2px;
  border-bottom: 1px solid var(--border);
  position: relative;
}

/* "żółta" (brand) belka tylko dla rozwiniętej grupy */
#step3ParamsContainer .acc-item.acc-open > .acc-btn{
  background: linear-gradient(180deg, rgba(244,196,0,0.22), rgba(244,196,0,0.06));
  box-shadow:
    0 10px 28px rgba(0,0,0,0.08),
    0 0 0 1px rgba(244,196,0,0.28) inset;
}

/* lewy "brand strip" – widoczny tylko gdy otwarte */
#step3ParamsContainer .acc-btn::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: transparent;
}
#step3ParamsContainer .acc-item.acc-open > .acc-btn::before{
  background: var(--brand);
}

/* układ: ikonka + tytuł po lewej */
#step3ParamsContainer .acc-left{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

#step3ParamsContainer .acc-icon{
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,0.04);
  font-size: 16px;
  flex: 0 0 auto;
}

/* caret bardziej "nowoczesny" */
#step3ParamsContainer .acc-caret{
  font-size: 14px;
  opacity: .9;
  transition: transform .18s ease;
}
#step3ParamsContainer .acc-item.acc-open .acc-caret{
  transform: rotate(0deg);
}
#step3ParamsContainer .acc-item:not(.acc-open) .acc-caret{
  transform: rotate(-90deg);
}

/* WOW: delikatny lift na hover (tylko w kroku 3) */
#step3ParamsContainer .acc-item:hover{
  transform: translateY(-1px);
}

/* =========================
   KROK 3: SHIMMER (premium, delikatny)
   ========================= */

#step3ParamsContainer .acc-item.acc-open > .acc-btn{
  position: relative;
  overflow: hidden;
}

/* shimmer tylko na aktywnej belce */
#step3ParamsContainer .acc-item.acc-open > .acc-btn::after{
  content:"";
  position:absolute;
  top:0;
  left:-40%;
  width:40%;
  height:100%;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,0.18) 45%,
    rgba(255,255,255,0) 100%
  );
  transform: skewX(-18deg);
  opacity: .35;
  pointer-events:none;
  animation: step3Shimmer 2.6s ease-in-out infinite;
}

@keyframes step3Shimmer{
  0%   { left:-45%; }
  55%  { left:110%; }
  100% { left:110%; }
}

/* troszkę gładsze wejście/wyjście panelu */
#step3ParamsContainer .acc-panel{
  transform-origin: top;
}

.admin-tools { display:flex; gap:10px; align-items:center; }
.admin-tools.hidden { display:none !important; }
.btn.btn-ghost { background: transparent; border: 1px solid var(--border); }

/* KROK 3: żółty przycisk "Przejdź do wyceny" jak w Kroku 2 */
#step3 .actions a.buttonlike[href="#/summary"]{
  background: #f5c400;
  border-color: #e0b000;
  color: #111;
  font-weight: 600;
}
#step3 .actions a.buttonlike[href="#/summary"]:hover{
  filter: brightness(0.98);
}
#step3 .actions a.buttonlike[href="#/summary"]:active{
  transform: translateY(1px);
}


