:root,[data-theme=blue]{--primary: #1d4ed8;--primary-deep: #16389b;--primary-ink: #0e2464;--accent: #f59e0b;--accent-soft: #fef3c7;--side-bg: #101f4d;--side-active: #1d4ed8}[data-theme=graphite]{--primary: #334155;--primary-deep: #1e293b;--primary-ink: #0f172a;--accent: #0ea5e9;--accent-soft: #e0f2fe;--side-bg: #17202b;--side-active: #0ea5e9}[data-theme=burgundy]{--primary: #8e1538;--primary-deep: #6d0f2a;--primary-ink: #4a091c;--accent: #d4a017;--accent-soft: #f8ecd0;--side-bg: #3d0716;--side-active: #b91c48}:root{--bg: #f3f5f9;--card: #ffffff;--text: #1a2233;--muted: #64748b;--border: #e2e8f0;--danger: #dc2626;--ok: #059669;--warn: #d97706;--ok-soft: #d1fae5;--warn-soft: #fef3c7;--danger-soft: #fee2e2}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px}a{color:inherit;text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:224px;background:var(--side-bg);color:#fff;padding:16px 0;flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;align-self:flex-start}.sidebar .brand{font-size:23px;font-weight:800;padding:6px 20px 18px;letter-spacing:.5px}.sidebar .brand span{color:var(--accent)}.sidebar a{display:block;padding:10px 20px;font-size:13.5px;color:#ffffffc7;border-left:3px solid transparent}.sidebar a:hover{background:#ffffff14;color:#fff}.sidebar a.active{background:#ffffff1f;color:#fff;border-left-color:var(--accent);font-weight:600}.sidebar .section{font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;opacity:.45;padding:16px 20px 6px}.main{flex:1;padding:0 30px 22px;max-width:1280px}.topbar{display:flex;justify-content:space-between;align-items:center;margin:0 -30px 18px;gap:12px;position:sticky;top:0;z-index:60;background:var(--bg);padding:14px 30px;border-bottom:1px solid var(--border);box-shadow:0 2px 8px #1018280d}.topbar h1{font-size:20px;margin:0;color:var(--primary-ink)}.topbar .who{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:10px}.theme-dots{display:flex;gap:6px}.theme-dots button{width:20px;height:20px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--border);padding:0;cursor:pointer}.theme-dots button.sel{box-shadow:0 0 0 2px var(--primary)}.dot-blue{background:#1d4ed8}.dot-graphite{background:#334155}.dot-burgundy{background:#8e1538}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(158px,1fr));gap:12px;margin-bottom:20px}.card{background:var(--card);border:1px solid var(--border);border-top:3px solid var(--primary);border-radius:10px;padding:14px 16px}.card.accent{border-top-color:var(--accent)}.card.alert{border-top-color:var(--danger)}.card .num{font-size:26px;font-weight:800;color:var(--primary);line-height:1.1}.card.alert .num{color:var(--danger)}.card .lbl{font-size:11.5px;color:var(--muted);margin-top:3px}.panel{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:18px;box-shadow:0 1px 3px #1018280f}.panel h2{font-size:16px;margin:0 0 14px;color:var(--primary-ink)}.avatar,.avatar-lg{border-radius:50%;object-fit:cover;background:color-mix(in srgb,var(--primary) 12%,#fff);color:var(--primary);font-weight:800;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border:2px solid #fff;box-shadow:0 0 0 1px var(--border)}.avatar{width:34px;height:34px;font-size:13px}.avatar-lg{width:84px;height:84px;font-size:28px}.dropzone{border:2px dashed color-mix(in srgb,var(--primary) 40%,var(--border));border-radius:12px;padding:14px;text-align:center;color:var(--muted);font-size:12px;cursor:pointer;transition:background .15s}.dropzone:hover,.dropzone.drag{background:color-mix(in srgb,var(--primary) 6%,#fff);color:var(--primary)}.ts-day.clickable{cursor:pointer;transition:transform .1s,box-shadow .1s}.ts-day.clickable:hover{transform:translateY(-1px);box-shadow:0 2px 8px #10182826;border-color:var(--primary)}.ts-day.selected{outline:2px solid var(--primary)}.ts-day.HOLIDAY{background:var(--accent-soft);border-color:var(--accent)}.profile-head{display:flex;align-items:center;gap:18px}.chiprow{display:flex;flex-wrap:wrap;gap:8px}.chip{border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:12px;background:#fff}table{width:100%;border-collapse:collapse;font-size:13.5px}th{text-align:left;background:color-mix(in srgb,var(--primary) 8%,#fff);color:var(--primary-ink);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.6px;padding:11px 14px;border-bottom:2px solid color-mix(in srgb,var(--primary) 25%,var(--border))}td{padding:12px 14px;border-bottom:1px solid var(--border)}tbody tr:nth-child(2n) td{background:color-mix(in srgb,var(--primary) 2.5%,#fff)}tbody tr:hover td{background:color-mix(in srgb,var(--primary) 7%,#fff)}button,.btn{background:var(--primary);color:#fff;border:none;border-radius:7px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer}button:hover{background:var(--primary-deep)}button.secondary{background:#fff;color:var(--primary);border:1px solid var(--border)}button.secondary:hover{background:var(--bg)}button.danger{background:var(--danger)}button:disabled{opacity:.5;cursor:default}input,select,textarea{border:1px solid #cbd5e1;border-radius:7px;padding:8px 10px;font-size:13.5px;font-family:inherit;width:100%;background:#fff;color:var(--text)}input:focus,select:focus,textarea:focus{outline:2px solid color-mix(in srgb,var(--primary) 30%,transparent);border-color:var(--primary)}label{font-size:11.5px;color:var(--muted);display:block;margin-bottom:4px;font-weight:600}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:12px}.field{margin-bottom:4px}.field .ferr{color:var(--danger);font-size:11px;margin-top:2px}.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700}.badge.green{background:var(--ok-soft);color:var(--ok)}.badge.orange{background:var(--warn-soft);color:var(--warn)}.badge.red{background:var(--danger-soft);color:var(--danger)}.badge.grey{background:#eef1f5;color:var(--muted)}.badge.theme{background:var(--accent-soft);color:var(--primary-ink)}.section-label{font-size:11.5px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.8px;margin:18px 0 8px;border-bottom:1px solid var(--border);padding-bottom:4px}.tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:2px solid var(--border);flex-wrap:wrap}.tabs button{background:none;color:var(--muted);border:none;border-radius:0;padding:9px 15px;font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px}.tabs button:hover{background:none;color:var(--primary)}.tabs button.active{color:var(--primary);border-bottom-color:var(--accent)}.ts-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.ts-day{border:1px solid var(--border);border-radius:7px;padding:6px 7px;min-height:52px;font-size:11px;background:#fff}.ts-day .d{font-weight:700;color:var(--text);font-size:12px}.ts-day.PRESENT{background:var(--ok-soft);border-color:var(--ok)}.ts-day.ABSENT{background:var(--danger-soft);border-color:var(--danger)}.ts-day.LEAVE{background:var(--warn-soft);border-color:var(--warn)}.ts-day.WEEKEND{background:#f1f5f9}.ts-day.FUTURE{opacity:.45}.ts-day .m{color:var(--muted);font-size:10px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(155deg,var(--side-bg),var(--primary-deep))}.login-box{background:#fff;border-radius:14px;padding:36px;width:370px}.login-box h1{margin:0 0 4px;color:var(--primary);font-size:30px}.login-box h1 span{color:var(--accent)}.login-box p{color:var(--muted);font-size:13px;margin-top:0}.login-box .field{margin-bottom:14px}.error{color:var(--danger);font-size:13px;margin:8px 0}.muted{color:var(--muted);font-size:12.5px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.logo-ph{border:2px dashed var(--border);border-radius:8px;padding:6px 14px;font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:1px}.sheet{background:#fff;max-width:800px;margin:20px auto;padding:36px 44px;border:1px solid var(--border);border-radius:10px;color:#1a2233}.sheet-head{display:flex;justify-content:space-between;align-items:center;border-bottom:3px solid var(--primary);padding-bottom:14px;margin-bottom:18px}.sheet-head img{max-height:54px;max-width:180px;object-fit:contain}.sheet h1{font-size:18px;color:var(--primary-ink);margin:0}.sheet .doc-title{text-align:center;font-size:15px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--primary-ink);margin:14px 0}.sheet table{font-size:13px}.sheet .sig-block{margin-top:44px}.sheet .sig-block img{max-height:60px;display:block;margin-bottom:4px}.sheet .sig-line{border-top:1px solid #1a2233;width:220px;padding-top:4px;font-size:12px}.letterbody{white-space:pre-wrap;font-size:13.5px;line-height:1.8;font-family:Georgia,Times New Roman,serif}.print-actions{max-width:800px;margin:14px auto;display:flex;gap:10px}@media print{.sidebar,.topbar,.print-actions,.noprint{display:none!important}.main{padding:0;max-width:none}body{background:#fff}.sheet{border:none;margin:0;max-width:none}}.hamburger{display:none;background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--primary-ink);padding:2px 6px}.nav-overlay{display:none}@media (max-width: 820px){.hamburger{display:inline-flex;align-items:center}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:200;transform:translate(-100%);transition:transform .2s ease;box-shadow:2px 0 18px #00000040}.sidebar.open{transform:translate(0)}.nav-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:150}.main{padding:0 12px 20px;max-width:100%}.topbar{margin:0 -12px 14px;padding:11px 12px}.topbar h1{font-size:15px}.topbar .who{gap:6px;flex-wrap:wrap;justify-content:flex-end;font-size:12px}.topbar .theme-dots{display:none}.form-grid{grid-template-columns:1fr}.cards{grid-template-columns:1fr 1fr}.panel{padding:14px;overflow-x:auto}.panel table{min-width:560px}.login-box{width:100%;max-width:380px;margin:0 14px;padding:26px}}@media (max-width: 460px){.cards{grid-template-columns:1fr}}
