*,*:before,*:after{box-sizing:border-box}:root{--primary: #16a34a;--primary-dark: #15803d;--primary-light: #4ade80;--accent: #f59e0b;--accent-soft: #fef3c7;--surface: #ffffff;--surface-2: #f0fdf4;--text: #1f2937;--text-muted: #6b7280;--border: #d1fae5;--shadow: 0 4px 20px rgba(22, 163, 74, .12);--radius: 14px;--header-gradient: linear-gradient(135deg, #16a34a 0%, #22c55e 45%, #84cc16 100%)}body[data-theme=green]{--primary: #059669;--primary-dark: #047857;--primary-light: #34d399;--surface-2: #ecfdf5;--border: #a7f3d0;--header-gradient: linear-gradient(135deg, #059669 0%, #10b981 50%, #6ee7b7 100%)}body[data-theme=orange]{--primary: #ea580c;--primary-dark: #c2410c;--primary-light: #fb923c;--accent: #fbbf24;--accent-soft: #fff7ed;--surface-2: #fff7ed;--border: #fed7aa;--shadow: 0 4px 20px rgba(234, 88, 12, .15);--header-gradient: linear-gradient(135deg, #ea580c 0%, #f97316 50%, #fbbf24 100%)}body[data-mode=dark]{--surface: #1e293b;--surface-2: #0f172a;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--accent-soft: #1e293b;--shadow: 0 4px 20px rgba(0, 0, 0, .45);--page-bg-end: #020617}body[data-mode=dark][data-theme=light],body[data-mode=dark]:not([data-theme]){--primary-light: #4ade80}body[data-mode=dark][data-theme=green]{--primary-light: #34d399}body[data-mode=dark][data-theme=orange]{--primary-light: #fb923c;--accent-soft: #292524}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:linear-gradient(160deg,var(--surface-2) 0%,var(--page-bg-end, #e0f2fe) 100%);color:var(--text);min-height:100vh}#app{min-height:100vh}.app{display:flex;flex-direction:column;min-height:100vh}.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;background:var(--header-gradient);color:#fff;box-shadow:0 2px 16px #0000001f}.logo{display:flex;align-items:center;gap:.5rem;font-weight:800;font-size:1.25rem;letter-spacing:-.02em;text-shadow:0 1px 2px rgba(0,0,0,.15);border:none;background:none;color:inherit;padding:0;cursor:pointer;font-family:inherit}.logo:hover{opacity:.92}.logo-icon{font-size:1.5rem;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.top-actions{display:flex;align-items:center;gap:.6rem}.btn-header{border:2px solid rgba(255,255,255,.85);background:#fff3;color:#fff;padding:.45rem 1rem;border-radius:999px;font-weight:600;cursor:pointer;transition:transform .15s,background .15s,box-shadow .15s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-header:hover{background:#fff;color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn-header.primary-solid{background:#fff;color:var(--primary-dark);border-color:#fff}.btn-header.primary-solid:hover{background:var(--accent-soft);color:var(--primary-dark)}.user-menu-wrap{position:relative;display:flex;align-items:center;gap:.45rem}.cart-header-btn{position:relative;width:44px;height:44px;border-radius:50%;border:3px solid rgba(255,255,255,.9);background:#fff3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s,box-shadow .15s;box-shadow:0 2px 10px #00000026;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.cart-header-btn:hover{background:#fff;color:var(--primary-dark);transform:scale(1.06);box-shadow:0 4px 16px #00000038}.cart-header-btn.active{background:#fff;color:var(--primary-dark)}.cart-header-btn.cart-bounce{animation:cartBounce .65s cubic-bezier(.34,1.4,.64,1)}.cart-header-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--accent);color:#78350f;font-size:.7rem;font-weight:800;line-height:20px;text-align:center;border:2px solid white;box-shadow:0 2px 8px #0003}.cart-header-badge.badge-pop{animation:badgePop .55s cubic-bezier(.34,1.5,.64,1)}.cart-header-ring{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;border:2px solid rgba(255,255,255,.9);animation:cartRing .65s ease-out forwards;pointer-events:none}@keyframes cartBounce{0%{transform:scale(1)}20%{transform:scale(1.22) rotate(-6deg)}45%{transform:scale(1.12) rotate(4deg)}70%{transform:scale(1.18) rotate(-2deg)}to{transform:scale(1)}}@keyframes badgePop{0%{transform:scale(1)}40%{transform:scale(1.45)}to{transform:scale(1)}}@keyframes cartRing{0%{transform:scale(1);opacity:.9}to{transform:scale(1.55);opacity:0}}.avatar-btn{width:44px;height:44px;border-radius:50%;border:3px solid rgba(255,255,255,.9);background:linear-gradient(145deg,#fff 0%,var(--accent-soft) 100%);color:var(--primary-dark);font-weight:800;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s;box-shadow:0 2px 10px #0003}.avatar-btn:hover,.avatar-btn.open{transform:scale(1.06);box-shadow:0 4px 16px #00000040}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150}.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;z-index:200;min-width:260px;background:var(--surface);border-radius:var(--radius);box-shadow:0 12px 40px #0000002e;border:1px solid var(--border);overflow:hidden;animation:menuIn .2s ease}@keyframes menuIn{0%{opacity:0;transform:translateY(-8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.menu-header{padding:1rem 1.1rem;background:var(--surface-2);border-bottom:1px solid var(--border)}.menu-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.menu-header strong{display:block;color:var(--text);font-size:1rem}.menu-header span{font-size:.8rem;color:var(--text-muted)}.color-mode-toggle{flex-shrink:0;width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:var(--surface);color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .15s}.color-mode-toggle:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:scale(1.05)}.menu-section{padding:.5rem}.menu-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.35rem .65rem;font-weight:700}.menu-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.65rem .75rem;border:none;background:transparent;border-radius:10px;color:var(--text);font-size:.95rem;font-weight:500;cursor:pointer;text-align:left;transition:background .12s,color .12s}.menu-item:hover{background:var(--surface-2);color:var(--primary-dark)}.menu-item.active{background:var(--primary);color:#fff}.menu-item.danger:hover{background:#fee2e2;color:#b91c1c}.menu-badge{margin-left:auto;background:var(--accent);color:#78350f;font-size:.75rem;font-weight:700;padding:.15rem .5rem;border-radius:999px}.theme-options{display:flex;gap:.5rem;padding:.35rem .65rem .65rem}.theme-swatch{flex:1;padding:.5rem .25rem;border:2px solid transparent;border-radius:10px;cursor:pointer;font-size:.7rem;font-weight:600;text-align:center;transition:transform .12s,border-color .12s}.theme-swatch:hover{transform:scale(1.05)}.theme-swatch.selected{border-color:var(--primary);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--primary-light)}.theme-swatch.light{background:linear-gradient(135deg,#f0fdf4,#dbeafe);color:#166534}.theme-swatch.green{background:linear-gradient(135deg,#059669,#6ee7b7);color:#fff}.theme-swatch.orange{background:linear-gradient(135deg,#ea580c,#fbbf24);color:#fff}.content{flex:1;padding:1rem;max-width:1100px;width:100%;margin-inline:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.catalog-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.category-filters{display:flex;gap:.45rem}.category-filters button{padding:.45rem 1rem;border-radius:999px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-weight:700;font-size:.9rem;cursor:pointer}.category-filters button.active{background:var(--primary);border-color:var(--primary);color:#fff}.catalog-search{flex:1;min-width:min(100%,220px);max-width:360px;margin-left:auto}.catalog-search input{width:100%;padding:.55rem .85rem;border-radius:999px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-size:.95rem}.catalog-search input:focus{outline:none;border-color:var(--primary)}.category-label{display:inline-block;margin-left:.45rem;font-size:.72rem;font-weight:700;text-transform:uppercase;padding:.1rem .4rem;border-radius:999px;background:var(--surface-2);color:var(--primary-dark);border:1px solid var(--border)}.page-title{margin:0 0 1rem;font-size:1.5rem;color:var(--primary-dark);font-weight:800}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.card{position:relative;background:var(--surface);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--border);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}.card:hover{transform:translateY(-4px);box-shadow:0 12px 28px #16a34a33}.card-out-of-stock{opacity:.72}.card-out-of-stock:hover{transform:none;box-shadow:var(--shadow)}.card-out-of-stock .card-img,.card-out-of-stock .card-img-placeholder{filter:grayscale(.65)}.card-stock-badge{position:absolute;top:.5rem;right:.5rem;z-index:2;background:#fee2e2;color:#b91c1c;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .5rem;border-radius:999px;border:1px solid #fecaca}.stock-filters{display:flex;gap:.45rem}.stock-filters button{padding:.35rem .75rem;border-radius:999px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;font-size:.85rem;cursor:pointer}.stock-filters button.active{background:var(--primary);border-color:var(--primary);color:#fff}.stock-toggle{padding:.35rem .65rem;border-radius:999px;font-size:.8rem;font-weight:700;cursor:pointer;border:2px solid transparent;white-space:nowrap}.stock-toggle.in-stock{background:#dcfce7;color:#15803d;border-color:#86efac}.stock-toggle.out-of-stock{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.stock-label{display:inline-block;margin-left:.5rem;font-size:.72rem;font-weight:700;text-transform:uppercase;padding:.1rem .4rem;border-radius:999px}.stock-label.out{background:#fee2e2;color:#b91c1c}.user-row-out-of-stock{opacity:.85}.card-img{width:100%;height:130px;object-fit:cover;background:linear-gradient(135deg,#bbf7d0,#fef08a)}.card-img-placeholder{height:130px;display:flex;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,#bbf7d0,#fde68a)}.card-body{padding:.85rem;display:flex;flex-direction:column;gap:.5rem;flex:1}.card-body h3{margin:0;font-size:1rem;color:var(--text)}.price{margin:0;font-weight:800;font-size:1.1rem;color:var(--primary)}.unit{font-size:.75rem;font-weight:500;color:var(--text-muted)}.btn-primary{margin-top:auto;width:100%;padding:.55rem;border:none;border-radius:10px;background:var(--header-gradient);color:#fff;font-weight:700;cursor:pointer;transition:transform .12s,opacity .12s}.btn-primary:hover{transform:scale(1.02);opacity:.95}.btn-primary.btn-added{animation:btnAddedPulse .55s ease;background:linear-gradient(135deg,#15803d,#22c55e,#4ade80);transform:scale(1.03)}@keyframes btnAddedPulse{0%{transform:scale(1);box-shadow:0 0 #22c55e80}50%{transform:scale(1.06);box-shadow:0 0 0 8px #22c55e00}to{transform:scale(1.03);box-shadow:0 0 #22c55e00}}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.panel{background:var(--surface);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border);max-width:420px;margin-inline:auto}.panel.wide{max-width:100%}.panel h2{margin:0 0 .25rem;color:var(--primary-dark);font-size:1.5rem}.panel-sub{color:var(--text-muted);font-size:.9rem;margin:0 0 1.25rem}.panel label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:600;color:var(--text-muted);margin-bottom:1rem}.panel input,.panel select{border:2px solid var(--border);border-radius:10px;padding:.65rem .85rem;font-size:1rem;color:var(--text);background:var(--surface-2);transition:border-color .15s,box-shadow .15s}.panel input:focus,.panel select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #16a34a33}.auth-switch{text-align:center;margin-top:1rem;font-size:.9rem;color:var(--text-muted)}.auth-switch button{background:none;border:none;color:var(--primary);font-weight:700;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.stack{display:flex;flex-direction:column;gap:.85rem}.error{color:#b91c1c;background:#fee2e2;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;margin-bottom:.75rem}.hint{color:var(--text-muted);font-size:.9rem}.muted{color:var(--text-muted);font-size:.85rem}.cart-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px dashed var(--border)}.cart-row-actions{display:flex;align-items:center;gap:.5rem}.cart-remove{flex-shrink:0}.cart-qty{display:flex;align-items:center;gap:.4rem}.cart-qty button{width:32px;height:32px;border-radius:8px;border:2px solid var(--border);background:var(--surface-2);color:var(--primary-dark);font-weight:700;cursor:pointer}.cart-qty button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.cart-footer{margin-top:1rem;padding-top:1rem;border-top:2px solid var(--border);display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:1.1rem}.order-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:0 2px 8px #0000000a}.order-card ul.order-items{list-style:none;margin:.65rem 0;padding:.65rem .75rem;background:var(--surface-2);border-radius:8px;border:1px solid var(--border)}.order-items li{display:grid;grid-template-columns:1fr auto auto;gap:.5rem .75rem;align-items:center;padding:.35rem 0;font-size:.9rem}.order-items-editable li{grid-template-columns:1fr auto auto auto}.order-items-editable .order-item-remove{justify-self:end;font-size:1rem;line-height:1;padding:.2rem .35rem}.order-line-removed .order-item-name,.order-line-removed .order-item-qty,.order-line-removed .order-item-price,.order-line-removed>span:first-child{text-decoration:line-through;opacity:.65}.order-item-removal-reason{grid-column:1 / -1;font-size:.78rem;font-weight:500;color:#c0392b;margin-top:-.15rem}.remove-item-target{margin:0 0 .75rem}.order-items li+li{border-top:1px dashed var(--border)}.order-item-name{font-weight:600;color:var(--text)}.order-item-qty{font-weight:700;color:var(--primary-dark);white-space:nowrap}.order-item-price{font-size:.82rem;white-space:nowrap;text-align:right}.order-items-empty{margin:.5rem 0;font-size:.85rem}.order-header-main{display:flex;flex-direction:column;gap:.15rem;min-width:0}.order-customer{font-size:1rem;color:var(--text)}.order-username{font-size:.8rem;font-weight:500;color:var(--text-muted)}.order-datetime{font-size:.85rem;font-weight:500;color:var(--text-muted)}.order-date-separator{display:flex;align-items:center;gap:.75rem;margin:.35rem 0 .15rem}.order-date-separator:before,.order-date-separator:after{content:"";flex:1;height:1px;background:var(--border)}.order-date-separator span{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);white-space:nowrap;padding:0 .25rem}.admin-orders-list{gap:.65rem}.load-more-orders{width:100%;margin-top:.25rem}.order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.order-footer{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.85rem}.status{border-radius:999px;padding:.2rem .65rem;font-size:.75rem;font-weight:700}.status-created{background:#dbeafe;color:#1d4ed8}.status-packing{background:#fef9c3;color:#854d0e}.status-outfordelivery{background:#ffedd5;color:#c2410c}.status-delivered{background:#dcfce7;color:#15803d}.status-cancelled{background:#fee2e2;color:#b91c1c}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.admin-tabs button{padding:.5rem 1rem;border-radius:999px;border:2px solid var(--border);background:var(--surface);color:var(--text);font-weight:600;cursor:pointer;transition:all .15s}.admin-tabs button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.admin-actions{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.admin-actions button,.admin-actions select{padding:.35rem .65rem;border-radius:8px;border:1px solid var(--border);font-size:.8rem;cursor:pointer}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem}.user-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem;background:var(--surface-2);border-radius:10px}.user-row-main{display:flex;align-items:center;gap:.75rem;min-width:0}.user-row-actions{display:flex;gap:.5rem;flex-shrink:0}.form-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-danger{padding:.5rem 1rem;border-radius:10px;border:2px solid #fecaca;background:var(--surface);color:#b91c1c;font-weight:600;cursor:pointer}.btn-danger:hover{background:#fee2e2}.btn-icon{width:38px;height:38px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,border-color .15s,transform .12s}.btn-icon:hover{transform:scale(1.06)}.btn-icon-edit{border:2px solid var(--primary);background:var(--surface);color:var(--primary-dark)}.btn-icon-edit:hover{background:var(--surface-2)}.btn-icon-delete{border:2px solid #fecaca;background:var(--surface);color:#b91c1c}.btn-icon-delete:hover{background:#fee2e2}.btn-sm{padding:.35rem .65rem;font-size:.85rem}.section-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.section-header h3{margin:0}.section-header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-left:auto}.admin-item-search{min-width:min(100%,180px);max-width:280px;margin-left:0}.address-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.address-card{display:flex;flex-direction:column;gap:.65rem;padding:.85rem;background:var(--surface-2);border-radius:10px;border:1px solid var(--border)}.address-card-main p{margin:.35rem 0 0;line-height:1.45}.profile-actions{display:flex;flex-direction:column;gap:.65rem}.profile-action-btn{width:100%;justify-content:center;border:1px solid var(--border);background:var(--surface-2)}.profile-action-btn:hover{background:var(--surface)}.input-disabled{opacity:.75;cursor:not-allowed;background:var(--surface-2)!important;color:var(--text-muted)}.label-optional{font-weight:500;color:var(--text-muted);font-size:.85em}.profile-password-form{padding:.85rem;border-radius:10px;border:1px solid var(--border);background:var(--surface-2)}.inactive-badge{display:inline-block;margin-left:.5rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:.12rem .45rem;border-radius:999px;background:#fee2e2;color:#b91c1c;vertical-align:middle}.user-row-inactive{opacity:.92}.address-badge{display:inline-block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:.15rem .5rem;border-radius:999px;background:var(--primary);color:#fff}.address-card-actions{display:flex;flex-wrap:wrap;gap:.5rem}.link-button{background:none;border:none;padding:0;font:inherit;color:var(--primary-dark);font-weight:600;text-decoration:underline;cursor:pointer}.link-button:hover{color:var(--primary)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.empty-state span{font-size:3rem;display:block;margin-bottom:.5rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;z-index:300}.modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:400;width:min(92vw,520px);max-height:85vh;overflow:auto;background:var(--surface);border-radius:var(--radius);box-shadow:0 20px 50px #00000040;border:1px solid var(--border)}.image-picker-modal{width:min(96vw,640px)}.user-orders-modal{width:min(96vw,560px)}.modal-orders-body{padding:1rem 1.1rem 1.1rem;max-height:min(60vh,480px);overflow-y:auto}.empty-state.compact{padding:1.5rem 1rem}.empty-state.compact span{font-size:2rem}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.1rem;border-bottom:1px solid var(--border);background:var(--surface-2)}.modal-header h3{margin:0;font-size:1.1rem;color:var(--primary-dark)}.modal-close{width:36px;height:36px;border:none;border-radius:50%;background:#fff;font-size:1.4rem;line-height:1;cursor:pointer;color:var(--text-muted)}.modal-close:hover{background:#fee2e2;color:#b91c1c}.modal-form{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.75rem}.modal-form label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;font-size:.9rem;color:var(--text)}.checkbox-label{flex-direction:row!important;align-items:center;gap:.5rem!important;font-weight:500!important}.checkbox-label input{width:auto}.image-picker-choices{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;padding:1rem}.picker-choice{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:1.25rem .75rem;border:2px solid var(--border);border-radius:var(--radius);background:var(--surface-2);cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;text-align:center}.picker-choice:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow)}.picker-icon{font-size:2rem}.picker-choice strong{color:var(--text)}.gallery-panel,.upload-panel{padding:1rem}.link-back{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;margin-bottom:.75rem;padding:0}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.65rem;max-height:50vh;overflow-y:auto}.gallery-thumb{display:flex;flex-direction:column;gap:.25rem;padding:.35rem;border:2px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;transition:border-color .12s,transform .12s}.gallery-thumb:hover{border-color:var(--primary);transform:scale(1.03)}.gallery-thumb img{width:100%;height:72px;object-fit:cover;border-radius:6px}.gallery-thumb span{font-size:.65rem;color:var(--text-muted);text-transform:capitalize;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-drop{display:flex;align-items:center;justify-content:center;min-height:140px;border:2px dashed var(--primary);border-radius:var(--radius);background:var(--surface-2);cursor:pointer;font-weight:600;color:var(--primary-dark)}.upload-drop input{display:none}.image-field-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.btn-secondary{padding:.5rem 1rem;border-radius:10px;border:2px solid var(--primary);background:var(--surface);color:var(--primary-dark);font-weight:600;cursor:pointer}.btn-secondary:hover{background:var(--surface-2)}.image-preview-thumb{width:56px;height:56px;object-fit:cover;border-radius:10px;border:2px solid var(--border)}.image-preview-thumb.small{width:40px;height:40px}@media (max-width: 600px){.logo{font-size:1.05rem}.panel{padding:1.1rem}.grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.image-picker-choices{grid-template-columns:1fr}}
