:root{--bg: #f7f3ec;--bg-subtle: #efe9de;--bg-elevated: #ffffff;--text: #1a1310;--text-secondary: #5c4f42;--muted: #8a7b68;--accent: #c8952a;--accent-hover: #b07f1c;--accent-light: rgba(200, 149, 42, .14);--accent-soft: #faf1dc;--secondary: #a53f2d;--secondary-light: rgba(165, 63, 45, .1);--success: #2d8a4e;--success-bg: #e8f5e9;--success-soft: #d8efda;--error: #c93b37;--error-bg: #fdeaea;--warning: #c08410;--warning-bg: #fdf0d0;--info: #3e7ea2;--info-bg: #e3eff8;--border: #e5ddcf;--border-strong: #ccbea7;--card: #ffffff;--shadow-xs: 0 1px 2px rgba(37, 27, 18, .04);--shadow-sm: 0 2px 4px rgba(37, 27, 18, .06), 0 1px 2px rgba(37, 27, 18, .04);--shadow: 0 4px 12px rgba(37, 27, 18, .08), 0 2px 4px rgba(37, 27, 18, .05);--shadow-md: 0 8px 20px rgba(37, 27, 18, .1), 0 3px 6px rgba(37, 27, 18, .06);--shadow-lg: 0 16px 40px rgba(37, 27, 18, .14), 0 4px 10px rgba(37, 27, 18, .06);--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--radius-lg: 16px;--nav-height: 64px;--transition: .18s cubic-bezier(.4, 0, .2, 1);--transition-slow: .28s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.55;color:var(--text);background:radial-gradient(900px circle at 15% -10%,rgba(200,149,42,.07) 0%,transparent 55%),radial-gradient(700px circle at 105% 105%,rgba(165,63,45,.05) 0%,transparent 55%),var(--bg);background-attachment:fixed;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-numeric:tabular-nums}h1,h2,h3,h4{letter-spacing:-.015em;color:var(--text)}code{font-family:JetBrains Mono,Menlo,monospace;font-size:.88em;padding:1px 6px;background:var(--bg-subtle);border-radius:4px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:3px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.app{min-height:100%;display:flex;flex-direction:column}.app-header{background:#ffffffd9;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border-bottom:1px solid var(--border);padding:14px 0;position:sticky;top:0;z-index:10}.app-header-inner{display:flex;flex-direction:column;padding:0 24px;max-width:1000px;margin:0 auto;width:100%}.brand{font-weight:800;font-size:18px;letter-spacing:-.02em;color:var(--text)}.brand-sub{font-size:11px;color:var(--muted);letter-spacing:1.2px;text-transform:uppercase;font-weight:600}.app-main{flex:1;padding:24px;padding-bottom:calc(var(--nav-height) + 24px);max-width:1000px;width:100%;margin:0 auto;animation:fadeInUp .35s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.offline-banner{background:var(--error);color:#fff;padding:10px 20px;text-align:center;font-size:14px;font-weight:600;box-shadow:0 2px 8px #c93b3747}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:#ffffffe6;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border-top:1px solid var(--border);display:flex;justify-content:space-around;align-items:stretch;z-index:20;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 16px #251b120f}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);text-decoration:none;font-size:11px;font-weight:600;padding:6px;min-height:44px;transition:color var(--transition);position:relative}.bottom-nav a.active{color:var(--accent-hover)}.bottom-nav a.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:28px;height:2px;background:var(--accent);border-radius:0 0 2px 2px;opacity:.7}.bottom-nav .nav-icon{font-size:22px;line-height:1}.card{background:#ffffffb8;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border:1px solid rgba(255,255,255,.45);border-radius:var(--radius);padding:16px 18px;margin-bottom:10px;box-shadow:var(--shadow-xs),inset 0 0 0 1px #ffffff4d;transition:box-shadow var(--transition),transform var(--transition),background var(--transition)}.card:hover{background:#ffffffd9;box-shadow:var(--shadow-sm),inset 0 0 0 1px #fff6}.card-title{font-weight:700;font-size:16px;margin:0 0 3px;letter-spacing:-.015em}.card-sub{color:var(--muted);font-size:13px}button,.btn{font-family:inherit;font-size:14px;color:var(--text);background:var(--card);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:9px 16px;min-height:42px;cursor:pointer;font-weight:600;transition:all var(--transition);position:relative}button:hover,.btn:hover{background:var(--bg-subtle);border-color:var(--muted);transform:translateY(-1px);box-shadow:var(--shadow-sm)}button:active,.btn:active{transform:translateY(0) scale(.98)}button:disabled,.btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:#ffffff8c;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border:1px solid rgba(200,149,42,.42);color:var(--accent-hover);font-weight:700;box-shadow:0 1px 2px #c8952a14,inset 0 0 0 1px #fff6}.btn-primary:hover{background:#ffffffbf;border-color:var(--accent);color:var(--accent-hover);box-shadow:0 4px 16px #c8952a2e,inset 0 0 0 1px #ffffff8c}.btn-danger{background:#ffffff80;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border:1px solid rgba(201,59,55,.45);color:var(--error);font-weight:700}.btn-danger:hover{background:#ffffffbf;border-color:var(--error);color:var(--error);box-shadow:0 4px 16px #c93b3729}.btn-ghost{background:transparent;border-color:transparent;color:var(--muted);min-height:auto;padding:6px 10px;font-weight:500;box-shadow:none}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text);border-color:transparent;box-shadow:none;transform:none}input,select,textarea{font-family:inherit;font-size:14px;color:var(--text);background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;min-height:42px;width:100%;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}input:hover,select:hover,textarea:hover{border-color:var(--border-strong)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light);background:#fff}input::placeholder,textarea::placeholder{color:var(--border-strong);font-weight:400}label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.01em}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.3px;border:1px solid transparent}.badge-pending{background:var(--error-bg);color:var(--error);border-color:#c93b3733}.badge-partial{background:var(--warning-bg);color:var(--warning);border-color:#c0841038}.badge-printed{background:var(--success-bg);color:var(--success);border-color:#2d8a4e38}.badge-source{background:var(--bg-subtle);color:var(--text-secondary);border-color:var(--border)}.empty{text-align:center;padding:56px 20px;color:var(--muted);background:var(--bg-elevated);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);margin:16px 0}.empty-icon{font-size:44px;margin-bottom:14px;opacity:.55}.loading{text-align:center;padding:36px;color:var(--muted)}.loading:after{content:"…";animation:loadingDots 1.2s steps(4,end) infinite}@keyframes loadingDots{0%{content:"·"}25%{content:"··"}50%{content:"···"}75%{content:"····"}to{content:"·"}}.tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:8px;margin-bottom:16px;-webkit-overflow-scrolling:touch}.tabs::-webkit-scrollbar{display:none}.tab{flex:0 0 auto;padding:8px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.3);background:#fff6;backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;color:var(--text-secondary);min-height:36px;transition:all var(--transition)}.tab:hover{background:#ffffffa6;border-color:#ffffff8c;transform:translateY(-1px)}.tab.active{background:#ffffffd9;border-color:#c8952a8c;color:var(--accent-hover);box-shadow:0 2px 8px #c8952a24,inset 0 0 0 1px #ffffff80}.action-bar{position:fixed;left:0;right:0;bottom:var(--nav-height);background:#ffffffeb;backdrop-filter:blur(14px) saturate(180%);-webkit-backdrop-filter:blur(14px) saturate(180%);border-top:1px solid var(--border);padding:14px 24px;display:flex;gap:10px;align-items:center;justify-content:space-between;z-index:15;box-shadow:0 -4px 20px #251b1214;padding-bottom:calc(14px + env(safe-area-inset-bottom));animation:slideUp .28s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a13108c;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .22s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--card);border-radius:var(--radius-lg);max-width:520px;width:100%;max-height:90vh;overflow:auto;padding:28px;box-shadow:var(--shadow-lg);animation:scaleIn .22s cubic-bezier(.34,1.56,.64,1)}@keyframes scaleIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h2{margin-top:0;font-size:22px;font-weight:700;letter-spacing:-.02em}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:radial-gradient(900px circle at 20% 0%,var(--accent-soft) 0%,transparent 50%),radial-gradient(900px circle at 100% 100%,#f5d8d3 0%,transparent 50%),var(--bg)}.login-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 32px;max-width:400px;width:100%;box-shadow:var(--shadow-lg)}.login-header{display:flex;flex-direction:column;margin-bottom:28px;text-align:center}.login-error{margin-top:12px;padding:12px 16px;background:var(--error-bg);color:var(--error);border:1px solid rgba(201,59,55,.22);border-radius:var(--radius-sm);font-size:14px;font-weight:500}hr{border:0;height:1px;background:var(--border);margin:18px 0}::selection{background:var(--accent-light);color:var(--text)}@media (min-width: 900px){body{font-size:15px}.app-main{padding:32px 40px}.bottom-nav{position:sticky;height:auto;flex-direction:column;width:220px;border-top:none;border-right:1px solid var(--border);box-shadow:none}}
