:root{--bg: #f4efe6;--surface: #fffaf0;--surface-soft: #fffaf6;--surface-strong: #fff4e8;--text: #1d232e;--muted: #626f82;--accent: #8f4f22;--accent-strong: #4c270a;--accent-soft: #f2d7bd;--border: #e2d8c9;--sidebar-start: #f8ead8;--sidebar-end: #f3e4d0;--shadow: rgba(31, 35, 46, .08);--error-bg: #ffe9e7;--error-text: #9f2c28;--link: #0f4b7d;--video-bg: #111;font-family:Trebuchet MS,Avenir Next,Segoe UI,sans-serif;color:var(--text);background:radial-gradient(circle at 20% 0%,#faead6,var(--bg) 45%);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{--bg: #11151d;--surface: #1a212d;--surface-soft: #202938;--surface-strong: #243043;--text: #edf2fb;--muted: #afbacd;--accent: #d67a3b;--accent-strong: #fff1e5;--accent-soft: #c77b45;--border: #344154;--sidebar-start: #171d28;--sidebar-end: #121822;--shadow: rgba(0, 0, 0, .35);--error-bg: #4d2324;--error-text: #ffcac3;--link: #8fc9ff;--video-bg: #05070b}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg);color:var(--text)}#app{min-height:100vh}.app-shell{display:grid;grid-template-columns:250px minmax(0,1fr);min-height:100vh}.sidebar{padding:2rem 1rem;border-right:1px solid var(--border);background:linear-gradient(180deg,var(--sidebar-start) 0%,var(--sidebar-end) 100%)}.brand{margin:0 0 1rem;font-size:1.4rem;font-weight:800;letter-spacing:.02em}.sidebar-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.desktop-only{display:block}.menu-toggle{display:none;border:1px solid var(--border);border-radius:999px;padding:.45rem .85rem;font:inherit;font-weight:700;color:var(--text);background:var(--surface);cursor:pointer;transition:background-color .12s ease,color .12s ease,border-color .12s ease}.menu-toggle:hover{background:color-mix(in srgb,var(--accent-soft) 65%,var(--surface));color:var(--accent-strong);border-color:color-mix(in srgb,var(--accent-soft) 70%,var(--border))}.mobile-menu-backdrop{display:none}.auth-box{margin-bottom:1rem}.profile-chip{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;padding:.55rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-soft)}.profile-chip img{width:38px;height:38px;border-radius:50%;object-fit:cover}.profile-meta{min-width:0}.profile-name{margin:0;font-size:.93rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-username{margin:0;color:var(--muted);font-size:.82rem}:root[data-theme=dark] .profile-chip{background:linear-gradient(180deg,#253245,#1d2736);border-color:#42526a;box-shadow:inset 0 1px #ffffff0d}:root[data-theme=dark] .profile-name{color:#fff}:root[data-theme=dark] .profile-username{color:#d3dded}.sidebar-nav{display:flex;flex-direction:column;gap:.45rem}.nav-link{display:block;color:var(--text);text-decoration:none;padding:.65rem .85rem;border-radius:10px;font-weight:600;transition:background-color .12s ease,color .12s ease}.nav-link:hover{background:color-mix(in srgb,var(--accent-soft) 65%,transparent);color:var(--accent-strong)}.nav-link.router-link-active{background:var(--accent-soft);color:var(--accent-strong)}.content{padding:1.5rem}.panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:1.5rem;box-shadow:0 14px 35px var(--shadow)}.home-panel{display:grid;gap:1rem}.home-copy{max-width:42rem}.home-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.85rem}.home-action-card{display:grid;gap:.45rem;color:inherit;text-decoration:none;border:1px solid var(--border);border-radius:14px;padding:1rem;background:linear-gradient(180deg,color-mix(in srgb,var(--surface-soft) 88%,white),var(--surface-soft));transition:background-color .12s ease,border-color .12s ease,color .12s ease}.home-action-card h2{margin:0;font-size:1.05rem}.home-action-card:hover{background:color-mix(in srgb,var(--accent-soft) 20%,var(--surface-soft));border-color:color-mix(in srgb,var(--accent-soft) 70%,var(--border));color:inherit}.login-panel{max-width:480px}.login-sections{display:grid;gap:.8rem;margin-top:.8rem;margin-bottom:.8rem}.auth-card{border:1px solid var(--border);border-radius:12px;padding:.85rem;background:var(--surface-soft)}.auth-card h2{margin:0 0 .6rem;font-size:1rem}.auth-form{display:grid;gap:.5rem}.eyebrow{margin:0;color:var(--accent);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}h1{margin:.45rem 0 .8rem;line-height:1.2}.copy{margin:0;color:var(--muted);line-height:1.6}.scanner{margin-top:1.25rem}.scan-panel{display:grid;gap:.9rem}.scanner-video{width:100%;min-height:220px;border-radius:12px;background:var(--video-bg);border:1px solid var(--border);object-fit:cover}.scanner-actions{margin-top:.8rem}.btn{border:0;border-radius:10px;padding:.6rem 1rem;font-weight:700;cursor:pointer;color:#fff;background:var(--accent);transition:background-color .12s ease,filter .12s ease}.btn:hover:not(:disabled){filter:brightness(1.06)}.btn:disabled{opacity:.7;cursor:not-allowed}.btn-secondary{background:#334155}.logout-btn{margin-bottom:1rem;width:100%}.manual-form{margin-top:1.2rem}.manual-row{display:flex;gap:.55rem;margin-top:.4rem}.label{font-weight:600;color:var(--text)}.input{width:100%;border:1px solid var(--border);border-radius:10px;padding:.62rem .75rem;font:inherit;background:var(--surface);color:var(--text)}.hint{margin-top:.45rem;color:var(--muted);font-size:.9rem}.hint a{color:var(--link);font-weight:700}.error{margin-top:1rem;padding:.8rem;border-radius:10px;background:var(--error-bg);color:var(--error-text)}.result-card{margin-top:1rem;padding:1rem;border-radius:12px;background:var(--surface-strong);border:1px solid var(--border)}.result-card h2{margin:0 0 .6rem}.result-card p{margin:.2rem 0}.rate-form{margin-top:.9rem;display:grid;gap:.45rem}.upload-form{display:grid;gap:.5rem}.upload-form h3{margin:.3rem 0 .1rem;font-size:1rem}.upload-trigger{display:inline-flex;align-items:center;justify-content:center;width:fit-content;position:relative;overflow:hidden}.upload-trigger.disabled{opacity:.7;cursor:not-allowed}.upload-input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-trigger.disabled .upload-input{cursor:not-allowed}.crop-modal{width:min(100%,560px);max-height:min(92vh,92dvh);overflow:auto;-webkit-overflow-scrolling:touch}.crop-stage{position:relative;width:min(100%,420px);margin:1rem auto 0}.crop-stage-image{display:block;width:100%;max-height:420px;object-fit:contain;border-radius:14px;border:1px solid var(--border);background:var(--surface)}.crop-overlay{position:absolute;inset:0;cursor:grab;touch-action:none}.crop-overlay.dragging{cursor:grabbing}.crop-overlay-hole{position:absolute;left:var(--crop-left);top:var(--crop-top);width:var(--crop-width);height:var(--crop-height);border:2px solid rgba(255,255,255,.95);border-radius:14px;background:transparent;box-shadow:0 0 0 999px #11151d47,0 0 0 1px #11151d33 inset;pointer-events:none}.crop-preview{margin:1rem auto 0}.crop-controls{display:grid;gap:.45rem;margin-top:1rem}.crop-controls input[type=range]{width:100%}.rate-form h3{margin:.3rem 0 .1rem;font-size:1rem}.textarea{resize:vertical}.profile-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.8rem}.mini-profile{border:1px solid var(--border);border-radius:12px;padding:.8rem;background:var(--surface-soft);display:grid;grid-template-columns:46px 1fr;gap:.7rem}.mini-profile img{width:46px;height:46px;border-radius:50%;object-fit:cover}.mini-profile h2{margin:0 0 .15rem;font-size:1rem}.rating-list{margin-top:1rem;display:grid;gap:.8rem}.rating-item{border:1px solid var(--border);border-radius:12px;padding:.9rem;background:var(--surface-soft)}.rating-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.rating-head h2{margin:0;font-size:1.05rem}.score-pill{margin:0;padding:.2rem .55rem;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong);font-weight:800;font-size:.9rem}.products-toolbar{display:grid;gap:1rem;margin-top:1rem}.mobile-filter{display:none}.category-chips,.toggle-group{display:flex;gap:.6rem;flex-wrap:wrap}.chip-btn{border:1px solid var(--border);background:var(--surface-soft);color:var(--text);border-radius:999px;padding:.55rem .9rem;font:inherit;font-weight:700;cursor:pointer}.chip-btn.active{background:var(--accent-soft);color:var(--accent-strong)}.category-heading{margin-top:1rem}.product-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.9rem}.product-card{border:1px solid var(--border);border-radius:14px;padding:.95rem;background:var(--surface-soft)}.product-image,.product-detail-image{display:block;width:100%;object-fit:cover;border-radius:12px;border:1px solid var(--border);background:var(--surface)}.product-image{max-width:260px;aspect-ratio:4/5;margin:0 auto .85rem}.product-detail-image{width:min(100%,420px);aspect-ratio:4/5;max-height:none;margin:0 auto .9rem}.product-detail-layout{display:grid;gap:1rem}.product-detail-media,.product-detail-content{min-width:0}.product-link{color:inherit;text-decoration:none;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.product-link:hover{transform:translateY(-2px);border-color:var(--accent-soft);box-shadow:0 12px 24px var(--shadow)}.product-card-head{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start}.product-card h2{margin:0 0 .2rem;font-size:1.05rem}.barcode-pill{margin:0;border-radius:999px;background:var(--surface);border:1px solid var(--border);padding:.2rem .55rem;font-size:.78rem;color:var(--muted)}.ratings-section{margin-top:1.2rem}.ratings-section h2{margin:0 0 .8rem}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;padding:1rem 1rem calc(1rem + env(safe-area-inset-bottom,0px));background:#11151d6b;z-index:40;overscroll-behavior:contain}.modal-card{width:min(100%,420px);border:1px solid var(--border);border-radius:16px;padding:1.2rem;background:var(--surface);box-shadow:0 18px 36px var(--shadow)}.modal-card h2{margin:.4rem 0 .6rem}.modal-actions{display:flex;gap:.7rem;margin-top:1rem;flex-wrap:wrap;padding-bottom:max(.2rem,env(safe-area-inset-bottom,0px))}.profile-page{max-width:980px}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-top:1rem}.settings-card{border:1px solid var(--border);border-radius:14px;padding:1rem;background:var(--surface-soft)}.settings-card h2{margin:0 0 .5rem}.admin-page{max-width:1080px}.admin-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-top:1rem}.admin-list{display:grid;gap:.8rem;margin-top:1rem}.admin-item{border:1px solid var(--border);border-radius:12px;padding:.9rem;background:var(--surface);display:grid;gap:.8rem}.admin-item h3{margin:0 0 .2rem;font-size:1rem}.admin-actions{display:flex;gap:.6rem;flex-wrap:wrap}.settings-form{display:grid;gap:.6rem;margin-top:.9rem}.theme-setting,.account-summary,.theme-preview{border:1px solid var(--border);border-radius:12px;padding:.9rem;background:var(--surface)}.theme-setting{display:flex;justify-content:space-between;gap:1rem;align-items:center;margin-top:.9rem}.theme-preview,.account-summary{margin-top:.9rem}.setting-title{margin:0;font-weight:800;color:var(--text)}[data-preview-theme=dark]{background:linear-gradient(135deg,#171d28,#222c3b)}[data-preview-theme=light]{background:linear-gradient(135deg,#fff6ea,#f5e4cf)}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--border);padding:.7rem .9rem}.desktop-only{display:none!important}.brand{margin-bottom:0}.menu-toggle{display:inline-flex;align-items:center;justify-content:center}.mobile-menu-backdrop{position:fixed;inset:0;display:block;padding:4.25rem 1rem 1rem;background:#11151d4d;z-index:35}.mobile-menu-card{width:min(100%,420px);margin:0 auto;border:1px solid var(--border);border-radius:16px;background:var(--surface);box-shadow:0 18px 36px var(--shadow);padding:1rem}.mobile-menu-card .sidebar-nav{display:flex;flex-direction:column;gap:.35rem;margin-top:.9rem}.mobile-menu-card .logout-btn{width:100%}.manual-row{flex-direction:column}.scanner-actions .btn,.manual-row .btn{width:100%}.scan-panel{padding-top:.85rem;gap:.8rem}.scan-panel>h1{margin-bottom:.35rem}.scan-panel>.copy,.scan-panel>.hint{margin-top:0}.scanner{margin-top:.25rem}.scanner-video{min-height:min(42vh,24rem);aspect-ratio:auto;border-radius:0;border-left:0;border-right:0;margin-left:-1rem;margin-right:-1rem;width:calc(100% + 2rem)}.scanner-actions{margin-top:.6rem}.manual-form{margin-top:.7rem}.products-toolbar{gap:.75rem}.mobile-filter{display:grid;gap:.35rem}.desktop-filter{display:none}.category-chips,.toggle-group{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;width:100%;max-width:100%;padding-bottom:.15rem;scrollbar-width:none}.category-chips::-webkit-scrollbar,.toggle-group::-webkit-scrollbar{display:none}.chip-btn{flex:0 0 auto;white-space:nowrap}.product-grid,.profile-grid,.settings-grid,.admin-grid{grid-template-columns:1fr;gap:.75rem}.product-card,.settings-card,.admin-item,.mini-profile,.rating-item,.result-card,.theme-setting,.account-summary,.theme-preview{border-radius:12px;padding:.85rem}.mini-profile{grid-template-columns:42px 1fr;gap:.6rem}.mini-profile img{width:42px;height:42px}.product-image{max-width:none;width:100%}.product-card-head,.rating-head,.theme-setting{gap:.6rem}.product-card-head{align-items:flex-start}.barcode-pill{font-size:.74rem}.admin-actions,.modal-actions{flex-direction:column}.admin-actions .btn,.modal-actions .btn{width:100%}.product-detail-layout{grid-template-columns:1fr}.theme-setting{flex-direction:column;align-items:stretch}.content{padding:0}.panel{border-radius:0;border-left:0;border-right:0;box-shadow:none;padding:1rem}.home-panel{gap:.9rem}.home-actions{grid-template-columns:1fr;gap:.7rem}.home-action-card{padding:.9rem}.modal-backdrop{align-items:end;place-items:end center}.crop-modal{width:100%}.modal-actions{position:sticky;bottom:calc(-1.2rem + env(safe-area-inset-bottom,0px));margin-left:-1.2rem;margin-right:-1.2rem;margin-bottom:-1.2rem;padding:.9rem 1.2rem calc(.9rem + env(safe-area-inset-bottom,0px));background:var(--surface);border-top:1px solid var(--border)}.modal-actions .btn{flex:1 1 0}}@media(min-width:980px){.product-detail-layout{grid-template-columns:minmax(280px,420px) minmax(0,1fr);align-items:start}.product-detail-image{margin-bottom:0}}
