*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--surface:#1a1d27;--surface-2:#22263a;--border:#2e3250;--accent:#4f8ef7;--accent-hover:#6ba3ff;--success:#34d399;--warning:#fbbf24;--danger:#f87171;--text:#e8eaf6;--text-muted:#8b92b8;--radius:12px;--radius-sm:8px}body{background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.6;min-height:100vh}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select,textarea{font-family:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;width:100%;transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}textarea{resize:vertical;min-height:64px}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.app-header-inner{max-width:860px;margin:0 auto;display:flex;align-items:center;gap:12px}.app-logo{font-size:26px}.app-title{font-size:20px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.app-main{max-width:860px;width:100%;margin:0 auto;padding:32px 24px 80px;display:flex;flex-direction:column;gap:28px}.app-nav{display:flex;gap:4px;margin-left:auto}.nav-link{padding:6px 14px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{background:var(--surface-2);color:var(--text)}.nav-link.active{background:rgba(79,142,247,.15);color:var(--accent)}.nav-link-eos{border:1px solid rgba(129,140,248,.3);color:#818cf8!important}.nav-link-eos:hover{background:rgba(129,140,248,.1)!important}.nav-link-eos.active{background:rgba(129,140,248,.15)!important;border-color:rgba(129,140,248,.5)}.nav-link-admin{border:1px solid rgba(52,211,153,.3);color:#34d399!important}.nav-link-admin:hover{background:rgba(52,211,153,.1)!important}.nav-link-admin.active{background:rgba(52,211,153,.15)!important;border-color:rgba(52,211,153,.5)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:background .15s,opacity .15s,transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-success{background:var(--success);color:#0f1117}.btn-success:hover:not(:disabled){opacity:.88}.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn-danger:hover:not(:disabled){background:rgba(248,113,113,.1)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:13px 28px;font-size:15px}.btn-link{background:none;border:none;color:var(--accent);font-size:13px;font-weight:600;padding:0;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.btn-link:hover{color:var(--accent-hover)}.error-banner{background:rgba(248,113,113,.12);border:1px solid var(--danger);border-radius:var(--radius-sm);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--danger);font-size:14px}.error-dismiss{background:none;color:var(--danger);font-size:16px;padding:0 4px;line-height:1}.processing-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:60px 24px;display:flex;flex-direction:column;align-items:center;gap:20px}.spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.processing-label{color:var(--text-muted);font-size:15px}.done-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:48px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.done-icon{font-size:40px}.done-title{font-size:22px;font-weight:700}.done-sub{color:var(--text-muted);font-size:14px;margin-bottom:12px}.done-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:center}.approver-row{display:flex;flex-direction:column;gap:6px}.approver-label{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.approver-input{max-width:320px}.nav-user{display:flex;align-items:center;gap:8px;margin-left:8px;padding-left:8px;border-left:1px solid var(--border)}.nav-user-name{font-size:13px;font-weight:600;color:var(--text-muted)}.nav-role-chip{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;text-transform:capitalize}.nav-role-owner{background:rgba(52,211,153,.15);color:#34d399;border:1px solid rgba(52,211,153,.3)}.nav-role-employee{background:rgba(79,142,247,.15);color:var(--accent);border:1px solid rgba(79,142,247,.3)}.nav-logout{background:none;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s}.nav-logout:hover{color:var(--danger)}.auth-page+*{display:none}