@import"https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Syne:wght@700;800&family=Outfit:wght@300;400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #080c12;--bg-card: #0b111a;--bg-raised: #0d1622;--border: #1a2535;--border-sub: #131d2b;--text-primary: #e2e8f0;--text-muted: #64748b;--text-dim: #475569;--text-faint: #334155;--amber: #f59e0b;--green: #4ade80;--green2: #22c55e;--blue: #38bdf8;--blue2: #0ea5e9;--orange: #fb923c;--red: #f87171;--purple: #c084fc;--amber-bg: rgba(245, 158, 11, .12);--green-bg: rgba(74, 222, 128, .12);--green2-bg: rgba(34, 197, 94, .12);--blue-bg: rgba(56, 189, 248, .12);--orange-bg: rgba(251, 146, 60, .12);--red-bg: rgba(248, 113, 113, .12);--purple-bg: rgba(192, 132, 252, .12);--font-display: "Bebas Neue", sans-serif;--font-head: "Syne", sans-serif;--font-body: "Outfit", sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--max-w: 480px}html,body,#root{height:100%;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);-webkit-font-smoothing:antialiased;overscroll-behavior:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.app-shell{max-width:var(--max-w);margin:0 auto;min-height:100%;display:flex;flex-direction:column;padding-bottom:48px}.top-bar{background:var(--bg-card);border-bottom:1px solid var(--border);padding:14px 20px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.top-bar-title{font-family:var(--font-head);font-size:18px;font-weight:800}.top-bar-sub{font-size:12px;color:var(--text-muted);text-align:right}.clock{font-family:var(--font-display);font-size:32px;letter-spacing:2px;color:var(--amber);line-height:1}.section{margin:20px 16px 0}.section-title{font-family:var(--font-head);font-size:10px;text-transform:uppercase;letter-spacing:4px;color:var(--text-faint);margin-bottom:12px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-row{padding:13px 16px;border-bottom:1px solid var(--border-sub);display:flex;justify-content:space-between;align-items:center}.card-row:last-child{border-bottom:none}.card-label{font-size:13px;color:var(--text-muted)}.card-value{font-family:var(--font-display);font-size:22px;letter-spacing:.5px}.field{padding:12px 16px;border-bottom:1px solid var(--border-sub)}.field:last-child{border-bottom:none}.field-label{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin-bottom:6px;display:flex;align-items:center;gap:4px}.field-required{color:var(--red);font-size:12px}.field-input{width:100%;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-body);font-size:15px;outline:none;padding:0}.field-input::placeholder{color:var(--text-faint)}.field-textarea{width:100%;background:transparent;border:none;color:var(--text-primary);font-family:var(--font-body);font-size:15px;outline:none;padding:0;resize:none;line-height:1.6;min-height:80px}.field-textarea::placeholder{color:var(--text-faint)}.btn-primary{width:100%;background:var(--amber);color:#000;border:none;border-radius:var(--radius-md);padding:17px;font-family:var(--font-head);font-size:17px;font-weight:800;cursor:pointer;letter-spacing:2px;text-transform:uppercase;transition:opacity .2s}.btn-primary:disabled{opacity:.25;cursor:not-allowed}.btn-primary:active:not(:disabled){opacity:.85;transform:scale(.99)}.btn-ghost{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 14px;color:var(--text-dim);font-family:var(--font-body);font-size:13px;cursor:pointer;transition:border-color .2s,color .2s}.btn-ghost:hover{border-color:var(--text-faint);color:var(--text-muted)}.action-btn{width:100%;padding:15px 18px;border-radius:var(--radius-md);border:1px solid;cursor:pointer;display:flex;align-items:center;gap:14px;margin-bottom:10px;transition:opacity .1s,transform .1s;font-family:var(--font-body);text-align:left}.action-btn:active{transform:scale(.98);opacity:.85}.action-btn-emoji{font-size:22px;width:28px;text-align:center;flex-shrink:0}.action-btn-text{flex:1}.action-btn-label{font-size:16px;font-weight:600;display:block}.action-btn-desc{font-size:12px;opacity:.65;display:block;margin-top:1px}.action-btn-time{font-family:var(--font-display);font-size:22px;letter-spacing:1px;opacity:.8;flex-shrink:0}.status-card{margin:18px 16px 0;border-radius:var(--radius-lg);padding:22px 20px 18px;border:1px solid;transition:background .5s ease,border-color .5s ease;position:relative;overflow:hidden}.status-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 80% 50%,currentColor,transparent 70%);opacity:.04;pointer-events:none}.status-eyebrow{font-family:var(--font-head);font-size:10px;text-transform:uppercase;letter-spacing:4px;opacity:.6;margin-bottom:6px}.status-value{font-family:var(--font-head);font-size:30px;font-weight:800;line-height:1.1}.status-since{font-size:12px;color:var(--text-muted);margin-top:8px}.ctrl-row{display:flex;gap:8px;margin:18px 16px 0}.ctrl-btn{flex:1;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text-dim);font-family:var(--font-body);font-size:13px;cursor:pointer;transition:all .2s}.ctrl-btn:hover{border-color:var(--text-faint);color:var(--text-muted)}.ctrl-btn:disabled{opacity:.25;cursor:not-allowed}.log-wrap{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;max-height:480px;overflow-y:auto}.log-row{display:flex;align-items:center;padding:11px 16px;border-bottom:1px solid var(--border-sub);gap:12px;cursor:pointer;transition:background .15s}.log-row:hover{background:var(--bg-raised)}.log-row:last-child{border-bottom:none}.log-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.log-label{flex:1;font-size:13px;font-weight:500}.log-time{font-family:var(--font-display);font-size:17px;letter-spacing:1px;color:var(--text-dim)}.log-empty{padding:24px;text-align:center;color:var(--text-faint);font-size:14px}.edit-form{padding:12px 16px 14px;background:var(--bg-raised);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.edit-time-input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--amber);font-family:var(--font-display);font-size:22px;letter-spacing:2px;outline:none;width:100%}.edit-reason-input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text-primary);font-family:var(--font-body);font-size:13px;outline:none;width:100%;resize:none;line-height:1.5}.edit-reason-input::placeholder{color:var(--text-faint)}.edit-btns{display:flex;gap:8px}.edit-save{flex:1;background:#f59e0b22;border:1px solid #f59e0b44;border-radius:var(--radius-sm);padding:9px;color:var(--amber);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer}.edit-save:disabled{opacity:.3;cursor:not-allowed}.edit-cancel{flex:1;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px;color:var(--text-dim);font-family:var(--font-body);font-size:13px;cursor:pointer}.sig-wrap{position:relative}.sig-canvas{width:100%;background:#050810;display:block;touch-action:none;cursor:crosshair}.sig-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;color:#1e2d3d;pointer-events:none;text-align:center}.sig-clear{width:100%;background:none;border:none;border-top:1px solid var(--border-sub);padding:10px;color:var(--text-dim);font-family:var(--font-body);font-size:12px;cursor:pointer;text-align:center}.sig-clear:hover{color:var(--red)}.photos-wrap{display:flex;flex-wrap:wrap;gap:10px;padding:12px 16px}.photo-thumb{width:80px;height:80px;border-radius:8px;object-fit:cover;border:1px solid var(--border)}.photo-item{position:relative}.photo-del{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:var(--red);border:none;border-radius:50%;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-add{width:80px;height:80px;border-radius:8px;border:1px dashed var(--border);background:none;color:var(--text-faint);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.photo-input{display:none}.dropdown-wrap{position:relative}.dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:20;overflow:hidden;box-shadow:0 8px 24px #0006;max-height:240px;overflow-y:auto}.dropdown-item{padding:11px 16px;font-size:14px;color:var(--text-muted);cursor:pointer;border-bottom:1px solid var(--border-sub);transition:background .1s}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background:var(--border);color:var(--text-primary)}.dropdown-empty{padding:16px;font-size:13px;color:var(--text-faint);text-align:center}.badge{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;padding:3px 8px;border-radius:4px;border:1px solid}.empty-state{padding:48px 24px;text-align:center;color:var(--text-faint);font-size:14px;line-height:1.8}@keyframes fadeSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeSlide .25s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-raised) 0%,var(--border) 50%,var(--bg-raised) 100%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-line{height:12px;margin:8px 0}.skeleton-card{height:80px;margin:12px 0;border-radius:var(--radius-md)}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .15s ease forwards}.dialog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:380px;padding:24px;box-shadow:0 10px 40px #00000080;animation:dialogPop .18s cubic-bezier(.16,1,.3,1) forwards}@keyframes dialogPop{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.dialog-title{font-family:var(--font-head);font-size:18px;font-weight:800;color:var(--text-primary);margin-bottom:8px}.dialog-body{font-size:14px;line-height:1.5;color:var(--text-muted);margin-bottom:20px}.dialog-actions{display:flex;gap:8px;justify-content:flex-end}.toast-stack{position:fixed;left:50%;bottom:24px;transform:translate(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;pointer-events:none;width:calc(100vw - 32px);max-width:var(--max-w)}.toast{pointer-events:auto;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--text-faint);color:var(--text-primary);font-size:13px;line-height:1.4;box-shadow:0 8px 24px #0006;animation:toastIn .2s ease forwards}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast.success{border-left-color:var(--green)}.toast.error{border-left-color:var(--red)}.toast.info{border-left-color:var(--blue)}.toast-icon{font-size:16px;flex-shrink:0}.toast-msg{flex:1}.empty-state-cta{margin-top:20px;display:inline-block}.pin-dots{display:flex;justify-content:center;gap:18px;margin:8px 0 4px}.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--text-faint);background:transparent;transition:background .1s ease,border-color .1s ease}.pin-dot.filled{background:var(--amber);border-color:var(--amber)}.pin-dots.shake{animation:shake .4s ease}.pin-dots.shake .pin-dot.filled{background:var(--red);border-color:var(--red)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.pin-numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:280px;margin:0 auto}.pin-key{height:64px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-head);font-size:24px;font-weight:600;color:var(--text-primary);cursor:pointer;transition:background .1s ease,transform .05s ease}.pin-key:active:not(:disabled){background:var(--bg-raised);transform:scale(.96)}.pin-key:disabled{opacity:.35;cursor:not-allowed}.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 28px;background:var(--bg-base)}.login-logo{font-family:var(--font-head);font-size:48px;font-weight:800;letter-spacing:-1px;margin-bottom:4px}.login-tagline{font-size:12px;text-transform:uppercase;letter-spacing:4px;color:var(--text-faint);margin-bottom:48px}.login-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--text-dim);margin-bottom:10px;width:100%;max-width:340px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:6px}@media (min-width: 768px){.cal-grid{gap:4px;padding:10px}}.cal-day-header{text-align:center;font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--text-faint);padding:4px 0}.cal-day{min-height:96px;border-radius:6px;padding:3px;font-size:12px;cursor:pointer;transition:background .15s;position:relative;display:flex;flex-direction:column;gap:2px}@media (min-width: 768px){.cal-day{min-height:110px;padding:6px;overflow:hidden}}.cal-day:hover{background:var(--bg-raised)}.cal-day.today{background:#f59e0b14;outline:1px solid var(--amber)}.cal-day.today .cal-day-num{color:var(--amber);font-weight:700}.cal-day-num{font-size:12px;line-height:1;padding:2px 4px}.cal-day.other-month .cal-day-num{color:var(--text-faint)}.cal-day-chip{display:flex;align-items:flex-start;gap:3px;width:100%;box-sizing:border-box;font-size:9px;line-height:1.2;padding:2px 4px;border-radius:3px;background:transparent;font-weight:600;text-align:left}.cal-day-chip-icon{flex-shrink:0}.cal-day-chip-label{flex:1;min-width:0;white-space:normal;overflow-wrap:anywhere;word-break:break-word}@media (min-width: 768px){.cal-day-chip{font-size:11px;padding:3px 6px}}.cal-day-chip.planned{color:var(--blue);background:var(--blue-bg)}.cal-day-chip.draft{color:var(--amber);background:var(--amber-bg)}.cal-day-chip.filled{color:var(--orange);background:var(--orange-bg)}.cal-day-chip.signed{color:var(--green);background:var(--green-bg)}.cal-day-chip.field-domestic{color:var(--orange);background:var(--orange-bg)}.cal-day-chip.field-overseas{color:var(--blue);background:var(--blue-bg)}.cal-day-chip.field-na{color:var(--amber);background:var(--amber-bg)}.cal-day-chip.office{color:var(--green);background:var(--green-bg)}.cal-day-chip.sick_leave{color:var(--red);background:var(--red-bg)}.cal-day-chip.personal_leave{color:var(--purple);background:var(--purple-bg)}.cal-day-chip.annual_leave{color:var(--amber);background:var(--amber-bg)}.cal-day-more{font-size:10px;color:var(--text-faint);padding:0 4px;letter-spacing:.5px}.cal-sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;background:#0009;display:flex;flex-direction:column;justify-content:flex-end;animation:fadeIn .15s ease forwards}.cal-sheet{background:var(--bg-card);border-radius:20px 20px 0 0;max-height:75vh;display:flex;flex-direction:column;overflow:hidden;animation:sheetUp .22s cubic-bezier(.16,1,.3,1) forwards}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cal-sheet-handle{display:flex;justify-content:center;padding:10px 0 4px}.cal-sheet-handle>div{width:36px;height:4px;border-radius:2px;background:var(--border)}.cal-sheet-header{padding:4px 20px 12px;border-bottom:1px solid var(--border-sub)}.cal-sheet-body{padding:12px 20px 16px;overflow-y:auto;flex:1}.spinner{display:flex;align-items:center;justify-content:center;min-height:100vh;font-family:var(--font-body);color:var(--amber);font-size:16px}.md-preview{min-height:140px;padding:10px 12px;font-size:13px;line-height:1.65;color:var(--text-primary);background:var(--bg-input, var(--bg-raised));border-radius:var(--radius-md, 8px)}.md-preview p{margin:0 0 8px}.md-preview p:last-child{margin-bottom:0}.md-preview h1,.md-preview h2,.md-preview h3{font-weight:700;color:var(--text-primary);margin:10px 0 4px;line-height:1.3}.md-preview h1{font-size:16px}.md-preview h2{font-size:14px}.md-preview h3{font-size:13px}.md-preview ul,.md-preview ol{margin:0 0 8px;padding-left:20px}.md-preview li{margin-bottom:3px}.md-preview strong{font-weight:700;color:var(--text-primary)}.md-preview em{font-style:italic;color:var(--text-dim)}.md-preview code{font-family:monospace;font-size:11px;background:var(--bg-raised);border-radius:3px;padding:1px 4px}.md-preview table{width:100%;border-collapse:collapse;font-size:12px;margin:0 0 8px}.md-preview th,.md-preview td{border:1px solid var(--border);padding:6px 10px;text-align:left}.md-preview th{background:var(--bg-raised);font-weight:600;color:var(--text-primary);text-transform:uppercase;font-size:10px;letter-spacing:1px}.md-preview td{color:var(--text-muted)}.md-preview tr:nth-child(2n) td{background:#ffffff05}.md-tabs{display:flex;gap:6px;margin-bottom:6px}.md-tab{padding:4px 12px;font-size:12px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:var(--font-body)}.md-tab.active{background:var(--amber);border-color:var(--amber);color:#000;font-weight:600}.app-frame{display:flex;min-height:100%}.app-main{flex:1;min-width:0}.sidebar{display:none}.sidebar-brand{padding:24px 20px 18px;border-bottom:1px solid var(--border)}.sidebar-brand-name{font-family:var(--font-head);font-size:26px;font-weight:800;letter-spacing:-1px;line-height:1}.sidebar-brand-sub{font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-faint);margin-top:4px;white-space:nowrap}.sidebar-nav{flex:1;padding:14px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-nav-label{font-size:9px;text-transform:uppercase;letter-spacing:3px;color:var(--text-faint);padding:8px 10px 5px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-muted);font-family:var(--font-body);font-size:14px;cursor:pointer;text-align:left;width:100%;transition:background .15s,color .15s}.sidebar-item:hover{background:var(--bg-raised);color:var(--text-primary)}.sidebar-item.active{background:#f59e0b18;color:var(--amber);font-weight:600}.sidebar-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}.sidebar-divider{height:1px;background:var(--border);margin:8px 0}.sidebar-footer{padding:14px 16px 20px;border-top:1px solid var(--border);flex-shrink:0}.sidebar-user-info{margin-bottom:12px}.sidebar-user-code{font-family:var(--font-display);font-size:20px;letter-spacing:2px;color:var(--text-primary);line-height:1.1}.sidebar-user-name{font-size:12px;color:var(--text-muted);margin-top:2px}.sidebar-user-pos{font-size:10px;color:var(--text-faint);margin-top:1px}.sidebar-changepin,.sidebar-logout{width:100%;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px;color:var(--text-dim);font-family:var(--font-body);font-size:12px;cursor:pointer;transition:border-color .2s,color .2s;text-align:center;margin-bottom:6px}.sidebar-changepin:hover{border-color:var(--amber);color:var(--amber)}.sidebar-logout:hover{border-color:var(--red);color:var(--red)}.sidebar-logout{margin-bottom:0}@media (min-width: 768px){:root{--max-w: 720px}.sidebar{display:flex;flex-direction:column;width:220px;flex-shrink:0;background:var(--bg-card);border-right:1px solid var(--border);height:100vh;position:sticky;top:0}}
