/* Poppins SemiBold (SIL OFL) — okrojona, osadzona: napis marki */
@font-face{font-family:'Comfortaa';font-weight:700;font-display:swap;src:url(data:font/woff2;base64,d09GMgABAAAAAAWcABAAAAAAC1AAAAVAAAMa4QAAAAAAAAAAAAAAAAAAAAAAAAAAGhYbgiwcKgZgP1NUQVQqAHQRCAqJKIdVATYCJAM0CxwABCAFhDAHIAwHG0sJCB6D425pZcASm3HzQT3WEw+9+33emeT9BaCykD3rCyQUkGNFbHSFKys0tiwcgs/P47beGBYz8s+6u1kFiCdGYsasHGF0jIvqyH9YAKvfOy2lyT8okHU8QoLC4ty+Qrl539Baivs6pVQho6JxkahnU7ti4qMS4TNRTUblMTZB2nHo51UEhgEphCEhMGgLEc7OsJhk0D7H1FWAtgr/xpyzipoKUCcLqpICWulBi56fwiUg9EnL7Q2uC8DNevvbI6CwtCPthpdVL+GJOOFcV9quctmVd4apXrfqGRA69OuTKAZZ9iHZ1t5TGB26PUvfxt5rvCQ3vSabe6hQjaYDOHCQOAaiiABIDe98x0E6FA4Apb5U/0eg67AYAAG5GdcCNsCF0C8wDcMyzpXCojoMkAKi4+wBSBRMw1u2uE7gc3Thqg0kYiRKwShTrb79x+iO9peq+p3tezvQtttsg6XmmGlaGPlfQ7T/xhBGwCIwA+I6QCYA9YRUKXJPZXwBM9XCQNvQkNLT5Wloa5CkruijiTbBPjErnU8oV4pnruGxD1AukT1lSVqaVgrBPsBUuh8SyvvAOTl9efLROcbJiplzVvDYxcxk6FphWeCOpDBcgFeZOq2bnK40Spk613AKm89eyxlY9weDUL4zoOtKIVWZwsQsCjwWgQyJ4VcwfEimIYK7JEQkeGZ3bz7gCQJJAnH6wlUYlpYCXSvSUgunbzWaOsdQPknoLdmUbSjVEhERXS6B4mOiOty1g5fSSuHzlWTx2Pf+nOY7ZY1nLy/ge1hL58Xsk2WKeZvYYCasa+gwRnRZUVo/ufU99F6o+f1dxvMeWVofMlmw+swInQXHvhea/z5Zud52tV3KUL6fMMPoLVqK3hqhu8g5Kmq3J2GSk/7hn8JsELcYmj/9kxoe/hHdhenorL3jbqG6JGEYB3d1Llz4b9eGL7x6r5LpN2ikT/QuKvGalJ7uNVFABahP8C5W2yfmJwGkLi1HUsaPpx0rJZIi0FfmAmjE0U5qACQ4z4NVOvmTw+j2xMvkHUSeIS+LPWk5XxKQzxfTYpNtz0UTE9rHh4FfiayNCGqLj49ob4uIi2uNwHq8XXwK7dTRGW7xQpdkd3ERcoqbKEHITxa7A+DReqnoDJqpX0xb3UdnYOdxv2CR3lvJuXsGb5mbaBVaDTK4fBz3j/T8qV+hkvP/z2+BO87BAhtabIl2o/AZljb7kYmhEqGskTDmJTqDTkDcnvbWiLj4qQjSRfpIhQ7aaM+JADcR4Ce7i+WM7C52lyEQfSGdLtomMqHPavInOrB/Wz3VQEANLfP2r076RoTyl/q27hARbuniFGTRbB3g7ysr8prJ1b+lfeRpRO4m96E9ALjzGwJl8eG2zNireTq+X/sL/gKA9/brTQD4WDF9JxANlUycBNCTIPjYei53EfpL5hdy2ZGsBpvcj8jZ5NlDXmYKLLEq3WL+6QWZ4QxhvILMItS/ZpX4sAEQGLEdDkJ62oDzcFE1gP+oYmHSl1gaDdVYsR6GsWpTxMQ6i1FBPbNraBwGhmMVgPty/bFNsEpVmtUoVqhIHYqIkCtXlGRFFCjvOeUKVKpRh8GgJKhRqYSCrPVoiXp1ipBqY2XfKzyqUs72JiBQqJg5up4Un6xvJfjOP1uhiUKxBgwB2ajjHTijNPZzOIWmUEuhRgMFOYTCVKoYTYnDKJ/9bpbeXpb4Rt7vXytUrwyjhhs+V0LufATLQAvl03oHF281ZjJKpc69Vat41luoEdc7ymAaxVn9qiCVysjhQJuTSG7kS+x//9yxAAA=) format('woff2')}
/* =========================================================
   AQUALUK — system projektowy „construction-tech premium"
   Granat + bursztyn, chłodne neutralne, mocna hierarchia.
   (Nazwy zmiennych i klas zachowane — logika bez zmian.)
   ========================================================= */
:root{
  /* neutralne z lekkim chłodem (nie czysta szarość) */
  --bg:#eceff5;
  --card:#ffffff;
  --ink:#131a2a;
  --muted:#66738c;
  --line:#e2e7f0;
  /* marka — granat AQUALUK #263A54 */
  --brand:#263a54;
  --brand-d:#1a2b3f;
  --brand-soft:#eaedf3;
  --accent:#f0a52a;          /* bursztyn — akcent, oszczędnie */
  /* semantyka statusów */
  --ok:#188a55; --no:#cc4949; --up:#2f6fb0; --ub:#bd7a1f; --zl:#7654c8;
  /* wykończenie */
  --shadow:0 1px 2px rgba(16,24,40,.06), 0 6px 16px -6px rgba(16,24,40,.14);
  --shadow-sm:0 1px 2px rgba(16,24,40,.08);
  --radius:16px;
  --safe-b:env(safe-area-inset-bottom,0px);
  --font:"Segoe UI Variable Display","Segoe UI",system-ui,-apple-system,Roboto,"Helvetica Neue",sans-serif;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:
    radial-gradient(120% 60% at 100% 0%, #eef2f8 0%, var(--bg) 60%) fixed;
  color:var(--ink);
  font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  padding-bottom:calc(76px + var(--safe-b));
  letter-spacing:-0.006em;
}
h2{font-weight:750;letter-spacing:-0.015em;text-wrap:balance}
button{font-family:inherit}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:2px;border-radius:8px}
/* ikonka w tekście — dziedziczy kolor, delikatnie osadzona w linii */
.ti{display:inline-flex;align-items:center;vertical-align:-2.5px;flex:none}
.ti svg{display:block}

/* ---------- Pasek roli (tryb podglądu) ---------- */
.rolebar{display:flex;align-items:center;gap:8px;background:#0c1c33;color:#dfe7f3;
  padding:7px 12px;font-size:11px;overflow-x:auto;border-bottom:1px solid #0a1730}
.rolebar::-webkit-scrollbar{display:none}
.rolebar .rb-lbl{opacity:.6;white-space:nowrap;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.rolebar select{color:#fff;border:1px solid #2a3d5c;border-radius:9px;
  padding:6px 9px;font-size:12px;font-weight:600;background:#132844;max-width:190px}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:5;color:#fff;
  background:linear-gradient(180deg,#31496b 0%,#263a54 100%);
  padding:10px 14px 12px;box-shadow:0 8px 24px -12px rgba(15,30,52,.6);
  border-bottom:2px solid var(--accent)}
/* pasek marki — prawdziwe logo AQUALUK + „app" */
.brandbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px;color:#fff}
.brand{display:flex;align-items:center;gap:8px;min-width:0}
.topnav{display:flex;align-items:center;gap:5px;flex:none}
.topbtn{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);color:#fff;
  border-radius:11px;width:38px;height:38px;flex:none;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .12s, transform .08s}
.topbtn:active{transform:scale(.93)}
.topbtn.active{background:var(--accent);border-color:var(--accent);color:#3a2400}
.topbtn svg{width:20px;height:20px}
.brandbar .bmark{flex:none;display:flex}
.brandbar .bmark svg{height:32px;width:auto;display:block}
.brandbar .word{position:relative;display:inline-flex;align-items:flex-start;gap:3px}.brandbar .aqword{height:15px;width:auto;display:block}.brandbar .app{font-family:'Comfortaa','Segoe UI',sans-serif;font-size:11px;font-weight:700;color:var(--accent);line-height:1;margin-top:-1px}
.topbar-row{display:flex;gap:9px;align-items:stretch}
.site-select{flex:1;position:relative;display:flex;flex-direction:column;align-items:flex-start;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);color:#fff;border-radius:13px;
  padding:8px 13px;text-align:left;backdrop-filter:blur(4px);transition:background .15s}
.site-select:active{background:rgba(255,255,255,.2)}
.site-label{font-size:10px;opacity:.75;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.site-name{font-size:17px;font-weight:750;line-height:1.15;letter-spacing:-0.01em}
.chev{position:absolute;right:12px;top:50%;transform:translateY(-50%);opacity:.7;font-size:13px}
.date-nav{display:flex;align-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);border-radius:13px}
.date-arrow{background:none;border:none;color:#fff;font-size:24px;width:38px;height:100%;border-radius:13px;opacity:.9}
.date-arrow:active{background:rgba(255,255,255,.16)}
.date-btn{background:none;border:none;color:#fff;font-weight:700;font-size:13px;min-width:76px;padding:0 4px;letter-spacing:-0.01em}
.summary-bar{display:flex;gap:6px;flex-wrap:wrap;margin-top:11px;font-size:12px}
.summary-bar:empty{margin-top:0}
.summary-bar .chip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.1);
  border-radius:999px;padding:3px 11px;font-weight:650;font-variant-numeric:tabular-nums}

/* ---------- Widok ---------- */
.view{padding:14px 13px 24px;max-width:660px;margin:0 auto}
.view>h2{font-size:15px;margin:14px 4px 8px;color:var(--ink)}

/* ---------- Karty ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:16px;margin-bottom:13px}
.card h2{margin:0 0 12px;font-size:16px}

/* ---------- Wiersz pracownika / obecność ---------- */
.emp{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);margin-bottom:11px;padding:13px 14px}
.emp-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.emp-name{font-weight:750;font-size:16px;letter-spacing:-0.01em}
.emp-sub{color:var(--muted);font-size:12.5px;margin-top:1px;line-height:1.35}
.emp-hours{font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:6px;font-weight:600}
.emp-hours input{width:56px;border:1px solid var(--line);border-radius:9px;padding:6px;text-align:center;font-size:14px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:12px}
.st{border:1.5px solid var(--line);background:#fff;border-radius:12px;
  padding:9px 2px;font-weight:800;font-size:14px;color:var(--muted);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:2px;
  transition:transform .08s ease, box-shadow .12s ease, background .12s;font-variant-numeric:tabular-nums}
.st:active{transform:scale(.94)}
.st small{font-weight:650;font-size:9px;letter-spacing:.02em;opacity:.85}
.st.active{color:#fff;border-color:transparent;box-shadow:0 4px 10px -4px rgba(16,24,40,.4)}
.st.active[data-s="X"]{background:var(--ok)} .st.active[data-s="-"]{background:var(--no)}
.st.active[data-s="UP"]{background:var(--up)} .st.active[data-s="UB"]{background:var(--ub)}
.st.active[data-s="ZL"]{background:var(--zl)}

/* ---------- Formularze ---------- */
label.f{display:block;font-size:11px;color:var(--muted);margin:12px 0 5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em}
input.f,select.f,textarea.f{width:100%;border:1.5px solid var(--line);border-radius:12px;
  padding:12px;font-size:15px;background:#fdfdfe;color:var(--ink);transition:border-color .12s, box-shadow .12s;font-family:inherit}
input.f:focus,select.f:focus,textarea.f:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft);outline:none}
input.f:disabled{background:#f1f3f7;color:var(--muted)}
.row2{display:flex;gap:10px}.row2>*{flex:1}
.btn{display:block;width:100%;color:#fff;border:none;border-radius:13px;padding:14px;
  font-size:16px;font-weight:750;margin-top:16px;letter-spacing:-0.01em;cursor:pointer;
  background:linear-gradient(180deg,#324b6d,#263a54);box-shadow:0 8px 18px -8px rgba(38,58,84,.6);
  transition:transform .08s, box-shadow .12s, filter .12s}
.btn:active{transform:translateY(1px);filter:brightness(.96)}
.btn.sec{background:var(--brand-soft);color:var(--brand-d);box-shadow:none;border:1px solid #d4e1f1}
.hint{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.5}
.empty{text-align:center;color:var(--muted);padding:32px 12px;font-size:14px;
  background:var(--card);border:1px dashed var(--line);border-radius:var(--radius)}

/* ---------- Listy / pozycje ---------- */
.li{background:var(--card);border:1px solid var(--line);border-radius:13px;box-shadow:var(--shadow-sm);
  padding:12px 14px;margin-bottom:9px;display:flex;justify-content:space-between;gap:10px;align-items:center;
  transition:transform .08s, box-shadow .12s}
.li[data-dopen]:active,.li[data-open]:active,.li[data-costemp]:active{transform:scale(.99);box-shadow:var(--shadow)}
.li b{font-size:15px;font-weight:700;letter-spacing:-0.01em}
.badge{font-size:11px;font-weight:750;padding:4px 10px;border-radius:999px;letter-spacing:.01em;
  white-space:nowrap;display:inline-flex;align-items:center;gap:5px;background:#eef1f6;color:var(--muted);
  align-self:center;height:fit-content}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.badge.wait{background:rgba(240,165,42,.14);color:#9a6410;box-shadow:inset 0 0 0 1px rgba(240,165,42,.28)}
.badge.ok{background:#d8f2e4;color:#0f6e42}
.badge.no{background:#fbe4e4;color:#b23b3b}

/* karta oczekującego wniosku — subtelny bursztynowy akcent, nie krzykliwa żółć */
.card.pending{border-left:3px solid var(--accent);
  background:linear-gradient(100deg, rgba(240,165,42,.055), var(--card) 42%)}
.counter-box{background:var(--brand-soft);border:1px solid #d7e3f2;color:var(--brand-d);
  border-radius:11px;padding:9px 11px;font-size:13px;line-height:1.4}
.counter-box b{color:var(--brand-d)}

/* ---------- Tabbar ---------- */
.tabbar{position:fixed;left:0;right:0;bottom:0;display:flex;
  background:rgba(255,255,255,.92);backdrop-filter:blur(12px) saturate(1.4);
  border-top:1px solid var(--line);padding:6px 4px calc(4px + var(--safe-b));z-index:6;
  overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:0 -6px 20px -12px rgba(16,24,40,.2)}
.tabbar::-webkit-scrollbar{display:none}
.tab{flex:1 0 auto;min-width:62px;background:none;border:none;padding:7px 4px 5px;font-size:10.5px;
  font-weight:650;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:3px;
  white-space:nowrap;border-radius:12px;cursor:pointer;transition:color .12s, background .12s}
.tab .ico{font-size:19px;line-height:1;transition:transform .12s;display:flex}
.tab .ico svg{display:block}
.tab.active{color:var(--brand);background:var(--brand-soft)}
.tab.active .ico{transform:translateY(-1px) scale(1.05)}

/* ---------- Sheet / modal ---------- */
.sheet-backdrop{position:fixed;inset:0;background:rgba(12,22,40,.5);z-index:20;
  display:flex;align-items:flex-end;backdrop-filter:blur(2px);animation:fade .18s ease}
.sheet-backdrop.hidden{display:none}
.sheet{background:var(--card);width:100%;border-radius:22px 22px 0 0;
  padding:10px 15px calc(18px + var(--safe-b));max-height:82vh;overflow:auto;
  box-shadow:0 -12px 40px -12px rgba(12,22,40,.4);animation:slideup .24s cubic-bezier(.2,.8,.2,1)}
.sheet::before{content:"";display:block;width:38px;height:4px;border-radius:99px;background:var(--line);margin:4px auto 12px}
.sheet-title{font-weight:800;font-size:18px;margin-bottom:12px;letter-spacing:-0.015em}
.sheet-opt{width:100%;text-align:left;border:1px solid var(--line);background:#f7f9fc;border-radius:13px;
  padding:14px;font-size:16px;margin-bottom:8px;font-weight:650;cursor:pointer;transition:background .12s, transform .08s}
.sheet-opt:active{transform:scale(.99)}
.sheet-opt.sel{background:var(--brand);color:#fff;border-color:var(--brand)}
.sheet-close{width:100%;background:var(--brand-soft);color:var(--brand-d);border:none;border-radius:13px;padding:13px;font-weight:750;margin-top:6px;font-size:15px;cursor:pointer}
@keyframes slideup{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:92px;transform:translateX(-50%) translateY(8px);
  background:#0c1c33;color:#fff;padding:11px 18px;border-radius:999px;font-size:14px;font-weight:600;
  z-index:30;opacity:0;transition:opacity .2s, transform .2s;box-shadow:0 10px 30px -8px rgba(12,22,40,.6);
  max-width:90%;text-align:center;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- Segmentowany przełącznik ---------- */
.seg2{display:flex;gap:4px;background:#e6ebf3;border:1px solid var(--line);border-radius:13px;padding:4px;margin-bottom:13px}
.segb{flex:1;border:none;background:transparent;border-radius:10px;padding:10px;font-weight:700;font-size:14px;color:var(--muted);cursor:pointer;transition:background .14s, color .14s, box-shadow .14s}
.segb.on{background:#fff;color:var(--brand-d);box-shadow:var(--shadow-sm)}

/* ---------- Skład / dodawanie ---------- */
.crew-add{display:flex;width:100%;background:var(--brand-soft);color:var(--brand-d);border:1.5px dashed #b7c9e2;
  border-radius:13px;padding:14px;font-weight:750;font-size:15px;justify-content:center;gap:6px;margin-bottom:13px;cursor:pointer;transition:background .12s}
.crew-add:active{background:#dde8f6}
.crew-note{font-size:12px;color:var(--muted);margin:-4px 3px 13px;line-height:1.5}
.seg-tag{display:inline-flex;align-items:center;gap:4px;background:var(--brand-soft);color:var(--brand-d);
  border:1px solid #d4e1f1;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:650;margin-top:8px}
.split-btn{background:none;border:none;color:var(--brand);font-weight:700;font-size:12.5px;padding:6px 0 0;cursor:pointer}
.wk-remove{background:none;border:none;color:var(--no);font-size:18px;line-height:1;padding:2px 4px;cursor:pointer;opacity:.7}
.wk-remove:active{opacity:1}
.conflict{background:#fff5e6;border:1px solid #f2c986;color:#8a5a12;border-radius:11px;
  padding:9px 11px;font-size:12px;margin-top:8px;font-weight:600;line-height:1.45}
.conflict b{color:inherit}
.ck{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:1px solid var(--line);background:#f7f9fc;
  border-radius:13px;padding:13px;font-size:15px;margin-bottom:8px;font-weight:650;cursor:pointer;transition:background .12s}
.ck .box{width:23px;height:23px;border-radius:7px;border:2px solid #bccbe0;flex:none;
  display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;transition:.14s}
.ck.on{background:var(--brand-soft);border-color:#bcd2ee}
.ck.on .box{background:var(--brand);border-color:var(--brand)}
.split-row{display:flex;gap:8px;align-items:center;margin:8px 0;font-weight:600}
.split-row input{width:74px}

/* ---------- Przeglądarka folderów ---------- */
.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:2px 2px 13px;font-size:13px}
.crumb{color:var(--brand);font-weight:700;cursor:pointer}
.crumb.cur{color:var(--ink);cursor:default}
.breadcrumb .sep{color:#aab4c6}
.folders{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
.folder{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:15px;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:3px;cursor:pointer;
  transition:transform .1s, box-shadow .14s, border-color .14s}
.folder:active{transform:scale(.98);box-shadow:var(--shadow);border-color:#cdd9ea}
.folder .fic{font-size:30px;line-height:1;color:var(--brand);display:flex}
.folder .fic svg{display:block}
.thumb svg{color:var(--muted)}
.folder .fname{font-weight:750;font-size:15px;word-break:break-word;letter-spacing:-0.01em}
.folder .fcount{font-size:12px;color:var(--brand);font-weight:700;font-variant-numeric:tabular-nums}

/* ---------- Miniatury zdjęć ---------- */
.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:8px;margin-top:10px}
.thumb{background:linear-gradient(160deg,#eef2f8,#e2e8f2);border:1px solid var(--line);border-radius:11px;aspect-ratio:1;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  font-size:24px;color:var(--muted);padding:6px;text-align:center}
.thumb span{font-size:9px;line-height:1.15;word-break:break-all;color:var(--muted)}

/* ---------- Chipsy zakresu / kalendarz ---------- */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:11px}
.qchip{border:1px solid var(--line);background:var(--card);border-radius:999px;padding:7px 13px;font-size:12px;font-weight:700;color:var(--brand-d);cursor:pointer;box-shadow:var(--shadow-sm);transition:background .12s}
.qchip:active{background:var(--brand-soft)}
.range-ctl{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:12px}
.range-ctl .fld{flex:1;min-width:120px}

/* ---------- Siatka obecności (kalendarz) ---------- */
.gridwrap{overflow-x:auto;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-sm);padding:4px}
table.att{border-collapse:separate;border-spacing:0;font-size:12px;width:auto;font-variant-numeric:tabular-nums}
table.att th,table.att td{padding:6px 5px;text-align:center;white-space:nowrap;border-bottom:1px solid var(--line)}
table.att th{color:var(--muted);font-weight:700;font-size:11px}
table.att th.day{cursor:pointer}
table.att th.wknd,table.att td.wknd{background:#f4f7fb}
table.att .name{position:sticky;left:0;background:var(--card);text-align:left;font-weight:700;z-index:2;box-shadow:1px 0 0 var(--line);max-width:132px;overflow:hidden;text-overflow:ellipsis}
table.att thead .name{z-index:3}
.cellv{display:inline-block;min-width:22px;padding:2px 4px;border-radius:7px;font-weight:800;color:#fff;font-size:11px}
.grid-legend{display:flex;gap:12px;flex-wrap:wrap;font-size:11px;color:var(--muted);margin:10px 2px 0}
.grid-legend span{display:inline-flex;align-items:center;gap:5px;font-weight:600}
.grid-legend i{width:12px;height:12px;border-radius:4px;display:inline-block}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
}
