:root{--t-navy:#345778;--t-navy-dark:#1f3448;--t-navy-700:#2a465f;--t-lime:#828133;--t-lime-light:#ccd465;--t-charcoal:#21222d;--t-body:#475569;--t-muted:#94a3b8;--t-line:#e7ebf0;--t-bg:#ffffff;--t-bg-soft:#f6f8fa;--t-success:#28a745;--t-danger:#dc3545;--t-warning:#f0ad4e;--t-font:"Open Sans","Noto Sans TC",Segoe,"Segoe UI",sans-serif;--t-radius:10px;--t-shadow:0 1px 3px rgba(33,34,45,.08),0 1px 2px rgba(33,34,45,.06)}*{box-sizing:border-box}body{margin:0;font-family:var(--t-font);color:var(--t-body);background:var(--t-bg-soft);font-size:14px}h1,h2,h3,h4{color:var(--t-charcoal);margin:0 0 .4em}a{color:var(--t-navy)}button{font-family:inherit}.shell{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--t-navy);color:#dde6ef;display:flex;flex-direction:column;flex-shrink:0}.sidebar .brand{padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.12)}.sidebar .brand img{height:30px;display:block}.sidebar nav{padding:10px 8px;display:flex;flex-direction:column;gap:2px}.sidebar nav a{color:#c6d3e1;text-decoration:none;padding:10px 14px;border-radius:8px;font-weight:500;font-size:13.5px}.sidebar nav a:hover{background:#ffffff14;color:#fff}.sidebar nav a.active{background:var(--t-lime);color:#fff}.sidebar .spacer{flex:1}.sidebar .me{padding:14px 18px;border-top:1px solid rgba(255,255,255,.12);font-size:12.5px;color:#9fb2c6}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:58px;background:#fff;border-bottom:1px solid var(--t-line);display:flex;align-items:center;padding:0 24px;gap:14px}.topbar h2{font-size:17px;margin:0}.content{padding:24px;max-width:1100px;width:100%}.card{background:#fff;border:1px solid var(--t-line);border-radius:var(--t-radius);box-shadow:var(--t-shadow);padding:18px;margin-bottom:18px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}table{border-collapse:collapse;width:100%;font-size:13.5px}th,td{border-bottom:1px solid var(--t-line);padding:9px 10px;text-align:left;vertical-align:middle}th{color:var(--t-muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:var(--t-bg-soft)}.btn{border:none;border-radius:8px;padding:9px 16px;font-weight:600;font-size:13.5px;cursor:pointer}.btn.primary{background:var(--t-navy);color:#fff}.btn.primary:hover{background:var(--t-navy-dark)}.btn.accent{background:var(--t-lime);color:#fff}.btn.ghost{background:#fff;border:1px solid var(--t-line);color:var(--t-charcoal)}.btn.danger{background:var(--t-danger);color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.sm{padding:6px 11px;font-size:12.5px}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}.badge.submitted{background:#e0f2fe;color:#075985}.badge.approved,.badge.paid{background:#dcfce7;color:#166534}.badge.mgr_approved{background:#fef9c3;color:#854d0e}.badge.rejected,.badge.cancelled{background:#fee2e2;color:#991b1b}label{display:block;font-size:12.5px;color:var(--t-charcoal);font-weight:600;margin:10px 0 4px}input,select,textarea{width:100%;padding:9px 11px;border:1px solid var(--t-line);border-radius:8px;font-family:inherit;font-size:13.5px}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--t-navy)}.row{display:flex;gap:12px;flex-wrap:wrap}.row>*{flex:1;min-width:140px}.err{color:var(--t-danger);font-size:13px;margin:8px 0}.muted{color:var(--t-muted)}.stat{font-size:30px;font-weight:800;color:var(--t-navy)}.stat-label{font-size:12.5px;color:var(--t-muted);text-transform:uppercase;letter-spacing:.03em}.auth{display:flex;min-height:100vh}.auth-hero{flex:1.15;background:linear-gradient(135deg,#1b2e40,#345778 58%,#2a465f);color:#fff;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:60px 64px}.auth-hero:before{content:"";position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(204,212,101,.2),transparent 70%);top:-180px;right:-140px}.auth-hero:after{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%);bottom:-140px;left:-90px}.auth-hero .top img{height:48px;position:relative;z-index:1}.auth-hero .headline{position:relative;z-index:1}.auth-hero .headline h1{font-size:46px;line-height:1.12;font-weight:800;color:#fff;margin:0 0 18px;letter-spacing:-.01em}.auth-hero .headline h1 .accent{color:var(--t-lime-light)}.auth-hero .headline p{font-size:17.5px;line-height:1.7;color:#c6d3e1;max-width:48ch;font-weight:300}.auth-hero .headline .rule{width:54px;height:4px;background:var(--t-lime);border-radius:3px;margin:26px 0}.auth-hero .cities{position:relative;z-index:1;font-size:12.5px;color:#9fb2c6;letter-spacing:.08em;font-weight:600}.auth-hero .cities .dot{color:var(--t-lime-light);margin:0 9px}.auth-form-side{flex:.85;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.auth-form{width:350px;max-width:100%}.auth-form h2{font-size:28px;margin-bottom:6px}.auth-form .sub{color:var(--t-muted);margin-bottom:10px;font-size:14.5px}.auth-form input{padding:12px 14px;font-size:15px}.auth-form .btn{padding:13px;font-size:15.5px;width:100%;margin-top:26px}.auth-mini-logo{display:none}@media (max-width:880px){.auth-hero{display:none}.auth-form-side{flex:1}.auth-mini-logo{display:block;background:var(--t-navy);border-radius:10px;padding:14px;text-align:center;margin-bottom:22px}.auth-mini-logo img{height:30px}}.sig-canvas{border:1px dashed var(--t-line);border-radius:8px;background:#fff;touch-action:none;width:100%;height:160px}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#21222d80;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:12px;padding:22px;width:440px;max-width:92vw}
