*,: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;--header-h:60px;--content-max:900px;--side-pad:20px}html{-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;font-size:15px;line-height:1.6;min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased}button{cursor:pointer;border:none;outline:none;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;text-align:center;line-height:1}input,select,textarea{font-family:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:15px;width:100%;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,142,247,.15)}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238b92b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}textarea{resize:vertical;min-height:80px;line-height:1.5}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app-header{background:var(--surface);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:100;height:var(--header-h)}.app-header-inner{max-width:var(--content-max);margin:0 auto;padding:0 var(--side-pad);height:100%;display:flex;align-items:center;gap:12px}.app-logo{font-size:22px;line-height:1;flex-shrink:0}.app-title{font-size:16px;font-weight:700;letter-spacing:-.2px;color:var(--text);white-space:nowrap;flex-shrink:0}.app-main{max-width:var(--content-max);width:100%;margin:0 auto;padding:28px var(--side-pad) 100px;display:flex;flex-direction:column;gap:24px;flex:1 1}.app-nav{display:flex;align-items:center;gap:2px;margin-left:auto;flex-shrink:0}.nav-link{padding:7px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:background .15s,color .15s;white-space:nowrap;display:inline-flex;align-items:center}.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)}.nav-link-platform{border:1px solid rgba(251,191,36,.3);color:#fbbf24!important}.nav-link-platform:hover{background:rgba(251,191,36,.1)!important}.nav-link-platform.active{background:rgba(251,191,36,.15)!important;border-color:rgba(251,191,36,.5)}.nav-user{display:flex;align-items:center;gap:8px;margin-left:8px;padding-left:12px;border-left:1px solid var(--border)}.nav-user-name{font-size:13px;font-weight:600;color:var(--text-muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-role-chip{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:capitalize;white-space:nowrap}.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:18px;cursor:pointer;padding:4px 6px;border-radius:6px;transition:color .15s,background .15s;display:inline-flex;align-items:center;justify-content:center;line-height:1}.nav-logout:hover{color:var(--danger);background:rgba(248,113,113,.1)}.nav-hamburger{display:none;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:var(--radius-sm);margin-left:auto;flex-direction:column;gap:5px;align-items:center;justify-content:center}.nav-hamburger span{display:block;width:20px;height:2px;background:currentColor;border-radius:2px;transition:transform .2s,opacity .2s}.nav-drawer{display:none;position:fixed;inset:0;z-index:200}.nav-drawer-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.nav-drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(280px,85vw);background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;padding:24px 20px;gap:6px;overflow-y:auto}.nav-drawer-close{align-self:flex-end;background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;padding:4px 8px;border-radius:6px;margin-bottom:12px}.nav-drawer-link{display:flex;align-items:center;padding:12px 16px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:background .15s,color .15s}.nav-drawer-link:hover{background:var(--surface-2);color:var(--text)}.nav-drawer-link.active{background:rgba(79,142,247,.15);color:var(--accent)}.nav-drawer-divider{height:1px;background:var(--border);margin:8px 0}.nav-drawer-user{display:flex;align-items:center;gap:10px;margin-top:auto;border-top:1px solid var(--border);padding:16px 16px 12px}.nav-drawer-name{flex:1 1;overflow:hidden;text-overflow:ellipsis}.btn,.nav-drawer-name{font-size:14px;font-weight:600;white-space:nowrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);line-height:1;text-align:center;transition:background .15s,opacity .15s,transform .1s,box-shadow .15s;cursor:pointer;border:none;text-decoration:none}.btn:active:not(:disabled){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:14px 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;display:inline;line-height:inherit}.btn-link:hover{color:var(--accent-hover)}.error-banner{background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.4);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:18px;padding:0 4px;flex-shrink:0}.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:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}@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}.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius)}@media (max-width:768px){:root{--side-pad:16px}.app-title{font-size:15px}.app-nav{display:none}.nav-hamburger{display:flex}.app-main{padding:20px var(--side-pad) 80px;gap:20px}}@media (max-width:480px){:root{--side-pad:14px}body{font-size:14px}.app-title{display:none}.app-main{padding:16px var(--side-pad) 72px;gap:16px}}.nav-drawer.open{display:block}