:root{--bg: #0a0e17;--bg-elev: #141a28;--bg-elev-2: #1f2738;--fg: #e9eef7;--fg-muted: #93a1b8;--accent: #38bdf8;--accent-strong: #0ea5e9;--accent-soft: rgba(56, 189, 248, .14);--danger: #f43f5e;--success: #22c55e;--warn: #f59e0b;--border: rgba(255, 255, 255, .07);--border-strong: rgba(255, 255, 255, .12);--radius: 16px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow: 0 2px 6px rgba(0, 0, 0, .3), 0 12px 28px -12px rgba(0, 0, 0, .6);--ring: 0 0 0 3px rgba(56, 189, 248, .22);--nav-h: 66px;--topbar-h: 46px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--text-display: 28px;--text-h1: 21px;--text-h2: 16px;--text-body: 15px;--text-caption: 12.5px;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color-scheme:dark}*{box-sizing:border-box}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.flex-1{flex:1}.w-full{width:100%}.wrap{flex-wrap:wrap}svg.lucide{flex-shrink:0;vertical-align:-.18em}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--fg);-webkit-tap-highlight-color:transparent}body{font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;background:radial-gradient(1200px 600px at 50% -10%,rgba(56,189,248,.08),transparent 60%),var(--bg)}input,textarea,select,button{font:inherit;color:inherit}button{cursor:pointer;border:none;background:linear-gradient(180deg,var(--accent),var(--accent-strong));color:#021018;padding:12px 18px;border-radius:var(--radius-sm);font-weight:650;letter-spacing:.01em;min-height:46px;box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);transition:transform .12s ease,filter .12s ease,background .12s ease,opacity .12s ease}button:hover{filter:brightness(1.06)}button:active{transform:translateY(1px) scale(.99)}button:disabled{opacity:.45;cursor:not-allowed;transform:none;filter:none}button.secondary{background:var(--bg-elev-2);color:var(--fg);box-shadow:none;border:1px solid var(--border-strong)}button.ghost{background:transparent;color:var(--accent);padding:8px 12px;box-shadow:none;min-height:40px}button.ghost:hover{background:var(--accent-soft)}button.danger{background:var(--danger);color:#fff}input[type=text],input[type=number],input[type=search],input[type=password],textarea,select{width:100%;padding:12px 14px;background:var(--bg-elev);border:1px solid var(--border-strong);border-radius:var(--radius-sm);outline:none;min-height:46px;transition:border-color .12s ease,box-shadow .12s ease}textarea{min-height:84px;resize:vertical}input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:var(--ring)}input::placeholder,textarea::placeholder{color:var(--fg-muted);opacity:.7}label.field{display:block;font-size:12.5px;font-weight:550;color:var(--fg-muted);margin-bottom:6px;letter-spacing:.01em}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.app-main{flex:1;padding:16px;padding-top:calc(var(--topbar-h) + var(--safe-top) + 12px);padding-bottom:calc(var(--nav-h) + 16px + var(--safe-bottom));max-width:760px;width:100%;margin:0 auto}.top-bar{position:fixed;top:0;left:0;right:0;height:calc(var(--topbar-h) + var(--safe-top));padding-top:var(--safe-top);padding-right:14px;display:flex;align-items:center;justify-content:flex-end;gap:10px;background:#0a0e17b8;backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--border);z-index:12}.usage-meter{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--fg-muted);white-space:nowrap;padding:3px 9px;border:1px solid var(--border);border-radius:999px;background:var(--bg-elev-2)}.lang-flag{background:var(--bg-elev-2);color:var(--fg);border:1px solid var(--border-strong);box-shadow:none;min-height:34px;padding:4px 12px;font-size:18px;line-height:1;border-radius:999px}.lang-flag:hover{filter:none;border-color:var(--accent)}.app-header{position:sticky;top:calc(var(--topbar-h) + var(--safe-top));background:#0a0e17b8;backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);z-index:5;padding:14px 4px;margin-bottom:4px;display:flex;align-items:center;justify-content:space-between;gap:12px}.app-header h1{margin:0;font-size:21px;font-weight:700;letter-spacing:-.02em}.app-header .sub{color:var(--fg-muted);font-size:13px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#141a28d1;backdrop-filter:saturate(140%) blur(16px);-webkit-backdrop-filter:saturate(140%) blur(16px);border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);z-index:10}.bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--fg-muted);text-decoration:none;font-size:11px;font-weight:550}.bottom-nav a span{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 14px;border-radius:14px;transition:background .15s ease,color .15s ease}.bottom-nav a span.active{color:var(--accent);background:var(--accent-soft)}.bottom-nav .icon{font-size:20px;line-height:1}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.card h3{margin:0 0 8px;font-size:16px;font-weight:650;letter-spacing:-.01em}.card.tappable{cursor:pointer;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.card.tappable:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.card.tappable:active{transform:translateY(0) scale(.995)}.row{display:flex;gap:8px;align-items:center}.row.between{justify-content:space-between}.stack{display:flex;flex-direction:column;gap:12px}.muted{color:var(--fg-muted);font-size:13px}.list-row{display:flex;align-items:center;gap:var(--space-3);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3);margin-bottom:var(--space-2);text-decoration:none;color:inherit;box-shadow:var(--shadow-sm);transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}a.list-row:hover,.list-row[role=button]:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}a.list-row:active,.list-row[role=button]:active{transform:translateY(0) scale(.995)}.list-row[role=button]{cursor:pointer}.list-row-body{flex:1;min-width:0}.list-row-titleline{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2)}.list-row-title{font-weight:600;font-size:var(--text-body);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row-trailing{color:var(--fg-muted);font-size:var(--text-caption);flex-shrink:0}.list-row-sub{color:var(--fg-muted);font-size:var(--text-caption);margin-top:2px}.list-row-preview{color:var(--fg-muted);font-size:var(--text-caption);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-row-chevron{color:var(--fg-muted);opacity:.6}.icon-tile{display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:12px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--border)}.tag{display:inline-flex;align-items:center;background:var(--bg-elev-2);color:var(--fg);border-radius:999px;padding:4px 11px;font-size:12px;font-weight:550}.tag.accent{background:var(--accent-soft);color:var(--accent)}.tag.warn{background:#f59e0b29;color:var(--warn)}.tag.success{background:#22c55e29;color:var(--success)}.chip-group{display:flex;flex-wrap:wrap;gap:7px}.chip{background:var(--bg-elev-2);color:var(--fg);padding:8px 14px;border-radius:999px;border:1px solid transparent;font-size:13px;font-weight:550;min-height:38px;display:inline-flex;align-items:center;transition:background .12s ease,border-color .12s ease,color .12s ease}.chip:hover{border-color:var(--border-strong)}.chip.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.swatch{width:34px;height:34px;min-height:34px;padding:0;border-radius:50%;border:2px solid var(--border-strong);background:var(--bg-elev-2);box-shadow:none}.swatch:hover{filter:none}.swatch.active{border-color:var(--fg);box-shadow:0 0 0 2px var(--accent)}.swatch.clear{background:transparent;position:relative;overflow:hidden}.swatch.clear:after{content:"";position:absolute;left:50%;top:-4px;bottom:-4px;width:2px;background:var(--danger);transform:rotate(45deg)}.fab{position:fixed;right:18px;bottom:calc(var(--nav-h) + 18px + var(--safe-bottom));background:linear-gradient(180deg,var(--accent),var(--accent-strong));color:#021018;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 8px 24px -6px #38bdf880,var(--shadow);border:none;z-index:8}.empty{text-align:center;padding:48px 20px;color:var(--fg-muted)}.empty .emoji{font-size:52px;margin-bottom:10px;opacity:.9}.empty .icon-illustration{display:inline-flex;align-items:center;justify-content:center;width:84px;height:84px;margin:0 auto var(--space-3);border-radius:22px;background:var(--bg-elev);border:1px solid var(--border);color:var(--fg-muted)}.grid-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.thumb{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.thumb img{width:100%;aspect-ratio:1;object-fit:cover;background:#000}.thumb .meta{padding:10px;font-size:13px}.toast{position:fixed;left:50%;bottom:calc(var(--nav-h) + 24px + var(--safe-bottom));transform:translate(-50%);background:var(--bg-elev-2);color:var(--fg);padding:12px 20px;border-radius:999px;z-index:20;box-shadow:var(--shadow);border:1px solid var(--border-strong);animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.summary-grid .card{margin-bottom:0}.summary-grid .value{font-size:24px;font-weight:750;letter-spacing:-.02em}.summary-grid .muted{font-size:12.5px}.hero-search{display:flex;align-items:center;gap:var(--space-3);padding:15px var(--space-4);border-radius:var(--radius);background:linear-gradient(180deg,var(--accent-soft),rgba(56,189,248,.06));border:1px solid var(--accent);color:var(--accent);font-weight:600;font-size:var(--text-body);text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .14s ease,box-shadow .14s ease}.hero-search:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.hero-search span{color:var(--fg-muted);font-weight:500}.bento{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.bento .span-2{grid-column:1 / -1}.stat-tile{margin-bottom:0;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:var(--space-1)}.stat-tile .value{font-size:24px;font-weight:750;letter-spacing:-.02em}.stat-tile.span-2 .value{font-size:30px}.stat-tile .muted{font-size:var(--text-caption)}.rail{display:flex;gap:var(--space-2);overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.rail::-webkit-scrollbar{display:none}.rail-card{flex:0 0 auto;width:92px;text-decoration:none;color:inherit}.rail-name{font-size:var(--text-caption);margin-top:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.path{display:inline-flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:13px;color:var(--fg-muted)}.path .crumb{color:var(--fg)}.path .crumb.zone{color:var(--accent);font-weight:600}.path .sep{opacity:.5}a{color:var(--accent)}hr{border:none;border-top:1px solid var(--border);margin:16px 0}.wizard-steps{display:flex;gap:8px;padding:8px 0;overflow-x:auto;margin-bottom:16px;scrollbar-width:none}.wizard-steps::-webkit-scrollbar{display:none}.wizard-step{display:flex;align-items:center;gap:8px;padding:7px 13px;border-radius:999px;flex-shrink:0;background:var(--bg-elev);border:1px solid var(--border);color:var(--fg);font:inherit;cursor:pointer;transition:background .12s ease}.wizard-step:disabled{cursor:default}.wizard-step.todo{color:var(--fg-muted)}.wizard-step.current{background:var(--accent-soft);border-color:var(--accent)}.wizard-step.done{color:var(--fg-muted)}.wizard-step .dot{width:24px;height:24px;border-radius:50%;background:var(--bg-elev-2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:650}.wizard-step.done .dot{background:var(--success);color:#fff}.wizard-step.current .dot{background:var(--accent);color:#021018}.wizard-step .label{font-size:13px;white-space:nowrap;font-weight:550}.sketch-toolbar{display:flex;gap:6px;padding:8px;background:var(--bg-elev);border-radius:var(--radius);border:1px solid var(--border);flex-wrap:wrap}.sketch-toolbar button{flex:1;min-width:80px;background:var(--bg-elev-2);color:var(--fg);box-shadow:none;border:1px solid var(--border-strong)}.sketch-toolbar button.active{background:var(--accent);color:#021018;border-color:transparent}.row-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:13px 15px;display:flex;align-items:center;gap:12px;margin-bottom:8px;cursor:pointer;transition:border-color .12s ease,background .12s ease}.row-card:hover{border-color:var(--border-strong)}.row-card.selected{border-color:var(--accent);background:var(--accent-soft)}.row-card .check{width:26px;height:26px;border-radius:8px;border:2px solid var(--border-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0}.row-card.selected .check{border-color:var(--accent);background:var(--accent);color:#021018;font-weight:700}.row-card .body{flex:1}.row-card .body .title{font-weight:600}.row-card .body .sub{font-size:13px;color:var(--fg-muted)}.action-bar{position:sticky;bottom:calc(var(--nav-h) + var(--safe-bottom) + 8px);display:flex;gap:8px;padding:12px;background:#0a0e17d1;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);margin-top:16px;z-index:6;box-shadow:var(--shadow)}.action-bar button{flex:1}.scan-view{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:30;overflow:hidden}.scan-view video{width:100%;height:100%;object-fit:cover;display:block}.scan-reticle{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.scan-reticle>div{width:64vw;max-width:320px;aspect-ratio:1;border:3px solid rgba(255,255,255,.85);border-radius:24px;box-shadow:0 0 0 100vmax #0006}.scan-topbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:calc(var(--safe-top) + 12px) 16px 12px;z-index:2}.scan-hint{position:absolute;left:0;right:0;bottom:calc(var(--safe-bottom) + 28px);display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.8);padding:0 24px;text-align:center}.scan-result{position:absolute;left:0;right:0;bottom:0;background:#141a28f7;backdrop-filter:saturate(140%) blur(18px);-webkit-backdrop-filter:saturate(140%) blur(18px);border-top:1px solid var(--border-strong);border-radius:22px 22px 0 0;padding:var(--space-4) var(--space-4) calc(var(--space-4) + var(--safe-bottom));max-height:46vh;overflow-y:auto;z-index:3;box-shadow:0 -12px 40px -12px #000000b3;animation:sheet-up .22s cubic-bezier(.22,1,.36,1)}.box-label{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;color:#000;border:1px solid #000;border-radius:8px;padding:10px 12px;break-inside:avoid}.box-label-code{font-size:24px;font-weight:800;letter-spacing:-.02em}.box-label-qr{width:64px;height:64px}.print-sheet{display:none}@media print{.top-bar,.bottom-nav{display:none!important}body *{visibility:hidden}.print-sheet,.print-sheet *{visibility:visible}.print-sheet{display:grid!important;position:absolute;left:0;top:0;width:100%;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px;padding:0}@page{margin:8mm}}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#03060c8c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:50;display:flex;align-items:flex-end;justify-content:center;animation:sheet-fade .15s ease}.sheet{width:100%;max-width:760px;background:#141a28f5;backdrop-filter:saturate(140%) blur(18px);-webkit-backdrop-filter:saturate(140%) blur(18px);border:1px solid var(--border-strong);border-bottom:none;border-radius:22px 22px 0 0;padding:var(--space-3) var(--space-4) calc(var(--space-4) + var(--safe-bottom));box-shadow:0 -12px 40px -12px #000000b3;animation:sheet-up .22s cubic-bezier(.22,1,.36,1)}.sheet-grabber{width:40px;height:4px;border-radius:999px;background:var(--border-strong);margin:0 auto var(--space-3)}.sheet-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-3)}.sheet-header h3{margin:0;font-size:var(--text-h1);font-weight:700;letter-spacing:-.01em}.sheet-close{min-height:36px;padding:6px}.sheet-option{width:100%;background:transparent;color:var(--fg);box-shadow:none;justify-content:space-between;padding:14px;border-radius:var(--radius-sm);min-height:50px}.sheet-option:hover{background:var(--bg-elev-2);filter:none}.select-field{width:100%;background:var(--bg-elev);color:var(--fg);border:1px solid var(--border-strong);border-radius:var(--radius-sm);box-shadow:none;font-weight:500;justify-content:space-between;padding:12px 14px;min-height:46px}.select-field:hover{filter:none;border-color:var(--accent)}.select-field .lucide{color:var(--fg-muted)}@keyframes sheet-fade{0%{opacity:0}to{opacity:1}}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}
