*,*:before,*:after{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color:var(--text-primary, #1A1D2E);background:var(--bg-base, #EEF2F7);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;min-width:320px;min-height:100dvh}#root{min-height:100dvh}h1,h2,h3,h4{margin:0}img{display:block;max-width:100%}@font-face{font-family:uic;src:url(/assets/uic-round-outline-regular-DleFKwKT.woff2) format("woff2"),url(/assets/uic-round-outline-regular-Bz2XwUTh.woff) format("woff"),url(/assets/uic-round-outline-regular-DXrgP-OY.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}.uic{display:inline-block;line-height:1;font-style:normal;font-weight:400;font-variant:normal;text-transform:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:currentColor;font-family:uic}.uic:before{display:inline-block;speak:none}.uic-barcode-scanner:before{content:""}.uic-box:before{content:""}.uic-user:before{content:""}.uic-user-group-2:before{content:""}.uic-camera:before{content:""}.uic-dots-3-vertical:before{content:""}.uic-logout:before{content:""}.uic-close:before{content:""}.uic-refresh:before{content:""}.uic-cog:before{content:""}.uic-sync:before{content:""}.uic-checkmark:before{content:""}.uic-check-circle:before{content:""}.uic-cloud-tick:before{content:""}.uic-cloud-upload:before{content:""}.uic-cloud-off:before{content:""}.uic-signal-strength-full:before{content:""}.uic-wifi:before{content:""}.uic-wifi-off:before{content:""}.uic-trash:before{content:""}.uic-error-triangle:before{content:""}.uic-clock:before{content:""}.uic-hourglass:before{content:""}.uic-close-circle:before{content:""}.uic-search:before{content:""}.uic-arrow-left:before{content:""}.uic-info-circle:before{content:""}.uic-keyboard:before{content:""}.uic-image:before{content:""}.uic-image-gallery:before{content:""}.uic-chart-pie:before{content:""}.uic-calendar:before{content:""}.uic-apple:before{content:""}.uic-leaf:before{content:""}.leaderboard{width:100%;margin:6px 0 0;padding:8px 0;font-size:.8125rem;color:#333}.leaderboard__rows{display:flex;flex-direction:column;gap:4px}.leaderboard__row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:10px;background:#f1f3f4b3;transition:background .15s}.leaderboard__row--you{background:#1a73e81a;font-weight:600}.leaderboard__rank{min-width:28px;text-align:center;font-weight:700;font-size:.875rem}.leaderboard__bar-wrap{flex:1;height:8px;background:#dfe1e5;border-radius:4px;overflow:hidden}.leaderboard__bar{height:100%;background:linear-gradient(90deg,#1a73e8,#4fc3f7);border-radius:4px;transition:width .4s ease}.leaderboard__row--you .leaderboard__bar{background:linear-gradient(90deg,#1a73e8,#34a853)}.leaderboard__points{min-width:52px;text-align:right;font-weight:700;font-size:.8125rem;color:#202124;white-space:nowrap}.leaderboard__you-tag{padding:2px 8px;background:#1a73e8;color:#fff;font-size:.6875rem;font-weight:700;border-radius:8px;text-transform:uppercase;letter-spacing:.04em}.leaderboard__separator{text-align:center;font-size:.75rem;color:#9aa0a6;line-height:1;padding:2px 0;letter-spacing:.15em}.leaderboard__hint{text-align:center;font-size:.6875rem;color:#9aa0a6;margin-top:4px}.scanner{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.scanner__viewport{position:relative;width:100%;max-width:480px;aspect-ratio:4 / 3;background:#000;border-radius:12px;overflow:hidden;transition:aspect-ratio .2s}.scanner--capturing .scanner__viewport{aspect-ratio:3 / 4}.scanner__video{width:100%;height:100%;object-fit:cover}.scanner__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0009}.scanner__guide{position:absolute;inset:20%;border:2px solid rgba(255,255,255,.6);border-radius:8px;pointer-events:none;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{border-color:#fff6}50%{border-color:#ff5860e6}}.scanner__stop{margin-top:4px}.scanner__toolbar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.scanner__manual{display:flex;gap:8px;width:100%;max-width:480px}.scanner__manual-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;font-family:Courier New,monospace;background:#fafafa;transition:border-color .15s}.scanner__manual-input:focus{outline:none;border-color:var(--color-primary, #ff5860);background:#fff}.scanner__error{color:var(--color-error, #ef4444);font-size:.875rem;text-align:center}.scanner__feedback{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:.875rem;width:100%;max-width:480px}.scanner__feedback--info{background:#f3f0ff;color:var(--color-secondary, #9B87F5)}.scanner__feedback--warn{background:#fef3c7;color:var(--color-warning, #f59e0b)}.scanner__feedback--success{background:#d1fae5;color:var(--color-success, #10b981)}.scanner__feedback--error{background:#fee2e2;color:var(--color-error, #ef4444)}.scanner__feedback-close{margin-left:auto;background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;opacity:.6}.scanner__checking{font-size:.875rem;color:#666;animation:blink 1s steps(3,end) infinite}@keyframes blink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}.scanner__capture-banner{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--color-primary, #ff5860);color:#fff;border-radius:10px;width:100%;max-width:480px;font-size:.9375rem}.scanner__capture-step{font-weight:700;font-size:1.05rem}.scanner__capture-barcode{font-family:Courier New,monospace;font-size:.8125rem;opacity:.85}.scanner__capture-controls{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:280px;padding:4px 0}.scanner__shutter{width:64px;height:64px;border-radius:50%;border:4px solid var(--color-primary, #ff5860);background:#fff;cursor:pointer;transition:transform .1s,background .1s;flex-shrink:0}.scanner__shutter:active{transform:scale(.9);background:var(--bg-base, #eef2f7)}.scanner__flash{position:absolute;inset:0;background:#fff;animation:scanner-flash .2s ease-out forwards;pointer-events:none;z-index:2}@keyframes scanner-flash{0%{opacity:.7}to{opacity:0}}.scanner__saving{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000073;color:#fff;font-size:.95rem;font-weight:600;z-index:2}.scanner__counter{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-secondary, #4a5568);padding:6px 14px;background:var(--bg-card, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:20px}.scanner__counter-num{font-weight:700;font-size:1rem;color:var(--color-primary, #ff5860)}.scanner__offline-banner{width:100%;max-width:480px;padding:8px 14px;background:#fef3c7;color:var(--color-warning, #f59e0b);border-radius:8px;font-size:.8125rem;font-weight:600;text-align:center}.zoomable{position:relative;width:100%;height:100%;overflow:hidden;background:#000;border-radius:10px;touch-action:none;user-select:none;-webkit-user-select:none}.zoomable__img{width:100%;height:100%;object-fit:contain;transform-origin:center center;will-change:transform;transition:transform .05s linear;pointer-events:none}.zoomable__reset{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:.8rem;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}.nutrition-form{width:100%;max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:16px}.nutrition-form__lang-row{display:flex;gap:4px;justify-content:flex-end}.nutrition-form__lang-btn{padding:3px 10px;border:1px solid #ccc;border-radius:6px;background:#f5f5f5;font-size:.75rem;font-weight:600;cursor:pointer;color:#666;transition:all .15s}.nutrition-form__lang-btn--active{background:var(--color-primary, #FF5860);border-color:var(--color-primary, #FF5860);color:#fff}.nutrition-form__hint{font-size:.8125rem;color:#666;margin:-8px 0 0;background:#f8f8f8;padding:8px 12px;border-radius:8px;border:1px solid var(--border-color, #E2E8F0)}.nutrition-form__unit-toggle{display:flex;align-items:center;gap:8px}.nutrition-form__unit-label{font-size:.8125rem;font-weight:600;color:#444}.nutrition-form__unit-btn{padding:5px 12px;border:1px solid #ccc;border-radius:6px;background:#f5f5f5;font-size:.8125rem;cursor:pointer;color:#555;transition:all .15s}.nutrition-form__unit-btn--active{background:#1a73e8;border-color:#1a73e8;color:#fff}.nutrition-form__section{display:flex;flex-direction:column;gap:10px}.nutrition-form__fieldset{border:1px solid #e0e0e0;border-radius:10px;padding:12px;margin:0}.nutrition-form__fieldset--muted{opacity:.7;border-style:dashed}.nutrition-form__legend{font-size:.8125rem;font-weight:700;color:#333;padding:0 6px}.nutrition-form__grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.nutrition-form__label{display:flex;flex-direction:column;gap:3px}.nutrition-form__label-text{font-size:.75rem;font-weight:600;color:#444}.nutrition-form__input-wrap{display:flex;align-items:center;gap:4px}.nutrition-form__input{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:8px;font-size:.9375rem;background:#fafafa;transition:border-color .15s}.nutrition-form__input:focus{outline:none;border-color:#1a73e8;background:#fff}.nutrition-form__label--num .nutrition-form__input{text-align:right;padding-right:4px}.nutrition-form__unit{font-size:.75rem;color:#888;min-width:24px}.nutrition-form__salt-note{font-size:.75rem;color:#666;margin:0 0 8px;font-style:italic}.nutrition-form__auto{font-size:.625rem;color:#999;font-weight:400}.nutrition-form__toggle{background:none;border:none;padding:0;font:inherit;font-size:.8125rem;font-weight:700;color:#333;cursor:pointer;display:flex;align-items:center;gap:6px}.nutrition-form__micro-entry{display:flex;flex-direction:column;gap:3px}.nutrition-form__micro-header{display:flex;align-items:center;justify-content:space-between}.nutrition-form__micro-remove{background:none;border:none;color:#b71c1c;font-size:1.1rem;line-height:1;cursor:pointer;padding:0 2px;opacity:.6;transition:opacity .15s}.nutrition-form__micro-remove:hover{opacity:1}.nutrition-form__micro-add{grid-column:1 / -1;margin-top:8px}.nutrition-form__micro-picker{margin-top:10px;padding:10px;border:1px solid #d0e3f7;border-radius:8px;background:#f5f9ff;display:flex;flex-direction:column;gap:10px}.nutrition-form__micro-presets{display:flex;flex-wrap:wrap;gap:6px}.nutrition-form__micro-preset-btn{padding:4px 10px;border:1px solid #c8dff7;border-radius:14px;background:#fff;font-size:.75rem;cursor:pointer;color:#1a73e8;transition:all .15s}.nutrition-form__micro-preset-btn:hover{background:#1a73e8;color:#fff;border-color:#1a73e8}.nutrition-form__micro-custom{display:flex;flex-direction:column;gap:6px;padding-top:6px;border-top:1px solid #d0e3f7}.nutrition-form__micro-custom-row{display:flex;gap:6px;align-items:center}.nutrition-form__micro-custom-row .nutrition-form__input--text{flex:1}.nutrition-form__input--select{padding:8px 6px;border:1px solid #ddd;border-radius:8px;font-size:.875rem;background:#fafafa;width:60px}.nutrition-form__warnings{padding:10px 12px;border-radius:8px;background:#fff8e1;border:1px solid #ffe082;display:flex;flex-direction:column;gap:4px}.nutrition-form__warnings--error{background:#fce4ec;border-color:#ef9a9a}.nutrition-form__warning{font-size:.8125rem;margin:0;line-height:1.35;color:#5d4037}.nutrition-form__warnings--error .nutrition-form__warning{color:#b71c1c}.nutrition-form__actions{display:flex;gap:10px;padding-top:8px}.nutrition-form__actions .btn{flex:1}.detail{display:flex;flex-direction:column;width:100%;max-width:900px;margin:0 auto;gap:0}.detail__header{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border-color, #eee);flex-wrap:wrap}.detail__barcode{font-family:Courier New,monospace;font-size:.85rem;font-weight:600;color:var(--text-primary, #333)}.detail__name{font-size:.85rem;color:var(--text-secondary, #666)}.detail__image-section{display:flex;flex-direction:column}.detail__side-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-color, #eee)}.detail__side-tab{flex:1;padding:8px 0;background:none;border:none;border-bottom:2px solid transparent;font-size:.85rem;font-weight:600;color:var(--text-muted, #888);cursor:pointer;transition:color .15s,border-color .15s}.detail__side-tab--active{color:var(--color-primary, #FF5860);border-bottom-color:var(--color-primary, #FF5860)}.detail__image-wrap{width:100%;height:30vh;min-height:160px;max-height:340px;background:var(--bg-elevated, #f5f5f5);overflow:hidden;flex-shrink:0}.detail__no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted, #bbb);font-size:.9rem}.detail__form-section{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch}.detail__toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--text-primary, #333);color:var(--bg-card, #fff);padding:8px 20px;border-radius:20px;font-size:.85rem;font-weight:600;z-index:1000;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(min-width:700px){.detail{flex-direction:column}.detail__image-section{max-height:50vh}.detail__image-wrap{height:50vh;max-height:500px}}.sync-panel{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--bg-card, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:10px;width:100%;max-width:480px;margin-bottom:8px}.sync-panel__row{display:flex;align-items:center;justify-content:space-between;gap:8px}.sync-panel__status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sync-panel__dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted, #a0aec0);flex-shrink:0}.sync-panel__dot--on{background:var(--color-success, #10b981);box-shadow:0 0 4px var(--color-success, #10b981)}.sync-panel__network{font-size:.8rem;color:var(--text-secondary, #4a5568)}.sync-panel__pending{font-size:.8rem;font-weight:600;color:var(--color-warning, #f59e0b)}.sync-panel__failed{font-size:.8rem;font-weight:600;color:var(--color-error, #ef4444)}.sync-panel__spinner{width:12px;height:12px;border:2px solid var(--border-color, #e2e8f0);border-top-color:var(--color-primary, #ff5860);border-radius:50%;animation:spin .7s linear infinite}.sync-panel__error{font-size:.75rem;color:var(--color-error, #ef4444);padding:4px 8px;background:#fef2f2;border-radius:4px}.sync-panel__toggle{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-secondary, #4a5568);cursor:pointer}.sync-panel__toggle input{accent-color:var(--color-primary, #ff5860)}@keyframes spin{to{transform:rotate(360deg)}}.sync{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:10px;width:100%;max-width:480px}.sync__row{display:flex;align-items:center;gap:8px}.sync__dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sync__dot--online{background:#4caf50}.sync__dot--offline{background:#bdbdbd}.sync__label{font-size:.85rem;color:#555}.sync__pending{font-size:.85rem;font-weight:600;color:#e65100}.sync__spinner{width:14px;height:14px;border:2px solid #ddd;border-top-color:#1a73e8;border-radius:50%;animation:spin .8s linear infinite}.sync__controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:4px}.sync__toggle{display:flex;align-items:center;gap:6px;font-size:.85rem;color:#555;cursor:pointer}.sync__toggle input{accent-color:#1a73e8}.gallery{width:100%;display:flex;flex-direction:column;gap:0}.gallery--empty{text-align:center;padding:40px 16px;color:#888}.gallery__hint{font-size:.85rem;color:#aaa}.gallery__progress{display:flex;align-items:center;gap:10px;padding:10px 12px 6px}.gallery__progress-bar{flex:1;height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.gallery__progress-fill{height:100%;background:#43a047;border-radius:3px;transition:width .3s ease;min-width:2px}.gallery__progress-text{font-size:.75rem;font-weight:600;color:#666;white-space:nowrap}.gallery__search{display:flex;align-items:center;gap:0;padding:4px 12px 8px;position:relative}.gallery__search-input{width:100%;padding:7px 32px 7px 10px;border:1px solid #ddd;border-radius:8px;font-size:.85rem;background:#fafafa;transition:border-color .15s}.gallery__search-input:focus{outline:none;border-color:var(--color-primary, #FF5860);background:#fff}.gallery__search-clear{position:absolute;right:18px;background:none;border:none;font-size:.85rem;color:#999;cursor:pointer;padding:4px}.gallery__stats{display:flex;gap:12px;padding:8px 12px;background:var(--bg-card, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;margin-bottom:8px;font-size:.8rem;color:var(--text-secondary, #4a5568);flex-wrap:wrap}.gallery__stats strong{color:var(--text-primary, #1a1d2e)}.gallery__tabs{display:flex;gap:4px;margin-bottom:8px}.gallery__filters{display:flex;gap:0;border-bottom:1px solid var(--border-color, #e2e8f0);padding:0 8px;overflow-x:auto;-webkit-overflow-scrolling:touch}.gallery__filter{padding:10px 12px;background:none;border:none;border-bottom:2px solid transparent;font-size:.8rem;font-weight:600;color:var(--text-muted, #a0aec0);cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s,background .15s;display:flex;align-items:center;gap:5px;border-radius:6px 6px 0 0}.gallery__filter:hover{color:var(--text-secondary, #4a5568)}.gallery__filter--active{color:var(--color-primary, #ff5860);border-bottom-color:var(--color-primary, #ff5860);background:#ff58600d}.gallery__filter-badge{background:var(--color-error, #ef4444);color:#fff;font-size:.65rem;font-weight:700;padding:1px 5px;border-radius:8px;min-width:16px;text-align:center}.gallery__list{display:flex;flex-direction:column;gap:1px;background:var(--border-color, #e2e8f0)}.card{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;cursor:pointer;transition:background .12s}.card:active{background:#f5f5f5}.card--needs-nutrition{border-left:3px solid #ff9800}.card__thumb{width:48px;height:48px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#f5f5f5}.card__thumb-img{width:100%;height:100%;object-fit:cover}.card__thumb-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.card__row{display:flex;align-items:center;gap:6px}.card__row--meta{justify-content:space-between}.card__barcode{font-family:Courier New,monospace;font-size:.82rem;font-weight:600;color:#333}.card__product-name{font-size:.78rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card__date{font-size:.7rem;color:#aaa}.card__nutrition-status{font-size:.7rem;font-weight:600}.card__nutrition-status--done{color:#2e7d32}.card__nutrition-status--missing{color:#e65100}.card__delete{flex-shrink:0;background:none;border:none;font-size:1rem;padding:4px;cursor:pointer;opacity:.4;transition:opacity .15s}.card__delete:hover{opacity:1}.badge{font-size:.65rem;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:8px;white-space:nowrap}.badge--pending{background:#fff3e0;color:#e65100}.badge--synced{background:#e8f5e9;color:#2e7d32}.badge--error{background:#ffebee;color:#c62828}.login{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--bg-base, #f5f5f5);padding:16px}.login__card{background:var(--bg-card, #fff);border-radius:16px;padding:32px 24px;width:100%;max-width:380px;box-shadow:0 2px 12px #00000014;text-align:center}.login__title{font-size:1.6rem;color:var(--color-primary, #FF5860);margin:0 0 4px}.login__subtitle{font-size:.9rem;color:var(--text-muted, #888);margin:0 0 24px}.login__form{display:flex;flex-direction:column;gap:12px}.login__input{padding:12px 14px;border:1px solid var(--border-color, #ddd);border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s;background:var(--bg-card, #fff);color:var(--text-primary, #1A1D2E)}.login__input:focus{border-color:var(--color-primary, #FF5860)}.login__error{color:var(--color-error, #c62828);font-size:.85rem;margin:0}.login__submit{margin-top:4px;width:100%;padding:12px}.login__toggle{background:none;border:none;color:var(--color-primary, #FF5860);font-size:.85rem;cursor:pointer;margin-top:16px;padding:0}.login__toggle:hover{text-decoration:underline}.login__version{margin-top:16px;font-size:.7rem;color:var(--text-muted, #999);text-align:center}.user-mgmt{width:100%;max-width:600px}.user-mgmt__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.user-mgmt__title{font-size:1.2rem;font-weight:700;color:#333;margin:0}.user-mgmt__error{color:#c62828;background:#ffebee;padding:8px 12px;border-radius:8px;font-size:.85rem;margin-bottom:12px}.user-mgmt__loading,.user-mgmt__empty{text-align:center;color:#888;padding:24px 0}.user-mgmt__list{display:flex;flex-direction:column;gap:8px}.user-row{background:#fff;border-radius:10px;border:1px solid #e0e0e0;overflow:hidden}.user-row--inactive{opacity:.65}.user-row__summary{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.user-row__info{display:flex;flex-direction:column;gap:2px}.user-row__name{font-weight:600;font-size:.95rem;color:#333}.user-row__email{font-size:.8rem;color:#888}.user-row__badges{display:flex;align-items:center;gap:6px}.user-row__chevron{font-size:.7rem;color:#aaa;margin-left:4px}.badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px}.badge--admin{background:#e3f2fd;color:#1565c0}.badge--active{background:#e8f5e9;color:#2e7d32}.badge--inactive{background:#fce4ec;color:#c62828}.user-row__details{padding:0 16px 16px;border-top:1px solid #f0f0f0}.user-row__actions{display:flex;flex-wrap:wrap;gap:8px;margin:12px 0}.user-row__reset{display:flex;gap:8px;align-items:center;margin-bottom:8px}.user-row__reset .user-form__input{flex:1;margin:0}.user-row__feedback{font-size:.8rem;color:#1565c0;background:#e3f2fd;padding:6px 10px;border-radius:6px;margin:8px 0}.user-row__meta{font-size:.75rem;color:#aaa;margin:4px 0 0}.user-form{background:#fff;border-radius:10px;border:1px solid #e0e0e0;padding:16px;margin-bottom:16px}.user-form__title{font-size:1rem;font-weight:600;margin:0 0 12px;color:#333}.user-form__input{display:block;width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:.9rem;margin-bottom:10px;box-sizing:border-box}.user-form__input:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e826}.user-form__checkbox{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#555;margin-bottom:12px;cursor:pointer}.user-form__error{color:#c62828;font-size:.8rem;margin-bottom:8px}.user-form__actions{display:flex;gap:8px}.update-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 20px;background:#1a73e8;color:#fff;font-size:.9rem;font-weight:500;box-shadow:0 -2px 12px #00000026;animation:update-slide-up .3s ease-out}@keyframes update-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.update-banner__text{flex-shrink:1}.update-banner__btn{flex-shrink:0;padding:6px 16px;border:2px solid #fff;border-radius:6px;background:transparent;color:#fff;font-weight:700;font-size:.85rem;cursor:pointer;transition:background .15s}.update-banner__btn:active{background:#fff3}:root{--color-primary: #FF5860;--color-primary-dark: #E04850;--color-secondary: #9B87F5;--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--bg-base: #EEF2F7;--bg-card: #FFFFFF;--bg-elevated: #FAFAFA;--text-primary: #1A1D2E;--text-secondary: #4A5568;--text-muted: #A0AEC0;--border-color: #E2E8F0;--border-radius: 12px}@media(prefers-color-scheme:dark){:root{--bg-base: #0F1117;--bg-card: #1A1D2E;--bg-elevated: #252836;--text-primary: #F5F5F5;--text-secondary: #A0AEC0;--text-muted: #6B7280;--border-color: #2D3748}}.app{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg-base)}.header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.header__brand{display:flex;align-items:center;gap:8px}.header__logo{font-size:1.2rem}.header__title{font-size:1.1rem;font-weight:700;color:var(--color-primary);letter-spacing:-.02em}.header__version{font-size:.65rem;font-weight:500;color:var(--text-muted);background:var(--bg-base);padding:2px 6px;border-radius:4px}.header__right{display:flex;align-items:center;gap:12px}.online-dot{width:10px;height:10px;border-radius:50%;transition:background .2s}.online-dot--on{background:var(--color-success);box-shadow:0 0 6px var(--color-success)}.online-dot--off{background:var(--text-muted)}.header__menu{position:relative}.header__menu-btn{background:none;border:none;font-size:1.3rem;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}.header__menu-btn:hover{background:var(--bg-base)}.header__dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:120px;z-index:100;overflow:hidden}.header__dropdown-item{display:block;width:100%;padding:10px 14px;border:none;background:none;text-align:left;font-size:.9rem;color:var(--text-primary);cursor:pointer;transition:background .15s}.header__dropdown-item:hover{background:var(--bg-base)}.header__dropdown-item--danger{color:var(--color-error)}.nav{display:flex;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.nav__tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 0;border:none;background:none;font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.nav__tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.nav__tab:hover:not(.nav__tab--active){color:var(--text-secondary)}.nav__icon{font-size:1.05rem}.nav__badge{background:var(--color-warning);color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px}.main{flex:1;display:flex;flex-direction:column;align-items:center;padding:16px;overflow-y:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:8px;font-weight:600;font-size:.9rem;border:none;cursor:pointer;transition:all .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px)}.btn--secondary{background:var(--bg-base);color:var(--text-primary);border:1px solid var(--border-color)}.btn--secondary:hover:not(:disabled){background:var(--border-color)}.btn--danger{background:#fee2e2;color:var(--color-error)}.btn--danger:hover:not(:disabled){background:#fecaca}.btn--small{padding:6px 12px;font-size:.8rem}
