:root{--black:#0f1011;--black-soft:#1c1d20;--bg:#f1f1f0;--bg-2:#ebebea;--surface:#ffffff;--surface-2:#fafafa;--surface-hover:#f5f5f5;--fg:#1a1a1a;--fg-strong:#0a0a0a;--muted:#6b6b6b;--muted-2:#9a9a9a;--border:rgba(0,0,0,0.08);--border-strong:rgba(0,0,0,0.14);--accent:#5ba3f5;--accent-hover:#87b8ff;--accent-text:#0f1011;--accent-blue:#5ba3f5;--accent-peach:#ffb69e;--accent-mint:#b9e6c8;--accent-lavender:#d6c4f5;--success:#28a745;--warning:#f59e0b;--danger:#ef4444;--info:var(--accent-blue);--card-peach:#fff1ea;--card-blue:#eaf2ff;--card-mint:#e8f7ee;--card-lavender:#f2ebff;--card-yellow:#fff5d6;--card-pink:#ffeaf2;--radius-sm:8px;--radius:16px;--radius-lg:28px;--radius-pill:999px;--shadow-sm:0 1px 2px rgba(15,16,17,0.04);--shadow:0 6px 24px rgba(15,16,17,0.06);--shadow-lg:0 20px 48px rgba(15,16,17,0.10)}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;background:radial-gradient(1400px 800px at -15% -20%,rgba(255,182,158,.35),transparent 60%),radial-gradient(1200px 700px at 115% -10%,rgba(180,200,230,.25),transparent 55%),var(--bg);background-attachment:fixed;font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.55;min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a,body,html{color:var(--fg)}a{transition:color .12s}a,a:hover{text-decoration:none}a:hover{color:var(--fg-strong)}main{max-width:720px;margin:0 auto;padding:4rem 1.5rem}h1{font-size:3rem;font-weight:800;letter-spacing:-.035em;margin:0 0 .5rem;line-height:1.05}h1,h2{color:var(--fg-strong)}h2{font-size:1.4rem;font-weight:700;letter-spacing:-.01em;margin:0 0 .6rem}h3{font-size:1.05rem;font-weight:600;margin:0 0 .4rem}p{margin:0 0 .75rem}code{font-family:ui-monospace,SF Mono,JetBrains Mono,Menlo,Consolas,monospace;font-size:.85em;background:var(--card-blue);color:#1e40af;padding:.1em .45em;border-radius:6px;border:1px solid rgba(91,163,245,.18)}a code{color:#1d4ed8}a:hover code{background:#dbe7ff}.muted{color:var(--muted)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{position:-webkit-sticky;position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:1.5rem;padding:1rem 2.5rem;background:rgba(255,255,255,.55);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:0;flex-wrap:wrap}.app-header .brand{font-size:1.4rem;font-weight:800;letter-spacing:-.04em;color:var(--fg-strong)}.app-header .brand .muted{color:var(--muted);font-weight:500;font-size:.85rem}.app-header .nav-strip{display:flex;gap:.4rem;flex:1 1;flex-wrap:wrap}.app-header .nav-strip a{color:var(--fg);font-size:.95rem;font-weight:500;padding:.55rem 1.25rem;border-radius:var(--radius-pill);background:rgba(255,255,255,.6);border:1px solid var(--border);transition:all .15s ease}.app-header .nav-strip a:hover{background:color-mix(in srgb,var(--accent-blue) 12%,var(--surface));border-color:color-mix(in srgb,var(--accent-blue) 35%,var(--border));color:#1e3a8a;text-decoration:none}.app-header .nav-strip a[aria-current=page]{background:var(--card-blue);border-color:rgba(91,163,245,.45);color:#1e3a8a;font-weight:700}.app-header .nav-strip a[aria-current=page]:hover{background:#dbe7ff}.app-header .user-info{display:flex;align-items:center;gap:.6rem;font-size:.85rem;color:var(--fg)}.app-header .user-info .muted{color:var(--muted)}.admin-content a.admin-overview-card[style*="border:"],.admin-overview-card{border-radius:16px!important}.admin-overview-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)!important;border-color:var(--border-strong)!important}.admin-content h1{font-size:1.75rem;letter-spacing:-.02em;margin-bottom:.25rem}.admin-content h2{font-size:1.05rem;font-weight:700}.admin-content a[style*="#6ea8ff"],.admin-content a[style*="rgba(110,168,255"]{color:var(--fg)!important;border-color:var(--border-strong)!important;background:var(--surface)!important;border-radius:999px!important;font-weight:500!important;box-shadow:var(--shadow-sm)!important}.admin-content a[style*="#6ea8ff"]:hover,.admin-content a[style*="rgba(110,168,255"]:hover{background:var(--black)!important;color:#fff!important;border-color:var(--black)!important}.admin-content a[style*="border:"]{border-radius:999px!important}.admin-sidebar-item,.admin-sidebar-item:hover{text-decoration:none}.admin-sidebar-item:hover .admin-sidebar-icon{background:var(--black)!important;color:#fff!important;border-color:var(--black)!important;transform:translateY(-1px);box-shadow:var(--shadow)}.admin-sidebar-item:hover>span:last-child{color:var(--fg-strong)!important;font-weight:700!important}.icon-btn{display:inline-flex;align-items:center;justify-content:center;position:relative;width:38px;height:38px;border-radius:999px;background:var(--surface);border:1px solid var(--border);color:var(--fg-strong);text-decoration:none;transition:all .15s ease;box-shadow:var(--shadow-sm);flex-shrink:0}.icon-btn:hover{background:var(--black);color:#fff;border-color:var(--black);text-decoration:none;transform:translateY(-1px);box-shadow:var(--shadow)}.icon-btn svg{width:18px;height:18px}.icon-btn-dot{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;padding:0 5px;background:#ef4444;color:#fff;border:2px solid var(--surface);border-radius:999px;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.data-table a.row-action,.data-table button.row-action,.row-action,a.row-action,button.row-action{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-width:82px;height:30px;padding:0 13px;margin:0;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--fg-strong);font-family:inherit!important;font-size:.78rem!important;font-weight:600!important;font-style:normal!important;letter-spacing:.01em!important;text-decoration:none;cursor:pointer;line-height:1!important;transition:all .12s ease;box-sizing:border-box;vertical-align:middle}.row-action:hover{background:var(--black);color:#fff;border-color:var(--black);text-decoration:none}.row-action svg{width:13px;height:13px;flex-shrink:0}.row-action--lg,a.row-action--lg,button.row-action--lg{height:36px;min-width:0;padding:0 16px;gap:7px;font-size:.85rem!important}.row-action--lg svg{width:15px;height:15px}.row-action--danger{background:rgba(196,56,56,.14)!important;color:#c43838!important;border-color:rgba(196,56,56,.45)!important}.row-action--danger:hover{background:#c43838!important;border-color:#c43838!important;color:#fff!important}.row-action--success{background:rgba(31,138,76,.14)!important;color:#1f8a4c!important;border-color:rgba(31,138,76,.45)!important}.row-action--success:hover{background:#1f8a4c!important;border-color:#1f8a4c!important;color:#fff!important}.row-action--warning{background:rgba(245,158,11,.18)!important;color:#b97800!important;border-color:rgba(185,120,0,.45)!important}.row-action--warning:hover{background:#b97800!important;border-color:#b97800!important;color:#fff!important}.row-action--info{background:rgba(91,163,245,.18)!important;color:#1f5fab!important;border-color:rgba(91,163,245,.5)!important}.row-action--info:hover{background:#1f5fab!important;border-color:#1f5fab!important;color:#fff!important}.stripe-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:.55rem 1.1rem;border:1px solid var(--border-strong);border-radius:999px;background:repeating-linear-gradient(45deg,#f4f4f4,#f4f4f4 5px,#ffffff 0,#ffffff 8px);color:var(--fg);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;box-shadow:var(--shadow-sm);transition:all .14s ease}.stripe-button:hover{background:repeating-linear-gradient(45deg,#eaeaea,#eaeaea 5px,#fafafa 0,#fafafa 8px);border-color:var(--border-strong);box-shadow:var(--shadow)}.stripe-button svg{width:14px;height:14px;flex-shrink:0}.confirm-dialog{border:0;border-radius:28px;padding:0;background:var(--surface);color:var(--fg-strong);box-shadow:0 24px 60px rgba(8,15,30,.2),0 8px 16px rgba(0,0,0,.08);width:min(92vw,460px)!important;max-width:min(92vw,460px)!important;min-width:0!important;box-sizing:border-box;overflow:visible;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0}.confirm-dialog::-webkit-backdrop{background:rgba(13,20,35,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-dialog::backdrop{background:rgba(13,20,35,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-dialog[open]{animation:confirm-dialog-pop .16s ease-out}@keyframes confirm-dialog-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.confirm-dialog-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:999px;background:transparent;border:0;cursor:pointer;color:var(--fg);display:inline-flex;align-items:center;justify-content:center;transition:background .12s ease}.confirm-dialog-close:hover{background:var(--surface-hover)}.confirm-dialog-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:40px auto 0;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);color:var(--fg-strong);box-shadow:var(--shadow-sm)}.confirm-dialog-icon[data-variant=danger]{background:rgba(196,56,56,.1);border-color:rgba(196,56,56,.22);color:#c43838;box-shadow:0 4px 12px rgba(196,56,56,.12)}.confirm-dialog-icon[data-variant=success]{background:rgba(31,138,76,.1);border-color:rgba(31,138,76,.25);color:#1f8a4c;box-shadow:0 4px 12px rgba(31,138,76,.12)}.confirm-dialog-icon[data-variant=default]{background:var(--surface-2);border-color:var(--border);color:var(--fg-strong);box-shadow:var(--shadow-sm)}.confirm-dialog-message{margin:18px 32px 24px;max-width:calc(100% - 64px);box-sizing:border-box;text-align:center;font-size:1.05rem;font-weight:600;line-height:1.4;color:var(--fg-strong);overflow-wrap:anywhere;word-break:break-word}.confirm-dialog-actions{display:flex;gap:12px;padding:0 24px 28px}.confirm-dialog-cancel,.confirm-dialog-confirm{flex:1 1;height:44px;border-radius:999px;border:0;font-size:.95rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .12s ease}.confirm-dialog-cancel{background:transparent;color:var(--fg);border:1px solid var(--border)}.confirm-dialog-cancel:hover{background:var(--surface-hover)}.confirm-dialog-confirm{background:var(--black);color:#fff}.confirm-dialog-confirm:hover{background:#2a2a2a}.confirm-dialog-confirm--danger{background:var(--black);color:#fff}.confirm-dialog-confirm--danger:hover{background:#2a2a2a}.confirm-dialog-confirm--success{background:#1f8a4c}.confirm-dialog-confirm--success:hover{background:#176837}.confirm-dialog-cancel:disabled,.confirm-dialog-confirm:disabled{opacity:.6;cursor:not-allowed}.filter-bar{display:flex;gap:.6rem;align-items:flex-end;flex-wrap:wrap;margin-top:1rem;padding:.85rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.filter-input,input.filter-input,select.filter-input{height:36px!important;padding:0 14px!important;border:1px solid var(--border)!important;border-radius:999px!important;background:var(--surface)!important;color:var(--fg-strong)!important;font-family:inherit!important;font-size:.85rem!important;font-weight:500!important;line-height:1!important;box-sizing:border-box!important;transition:border-color .12s ease,box-shadow .12s ease;outline:none}.filter-input:focus{border-color:var(--fg-strong)!important;box-shadow:0 0 0 3px rgba(0,0,0,.05)}input.filter-input::placeholder{color:#a0a0a0;font-weight:400}input.filter-input[type=date]{padding-right:10px!important}.role-badge{display:inline-block;background:var(--black);color:#fff;padding:.22em .95em;border-radius:var(--radius-pill);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700;min-width:110px;text-align:center;box-sizing:border-box}.small-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:999px;font-size:.72rem;font-weight:600;line-height:1.4;white-space:nowrap;background:var(--surface-hover,#f4f7fb);color:var(--fg);border:1px solid transparent}.small-pill[data-tint=success]{background:var(--card-mint);color:#1f8a4c}.small-pill[data-tint=info]{background:var(--card-blue);color:#1f5fab}.small-pill[data-tint=warning]{background:var(--card-yellow);color:#9a6f00}.small-pill[data-tint=danger]{background:var(--card-pink);color:#c43838}.small-pill[data-tint=muted]{background:var(--surface-hover);color:var(--muted)}.role-badge[data-tint=admin]{background:#1a1a1a;color:#fff}.role-badge[data-tint=manager]{background:var(--card-yellow);color:#9a6f00}.role-badge[data-tint=office]{background:var(--card-blue);color:#1f5fab}.role-badge[data-tint=hr]{background:var(--card-mint);color:#1f8a4c}.role-badge[data-tint=foreman]{background:var(--card-peach);color:#b97800}.role-badge[data-tint=inspector]{background:var(--card-lavender);color:#6b3fb3}.role-badge[data-tint=active],.role-badge[data-tint=approved],.role-badge[data-tint=done],.role-badge[data-tint=green],.role-badge[data-tint=signed]{background:var(--card-mint);color:#1f8a4c}.role-badge[data-tint=auto-draft],.role-badge[data-tint=in_progress],.role-badge[data-tint=on_hold],.role-badge[data-tint=pending],.role-badge[data-tint=submitted],.role-badge[data-tint=warning],.role-badge[data-tint=yellow]{background:var(--card-yellow);color:#9a6f00}.role-badge[data-tint=draft]{background:var(--surface-hover);color:var(--muted);border:1px solid var(--border)}.role-badge[data-tint=info]{background:var(--card-blue);color:#1f5fab}.role-badge[data-tint=critical]{background:var(--card-pink);color:#c43838}.data-table tr[data-urgency=critical] td:first-child{box-shadow:inset 4px 0 0 var(--danger)}.data-table tr[data-urgency=warning] td:first-child{box-shadow:inset 4px 0 0 var(--warning)}.data-table tr[data-urgency=info] td:first-child{box-shadow:inset 4px 0 0 var(--accent-blue)}.data-table tr[data-urgency=success] td:first-child{box-shadow:inset 4px 0 0 var(--success)}.action-card{--accent-color:var(--muted-2);display:flex;align-items:center;gap:.85rem;padding:.85rem 1.1rem;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-decoration:none;color:var(--fg-strong);transition:transform .14s ease,box-shadow .14s ease,background .14s ease,border-left-width .14s ease}.action-card:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-left-width:5px;background:color-mix(in srgb,var(--accent-color) 6%,var(--surface))}.action-card:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.role-badge[data-tint=cancelled],.role-badge[data-tint=closed],.role-badge[data-tint=ended],.role-badge[data-tint=snoozed]{background:var(--surface-hover);color:var(--fg)}.role-badge[data-tint=open]{background:var(--card-blue);color:#1f5fab}.role-badge[data-tint=blocked],.role-badge[data-tint=red],.role-badge[data-tint=rejected]{background:var(--card-pink);color:#c43838}.role-badge[data-tint=orange]{background:var(--card-peach);color:#c2410c}.role-badge[data-tint=planned]{background:var(--card-lavender);color:#6b3fb3}.link-button{background:none;border:0;color:var(--fg);cursor:pointer;font:inherit;padding:0;text-decoration:underline;transition:color .12s}.link-button:hover{color:var(--accent-blue)}.app-main{flex:1 1;max-width:1280px;width:100%;margin:0 auto;padding:2.5rem 2rem 1.5rem}.app-footer{padding:1.25rem 2rem;text-align:center;font-size:.78rem;color:var(--muted);border-top:1px solid var(--border);background:rgba(255,255,255,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn,button[type=submit]:not(.link-button):not(.row-action):not(.stripe-button):not(.btn-primary){display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:1px solid var(--border-strong);border-radius:var(--radius-pill);background:var(--surface);color:var(--fg);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease;box-shadow:var(--shadow-sm)}.btn:hover,button[type=submit]:not(.link-button):not(.row-action):not(.stripe-button):not(.btn-primary):hover{background:var(--surface-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:40px;padding:.55rem 1.4rem;border:1px solid var(--black);border-radius:var(--radius-pill);background:var(--black);color:#fff;font-family:inherit;font-size:.92rem;font-weight:600;line-height:1;text-decoration:none;cursor:pointer;box-sizing:border-box;box-shadow:var(--shadow-sm);transition:all .15s ease}.btn-primary:hover{background:var(--black-soft);border-color:var(--black-soft);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:40px;padding:.55rem 1.4rem;border:1px solid var(--border-strong);border-radius:var(--radius-pill);background:var(--surface);color:var(--fg);font-family:inherit;font-size:.92rem;font-weight:500;line-height:1;text-decoration:none;cursor:pointer;box-sizing:border-box;box-shadow:var(--shadow-sm);transition:all .15s ease}.btn-secondary:hover{background:var(--surface-hover);transform:translateY(-1px);box-shadow:var(--shadow)}.form-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding-top:1rem;margin-top:.25rem;border-top:1px solid var(--border)}.btn-primary:focus-visible,.btn-secondary:focus-visible,.row-action:focus-visible,.stripe-button:focus-visible{outline:2px solid #1f5fab;outline-offset:2px}.btn-danger{border-color:rgba(239,68,68,.4);color:var(--danger)}.btn-danger:hover{background:rgba(239,68,68,.08);border-color:var(--danger)}input[type=date],input[type=email],input[type=month],input[type=number],input[type=password],input[type=search],input[type=text],input[type=time],input[type=url],select,textarea{background:var(--surface);color:var(--fg);border:1px solid var(--border-strong);border-radius:var(--radius-pill);padding:.5rem .95rem;font:inherit;font-size:.9rem;transition:all .15s;box-shadow:var(--shadow-sm);min-width:0}textarea{border-radius:var(--radius);font-family:inherit}select{cursor:pointer;padding-right:2rem}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--black);box-shadow:0 0 0 3px rgba(0,0,0,.06)}input[type=checkbox],input[type=radio]{accent-color:var(--black);width:16px;height:16px;cursor:pointer}label.muted{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;color:var(--muted)}fieldset{border:0;border-radius:var(--radius-lg);padding:1.75rem 2rem;margin:0;background:var(--surface);box-shadow:var(--shadow)}fieldset legend{padding:0 .75rem;font-weight:700;font-size:1rem;color:var(--fg-strong);letter-spacing:-.005em}.data-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:1rem;font-size:.88rem;background:var(--surface);border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 1px 2px rgba(15,16,17,.03)}.data-table td,.data-table th{text-align:left;padding:1.15rem 1.25rem;line-height:1.4}.data-table th{padding-top:.95rem;padding-bottom:.95rem}.data-table td{border-bottom:1px solid rgba(0,0,0,.05);vertical-align:middle}.data-table thead{background:#fafafa}.data-table th{font-weight:500;color:#6b6b6b;font-size:.78rem;text-transform:none;letter-spacing:normal;background:transparent;border-bottom:1px solid rgba(0,0,0,.06);line-height:1.2}.data-table td:first-child,.data-table th:first-child{padding-left:1.5rem}.data-table td:last-child,.data-table th:last-child{padding-right:1.5rem}.data-table tbody tr{transition:background .14s ease}.data-table tbody tr:hover td{background:rgba(91,163,245,.04)}.data-table tbody tr:last-child td{border-bottom:0}.data-table a{color:var(--fg);font-weight:500}.data-table a:hover,.doc-card{color:var(--fg-strong);text-decoration:none}.doc-card{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto 1fr;grid-column-gap:.85rem;column-gap:.85rem;grid-row-gap:.85rem;row-gap:.85rem;padding:1.1rem 1.25rem;border-radius:18px;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease;height:132px;background:#ececec}.doc-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px -8px rgba(0,0,0,.18);text-decoration:none;filter:brightness(1.02)}.doc-card[data-fmt=pdf]{background:#fffdf6;color:#4a1d10}.doc-card[data-fmt=pdf] .doc-card-icon{color:#c43838}.doc-card[data-fmt=docx]{background:#f7fafd;color:#142e54}.doc-card[data-fmt=docx] .doc-card-icon{color:#1f5fab}.doc-card[data-fmt=xlsx]{background:#f7fbf7;color:#16401e}.doc-card[data-fmt=xlsx] .doc-card-icon{color:#1f8a4c}.doc-card-icon{grid-column:1;grid-row:1;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px}.doc-card-icon svg{width:28px;height:28px;stroke-width:1.6}.doc-card-check{grid-column:3;grid-row:1;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1.5px solid;opacity:.45;transition:opacity .12s ease}.doc-card:hover .doc-card-check{opacity:.85}.doc-card-title{grid-column:1/-1;grid-row:2;align-self:end;font-size:1.05rem;font-weight:700;line-height:1.25;color:inherit;word-break:break-word}.viewer-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);color:#fff!important;border-radius:999px;font-size:.82rem;font-weight:500;font-family:inherit;cursor:pointer;text-decoration:none;transition:background .12s}.viewer-btn svg{display:block;flex-shrink:0}.viewer-btn:hover{background:rgba(255,255,255,.18)}.viewer-btn--close{background:rgba(196,56,56,.18);border-color:rgba(196,56,56,.45)}.viewer-btn--close:hover{background:rgba(196,56,56,.32)}.empty-state{margin-top:2rem;padding:3rem 2rem 2.5rem;border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;color:var(--muted);background:radial-gradient(circle at 50% 0,var(--card-blue) 0,transparent 55%),var(--surface);box-shadow:var(--shadow-sm);position:relative}.empty-state:before{content:"";display:block;width:48px;height:48px;margin:0 auto 1rem;border-radius:999px;background:var(--card-blue);border:1px solid rgba(91,163,245,.25);box-shadow:0 0 0 6px color-mix(in srgb,var(--accent-blue) 8%,transparent)}.empty-state p{margin:0;font-size:.95rem;color:var(--muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;transition:all .15s}.card,.card:hover{box-shadow:var(--shadow)}.card:hover{transform:translateY(-1px)}.card-peach{background:var(--card-peach)}.card-blue{background:var(--card-blue)}.card-mint{background:var(--card-mint)}.card-lavender{background:var(--card-lavender)}dialog{background:var(--surface);color:var(--fg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:0}dialog::-webkit-backdrop{background:rgba(0,0,0,.35);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}dialog::backdrop{background:rgba(0,0,0,.35);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}::selection{background:var(--black);color:#fff}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.28)}a[style*="var(--accent)"],button[type=submit][style*="var(--accent)"]{background:var(--surface)!important;color:var(--fg-strong)!important;border:1px solid var(--border-strong)!important;border-radius:var(--radius-pill)!important;font-weight:500!important;box-shadow:var(--shadow-sm)!important;transition:all .15s ease!important}a[style*="var(--accent)"]:hover,button[type=submit][style*="var(--accent)"]:hover{background:var(--black)!important;color:#fff!important;border-color:var(--black)!important;text-decoration:none!important}form a[style*="border: 1px solid"][href^="/"]{border-radius:var(--radius-pill)!important}section[style*=border-top]{border-top:1px solid var(--border)!important}[style*="rgba(255, 255, 255, 0.02)"],[style*="rgba(255, 255, 255, 0.03)"],[style*="rgba(255, 255, 255, 0.04)"],[style*="rgba(255, 255, 255, 0.05)"],[style*="rgba(255,255,255,0.02)"],[style*="rgba(255,255,255,0.03)"],[style*="rgba(255,255,255,0.04)"],[style*="rgba(255,255,255,0.05)"]{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-sm)!important}section h2+div[style*=grid]>div[style*=border]{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow-sm)!important}@media (max-width:800px){.login-grid{grid-template-columns:1fr!important}.login-visual{display:none!important}.login-form-logo{display:block!important}}input.attendance-num::-webkit-inner-spin-button,input.attendance-num::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input.attendance-num{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.mobile-menu-trigger{display:none;position:relative;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--border,rgba(0,0,0,.1));border-radius:12px;background:var(--surface,white);color:var(--fg,#111);cursor:pointer;flex-shrink:0;margin-left:auto}.mobile-menu-trigger:active{background:rgba(0,0,0,.04)}.mobile-menu-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--accent-red,#a01f23);border:2px solid var(--surface,white)}.mobile-menu-dialog{padding:0;border:none;margin:0;width:100vw;max-width:100%;height:100dvh;max-height:100dvh;background:transparent;color:var(--fg);overflow:hidden}.mobile-menu-dialog::-webkit-backdrop{background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-menu-dialog::backdrop{background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mobile-menu-content{background:var(--surface,white);width:min(360px,92vw);height:100%;display:flex;flex-direction:column;padding:0;animation:mobileMenuSlideIn .22s cubic-bezier(.32,.72,0,1);box-shadow:4px 0 24px rgba(0,0,0,.12);overflow-y:auto}@keyframes mobileMenuSlideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border,rgba(0,0,0,.08));position:-webkit-sticky;position:sticky;top:0;background:var(--surface,white);z-index:1}.mobile-menu-brand img{height:32px!important;width:auto!important}.mobile-menu-close{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border,rgba(0,0,0,.1));border-radius:10px;color:var(--fg);cursor:pointer}.mobile-menu-close:active{background:rgba(0,0,0,.04)}.mobile-menu-user{padding:14px 20px;font-size:.9rem;font-weight:600;color:var(--fg)}.mobile-menu-nav,.mobile-menu-user{border-bottom:1px solid var(--border,rgba(0,0,0,.08))}.mobile-menu-nav{padding:12px 16px}.mobile-menu-nav .nav-strip{flex-direction:column;align-items:stretch;gap:4px}.mobile-menu-nav .nav-strip a{width:100%;justify-content:flex-start;padding:12px 14px!important;border-radius:10px;font-size:.95rem}.mobile-menu-nav .subnav-strip{margin-top:8px!important;padding-left:12px!important;border-left:2px solid var(--border,rgba(0,0,0,.08))}.mobile-menu-actions{display:flex;flex-direction:column;padding:12px 16px;gap:2px;border-bottom:1px solid var(--border,rgba(0,0,0,.08));flex:1 1}.mobile-menu-action{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;text-decoration:none;color:var(--fg);font-size:.92rem;position:relative}.mobile-menu-action:active{background:rgba(0,0,0,.04)}.mobile-menu-action svg{flex-shrink:0;opacity:.7}.mobile-menu-badge{margin-left:auto;background:var(--accent-red,#a01f23);color:white;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:999px;min-width:22px;text-align:center}.mobile-menu-locale{pointer-events:none}.mobile-menu-locale>*{pointer-events:auto}.mobile-menu-locale .icon-btn{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center}.mobile-menu-logout-form{padding:16px 20px calc(24px + env(safe-area-inset-bottom))}.mobile-menu-logout{width:100%;padding:14px;background:transparent;border:1px solid var(--accent-red,#a01f23);color:var(--accent-red,#a01f23);border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer}.mobile-menu-logout:active{background:rgba(160,31,35,.06)}@media (max-width:768px){.mobile-menu-trigger{display:inline-flex}.app-header>.desktop-only{display:none!important}.app-header{padding:.6rem 1rem!important;gap:.75rem!important}.app-header .brand img{height:32px!important}.data-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;font-size:.8rem}.data-table td,.data-table th{padding:.6rem .7rem!important;white-space:nowrap}.data-table td.muted{white-space:normal;word-break:break-word}.app-main{padding:1.25rem 1rem 1rem!important}}.salary-pin-modal{padding:0;border:none;border-radius:16px;background:transparent;max-width:460px;width:min(92vw,460px)}.salary-pin-modal::-webkit-backdrop{background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.salary-pin-modal::backdrop{background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.salary-pin-modal-content{background:var(--surface,white);border-radius:16px;padding:1.5rem 1.5rem 1.25rem;color:var(--fg);box-shadow:0 12px 32px rgba(0,0,0,.18)}@media (max-width:640px){.procedure-row{display:flex!important;flex-direction:column;gap:6px!important}.procedure-row>div{width:100%}.procedure-row>div:first-child{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.procedure-row>div:nth-child(4){position:absolute;right:.75rem;top:.55rem;text-align:right!important}.procedure-row{position:relative}.procedure-row>div:nth-child(2),.procedure-row>div:nth-child(3){display:inline-block}.procedure-row>div:nth-child(2){width:calc(100% - 110px);padding-right:8px;vertical-align:middle}.procedure-row>div:nth-child(3){width:110px;vertical-align:middle}}@media (hover:none){.action-card:hover,.icon-btn:hover,.nav-strip a:hover,.row-action:hover{background:inherit!important}}