/* ==========================================================================
   Munkaidő-nyilvántartó — a MÉRLEG-app (kevero-app) design-rendszere 1:1.
   Forrás: kevero-app/public/index.html <style> (2026-07-03 kimásolva).
   Cél: a UI TELJESEN egyezzen a mérleg-appal (közös SSO-portál egységes arculat).
   ========================================================================== */

/* ── Alias-tokenek: a korábbi munkaidő-nézet-CSS token-nevei → mérleg-tokenek ── */
:root{
  --background:var(--bg); --foreground:var(--ink); --border:var(--line);
  --primary:var(--accent); --primary-strong:var(--accent); --line-soft:var(--line);
  --pos:var(--green-tx); --neg:var(--red-tx); --warn:var(--amber-tx);
}

/* ===================== DESIGN TOKENS ===================== */
:root{
  --brand-1:#0f172a; --brand-2:#1e3a8a; --brand-3:#2563eb;
  --accent:#2563eb; --accent-2:#1e3a8a; --accent-soft:#eff6ff;
  --bg:#eef2f8; --card:#ffffff; --card-2:#f8fafc;
  --ink:#0f172a; --ink-2:#374151; --muted:#94a3b8; --faint:#94a3b8;
  --line:#e2e8f0; --line-2:#cbd5e1;
  --green:#22c55e; --green-bg:#dcfce7; --green-tx:#16a34a; --amber:#f59e0b; --amber-bg:#fef3c7; --amber-tx:#b45309;
  --red:#ef4444; --red-bg:#fee2e2; --red-tx:#dc2626; --blue:#2563eb; --blue-bg:#dbeafe; --purple:#7c3aed; --purple-bg:#f3e8ff; --purple-tx:#6d28d9;
  --side-w:248px;
  --r-sm:9px; --r:13px; --r-lg:18px;
  --sh-1:0 1px 2px rgba(15,42,74,.06),0 1px 3px rgba(15,42,74,.10);
  --sh-2:0 4px 14px rgba(15,42,74,.10);
  --sh-3:0 18px 50px rgba(8,20,40,.28);
  --ring:0 0 0 3px rgba(37,99,235,.18);
}
html[data-theme="dark"]{
  --bg:#0a0f1d; --card:#0f1a2e; --card-2:#0e1828;
  --ink:#e8eef8; --ink-2:#cbd5e1; --muted:#64748b; --faint:#64748b;
  --line:#1e293b; --line-2:#2c3c57; --accent-soft:#16223a;
  --accent:#3b82f6; --accent-2:#1e3a8a;
  --green-bg:#0d2a1b; --amber-bg:#2c220c; --red-bg:#2c1416; --blue-bg:#12203f; --purple-bg:#241640;
  --green-tx:#4ade80; --amber-tx:#fbbf24; --red-tx:#f87171; --purple-tx:#c4b5fd;
  --sh-1:0 1px 2px rgba(0,0,0,.4); --sh-2:0 6px 20px rgba(0,0,0,.45); --sh-3:0 22px 60px rgba(0,0,0,.6);
  --card-2:#0e1828;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px;line-height:1.45;-webkit-text-size-adjust:100%;
  transition:background .25s,color .25s}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:var(--accent)}
.ic{width:18px;height:18px;flex:0 0 auto;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:-3px}
.ic.sm{width:15px;height:15px}.ic.lg{width:22px;height:22px}

/* ===================== APP SHELL ===================== */
.app{min-height:100vh}
.sidebar{width:var(--side-w);flex:0 0 var(--side-w);background:linear-gradient(165deg,rgba(15,23,42,.92),rgba(30,58,138,.88));
  -webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);
  color:#dce7f5;position:fixed;inset:0 auto 0 0;height:100vh;display:flex;flex-direction:column;z-index:60;
  box-shadow:var(--sh-2);transition:width .28s cubic-bezier(.4,0,.2,1),transform .28s cubic-bezier(.4,0,.2,1)}
