.topnav{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:var(--bg-nav);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0;z-index:var(--z-sticky);padding:0;box-shadow:0 1px 4px #0006}.topnav-brand{display:flex;align-items:center;gap:6px;padding:0 var(--space-4);min-width:140px;height:100%;border-right:1px solid var(--border);flex-shrink:0}.brand-logo{font-size:13px;font-weight:var(--font-bold);color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:1px 5px;line-height:1.3;letter-spacing:.04em;flex-shrink:0}.brand-name{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:-.01em}.topnav-links{display:flex;align-items:center;height:100%;flex:1;overflow-x:auto;scroll-behavior:smooth}.topnav-links::-webkit-scrollbar{height:0}.nav-link{display:inline-flex;align-items:center;gap:5px;padding:0 var(--space-3);height:100%;font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap;transition:color var(--ease-fast),border-color var(--ease-fast),background var(--ease-fast)}.nav-link:hover{color:var(--text-primary);background:#ffffff0a}.nav-link.active{color:var(--accent);border-bottom-color:var(--accent)}.nav-icon{font-size:12px;line-height:1}.nav-label{line-height:1}.topnav-right{display:flex;align-items:center;gap:var(--space-1);padding:0 var(--space-3);height:100%;border-left:1px solid var(--border);flex-shrink:0}.nav-icon-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:all var(--ease-fast)}.nav-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-user{display:flex;align-items:center;gap:var(--space-2)}.user-avatar{width:24px;height:24px;border-radius:50%;background:var(--blue);color:var(--text-inverse);font-size:11px;font-weight:var(--font-bold);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.user-name{font-size:var(--text-xs);color:var(--text-secondary);max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[data-theme=light] .topnav{background:var(--bg-nav)}[data-theme=light] .topnav .nav-link{color:#ffffffb3}[data-theme=light] .topnav .nav-link:hover{color:#fff;background:#ffffff1a}[data-theme=light] .topnav .nav-link.active{color:#fff;border-bottom-color:var(--accent)}[data-theme=light] .topnav .nav-icon-btn{color:#ffffffb3}[data-theme=light] .topnav .nav-icon-btn:hover{background:#ffffff1a;color:#fff}[data-theme=light] .topnav .user-name{color:#fffc}[data-theme=light] .topnav .brand-name{color:#fff}[data-theme=light] .topnav .brand-logo{color:var(--accent)}[data-theme=light] .topnav{border-bottom-color:#0003}@media(max-width:768px){.topnav-brand{min-width:auto;padding:0 var(--space-2) 0 var(--space-3);gap:0}.brand-name{display:none}.topnav-links{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.topnav-links::-webkit-scrollbar{display:none}.nav-link{padding:0 var(--space-2);flex-direction:column;gap:2px;font-size:10px;min-width:48px;justify-content:center}.nav-icon{font-size:16px}.nav-label{font-size:9px;line-height:1}.topnav-right{padding:0 var(--space-2);gap:2px}.user-name{display:none}.nav-icon-btn{width:32px;height:32px}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height, 56px);background:var(--bg-nav);border-top:1px solid var(--border);z-index:var(--z-sticky);padding-bottom:env(safe-area-inset-bottom,0px);box-shadow:0 -1px 8px #0006}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;height:100%;text-decoration:none;color:var(--text-muted);transition:color var(--ease-fast);-webkit-tap-highlight-color:transparent;min-width:0}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item.active .bottom-nav-icon{transform:scale(1.15)}.bottom-nav-icon{font-size:20px;line-height:1;transition:transform var(--ease-fast)}.bottom-nav-label{font-size:10px;font-weight:var(--font-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}[data-theme=light] .bottom-nav{background:var(--bg-nav)}[data-theme=light] .bottom-nav-item{color:#ffffff8c}[data-theme=light] .bottom-nav-item.active{color:#fff}.logpanel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:var(--z-overlay)}.logpanel{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;background:var(--bg-surface);border-left:1px solid var(--border);box-shadow:-4px 0 20px #00000040;z-index:calc(var(--z-overlay) + 1);display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.4,0,.2,1)}.logpanel.open{transform:translate(0)}.logpanel.inline{position:relative;top:auto;right:auto;bottom:auto;width:100%;max-width:none;height:100%;border-left:none;border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-card);transform:none;z-index:auto}.logpanel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);flex-shrink:0}.logpanel-title{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--text-primary)}.logpanel-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.logpanel-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:16px;transition:background var(--ease-fast)}.logpanel-close:hover{background:var(--bg-hover);color:var(--text-primary)}.logpanel-body{flex:1;overflow-y:auto;padding:var(--space-4)}.logpanel-timeline{display:flex;flex-direction:column}.tl-item{display:flex;gap:var(--space-3);min-height:56px}.tl-dot-col{display:flex;flex-direction:column;align-items:center;width:16px;flex-shrink:0}.tl-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);border:2px solid var(--bg-surface);box-shadow:0 0 0 2px var(--accent-dim);flex-shrink:0;margin-top:4px}.tl-line{width:2px;flex:1;background:var(--border);margin:4px 0;opacity:.5}.tl-content{flex:1;padding-bottom:var(--space-3);min-width:0}.tl-dt{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);margin-bottom:2px}.tl-label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary)}.tl-meta{font-size:11px;color:var(--text-secondary);margin-top:2px}.tl-memo{font-size:11px;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:var(--space-1) var(--space-2);margin-top:var(--space-1);white-space:pre-wrap;line-height:1.4}@media(max-width:768px){.logpanel{width:100%;max-width:100%}}.chat-close-btn{font-size:12px;padding:2px 8px;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm)}.chat-close-btn:hover{color:var(--text-primary);background:var(--bg-hover);border-color:var(--border-emphasis)}.chat-toggle-btn--collapsed{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:200;width:28px;height:56px;background:var(--bg-card);border:1px solid var(--border);border-left:none;border-radius:0 var(--radius) var(--radius) 0;color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.chat-toggle-btn--collapsed:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-panel{position:relative;display:flex;flex-direction:column;height:calc(100vh - var(--nav-height));overflow:hidden;background:var(--bg-surface);border-right:1px solid var(--border);flex-shrink:0;min-width:220px;max-width:560px}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-3);height:40px;border-bottom:1px solid var(--border);background:var(--bg-nav);flex-shrink:0}.chat-header__title{font-size:var(--text-sm);font-weight:600;color:var(--accent-text)}.chat-header__actions{display:flex;gap:var(--space-1)}.chat-icon-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:2px 5px;border-radius:var(--radius-sm);transition:color .15s,background .15s}.chat-icon-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.chat-bubble{display:flex;gap:var(--space-2);max-width:100%}.chat-bubble--user{flex-direction:row-reverse}.chat-bubble__avatar{width:24px;height:24px;border-radius:var(--radius-full);background:var(--accent-dim);color:var(--accent-text);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.chat-bubble__body{display:flex;flex-direction:column;gap:var(--space-1);max-width:85%}.chat-bubble__text{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);line-height:1.55;color:var(--text-primary);word-break:break-word}.chat-bubble--user .chat-bubble__text{background:var(--blue-dim);border-color:var(--blue);color:var(--text-primary)}.chat-bubble__text code{background:var(--bg-base);padding:1px 4px;border-radius:3px;font-size:.9em;color:var(--cyan)}.chat-bubble__images{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-bottom:var(--space-1)}.chat-bubble__img{max-width:120px;max-height:90px;border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border)}.chat-typing{display:flex;gap:4px;align-items:center;padding:var(--space-2) var(--space-3)}.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--text-muted);animation:chat-bounce 1.2s infinite ease-in-out}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes chat-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-5px);opacity:1}}.chat-attach-preview{display:flex;flex-wrap:wrap;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-top:1px solid var(--border-light);background:var(--bg-base)}.chat-attach-item{position:relative}.chat-attach-item img{width:52px;height:52px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}.chat-attach-item button{position:absolute;top:-4px;right:-4px;width:16px;height:16px;border-radius:50%;background:var(--red);border:none;color:var(--text-inverse);font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.chat-footer{display:flex;align-items:center;justify-content:center;padding:4px var(--space-2);border-top:1px solid var(--border-light);background:var(--bg-surface);flex-shrink:0}.chat-footer__text{font-size:10px;color:var(--text-muted)}.chat-attach-file{display:flex;align-items:center;gap:4px;padding:4px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:11px;color:var(--text-secondary)}.chat-attach-file__icon{font-size:14px}.chat-attach-file__name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-input-area{display:flex;align-items:flex-end;gap:var(--space-1);padding:var(--space-2) var(--space-2);border-top:1px solid var(--border);background:var(--bg-base);flex-shrink:0;margin-top:auto}.chat-attach-btn{font-size:16px;padding:4px 6px;align-self:flex-end;margin-bottom:2px}.chat-textarea{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-size:var(--text-sm);padding:var(--space-2) var(--space-2);resize:none;line-height:1.4;font-family:inherit;transition:border-color .15s;min-height:36px;max-height:120px}.chat-textarea:focus{outline:none;border-color:var(--border-focus)}.chat-send-btn{background:var(--accent);border:none;border-radius:var(--radius);color:var(--text-inverse);font-size:15px;width:34px;height:34px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;align-self:flex-end;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:var(--accent-hover)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-send-btn--loading{background:var(--bg-hover)}.chat-resize-handle{position:absolute;right:-3px;top:0;bottom:0;width:6px;cursor:col-resize;z-index:10;background:transparent;transition:background .15s}.chat-resize-handle:hover,.chat-resize-handle:active{background:var(--accent-dim)}.chat-bubble__confirm{display:flex;gap:var(--space-2);margin-top:var(--space-2)}.chat-confirm-btn{padding:4px 14px;border-radius:var(--radius-sm);border:none;font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:opacity .15s}.chat-confirm-btn:hover{opacity:.85}.chat-confirm-btn--yes{background:var(--accent);color:var(--text-inverse)}.chat-confirm-btn--no{background:var(--bg-hover);color:var(--text-secondary);border:1px solid var(--border)}.chat-action-chips{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.chat-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px 6px 10px;background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);font-size:12px;font-weight:var(--font-medium);cursor:pointer;transition:border-color var(--ease-fast),background var(--ease-fast),box-shadow var(--ease-fast);line-height:1}.chat-chip:hover{border-color:var(--accent);background:var(--accent-dim);box-shadow:0 0 0 1px var(--accent-dim)}.chat-chip:active{transform:scale(.97)}.chat-chip__icon{font-size:13px;line-height:1}.chat-chip__label{white-space:nowrap}.chat-chip__arrow{font-size:11px;color:var(--text-muted);transition:color var(--ease-fast),transform var(--ease-fast)}.chat-chip:hover .chat-chip__arrow{color:var(--accent);transform:translate(2px)}.landing-root{min-height:100vh;background:var(--bg-canvas, #0d1117);color:var(--text-primary, #c9d1d9);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Apple SD Gothic Neo,Pretendard,Roboto,sans-serif;line-height:1.6}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:18px 48px;border-bottom:1px solid rgba(255,255,255,.08);background:#0d1117d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:50}.landing-brand{display:flex;align-items:center;gap:10px}.landing-logo{width:36px;height:36px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-weight:800;font-size:20px;display:flex;align-items:center;justify-content:center;border-radius:8px}.landing-name{font-size:20px;font-weight:700;letter-spacing:-.02em}.landing-nav-links{display:flex;align-items:center;gap:24px}.landing-nav-links a{color:var(--text-primary, #c9d1d9);text-decoration:none;font-weight:500;font-size:14px;transition:color .15s}.landing-nav-links a:hover{color:#60a5fa}.landing-hero{text-align:center;padding:96px 24px 80px;max-width:900px;margin:0 auto}.hero-title{font-size:56px;font-weight:800;line-height:1.15;letter-spacing:-.03em;margin:0 0 24px}.hero-title .accent{background:linear-gradient(120deg,#60a5fa,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-sub{font-size:20px;color:var(--text-secondary, #8b949e);margin:0 auto 40px;max-width:640px}.hero-cta{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.hero-note{color:var(--text-muted, #6e7681);font-size:13px}.section-title{text-align:center;font-size:36px;font-weight:800;letter-spacing:-.02em;margin:0 0 12px}.section-sub{text-align:center;font-size:16px;color:var(--text-secondary, #8b949e);margin:0 0 48px}.landing-features{padding:80px 32px;max-width:1200px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:48px}.feature-card{padding:32px 24px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;transition:transform .2s,border-color .2s}.feature-card:hover{transform:translateY(-4px);border-color:#60a5fa4d}.feature-icon{font-size:36px;margin-bottom:16px}.feature-card h3{font-size:18px;font-weight:700;margin:0 0 8px}.feature-card p{color:var(--text-secondary, #8b949e);font-size:14px;margin:0}.landing-pricing{padding:80px 32px;background:#ffffff05}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;max-width:1100px;margin:0 auto}.plan-card{padding:32px 28px;background:var(--bg-canvas, #0d1117);border:1px solid rgba(255,255,255,.1);border-radius:16px;position:relative;display:flex;flex-direction:column}.plan-card.accent{border-color:#60a5fa;border-width:2px;transform:scale(1.03);box-shadow:0 20px 40px #60a5fa26}.plan-badge{position:absolute;top:-12px;right:20px;padding:4px 12px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:999px;font-size:11px;font-weight:700}.plan-name{font-size:22px;font-weight:700;margin:0 0 8px}.plan-price{display:flex;align-items:baseline;gap:2px;margin:12px 0}.plan-currency{font-size:18px;opacity:.7}.plan-amount{font-size:42px;font-weight:800;letter-spacing:-.02em}.plan-period{font-size:16px;opacity:.6;margin-left:4px}.plan-desc{color:var(--text-secondary, #8b949e);font-size:13px;margin:0 0 16px}.plan-quota{padding:8px 12px;background:#60a5fa1a;border-radius:8px;font-size:13px;font-weight:600;margin-bottom:20px}.plan-features{list-style:none;padding:0;margin:0 0 24px;flex:1}.plan-features li{padding:6px 0;font-size:14px}.landing-cta-final{padding:96px 24px;text-align:center;background:linear-gradient(180deg,transparent 0%,rgba(96,165,250,.05) 100%)}.landing-cta-final h2{font-size:36px;font-weight:800;margin:0 0 12px}.landing-cta-final p{color:var(--text-secondary, #8b949e);margin:0 0 32px}.btn-block{width:100%;justify-content:center}.btn-lg{padding:14px 28px;font-size:16px;font-weight:600}@media(max-width:768px){.landing-nav{padding:12px 20px}.landing-nav-links{gap:12px;font-size:13px}.hero-title{font-size:36px}.hero-sub{font-size:16px}.section-title{font-size:28px}.plan-card.accent{transform:none}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base);padding:var(--space-4)}.login-card{width:100%;max-width:400px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-8);display:flex;flex-direction:column;gap:var(--space-6)}.login-logo{display:flex;align-items:center;gap:var(--space-4)}.logo-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:#10b9811a;border:1px solid rgba(16,185,129,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0}.logo-text h1{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);letter-spacing:-.02em}.logo-text p{font-size:var(--text-sm);color:var(--accent);margin-top:2px;font-weight:var(--font-medium)}.login-form input{pointer-events:auto;user-select:text;-webkit-user-select:text;touch-action:manipulation}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.login-footer{text-align:center}.legal-page{max-width:820px;margin:0 auto;padding:48px 32px 96px;font-size:14px;line-height:1.85;color:var(--text-primary)}.legal-page h1{font-size:28px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.legal-meta{color:var(--text-secondary);font-size:13px;margin:0 0 32px;display:flex;align-items:center;gap:8px}.legal-version-badge{display:inline-block;padding:2px 8px;background:#60a5fa26;color:#60a5fa;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.04em}.legal-body h2{font-size:18px;font-weight:700;margin:32px 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border-light)}.legal-body h3{font-size:15px;font-weight:700;margin:20px 0 8px;color:var(--text-primary)}.legal-body p{margin:0 0 12px}.legal-body ul,.legal-body ol{margin:0 0 12px;padding-left:24px}.legal-body li{margin:4px 0}.legal-body strong{color:var(--text-primary);font-weight:700}.legal-body code{padding:2px 6px;background:#ffffff0f;border-radius:3px;font-size:12px;font-family:ui-monospace,SFMono-Regular,monospace}.legal-body hr{margin:24px 0;border:none;border-top:1px solid var(--border-light)}.legal-table{width:100%;border-collapse:collapse;margin:12px 0 20px;font-size:13px}.legal-table th,.legal-table td{padding:10px 12px;border:1px solid var(--border-light);text-align:left;vertical-align:top}.legal-table th{background:#ffffff0a;font-weight:700}:root,[data-theme=dark]{--bg-base: #0d1117;--bg-surface: #111827;--bg-card: #1f2937;--bg-elevated: #1f2937;--bg-hover: #374151;--bg-input: #111827;--bg-nav: #0d1117;--bg-toolbar: #111827;--bg-thead: #0d1117;--bg-row-hover: rgba(55,65,81,.6);--bg-row-select: rgba(99,102,241,.12);--bg-row-stripe: rgba(255,255,255,.02);--text-primary: #f3f4f6;--text-secondary: #9ca3af;--text-muted: #6b7280;--text-inverse: #0d1117;--text-link: #60a5fa;--accent: #10b981;--accent-hover: #059669;--accent-dim: rgba(16,185,129,.15);--accent-text: #6ee7b7;--blue: #3b82f6;--blue-hover: #2563eb;--blue-dim: rgba(59,130,246,.15);--purple: #8b5cf6;--purple-dim: rgba(139,92,246,.15);--green: #10b981;--green-dim: rgba(16,185,129,.15);--amber: #f59e0b;--amber-dim: rgba(245,158,11,.15);--red: #ef4444;--red-hover: #dc2626;--red-dim: rgba(239,68,68,.15);--cyan: #06b6d4;--cyan-dim: rgba(6,182,212,.15);--pink: #ec4899;--pink-dim: rgba(236,72,153,.15);--orange: #f97316;--orange-dim: rgba(249,115,22,.15);--proc-offset: #c084fc;--proc-screen: #60a5fa;--proc-jeonghap: #4ade80;--proc-lami: #fbbf24;--proc-punching: #fb923c;--proc-stamping: #f87171;--proc-inspect: #a78bfa;--proc-ic: #38bdf8;--proc-nc: #34d399;--proc-ic-bg: rgba(56,189,248,.12);--proc-nc-bg: rgba(52,211,153,.12);--status-pending: var(--amber);--status-active: var(--accent);--status-done: var(--green);--status-error: var(--red);--status-canceled: var(--text-muted);--border: #374151;--border-light: #1f2937;--border-emphasis: #6b7280;--border-focus: var(--blue);--shadow-sm: 0 1px 2px rgba(0,0,0,.4);--shadow: 0 4px 12px rgba(0,0,0,.5);--shadow-lg: 0 8px 24px rgba(0,0,0,.6);--shadow-xl: 0 16px 40px rgba(0,0,0,.7);--shadow-btn: 0 1px 3px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.06);--nav-height: 44px;--bottom-nav-height: 56px;--toolbar-height:44px;--filter-height: 38px;--sidebar-width: 0px;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-xs: 2px;--radius-sm: 4px;--radius: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans KR", sans-serif;--font-mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;--text-2xs: .6875rem;--text-xs: .75rem;--text-sm: .8125rem;--text-base:.875rem;--text-md: .9375rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.25rem;--text-3xl: 1.5rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--z-base: 0;--z-dropdown:100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500;--ease-fast: .1s ease;--ease: .18s ease;--ease-slow: .3s ease;--blue-tint-008: rgba(59,130,246,.08);--blue-tint-015: rgba(59,130,246,.15);--green-tint-008: rgba(16,185,129,.08);--green-tint-015: rgba(16,185,129,.15);--red-tint-008: rgba(239,68,68,.08);--red-tint-015: rgba(239,68,68,.15);--amber-tint-008: rgba(245,158,11,.08);--amber-tint-015: rgba(245,158,11,.15);--purple-tint-008: rgba(139,92,246,.08);--purple-tint-015: rgba(139,92,246,.15);--accent-tint-008: rgba(16,185,129,.08);--accent-tint-015: rgba(16,185,129,.15)}[data-theme=light]{--bg-base: #f0f2f5;--bg-surface: #ffffff;--bg-card: #ffffff;--bg-elevated: #ffffff;--bg-hover: #f3f4f6;--bg-input: #ffffff;--bg-nav: #1f2937;--bg-toolbar: #ffffff;--bg-thead: #f9fafb;--bg-row-hover: rgba(0,0,0,.03);--bg-row-stripe: rgba(0,0,0,.015);--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--text-link: #2563eb;--accent: #059669;--accent-hover: #047857;--accent-dim: rgba(5,150,105,.1);--accent-text: #065f46;--blue: #2563eb;--blue-dim: rgba(37,99,235,.1);--purple: #7c3aed;--purple-dim: rgba(124,58,237,.1);--green: #059669;--green-dim: rgba(5,150,105,.1);--amber: #d97706;--amber-dim: rgba(217,119,6,.1);--red: #dc2626;--red-dim: rgba(220,38,38,.1);--border: #e5e7eb;--border-light: #f3f4f6;--border-emphasis: #9ca3af;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--font-normal);line-height:1.5;color:var(--text-primary);background:var(--bg-base);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-emphasis)}.grid-wrap::-webkit-scrollbar{width:10px;height:12px}.grid-wrap::-webkit-scrollbar-thumb{background:var(--border-emphasis);border-radius:6px;border:2px solid var(--bg-surface)}.grid-wrap::-webkit-scrollbar-thumb:hover{background:var(--accent)}.grid-wrap::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:6px}.grid-wrap{scrollbar-width:auto;scrollbar-color:var(--border-emphasis) var(--bg-elevated)}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}button:focus:not(:focus-visible),a:focus:not(:focus-visible){outline:none}#root,.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-body{flex:1;display:flex;flex-direction:column;margin-top:var(--nav-height);min-height:0}.app-body--split{flex-direction:row;height:calc(100vh - var(--nav-height));overflow:hidden}.app-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;min-width:0}.page-content{flex:1;padding:var(--space-4) var(--space-5);overflow-x:hidden;display:flex;flex-direction:column}.page-toolbar{display:flex;align-items:center;gap:var(--space-2);padding:0 var(--space-5);height:var(--toolbar-height);background:var(--bg-toolbar);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0}.toolbar-sep{width:1px;height:18px;background:var(--border);flex-shrink:0;margin:0 var(--space-1)}.toolbar-right{margin-left:auto;display:flex;align-items:center;gap:var(--space-2)}.toolbar-stat{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap}.toolbar-stat strong{color:var(--text-primary);font-weight:var(--font-semibold)}.filter-bar{display:flex;align-items:center;gap:2px;padding:var(--space-2) var(--space-5);background:var(--bg-surface);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0;min-height:var(--filter-height)}.filter-bar::-webkit-scrollbar{height:2px}.filter-tab{display:inline-flex;align-items:center;gap:4px;padding:3px var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:var(--radius-full);cursor:pointer;white-space:nowrap;transition:all var(--ease-fast);font-family:inherit;line-height:1.4}.filter-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.filter-tab.active{color:var(--accent);background:var(--accent-tint-008);border-color:var(--accent)}.filter-tab .tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;background:var(--bg-hover);border-radius:var(--radius-full);line-height:1}.filter-tab.active .tab-count{background:var(--accent);color:#fff}.sub-tabs{display:flex;align-items:flex-end;gap:0;padding:0 var(--space-5);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0}.sub-tab{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-secondary);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:inherit;transition:all var(--ease-fast);white-space:nowrap;margin-bottom:-1px}.sub-tab:hover{color:var(--text-primary)}.sub-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;font-size:var(--text-xs);font-weight:var(--font-medium);font-family:inherit;line-height:1.5;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:all var(--ease-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;box-shadow:var(--shadow-btn)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn .btn-icon-left{font-size:12px}.btn-accent{background:linear-gradient(180deg,#13c799,#0da578);color:#fff;border-color:#0da578;text-shadow:0 1px 1px rgba(0,0,0,.2)}.btn-accent:hover:not(:disabled){background:linear-gradient(180deg,#10d19f,#0b9169);border-color:#0b9169}.btn-primary{background:linear-gradient(180deg,#4f8ef7,#2563eb);color:#fff;border-color:#2563eb;text-shadow:0 1px 1px rgba(0,0,0,.2)}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#5a96f9,#1d4ed8);border-color:#1d4ed8}.btn-danger{background:linear-gradient(180deg,#f87171,#dc2626);color:#fff;border-color:#dc2626;text-shadow:0 1px 1px rgba(0,0,0,.2)}.btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#f97474,#b91c1c)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-emphasis)}.btn-success{background:var(--bg-card);color:var(--green);border-color:var(--green)}.btn-success:hover:not(:disabled){background:var(--green-tint-008)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent;box-shadow:none}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-xs{padding:2px 7px;font-size:11px;border-radius:3px}.btn-sm{padding:3px 9px;font-size:var(--text-xs)}.btn-md{padding:5px 12px;font-size:var(--text-sm)}.btn-lg{padding:7px 16px;font-size:var(--text-base)}.btn-icon-only{padding:4px 6px;aspect-ratio:1;justify-content:center}.grid-wrap{position:relative;overflow:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex:1;display:flex;flex-direction:column}.data-grid{width:100%;border-collapse:collapse;font-size:var(--text-xs);table-layout:fixed}.data-grid thead tr{background:var(--bg-thead);border-bottom:1px solid var(--border)}.data-grid thead th{padding:5px 8px;text-align:left;font-size:11px;font-weight:var(--font-semibold);color:var(--text-secondary);white-space:nowrap;border-right:1px solid var(--border-light);position:sticky;top:0;background:var(--bg-thead);z-index:2;-webkit-user-select:none;user-select:none}.data-grid.resizable thead th{position:relative}.data-grid.resizable thead th:after{content:"";position:absolute;right:-2px;top:0;bottom:0;width:5px;background:transparent;pointer-events:none;z-index:1;transition:background .12s}.data-grid.resizable thead th.col-resize-hover:after{background:var(--accent, #3b82f6);opacity:.5}.data-grid.resizable thead th:last-child:after{display:none}.data-grid.resizable thead th,.data-grid.resizable tbody td{overflow:hidden;text-overflow:ellipsis}.data-grid thead th:last-child{border-right:none}.data-grid thead th.sortable{cursor:pointer}.data-grid thead th.sortable:hover{color:var(--text-primary);background:var(--bg-hover)}.data-grid thead th .sort-icon{margin-left:2px;opacity:.4;font-size:9px}.data-grid thead th.sorted-asc .sort-icon,.data-grid thead th.sorted-desc .sort-icon{opacity:1;color:var(--accent)}.data-grid thead th.th-check{width:32px;text-align:center}.data-grid thead th.th-action{width:36px;text-align:center}.data-grid tbody tr{border-bottom:1px solid var(--border);transition:background var(--ease-fast)}.data-grid tbody tr:last-child{border-bottom:1px solid var(--border)}.data-grid tbody tr:nth-child(2n){background:var(--bg-row-stripe)}.data-grid tbody tr:hover{background:var(--bg-row-hover)}.data-grid tbody tr.selected{background:var(--bg-row-select)!important}.data-grid tbody td{padding:6px 10px;color:var(--text-primary);font-size:12px;vertical-align:middle;border-right:1px solid var(--border-light);white-space:nowrap;line-height:1.4}.data-grid tbody td:last-child{border-right:none}.data-grid tbody td.td-check{text-align:center;width:32px}.data-grid tbody td.td-action{text-align:center;width:36px}.data-grid tbody td.td-num{text-align:right;font-family:var(--font-mono)}.data-grid tbody td.td-center{text-align:center}.grid-check{width:13px;height:13px;accent-color:var(--blue);cursor:pointer}.row-action-btn{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:3px;color:var(--text-muted);cursor:pointer;font-size:12px;transition:all var(--ease-fast)}.row-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.grid-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);background:var(--bg-surface);border-top:1px solid var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg);flex-shrink:0;margin-top:auto}.grid-info{font-size:var(--text-xs);color:var(--text-muted)}.grid-info strong{color:var(--text-secondary)}.pagination{display:flex;align-items:center;gap:2px}.page-btn{min-width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;font-size:var(--text-xs);cursor:pointer;border:1px solid transparent;background:transparent;color:var(--text-secondary);transition:all var(--ease-fast);font-family:inherit;padding:0 4px}.page-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.page-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:var(--font-semibold)}.page-btn:disabled{opacity:.3;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;font-size:11px;font-weight:var(--font-medium);border-radius:var(--radius-full);white-space:nowrap;line-height:1.5;border:1px solid transparent}.badge-blue{background:var(--blue-tint-015);color:#60a5fa;border-color:#60a5fa33}.badge-green{background:var(--green-tint-015);color:#4ade80;border-color:#4ade8033}.badge-amber{background:var(--amber-tint-015);color:#fbbf24;border-color:#fbbf2433}.badge-red{background:var(--red-tint-015);color:#f87171;border-color:#f8717133}.badge-purple{background:var(--purple-tint-015);color:#c084fc;border-color:#c084fc33}.badge-cyan{background:var(--cyan-dim);color:#22d3ee;border-color:#22d3ee33}.badge-accent{background:var(--accent-tint-015);color:#34d399;border-color:#34d39933}.badge-muted{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border)}.badge-pink{background:var(--pink-dim);color:#f472b6;border-color:#f472b633}.badge-orange{background:var(--orange-dim);color:#fb923c;border-color:#fb923c33}[data-theme=light] .badge-blue{background:#2563eb14;color:#1d4ed8;border-color:#2563eb33}[data-theme=light] .badge-green{background:#05966914;color:#047857;border-color:#05966933}[data-theme=light] .badge-amber{background:#d9770614;color:#b45309;border-color:#d9770633}[data-theme=light] .badge-red{background:#dc262614;color:#b91c1c;border-color:#dc262633}[data-theme=light] .badge-purple{background:#7c3aed14;color:#6d28d9;border-color:#7c3aed33}[data-theme=light] .badge-cyan{background:#0891b214;color:#0e7490;border-color:#0891b233}[data-theme=light] .badge-accent{background:#05966914;color:#047857;border-color:#05966933}[data-theme=light] .badge-pink{background:#db277714;color:#be185d;border-color:#db277733}[data-theme=light] .badge-orange{background:#ea580c14;color:#c2410c;border-color:#ea580c33}.badge .dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.card-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.card-body{padding:var(--space-4)}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-3);box-shadow:var(--shadow-sm);transition:all var(--ease-fast);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--stat-accent, var(--blue));border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.stat-card:hover{border-color:var(--border-emphasis);box-shadow:var(--shadow)}.stat-icon{width:40px;height:40px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.stat-info{flex:1;min-width:0}.stat-value{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-label{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.stat-sub{font-size:11px;color:var(--text-muted);margin-top:var(--space-1)}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);letter-spacing:.02em}.form-control{width:100%;padding:5px var(--space-3);font-size:var(--text-sm);font-family:inherit;color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color var(--ease-fast),box-shadow var(--ease-fast);line-height:1.5}.form-control:focus{border-color:var(--blue);box-shadow:0 0 0 2px #3b82f633}.form-control::placeholder{color:var(--text-muted)}.form-control:disabled{opacity:.6;cursor:not-allowed}select.form-control{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}.form-control-sm{padding:3px var(--space-2);font-size:var(--text-xs);height:28px}.search-bar{display:flex;align-items:center;gap:6px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 8px;height:28px;transition:border-color var(--ease-fast),box-shadow var(--ease-fast)}.search-bar:focus-within{border-color:var(--blue);box-shadow:0 0 0 2px #3b82f626}.search-bar .search-icon{color:var(--text-muted);font-size:12px;flex-shrink:0}.search-bar input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:var(--text-xs);font-family:inherit;outline:none;min-width:80px}.search-bar input::placeholder{color:var(--text-muted)}.date-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-xs);font-family:inherit;padding:3px 6px;height:28px;outline:none;cursor:pointer;width:110px}.date-input:focus{border-color:var(--blue)}.date-sep{color:var(--text-muted);font-size:var(--text-xs)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .12s ease both}.modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:calc(100vh - 64px);overflow-y:auto;animation:slideUp .18s ease both}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border)}.modal-title{font-size:var(--text-base);font-weight:var(--font-semibold)}.modal-body{padding:var(--space-4)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--border)}.toast-container{position:fixed;top:calc(var(--nav-height) + var(--space-3));right:var(--space-5);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2)}.toast{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:240px;max-width:340px;font-size:var(--text-sm);animation:slideInRight .18s ease both}.toast-success{border-left:3px solid var(--green)}.toast-error{border-left:3px solid var(--red)}.toast-warning{border-left:3px solid var(--amber)}.toast-info{border-left:3px solid var(--blue)}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);text-align:center;cursor:pointer;transition:all var(--ease-fast);min-height:100px;display:flex;align-items:center;justify-content:center}.upload-zone:hover{border-color:var(--blue);background:var(--blue-tint-008)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}@media(max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10) var(--space-6);color:var(--text-muted);text-align:center}.empty-icon{font-size:40px;opacity:.3}.empty-text{font-size:var(--text-sm)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .65s linear infinite;display:inline-block;flex-shrink:0}.skeleton{background:linear-gradient(90deg,var(--bg-hover) 25%,var(--bg-elevated) 50%,var(--bg-hover) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.min-w-0{min-width:0}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-right{text-align:right}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wrap{white-space:normal;word-break:break-all}.text-primary{color:var(--text-primary)!important}.text-secondary{color:var(--text-secondary)!important}.text-muted{color:var(--text-muted)!important}.text-accent{color:var(--accent)!important}.text-blue{color:var(--blue)!important}.text-green{color:var(--green)!important}.text-amber{color:var(--amber)!important}.text-red{color:var(--red)!important}.text-purple{color:var(--purple)!important}.text-2xs{font-size:var(--text-2xs)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.font-mono{font-family:var(--font-mono)!important}.divider{height:1px;background:var(--border);margin:var(--space-4) 0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.topnav{display:none!important}.bottom-nav{display:flex!important}.app-body{margin-top:0;padding-bottom:calc(var(--bottom-nav-height, 56px) + env(safe-area-inset-bottom,0px))}.page-content{padding:var(--space-3) var(--space-3)}.page-toolbar{padding:0 var(--space-3);height:auto;min-height:40px;flex-wrap:wrap;gap:var(--space-1);row-gap:var(--space-2);padding-top:var(--space-2);padding-bottom:var(--space-2)}.filter-bar{padding:var(--space-2) var(--space-3)}.sub-tabs{padding:0 var(--space-3);overflow-x:auto}.sub-tab{padding:var(--space-2) var(--space-3);font-size:12px}.grid-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.btn-sm{min-height:32px}.btn-md{min-height:36px}.btn-lg{min-height:44px}.row-action-btn{width:32px;height:32px;font-size:14px}.toast-container{bottom:calc(64px + env(safe-area-inset-bottom,0px));right:var(--space-3);left:var(--space-3)}.toast{max-width:100%;min-width:unset}.modal-overlay{padding:var(--space-3);align-items:flex-end}.modal{max-width:100%;max-height:85vh;border-radius:var(--radius-xl) var(--radius-xl) var(--radius-sm) var(--radius-sm)}.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)!important;gap:var(--space-2)}.settings-row{grid-template-columns:1fr!important}.app-body--split{flex-direction:column}.chat-panel{position:fixed!important;left:0;right:0;bottom:0;top:auto!important;height:50vh;width:100%!important;max-width:100%!important;min-width:0!important;z-index:var(--z-overlay);border-top:1px solid var(--border);border-right:none!important;border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:0 -4px 20px #0000004d;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.chat-panel.mobile-open{transform:translateY(0)}.chat-resize-handle{display:none!important}.mobile-chat-fab{position:fixed;right:var(--space-4);bottom:var(--space-4);width:48px;height:48px;border-radius:50%;border:none;background:var(--accent);color:var(--text-inverse);font-size:14px;font-weight:var(--font-bold);cursor:pointer;z-index:calc(var(--z-overlay) + 1);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000059;transition:background var(--ease-fast),transform var(--ease-fast)}.mobile-chat-fab:active{transform:scale(.92)}.mobile-chat-fab.active{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}}@media(max-width:480px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr!important}.stat-card{padding:var(--space-3)}.stat-value{font-size:var(--text-lg)}}.tax-form-table input:not([type=radio]):not([type=checkbox]),.tax-form-table select,.tax-form-table textarea{background:#ffffff0f!important;border:1px solid rgba(255,255,255,.12)!important;border-radius:2px;color:var(--text-primary)!important;outline:none;transition:border-color .15s,background .15s}.tax-form-table input:not([type=radio]):not([type=checkbox]):hover,.tax-form-table select:hover{background:#ffffff1a!important;border-color:#ffffff40!important}.tax-form-table input:not([type=radio]):not([type=checkbox]):focus,.tax-form-table select:focus{background:#3b82f61f!important;border-color:var(--blue)!important;box-shadow:0 0 0 2px #3b82f62e}
