@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=IBM+Plex+Sans:wght@400;500;600&family=Kanit:wght@500;600&display=swap";:root{--bg-primary: #0b0e12;--bg-secondary: #12171e;--bg-tertiary: #1a2029;--bg-hover: #232b36;--bg-rail: #0f141a;--border-soft: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .12);--border-strong: rgba(255, 255, 255, .2);--text-primary: #e2e7ef;--text-secondary: #aab2c4;--text-muted: #778198;--text-disabled: #525c70;--state-available: #4f9b6f;--state-shared: #4c7ba6;--state-lent: #d2a45e;--state-unavailable: #c7645b;--state-rare: #7a6a9e;--accent-primary: #5aa47c;--accent-warning: #e08a41;--accent-info: #5a86b3;--fx-grid: rgba(255, 255, 255, .04);--fx-noise: rgba(255, 255, 255, .03);--fx-glow: rgba(90, 164, 124, .35);--fx-warning: rgba(224, 138, 65, .35);--inventory-accent: #5d6b8a;--inventory-accent-muted: rgba(93, 107, 138, .28);--font-display: "Kanit", "Rajdhani", "Segoe UI", sans-serif;--font-body: "IBM Plex Sans", "Source Sans 3", "SF Pro", sans-serif;--font-mono: "IBM Plex Mono", "JetBrains Mono", ui-monospace, monospace;--font-primary: var(--font-body);--text-xs: 11px;--text-sm: 13px;--text-md: 15px;--text-lg: 18px;--text-xl: 22px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--track-tight: -.01em;--track-wide: .06em;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 2px 6px rgba(0, 0, 0, .35);--shadow-md: 0 10px 28px rgba(0, 0, 0, .4);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .03), inset 0 -1px 0 rgba(0, 0, 0, .4);--motion-fast: .12s;--motion-normal: .18s;--motion-slow: .26s;--motion-scan: .32s;--motion-pulse: .22s;--ease-standard: cubic-bezier(.2, 0, .2, 1);--ease-scan: cubic-bezier(.22, 0, .12, 1);--z-base: 0;--z-card: 10;--z-action: 20;--z-sheet: 30;--z-modal: 40;--safe-top: max(env(safe-area-inset-top), var(--tg-safe-area-inset-top, 0px), var(--tg-content-safe-area-inset-top, 0px));--safe-bottom: max(env(safe-area-inset-bottom), var(--tg-safe-area-inset-bottom, 0px), var(--tg-content-safe-area-inset-bottom, 0px));--viewport-height: var(--tg-viewport-stable-height, 100svh);--top-inset: 0px}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-primary);background:radial-gradient(120% 120% at 10% 0%,#151c26,#0b0e12 55%,#07090d);color:var(--text-primary);min-height:var(--viewport-height);-webkit-text-size-adjust:100%;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(0deg,transparent 0 11px,var(--fx-grid) 11px 12px),repeating-linear-gradient(90deg,transparent 0 11px,var(--fx-grid) 11px 12px);opacity:.35;pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/></filter><rect width='120' height='120' filter='url(%23n)' opacity='0.15'/></svg>");opacity:.08;mix-blend-mode:soft-light;pointer-events:none;z-index:0}a{color:var(--accent-info)}button{font-family:inherit}#app{min-height:100%;position:relative;z-index:1}.app{min-height:var(--viewport-height);display:flex;flex-direction:column;padding:calc(var(--space-4) + var(--top-inset)) var(--space-3) calc(var(--space-6) + 64px + var(--safe-bottom));gap:var(--space-4)}.auth-gate{flex:1;display:flex;align-items:center;justify-content:center}.auth-link{text-decoration:none}.inventory-switcher{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);background:linear-gradient(140deg,#1a2029f2,#10141af2),var(--bg-secondary);border:1px solid var(--border-medium);box-shadow:var(--shadow-inset);position:relative;overflow:hidden;cursor:pointer;min-height:44px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard)}.inventory-switcher:active{background:var(--bg-hover)}.inventory-switcher:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 1px,transparent 1px 10px);opacity:.3;pointer-events:none;z-index:0}.inventory-switcher>*{position:relative;z-index:1}.inventory-switcher:focus-visible{outline:2px solid var(--border-medium);outline-offset:2px}.inv-dot{width:12px;height:12px;border-radius:999px;background:var(--inventory-accent);box-shadow:0 0 0 4px var(--inventory-accent-muted),0 0 12px #5d6b8a66}.inv-meta{display:grid;gap:2px}.inv-status{margin-left:auto;display:grid;gap:2px;text-align:right}.inv-count{font-size:var(--text-sm);color:var(--text-secondary)}.inv-title{font-size:var(--text-lg);font-weight:var(--weight-medium);font-family:var(--font-display);letter-spacing:var(--track-tight)}.inv-subtitle{font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.02em}.inv-chevron{margin-left:var(--space-2);color:var(--text-muted);font-size:var(--text-lg);font-family:var(--font-display)}.sticky-context{position:sticky;top:var(--top-inset);z-index:var(--z-action);display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin:0 -12px;background:#10141af5;border-bottom:1px solid var(--border-medium);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sticky-context .tag{font-size:var(--text-sm);letter-spacing:.08em}.sticky-context.hidden{display:none}.view-badge{margin-left:auto;padding:4px 8px;border-radius:999px;font-size:var(--text-xs);color:var(--text-secondary);border:1px solid var(--border-medium);background:#0f141aa6}.item-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-2)}@media (min-width: 520px){.item-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3)}}.item-card{background:var(--bg-tertiary);border:1px solid var(--border-soft);border-radius:var(--radius-md);overflow:hidden;display:grid;grid-template-rows:auto 1fr;min-height:140px;position:relative;cursor:pointer;box-shadow:var(--shadow-inset);transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard);animation:scanIn var(--motion-scan) var(--ease-scan) both}.item-grid .item-card:nth-child(odd){animation-delay:40ms}.item-grid .item-card:nth-child(3n){animation-delay:80ms}.item-card:active{background:var(--bg-hover);transform:translateY(1px)}.item-card.is-rare{border-color:#7a6a9e73;box-shadow:var(--shadow-inset),inset 2px 0 #7a6a9ecc}.item-card__image{width:100%;height:auto;aspect-ratio:4 / 3;background:linear-gradient(160deg,#ffffff0d,#fff0);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--text-xs);position:relative;overflow:hidden}.item-card__image:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 12px);opacity:.25;pointer-events:none}.item-card__image img{width:100%;height:100%;object-fit:cover;display:block;position:relative;z-index:1}.item-card__placeholder{position:relative;z-index:1}.item-card__content{padding:var(--space-3);display:grid;gap:var(--space-1)}.item-name{font-size:var(--text-md);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-title-row{display:grid;grid-template-columns:1fr auto;align-items:baseline;gap:var(--space-2)}.item-qty{font-size:var(--text-sm);color:var(--text-secondary);padding:2px 6px;border:1px solid var(--border-soft);border-radius:999px;background:#0f141a99}.state-icon{position:absolute;top:var(--space-2);right:var(--space-2);width:22px;height:22px;border-radius:999px;background:#07090d8c;border:1px solid var(--border-medium);display:flex;align-items:center;justify-content:center}.state-dot{width:8px;height:8px;border-radius:999px;background:var(--state-available)}.state-available{background:var(--state-available)}.state-lent{background:var(--state-lent)}.state-unavailable{background:var(--state-unavailable)}.state-shared{background:var(--state-shared)}.stat-fill.state-available{box-shadow:0 0 10px #4f9b6f59}.stat-fill.state-lent{box-shadow:0 0 10px #d2a45e59}.stat-fill.state-unavailable{box-shadow:0 0 10px #c7645b59}.stat-fill.state-shared{box-shadow:0 0 10px #4c7ba659}.skeleton{position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);animation:scanline 1.2s infinite}.skeleton-block{width:100%;height:100%;background:#ffffff0d}@keyframes scanline{to{transform:translate(100%)}}@keyframes scanIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.empty-state{border:1px dashed var(--border-medium);border-radius:var(--radius-lg);padding:var(--space-6);text-align:center;color:var(--text-muted);background:#0f141a99}.empty-ghost{height:140px;border-radius:var(--radius-md);background:linear-gradient(135deg,#ffffff0d,#ffffff03);margin-bottom:var(--space-4)}.action-bar{position:fixed;bottom:0;left:0;right:0;padding:var(--space-3);padding-bottom:calc(var(--space-3) + var(--safe-bottom));background:var(--bg-rail);border-top:1px solid var(--border-medium);box-shadow:0 -12px 28px #00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;grid-auto-flow:column;grid-auto-columns:minmax(0,1fr);gap:var(--space-2);justify-content:center;z-index:var(--z-action)}.action-bar .btn{width:100%;justify-content:center}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:10px 14px;border-radius:var(--radius-md);border:1px solid transparent;background:var(--bg-tertiary);color:var(--text-primary);font-size:var(--text-sm);cursor:pointer;min-height:44px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard),box-shadow var(--motion-fast) var(--ease-standard),transform var(--motion-fast) var(--ease-standard)}.btn.tiny{min-height:32px;padding:6px 10px;font-size:var(--text-xs)}.btn.primary{background:linear-gradient(140deg,#5aa47c33,#0d1214e6);border-color:#5aa47c73;box-shadow:0 0 0 1px #5aa47c33,0 0 18px var(--fx-glow);font-family:var(--font-display);letter-spacing:var(--track-tight)}.btn.secondary{background:linear-gradient(160deg,#1a2029e6,#10141ae6);border-color:var(--border-soft);box-shadow:var(--shadow-inset)}.btn.ghost{background:transparent;border-color:var(--border-medium);color:var(--text-muted)}.btn:active{transform:translateY(1px);box-shadow:0 0 0 1px #ffffff14}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--border-medium);outline-offset:2px}.spinner{width:var(--icon-sm);height:var(--icon-sm);border-radius:50%;border:2px solid var(--border-medium);border-top-color:var(--text-primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a0eb3;z-index:var(--z-sheet);display:flex;align-items:flex-end;justify-content:center}.sheet{width:100%;max-width:520px;background:linear-gradient(180deg,#12171efa,#0e1218fa);border-radius:0;border:1px solid var(--border-medium);padding:var(--space-4);box-shadow:var(--shadow-md);max-height:calc(var(--viewport-height) - var(--safe-top) - var(--space-6));overflow:auto;touch-action:pan-y;transition:transform var(--motion-normal) var(--ease-standard);will-change:transform;position:relative}.sheet.full{border-radius:0;max-width:none;height:100svh;padding-bottom:calc(var(--space-5) + var(--safe-bottom))}.sheet.dragging{transition:none}@supports (height: 100dvh){body,.app{min-height:100dvh}.sheet{max-height:calc(100dvh - var(--safe-top) - var(--space-6))}.sheet.full{height:100dvh}}.sheet-title{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--track-wide);font-family:var(--font-display);margin:0}.sheet-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.item-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.sheet-close{position:static;width:36px;height:36px;border-radius:999px;border:1px solid var(--border-medium);background:#0f141ae6;color:var(--text-secondary);font-family:var(--font-display);font-size:var(--text-sm);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-inset);transition:transform var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard)}.sheet-close:active{transform:translateY(1px)}.sheet-close:focus-visible{outline:2px solid var(--border-strong);outline-offset:2px}.rename-row{display:grid;gap:var(--space-2)}.rename-actions{display:flex;gap:var(--space-2);justify-content:flex-end}@media (min-width: 640px){.sheet{border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.sheet-section{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-soft);box-shadow:var(--shadow-inset);padding:var(--space-3);margin-bottom:var(--space-3)}.sheet-section:not(.list):not(.action-grid)>*+*{margin-top:var(--space-2)}.item-identity{display:grid;gap:var(--space-1)}.item-title{font-size:var(--text-lg);font-family:var(--font-display);letter-spacing:var(--track-tight)}.item-state-line{font-size:var(--text-sm);color:var(--text-secondary)}.stats-matrix{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-3)}.stat{display:grid;gap:6px}.stat-value{font-size:var(--text-sm);color:var(--text-secondary)}.stat-bar{height:6px;border-radius:999px;background:#ffffff14;overflow:hidden}.stat-fill{display:block;height:100%;border-radius:999px;background:var(--state-available)}.sheet-image{width:100%;height:auto;border-radius:var(--radius-md);display:block}.input{width:100%;padding:10px 12px;border-radius:var(--radius-md);border:1px solid var(--border-medium);background:var(--bg-secondary);color:var(--text-primary);font-size:16px}.input:focus{outline:1px solid var(--border-medium)}.input:focus-visible{outline:2px solid var(--border-medium);outline-offset:2px}.list{display:grid;gap:var(--space-2)}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-2)}.action-grid .btn{width:100%;justify-content:center}.notification-row{background:var(--bg-tertiary);border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:var(--space-3);color:var(--text-secondary);font-size:var(--text-sm);min-height:44px;box-shadow:var(--shadow-inset)}.notification-text{color:var(--text-secondary);line-height:1.4}.inventory-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-soft);box-shadow:var(--shadow-inset);position:relative;overflow:hidden;cursor:pointer;min-height:44px;transition:background var(--motion-fast) var(--ease-standard),border-color var(--motion-fast) var(--ease-standard)}.inventory-row.active{border-color:var(--border-strong)}.inventory-row:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 12px);opacity:.18;pointer-events:none}.inventory-row>*{position:relative;z-index:1}.inventory-row:focus-visible{outline:2px solid var(--border-medium);outline-offset:2px}.inventory-row__meta{display:grid;gap:2px}.inventory-row__title{font-family:var(--font-display);letter-spacing:var(--track-tight);font-size:var(--text-md)}.inventory-row__subtitle{color:var(--text-muted);font-size:var(--text-sm)}.checkmark{margin-left:auto;color:var(--state-available)}.tag,.hud-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--track-wide);font-family:var(--font-display)}.mono{font-family:var(--font-mono);letter-spacing:.02em}label{display:block;font-size:var(--text-xs);color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:var(--track-wide);font-family:var(--font-display)}.toast{position:fixed;left:50%;bottom:76px;transform:translate(-50%);background:var(--bg-tertiary);border:1px solid var(--border-medium);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);z-index:var(--z-modal);font-size:var(--text-sm);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--space-2)}.toast .btn{padding:6px 10px;font-size:var(--text-xs)}.camera-frame{background:#0b0e12;border-radius:var(--radius-lg);border:1px solid var(--border-medium);box-shadow:var(--shadow-inset);height:52vh;display:flex;align-items:center;justify-content:center;color:var(--text-muted);margin-bottom:var(--space-4)}.image-placeholder{height:160px;border-radius:var(--radius-md);border:1px solid var(--border-medium);background:#0b0e12;box-shadow:var(--shadow-inset);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.control-tray{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-3);border:1px solid var(--border-medium);box-shadow:var(--shadow-inset);display:grid;gap:var(--space-2);padding-bottom:calc(var(--space-3) + var(--safe-bottom))}.control-tray .btn{width:100%;justify-content:center}.file-input{display:none}.link-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);flex-wrap:wrap}.link-row .btn{padding:6px 10px;font-size:var(--text-xs)}.small{font-size:var(--text-xs);color:var(--text-muted)}.divider{height:1px;background:var(--border-medium);margin:var(--space-3) 0}.pad-1{padding:var(--space-1)}.pad-2{padding:var(--space-2)}.pad-3{padding:var(--space-3)}.pad-4{padding:var(--space-4)}.pad-5{padding:var(--space-5)}.pad-6{padding:var(--space-6)}.pad-7{padding:var(--space-7)}.radius-sm{border-radius:var(--radius-sm)}.radius-md{border-radius:var(--radius-md)}.radius-lg{border-radius:var(--radius-lg)}.radius-xl{border-radius:var(--radius-xl)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important}}
