:root{--bg: #f4efe6;--surface: #fffaf0;--surface-soft: #fffaf6;--surface-strong: #fff4e8;--text: #1d232e;--muted: #626f82;--accent: #aa5e28;--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: #ff9a58;--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}.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}.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)}.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}.scanner-video{width:100%;min-height:220px;border-radius:12px;background:var(--video-bg);border:1px solid var(--border)}.scanner-actions{margin-top:.8rem}.btn{border:0;border-radius:10px;padding:.6rem 1rem;font-weight:700;cursor:pointer;color:#fff;background:var(--accent)}.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}.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}.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{aspect-ratio:4/3;margin-bottom:.85rem}.product-detail-image{max-height:320px;margin-bottom:.9rem}.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}.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}.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-bottom:1rem}.sidebar-nav{flex-direction:row;flex-wrap:wrap}.manual-row{flex-direction:column}.settings-grid{grid-template-columns:1fr}.theme-setting{flex-direction:column;align-items:stretch}}
