﻿:root{--surface:#fff;--surface-soft:#fff8fc;--primary:#df6ea6;--primary-deep:#bf5d8d;--soft:#f8d7e8;--soft-strong:#f3c8dd;--text:#543244;--muted:#ab7f92;--border:#f3c7db;--shadow:0 16px 40px rgba(223,110,166,.12);--ok:#64b98a;--warn:#d89f4b;--danger:#d85b79}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{font-family:Sora,system-ui,sans-serif;font-size:15px;background:radial-gradient(circle at top left,#ffd7ea,transparent 20%),linear-gradient(180deg,#fffafd,#fff4f9);color:var(--text)}
button,input,select{font:inherit}
button{cursor:pointer;--btn-transform:none;transition:transform .16s ease,filter .16s ease,background-color .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease}
button:not(:disabled):hover{transform:var(--btn-transform) translateY(-1px);filter:saturate(1.03) brightness(.98)}
button:not(:disabled):active{transform:var(--btn-transform) translateY(0) scale(.99);filter:saturate(1.01) brightness(.95)}
.app{max-width:1480px;margin:0 auto;padding:18px}
.top{display:grid;grid-template-columns:minmax(280px,420px) minmax(260px,1fr) auto;gap:18px;align-items:center;position:sticky;top:12px;z-index:20;padding:18px 22px;border:1px solid var(--border);border-radius:30px;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);box-shadow:var(--shadow)}
.offline-notice{position:fixed;top:94px;left:50%;z-index:60;display:inline-flex;align-items:center;justify-content:center;max-width:min(calc(100vw - 28px),420px);padding:10px 14px;border:1px solid rgba(84,50,68,.08);border-radius:999px;background:rgba(84,50,68,.9);color:#fff;font-size:12px;font-weight:700;letter-spacing:.2px;box-shadow:0 12px 24px rgba(37,18,28,.16);transform:translate(-50%,-12px);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}
.offline-notice.show{opacity:1;transform:translate(-50%,0)}
.ai-search-trigger{position:absolute;top:50%;right:10px;transform:translateY(-50%);--btn-transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;gap:5px;min-width:66px;height:34px;padding:0 12px;border:1px solid rgba(223,110,166,.34);border-radius:999px;background:linear-gradient(135deg,#fff,#ffeaf5);color:var(--primary-deep);font-size:12px;font-weight:900;box-shadow:0 8px 18px rgba(223,110,166,.1)}
.ai-search-trigger:hover{background:#ffeaf5;border-color:var(--primary);transform:translateY(-50%) scale(1.02)}
.ai-search-popover{position:absolute;top:calc(100% + 10px);right:0;z-index:45;width:min(680px,calc(100vw - 36px));padding:16px;border:1px solid rgba(223,110,166,.34);border-radius:24px;background:rgba(255,255,255,.98);box-shadow:0 22px 54px rgba(84,50,68,.18);backdrop-filter:blur(14px)}
.ai-popover-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:12px}
.ai-popover-head strong{display:block;font-size:16px;line-height:1.1;color:var(--primary-deep)}
.ai-popover-head span{display:block;margin-top:4px;font-size:12px;line-height:1.35;color:var(--muted)}
.ai-popover-close{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--text);font-size:20px;line-height:1}
.ai-popover-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,1fr);gap:9px;margin-bottom:10px}
.ai-field{display:grid;gap:5px;min-width:0;width:100%;font-size:11px;font-weight:800;color:var(--muted)}
.ai-field-wide{grid-column:1 / -1}
.ai-field input{display:block;width:100%;min-width:0;height:42px;padding:0 14px;border:1px solid var(--border);border-radius:13px;background:var(--surface-soft);color:var(--text);outline:none;font-size:14px;font-weight:700;line-height:42px;text-overflow:clip}
.ai-mini-row,.ai-search-chips{display:flex;align-items:center;gap:7px;min-width:0;flex-wrap:wrap;margin-top:8px}
.ai-mini-chip,.ai-search-chip{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:6px 10px;border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--text);font-size:12px;font-weight:800;white-space:nowrap;box-shadow:0 8px 18px rgba(223,110,166,.06)}
.ai-mini-chip:hover,.ai-search-chip:hover{border-color:var(--primary);background:#fff4fa;color:var(--primary-deep)}
.ai-build-btn{width:100%;min-height:40px;margin-top:12px;border:none;border-radius:14px;background:var(--primary);color:#fff;font-weight:900}
.brand{display:flex;align-items:center;gap:14px;min-width:0;user-select:none;cursor:pointer;padding:6px 8px;margin:-6px -8px;border-radius:20px;transition:transform .15s ease,background .15s ease,box-shadow .15s ease}
.brand:hover{transform:translateY(-1px);background:#fff7fb;box-shadow:0 10px 24px rgba(223,110,166,.08)}
.brand:active{transform:translateY(0) scale(.99)}
.brand picture{display:block;flex:none}
.brand img,.brand picture img{width:66px;height:66px;display:block;object-fit:contain;flex:none}
.brand-text{min-width:0}
.brand-title{font-family:'Cormorant Garamond',serif;font-size:25px;line-height:1;font-weight:700;color:var(--primary);white-space:nowrap}
.brand-sub{display:inline-flex;align-items:center;gap:6px;margin-top:7px;font-size:11px;line-height:1;letter-spacing:.35px;text-transform:none;white-space:nowrap;color:var(--muted)}
.search{position:relative;min-width:0}
.search input{width:100%;height:50px;padding:0 100px 0 18px;border:1px solid var(--border);border-radius:999px;background:var(--surface-soft);color:var(--text);outline:none}
.search-clear{position:absolute;top:50%;right:80px;transform:translateY(-50%);--btn-transform:translateY(-50%);display:none;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:999px;background:transparent;color:var(--muted);font-size:18px;line-height:1}
.search-clear.show{display:flex}
.search-clear:hover{background:#f5e3ec;color:var(--primary-deep);transform:translateY(-50%) scale(1.04)}
.search-icon{position:absolute;top:50%;right:16px;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--primary-deep)}
.search-icon svg,.button-icon svg{display:block;width:18px;height:18px}
.actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.primary,.ghost,.apply,.add,.checkout,.pager button{border:none;border-radius:14px;transition:transform .15s ease,opacity .15s ease,background .15s ease}
.primary:hover,.ghost:hover,.apply:hover,.add:hover,.checkout:hover,.pager button:hover{transform:translateY(-1px)}
.button-icon{display:inline-flex;align-items:center;justify-content:center;flex:none}
.primary{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:999px;background:var(--primary);color:#fff;font-weight:700;white-space:nowrap}
.ghost{display:inline-flex;align-items:center;gap:8px;padding:11px 14px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:600}
.cart-pill{gap:10px;padding:12px 16px}
.cart-copy{display:inline-flex;align-items:center;gap:8px}
.cart-label{font-size:13px;line-height:1;color:#fff}
#cartTotalTop{display:inline-block;font-size:13px;line-height:1;color:#ffe6f1;font-weight:700}
.cart-counter{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;border-radius:999px;background:rgba(255,255,255,.22);font-size:12px;font-weight:800}
.layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;margin-top:18px}
.sidebar,.drawer{background:rgba(255,255,255,.92);border:1px solid var(--border);box-shadow:var(--shadow)}
.sidebar{position:sticky;top:128px;align-self:start;height:max-content;padding:16px 18px 18px;border-radius:24px}
.sidebar-head{display:none;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:0;border:none;background:transparent;text-align:left}
.sidebar .section-title{margin:0 0 10px;font-size:20px}
.sidebar-head .section-title{display:inline-flex;align-items:center;gap:8px;margin:0;font:inherit;font-size:14px;line-height:1;color:var(--muted);font-weight:700}
.filter-toggle-copy{display:none;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:0 14px;border-radius:999px;white-space:nowrap;font-weight:700;color:var(--muted)}
.filter-toggle-copy .chev{font-size:14px;line-height:1;transition:transform .18s ease}
.sidebar[data-collapsed="0"] .filter-toggle-copy .chev{transform:rotate(180deg)}
.sidebar-body{display:block}
.sidebar .label{margin:12px 0 7px;font-size:10px;letter-spacing:2.4px}
.sidebar .filter-label-main{margin:0 0 10px;font-size:14px;letter-spacing:0;text-transform:none;color:var(--muted);font-weight:700}
.sidebar #catList{gap:1px}
.sidebar .cat{padding:7px 10px;border-radius:12px}
.sidebar .count{min-width:24px;padding:2px 7px;font-size:10px}
.sidebar .price-row{gap:8px}
.sidebar .input,.sidebar .select{height:36px;padding:0 10px;border-radius:12px}
.sidebar .apply{margin-top:8px;padding:10px 12px}
.sidebar .stock-group{gap:8px;margin-top:2px}
.sidebar .stock-option{gap:6px;font-size:13px}
.section-title{margin:0 0 16px;font-family:'Cormorant Garamond',serif;font-size:22px;line-height:1.05}
.label{display:block;margin:18px 0 10px;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);font-weight:700}
#catList{display:grid;gap:4px}
.cat{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 12px;border-radius:14px;cursor:pointer}
.cat.active,.cat:hover{background:var(--soft);color:var(--primary)}
.count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:3px 8px;border-radius:999px;background:#fff;font-size:11px;line-height:1}
.price-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.input,.select{width:100%;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft);color:var(--text);outline:none}
.apply{width:100%;margin-top:10px;padding:12px 14px;background:var(--soft);color:var(--primary-deep);font-weight:700}
.stock-group{display:grid;gap:12px;margin-top:4px}
.stock-option{display:flex;align-items:center;gap:8px}
main{min-width:0;padding-bottom:104px}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;margin-bottom:18px;padding:14px 18px;border:1px solid var(--border);border-radius:22px;background:rgba(255,255,255,.82)}
#resultsText{min-width:0;font-size:14px;color:var(--muted)}
#resultsText strong{font-size:18px;color:var(--text)}
.results-word{color:var(--muted)}
.ai-results-hint{display:inline-flex;align-items:center;margin-left:8px;padding:3px 8px;border-radius:999px;background:#fff0f7;color:var(--primary-deep);font-size:11px;font-weight:800;vertical-align:middle}
.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;width:100%;grid-auto-rows:auto;align-items:stretch}
.card{min-width:0;display:flex;flex-direction:column;align-self:stretch;height:100%;border:1px solid var(--border);border-radius:24px;overflow:hidden;background:#fff;box-shadow:0 12px 28px rgba(223,110,166,.08);content-visibility:auto;contain-intrinsic-size:420px}
.card.card-loaded{opacity:0;animation:ntpfCardFadeIn .2s ease forwards}
.card.card-skeleton{pointer-events:none;user-select:none}
.thumb{position:relative;width:100%;aspect-ratio:1 / 1;height:auto;background:#f0f0f0;overflow:hidden;flex-shrink:0}
.thumb img{width:100%;height:100%;display:block;object-fit:cover;opacity:0;transition:opacity .3s ease}
.thumb[data-image-state="ready"] img{opacity:1}
.thumb-placeholder{position:absolute;inset:0;display:block;overflow:hidden;background:#f0f0f0;transition:opacity .3s ease}
.thumb-placeholder::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(240,240,240,0) 0%,rgba(255,255,255,.78) 50%,rgba(240,240,240,0) 100%);transform:translateX(-100%);animation:ntpfThumbPulse 1.15s linear infinite}
.thumb[data-image-state="ready"] .thumb-placeholder{opacity:0;pointer-events:none}
.thumb-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px}
.skeleton-block{position:relative;display:block;overflow:hidden;background:#f0f0f0}
.skeleton-block::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(240,240,240,0) 0%,rgba(255,255,255,.72) 50%,rgba(240,240,240,0) 100%);transform:translateX(-100%);animation:ntpfSkeletonShimmer 1.15s linear infinite}
.card-skeleton .thumb{background:#f0f0f0}
.skeleton-media{position:absolute;inset:0;border-radius:0}
.skeleton-name{display:grid;gap:8px}
.skeleton-line{height:12px;border-radius:999px}
.skeleton-cat{width:42%;height:10px;border-radius:999px}
.skeleton-title{width:88%}
.skeleton-title.short{width:64%}
.skeleton-price{width:34%;min-width:74px;height:16px;border-radius:999px}
.skeleton-pill{width:30%;min-width:84px;height:26px;border-radius:999px}
.skeleton-qty{height:40px;border-radius:14px}
.skeleton-btn{height:40px;border-radius:14px}
.thumb-nav{position:absolute;top:50%;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border:none;border-radius:999px;background:rgba(255,255,255,.92);color:var(--text);box-shadow:0 10px 24px rgba(37,18,28,.12);transform:translateY(-50%);--btn-transform:translateY(-50%)}
.thumb-nav.prev{left:12px}
.thumb-nav.next{right:12px}
.thumb-nav svg{width:20px;height:20px;display:block}
.thumb-count{position:absolute;right:12px;bottom:12px;z-index:2;display:inline-flex;align-items:center;justify-content:center;min-width:46px;height:28px;padding:0 10px;border-radius:999px;background:rgba(58,36,48,.68);color:#fff;font-size:11px;font-weight:700;backdrop-filter:blur(8px)}
.body{display:flex;flex:1;flex-direction:column;justify-content:flex-start;gap:10px;padding:14px 14px 16px;min-width:0;overflow:hidden}
.catline{font-size:11px;line-height:1.1;color:#f38bb6;font-weight:700;letter-spacing:1.6px;text-transform:uppercase}
.name{min-height:48px;max-height:calc(1.34em * 2);font-size:15px;line-height:1.34;font-weight:700;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;overflow:hidden;text-overflow:ellipsis;word-break:break-word;overflow-wrap:break-word;white-space:normal}
.card .name{height:calc(1.34em * 2);min-height:calc(1.34em * 2);max-height:calc(1.34em * 2)}
.price-stock{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:34px}
.final{font-size:17px;line-height:1.1;font-weight:800;color:#312235}
.variant{display:grid;gap:6px;align-content:start;min-height:40px}
.variant small{font-size:12px;color:var(--muted)}
.stock{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:0 12px;border-radius:999px;background:#e6f6ec;color:var(--ok);font-size:11px;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:.4px}
.stock.low{background:#fff3df;color:var(--warn);text-transform:none;letter-spacing:0}
.stock.none{background:#f6edf1;color:var(--muted)}
.add{width:100%;min-height:40px;padding:10px 12px;background:#f8d9e8;color:var(--primary);font-size:12px;font-weight:800}
.add:disabled,.checkout:disabled{opacity:.45;cursor:not-allowed;transform:none}
.pager{display:flex;flex-wrap:nowrap;align-items:center;justify-content:center;gap:8px;margin:22px 0 0;overflow-x:auto;overflow-y:hidden;padding:4px 84px 6px 4px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}
.pager button{min-width:40px;padding:10px 12px;background:#fff;border:1px solid var(--border);color:var(--text)}
.pager button.active{background:var(--primary);color:#fff;border-color:transparent}
.pager .dots{display:inline-flex;align-items:center;justify-content:center;min-width:28px;color:var(--muted);font-weight:700}
.pager button:disabled{opacity:.45;cursor:not-allowed;transform:none}
.overlay{position:fixed;inset:0;display:none;background:rgba(37,18,28,.34);z-index:40}
.overlay.open{display:block}
.drawer{position:fixed;top:18px;right:18px;bottom:18px;width:400px;display:none;overflow:auto;z-index:41;padding:18px;border-radius:28px;-webkit-overflow-scrolling:touch}
.drawer.open{display:block}
.product-overlay{position:fixed;inset:0;display:none;background:rgba(37,18,28,.42);z-index:44}
.product-overlay.open{display:block}
.product-sheet{position:fixed;top:50%;left:50%;display:none;z-index:45;width:min(96vw,1120px);height:min(92vh,920px);max-height:min(92vh,920px);transform:translate(-50%,-50%);overflow:hidden;border:1px solid var(--border);border-radius:30px;background:rgba(255,255,255,.98);box-shadow:0 24px 70px rgba(37,18,28,.24);overscroll-behavior:contain}
.product-sheet.open{display:block}
.product-shell{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);height:100%;max-height:min(92vh,920px);min-height:0}
.product-gallery-panel{display:grid;grid-template-rows:minmax(320px,1fr) auto;gap:14px;min-height:0;padding:20px;background:linear-gradient(180deg,#fff8fc,#fff4f9)}
.product-stage{position:relative;min-height:420px;height:100%;border:1px solid var(--border);border-radius:26px;overflow:hidden;background:#f0f0f0;touch-action:pan-y;-webkit-user-select:none;user-select:none}
.product-stage::before{content:'';position:absolute;inset:0;background:#f0f0f0;transition:opacity .3s ease;pointer-events:none}
.product-stage::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(240,240,240,0) 0%,rgba(255,255,255,.72) 50%,rgba(240,240,240,0) 100%);transform:translateX(-100%);animation:ntpfThumbPulse 1.15s linear infinite;pointer-events:none}
.product-stage img{width:100%;height:100%;display:block;object-fit:contain;background:transparent;opacity:0;transition:opacity .3s ease}
.product-stage[data-image-state="ready"] img{opacity:1}
.product-stage[data-image-state="ready"]::before,.product-stage[data-image-state="ready"]::after{opacity:0}
.product-stage .thumb-nav{width:48px;height:48px}
.product-gallery-thumbs{display:flex;gap:10px;max-width:100%;overflow-x:auto;overflow-y:hidden;padding:2px 2px 6px 0;scrollbar-width:thin;scroll-snap-type:x proximity}
.product-gallery-thumbs button{position:relative;flex:0 0 78px;width:78px;min-width:78px;padding:0;border:1px solid var(--border);border-radius:16px;background:#f0f0f0;overflow:hidden;opacity:.7;scroll-snap-align:start}
.product-gallery-thumbs button::before{content:'';position:absolute;inset:0;background:#f0f0f0;transition:opacity .3s ease;pointer-events:none}
.product-gallery-thumbs button.active{border-color:var(--primary);box-shadow:0 0 0 2px rgba(223,110,166,.18);opacity:1}
.product-gallery-thumbs img{display:block;width:100%;aspect-ratio:1;object-fit:cover;background:transparent;opacity:0;transition:opacity .3s ease}
.product-gallery-thumbs button[data-image-state="ready"] img{opacity:1}
.product-gallery-thumbs button[data-image-state="ready"]::before{opacity:0}
.buy-block{display:grid;grid-template-columns:108px minmax(0,1fr);gap:10px;align-items:center}
.qty-picker{display:grid;grid-template-columns:34px minmax(0,1fr) 34px;height:40px;border:1px solid var(--border);border-radius:14px;background:var(--surface-soft);overflow:hidden}
.qty-step{display:inline-flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;color:var(--primary-deep);font-size:20px;font-weight:700}
.qty-step:disabled{opacity:.35;cursor:not-allowed}
.qty-value{display:inline-flex;align-items:center;justify-content:center;min-width:0;font-size:13px;font-weight:800;color:var(--text)}
.product-info-panel{display:grid;grid-template-rows:auto minmax(0,1fr);min-height:0;overflow:hidden;padding:20px}
.product-info-head{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:flex-start;gap:12px;margin-bottom:12px}
.product-close{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border:1px solid var(--border);border-radius:14px;background:#fff;color:var(--text);font-size:22px;line-height:1}
.product-copy{display:grid;gap:12px;min-height:0;overflow:auto;padding-right:4px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.product-copy .name{min-height:auto;font-size:28px;line-height:1.08}
.product-copy .catline{font-size:12px}
.product-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.product-meta .final{font-size:30px}
.product-description-card{display:grid;gap:10px;padding:16px 18px;border:1px solid var(--border);border-radius:22px;background:var(--surface-soft)}
.product-description-card h3{margin:0;font-size:16px}
.product-description{font-size:14px;line-height:1.6;color:var(--text)}
.product-description > :first-child{margin-top:0}
.product-description > :last-child{margin-bottom:0}
.product-description ul,.product-description ol{margin:0;padding-left:20px}
.product-description a{color:var(--primary-deep)}
.product-description-empty{color:var(--muted)}
.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.close-ghost{display:inline-flex;align-items:center;justify-content:center;flex:none;width:42px;min-width:42px;height:42px;padding:0 !important;border-radius:14px;font-size:24px;line-height:1}
.cart-item{display:grid;grid-template-columns:74px 1fr auto;gap:12px;padding:12px 0;border-top:1px solid #f5dde9}
.cart-item img{width:74px;height:74px;border-radius:16px;object-fit:cover;background:#fff1f8}
.cart-copy-block{min-width:0}
.cart-actions{display:grid;justify-items:end;align-content:start;gap:8px;min-width:96px}
.cart-line-total{font-weight:800;color:var(--text);font-size:17px}
.qty{display:flex;align-items:center;gap:8px;margin-top:8px}
.qty button{width:28px;height:28px;border:none;border-radius:8px;background:#fff1f8;color:var(--text)}
.checkout{width:100%;margin-top:12px;padding:14px 16px;background:var(--primary);color:#fff;font-weight:700}
.checkout-panel{display:grid;gap:12px;margin-top:14px;padding:16px;border:1px solid var(--border);border-radius:22px;background:linear-gradient(180deg,#fff9fc,#fff3f8)}
.checkout-panel h4{margin:0;font-size:17px}
.checkout-copy{font-size:13px;color:var(--muted)}
.checkout-fields{display:grid;gap:10px}
.checkout-field{display:grid;gap:6px}
.checkout-field label{font-size:12px;font-weight:700;color:var(--text)}
.checkout-field input{width:100%;height:42px;padding:0 12px;border:1px solid var(--border);border-radius:14px;background:#fff;color:var(--text);font:inherit}
.checkout-mode{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.checkout-mode label{display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;justify-content:flex-start;gap:12px;min-height:42px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:#fff;font-size:13px;font-weight:700;cursor:pointer}
.checkout-mode label span{display:block;min-width:0}
.checkout-mode input[type="radio"]{appearance:none !important;-webkit-appearance:none !important;accent-color:transparent;display:inline-flex;align-items:center;justify-content:center;flex:none;width:18px;height:18px;margin:0;border:2px solid #d8bcc8;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 0 var(--primary);transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}
.checkout-mode input[type="radio"]:checked{border-color:var(--primary);box-shadow:inset 0 0 0 4px var(--primary)}
.checkout-mode label.active{border-color:#efbcd4;background:var(--soft);color:var(--primary-deep)}
.checkout-actions{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px}
.checkout-actions .ghost,.checkout-actions .checkout{margin-top:0}
.checkout-error{padding:10px 12px;border-radius:14px;background:#ffe7ee;color:var(--danger);font-size:13px;font-weight:600}
.empty{padding:24px;border:1px dashed var(--border);border-radius:16px;text-align:center;color:var(--muted)}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);display:none;padding:12px 18px;border-radius:999px;background:#3a2430;color:#fff;z-index:80;pointer-events:none}
.toast.show{display:block}
.floating-socials{position:fixed;right:22px;bottom:22px;z-index:18;display:grid;gap:10px}
.social-fab{display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:999px;color:#fff;box-shadow:0 16px 32px rgba(37,18,28,.18);transition:transform .15s ease,box-shadow .15s ease}
.social-fab:hover{transform:translateY(-2px);box-shadow:0 20px 40px rgba(37,18,28,.22)}
.social-fab svg{display:block;width:28px;height:28px}
.social-fab.instagram{background:linear-gradient(135deg,#515bd4 0%,#8134af 35%,#dd2a7b 65%,#f58529 100%)}
.social-fab.whatsapp{background:#25d366}
@keyframes ntpfThumbPulse{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@keyframes ntpfSkeletonShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
@keyframes ntpfCardFadeIn{0%{opacity:0}100%{opacity:1}}
@media (max-width:1320px){.grid{grid-template-columns:repeat(3,minmax(0,1fr))}.top{grid-template-columns:minmax(240px,360px) minmax(220px,1fr) auto}}
@media (max-width:1040px){.top{grid-template-columns:1fr}.actions{justify-content:flex-start}.layout{grid-template-columns:1fr}.sidebar{position:static;max-height:none;overflow:visible}.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.product-shell{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr)}.product-stage{min-height:360px}}
@media (max-width:1040px){.ai-popover-grid{grid-template-columns:1fr}.ai-search-popover{left:0;right:auto}}
@media (max-width:700px){.ai-search-trigger{right:8px;min-width:56px;height:30px;padding:0 9px;font-size:11px}.ai-search-popover{position:fixed;top:88px;left:10px;right:10px;width:auto;max-height:calc(100vh - 108px);overflow:auto;padding:14px;border-radius:20px}.ai-search-chips{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.ai-search-chips::-webkit-scrollbar{display:none}.ai-mini-row{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.ai-mini-row::-webkit-scrollbar{display:none}.ai-search-chip,.ai-mini-chip{min-height:30px;padding:6px 10px;font-size:11px}}
@media (max-width:700px){.app{padding:10px}.top{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand brand" "search actions";gap:10px;padding:12px 14px;border-radius:22px;top:8px;transform:translateZ(0);backface-visibility:hidden;will-change:transform;isolation:isolate}.offline-notice{top:78px;max-width:min(calc(100vw - 18px),360px);padding:9px 12px;font-size:11px}.brand{grid-area:brand;gap:10px}.brand img,.brand picture img{width:48px;height:48px}.brand-title{font-size:18px;white-space:normal}.brand-sub{margin-top:4px;font-size:8.3px;letter-spacing:.15px;gap:4px}.search{grid-area:search}.search input{height:42px;padding:0 94px 0 14px;border-radius:18px;font-size:16px}.search-clear{right:66px;width:22px;height:22px;font-size:17px}.search-icon{right:12px;width:20px;height:20px}.actions{grid-area:actions;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:nowrap}.ghost{padding:10px 12px}.primary{padding:10px 12px}.cart-pill{min-height:42px;padding:10px 12px}.cart-label{display:none}#cartTotalTop{font-size:12px}.cart-counter{min-width:22px;height:22px;padding:0 6px;font-size:11px}#adminBtn{width:42px;min-width:42px;height:42px;padding:0;justify-content:center;font-size:0;border-radius:14px}#adminBtn .button-icon{margin:0}.layout{gap:12px;margin-top:12px}.sidebar{max-height:none;overflow:visible;padding:16px 14px}.sidebar-head{display:flex;align-items:center;cursor:pointer}.filter-toggle-copy{display:inline-flex}.sidebar[data-collapsed="1"] .sidebar-body{display:none}.sidebar .filter-label-main{display:none}.toolbar{flex-direction:column;align-items:stretch;margin-bottom:12px;padding:10px 12px;scroll-margin-top:94px}.grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.card{border-radius:18px;content-visibility:visible;contain-intrinsic-size:none}.thumb{height:auto}.thumb-nav{width:30px;height:30px}.thumb-nav.prev{left:8px}.thumb-nav.next{right:8px}.thumb-nav svg{width:16px;height:16px}.thumb-count{right:8px;bottom:8px;min-width:40px;height:24px;padding:0 8px;font-size:10px}.body{gap:8px;padding:10px 10px 12px}.catline{font-size:9px;letter-spacing:1.2px}.name{min-height:34px;max-height:calc(1.22em * 2);font-size:13px;line-height:1.22}.card .name{height:calc(1.22em * 2);min-height:calc(1.22em * 2);max-height:calc(1.22em * 2)}.price-stock{display:grid;grid-template-columns:1fr;gap:6px}.final{font-size:15px}.stock{min-height:24px;padding:0 8px;font-size:10px;max-width:100%;width:max-content}.stock.low{font-size:10px}.variant{gap:4px}.variant small{font-size:10px}.input,.select,input[type="text"],input[type="search"],input[type="number"],input[type="tel"],input[type="email"],input[type="password"],textarea,select{font-size:16px !important}.input,.select{height:36px;border-radius:12px;padding:0 10px}.add{min-height:36px;padding:8px 10px;font-size:11px}.buy-block{grid-template-columns:88px minmax(0,1fr);gap:6px}.qty-picker{height:36px;border-radius:12px}.qty-step{font-size:18px}.qty-value{font-size:12px}.price-row{grid-template-columns:1fr}.drawer{left:8px;right:8px;top:8px;bottom:8px;width:auto;padding:12px 12px calc(12px + env(safe-area-inset-bottom));border-radius:24px;background:#fff}.drawer-head{position:sticky;top:-12px;z-index:3;padding:0 0 12px;margin-bottom:12px;background:linear-gradient(180deg,rgba(255,255,255,.99) 84%,rgba(255,255,255,0))}.drawer-head .section-title{font-size:18px}.close-ghost{width:40px;min-width:40px;height:40px;font-size:22px}.cart-item{grid-template-columns:64px minmax(0,1fr);grid-template-areas:"image copy" "image actions";gap:10px;padding:10px 0;align-items:start}.cart-item img{grid-area:image;width:64px;height:64px;border-radius:14px}.cart-copy-block{grid-area:copy}.cart-copy-block>div:first-child{font-size:14px;line-height:1.25}.cart-actions{grid-area:actions;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding-top:2px}.cart-line-total{font-size:15px;line-height:1.1}.qty{margin-top:6px}.checkout-panel{gap:10px;margin-top:12px;padding:14px;border-radius:20px}.checkout-panel h4{font-size:16px}.checkout-copy{font-size:12px;line-height:1.45}.checkout-fields{gap:8px}.checkout-field{gap:5px}.checkout-field input{height:40px;border-radius:12px;padding:0 12px}.checkout-mode,.checkout-actions{grid-template-columns:1fr}.checkout-mode label{min-height:48px;padding:0 14px;border-radius:14px}.product-sheet{top:8px;left:8px;right:8px;bottom:8px;width:auto;height:auto;max-height:none;transform:none;border-radius:24px}.product-shell{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr);height:100%;max-height:none}.product-gallery-panel{grid-template-rows:minmax(198px,32vh) auto;gap:10px;padding:12px 12px 8px}.product-stage{height:min(32vh,268px);max-height:268px;min-height:198px;border-radius:18px}.product-stage .thumb-nav{width:40px;height:40px}.product-gallery-thumbs{gap:8px;padding:2px 2px 4px 0;scrollbar-width:none}.product-gallery-thumbs::-webkit-scrollbar{display:none}.product-gallery-thumbs button{flex-basis:58px;width:58px;min-width:58px;border-radius:14px}.product-info-panel{min-height:0;padding:0 12px calc(12px + env(safe-area-inset-bottom));overflow:hidden}.product-info-head{position:sticky;top:0;z-index:3;margin:0;padding:8px 0;background:linear-gradient(180deg,rgba(255,255,255,.98) 82%,rgba(255,255,255,0))}.product-close{width:40px;height:40px;border-radius:14px;box-shadow:0 8px 18px rgba(37,18,28,.1)}.product-copy{gap:10px;padding:0 0 8px;overflow:auto;-webkit-overflow-scrolling:touch}.product-copy>.variant+.buy-block{margin-top:4px}.product-copy .name{font-size:21px;line-height:1.08}.product-meta{align-items:flex-start;gap:8px}.product-meta .final{font-size:24px}.product-description-card{padding:14px 14px 16px;border-radius:18px}.product-description{font-size:13px;line-height:1.55}.pager{justify-content:flex-start;padding-right:70px;padding-bottom:4px}.floating-socials{right:14px;bottom:calc(16px + env(safe-area-inset-bottom));gap:8px}.social-fab{width:52px;height:52px}.social-fab svg{width:24px;height:24px}main{padding-bottom:88px}}
@media (max-width:390px){.top{padding:10px 12px}.brand img,.brand picture img{width:42px;height:42px}.brand-title{font-size:16px}.brand-sub{font-size:7.4px;letter-spacing:0}.search input{height:40px;padding-right:90px;font-size:16px}.search-clear{right:62px}.cart-pill{padding:9px 10px}.thumb{height:auto}.body{padding:9px}.name{font-size:12px;min-height:30px}.card .name{height:calc(1.22em * 2);min-height:calc(1.22em * 2);max-height:calc(1.22em * 2)}.final{font-size:14px}.drawer{top:8px;left:8px;right:8px;bottom:8px;padding:10px 10px calc(10px + env(safe-area-inset-bottom));border-radius:22px}.drawer-head{top:-10px}.cart-actions{gap:10px}.product-sheet{top:8px;left:8px;right:8px;bottom:8px;border-radius:22px;height:auto;max-height:none}.product-stage{height:min(30vh,248px);max-height:248px;min-height:198px}.product-gallery-thumbs button{flex-basis:52px;width:52px;min-width:52px}.product-copy .name{font-size:20px}.product-meta .final{font-size:22px}.buy-block{grid-template-columns:82px minmax(0,1fr)}}

