:root{--admin-blue: #2563eb;--admin-bg: #f3f4f6;--sidebar-bg: #111827;--text-main: #111827;--text-muted: #6b7280;--border: #eef0f4}*{box-sizing:border-box}body{margin:0;color:var(--text-main);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--admin-bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.72}.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,#dbeafe,transparent 34%),linear-gradient(135deg,#0f172a,#1e293b)}.login-card{width:420px;padding:36px;border-radius:24px;background:#fffffff5;box-shadow:0 24px 80px #0f172a47}.login-logo{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;color:#fff;font-weight:800;background:var(--admin-blue)}.login-card h1{margin:20px 0 8px;font-size:24px}.login-card p{margin:0 0 24px;color:var(--text-muted);font-size:14px}.login-form{display:grid;gap:16px}.login-form label,.filters label,.settings-form label{display:grid;gap:7px;color:#374151;font-size:13px}.login-form input,.filters input,.filters select,.settings-form input,.settings-form select{height:38px;border:1px solid #d9dee8;border-radius:10px;padding:0 12px;background:#fff;outline:none}.settings-form textarea{min-height:86px;border:1px solid #d9dee8;border-radius:10px;padding:10px 12px;background:#fff;outline:none;resize:vertical}.login-form input:focus,.filters input:focus,.filters select:focus,.settings-form input:focus,.settings-form select:focus,.settings-form textarea:focus{border-color:var(--admin-blue);box-shadow:0 0 0 3px #2563eb1a}.form-error{min-height:18px;color:#ef4444;font-size:12px}.admin-shell{height:100vh;display:flex;overflow:hidden;background:var(--admin-bg)}.sidebar{width:220px;flex:0 0 220px;display:flex;flex-direction:column;background:var(--sidebar-bg);color:#fff;transition:width .2s ease,flex-basis .2s ease;overflow-y:auto;scrollbar-width:none}.admin-shell.collapsed .sidebar{width:58px;flex-basis:58px}.brand{height:56px;display:flex;align-items:center;gap:10px;padding:0 14px;border-bottom:1px solid rgba(255,255,255,.08);font-size:14px;font-weight:800;white-space:nowrap}.brand-icon{width:30px;height:30px;flex:0 0 30px;display:grid;place-items:center;border-radius:10px;background:var(--admin-blue)}.admin-shell.collapsed .brand span,.admin-shell.collapsed .nav-title,.admin-shell.collapsed .nav-item b,.admin-shell.collapsed .nav-item em{display:none}.nav-group{margin:8px 0}.nav-title{padding:7px 14px;color:#ffffff52;font-size:10px;letter-spacing:.08em}.nav-item{width:100%;min-height:38px;display:flex;align-items:center;gap:10px;padding:0 12px;color:#ffffffad;border:0;border-left:3px solid transparent;background:transparent;text-align:left}.nav-item span{width:18px;text-align:center;font-size:15px}.nav-item b{flex:1;font-size:13px;font-weight:500}.nav-item em{min-width:17px;height:17px;padding:0 5px;border-radius:999px;display:grid;place-items:center;background:var(--admin-blue);color:#fff;font-size:10px;font-style:normal;font-weight:800}.nav-item:hover,.nav-item.active{color:#fff;background:#2563eb29;border-left-color:var(--admin-blue)}.main-panel{min-width:0;flex:1;display:flex;flex-direction:column}.topbar{height:56px;display:flex;align-items:center;gap:16px;padding:0 18px;background:#fff;border-bottom:1px solid #f0f0f0}.icon-btn{width:34px;height:34px;border:0;border-radius:9px;background:#f8fafc;color:#64748b}.breadcrumb{display:flex;align-items:center;gap:8px;color:#9ca3af;font-size:13px}.breadcrumb strong{color:#111827;font-weight:700}.topbar-spacer{flex:1}.bell{position:relative;border:0;background:transparent;font-size:18px}.bell small{position:absolute;top:-5px;right:-7px;width:16px;height:16px;display:grid;place-items:center;border-radius:50%;background:var(--admin-blue);color:#fff;font-size:9px}.admin-user{display:flex;align-items:center;gap:10px;color:#374151;font-size:13px}.admin-user button{border:0;color:var(--admin-blue);background:transparent}.page{flex:1;overflow-y:auto;padding:24px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.page-head h1{margin:0;font-size:22px;line-height:1.3}.page-head p{margin:5px 0 0;color:#8a94a6;font-size:13px}.head-actions{display:flex;gap:10px}.btn{height:36px;padding:0 14px;border-radius:10px;border:1px solid #d9dee8;background:#fff;color:#374151}.btn.primary{border-color:var(--admin-blue);background:var(--admin-blue);color:#fff}.btn.danger{border-color:#ef4444;background:#ef4444;color:#fff}.panel{background:#fff;border-radius:16px;box-shadow:0 1px 5px #0000000f}.panel-title{padding:16px 18px;border-bottom:1px solid var(--border);font-size:15px;font-weight:800}.filters{display:flex;align-items:end;flex-wrap:wrap;gap:12px;padding:16px;border-bottom:1px solid var(--border)}.filters input{width:240px}.filters input[type=number],.filters input[type=date],.filters select{width:150px}.product-filter-row{width:100%;display:flex;align-items:end;flex-wrap:wrap;gap:10px}.product-quick-filter-row{align-items:center}.product-main-filter-row input[name=keyword]{width:280px}.product-category-filter{display:grid;gap:7px}.quick-filter{height:30px;padding:0 12px;border:1px solid #d9dee8;border-radius:999px;background:#fff;color:#4b5563;font-size:12px}.quick-filter.active{border-color:var(--admin-blue);background:#eff6ff;color:#1d4ed8;font-weight:700}.product-more-filters{width:100%;display:none;grid-template-columns:repeat(5,minmax(140px,1fr));gap:12px;padding:12px;border:1px solid #edf2f7;border-radius:10px;background:#fbfdff}.product-more-filters.open{display:grid}.product-more-filters input{width:100%}.product-more-actions{grid-column:1 / -1;display:flex;justify-content:flex-end;gap:10px}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:860px}.data-table th{padding:12px 14px;color:#64748b;background:#f8fafc;border-bottom:1px solid var(--border);font-size:12px;font-weight:700;text-align:left;white-space:nowrap}.data-table td{padding:13px 14px;border-bottom:1px solid #f4f6fa;color:#374151;font-size:13px;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table tr:hover td{background:#fbfdff}.actions-col{position:sticky;right:0;background:inherit;text-align:right!important;box-shadow:-8px 0 12px #ffffffd9}.link{margin-left:10px;border:0;color:var(--admin-blue);background:transparent;font-size:13px}.link.primary{font-weight:700}.link.danger{color:#ef4444}.tag{display:inline-flex;align-items:center;height:24px;padding:0 9px;border-radius:999px;background:#eef2ff;color:#4f46e5;font-size:12px}.tag.approved,.tag.enabled,.tag.on_sale,.tag.completed,.tag.shipped,.tag.active{background:#dcfce7;color:#15803d}.tag.pending,.tag.confirmed{background:#fef3c7;color:#b45309}.tag.rejected,.tag.disabled,.tag.off_sale,.tag.cancelled,.tag.hidden,.tag.inactive{background:#fee2e2;color:#b91c1c}.tag.transferred,.tag.closed{background:#e5e7eb;color:#4b5563}.product-batch-bar{min-width:1320px;display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:#fff;color:#64748b;font-size:13px}.product-batch-dropdown{position:relative}.product-batch-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:20;min-width:190px;padding:6px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;box-shadow:0 12px 34px #0f172a29}.product-batch-menu button{width:100%;min-height:34px;padding:0 10px;border:0;border-radius:8px;background:transparent;color:#374151;text-align:left;font-size:13px}.product-batch-menu button:hover{background:#f8fafc}.product-batch-menu button.danger{color:#dc2626}.product-table{min-width:1320px}.product-index-col,.product-select-col{width:52px;text-align:center!important}.product-table th:first-child,.product-table td:first-child,.product-table th:nth-child(2),.product-table td:nth-child(2){text-align:center}.column-gear{width:28px;height:28px;border:1px solid #d9dee8;border-radius:8px;background:#fff;color:#64748b}.product-thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1px solid #e5e7eb;background:#f8fafc;vertical-align:middle}.product-empty{position:relative;min-height:160px;gap:10px}.empty-column-gear{margin-left:8px}.product-pagination{display:flex;align-items:center;justify-content:flex-end;gap:14px}.product-pagination label{display:inline-flex;align-items:center;gap:8px}.product-pagination select{height:30px;border:1px solid #d9dee8;border-radius:8px;background:#fff;color:#374151}.column-settings-list{display:grid;gap:8px}.column-settings-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:9px 10px;border:1px solid #edf2f7;border-radius:10px;background:#fbfdff}.column-order-actions{display:flex;gap:6px}.column-order-actions .icon-btn{width:30px;height:30px}.category-table{min-width:980px}.category-table td{vertical-align:middle}.category-name{display:inline-flex;align-items:center;gap:7px;min-width:150px}.category-name.parent{font-weight:700;color:#111827}.category-name.child{padding-left:26px;color:#374151}.tree-arrow{width:16px;color:#64748b;font-size:15px;text-align:center}.tree-branch{width:16px;color:#cbd5e1;text-align:center}.folder-icon{width:20px;text-align:center;font-size:16px}.folder-icon.child{color:#94a3b8;font-size:13px}.category-thumb{width:42px;height:42px;display:inline-grid;place-items:center;border-radius:9px;object-fit:cover;border:1px solid #e5e7eb;background:#f8fafc;color:#94a3b8;font-size:12px}.category-thumb.placeholder{border-style:dashed}.category-child-row td:first-child{position:relative}.category-child-row td:first-child:before{content:"";position:absolute;left:28px;top:0;bottom:0;width:1px;background:#edf2f7}.category-child-row .category-name{position:relative;z-index:1;background:inherit}.loading,.empty{min-height:220px;display:grid;place-items:center;color:#94a3b8;font-size:14px}.empty.error{color:#ef4444}.pagination{padding:13px 16px;color:#8a94a6;font-size:12px;text-align:right}.stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:16px}.stat-card{padding:18px;border-radius:16px;background:#fff;box-shadow:0 1px 5px #0000000f}.stat-card span{color:#8a94a6;font-size:13px}.stat-card strong{display:block;margin-top:6px;font-size:26px}.stat-card p{margin:4px 0 0;color:#10b981;font-size:12px}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.dashboard-grid .wide{grid-row:span 2}.chart-bars{height:280px;display:flex;align-items:end;gap:18px;padding:22px}.chart-bars div{flex:1;height:100%;display:flex;flex-direction:column;justify-content:end;align-items:center;gap:10px;color:#94a3b8;font-size:11px}.chart-bars i{width:100%;max-width:46px;border-radius:10px 10px 4px 4px;background:linear-gradient(180deg,#60a5fa,#2563eb)}.todo{width:calc(100% - 32px);margin:10px 16px 0;padding:12px;border:1px solid #dbeafe;border-radius:12px;display:grid;grid-template-columns:1fr auto;gap:3px 8px;text-align:left;background:#eff6ff}.todo span{font-weight:700;color:#1e3a8a}.todo small{color:#64748b}.todo b{grid-row:1 / 3;grid-column:2;align-self:center;color:var(--admin-blue)}.rule-list{margin:0;padding:14px 20px 18px 34px;color:#64748b;font-size:13px;line-height:1.9}.settings-form{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:16px;padding:18px}.settings-form .btn{width:120px}.settings-form .wide,.settings-form .form-error{grid-column:1 / -1}.salesman-stat-grid{padding:16px;margin-bottom:0}.toast{position:fixed;right:24px;top:76px;z-index:100;padding:12px 16px;border-radius:12px;color:#fff;background:#16a34a;box-shadow:0 12px 30px #0000002e;font-size:14px}.toast.danger{background:#ef4444}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:24px;background:#0f172a6b}.modal-card{width:min(760px,100%);max-height:min(86vh,820px);display:flex;flex-direction:column;overflow:hidden;border-radius:16px;background:#fff;box-shadow:0 28px 90px #0f172a52}.modal-head{height:58px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:18px}.modal-close{width:32px;height:32px;border:0;border-radius:8px;background:#f8fafc;color:#64748b;font-size:20px;line-height:1}.modal-form{min-height:0;display:flex;flex-direction:column}.modal-body{min-height:0;overflow-y:auto;padding:18px}.modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.modal-grid .wide,.modal-section-title{grid-column:1 / -1}.modal-section-title{margin-top:4px;padding-top:4px;color:#111827;font-size:13px;font-weight:800}.modal-tip{color:#64748b;font-size:13px;line-height:1.6}.modal-form label{display:grid;gap:7px;color:#374151;font-size:13px}.modal-form input,.modal-form select,.modal-form textarea{width:100%;border:1px solid #d9dee8;border-radius:10px;background:#fff;outline:none}.modal-form input,.modal-form select{height:38px;padding:0 12px}.modal-form textarea{min-height:86px;padding:10px 12px;resize:vertical}.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus{border-color:var(--admin-blue);box-shadow:0 0 0 3px #2563eb1a}.product-image-field{align-content:start;display:grid;gap:7px;color:#374151;font-size:13px}.product-image-label{color:#374151}.product-image-upload{display:grid;gap:10px}.product-image-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center}.product-image-row .btn{white-space:nowrap}.product-image-clear{display:none}.product-image-preview{display:none;width:132px;padding:6px;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc}.product-image-preview img{display:block;width:118px;height:118px;object-fit:cover;border-radius:8px;background:#fff}.checkbox-line{min-height:38px;display:flex!important;align-items:center;gap:9px!important}.checkbox-line input{width:16px;height:16px}.product-specs-field{display:grid;gap:12px}.product-specs-selector{display:flex;flex-wrap:wrap;gap:8px;padding:10px;border:1px solid #e5e7eb;border-radius:10px;background:#fbfdff}.product-spec-option{min-height:32px;padding:0 10px;border:1px solid #e5e7eb;border-radius:999px;background:#fff}.product-spec-option:has(input:checked){border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8;font-weight:700}.product-spec-values{display:grid;gap:10px}.product-spec-value-panel{display:grid;gap:10px;padding:12px;border:1px solid #edf2f7;border-radius:10px;background:#fff}.product-spec-value-head,.product-spec-value-input{display:flex;align-items:center;gap:10px}.product-spec-value-head{justify-content:space-between;color:#111827;font-size:13px}.product-spec-value-head span{color:#8a94a6;font-size:12px;font-weight:400}.product-spec-value-input input{flex:1}.product-spec-value-input .btn{flex:0 0 auto}.product-spec-value-tags{min-height:28px;display:flex;flex-wrap:wrap;gap:8px}.product-spec-value-tag{min-height:28px;display:inline-flex;align-items:center;gap:6px;padding:0 8px 0 10px;border-radius:999px;background:#f1f5f9;color:#334155;font-size:12px}.product-spec-value-tag button{width:18px;height:18px;display:grid;place-items:center;border:0;border-radius:50%;background:#e2e8f0;color:#64748b;line-height:1}.product-spec-preview{padding:10px 12px;border:1px solid #dbeafe;border-radius:10px;background:#eff6ff;color:#1d4ed8;font-size:13px;font-weight:700}.product-spec-preview.danger{border-color:#fecaca;background:#fef2f2;color:#b91c1c}.sku-price-modal-card{width:min(1180px,100%)}.sku-price-wrap{max-width:100%}.sku-price-table{min-width:980px}.sku-price-table td{max-width:none}.sku-price-input{width:112px!important;min-width:112px}.sku-price-table-wrap{padding:20px 0}.sku-price-table{width:100%;border-collapse:collapse;background:#fff}.sku-price-table th,.sku-price-table td{padding:12px;border:1px solid var(--border);text-align:left;font-size:13px}.sku-price-table th{background:#f9fafb;color:#374151;font-weight:600;white-space:nowrap}.sku-price-table td{color:#111827}.sku-price-table .price-input{width:100px;height:32px;padding:0 8px;border:1px solid #d1d5db;border-radius:6px;font-size:13px}.sku-price-table .price-input:focus{border-color:var(--admin-blue);outline:none;box-shadow:0 0 0 3px #2563eb1a}.sku-price-actions{display:flex;gap:12px;padding:20px 0}.rich-text-field{display:grid;gap:7px}.rich-text-label{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#374151;font-size:13px}.rich-text-label span{color:#8a94a6;font-size:12px;font-weight:400}.rich-text-editor{position:relative;border:1px solid #d6dbe6;border-radius:8px;overflow:hidden;background:#fff}.rich-text-editor:focus-within{border-color:#b8c4d6;box-shadow:0 0 0 3px #2563eb14}.rich-text-toolbar{min-height:74px;display:flex;align-items:center;align-content:flex-start;flex-wrap:wrap;gap:0;padding:6px 7px;border-bottom:1px solid #e6eaf2;background:#f7f8fa}.rich-toolbar-group{min-height:30px;display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-right:1px solid #dfe4ec}.rich-toolbar-group:last-child{border-right:0}.rich-tool-button,.rich-toolbar-select,.rich-color-button{position:relative;height:28px;border:1px solid transparent;border-radius:4px;background:transparent;color:#4b5563;font-size:12px;line-height:1}.rich-tool-button{min-width:28px;padding:0 7px;display:inline-grid;place-items:center}.rich-tool-button.wide{min-width:42px}.rich-tool-button:hover,.rich-tool-button.active,.rich-color-button:hover,.rich-toolbar-select:hover,.rich-toolbar-select:focus{border-color:#cbd5e1;background:#fff;color:#1d4ed8}.rich-tool-button.active{box-shadow:inset 0 0 0 1px #bfdbfe}.rich-tool-button:disabled{cursor:not-allowed;opacity:.62}.rich-toolbar-select{min-width:76px;padding:0 24px 0 8px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#6b7280 50%),linear-gradient(135deg,#6b7280 50%,transparent 50%);background-position:calc(100% - 12px) 11px,calc(100% - 7px) 11px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.rich-toolbar-select.small{min-width:66px}.rich-color-button{width:30px;display:inline-grid;place-items:center;cursor:pointer}.rich-color-button span{position:relative;font-weight:700}.rich-color-button span:after{content:"";position:absolute;left:0;right:0;bottom:-5px;height:3px;border-radius:999px;background:#374151}.rich-color-button-bg span:after{background:#facc15}.rich-color-button input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding:0;border:0;opacity:0;cursor:pointer}.rich-tool-button[data-tooltip]:after,.rich-color-button[data-tooltip]:after,.rich-toolbar-select[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:50%;top:calc(100% + 8px);z-index:4;min-width:max-content;max-width:160px;padding:5px 8px;border-radius:4px;background:#111827f5;color:#fff;font-size:12px;font-weight:400;line-height:1.4;white-space:nowrap;transform:translate(-50%) translateY(-4px);opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease}.rich-tool-button[data-tooltip]:before,.rich-color-button[data-tooltip]:before,.rich-toolbar-select[data-tooltip]:before{content:"";position:absolute;left:50%;top:calc(100% + 3px);z-index:4;border:5px solid transparent;border-bottom-color:#111827f5;transform:translate(-50%) translateY(-4px);opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease}.rich-tool-button:hover:after,.rich-tool-button:hover:before,.rich-color-button:hover:after,.rich-color-button:hover:before,.rich-toolbar-select:hover:after,.rich-toolbar-select:hover:before{opacity:1;transform:translate(-50%) translateY(0)}.rich-text-area,.rich-text-source{width:100%;min-height:300px;padding:18px 20px;border:0;background:#fff;color:#111827;font-size:14px;line-height:1.75;outline:none;overflow:auto;overflow-wrap:anywhere}.rich-text-source{display:block;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.6}.rich-text-editor.is-empty .rich-text-area:before{content:attr(data-placeholder);color:#b0b7c3;pointer-events:none}.rich-text-area p{margin:0 0 10px}.rich-text-area h1,.rich-text-area h2,.rich-text-area h3,.rich-text-area h4{margin:14px 0 10px;line-height:1.35}.rich-text-area blockquote{margin:12px 0;padding:8px 12px;border-left:3px solid #cbd5e1;background:#f8fafc;color:#4b5563}.rich-text-area ul,.rich-text-area ol{margin:0 0 10px;padding-left:22px}.rich-text-area a{color:var(--admin-blue);text-decoration:underline}.rich-text-area hr{height:1px;margin:16px 0;border:0;background:#e5e7eb}.rich-text-area img,.rich-text-area video{max-width:100%;height:auto}.rich-text-area img{display:block;margin:8px 0;border-radius:6px}.rich-text-area video{display:block;margin:8px 0;background:#111827;border-radius:8px}.rich-text-area table{width:100%;max-width:100%;margin:12px 0;border-collapse:collapse;table-layout:fixed}.rich-text-area th,.rich-text-area td{min-width:90px;border:1px solid #d8dee8;padding:8px 10px;vertical-align:top}.rich-text-area th{background:#f5f7fb;color:#374151;font-weight:700}.rich-text-editor.is-fullscreen{position:fixed;top:18px;right:18px;bottom:18px;left:18px;z-index:130;display:flex;flex-direction:column;border-radius:10px;box-shadow:0 24px 90px #0f172a5c}.rich-text-editor.is-fullscreen .rich-text-toolbar{flex:0 0 auto}.rich-text-editor.is-fullscreen .rich-text-area,.rich-text-editor.is-fullscreen .rich-text-source{flex:1;min-height:0}.rich-text-lock{overflow:hidden}.modal-error{padding:0 18px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid var(--border)}@media(max-width:1100px){.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid{grid-template-columns:1fr}.product-more-filters{grid-template-columns:repeat(2,minmax(160px,1fr))}}@media(max-width:720px){.page{padding:16px}.page-head{align-items:flex-start;flex-direction:column}.product-main-filter-row input[name=keyword],.product-category-filter,.product-category-filter select{width:100%}.product-more-filters{grid-template-columns:1fr}.modal-backdrop{padding:12px;place-items:stretch}.modal-card{max-height:calc(100vh - 24px)}.modal-grid,.product-image-row{grid-template-columns:1fr}.product-image-row .btn{width:100%}}