.side-logo{display:flex;align-items:center;gap:11px;padding:18px 16px 14px}
.side-logo .mark{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#2563eb,#1e3a8a);
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(37,99,235,.45);flex:0 0 auto}
.side-logo .mark .ic{width:22px;height:22px;stroke:#fff;stroke-width:2.2}
.side-logo .tt-wrap{display:flex;flex-direction:column;min-width:0;flex:1 1 auto}
.side-logo .tt{font-weight:800;font-size:15px;letter-spacing:.2px;color:#fff;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-logo .st{font-size:11px;color:#9db6d6;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-collapse{flex:0 0 auto;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#9db6d6;transition:.15s}
.side-collapse:hover{background:rgba(255,255,255,.12);color:#fff}
.side-collapse .ic{width:18px;height:18px}
.side-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 12px;display:flex;flex-direction:column;gap:3px}
.side-sec{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:#6f8cb3;padding:14px 12px 5px;font-weight:700;white-space:nowrap}
.side-nav button{display:flex;align-items:center;gap:12px;width:100%;text-align:left;color:#c2d3ea;
  padding:10px 13px;border-radius:11px;font-size:13.7px;font-weight:600;position:relative;transition:.16s}
.side-nav button span:not(.nav-badge){flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-nav button .ic{color:#8fb0d8;transition:.16s;flex:0 0 auto}
.side-nav button .nav-badge{margin-left:auto;flex:0 0 auto}
.side-nav button:hover{background:rgba(255,255,255,.07);color:#fff}
.side-nav button:hover .ic{color:#cfe0f5}
.side-nav button.active{background:linear-gradient(90deg,rgba(96,165,250,.30),rgba(96,165,250,.08));color:#fff}
.side-nav button.active .ic{color:#93c5fd}
.side-nav button.active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:4px;border-radius:0 4px 4px 0;background:#60a5fa}
/* ── lenyitható szülő-menüpont (accordion, pl. „Elemzés") ── */
.side-nav .acc-chev{margin-left:auto;flex:0 0 auto;font-size:16px;line-height:1;color:#7f9bc0;transition:transform .18s}
.side-nav button.acc-parent.open .acc-chev{transform:rotate(90deg)}
.side-sub{display:none;flex-direction:column;gap:3px;margin:1px 0 3px}
.side-sub.open{display:flex}
.side-sub button{padding-left:34px;font-size:13px}
.side-sub button .ic{width:16px;height:16px}
/* ── összecsukott „rail" (ikon-only) ── */
body.sb-collapsed .sidebar{width:74px}
body.sb-collapsed .main{margin-left:74px}
body.sb-collapsed .side-logo{flex-direction:column;gap:9px;padding:16px 0 12px}
body.sb-collapsed .side-logo .tt-wrap{display:none}
body.sb-collapsed .side-nav{padding:8px 9px}
body.sb-collapsed .side-nav button{justify-content:center;padding:11px 0;gap:0}
body.sb-collapsed .side-nav button span:not(.nav-badge){display:none}
body.sb-collapsed .side-nav button .nav-badge{position:absolute;top:4px;right:9px;margin:0;min-width:16px;height:16px;font-size:10px}
body.sb-collapsed .side-nav button.active::before{left:-9px}
body.sb-collapsed .side-sec{font-size:0;padding:12px 0 4px;text-align:center}
body.sb-collapsed .side-sec::after{content:"•••";font-size:11px;letter-spacing:1px;color:#6f8cb3}
.side-foot{padding:12px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:9px}
.user-row{display:flex;align-items:center;gap:9px;font-size:12.5px;color:#bdd0ea}
.user-row .av{width:28px;height:28px;border-radius:50%;background:#274a7d;display:flex;align-items:center;justify-content:center;font-weight:700;color:#cfe0f5;font-size:12px;flex:0 0 auto}
#headerMeta{font-size:10.8px;color:#86a0c4;line-height:1.5}
.logout-btn{margin-left:auto;color:#9db6d6;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.15s}
.logout-btn:hover{background:rgba(255,255,255,.12);color:#fff}
.login-wrap{position:fixed;inset:0;z-index:1500;background:radial-gradient(1200px 600px at 30% -10%,#1e3a8a,transparent),linear-gradient(165deg,#0f172a,#1e3a8a)}
.login-wrap .lockbox{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:390px;padding:16px}
.login-wrap .lock{margin:0}
.role-badge{display:inline-block;padding:1px 8px;border-radius:999px;font-size:10.5px;font-weight:700;background:rgba(96,165,250,.22);color:#bfdbfe}

/* ===================== MAIN ===================== */
.main{flex:1;margin-left:var(--side-w);min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:40;background:linear-gradient(160deg,#0f172a,#1e3a8a);
  color:#fff;border-bottom:1px solid rgba(255,255,255,.10);box-shadow:0 6px 20px -12px rgba(8,16,38,.6);
  display:flex;align-items:center;gap:12px;padding:13px 20px}   /* navy króm (sidebar.html topbar minta): fehér szöveg, áttetsző-fehér kontrollok */
.actions.tb-right{margin-left:auto}   /* a jobb akció-csoport mindig a jobb szélen (asztali: a flex:1 nav úgyis odanyomja; mobil/drawer: az auto-margin) */
.hamb{display:none;color:#fff;padding:6px;border-radius:9px}
.hamb:hover{background:rgba(255,255,255,.14)}
.page-head{display:flex;flex-direction:column;justify-content:center;gap:1px;min-width:0;flex:1 1 auto}
.page-title{font-size:17px;font-weight:800;letter-spacing:.2px;color:#fff;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.page-sub{font-size:11.5px;color:rgba(255,255,255,.7);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar .sp{flex:1}
.tb-btn{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.88);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);
  padding:8px 12px;border-radius:10px;font-size:13px;font-weight:600;transition:.15s}
.tb-btn:hover{border-color:rgba(255,255,255,.45);color:#fff;background:rgba(255,255,255,.2)}
.tb-btn .ic{color:inherit}
.tb-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:rgba(255,255,255,.88);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);transition:.15s;position:relative}
.tb-icon:hover{color:#fff;border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.2)}
.sync-dot{position:absolute;top:-3px;right:-3px;width:11px;height:11px;border-radius:50%;background:var(--faint);border:2px solid #14213f}
.sync-dot.ok{background:var(--green)}.sync-dot.warn{background:var(--amber)}.sync-dot.err{background:var(--red)}
.content{padding:20px;width:100%}   /* TELJES szélesség minden méreten (a max-width:1560px korlát kivéve — user 2026-06-23) */
/* felső menüsor: brand + modul-nav + akciók */
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.brand .mark{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,#2563eb,#1e3a8a);display:flex;align-items:center;justify-content:center;box-shadow:0 5px 14px rgba(37,99,235,.45);flex:0 0 auto}
.brand .mark .ic{width:20px;height:20px;stroke:#fff;stroke-width:2.2}
.brand .b1{font-weight:800;font-size:14.5px;color:#fff;line-height:1.1;display:block}
.brand .b2{font-size:10.5px;color:rgba(255,255,255,.7);display:block}
.topnav{display:flex;align-items:center;gap:3px;flex:1 1 auto;min-width:0;overflow-x:auto}
.topnav::-webkit-scrollbar{height:0}
.topnav button{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;border-radius:10px;color:rgba(255,255,255,.82);font-size:13.6px;font-weight:600;white-space:nowrap;transition:.15s}
.topnav button .ic{color:rgba(255,255,255,.6);transition:.15s}
.topnav button:hover{background:rgba(255,255,255,.12);color:#fff}
.topnav button:hover .ic{color:#fff}
.topnav button.active{background:var(--accent);color:#fff;box-shadow:0 3px 12px rgba(37,99,235,.5)}
.topnav button.active .ic{color:#fff}
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--amber);color:#fff;font-size:11px;font-weight:800;line-height:1}
.topnav button.active .nav-badge{background:#fff;color:var(--amber)}
.nav-badge.red{background:var(--red)} .topnav button.active .nav-badge.red{background:#fff;color:var(--red)}
.actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.gmonth-wrap{position:relative;display:inline-block}
.gmonth{display:inline-flex;align-items:center;gap:7px;padding:7px 11px;border:1px solid rgba(255,255,255,.28);border-radius:9px;font-size:12.8px;font-weight:700;background:rgba(255,255,255,.14);color:#fff;max-width:235px;cursor:pointer;white-space:nowrap}
.gmonth:hover{background:rgba(255,255,255,.22)}
.gmonth:focus{outline:none;box-shadow:var(--ring)}
.gmonth .gm-lbl{overflow:hidden;text-overflow:ellipsis}
.gmonth .gm-cev{flex:0 0 auto;opacity:.8;font-size:10px}
.gmonth-pop{position:absolute;top:calc(100% + 6px);right:0;z-index:1200;width:288px;max-width:calc(100vw - 24px);background:var(--card);border:1px solid var(--line-2);border-radius:12px;box-shadow:var(--sh-3);padding:6px;display:none}
.gmonth-wrap.open .gmonth-pop{display:block}
.gmonth-pop .gm-opt{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:8px;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer;transition:.12s}
.gmonth-pop .gm-opt:hover{background:var(--accent-soft)}
.gmonth-pop .gm-opt.sel{background:var(--accent-soft);color:var(--accent)}
.gmonth-pop .gm-check{width:16px;height:16px;flex:0 0 auto;border:1.6px solid var(--line-2);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;background:var(--card)}
.gmonth-pop .gm-opt.sel .gm-check{background:var(--accent);border-color:var(--accent)}
.gmonth-pop .gm-all{border-bottom:1px solid var(--line);margin-bottom:4px;padding-bottom:4px}
.gmonth-pop .gm-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.gmonth-pop .gm-grid .gm-opt{padding:6px 8px;font-size:12.6px}
.gmonth-pop.gm-yearpop{width:auto;min-width:150px}   /* ÉV legördülő: keskeny lista (single-select) */
.gmonth-pop .gm-yopt{padding:8px 12px}
.gmonth-pop .gm-years{display:flex;align-items:center;gap:5px;flex-wrap:wrap;padding:3px 4px 6px}   /* ÉV-szűrő sor a hó-picker tetején */
.gmonth-pop .gm-ylab{font-size:10.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-right:2px}
.gmonth-pop .gm-yr{padding:4px 11px;border:1px solid var(--line-2);border-radius:999px;font-size:12.5px;font-weight:700;background:var(--card-2);color:var(--ink-2);cursor:pointer;transition:.12s}
.gmonth-pop .gm-yr:hover{border-color:var(--accent);color:var(--accent)}
.gmonth-pop .gm-yr.sel{background:var(--accent);color:#fff;border-color:var(--accent)}
.gmonth-pop .gm-sep{height:1px;background:var(--line);margin:1px 4px 5px}
.tb-icon.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.user-chip{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 5px;border:1px solid rgba(255,255,255,.22);border-radius:999px}
.user-chip .av{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;flex:0 0 auto;box-shadow:0 0 0 1.5px rgba(255,255,255,.25)}
.user-chip #headerMeta{font-size:12.7px;font-weight:700;color:#fff;max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-chip .logout-btn{color:rgba(255,255,255,.72);width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.15s}
.user-chip .logout-btn:hover{background:var(--red);color:#fff}
/* (A régi vízszintes-nav média-blokkjai eltávolítva — a navigáció átkerült a bal oldalsávba.) */
.subnav{position:sticky;top:var(--top-h,58px);z-index:30;background:color-mix(in srgb,var(--card) 92%,transparent);backdrop-filter:saturate(1.4) blur(7px);border-bottom:1px solid var(--line)}
.subnav:empty{display:none}
.subnav .subtabs{width:100%;padding:11px 20px;gap:6px}   /* teljes szélesség (1560px-cap kivéve) — igazodik a .content-hez */
/* Beállítások-oldal szekció-ugró csík (a hosszú egységes oldalhoz) */
.bset-nav{display:flex;flex-wrap:wrap;gap:8px;position:sticky;top:calc(var(--top-h,58px) + var(--sub-h,0px));z-index:20;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:saturate(1.3) blur(6px);padding:9px 2px;margin:-4px 0 10px}
.bset-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--ink-2);font-size:13px;font-weight:700;cursor:pointer;transition:.15s}
.bset-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}

/* ===================== KPI ===================== */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 17px;box-shadow:var(--sh-1);position:relative;overflow:hidden;transition:.18s}
.kpi:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.kpi .k-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.kpi .k-label{font-size:11.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.kpi .k-ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent)}
.kpi .k-val{font-size:25px;font-weight:800;margin-top:9px;letter-spacing:-.5px;font-variant-numeric:tabular-nums}
.kpis.compact{display:flex;flex-wrap:wrap;gap:11px;max-width:none}   /* user 2026-06-26: a kártyák töltsék ki a tartalom szélességét (a 820px-es rács balra zsúfolta őket); flex + kártyánkénti max-width → 4 kártya kitölti, 2-3 kártya nem ugrik szét */
.kpis.compact .kpi{flex:1 1 170px;max-width:300px;padding:11px 15px}
.kpis.compact .k-ic{width:28px;height:28px;border-radius:8px}
.kpis.compact .k-ic .ic{width:15px;height:15px}
.kpis.compact .k-val{font-size:20px;margin-top:4px}
.kpis.compact .k-label{font-size:10.5px}
.kpi .k-sub{font-size:11.8px;color:var(--muted);margin-top:3px}
/* Labor „QC-összegző" panel: megfelelés-gyűrű + statok (a KPI-kártyák helyett) */
.lab-hero{display:flex;align-items:center;gap:26px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 24px;box-shadow:var(--sh-1);margin-bottom:18px;flex-wrap:wrap}
.lab-hero .lh-ringbox{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto}
.lab-hero .lh-rsub{display:flex;flex-direction:column;align-items:center;gap:5px}
.lab-hero .lh-rsub-n{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap}
.lab-hero .lh-scope{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:2px 9px;border-radius:999px;background:color-mix(in srgb,var(--accent) 13%,transparent);color:var(--accent);white-space:nowrap}
.lab-hero .lh-ring{width:108px;height:108px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:conic-gradient(var(--ring) calc(var(--pct)*1%),var(--line) 0)}
.lab-hero .lh-ring-in{width:82px;height:82px;border-radius:50%;background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}
.lab-hero .lh-pct{font-size:25px;font-weight:800;letter-spacing:-.5px}
.lab-hero .lh-rlbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.lab-hero .lh-stats{display:flex;gap:14px;flex-wrap:wrap;flex:1;min-width:0}
.lab-hero .lh-stat{display:flex;align-items:center;gap:11px;flex:1 1 130px;min-width:118px}
.lab-hero .lh-sic{width:36px;height:36px;border-radius:10px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.lab-hero .lh-sic .ic{width:18px;height:18px}
.lab-hero .lh-sv{font-size:21px;font-weight:800;letter-spacing:-.3px;font-variant-numeric:tabular-nums}
.lab-hero .lh-sk{font-size:11.5px;color:var(--muted);font-weight:600;margin-top:1px}
@media(max-width:640px){.lab-hero{flex-direction:column;align-items:stretch;gap:15px}.lab-hero .lh-ring{margin:0 auto}.lab-hero .lh-stat{flex:1 1 calc(50% - 7px);min-width:0}}
.kpi.green .k-ic{background:var(--green-bg);color:var(--green-tx)} .kpi.green .k-val{color:var(--green-tx)}
.kpi.amber .k-ic{background:var(--amber-bg);color:var(--amber-tx)} .kpi.amber .k-val{color:var(--amber-tx)}
.kpi.red .k-ic{background:var(--red-bg);color:var(--red-tx)} .kpi.red .k-val{color:var(--red-tx)}
.kpi.purple .k-ic{background:var(--purple-bg);color:var(--purple)}

/* ===================== PANEL / GRID ===================== */
.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;margin-bottom:18px}
.grid2.even{grid-template-columns:1fr 1fr}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);margin-bottom:18px;overflow:hidden}
.panel-h{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.panel-h h2{margin:0;font-size:15px;font-weight:800;letter-spacing:.2px;display:flex;align-items:center;gap:9px}
.panel-h h2 .ic{color:var(--accent)}
.panel-h .sp{flex:1}
.panel-b{padding:16px 18px}
.chart-box{position:relative;height:280px}
.chart-box.sm{height:240px}

/* ===================== SUBTABS / FILTERS ===================== */
.subtabs{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:14px 18px 0}
.subtab{background:var(--bg);border:1px solid var(--line);color:var(--ink-2);padding:7px 13px;border-radius:999px;font-size:12.6px;font-weight:600;transition:.15s}
.subtab:hover{border-color:var(--accent);color:var(--accent)}
.subtab.warn{background:var(--amber-bg);color:var(--amber-tx);border-color:var(--amber)}
.subtab.danger{background:var(--red-bg);color:var(--red-tx);border-color:var(--red)}
.subtab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px rgba(37,99,235,.3)}
.subnav .subtabs.sub2{padding-top:3px;padding-bottom:3px}
.subtabs.sub2{align-items:center;gap:5px}
.subtabs.sub2 .subtab{font-size:11.6px;padding:4px 10px;font-weight:600}
.subnav .subtabs.seg-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;padding:9px 20px;width:100%}   /* EGYSÉGES alfül-sáv: címkék + szegmens-trackek; MINDEN oldalon szegmens-kapcsoló (teljes szélesség, 1560px-cap kivéve) */
.subtabs.seg-wrap .seg{display:flex;flex-wrap:nowrap;width:max-content;max-width:100%;overflow-x:auto;gap:3px;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:4px;scrollbar-width:thin}   /* egy szegmens-track (összefüggő fül-futam); sok fülnél (Mozgások) egy sorban VÍZSZINTESEN görgethető */
.subtabs.seg-wrap .seg .subtab{background:transparent;border:1px solid transparent;color:var(--ink-2);box-shadow:none;white-space:nowrap;flex:0 0 auto}
.subtabs.seg-wrap .seg .subtab:hover{background:var(--card);border-color:transparent;color:var(--ink)}
.subtabs.seg-wrap .seg .subtab.active{background:var(--card);color:var(--accent);border-color:transparent;box-shadow:0 1px 3px rgba(15,23,42,.14)}
.subtabs.seg-wrap .seg::-webkit-scrollbar{height:6px}
.subtabs.seg-wrap .seg::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px}
.sub2-lab{font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-right:2px}
.filters{display:flex;gap:11px;flex-wrap:wrap;align-items:flex-end;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--card-2)}
.fld{display:flex;flex-direction:column;gap:4px}
.fld label{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.3px}
.fld input,.fld select{padding:8px 10px;border:1px solid var(--line-2);border-radius:9px;font-size:13px;background:var(--card);color:var(--ink);min-width:130px}
.fld .with-ic{position:relative}
.fld .with-ic .ic{position:absolute;left:10px;top:9px;color:var(--faint)}
.fld .with-ic input{padding-left:32px}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.fld.gfld label{color:var(--accent)}                                   /* globális (közös) hónap-szűrő kiemelése */
.fld.gfld select{border-color:var(--accent);font-weight:700;background:var(--accent-soft);color:var(--accent)}

/* ===================== BUTTONS ===================== */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--accent);color:#fff;padding:9px 15px;border-radius:10px;font-size:13px;font-weight:700;transition:.15s;box-shadow:0 2px 8px rgba(37,99,235,.25)}
.btn:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 6px 16px rgba(37,99,235,.35)}
.btn.ghost{background:var(--card);color:var(--ink-2);border:1px solid var(--line-2);box-shadow:none}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent);transform:none}
.btn.green{background:var(--green-tx);box-shadow:0 2px 8px rgba(22,163,74,.3)} .btn.green:hover{background:#15803d}
.btn.danger{background:var(--red);box-shadow:0 2px 8px rgba(239,68,68,.32)} .btn.danger:hover{background:#dc2626}
.btn.sm{padding:6px 11px;font-size:12px;border-radius:8px}
.btn .ic{color:inherit}
.icon-btn{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;color:var(--muted);transition:.15s}
.icon-btn:hover{background:var(--accent-soft);color:var(--accent)}
.icon-btn.del:hover{background:var(--red-bg);color:var(--red)}
.icon-btn.lab-done{position:relative;color:var(--green-tx)}                         /* #2: a 🧪 labor-ikon zöld, ha már van minta erre a mérlegjegyre */
.icon-btn.lab-done:hover{background:var(--green-bg);color:var(--green-tx)}
.icon-btn.ic-faded{opacity:.32}                                                     /* üres állapotú akció-ikon (pl. ⚖ ahol még NINCS beszállítás) — halvány, de kattintható: „+ hozzáadás" */
.icon-btn.ic-faded:hover{opacity:1}
.icon-btn.lez-btn:hover{background:var(--amber-bg);color:var(--amber-tx)}            /* sor-lezáró lakat (Terményvásárlás/eladás) — akció jelleg */
.icon-btn.ff-ro,input.ff-ro{background:var(--accent-soft,#f1f5f9);color:var(--muted);cursor:default}                 /* csak-olvasható űrlapmező (auto-sorszám/ID) */
.lab-chk{position:absolute;right:-2px;bottom:-2px;font-size:9px;font-weight:900;line-height:1;color:#fff;background:var(--green);border-radius:50%;width:12px;height:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 1.5px var(--card)}
.ov-tag{display:inline-flex;align-items:center;white-space:nowrap;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px;background:var(--purple-bg);color:var(--purple-tx);cursor:help;vertical-align:middle}  /* #B: összevont fuvar — melyik fuvarral (társ azonosító kiírva) */
.rk-tag{display:inline-flex;align-items:center;white-space:nowrap;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:999px;background:var(--amber-bg);color:var(--amber-tx);cursor:help;vertical-align:middle}     /* #B: halmozott rakomány — egy autó több termék */
.kp-cell{display:flex;flex-direction:column;gap:2px;min-width:120px}                                   /* Önkalibráció adatgyűjtés-mutató */
.kp-bar{height:6px;border-radius:4px;background:var(--line);overflow:hidden}
.kp-fill{height:100%;background:var(--amber);border-radius:4px;transition:width .2s} .kp-fill.ok{background:var(--green)}

/* ===================== TABLE ===================== */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.panel.lt-panel{overflow:visible}          /* Leltár: a tétel/raktár kereshető legördülője ne vágódjon le a panel-szélen */
.panel.lt-panel th{position:static}        /* scroll-konténer híján a sticky fejléc a topbar mögé kerülne — a rövid leltár-táblán nem kell sticky */
.panel.lt-panel thead th{text-align:center}   /* Leltár: minden oszlop-fejléc középre (user 2026-06-29) */
.tbl-wrap.lt-wrap{overflow:visible}
table{border-collapse:collapse;width:100%;font-size:13px}
th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
th{background:var(--card-2);font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;position:sticky;top:0;cursor:default;z-index:1}
th.th-sort{cursor:pointer;user-select:none;-webkit-user-select:none;white-space:nowrap}   /* kattintható oszlop-fejléc (rendezés) */
th.th-sort:hover{color:var(--accent)}
th.sorted{color:var(--accent)}
th .sort-ar{font-size:8.5px;margin-left:3px;opacity:.85}
th .sort-ar.idle{opacity:.32;font-weight:600}   /* állandó ↕ jel: jelzi, hogy a fejléc kattintható (rendezhető), mielőtt rákattintanának */
th.th-sort:hover .sort-ar.idle{opacity:.7;color:var(--accent)}
tbody tr{transition:background .12s}
tbody tr:hover{background:var(--accent-soft)}
td.num{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.muted{color:var(--muted)} .dash{color:var(--faint)}
.rowact{display:flex;gap:3px;justify-content:flex-end}
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11.3px;font-weight:700;line-height:1.5}
.pill.green{background:var(--green-bg);color:var(--green-tx)} .pill.amber{background:var(--amber-bg);color:var(--amber-tx)}
.pill.red{background:var(--red-bg);color:var(--red-tx)} .pill.grey{background:var(--line);color:var(--muted)}
.pill.be{background:var(--blue-bg);color:var(--blue)} .pill.ki{background:var(--purple-bg);color:var(--purple)} .pill.att{background:var(--amber-bg);color:var(--amber-tx)}
.delta{display:inline-flex;align-items:center;font-size:11px;font-weight:800;padding:1px 6px;border-radius:7px;margin-left:6px}
.delta.up{color:var(--green-tx);background:var(--green-bg)} .delta.down{color:var(--red-tx);background:var(--red-bg)} .delta.flat{color:var(--muted);background:var(--line)}
.zchip{display:inline-flex;align-items:center;gap:9px;padding:8px 11px;border:1px solid var(--line-2);border-radius:11px;background:var(--card)}
.zchip.locked{border-color:var(--amber);background:var(--amber-bg)}
.zchip .zlab{font-weight:800;font-size:13px;color:var(--ink)} .zchip .zcnt{font-size:11.5px;color:var(--muted)}
.lockmark{font-size:14px;opacity:.85;padding:0 4px}
.empty{padding:54px 20px;text-align:center;color:var(--muted)}
.empty .big{width:54px;height:54px;margin:0 auto 12px;border-radius:16px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.empty .big .ic{width:26px;height:26px}
.tbl-foot{padding:11px 18px;font-size:12px;color:var(--muted);border-top:1px solid var(--line);display:flex;align-items:center;gap:8px}
.panel-note{padding:10px 18px;font-size:12.5px;line-height:1.5;color:var(--ink-2);background:var(--accent-soft);border-bottom:1px solid var(--line)}
.panel-note b{color:var(--ink);font-weight:700}
/* Karbantartás — esemény-napló (lenyitható idővonal egy hibajegynél/tervnél) */
.naplo-det{margin-top:5px;font-size:11.5px}
.naplo-det>summary{cursor:pointer;color:var(--muted);font-weight:600;user-select:none;display:inline-flex;align-items:center;gap:4px;padding:1px 0;list-style:none}
.naplo-det>summary::-webkit-details-marker{display:none}
.naplo-det>summary::before{content:'▸';font-size:10px;transition:transform .12s}
.naplo-det[open]>summary::before{transform:rotate(90deg)}
.naplo-det>summary:hover{color:var(--accent)}
.naplo-list{margin:5px 0 3px;padding:6px 8px 6px 10px;list-style:none;border-left:2px solid var(--line-2);background:var(--card-2);border-radius:0 8px 8px 0}
.naplo-list li{margin:2px 0;line-height:1.45;color:var(--ink)}
.naplo-ts{color:var(--muted);font-variant-numeric:tabular-nums;margin-right:5px;white-space:nowrap}
.naplo-list li b{font-weight:700}
/* listView sor-kibontás (Elemzés drill-down — a Dolgozók/Tkm mintára: teljes szélességű, oszlopos, színezett) */
tr.lv-exp{cursor:pointer}
tr.lv-exp:hover>td{background:rgba(37,99,235,.045)}
.lv-arrow{color:var(--muted);display:inline-block;width:15px;font-size:11px;flex:none}
.lv-det{padding:10px 14px;border-left:3px solid var(--accent);background:rgba(37,99,235,.05)}
html[data-theme="dark"] .lv-det{background:rgba(96,165,250,.08)}
.lv-det-h{font-weight:700;font-size:11px;color:var(--muted);margin-bottom:7px;text-transform:uppercase;letter-spacing:.04em}
.lv-det-tbl{width:100%;font-size:12.5px;border-collapse:collapse}
.lv-det-tbl th{text-align:left;font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;padding:2px 9px 5px;border-bottom:1px solid var(--line);white-space:nowrap}
.lv-det-tbl th.num,.lv-det-tbl td.num{text-align:right}
.lv-det-tbl td{padding:4px 9px;border-bottom:1px solid var(--line);color:var(--ink);vertical-align:middle}
.lv-det-tbl tbody tr:last-child td{border-bottom:none}
.lv-det-tbl tbody tr:hover td{background:rgba(0,0,0,.02)}
html[data-theme="dark"] .lv-det-tbl tbody tr:hover td{background:rgba(255,255,255,.03)}
.col-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px rgba(37,99,235,.25)}
.col-toggle.active .ic{color:#fff}
.col-search-row{background:var(--accent-soft)}
.col-search-row th{position:static;padding:9px 8px;background:transparent;border-bottom:2px solid var(--accent)}
.col-search{width:100%;min-width:74px;padding:7px 9px 7px 30px;border:1px solid var(--line-2);border-radius:8px;font-size:12.5px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--ink);background:var(--card) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="%2394a3b8" stroke-width="2" stroke-linecap="round" viewBox="0 0 24 24"><circle cx="11" cy="11" r="7"/><line x1="21" y1="21" x2="16.65" y2="16.65"/></svg>') no-repeat 9px center;background-size:13px}
.col-search::placeholder{color:var(--faint);font-weight:500}
.col-search:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(37,99,235,.18)}
select.col-sel{min-width:74px;padding:7px 26px 7px 10px;border:1px solid var(--line-2);border-radius:8px;font-size:12.5px;font-weight:600;color:var(--ink);background:var(--card) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round'><path d='M3 5l4 4 4-4'/></svg>") no-repeat right 8px center;background-size:12px;appearance:none;-webkit-appearance:none;cursor:pointer;text-overflow:ellipsis}
select.col-sel:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(37,99,235,.18)}
select.col-sel option{color:var(--ink);background:var(--card)}
.col-clear{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);background:var(--card);border:1px solid var(--line-2);transition:.15s}
.col-clear:hover{background:var(--red-bg);color:var(--red);border-color:var(--red)}
.col-search.col-date{padding-left:9px;background-image:none;min-width:140px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
.icon-btn.active{background:var(--accent);color:#fff}
/* a fix sávban maradó Keresés: letisztult, beágyazott nagyítóval */
.filters .fld input[type="text"]{padding-left:31px;background:var(--card) url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" fill="none" stroke="%2394a3b8" stroke-width="2" stroke-linecap="round" viewBox="0 0 24 24"><circle cx="11" cy="11" r="7"/><line x1="21" y1="21" x2="16.65" y2="16.65"/></svg>') no-repeat 10px center;background-size:14px}
/* szűrő-ikon (tölcsér) közvetlenül a Keresés mellett + a „Megj.+rotáció" chip */
.filters .filter-toggle{flex:0 0 auto;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;border:1px solid var(--line-2);background:var(--card);color:var(--ink-2);cursor:pointer;transition:.15s}
.filters .filter-toggle:hover{border-color:var(--accent);color:var(--accent)}
.filters .filter-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px rgba(37,99,235,.25)}
.filters .filter-toggle .ic{color:inherit}
/* listView fejléc-kapcsoló (pl. „Minden oszlop") — ikon + felirat, a Szűrő gomb mellett */
.lv-toggle{flex:0 0 auto;height:34px;padding:0 11px;display:inline-flex;align-items:center;gap:6px;border-radius:9px;border:1px solid var(--line-2);background:var(--card);color:var(--ink-2);cursor:pointer;font-size:12.5px;font-weight:700;transition:.15s;white-space:nowrap}
.lv-toggle:hover{border-color:var(--accent);color:var(--accent)}
.lv-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px rgba(37,99,235,.25)}
.lv-toggle .ic{width:15px;height:15px;color:inherit}
.filters .extra-toggle{flex:0 0 auto;height:38px;display:inline-flex;align-items:center;gap:6px;padding:0 13px;border-radius:9px;border:1px solid var(--line-2);background:var(--card);color:var(--ink-2);font-size:12.8px;font-weight:600;cursor:pointer;transition:.15s}
.filters .extra-toggle:hover{border-color:var(--accent);color:var(--accent)}
.filters .extra-toggle.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.filters .extra-toggle .ic{color:inherit}

/* recent list (dashboard) */
.recent{display:flex;flex-direction:column}
.recent .ri{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line)}
.recent .ri:last-child{border-bottom:none}
.recent .ri .rico{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;background:var(--accent-soft);color:var(--accent)}
.recent .ri .rico.be{background:var(--blue-bg);color:var(--blue)} .recent .ri .rico.ki{background:var(--purple-bg);color:var(--purple)} .recent .ri .rico.att{background:var(--amber-bg);color:var(--amber)}
.recent .ri .rt{flex:1;min-width:0}
.recent .ri .rt .a{display:block;font-weight:700;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recent .ri .rt .b{display:block;font-size:11.6px;color:var(--muted)}
.recent .ri .rv{font-weight:700;font-variant-numeric:tabular-nums;font-size:13px;white-space:nowrap}
.quick{display:flex;gap:10px;flex-wrap:wrap}
.quick .qbtn{flex:1 1 160px;display:flex;align-items:center;gap:11px;padding:14px;border-radius:var(--r);border:1px solid var(--line);background:var(--card-2);text-align:left;transition:.16s}
.quick .qbtn:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-2px);box-shadow:var(--sh-2)}
.quick .qbtn .qi{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;flex:0 0 auto}
.quick .qbtn .qt{display:block;font-weight:700;font-size:13.5px;line-height:1.25} .quick .qbtn .qs{display:block;font-size:11.5px;color:var(--muted);margin-top:2px}

/* ===================== NYITOTT-MÉRLEGELÉSEK BOARD (kétfázisú) ===================== */
.open-board{background:var(--card);border:1px solid var(--amber);border-radius:var(--r-lg);box-shadow:var(--sh-1);margin-bottom:18px;overflow:hidden}
.ob-head{display:flex;align-items:center;gap:10px;padding:10px 15px;background:var(--amber-bg);border-bottom:1px solid color-mix(in srgb,var(--amber) 32%,transparent)}
.ob-toggle{width:26px;height:26px;border-radius:7px;color:var(--amber-tx);font-size:13px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.ob-toggle:hover{background:color-mix(in srgb,var(--amber) 16%,transparent)}
.ob-title{font-weight:800;font-size:14px;color:var(--amber-tx);display:flex;align-items:center;gap:8px}
.ob-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:var(--amber-tx);color:#fff;font-size:12px;font-weight:800}
.ob-sp{flex:1}
.ob-sync{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--amber-tx);padding:5px 10px;border-radius:8px;border:1px solid color-mix(in srgb,var(--amber) 38%,transparent);background:var(--card);transition:.15s}
.ob-sync:hover{background:var(--card-2)} .ob-sync .ic{color:inherit}
.open-board.collapsed .ob-cards{display:none}
.ob-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:11px;padding:14px 15px}   /* GRID (nem flex): minden kártya EGYENLŐ oszlopszélesség → a sorok pontosan illeszkednek (a régi flex-grow+max-width a tele sorban szűkebbre húzta a kártyákat, mint a fél-sorban → szétcsúszott) */
.ob-card{display:flex;flex-direction:column;gap:3px;background:var(--card-2);border:1px solid var(--line);border-left:4px solid var(--faint);border-radius:var(--r);padding:12px 13px;transition:.15s}
.ob-card:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.ob-card.age-green{border-left-color:var(--green)} .ob-card.age-amber{border-left-color:var(--amber)} .ob-card.age-red{border-left-color:var(--red)}
.obc-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.obc-age{font-size:11px;color:var(--muted);font-weight:600;white-space:nowrap}
.obc-prod{font-weight:800;font-size:14.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.obc-sub{font-size:11.8px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.obc-net{font-size:18px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--ink);margin-top:2px}
.obc-miss{font-size:11.6px;font-weight:700;color:var(--amber-tx)}
.obc-btns{display:flex;gap:6px;margin-top:auto;padding-top:9px}   /* margin-top:auto = a gomb a kártya ALJÁRA (egyenlő-magas grid-kártyáknál a Befejez gombok egy vonalban) */
.obc-btns .btn.green{flex:1 1 auto;justify-content:center} .obc-btns .btn.ghost{flex:0 0 auto}
/* ⚡ Gyors mérés gomb + modal */
.btn.quick-btn{background:var(--amber-tx);box-shadow:0 2px 8px rgba(180,83,9,.3)} .btn.quick-btn:hover{background:#92400e}
.qc-types{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:13px}
.qc-type{display:flex;align-items:center;gap:9px;padding:10px 12px;border:1px solid var(--line-2);border-radius:11px;background:var(--card-2);text-align:left;transition:.15s}
.qc-type:hover{border-color:var(--accent)}
.qc-type.active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 2px 8px rgba(37,99,235,.2)}
.qc-type .qct-l{font-weight:700;font-size:13px;color:var(--ink)}
.qc-hint{font-size:12.2px;margin-bottom:11px;padding:8px 11px;background:var(--card-2);border-radius:9px;border:1px solid var(--line)}
.qc-hint:empty{display:none}
.ff input.auto-net{background:var(--accent-soft);color:var(--accent);font-weight:800;border-color:transparent}

/* ===================== MODAL ===================== */
.overlay{position:fixed;inset:0;background:rgba(8,18,36,.55);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:0 14px;overflow-y:auto;backdrop-filter:blur(3px);animation:fade .18s ease}   /* NINCS függőleges padding → a sticky modal-fejléc/lábléc a viewport TETEJÉHEZ/ALJÁHOZ tapad (a 34px rés a .modal margin-jában van, ami elgörög); különben a padding-sávban átlátszott a görgő adat */
.modal{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-3);width:100%;max-width:780px;margin:34px auto;animation:pop .22s cubic-bezier(.34,1.4,.5,1);border:1px solid var(--line)}   /* a 34px függőleges rés MARGIN (nem overlay-padding) → elgörög, a sticky sávok flush-ra tapadnak */
.modal.wide{max-width:1080px}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.modal-h{display:flex;align-items:center;gap:12px;padding:16px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card);border-radius:var(--r-lg) var(--r-lg) 0 0;z-index:3}   /* TELJESEN ÁTLÁTSZATLAN (a régi 92%+blur átengedte a görgő tartalmat → a pillek „átsütöttek" a fejlécen) */
.modal-h h3{margin:0;font-size:17px;font-weight:800;letter-spacing:.1px;line-height:1.2}
.mh-tt{flex:0 1 auto;min-width:0}   /* NE nőjön ki (régen flex:1 → a badge ~600px-rel a cím mögé csúszott a széles ablakban); a badge közvetlenül a cím mellé kerül, az X-et a .x margin-left:auto tolja jobbra */
.mh-sub{font-size:12.5px;color:var(--muted);font-weight:500;margin-top:3px}
.mh-badge{flex:0 0 auto}
.modal-h .x{flex:0 0 auto;margin-left:auto;color:var(--muted);width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.modal-h .x:hover{background:var(--line);color:var(--ink)}
.modal-b{padding:20px 22px}
.modal-f{padding:14px 22px;border-top:1px solid var(--line);display:flex;gap:10px;align-items:center;justify-content:space-between;position:sticky;bottom:0;background:var(--card);border-radius:0 0 var(--r-lg) var(--r-lg);z-index:3}   /* TELJESEN ÁTLÁTSZATLAN (a régi 94%+blur átengedte a Megjegyzést a lábléc mögött) */
.mf-hint{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px}
.mf-btns{display:flex;gap:10px;flex:0 0 auto}
/* szekciók az űrlapban */
.form-sec{margin-bottom:20px}
.form-sec:last-child{margin-bottom:0}
.form-sec-h{display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.form-sec-h .ic{width:15px;height:15px;color:var(--accent)}
/* egységes mérlegelés-űrlap: típus-pillek (széles ablakban 3 oszlop) + mező-súgók */
@media(min-width:641px){.modal.wide .qc-types{grid-template-columns:repeat(3,1fr)}}
.ff-hint{font-size:11.5px;color:var(--muted);line-height:1.35;margin-top:1px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 16px}
.modal.wide .form-grid{grid-template-columns:repeat(3,1fr)}   /* széles űrlap (mozgás/labor) → 3 oszlop, kevesebb görgetés */
.form-grid .full{grid-column:1/-1}
.ff{display:flex;flex-direction:column;gap:5px}
.ff label{font-size:12px;color:var(--muted);font-weight:700}
.ff label .req{color:var(--red);font-weight:800;margin-left:1px}
.ff input,.ff select,.ff textarea{padding:10px 12px;border:1px solid var(--line-2);border-radius:9px;font-size:14px;width:100%;background:var(--card);color:var(--ink);transition:border-color .14s,box-shadow .14s}
.ff input:focus,.ff select:focus,.ff textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.ff input[readonly]{background:var(--accent-soft);color:var(--accent);font-weight:800;border-color:transparent}
.ff.calc input{font-size:17px;font-weight:800;text-align:right;letter-spacing:-.2px;background:var(--accent-soft);color:var(--accent);border:1px dashed color-mix(in srgb,var(--accent) 38%,transparent)}
/* kereshető legördülő (combo) — MINDIG mutatja az összes opciót + saját érték is beírható */
.combo{position:relative;width:100%}
.combo-inp{padding-right:34px!important}
.combo-arrow{position:absolute;right:6px;top:6px;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px;background:transparent}
.combo.open .combo-arrow,.combo-arrow:hover{background:var(--accent-soft);color:var(--accent)}
.combo-pop{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:50;min-width:210px;max-width:calc(100vw - 24px);max-height:300px;background:var(--card);border:1px solid var(--line-2);border-radius:10px;box-shadow:var(--sh-2);padding:5px;display:flex;flex-direction:column}   /* min-width: keskeny oszlopban (pl. Leltár-rács) is olvasható maradjon a terméknév-lista */
.combo-search{flex:0 0 auto;margin:0 0 5px;padding:8px 10px;border:1px solid var(--line-2);border-radius:7px;font-size:13.5px;background:var(--card-2);color:var(--ink);width:100%}
.combo-search:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.combo-list{overflow-y:auto;flex:1 1 auto;min-height:0;max-height:250px}   /* max-height KÖZVETLENÜL a listán: a popupot a JS display:block-ra váltja (felülírja a CSS flexet), így a flex-alapú görgetés NEM él → a lista magától kapja a görgetést a 250px cap-pel */
.combo-it{padding:8px 11px;border-radius:7px;font-size:14px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.combo-it:hover,.combo-it.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.combo-empty{padding:9px 11px;font-size:12.5px;color:var(--muted)}
.combo.strict.unlisted .combo-inp{border-color:var(--amber)!important;background:var(--amber-bg)}   /* strict mező: a jelenlegi érték nincs a listában (régi/beceneves rekord) → sárga jelzés, cseréld listásra */
/* Leltár szerkeszthető rács */
.lt-in{width:100%;padding:6px 8px;border:1px solid var(--line-2);border-radius:7px;font-size:13px;background:var(--card);color:var(--ink)}
.lt-in:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.lt-in:disabled{background:var(--card-2);color:var(--muted)}
.lt-num{text-align:right;font-variant-numeric:tabular-nums}
.lt-diff{text-align:right;white-space:nowrap}
.lt-period{padding:7px 10px;border:1px solid var(--line-2);border-radius:9px;font-size:13px;background:var(--card);color:var(--ink)}
.lt-plab{font-size:12px;color:var(--muted);font-weight:600}
/* Leltár rács: a kereshető legördülő (combo) a cellában töltse ki a szélességet és nézzen ki .lt-in-mezőnek — különben a nyíl elszakad az inputtól (kép1) */
.lt-wrap .combo{width:100%}
.lt-wrap .combo-inp{width:100%;padding:6px 8px;border:1px solid var(--line-2);border-radius:7px;font-size:13px;background:var(--card);color:var(--ink)}
.lt-wrap .combo-inp:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.lt-wrap .combo-arrow{top:5px;right:5px;width:22px;height:22px}
.ff.checkbox{flex-direction:row;align-items:center;gap:11px;background:var(--card-2);border:1px solid var(--line);border-radius:10px;padding:10px 13px;cursor:pointer;transition:border-color .15s,background .15s}
.ff.checkbox:hover{border-color:var(--line-2)}
.ff.checkbox:has(input:checked){border-color:color-mix(in srgb,var(--accent) 45%,transparent);background:var(--accent-soft)}
.ff.checkbox input{appearance:none;-webkit-appearance:none;position:relative;width:40px;height:23px;border-radius:999px;background:var(--line-2);flex:0 0 auto;cursor:pointer;transition:background .18s;margin:0}
.ff.checkbox input::after{content:"";position:absolute;top:2.5px;left:2.5px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3);transition:transform .18s}
.ff.checkbox input:checked{background:var(--accent)}
.ff.checkbox input:checked::after{transform:translateX(17px)}
.ff.checkbox label{font-size:13.5px;color:var(--ink);font-weight:600;cursor:pointer;flex:1}
.ff.sub{position:relative;border-left:2px solid color-mix(in srgb,var(--accent) 35%,transparent);padding-left:12px;margin-left:2px}   /* feltételes al-mező (a fölötte lévő kapcsolóhoz tartozik) */
/* ===== jogosultság-mátrix (oldal × művelet) ===== */
.pgmtx-legend{display:flex;gap:8px 16px;flex-wrap:wrap;font-size:12px;color:var(--muted);margin:2px 0 10px;align-items:center}
.pgmtx-legend .lg{display:inline-flex;align-items:center;gap:5px}
.pgmtx-legend .dot{width:11px;height:11px;border-radius:4px;flex:0 0 auto;border:1px solid var(--line-2)}
.pgmtx-wrap{border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.pgmtx{width:100%;border-collapse:collapse;font-size:12.5px}
.pgmtx th,.pgmtx td{padding:8px 10px;text-align:center;border-bottom:1px solid var(--line)}
.pgmtx thead th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:800;background:var(--card-2);border-bottom:2px solid var(--line-2);position:sticky;top:0;z-index:2}
.pgmtx thead th .ah{display:block;font-size:9.5px;font-weight:600;color:var(--faint);text-transform:none;letter-spacing:0;margin-top:1px}
.pgmtx th.pg-name,.pgmtx td.pg-name{text-align:left;font-weight:700;color:var(--ink);white-space:nowrap;min-width:150px}
.pgmtx tr.pg-grp td{text-align:left;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--brand-2);background:var(--accent-soft);padding:6px 12px}
.pgmtx tr.pg-grp td .gh{font-weight:600;text-transform:none;letter-spacing:0;color:var(--muted);margin-left:8px}
.pgmtx tr.pg-row:hover td{background:var(--card-2)}
.pgmtx tr.pg-subrow td{border-bottom:1px dashed var(--line)}
.pgmtx tr.pg-subrow td.pg-subname{font-weight:600;font-size:12px;color:var(--muted);padding-left:24px}
.pgmtx tr.pg-subrow:hover td{background:var(--card-2)}
.pgmtx td.na{color:var(--faint)}
.pgmtx select.tri{width:118px;max-width:100%;padding:6px 8px;border-radius:8px;font-size:12px;font-weight:700;border:1px solid var(--line-2);background:var(--card);color:var(--ink);cursor:pointer;transition:.14s}
.pgmtx select.tri:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.pgmtx select.tri.is-yes{color:var(--green-tx);border-color:color-mix(in srgb,var(--green) 50%,transparent);background:var(--green-bg)}
.pgmtx select.tri.is-no{color:var(--red-tx);border-color:color-mix(in srgb,var(--red) 50%,transparent);background:var(--red-bg)}
.pgmtx select.tri.is-inherit{color:var(--muted);background:var(--card)}
.pgmtx .pgcb{appearance:none;-webkit-appearance:none;width:22px;height:22px;border:1.6px solid var(--line-2);border-radius:6px;cursor:pointer;position:relative;vertical-align:middle;transition:.14s;background:var(--card);margin:0}
.pgmtx .pgcb:hover{border-color:var(--accent)}
.pgmtx .pgcb:checked{background:var(--accent);border-color:var(--accent)}
.pgmtx .pgcb:checked::after{content:"";position:absolute;left:6.5px;top:2.5px;width:5px;height:10px;border:solid #fff;border-width:0 2.6px 2.6px 0;transform:rotate(45deg)}
.pgmtx .rowtog{font-size:10.5px;font-weight:700;color:var(--muted);background:none;padding:2px 6px;border-radius:6px}
.pgmtx .rowtog:hover{color:var(--accent);background:var(--accent-soft)}
.lab-verdict{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;padding:12px;background:var(--card-2);border-radius:var(--r);border:1px solid var(--line)}

/* ===================== TOAST ===================== */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:2000;display:flex;flex-direction:column;gap:9px;align-items:center}
.toast{display:flex;align-items:center;gap:9px;background:var(--ink);color:#fff;padding:12px 20px;border-radius:12px;font-size:13.5px;font-weight:600;box-shadow:var(--sh-3);opacity:0;transform:translateY(12px);transition:.26s}
.toast.show{opacity:1;transform:none}
.toast.ok{background:#16a34a} .toast.err{background:#dc2626} .toast.warn{background:#d97706}

/* ===================== ADMIN ===================== */
.adm-groups{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:12px;margin-bottom:18px}
.adm-grp{display:flex;flex-direction:column;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:13px 15px;box-shadow:var(--sh-1)}
.adm-grp-lab{font-size:11px;font-weight:800;color:var(--brand-2);text-transform:uppercase;letter-spacing:.06em;display:flex;flex-direction:column;gap:2px}
.adm-grp-hint{font-weight:600;text-transform:none;letter-spacing:0;color:var(--faint);font-size:11px}
.adm-cats{display:flex;flex-wrap:wrap;gap:7px}
.adm-cat{display:inline-flex;align-items:center;gap:7px;background:var(--card-2);border:1px solid var(--line);padding:6px 11px;border-radius:9px;font-size:12.6px;font-weight:600;color:var(--ink-2);transition:.15s}
.adm-cat .cnt{font-size:11px;font-weight:700;color:var(--faint);background:var(--card);border:1px solid var(--line);border-radius:999px;padding:0 6px;min-width:18px;text-align:center}
.adm-cat:hover{border-color:var(--accent);color:var(--accent);background:var(--card)}
.adm-cat.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 3px 9px rgba(37,99,235,.28)}
.adm-cat.active .cnt{color:#fff;background:rgba(255,255,255,.18);border-color:transparent}
.adm-cat.rel{border-style:dashed}                 /* reláció-térkép (auto-kitöltés) — szaggatott szegély */
.adm-cat.rel.active{border-style:solid}
.lock{max-width:400px;margin:50px auto;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:38px;box-shadow:var(--sh-2)}
.lock .big{width:64px;height:64px;margin:0 auto 14px;border-radius:18px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.lock .big .ic{width:30px;height:30px}

/* ===================== RESPONSIVE ===================== */
.scrim{display:none;position:fixed;inset:0;background:rgba(8,18,36,.5);z-index:55;backdrop-filter:blur(2px)}
@media(max-width:1600px){   /* a fejléc-hónapválasztó miatt korábban kapcsoljon kompakt módba, hogy a 6 menüpont kiférjen (ne csússzon össze) */
  .brand .b2{display:none}
  .topbar .tb-btn .lbl{display:none}
  .topbar .tb-btn{padding:8px 10px}
  .user-chip #headerMeta{display:none}
  .user-chip{padding:4px}
  .gmonth{max-width:120px}
}
@media(max-width:980px){
  .hamb{display:inline-flex}
  .side-collapse{display:none}                                   /* mobilon a hamburger visz — nincs rail */
  .sidebar{transform:translateX(-100%);box-shadow:var(--sh-3)}   /* becsúszó drawer */
  .sidebar.open{transform:none}
  .main{margin-left:0}
  body.sb-collapsed .sidebar{width:var(--side-w);transform:translateX(-100%)}   /* mobilon mindig TELJES (a rail kikapcsol) */
  body.sb-collapsed .sidebar.open{transform:none}
  body.sb-collapsed .main{margin-left:0}
  body.sb-collapsed .side-logo{flex-direction:row;gap:11px;padding:18px 16px 14px}
  body.sb-collapsed .side-logo .tt-wrap{display:flex}
  body.sb-collapsed .side-nav{padding:8px 12px}
  body.sb-collapsed .side-nav button{justify-content:flex-start;padding:11px 13px;gap:12px}
  body.sb-collapsed .side-nav button span:not(.nav-badge){display:inline}
  body.sb-collapsed .side-nav button .nav-badge{position:static;margin-left:auto}
  body.sb-collapsed .side-sec{font-size:10.5px;padding:14px 12px 5px;text-align:left}
  body.sb-collapsed .side-sec::after{content:none}
  .scrim.show{display:block}
  .grid2,.grid2.even{grid-template-columns:1fr}
  .content{padding:16px}
  .user-chip{border:none;padding:0}
  .user-chip #headerMeta{display:none}
}
@media(max-width:900px){
  .modal.wide .form-grid{grid-template-columns:1fr 1fr}   /* széles űrlap szűkebb képernyőn → 2 oszlop */
}
@media(max-width:640px){
  .topbar{padding:11px 14px}
  .page-title{font-size:16px} .page-sub{display:none}
  .content{padding:13px 11px 60px}
  .kpis{grid-template-columns:repeat(2,1fr);gap:10px}
  .kpi{padding:13px} .kpi .k-val{font-size:20px} .kpi .k-ic{width:30px;height:30px}
  .filters{flex-wrap:wrap}
  .fld{flex:1 1 calc(50% - 6px)} .fld input,.fld select{min-width:0;width:100%}
  .form-grid,.modal.wide .form-grid{grid-template-columns:1fr}
  .modal-h,.modal-b,.modal-f{padding-left:16px;padding-right:16px}
  .mf-hint{display:none}
  th,td{padding:8px 9px;font-size:12px}
  .tb-btn span.lbl{display:none}
  .chart-box{height:240px}
  .ob-cards{grid-template-columns:1fr}        /* nyitott-kártyák 1 oszlop mobilon (teljes szélesség, nincs ellipsis-vágás) */
  .qc-types{grid-template-columns:1fr}           /* gyors-mérés típusgombok 1 oszlop mobilon */
  .icon-btn{width:38px;height:38px}              /* nagyobb érintő-célméret mobilon */
}

/* ════════ TÁPTERV-MODUL CSS (Tápelőrejelzés natív beépítés — scope-olva) ════════ */
:root{ --st-elo:#64748b; --st-elo-bg:#eef2f8; --st-rend:#ea580c; --st-rend-bg:#fff1e6; --st-kev:#7c3aed; --st-kev-bg:#f3e8ff; --st-kesz:#2563eb; --st-kesz-bg:#dbeafe; --st-kisz:#16a34a; --st-kisz-bg:#dcfce7; }
html[data-theme="dark"]{ --st-elo:#94a3b8; --st-elo-bg:#18222f; --st-rend:#fb923c; --st-rend-bg:#2a1a0c; --st-kev:#c084fc; --st-kev-bg:#241640; --st-kesz:#60a5fa; --st-kesz-bg:#12203f; --st-kisz:#4ade80; --st-kisz-bg:#0d2a1b; }
.tap-fc,.tap-board{width:100%;}
html[data-theme="dark"] .tap-fc{
  --bg:#0a1120; --card:#111c30; --card-2:#0e1828;
  --ink:#e8eef7; --ink-2:#c4d0e0; --muted:#90a2bb; --faint:#64748b;
  --line:#1d2c44; --line-2:#26395a; --accent-soft:#1b2550;
  
  --accent:#3b82f6; --accent-2:#1e3a8a;
  --green:#4ade80; --amber:#fbbf24; --red:#f87171; --blue:#60a5fa; --purple:#c084fc;
  --f1:#38bdf8; --f2:#4ade80; --f3:#fbbf24; --f4:#a78bfa;
  --green-bg:#0d2a1b; --amber-bg:#2c220c; --red-bg:#2c1416; --blue-bg:#12203f; --purple-bg:#241640;
  --f1-bg:#0c2c3f; --f2-bg:#0d2a1b; --f3-bg:#2c220c; --f4-bg:#241640;
  --sh-1:0 1px 2px rgba(0,0,0,.4); --sh-2:0 6px 20px rgba(0,0,0,.45); --sh-3:0 22px 60px rgba(0,0,0,.6);
}
html[data-theme="dark"] .tap-fc .pill.f1{color:#7dd3fc}
html[data-theme="dark"] .tap-fc .pill.f2{color:#86efac}
html[data-theme="dark"] .tap-fc .pill.f3{color:#fcd34d}
html[data-theme="dark"] .tap-fc .pill.f4{color:#c4b5fd}
.tap-fc :focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
.tap-fc button:focus-visible,.tap-fc select:focus-visible,.tap-fc input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.tap-fc button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.tap-fc input,.tap-fc select{font-family:inherit}
.tap-fc a{color:var(--accent)}
.tap-fc .ic{width:18px;height:18px;flex:0 0 auto;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:-3px}
.tap-fc .ic.sm{width:15px;height:15px}
.tap-fc .ic.lg{width:22px;height:22px}
.tap-fc .tnum{font-variant-numeric:tabular-nums}
.tap-fc .seg{display:flex;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:11px;padding:3px;gap:2px}
.tap-fc .seg button{padding:7px 13px;border-radius:8px;font-size:12.8px;font-weight:700;color:#c9d8ee;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:.15s}
.tap-fc .seg button .ic{color:#9db6d6}
.tap-fc .seg button.active{background:#fff;color:#1e3a8a}
.tap-fc .seg button.active .ic{color:#1e3a8a}
.tap-fc .tb-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:#cfe0f5;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);transition:.15s}
.tap-fc .tb-icon:hover{background:rgba(255,255,255,.18);color:#fff}
.tap-fc .layout{display:grid;grid-template-columns:370px 1fr;gap:18px;align-items:start}
.tap-fc .col-stack{display:flex;flex-direction:column;gap:16px}
.tap-fc .input-col{position:sticky;top:84px}
.tap-fc .panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.tap-fc .panel-h{display:flex;align-items:center;gap:10px;padding:14px 17px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tap-fc .panel-h h2{margin:0;font-size:14.5px;font-weight:800;letter-spacing:.2px;display:flex;align-items:center;gap:9px}
.tap-fc .panel-h h2 .ic{color:var(--accent)}
.tap-fc .panel-h .sp{flex:1}
.tap-fc .panel-h .hint{font-size:11.5px;color:var(--muted);font-weight:600}
.tap-fc .panel-b{padding:16px 17px}
.tap-fc .fld{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.tap-fc .fld label{font-size:11.5px;color:var(--muted);font-weight:700;letter-spacing:.3px}
.tap-fc .fld input,.tap-fc .fld select{padding:10px 11px;border:1px solid var(--line-2);border-radius:10px;font-size:14px;background:var(--card);color:var(--ink);width:100%}
.tap-fc .fld input:focus,.tap-fc .fld select:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.tap-fc .fld .row{display:flex;gap:10px}
.tap-fc .fld .row>*{flex:1}
.tap-fc .checkrow{display:flex;align-items:center;gap:9px;padding:10px 12px;background:var(--card-2);border:1px solid var(--line);border-radius:10px;margin-bottom:11px;cursor:pointer;user-select:none}
.tap-fc .checkrow input{width:17px;height:17px;accent-color:var(--accent);cursor:pointer;flex:0 0 auto}
.tap-fc .checkrow .t{font-size:13px;font-weight:600;color:var(--ink-2)}
.tap-fc .checkrow .s{font-size:11px;color:var(--muted)}
.tap-fc .seg-mini{display:inline-flex;flex-wrap:nowrap;gap:3px;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:4px;width:max-content;max-width:100%;overflow-x:auto;scrollbar-width:thin}   /* EGYSÉGES szegmens-track (mint az alfül-sáv .seg) */
.tap-fc .seg-mini button{flex:0 0 auto;min-width:auto;padding:7px 13px;border:1px solid transparent;border-radius:999px;font-size:12.6px;font-weight:600;color:var(--ink-2);background:transparent;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:.14s}
.tap-fc .seg-mini button:hover{background:var(--card);border-color:transparent;color:var(--ink)}
.tap-fc .seg-mini button.active{background:var(--card);color:var(--accent);border-color:transparent;box-shadow:0 1px 3px rgba(15,23,42,.14)}
.tap-fc .seg-mini button .ic{color:currentColor}
.tap-fc .seg-mini::-webkit-scrollbar{height:6px}.tap-fc .seg-mini::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px}
.tap-fc .ctrlbar{display:flex;align-items:center;gap:7px 13px;flex-wrap:wrap;margin-bottom:16px}
.tap-fc .ctrlbar .seg-lab{font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.tap-fc .chk-inline{display:inline-flex;align-items:center;gap:8px;font-size:12.6px;font-weight:600;color:var(--ink-2);cursor:pointer;background:var(--card);border:1px solid var(--line-2);border-radius:10px;padding:7px 12px;user-select:none}
.tap-fc .chk-inline input{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}
.tap-fc [hidden]{display:none!important}
.tap-fc .batch-layout{display:grid;grid-template-columns:minmax(330px,400px) 1fr;gap:18px;align-items:start}
.tap-fc .batch-row-edit{outline:2px solid var(--accent);outline-offset:1px}
@media(max-width:820px){.tap-fc .batch-layout{grid-template-columns:1fr}}
.tap-fc .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;padding:11px 16px;border-radius:11px;font-size:14px;font-weight:700;width:100%;transition:.15s;box-shadow:0 2px 8px rgba(37,99,235,.28)}
.tap-fc .btn:hover{background:var(--accent-2);transform:translateY(-1px);box-shadow:0 6px 16px rgba(37,99,235,.36)}
.tap-fc .btn.ghost{background:var(--card);color:var(--ink-2);border:1px solid var(--line-2);box-shadow:none}
.tap-fc .btn.ghost:hover{border-color:var(--accent);color:var(--accent);transform:none}
.tap-fc .btn.sm{padding:7px 12px;font-size:12.5px;width:auto}
.tap-fc .profile-note{font-size:11.5px;color:var(--muted);background:var(--accent-soft);border:1px solid var(--line);border-radius:10px;padding:9px 11px;margin-top:4px;line-height:1.5}
.tap-fc .profile-note b{color:var(--accent)}
.tap-fc .batch{display:flex;align-items:center;gap:11px;padding:11px 13px;border:1px solid var(--line);border-radius:12px;background:var(--card-2);margin-bottom:9px;transition:.15s}
.tap-fc .batch:hover{border-color:var(--line-2);box-shadow:var(--sh-1)}
.tap-fc .batch .dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.tap-fc .batch .bm{flex:1;min-width:0}
.tap-fc .batch .bm .n{font-weight:700;font-size:13.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tap-fc .batch .bm .d{font-size:11.5px;color:var(--muted);margin-top:1px}
.tap-fc .batch .tag{font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:999px;background:var(--amber-bg);color:var(--amber-tx);flex:0 0 auto}
.tap-fc .batch .x{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--faint);flex:0 0 auto}
.tap-fc .batch .x:hover{background:var(--red-bg);color:var(--red)}
.tap-fc .batch.batch-expired{opacity:.62;background:transparent;border-style:dashed}   /* Lezárt turnus (>50 nap): halványabb, nem aktív (user 2026-06-29) */
.tap-fc .batch .tag.tag-exp{background:var(--line);color:var(--muted)}
.tap-fc .batch-sep{margin:14px 0 8px;font-size:11.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-top:1px dashed var(--line-2);padding-top:11px}
.tap-fc .batch-sep .batch-sep-note{font-weight:600;text-transform:none;letter-spacing:0;color:var(--faint)}
.tap-fc .batch-sep-toggle{cursor:pointer;user-select:none;-webkit-user-select:none;border-radius:8px;padding:9px 8px 8px;margin:14px -8px 8px}   /* összecsukható Lezárt turnus fejléc (user 2026-06-29) */
.tap-fc .batch-sep-toggle:hover{background:var(--card-2);color:var(--ink)}
.tap-fc .batch-sep-toggle .exp-chev{display:inline-block;width:12px;color:var(--accent);font-weight:900}
.tap-fc .empty{text-align:center;color:var(--muted);font-size:13px;padding:26px 14px}
.tap-fc .empty .ic{width:34px;height:34px;color:var(--faint);margin-bottom:8px}
.tap-fc .kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:13px}
.tap-fc .kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px;box-shadow:var(--sh-1);position:relative;overflow:hidden}
.tap-fc .kpi .k-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.tap-fc .kpi .k-label{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.tap-fc .kpi .k-ic{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);color:var(--accent)}
.tap-fc .kpi .k-val{font-size:24px;font-weight:800;margin-top:8px;letter-spacing:-.5px}
.tap-fc .kpi .k-sub{font-size:11.5px;color:var(--muted);margin-top:2px}
.tap-fc .kpi.green .k-ic{background:var(--green-bg);color:var(--green-tx)}
.tap-fc .kpi.green .k-val{color:var(--green-tx)}
.tap-fc .kpi.amber .k-ic{background:var(--amber-bg);color:var(--amber-tx)}
.tap-fc .kpi.amber .k-val{color:var(--amber-tx)}
.tap-fc .kpi.purple .k-ic{background:var(--purple-bg);color:var(--purple)}
.tap-fc .legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center;font-size:11.5px;color:var(--muted);font-weight:600}
.tap-fc .legend .lg{display:inline-flex;align-items:center;gap:5px}
.tap-fc .legend .sw{width:11px;height:11px;border-radius:3px;flex:0 0 auto}
.tap-fc .cal{overflow-x:auto;padding:4px 2px}
.tap-fc .week{display:grid;grid-template-columns:96px repeat(7,minmax(78px,1fr));gap:6px;margin-bottom:6px;min-width:680px}
.tap-fc .week.head .cell{background:transparent;border:none;box-shadow:none;font-size:11px;color:var(--muted);font-weight:700;text-align:center;padding:4px 0;min-height:0}
.tap-fc .week.head .wk{text-align:left}
.tap-fc .cell{background:var(--card-2);border:1px solid var(--line);border-radius:10px;min-height:62px;padding:18px 6px 6px;position:relative;display:flex;flex-direction:column;gap:4px}
.tap-fc .cell.wk{background:transparent;border:none;display:flex;flex-direction:column;justify-content:center;padding:5px 8px}
.tap-fc .cell.wk .wkn{font-size:12px;font-weight:800;color:var(--ink-2)}
.tap-fc .cell.wk .wkd{font-size:10.5px;color:var(--muted)}
.tap-fc .cell.busy{background:var(--amber-bg);border-color:#f0d089}
.tap-fc .cell.weekend{background:repeating-linear-gradient(45deg,var(--card-2),var(--card-2) 6px,var(--bg) 6px,var(--bg) 12px);opacity:.85}
.tap-fc .cell .dn{position:absolute;top:3px;right:6px;font-size:10px;color:var(--faint);font-weight:700}
.tap-fc .cell.today{outline:2px solid var(--accent);outline-offset:-2px}
.tap-fc .pill{display:block;border-radius:7px;padding:3px 6px;margin-top:0;font-size:11px;font-weight:700;line-height:1.25;cursor:default;border-left:3px solid}
.tap-fc .pill+.pill{margin-top:0}
.tap-fc .pill .pt{font-size:10px;font-weight:600;opacity:.85}
.tap-fc .pill.f1{background:var(--f1-bg);color:#0369a1;border-color:var(--f1)}
.tap-fc .pill.f2{background:var(--f2-bg);color:#15803d;border-color:var(--f2)}
.tap-fc .pill.f3{background:var(--f3-bg);color:#b45309;border-color:var(--f3)}
.tap-fc .pill.f4{background:var(--f4-bg);color:#6d28d9;border-color:var(--f4)}
.tap-fc .daytot{margin-top:auto;padding-top:4px;font-size:10px;font-weight:800;color:var(--ink-2);opacity:.7}
.tap-fc .tbl{width:100%;border-collapse:collapse;font-size:13px}
.tap-fc .tbl th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:700;padding:9px 10px;border-bottom:2px solid var(--line);position:sticky;top:0;background:var(--card)}
.tap-fc .tbl td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.tap-fc .tbl tr:hover td{background:var(--card-2)}
.tap-fc .tbl .num{text-align:right;font-variant-numeric:tabular-nums}
.tap-fc .tbl .grp td{background:var(--card-2);font-weight:800;color:var(--ink);font-size:13px}
.tap-fc .fz{display:inline-flex;align-items:center;gap:6px;font-weight:700}
.tap-fc .fz .sw{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.tap-fc .daychip{display:inline-block;padding:1px 7px;border-radius:999px;font-size:11px;font-weight:700}
.tap-fc .daychip.busy{background:var(--amber-bg);color:var(--amber-tx)}
.tap-fc .daychip.ok{background:var(--green-bg);color:var(--green-tx)}
.tap-fc .daychip.we{background:var(--blue-bg);color:var(--blue)}
.tap-fc .foot{margin-top:18px;font-size:11.5px;color:var(--muted);line-height:1.6}
.tap-fc .dq{display:flex;gap:9px;align-items:flex-start;padding:11px 13px;border:1px solid var(--line);border-radius:11px;background:var(--card);margin-bottom:8px}
.tap-fc .dq .ic{color:var(--amber);flex:0 0 auto;margin-top:1px}
.tap-fc .dq.ok .ic{color:var(--green)}
.tap-fc .dq b{color:var(--ink-2)}
.tap-fc .banner{display:flex;gap:10px;align-items:flex-start;background:var(--accent-soft);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:16px;font-size:12.5px;color:var(--ink-2);line-height:1.5}
.tap-fc .banner .ic{color:var(--accent);flex:0 0 auto;margin-top:1px}
@media(max-width:980px){.tap-fc .layout{grid-template-columns:1fr}
.tap-fc .input-col{position:static}}
@media(max-width:640px){.tap-fc .seg button{padding:6px 10px;font-size:12px}
.tap-fc .panel-b{padding:13px}
.tap-fc .kpis{grid-template-columns:repeat(2,1fr);gap:9px}
.tap-fc .kpi .k-val{font-size:20px}
.tap-fc .week{grid-template-columns:70px repeat(7,minmax(64px,1fr));min-width:560px}}
html[data-theme="dark"] .tap-board{
  --bg:#0a1120; --card:#111c30; --card-2:#0e1828;
  --ink:#e8eef7; --ink-2:#c4d0e0; --muted:#90a2bb; --faint:#64748b;
  --line:#1d2c44; --line-2:#26395a; --accent-soft:#16224a;
  --accent:#3b82f6; --accent-2:#1e3a8a;
  --green:#4ade80; --amber:#fbbf24; --red:#f87171; --blue:#60a5fa; --purple:#c084fc;
  --st-elo:#94a3b8;   --st-elo-bg:#18222f;
  --st-rend:#fb923c;  --st-rend-bg:#2a1a0c;
  --st-kev:#c084fc;   --st-kev-bg:#241640;
  --st-kesz:#60a5fa;  --st-kesz-bg:#12203f;
  --st-kisz:#4ade80;  --st-kisz-bg:#0d2a1b;
  --sh-1:0 1px 2px rgba(0,0,0,.35),0 2px 6px rgba(0,0,0,.30); --sh-2:0 14px 34px -10px rgba(0,0,0,.55),0 4px 12px -4px rgba(0,0,0,.4); --sh-3:0 30px 70px -14px rgba(0,0,0,.7);
}
.tap-board :focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
.tap-board button:focus-visible,.tap-board select:focus-visible,.tap-board input:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.tap-board button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.tap-board input,.tap-board select,.tap-board textarea{font-family:inherit}
.tap-board a{color:var(--accent)}
.tap-board .ic{width:18px;height:18px;flex:0 0 auto;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:-3px}
.tap-board .ic.sm{width:15px;height:15px}
.tap-board .ic.lg{width:22px;height:22px}
.tap-board .tnum{font-variant-numeric:tabular-nums}
.tap-board .seg{display:inline-flex;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:4px;gap:3px}   /* EGYSÉGES szegmens-track (mint az alfül-sáv .seg) */
.tap-board .seg button{padding:7px 13px;border-radius:999px;font-size:12.8px;font-weight:600;color:var(--ink-2);background:transparent;border:1px solid transparent;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;transition:.15s}
.tap-board .seg button .ic{color:currentColor}
.tap-board .seg button:hover{background:var(--card);color:var(--ink)}
.tap-board .seg button.active{background:var(--card);color:var(--accent);box-shadow:0 1px 3px rgba(15,23,42,.14)}
.tap-board .seg button.active .ic{color:var(--accent)}
.tap-board .tb-icon{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:#cfe0f5;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);transition:.15s}
.tap-board .tb-icon:hover{background:rgba(255,255,255,.18);color:#fff}
.tap-board .toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.tap-board .btn{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:11px;font-weight:700;font-size:13px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:var(--sh-1);transition:.15s;border:1px solid transparent}
.tap-board .btn:hover{filter:brightness(1.06);transform:translateY(-1px)}
.tap-board .btn.ghost{background:var(--card);color:var(--ink-2);border:1px solid var(--line-2);box-shadow:none}
.tap-board .btn.ghost:hover{background:var(--card-2);border-color:var(--accent)}
.tap-board .btn.amber{background:linear-gradient(135deg,#f97316,#ea580c)}
.tap-board .wknav{display:flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--line-2);border-radius:11px;padding:3px}
.tap-board .wknav button{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;color:var(--ink-2)}
.tap-board .wknav button:hover{background:var(--accent-soft);color:var(--accent)}
.tap-board .wknav .lbl{padding:0 12px;font-weight:800;font-size:13.5px;white-space:nowrap;min-width:170px;text-align:center}
.tap-board .wknav .today{font-size:12px;font-weight:700;padding:0 11px;color:var(--accent);height:32px;border-radius:8px}
.tap-board .fpick{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line-2);border-radius:11px;padding:6px 11px;font-size:12.6px;color:var(--ink-2);font-weight:600}
.tap-board .fpick select{border:none;background:none;color:var(--ink);font-weight:700;font-size:12.6px;outline:none}
.tap-board .legend{display:flex;gap:13px;flex-wrap:wrap;align-items:center;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:12px}
.tap-board .legend .lg{display:inline-flex;align-items:center;gap:6px}
.tap-board .legend .dot{width:11px;height:11px;border-radius:4px;flex:0 0 auto}
.tap-board .cal{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.tap-board .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);min-height:560px}
.tap-board .cal-col{border-right:1px solid var(--line);display:flex;flex-direction:column;min-width:0}
.tap-board .cal-col:last-child{border-right:none}
.tap-board .cal-col.weekend{background:var(--card-2)}
.tap-board .cal-col.today{background:linear-gradient(180deg,var(--accent-soft),transparent 120px)}
.tap-board .cal-head{padding:9px 10px 8px;border-bottom:1px solid var(--line);text-align:center;position:sticky;top:0}
.tap-board .cal-head .dn{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.tap-board .cal-head .dd{font-size:19px;font-weight:800;margin-top:1px;line-height:1}
.tap-board .cal-col.today .cal-head .dd{color:var(--accent)}
.tap-board .cal-head .ds{font-size:10.5px;color:var(--faint);margin-top:3px;font-weight:600;height:13px}
.tap-board .cal-body{flex:1;padding:7px 7px 12px;display:flex;flex-direction:column;gap:5px;overflow:visible}
.tap-board .cal-body.dragover{background:var(--accent-soft);outline:2px dashed var(--accent);outline-offset:-4px;border-radius:10px}
.tap-board .cal-add{margin-top:auto;font-size:11.5px;color:var(--faint);font-weight:600;padding:5px;border-radius:8px;border:1px dashed var(--line-2);text-align:center;opacity:0;transition:.15s}
.tap-board .cal-col:hover .cal-add{opacity:1}
.tap-board .cal-add:hover{color:var(--accent);border-color:var(--accent)}
.tap-board .chip{border-radius:8px;padding:6px 8px 7px;border-left:4px solid var(--c);background:var(--cbg);cursor:grab;box-shadow:var(--sh-1);transition:transform .1s,box-shadow .15s;position:relative;user-select:none}
.tap-board .chip:active{cursor:grabbing}
.tap-board .chip:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.tap-board .chip.dragging{opacity:.45}
.tap-board .chip .c-top{display:flex;align-items:baseline;gap:6px;justify-content:space-between}
.tap-board .chip .c-telep{font-weight:800;font-size:12.5px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tap-board .chip .c-q{font-weight:900;font-size:17px;color:var(--c);white-space:nowrap;flex:0 0 auto;letter-spacing:-.4px}
.tap-board .chip .c-sub{font-size:11px;color:var(--ink-2);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tap-board .chip .c-badge{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.3px;text-transform:uppercase;color:var(--c);opacity:.85;margin-top:3px}
.tap-board .chip .c-fc,.tap-board .chip .c-pin{font-size:11px;opacity:.72;flex:0 0 auto;line-height:1}
.tap-board [hidden]{display:none!important}
.tap-board .kanban{display:flex;gap:14px;align-items:flex-start;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x proximity}
.tap-board .kcol{flex:1 1 0;min-width:200px;max-width:400px;scroll-snap-align:start;background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh-1);display:flex;flex-direction:column;min-height:320px;overflow:hidden;transition:box-shadow .16s,transform .12s}
.tap-board .kcol:hover{box-shadow:var(--sh-2)}
.tap-board .kcol-h{padding:13px 15px 12px;background:linear-gradient(180deg,var(--cbg),transparent);border-bottom:1px solid var(--line)}
.tap-board .kcol-h .kc-top{display:flex;align-items:center;gap:9px}
.tap-board .kcol-h .kc-dot{width:10px;height:10px;border-radius:50%;background:var(--c);box-shadow:0 0 0 3px var(--cbg);flex:0 0 auto}
.tap-board .kcol-h .kc-t{font-weight:800;font-size:13.5px;color:var(--ink);letter-spacing:-.2px}
.tap-board .kcol-h .kc-n{margin-left:auto;font-size:11.5px;font-weight:800;color:var(--c);background:var(--card);border-radius:20px;padding:2px 10px;border:1px solid var(--c);min-width:27px;text-align:center}
.tap-board .kcol-h .kc-meta{display:flex;align-items:center;gap:8px;margin-top:7px;min-height:21px}
.tap-board .kcol-h .kc-sum{font-size:11.5px;font-weight:700;color:var(--muted)}
.tap-board .kcol-body{flex:1;padding:11px;display:flex;flex-direction:column;gap:9px;min-height:90px}
.tap-board .kcol-body.dragover{background:var(--accent-soft);outline:2px dashed var(--accent);outline-offset:-5px;border-radius:14px}
.tap-board .kcol .k-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--faint);font-size:12px;text-align:center;padding:24px 8px;font-weight:700;border:1.5px dashed var(--line-2);border-radius:13px;cursor:pointer;transition:.14s;min-height:130px}
.tap-board .kcol .k-empty span{font-size:10.5px;font-weight:600}
.tap-board .kcol .k-empty:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}
.tap-board .kcol-add{font-size:11.5px;color:var(--faint);font-weight:700;padding:8px;border-radius:10px;border:1px dashed transparent;text-align:center;cursor:pointer;transition:.14s}
.tap-board .kcol-body:hover .kcol-add{border-color:var(--line-2)}
.tap-board .kcol-add:hover{color:var(--accent);border-color:var(--accent)!important;background:var(--accent-soft)}
.tap-board .kcol .chip .c-date{font-size:10.5px;color:var(--muted);font-weight:700}
.tap-board .kcol .kc-sub{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:6px 2px 0}
.tap-board .kcol .kc-sub::after{content:"";flex:1;height:1px;background:var(--line)}
.tap-board .kcol .kc-nextwk{display:flex;flex-direction:column;gap:9px;opacity:.6}
.tap-board .kcol .kc-later{font-size:11px;font-weight:800;color:var(--muted);text-align:center;padding:9px 8px;border:1px dashed var(--line-2);border-radius:11px;line-height:1.35}
.tap-board .kcol .kc-later span{display:block;font-size:9.5px;font-weight:600;color:var(--faint);margin-top:2px}
.tap-board .kcol .kc-sub--warn{color:var(--amber-tx)}
.tap-board .kcol .kc-sub--warn::after{background:var(--amber)}
.tap-board .kcol .kc-past{display:flex;flex-direction:column;gap:9px;border:1.5px dashed var(--amber);border-radius:12px;padding:8px;background:linear-gradient(180deg,var(--amber-bg),transparent 70%)}
html[data-theme="dark"] .tap-board .kcol .kc-past{background:none}
.tap-board .kcol .k-empty--ro{cursor:default;border-style:dotted}
.tap-board .kcol .k-empty--ro:hover{border-color:var(--line-2);color:var(--faint);background:none}
.tap-board .overlay{position:fixed;inset:0;background:rgba(8,18,36,.55);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:0 16px;overflow:auto}   /* user 2026-06-29: NINCS függőleges padding → a sticky lábléc a viewport ALJÁHOZ tapad (a rés a .modal margin-ja, ami elgörög) — mint a globális modáloknál */
.tap-board .overlay[hidden]{display:none}
.tap-board .modal{background:var(--card);border-radius:var(--r-lg);box-shadow:var(--sh-3);width:100%;max-width:540px;border:1px solid var(--line);margin:34px auto}   /* a 34px rés MARGIN (nem overlay-padding) → elgörög, a sticky fejléc/lábléc flush-ra tapad a viewport tetejéhez/aljához — user 2026-06-29 */
.tap-board .modal-h{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid var(--line)}
.tap-board .modal-h h2{margin:0;font-size:16px;font-weight:800;display:flex;align-items:center;gap:9px}
.tap-board .modal-h .x{margin-left:auto;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;color:var(--muted)}
.tap-board .modal-h .x:hover{background:var(--card-2);color:var(--ink)}
.tap-board .modal-b{padding:16px 18px;display:flex;flex-direction:column;gap:13px}
.tap-board .modal-f{padding:14px 18px;border-top:1px solid var(--line);display:flex;gap:10px;align-items:center;justify-content:flex-end;flex-wrap:wrap}   /* EGYSÉGES: a gombok jobbra (mint a globális modálok); a fő gomb jobb szélen, Mégse mellette, Törlés balra (margin-right:auto) — user 2026-06-29 */
.modal-f .spacer{flex:1 1 auto}   /* térkitöltő a láblécben (a kézi spacer eddig CSS nélkül semmit sem csinált) */
.tap-board .fld{display:flex;flex-direction:column;gap:5px;min-width:0}
.tap-board .fld label{font-size:11.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.tap-board .fld input,.tap-board .fld select,.tap-board .fld textarea{width:100%;padding:9px 11px;border:1px solid var(--line-2);border-radius:10px;background:var(--card-2);color:var(--ink);font-size:13.5px;font-weight:600;outline:none;transition:.15s}
.tap-board .fld input:focus,.tap-board .fld select:focus,.tap-board .fld textarea:focus{border-color:var(--accent);box-shadow:var(--ring);background:var(--card)}
.tap-board .row2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.tap-board .row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:11px}
.tap-board .pills{display:flex;gap:6px;flex-wrap:wrap}
.tap-board .pills button{padding:7px 12px;border-radius:9px;border:1px solid var(--line-2);background:var(--card-2);font-weight:700;font-size:12.5px;color:var(--ink-2);transition:.12s}
.tap-board .pills button.on{background:var(--cbg,var(--accent-soft));border-color:var(--c,var(--accent));color:var(--c,var(--accent))}
.tap-board .pills.sm button{padding:5px 10px;font-size:11.5px;border-radius:8px}
.tap-board .statpills button{flex:1;min-width:0}
.tap-board .hint{font-size:11.5px;color:var(--muted);line-height:1.5;background:var(--accent-soft);border:1px solid var(--line);border-radius:10px;padding:9px 11px}
.tap-board .auto-or{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:12px 0 8px;display:flex;align-items:center;gap:9px}
.tap-board .auto-or::after{content:"";flex:1;height:1px;background:var(--line)}
.tap-board .ffb{display:flex;align-items:center;gap:10px;padding:9px 11px;border:1px solid var(--line-2);border-radius:10px;background:var(--card-2);margin-bottom:7px}
.tap-board .ffb .n{font-weight:800;font-size:13px;color:var(--ink)}
.tap-board .ffb .d{font-size:11.5px;color:var(--muted);margin-top:1px}
.tap-board .ffb .badd{margin-left:auto;flex:0 0 auto;padding:6px 12px;border-radius:9px;font-weight:700;font-size:12px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--line-2);white-space:nowrap}
.tap-board .ffb .badd:hover{background:var(--card);border-color:var(--accent)}
.tap-board .drawer{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:92vw;background:var(--card);border-left:1px solid var(--line);box-shadow:var(--sh-3);z-index:90;display:flex;flex-direction:column;transform:translateX(102%);transition:transform .25s}
.tap-board .drawer.open{transform:none}
.tap-board .drawer-h{padding:15px 17px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:9px;font-weight:800}
.tap-board .drawer-h .x{margin-left:auto;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;color:var(--muted)}
.tap-board .drawer-b{flex:1;overflow:auto;padding:8px 14px 20px}
.tap-board .log{display:flex;gap:9px;padding:9px 2px;border-bottom:1px solid var(--line);font-size:12px}
.tap-board .log .lg-ic{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:12px;background:var(--card-2);border:1px solid var(--line)}
.tap-board .log .lg-txt{flex:1;min-width:0}
.tap-board .log .lg-when{color:var(--faint);font-size:10.5px;margin-top:2px}
.tap-board .log b{color:var(--ink)}
.tap-board .empty-big{padding:60px 20px;text-align:center;color:var(--faint)}
.tap-board .empty-big .ic{width:40px;height:40px;margin-bottom:10px}
.tap-board .who{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line-2);border-radius:11px;padding:6px 11px;font-size:12.5px;color:var(--ink-2);font-weight:600}
.tap-board .who input{border:none;background:none;outline:none;font-weight:700;color:var(--ink);width:120px;font-size:12.5px}
@media(max-width:980px){.tap-board .cal-grid{min-width:760px}
.tap-board .fb-hint{display:none}
.tap-board .cap .cap-l{display:none}}
@media(max-width:640px){.tap-board .kcol{flex-basis:80vw;min-width:80vw}
.tap-board .wknav .lbl{min-width:110px;font-size:12.5px}
.tap-board .drawer{width:100%}
.tap-board .row2,.tap-board .row3{grid-template-columns:1fr}
.tap-board .cal-grid{min-width:680px}
.tap-board .chip{cursor:pointer}
.tap-board .statbar{grid-template-columns:repeat(2,1fr)}
.tap-board .mgrid .mcell{min-height:54px}}
.tap-board .seg.sm{padding:4px;background:var(--bg);border:1px solid var(--line);border-radius:999px;display:inline-flex;gap:3px}
.tap-board .seg.sm button{padding:6px 13px;font-size:12px;font-weight:600;border-radius:999px;color:var(--ink-2);background:transparent;border:1px solid transparent;transition:.14s}
.tap-board .seg.sm button:hover{background:var(--card);color:var(--ink)}
.tap-board .seg.sm button.active{background:var(--card);color:var(--accent);box-shadow:0 1px 3px rgba(15,23,42,.14)}
.tap-board .filterbar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin:0 0 12px}
.tap-board .filterbar .fpick{padding:5px 10px}
.tap-board .cap{display:inline-flex;align-items:center;gap:7px;background:var(--card);border:1px solid var(--line-2);border-radius:11px;padding:5px 11px;font-size:12.5px;color:var(--ink-2);font-weight:600}
.tap-board .cap input{width:58px;border:none;background:none;outline:none;font-weight:800;color:var(--ink);font-size:13px;text-align:right}
.tap-board .cap .cap-u{color:var(--muted);font-weight:700}
.tap-board .cap .cap-l{color:var(--muted)}
.tap-board .fb-hint{margin-left:auto;font-size:11.5px;color:var(--faint);font-weight:600}
.tap-board .fb-hint b{color:var(--st-rend)}
.tap-board .btn.sm{padding:6px 11px;font-size:12px}
.tap-board .statbar{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.tap-board .sb-card{display:flex;flex-direction:column;gap:3px;align-items:flex-start;text-align:left;padding:10px 12px;border-radius:13px;background:var(--cbg);border:1px solid var(--line);border-left:4px solid var(--c);box-shadow:var(--sh-1);transition:.14s;cursor:pointer}
.tap-board .sb-card:hover{box-shadow:var(--sh-2);transform:translateY(-1px)}
.tap-board .sb-card.on{outline:2px solid var(--c);outline-offset:1px}
.tap-board .sb-card .sb-hd{display:flex;align-items:center;gap:6px;width:100%}
.tap-board .sb-card .sb-t{font-weight:800;font-size:12.5px;color:var(--ink)}
.tap-board .sb-card .sb-n{font-size:14px;font-weight:800;color:var(--c)}
.tap-board .sb-card .sb-n i{font-style:normal;font-size:10.5px;color:var(--muted);font-weight:700}
.tap-board .sb-card .sb-wk{font-size:10.5px;color:var(--faint);font-weight:600}
.tap-board .sb-card .sb-acc{margin-left:auto;font-size:10.5px;font-weight:800;color:var(--st-rend);background:var(--card);border:1px solid var(--st-rend);border-radius:7px;padding:2px 7px}
.tap-board .sb-card .sb-acc:hover{background:var(--st-rend-bg)}
.tap-board .kcol-h .kc-acc{margin-left:auto;font-size:10.5px;font-weight:800;color:var(--st-rend);background:var(--card);border:1px solid var(--st-rend);border-radius:7px;padding:2px 8px;white-space:nowrap}
.tap-board .kcol-h .kc-acc:hover{background:var(--st-rend-bg)}
.tap-board .wknd-btn{font-size:12px;font-weight:700;color:var(--ink-2);background:var(--card);border:1px solid var(--line-2);border-radius:11px;padding:7px 11px}
.tap-board .wknd-btn:hover{border-color:var(--accent);color:var(--accent)}
.tap-board .wknd-btn.off{color:var(--faint);background:var(--card-2)}
.tap-board .wknd-btn.off .wb-state{text-decoration:line-through}
.tap-board .today-pill{padding:9px 17px;border:1px solid var(--line-2);border-radius:10px;background:var(--card);color:var(--ink-2);font-weight:700;font-size:13.5px;box-shadow:var(--sh-1);transition:.14s}
.tap-board .today-pill:hover{background:var(--card-2);border-color:var(--accent);color:var(--accent)}
.tap-board .navbtns{display:flex;gap:2px;align-items:center}
.tap-board .navbtns button{width:38px;height:38px;border-radius:50%;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;transition:.12s}
.tap-board .navbtns button:hover{background:var(--accent-soft);color:var(--accent)}
.tap-board .navbtns .ic{width:20px;height:20px}
.tap-board .period{font-size:21px;font-weight:500;color:var(--ink);letter-spacing:-.3px;white-space:nowrap;margin-left:2px}
@media(max-width:640px){.tap-board .period{font-size:17px}
.tap-board .today-pill{padding:7px 13px}
.tap-board .navbtns button{width:34px;height:34px}}
.tap-board .tb-search{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);background:var(--card);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--sh-1);transition:.14s}
.tap-board .tb-search:hover{border-color:var(--accent);color:var(--accent);background:var(--card-2)}
.tap-board .search-modal{max-width:640px}
.tap-board .search-h{display:flex;align-items:center;gap:11px;padding:13px 16px;border-bottom:1px solid var(--line)}
.tap-board .search-h .ic{color:var(--muted);flex:0 0 auto}
.tap-board .search-h input{flex:1;min-width:0;border:none;background:none;outline:none;font-size:16px;font-weight:600;color:var(--ink)}
.tap-board .search-h .x{flex:0 0 auto;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;color:var(--muted)}
.tap-board .search-h .x:hover{background:var(--card-2);color:var(--ink)}
.tap-board .search-res{max-height:62vh;overflow:auto;padding:4px 0 8px}
.tap-board .sr-empty{padding:30px 18px;text-align:center;color:var(--faint);font-size:13px;font-weight:600}
.tap-board .sr-row{display:flex;align-items:center;gap:12px;padding:9px 16px;cursor:pointer;border-bottom:1px solid var(--line)}
.tap-board .sr-row:hover{background:var(--card-2)}
.tap-board .sr-date{flex:0 0 100px;font-size:10px;font-weight:700;color:var(--muted);line-height:1.25;text-transform:uppercase}
.tap-board .sr-date b{display:block;font-size:16px;color:var(--ink);font-weight:800}
.tap-board .sr-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.tap-board .sr-txt{flex:1;min-width:0;font-size:13.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tap-board .sr-sub{font-size:12px;color:var(--muted);font-weight:600}
.tap-board .chip .c-foot{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}
.tap-board .chip .c-badge,.tap-board .chip .c-date{white-space:nowrap}
.tap-board .chip .c-acts{margin-left:auto;display:flex;gap:4px;align-items:center}
.tap-board .chip .c-adv,.tap-board .chip .c-rev{border:1px solid var(--line-2);background:var(--card);color:var(--ink-2);border-radius:7px;font-weight:800;font-size:11px;padding:2px 7px;line-height:1.5;transition:.12s;white-space:nowrap}
.tap-board .chip .c-adv:hover,.tap-board .chip .c-rev:hover{border-color:var(--c);color:var(--c);background:var(--cbg)}
.tap-board .chip .c-adv.accept{background:var(--st-rend-bg);border-color:var(--st-rend);color:var(--st-rend)}
.tap-board .chip .c-rev{padding:2px 6px;font-size:12px;color:var(--faint)}
.tap-board .chip--pre{border-left-style:dashed}
.tap-board .chip--pre .c-telep{color:var(--ink-2)}
.tap-board .cap-bar{height:4px;border-radius:3px;background:var(--line);margin:5px 6px 0;overflow:hidden}
.tap-board .cap-bar span{display:block;height:100%;background:var(--st-kisz);border-radius:3px}
.tap-board .cap-bar.over span{background:var(--st-rend)}
.tap-board .cal-col.over .cal-head{background:linear-gradient(180deg,var(--st-rend-bg),transparent)}
.tap-board .over-b{color:var(--st-rend);font-weight:800;font-size:9.5px}
.tap-board .day-acc{display:block;margin:6px auto 0;font-size:10.5px;font-weight:800;color:var(--st-rend);background:var(--st-rend-bg);border:1px solid var(--st-rend);border-radius:7px;padding:2px 8px}
.tap-board .day-acc:hover{filter:brightness(.97)}
.tap-board .calm{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.tap-board .mhead{display:grid;grid-template-columns:repeat(7,1fr);background:var(--card-2);border-bottom:1px solid var(--line)}
.tap-board .mhead span{padding:8px 4px;text-align:center;font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.tap-board .mgrid{display:grid;grid-template-columns:repeat(7,1fr)}
.tap-board .mgrid.c5{grid-template-columns:repeat(5,1fr)}
.tap-board .mhead.c5{grid-template-columns:repeat(5,1fr)}
.tap-board .mcell{min-height:86px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:5px 6px;display:flex;flex-direction:column;gap:4px;cursor:pointer;position:relative;transition:.12s}
.tap-board .mgrid:not(.c5) .mcell:nth-child(7n){border-right:none}
.tap-board .mgrid.c5 .mcell:nth-child(5n){border-right:none}
.tap-board .mcell:hover{background:var(--accent-soft)}
.tap-board .mcell.out{background:var(--card-2);opacity:.5}
.tap-board .mcell.weekend{background:var(--card-2)}
.tap-board .mcell.today{box-shadow:inset 0 0 0 2px var(--accent)}
.tap-board .mcell.over{background:linear-gradient(180deg,var(--st-rend-bg),transparent)}
.tap-board .mc-h{display:flex;align-items:center;gap:5px}
.tap-board .mc-d{font-weight:800;font-size:13px;color:var(--ink)}
.tap-board .mcell.out .mc-d{color:var(--faint)}
.tap-board .mc-t{font-size:10.5px;font-weight:800;color:var(--muted)}
.tap-board .mc-h .md-acc{margin-left:auto;font-size:9.5px;font-weight:800;color:var(--st-rend);background:var(--st-rend-bg);border:1px solid var(--st-rend);border-radius:6px;padding:1px 5px}
.tap-board .mc-dots{display:flex;flex-wrap:wrap;gap:3px;align-content:flex-start}
.tap-board .md-dot{width:9px;height:9px;border-radius:50%}
.tap-board .md-more{font-size:9.5px;font-weight:800;color:var(--muted)}
.tap-board .mc-over{position:absolute;bottom:4px;right:6px;color:var(--st-rend);font-size:10px}
.tap-board .btn{box-shadow:0 6px 16px -7px rgba(46,88,239,.55),var(--sh-1);transition:transform .12s,box-shadow .16s,filter .16s}
.tap-board .btn:hover{transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 12px 24px -9px rgba(46,88,239,.6)}
.tap-board .btn:active{transform:translateY(0)}
.tap-board .btn.amber{background:linear-gradient(135deg,#fb923c,#ea580c);box-shadow:0 6px 16px -7px rgba(234,88,12,.55),var(--sh-1)}
.tap-board .btn.amber:hover{box-shadow:0 12px 24px -9px rgba(234,88,12,.6)}
.tap-board .tb-icon,.tap-board .wknav,.tap-board .fpick,.tap-board .cap,.tap-board .who,.tap-board .wknd-btn{border-radius:12px}
.tap-board .statbar{gap:12px;margin-bottom:16px}
.tap-board .sb-card{padding:13px 15px;border-radius:16px;background:linear-gradient(180deg,var(--card) 30%,var(--cbg));box-shadow:var(--sh-1)}
.tap-board .sb-card:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.tap-board .sb-card .sb-t{font-size:12px;color:var(--ink-2);font-weight:700}
.tap-board .sb-card .sb-dot{width:9px;height:9px;border-radius:50%;background:var(--c);box-shadow:0 0 0 3px var(--cbg);flex:0 0 auto}
.tap-board .sb-card .sb-n{font-size:18.5px;font-weight:900;color:var(--ink);letter-spacing:-.5px;margin-top:3px;line-height:1.1}
.tap-board .sb-card .sb-n i{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:0}
.tap-board .sb-card .sb-wk{margin-top:1px}
.tap-board .chip{border-radius:12px;padding:9px 11px 10px;box-shadow:var(--sh-1);transition:transform .12s,box-shadow .16s}
.tap-board .chip:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.tap-board .chip .c-telep{font-size:12.5px;letter-spacing:-.2px}
.tap-board .cal{border-radius:18px}
.tap-board .cal-col.today{background:linear-gradient(180deg,var(--accent-soft),transparent 150px)}
.tap-board .cal-body{gap:6px}
.tap-board .mcell:hover{background:var(--accent-soft);box-shadow:inset 0 0 0 1px var(--accent-soft)}
.tap-board .chip .c-label{margin-top:4px;font-size:13px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tap-board .chip .c-label .cl-mk{font-weight:900;color:var(--accent);letter-spacing:-.1px}
.tap-board .chip .c-label .cl-mk.empty{color:var(--faint);font-weight:700}
.tap-board .chip .c-label .cl-mid{font-weight:700;color:var(--ink)}
.tap-board .chip .c-label .cl-fm{font-weight:600;color:var(--ink-2)}
.tap-board .chip .c-label .cl-note{font-weight:700;color:var(--ink-2)}
.tap-board .chip .c-prod{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}
.tap-board .chip .cf-gy,.tap-board .chip .cf-tk{font-size:11.5px;font-weight:800;border-radius:7px;padding:1px 7px;border:1px solid var(--line)}
.tap-board .chip .cf-gy{color:var(--ink-2);background:var(--card-2)}
.tap-board .chip .cf-tk{color:var(--st-kesz);background:var(--st-kesz-bg);border-color:var(--st-kesz)}
.tap-board .tkgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(54px,1fr));gap:6px}
.tap-board .tkgrid button{padding:8px 4px;font-size:12.5px;text-align:center}
.tap-board .tkgrid button.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:800}
.tap-board .status-view{display:flex}
.tap-board .esv-badge{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:13.5px;color:var(--c);background:var(--cbg);border:1px solid var(--c);border-radius:10px;padding:7px 13px}
.tap-board .lbl-note{font-weight:600;text-transform:none;letter-spacing:0;color:var(--faint);font-size:10.5px}
.tap-board .overwarn{display:flex;align-items:flex-start;gap:9px;background:var(--red-bg);border:1px solid var(--red);color:var(--red-tx);border-radius:13px;padding:10px 14px;margin-bottom:13px;font-size:12.5px;font-weight:700;line-height:1.45}
.tap-board .overwarn .ic{flex:0 0 auto;stroke:var(--red);margin-top:1px}
.tap-board .overwarn .ow-note{font-weight:600;opacity:.85}
.tap-board .overwarn[hidden]{display:none!important}
.tap-board .cfg-row2{display:grid;grid-template-columns:1.4fr 1fr;gap:10px;align-items:center;padding:6px 0;border-bottom:1px solid var(--line)}
.tap-board .cfg-row2 .ct{font-weight:800;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tap-board .cfg-row2 input{width:100%;padding:7px 9px;border:1px solid var(--line-2);border-radius:9px;background:var(--card-2);color:var(--ink);font-size:12.5px;font-weight:700;outline:none}
.tap-board .cfg-row2 input:focus{border-color:var(--accent);background:var(--card)}
.tap-board .cfg-sec{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:12px 0 3px}
.tap-board .cfg-list{max-height:38vh;overflow:auto}
.tap-board .cfg-telep{padding:9px 0;border-bottom:1px solid var(--line)}
.tap-board .cfg-telep-h{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.tap-board .cfg-telep .ct{font-weight:800;font-size:13px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.tap-board .cfg-add-fajta{flex:0 0 auto;font-size:11px;font-weight:800;color:var(--accent);background:var(--accent-soft);border:1px solid var(--line-2);border-radius:8px;padding:4px 10px}
.tap-board .cfg-add-fajta:hover{border-color:var(--accent)}
.tap-board .cfg-fajta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:4px 0}
.tap-board .cfg-fajta-row .ci-fajta{flex:0 0 130px;padding:7px 9px;border:1px solid var(--line-2);border-radius:9px;background:var(--card-2);color:var(--ink);font-size:12.5px;font-weight:700;outline:none}
.tap-board .cfg-fajta-row .ci-fajta:focus{border-color:var(--accent);background:var(--card)}
.tap-board .cfg-fajta-row .tipuspills{flex:1;min-width:0}
.tap-board .cfg-del-fajta{flex:0 0 auto;width:26px;height:26px;border-radius:8px;color:var(--faint);font-weight:800;font-size:13px;border:1px solid var(--line-2);background:var(--card)}
.tap-board .cfg-del-fajta:hover{color:var(--red);border-color:var(--red)}
.tap-board .formapills button,.tap-board .tipuspills button{border-color:var(--line-2)}
.tap-board .formapills button.on,.tap-board .tipuspills button.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:800}
.tap-board .list-editor{margin-bottom:11px}
.tap-board .list-editor .le-h{font-size:11.5px;font-weight:800;color:var(--ink-2);margin-bottom:5px}
.tap-board .le-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}
.tap-board .le-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:8px;background:var(--accent-soft);border:1px solid var(--line-2);font-size:12px;font-weight:700;color:var(--ink)}
.tap-board .le-chip .le-del{color:var(--faint);font-weight:800;line-height:1;font-size:12px;padding:0}
.tap-board .le-chip .le-del:hover{color:var(--red)}
.tap-board .le-empty{color:var(--faint);font-size:12px}
.tap-board .le-add{display:flex;gap:6px}
.tap-board .le-add .le-input{flex:1;padding:6px 9px;border:1px solid var(--line-2);border-radius:8px;background:var(--card-2);color:var(--ink);font-size:12.5px;font-weight:600;outline:none}
.tap-board .le-add .le-input:focus{border-color:var(--accent);background:var(--card)}
.tap-board .le-add .le-add-btn{flex:0 0 auto;padding:6px 13px;border-radius:8px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--line-2);font-weight:800;font-size:14px}
.tap-board .le-add .le-add-btn:hover{border-color:var(--accent)}
.tap-board #viewSettings{max-width:1100px;margin:0 auto}
.tap-board .set-head{display:flex;align-items:center;gap:14px;margin-bottom:8px}
.tap-board .set-head h2{margin:0;font-size:20px;font-weight:800;letter-spacing:-.3px}
.tap-board .set-head .set-saved{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:800;color:var(--green-tx);opacity:0;transition:opacity .2s}
.tap-board .set-head .set-saved.show{opacity:1}
.tap-board .set-head .set-saved .ic{stroke:var(--green)}
.tap-board .set-note{font-size:12.5px;color:var(--ink-2);background:var(--accent-soft);border:1px solid var(--line);border-radius:12px;padding:11px 14px;margin-bottom:16px;line-height:1.5}
.tap-board .set-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tap-board .set-card{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-1);padding:16px 18px;margin-bottom:16px}
.tap-board .set-grid .set-card{margin-bottom:0}
.tap-board .set-card h3{margin:0 0 12px;font-size:14px;font-weight:800;color:var(--ink)}
.tap-board .set-card-hint{font-size:11.5px;color:var(--muted);margin:-6px 0 12px;line-height:1.5}
.tap-board .set-card .cfg-fajta-row .ci-fajta{flex:0 0 150px}
@media(max-width:860px){.tap-board .set-grid{grid-template-columns:1fr}
.tap-board .set-head h2{font-size:17px}}
.tap-board .calpick-grid{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.tap-board .calpick{display:flex;align-items:center;gap:13px;width:100%;text-align:left;padding:13px 15px;border-radius:15px;border:1.5px solid var(--line-2);background:var(--card-2);transition:.14s;position:relative}
.tap-board .calpick:not(.soon):hover{border-color:var(--c);background:var(--cbg);transform:translateY(-1px);box-shadow:var(--sh-2)}
.tap-board .calpick .cp-ico{width:42px;height:42px;flex:0 0 auto;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:var(--cbg);border:1px solid var(--c)}
.tap-board .calpick .cp-ico .cp-svg{width:25px;height:25px}   /* saját SVG-ikon (zsák / tartály) — user 2026-06-29 */
.tap-board .calpick .cp-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.tap-board .calpick .cp-nm{font-weight:800;font-size:14.5px;color:var(--ink);letter-spacing:-.2px}
.tap-board .calpick .cp-desc{font-size:11.5px;color:var(--muted);font-weight:600}
.tap-board .calpick .cp-go{flex:0 0 auto;font-size:20px;font-weight:800;color:var(--c)}
.tap-board .calpick .cp-soon{flex:0 0 auto;font-size:10.5px;font-weight:800;color:var(--faint);background:var(--card);border:1px solid var(--line-2);border-radius:20px;padding:3px 10px;text-transform:uppercase;letter-spacing:.4px}
.tap-board .calpick.soon{opacity:.62;cursor:not-allowed}
.tap-board .calpick.soon .cp-ico{filter:grayscale(.55)}
.tap-board .cal-wrap{display:flex;gap:14px;align-items:flex-start}
.tap-board .cal-main{flex:1;min-width:0;overflow-x:auto}
.tap-board .cal-sidebar{flex:0 0 190px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:12px;position:sticky;top:80px}
.tap-board .cal-sb-h{font-size:10.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin:4px 2px 7px}
.tap-board .cal-list{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}
.tap-board .cal-item{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:10px;width:100%;text-align:left;transition:.12s}
.tap-board .cal-item:hover{background:var(--card-2)}
.tap-board .cal-item .cal-cb{width:17px;height:17px;border-radius:6px;border:2px solid var(--cc);background:var(--cc);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;line-height:1;flex:0 0 auto}
.tap-board .cal-item.off .cal-cb{background:transparent;color:transparent}
.tap-board .cal-item .cal-nm{font-size:12.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.tap-board .cal-item.off .cal-nm{color:var(--faint)}
.tap-board .cal-item .cal-n{font-size:11px;font-weight:800;color:var(--muted)}
.tap-board .cal-row{display:flex;align-items:center;gap:6px;border-radius:10px;transition:.12s}   /* user 2026-06-29: naptár-sor = láthatóság-gomb + darabszám + szín-gomb */
.tap-board .cal-row:hover{background:var(--card-2)}
.tap-board .cal-row .cal-item{flex:1;min-width:0;width:auto}
.tap-board .cal-row .cal-item:hover{background:transparent}
.tap-board .cal-row .cal-n{font-size:11px;font-weight:800;color:var(--muted);flex:0 0 auto}
.tap-board .cal-colbtn{width:18px;height:18px;border-radius:6px;border:1px solid rgba(0,0,0,.18);box-shadow:inset 0 0 0 2px var(--card);flex:0 0 auto;cursor:pointer;transition:.12s}
.tap-board .cal-colbtn:hover{transform:scale(1.12);box-shadow:inset 0 0 0 2px var(--card),0 0 0 2px var(--accent)}
.cal-sb-note{font-weight:600;text-transform:none;letter-spacing:0;color:var(--faint);font-size:9.5px}
.cal-color-pop{position:absolute;z-index:1200;background:var(--card);border:1px solid var(--line-2);border-radius:12px;box-shadow:0 12px 34px rgba(0,0,0,.20);padding:11px;width:206px}
.cal-color-pop .ccp-h{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.cal-color-pop .ccp-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:9px}
.cal-color-pop .ccp-sw{width:30px;height:30px;border-radius:8px;border:2px solid var(--card);box-shadow:0 0 0 1px var(--line-2);cursor:pointer;color:#fff;font-weight:900;font-size:13px;display:flex;align-items:center;justify-content:center;transition:.1s}
.cal-color-pop .ccp-sw:hover{transform:scale(1.1)}
.cal-color-pop .ccp-sw.sel{box-shadow:0 0 0 2px var(--accent)}
.cal-color-pop .ccp-reset{width:100%;font-size:12px;font-weight:700;color:var(--muted);padding:7px;border:1px solid var(--line-2);border-radius:8px;cursor:pointer;background:var(--card)}
.cal-color-pop .ccp-reset:hover{background:var(--card-2);color:var(--ink)}
.tap-board .cmseg{width:100%}
.tap-board .cmseg button{flex:1;justify-content:center}
.tap-board .mm{margin-bottom:12px}
.tap-board .mm-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.tap-board .mm-h span{font-size:12.5px;font-weight:800;color:var(--ink)}
.tap-board .mm-h button{width:24px;height:24px;border-radius:7px;color:var(--muted);font-size:16px;font-weight:800;line-height:1}
.tap-board .mm-h button:hover{background:var(--accent-soft);color:var(--accent)}
.tap-board .mm-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:2px}
.tap-board .mm-dow span{text-align:center;font-size:9px;font-weight:800;color:var(--faint);text-transform:uppercase}
.tap-board .mm-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.tap-board .mm-d{aspect-ratio:1;border-radius:6px;font-size:10.5px;font-weight:700;color:var(--ink-2);display:flex;align-items:center;justify-content:center;line-height:1}
.tap-board .mm-d:hover{background:var(--accent-soft);color:var(--accent)}
.tap-board .mm-d.out{color:var(--faint);opacity:.55}
.tap-board .mm-d.inwk{background:var(--accent-soft);color:var(--accent)}
.tap-board .mm-d.today{background:var(--accent);color:#fff;font-weight:900}
.tap-board .mm-d.today.inwk{background:var(--accent)}
.tap-board .gbar{display:flex;align-items:center;gap:5px;background:var(--c);color:#fff;border-radius:5px;padding:2px 7px;min-height:19px;cursor:grab;box-shadow:0 1px 1px rgba(16,24,40,.10);transition:filter .12s,transform .1s;user-select:none}
.tap-board .gbar:hover{filter:brightness(1.07);transform:translateY(-1px);box-shadow:var(--sh-1)}
.tap-board .gbar:active{cursor:grabbing}
.tap-board .gbar.dragging{opacity:.45}
.tap-board .gbar.hollow{background:var(--cbg);color:var(--c);border:1px dashed var(--c);padding:1px 6px}
.tap-board .gbar .gb-txt{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11.5px;font-weight:700}
.tap-board .gbar .gb-q{flex:0 0 auto;font-weight:900;font-size:13px;opacity:1;letter-spacing:-.2px}
.tap-board .gbar .gb-st{width:7px;height:7px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 1.5px rgba(255,255,255,.55)}
.tap-board .gbar .gb-fc{flex:0 0 auto;font-size:9px;opacity:.85}
.tap-board .cal-body{gap:3px!important;padding:5px 6px 12px}
@media(max-width:860px){.tap-board .cal-wrap{flex-direction:column}
.tap-board .cal-sidebar{flex:none;width:100%;position:static;display:flex;flex-wrap:wrap;align-items:center;gap:7px 16px}
.tap-board .cal-sidebar .mm{display:none}
.tap-board .cal-sb-h{margin:0}
.tap-board .cal-list{flex-direction:row;flex-wrap:wrap;margin:0;gap:4px 6px}
.tap-board .cal-item{width:auto}
.tap-board .cal-row{flex:0 0 auto;width:auto}
.tap-board .cmseg{width:auto}}

/* ==========================================================================
   Oldalsáv „Munkalap" → lenyíló dolgozó-lista (admin/vezető) — a mérleg
   .side-sub accordion mintájára, kereshető.
   ========================================================================== */
.emp-sub.side-sub{padding:2px 8px 8px}
.emp-search{width:100%;margin:2px 0 6px;padding:7px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);color:#e6eefc;font-size:12.5px}
.emp-search::placeholder{color:#8fb0d8}
.emp-search:focus{outline:none;border-color:rgba(255,255,255,.4);background:rgba(255,255,255,.14)}
.emp-list{display:flex;flex-direction:column;gap:1px;max-height:46vh;overflow-y:auto;scrollbar-width:thin}
.emp-list::-webkit-scrollbar{width:6px}.emp-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:999px}
.side-nav .emp-item{padding:7px 10px 7px 12px;gap:9px;font-size:12.8px;font-weight:600;border-radius:9px}
.side-nav .emp-item .emp-av{flex:0 0 auto;width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,.14);color:#dce7f5;font-size:10.5px;font-weight:800;display:flex;align-items:center;justify-content:center}
.side-nav .emp-item .emp-nm{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-nav .emp-item.active{background:linear-gradient(90deg,rgba(96,165,250,.30),rgba(96,165,250,.08));color:#fff}
.side-nav .emp-item.active .emp-av{background:rgba(147,197,253,.34);color:#fff}
.emp-empty{padding:8px 12px;color:#8fb0d8;font-size:12px}
/* összecsukott „rail" módban a dolgozó-lista rejtve (csak ikon-nav) */
body.sb-collapsed .emp-sub{display:none !important}
