/* ============================================================
   Reborn Heaven — Boutique Storefront
   Editorial design system: warm neutrals, serif display type,
   generous spacing, refined micro-interactions.
   ============================================================ */

/* 1. Theme tokens
   ---------------------------------------------------------- */
:root{
    --primary:#D97706;
    --bg:#FFF7ED;
    --dark:#1F2937;
    --accent:#F9A8D4;
    --cream:#FFFBEB;
    --footer:#1F2937;
    --footer-accent:#F9A8D4;

    --primary-600:color-mix(in srgb,var(--primary) 88%,#000);
    --primary-50: color-mix(in srgb,var(--primary) 10%,#fff);
    --accent-50:  color-mix(in srgb,var(--accent) 18%,#fff);

    --ink-900:#0b1020;
    --ink-800:#1a2236;
    --ink-700:#2f3a52;
    --ink-600:#4b5670;
    --ink-500:#6b7388;
    --ink-400:#97a0b4;
    --ink-300:#c4cad8;
    --ink-200:#e3e6ee;
    --ink-100:#f1f3f8;
    --ink-50: #f7f8fb;

    --line:    rgba(11,16,32,.08);
    --line-2:  rgba(11,16,32,.14);
    --surface: #ffffff;
    --surface-2:#fbf6ee;
    --warm:    #fdf3e3;

    --shadow-xs:0 1px 2px rgba(11,16,32,.05);
    --shadow-sm:0 6px 16px -6px rgba(11,16,32,.10);
    --shadow:   0 22px 48px -16px rgba(11,16,32,.18);
    --shadow-lg:0 50px 90px -24px rgba(11,16,32,.28);

    --r-xs:8px; --r-sm:14px; --r-md:18px;
    --r-lg:24px; --r-xl:32px; --r-pill:999px;

    --t-fast:160ms cubic-bezier(.2,.7,.2,1);
    --t-base:280ms cubic-bezier(.2,.7,.2,1);

    --font-serif:"DM Serif Display",Georgia,"Times New Roman",serif;
    --font-sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

/* 2. Reset + base
   ---------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
    margin:0;
    font-family:var(--font-sans);
    font-size:16px;line-height:1.6;
    color:var(--ink-800);
    background:var(--bg);
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--primary)}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}
::selection{background:var(--primary);color:#fff}

h1,h2,h3,h4{font-family:var(--font-serif);color:var(--ink-900);line-height:1.08;letter-spacing:-.005em;margin:0 0 .35em;font-weight:400}
h1{font-size:clamp(36px,5.4vw,64px);letter-spacing:-.015em}
h2{font-size:clamp(26px,3.4vw,42px)}
h3{font-size:22px;letter-spacing:-.005em}
p{margin:0 0 1em;color:var(--ink-600)}
hr{border:0;border-top:1px solid var(--line);margin:32px 0}

/* 3. Layout primitives
   ---------------------------------------------------------- */
.container{width:min(1280px,92vw);margin-inline:auto}
.card{
    background:var(--surface);
    border-radius:var(--r-lg);
    box-shadow:var(--shadow-sm);
    border:1px solid var(--line);
}
.eyebrow{
    display:inline-flex;align-items:center;gap:10px;
    margin-bottom:16px;
    color:var(--primary);
    font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:800;
}
.eyebrow::before{content:"";width:28px;height:1px;background:currentColor;opacity:.6}

/* 4. Buttons (shared base)
   ---------------------------------------------------------- */
.hero-actions a,
.product-actions a,
.product-actions button,
.summary-cta,.ghost-button,
.form-card button,.checkout-form button,
.search-bar button,.support-panel button,
.admin-sidebar button,.stack-form button,
.admin-form-grid button,.mobile-filter-toggle{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:14px 22px;
    border-radius:var(--r-pill);
    border:1px solid transparent;
    background:var(--ink-900);
    color:#fff;font-weight:600;
    letter-spacing:.01em;
    text-align:center;
    transition:transform var(--t-fast),background var(--t-base),box-shadow var(--t-base),color var(--t-base),border-color var(--t-base);
    box-shadow:var(--shadow-xs);
}
.hero-actions a:hover,
.product-actions button:hover,
.summary-cta:hover,
.form-card button:hover,
.checkout-form button:hover,
.search-bar button:hover,
.support-panel button:hover,
.admin-sidebar button:hover,
.stack-form button:hover,
.admin-form-grid button:hover{
    background:var(--ink-700);
    transform:translateY(-1px);
    box-shadow:var(--shadow-sm);
    color:#fff;
}
.hero-actions .ghost,.ghost-button,.product-actions a{
    background:transparent;color:var(--ink-900);
    border-color:var(--ink-200);
    box-shadow:none;
}
.hero-actions .ghost:hover,.ghost-button:hover,.product-actions a:hover{
    background:var(--ink-50);border-color:var(--ink-300);color:var(--ink-900);
}
.search-bar button{background:var(--primary)}
.search-bar button:hover{background:var(--primary-600)}
.summary-cta{background:var(--primary)}
.summary-cta:hover{background:var(--primary-600)}



/* 5. Header — boutique edition
   ---------------------------------------------------------- */
.site-shell{display:flex;flex-direction:column;min-height:100vh}
.site-header{
    position:sticky;top:0;z-index:40;
    background:rgba(255,255,255,.94);
    backdrop-filter:saturate(140%) blur(16px);
    -webkit-backdrop-filter:saturate(140%) blur(16px);
    border-bottom:1px solid var(--line);
}
.header-row.top{padding:18px 0;background:#fff}
.top-grid{display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center}

/* Brand */
.brand{display:flex;align-items:center;gap:14px;color:var(--ink-900)}
.brand:hover{color:var(--ink-900)}
.brand-mark{
    width:46px;height:46px;border-radius:50%;
    display:grid;place-items:center;
    background:var(--ink-900);
    color:#fff;font-family:var(--font-serif);font-weight:400;
    font-size:18px;letter-spacing:.04em;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
    transition:transform var(--t-fast);
}
.brand:hover .brand-mark{transform:rotate(-4deg)}
.brand-copy strong{
    display:block;font-size:22px;line-height:1;
    color:var(--ink-900);font-family:var(--font-serif);font-weight:400;
    letter-spacing:-.005em;
}
.brand-copy small{
    display:block;margin-top:5px;
    color:var(--ink-500);font-size:10px;letter-spacing:.28em;
    text-transform:uppercase;font-weight:700;
}

/* Search bar — slim, pill-shaped */
.search-bar{
    display:grid;grid-template-columns:160px 1fr auto;
    background:var(--ink-50);
    border-radius:var(--r-pill);
    overflow:hidden;
    border:1px solid transparent;
    transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
    max-width:640px;justify-self:center;width:100%;
}
.search-bar:focus-within{
    background:#fff;
    border-color:var(--ink-900);
    box-shadow:0 0 0 4px var(--ink-100);
}
.search-bar select,.search-bar input{
    border:0;padding:14px 20px;background:transparent;outline:none;color:var(--ink-800);
    font-size:14px;
}
.search-bar select{
    background:transparent;border-right:1px solid var(--line);
    font-weight:600;color:var(--ink-700);
    appearance:none;-webkit-appearance:none;
    background-image:linear-gradient(45deg,transparent 50%,var(--ink-500) 50%),linear-gradient(135deg,var(--ink-500) 50%,transparent 50%);
    background-position:calc(100% - 18px) 50%,calc(100% - 13px) 50%;
    background-size:5px 5px;background-repeat:no-repeat;
    padding-right:36px;
}
.search-bar input::placeholder{color:var(--ink-400)}
.search-bar button{
    display:inline-flex;align-items:center;gap:8px;
    padding:0 22px;border-radius:0;box-shadow:none;
    background:var(--ink-900);color:#fff;
    font-size:13px;font-weight:700;letter-spacing:.04em;
    transition:background var(--t-base);
}
.search-bar button:hover{background:var(--primary)}
.search-bar button svg{stroke:currentColor}

/* Header actions — icon-led with stacked label */
.header-actions{display:flex;align-items:center;gap:4px}
.header-actions .ha-link{
    display:flex;align-items:center;gap:10px;
    padding:8px 12px;border-radius:var(--r-md);
    color:var(--ink-800);
    transition:background var(--t-fast),color var(--t-fast);
}
.header-actions .ha-link:hover{background:var(--ink-50);color:var(--ink-900)}
.header-actions .ha-link svg{flex-shrink:0;color:var(--ink-700)}
.header-actions .ha-link:hover svg{color:var(--ink-900)}
.header-actions .ha-stack{display:grid;gap:1px;line-height:1.1}
.header-actions .ha-stack > span{
    font-size:10px;color:var(--ink-500);
    letter-spacing:.16em;text-transform:uppercase;font-weight:700;
}
.header-actions .ha-stack > strong{
    font-size:13px;color:var(--ink-900);font-weight:700;
}
.header-actions .cart-link{position:relative}
.header-actions .cart-link .ha-stack > strong{
    display:inline-grid;place-items:center;min-width:24px;height:22px;padding:0 8px;
    border-radius:var(--r-pill);background:var(--primary);color:#fff;
    font-size:12px;letter-spacing:0;
}

/* Nav row */
.header-row.middle{
    padding:0;background:#fff;
    border-top:1px solid var(--line);
}
.middle-grid{display:grid;justify-content:center}
.header-nav{
    display:flex;flex-wrap:wrap;justify-content:center;gap:36px;
    font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
    padding:14px 0;
}
.header-nav a{
    position:relative;padding:8px 0;color:var(--ink-600);
    transition:color var(--t-fast);
}
.header-nav a::after{
    content:"";position:absolute;left:50%;right:50%;bottom:0;height:2px;
    background:var(--ink-900);border-radius:2px;
    transition:left var(--t-base),right var(--t-base);
}
.header-nav a:hover,.header-nav a.is-active{color:var(--ink-900)}
.header-nav a:hover::after,.header-nav a.is-active::after{left:0;right:0}

/* Toast */
.toast{
    position:fixed;top:24px;right:24px;z-index:60;
    background:var(--ink-900);color:#fff;
    padding:14px 20px;border-radius:var(--r-pill);
    box-shadow:var(--shadow);
    font-weight:600;font-size:14px;
    animation:toast-in .4s var(--t-base);
}
@keyframes toast-in{from{transform:translateY(-12px);opacity:0}to{transform:none;opacity:1}}

/* 6. Page wrapper + section rhythm
   ---------------------------------------------------------- */
.page{padding:32px 0 96px;flex:1}
.page-section{padding-top:72px}
.page-section:first-of-type{padding-top:48px}
.section-head{
    display:flex;justify-content:space-between;align-items:end;gap:24px;
    margin-bottom:28px;
    border-bottom:1px solid var(--line);padding-bottom:18px;
}
.section-head h2{margin:0}
.section-head a{
    color:var(--ink-700);font-weight:600;font-size:14px;
    display:inline-flex;align-items:center;gap:6px;
}
.section-head a::after{content:"→";transition:transform var(--t-fast)}
.section-head a:hover{color:var(--primary)}
.section-head a:hover::after{transform:translateX(3px)}


/* 7. Hero
   ---------------------------------------------------------- */
.hero-section{
    position:relative;
    padding:24px 0 8px;
}
.hero-section::before{
    content:"";position:absolute;inset:-40px 0 0 0;z-index:-1;
    background:
        radial-gradient(900px 380px at 12% 10%,var(--cream),transparent 70%),
        radial-gradient(700px 360px at 92% 0%,var(--accent-50),transparent 70%);
    pointer-events:none;
}
.hero-grid{
    display:grid;grid-template-columns:1fr 1.05fr;gap:32px;align-items:center;
    padding:24px 0;
}
.hero-copy{
    padding:48px;
    background:var(--surface);
    border-radius:var(--r-xl);
    border:1px solid var(--line);
    box-shadow:var(--shadow);
    position:relative;overflow:hidden;
}
.hero-copy::after{
    content:"";position:absolute;right:-80px;bottom:-80px;width:260px;height:260px;
    border-radius:50%;background:radial-gradient(closest-side,var(--accent-50),transparent 70%);
    pointer-events:none;
}
.hero-copy h1{font-size:clamp(38px,5.6vw,68px);margin-bottom:18px}
.hero-copy p{font-size:18px;color:var(--ink-600);max-width:54ch;margin-bottom:28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px}

.hero-carousel{
    position:relative;
    display:grid;
    grid-template-columns:1.4fr 1fr;
    grid-template-rows:1fr 1fr;
    gap:14px;
    padding:0;
    background:transparent;
    border:0;box-shadow:none;
    aspect-ratio:1.05/1;
}
.hero-slide{
    border-radius:var(--r-xl);overflow:hidden;
    background:var(--surface-2);
    border:1px solid var(--line);
    box-shadow:var(--shadow-sm);
    transition:transform var(--t-base),box-shadow var(--t-base);
    position:relative;
}
.hero-slide:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.hero-slide:nth-child(1){grid-row:1 / span 2}
.hero-slide:nth-child(2){grid-column:2;grid-row:1}
.hero-slide:nth-child(3){grid-column:2;grid-row:2}
.hero-image-frame{aspect-ratio:auto;height:100%}
.hero-image-frame img{width:100%;height:100%;object-fit:cover}

/* Trust strip (homepage) */
.trust-strip{
    margin-top:32px;
    padding:22px 28px;
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--r-lg);
    box-shadow:var(--shadow-xs);
    display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;
}
.trust-item{display:flex;align-items:center;gap:14px}
.trust-item .ti-icon{
    width:40px;height:40px;border-radius:12px;flex-shrink:0;
    display:grid;place-items:center;
    background:var(--warm);color:var(--primary);font-size:18px;
}
.trust-item strong{display:block;color:var(--ink-900);font-size:14px;font-weight:700}
.trust-item span{display:block;color:var(--ink-500);font-size:12px;margin-top:2px}

/* 8. Category grid
   ---------------------------------------------------------- */
.category-grid{display:grid;gap:18px;grid-template-columns:repeat(4,minmax(0,1fr))}
.category-card{
    display:grid;gap:14px;padding:14px;
    background:var(--surface);
    border-radius:var(--r-lg);
    border:1px solid var(--line);
    box-shadow:var(--shadow-xs);
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
    overflow:hidden;
}
.category-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow);
    border-color:var(--ink-200);
}
.category-card .category-image-frame{border-radius:var(--r-md);overflow:hidden}
.category-card h3{margin:0 0 6px;font-size:22px}
.category-card p{margin:0;color:var(--ink-500);font-size:14px;line-height:1.5;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.category-card > div{padding:6px 10px 12px}

/* 9. Product cards
   ---------------------------------------------------------- */
.product-grid{display:grid;gap:24px;grid-template-columns:repeat(4,minmax(0,1fr))}
.compact-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.product-card{
    display:flex;flex-direction:column;
    background:var(--surface);
    border-radius:var(--r-lg);
    overflow:hidden;
    border:1px solid var(--line);
    box-shadow:var(--shadow-xs);
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
}
.product-card:hover{
    transform:translateY(-4px);
    box-shadow:var(--shadow);
    border-color:var(--ink-200);
}
.product-media{position:relative;display:block;overflow:hidden}
.product-media .product-image-frame img{transition:transform 700ms cubic-bezier(.2,.6,.2,1)}
.product-card:hover .product-image-frame img{transform:scale(1.05)}
.stock-pill{
    position:absolute;top:14px;left:14px;
    padding:6px 12px;border-radius:var(--r-pill);
    background:rgba(11,16,32,.85);color:#fff;
    font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
    backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.product-body{padding:20px}
.product-body small{
    color:var(--ink-400);text-transform:uppercase;
    letter-spacing:.14em;font-weight:700;font-size:11px;
}
.product-body h3{margin:10px 0 12px;font-size:20px;line-height:1.25}
.product-body h3 a{color:var(--ink-900)}
.product-body h3 a:hover{color:var(--primary)}
.price-row{display:flex;gap:10px;align-items:baseline}
.price-row strong{font-size:22px;color:var(--ink-900);font-weight:700;letter-spacing:-.01em}
.price-row span{text-decoration:line-through;color:var(--ink-400);font-size:14px}
.price-row.large strong{font-size:38px;font-family:var(--font-serif);font-weight:400}
.price-row.large span{font-size:18px}
.trust-row{margin:12px 0 18px;color:var(--primary);font-weight:700;font-size:13px;letter-spacing:.05em}
.trust-row span{margin-left:8px;color:var(--ink-500);font-weight:500;letter-spacing:0}
.product-actions{display:flex;flex-wrap:wrap;gap:10px}
.product-actions form{flex:1}
.product-actions button,.product-actions a{width:100%;padding:12px 16px;font-size:14px}


/* 10. External-image frame
   ---------------------------------------------------------- */
.external-image-frame{
    position:relative;overflow:hidden;
    border-radius:var(--r-md);
    background:linear-gradient(135deg,var(--warm),var(--accent-50));
}
.external-image-frame img{width:100%;height:100%;object-fit:cover}
.external-image-placeholder{
    position:absolute;inset:0;display:none;place-items:center;padding:20px;
    background:linear-gradient(135deg,var(--warm),var(--accent-50));
    color:var(--ink-700);text-align:center;font-weight:700;font-family:var(--font-serif);
}
.external-image-frame.is-broken .external-image-placeholder{display:grid}
.external-image-frame.is-broken img{display:none}

.hero-image-frame,.product-image-frame,.category-image-frame,
.main-gallery-frame,.thumb-frame,.cart-image-frame{
    aspect-ratio:1/1.15;
    overflow:hidden;border-radius:var(--r-md);
}
.product-image-frame,.category-image-frame{aspect-ratio:1/1.05}
.hero-image-frame img,.product-image-frame img,.category-image-frame img,
.main-gallery-frame img,.thumb-frame img,.cart-image-frame img{
    width:100%;height:100%;object-fit:cover;
}

/* 11. Info / why-choose-us cards
   ---------------------------------------------------------- */
.why-grid{display:grid;gap:20px;grid-template-columns:repeat(3,minmax(0,1fr))}
.info-card{
    padding:32px;background:var(--surface);
    border-radius:var(--r-lg);border:1px solid var(--line);
    box-shadow:var(--shadow-xs);
    transition:transform var(--t-base),box-shadow var(--t-base);
    position:relative;
}
.info-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.info-card strong{
    display:block;font-family:var(--font-serif);
    font-size:24px;color:var(--ink-900);font-weight:400;
    line-height:1.2;margin-bottom:10px;
}
.info-card p{margin:0;color:var(--ink-500);font-size:15px;line-height:1.6}

/* 12. Page intro (shop, etc.)
   ---------------------------------------------------------- */
.page-intro{padding:24px 0 28px;border-bottom:1px solid var(--line);margin-bottom:32px}
.page-intro h1{margin:0 0 10px}
.page-intro p{margin:0;color:var(--ink-500);font-size:17px;max-width:62ch}

/* 13. Shop layout / filters
   ---------------------------------------------------------- */
.shop-layout{display:grid;grid-template-columns:280px 1fr;gap:32px;align-items:start}
.shop-filters{
    display:grid;gap:18px;
    position:sticky;top:170px;
    padding:24px;background:var(--surface);
    border-radius:var(--r-lg);border:1px solid var(--line);
    box-shadow:var(--shadow-xs);
    height:max-content;
}
.shop-filters > button[type=submit]{margin-top:6px;background:var(--primary)}
.shop-filters > button[type=submit]:hover{background:var(--primary-600)}

.field,.field-inline{display:grid;gap:8px}
.field-inline,.grid-two{grid-template-columns:repeat(2,minmax(0,1fr));display:grid;gap:14px}
.field label{
    font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
    color:var(--ink-500);
}
.field input,.field select,.field textarea,
.stack-form input,.stack-form select,.stack-form textarea,
.admin-form-grid input,.admin-form-grid select,.admin-form-grid textarea,
.support-panel input,.support-panel textarea{
    width:100%;padding:13px 16px;
    border-radius:var(--r-md);
    border:1px solid var(--ink-200);
    background:#fff;color:var(--ink-900);
    transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
    outline:none;
}
.field input:focus,.field select:focus,.field textarea:focus,
.stack-form input:focus,.stack-form select:focus,.stack-form textarea:focus,
.admin-form-grid input:focus,.admin-form-grid select:focus,.admin-form-grid textarea:focus,
.support-panel input:focus,.support-panel textarea:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px var(--primary-50);
}

/* 14. Pagination
   ---------------------------------------------------------- */
.pagination-wrap{margin-top:36px;display:flex;justify-content:center}
.custom-pagination{display:flex;gap:6px;flex-wrap:wrap}
.page-link{
    padding:10px 14px;min-width:42px;text-align:center;
    border-radius:var(--r-md);background:#fff;
    border:1px solid var(--ink-200);font-weight:600;font-size:14px;color:var(--ink-700);
    transition:all var(--t-fast);
}
.page-link:hover{border-color:var(--ink-400);color:var(--ink-900)}
.page-link.current{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.page-link.disabled{opacity:.4;pointer-events:none}

/* 15. Product detail
   ---------------------------------------------------------- */
.product-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:start}
.gallery-card{padding:28px}
.main-gallery-image{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line)}
.thumb-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:14px}
.thumb-frame{border-radius:var(--r-sm);border:1px solid var(--line);cursor:zoom-in;transition:border-color var(--t-fast)}
.thumb-frame:hover{border-color:var(--primary)}
.description-card{margin-top:28px;padding-top:28px;border-top:1px solid var(--line)}
.description-card h2{margin:0 0 14px;font-size:24px}
.description-card p{color:var(--ink-600);line-height:1.75}

.buy-card{position:sticky;top:170px;height:max-content;padding:32px}
.buy-card small{color:var(--ink-400);text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-size:11px}
.buy-card h1{margin:10px 0 18px;font-size:clamp(28px,3vw,40px)}
.buy-card .price-row{margin-bottom:8px}
.buy-card form{margin-top:20px;display:grid;gap:12px}
.buy-card form button[type=submit]{background:var(--primary);padding:16px 22px;font-size:15px}
.buy-card form button[type=submit]:hover{background:var(--primary-600)}
.buy-note{
    margin-top:18px;padding:14px 16px;
    background:var(--ink-50);border-radius:var(--r-md);
    color:var(--ink-600);font-size:13px;border:1px solid var(--line);
}
.spec-list{
    margin:18px 0;padding:18px 22px;
    background:var(--surface-2);border-radius:var(--r-md);
    list-style:none;display:grid;gap:8px;
}
.spec-list li{
    display:flex;justify-content:space-between;gap:12px;
    padding:6px 0;color:var(--ink-700);font-size:14px;
    border-bottom:1px dashed var(--line);
}
.spec-list li:last-child{border-bottom:0}

/* 16. Cart
   ---------------------------------------------------------- */
.cart-layout{display:grid;grid-template-columns:1.3fr .7fr;gap:32px;align-items:start}
.cart-list{display:grid;gap:14px}
.cart-item{
    display:grid;grid-template-columns:120px 1fr auto;gap:22px;align-items:center;
    padding:20px;
}
.cart-item h3{margin:0 0 6px;font-size:18px}
.cart-image-frame{width:120px;height:120px;border-radius:var(--r-md)}
.cart-controls{display:grid;gap:10px;justify-items:end}
.cart-controls input{width:88px;padding:10px;border:1px solid var(--ink-200);border-radius:var(--r-sm);text-align:center}
.cart-controls button{padding:10px 14px;font-size:13px}
.link-danger{background:#fff;color:#b91c1c;border:1px solid #fecaca;box-shadow:none}
.link-danger:hover{background:#fef2f2;color:#991b1b;border-color:#fca5a5}


/* 17. Summary card / checkout
   ---------------------------------------------------------- */
.summary-card{padding:28px;position:sticky;top:170px;height:max-content}
.summary-card h2{margin:0 0 18px;font-size:24px}
.summary-card dl{display:grid;gap:10px;margin:18px 0}
.summary-card dl div,.summary-line,.line-row{
    display:flex;justify-content:space-between;gap:16px;align-items:start;
    padding:10px 0;border-bottom:1px dashed var(--line);
    color:var(--ink-700);font-size:14px;
}
.summary-card dl div:last-child,.summary-line:last-child{border-bottom:0}
.summary-card dt{color:var(--ink-500);font-weight:500}
.summary-card dd{margin:0;color:var(--ink-900);font-weight:700}
.summary-cta{width:100%;margin-top:16px;padding:16px 22px;font-size:15px}

.checkout-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:start}
.checkout-form{display:grid;gap:20px}
.form-card{padding:32px}
.form-card h1{margin:0 0 22px;font-size:clamp(28px,3.2vw,40px)}
.form-card h2{margin:0 0 18px;font-size:22px}
.section-inline{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}
.check-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--ink-600)}
.payment-note{
    margin-top:14px;padding:14px 18px;border-radius:var(--r-md);
    background:var(--accent-50);color:#7a1f44;
    border:1px solid color-mix(in srgb,var(--accent) 40%,transparent);
    font-size:13px;
}
.place-order{width:100%;padding:18px 24px;font-size:16px;background:var(--primary)}
.place-order:hover{background:var(--primary-600)}
.narrow{width:min(540px,92vw);margin:0 auto}

/* 18. Account / orders
   ---------------------------------------------------------- */
.account-layout{display:grid;grid-template-columns:.8fr 1.2fr;gap:32px;align-items:start}
.order-list{display:grid;gap:12px}
.order-card{
    display:flex;justify-content:space-between;align-items:center;gap:16px;
    padding:18px 20px;background:var(--surface);
    border-radius:var(--r-md);border:1px solid var(--line);
}
.order-card strong{display:block;color:var(--ink-900);font-size:15px}
.order-card p{margin:4px 0 0;color:var(--ink-500);font-size:13px}
.order-card a{
    padding:10px 14px;border-radius:var(--r-pill);
    background:var(--ink-50);font-size:13px;font-weight:600;color:var(--ink-700);
    border:1px solid var(--ink-200);
}
.order-card a:hover{background:var(--ink-100);color:var(--ink-900)}

.empty-card{text-align:center;padding:48px 32px;color:var(--ink-500)}

/* 19. Footer
   ---------------------------------------------------------- */
.site-footer{
    margin-top:96px;
    padding:72px 0 40px;
    background:var(--ink-900);
    color:#e6e9f1;
    position:relative;
}
.site-footer::before{
    content:"";position:absolute;left:0;right:0;top:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
}
.footer-grid{
    display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
    padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
}
.site-footer h2{
    color:#fff;font-size:30px;margin:0 0 14px;font-weight:400;
}
.site-footer h3{
    color:#fff;font-size:13px;font-family:var(--font-sans);
    text-transform:uppercase;letter-spacing:.18em;font-weight:700;margin:0 0 18px;
}
.site-footer p,.site-footer a{
    display:block;margin:0 0 10px;
    color:#a8afc1;font-size:14px;line-height:1.6;
}
.site-footer a{transition:color var(--t-fast)}
.site-footer a:hover{color:var(--accent)}

/* 20. Support widget + back to top
   ---------------------------------------------------------- */
.support-widget{position:fixed;right:24px;bottom:24px;z-index:35}
.support-toggle{
    padding:14px 22px;border-radius:var(--r-pill);border:0;
    background:var(--primary);color:#fff;font-weight:700;
    box-shadow:var(--shadow);
    transition:transform var(--t-fast),background var(--t-base);
}
.support-toggle:hover{transform:translateY(-2px);background:var(--primary-600)}
.support-panel{
    position:absolute;right:0;bottom:64px;display:none;
    width:min(360px,90vw);padding:22px;
    background:#fff;border-radius:var(--r-lg);
    box-shadow:var(--shadow-lg);border:1px solid var(--line);
    gap:12px;
}
.support-widget.open .support-panel{display:grid}
.support-panel h3{margin:0 0 6px;font-size:18px}
.support-panel button{margin-top:6px}

.back-to-top{
    position:fixed;left:24px;bottom:24px;z-index:35;
    border:1px solid var(--line);
    background:#fff;padding:12px 18px;
    border-radius:var(--r-pill);
    box-shadow:var(--shadow-sm);
    font-weight:700;font-size:13px;color:var(--ink-700);
    transition:transform var(--t-fast),box-shadow var(--t-fast);
}
.back-to-top:hover{transform:translateY(-2px);box-shadow:var(--shadow);color:var(--ink-900)}

/* 21. Modal
   ---------------------------------------------------------- */
.modal{
    position:fixed;inset:0;background:rgba(11,16,32,.55);
    display:none;place-items:center;padding:20px;z-index:80;
    backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.modal.show{display:grid;animation:modal-in .3s var(--t-base)}
@keyframes modal-in{from{opacity:0}to{opacity:1}}
.modal-card{
    background:#fff;padding:36px;border-radius:var(--r-xl);
    max-width:520px;box-shadow:var(--shadow-lg);
    border:1px solid var(--line);
    animation:modal-pop .35s var(--t-base);
}
@keyframes modal-pop{from{transform:scale(.96);opacity:0}to{transform:none;opacity:1}}
.modal-card h2{margin:0 0 12px;font-size:26px}
.modal-card p{color:var(--ink-600);margin-bottom:24px}

/* 22. Mobile filter toggle
   ---------------------------------------------------------- */
.mobile-filter-toggle{display:none;margin:0 0 18px;padding:12px 18px;font-size:14px;background:var(--ink-900)}


/* 23. Testimonials (homepage)
   ---------------------------------------------------------- */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.testimonial-card{
    padding:32px;background:var(--surface);
    border-radius:var(--r-lg);border:1px solid var(--line);
    box-shadow:var(--shadow-xs);
    display:grid;gap:18px;
    transition:transform var(--t-base),box-shadow var(--t-base);
    position:relative;
}
.testimonial-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.testimonial-card::before{
    content:"\201C";position:absolute;top:18px;right:24px;
    font-family:var(--font-serif);font-size:80px;line-height:1;
    color:var(--accent);opacity:.35;pointer-events:none;
}
.testimonial-card p{
    margin:0;font-family:var(--font-serif);font-size:20px;line-height:1.4;
    color:var(--ink-800);font-weight:400;
}
.testimonial-meta{display:flex;align-items:center;gap:12px}
.testimonial-avatar{
    width:44px;height:44px;border-radius:50%;flex-shrink:0;
    background:linear-gradient(140deg,var(--accent),var(--primary));
    display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;
}
.testimonial-meta strong{display:block;color:var(--ink-900);font-size:14px}
.testimonial-meta span{display:block;color:var(--ink-500);font-size:12px;letter-spacing:.05em}

/* 24. Newsletter / CTA strip
   ---------------------------------------------------------- */
.cta-strip{
    margin-top:32px;
    padding:56px 48px;
    border-radius:var(--r-xl);
    background:
        radial-gradient(700px 300px at 100% 0%,rgba(255,255,255,.08),transparent 60%),
        linear-gradient(135deg,var(--ink-900),var(--ink-700));
    color:#fff;
    display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:center;
    box-shadow:var(--shadow);
    position:relative;overflow:hidden;
}
.cta-strip::after{
    content:"";position:absolute;left:-80px;bottom:-80px;width:240px;height:240px;
    border-radius:50%;background:radial-gradient(closest-side,var(--primary),transparent 70%);
    opacity:.35;pointer-events:none;
}
.cta-strip h2{color:#fff;margin:0 0 10px;font-size:clamp(28px,3vw,40px)}
.cta-strip p{color:rgba(255,255,255,.75);margin:0;font-size:16px}
.cta-strip .eyebrow{color:var(--accent)}
.cta-strip .cta-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}
.cta-strip .cta-actions a{
    padding:14px 24px;border-radius:var(--r-pill);
    font-weight:700;font-size:14px;
    background:#fff;color:var(--ink-900);
    border:1px solid rgba(255,255,255,.3);
    transition:transform var(--t-fast),background var(--t-base);
}
.cta-strip .cta-actions a.alt{background:transparent;color:#fff}
.cta-strip .cta-actions a:hover{transform:translateY(-2px)}
.cta-strip .cta-actions a.alt:hover{background:rgba(255,255,255,.08)}

/* 25. Admin console
   ---------------------------------------------------------- */
.admin-body{
    background:#f4f5f9;
    color:var(--ink-800);
    font-family:var(--font-sans);
    -webkit-font-smoothing:antialiased;
}
.admin-shell{
    --admin-sidebar-w:264px;
    display:grid;grid-template-columns:var(--admin-sidebar-w) 1fr;
    min-height:100vh;
}

/* Sidebar */
.admin-sidebar{
    background:#fff;
    border-right:1px solid var(--ink-200);
    display:flex;flex-direction:column;
    position:sticky;top:0;height:100vh;
    z-index:60;
}
.admin-sidebar-head{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:22px 22px 18px;
    border-bottom:1px solid var(--ink-100);
}
.admin-brand{display:flex;align-items:center;gap:12px;color:var(--ink-900);text-decoration:none}
.admin-brand-mark{
    width:38px;height:38px;border-radius:11px;
    background:linear-gradient(140deg,var(--ink-900),var(--ink-700));
    color:#fff;display:grid;place-items:center;
    font-family:var(--font-serif);font-size:16px;letter-spacing:.02em;
    box-shadow:0 4px 10px rgba(11,16,32,.18);
}
.admin-brand-copy{display:grid;line-height:1.15}
.admin-brand-copy strong{font-size:15px;color:var(--ink-900);font-weight:700}
.admin-brand-copy small{font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.14em;margin-top:2px}
.admin-drawer-close{
    display:none;background:transparent;border:0;color:var(--ink-600);
    width:36px;height:36px;border-radius:10px;cursor:pointer;
    align-items:center;justify-content:center;
}
.admin-drawer-close:hover{background:var(--ink-100);color:var(--ink-900)}

.admin-nav{
    flex:1;overflow-y:auto;
    padding:18px 14px 14px;
    display:flex;flex-direction:column;gap:18px;
}
.admin-nav-group{display:flex;flex-direction:column;gap:2px}
.admin-nav-label{
    padding:6px 12px;
    font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
    color:var(--ink-400);
}
.admin-nav-link{
    display:flex;align-items:center;gap:11px;
    padding:10px 12px;border-radius:10px;
    color:var(--ink-600);font-size:14px;font-weight:500;
    text-decoration:none;
    transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast);
}
.admin-nav-link:hover{background:var(--ink-50);color:var(--ink-900)}
.admin-nav-link .admin-nav-icon{flex-shrink:0;color:var(--ink-400);transition:color var(--t-fast)}
.admin-nav-link:hover .admin-nav-icon{color:var(--ink-700)}
.admin-nav-link.is-active{
    background:var(--ink-900);color:#fff;
    box-shadow:0 6px 14px rgba(11,16,32,.22);
}
.admin-nav-link.is-active .admin-nav-icon{color:#fff}

.admin-sidebar-foot{
    border-top:1px solid var(--ink-100);
    padding:16px;display:flex;flex-direction:column;gap:12px;
}
.admin-user-card{
    display:flex;align-items:center;gap:12px;
    padding:10px 12px;border-radius:12px;
    background:var(--ink-50);
}
.admin-user-avatar{
    width:36px;height:36px;border-radius:50%;
    background:linear-gradient(140deg,var(--primary),var(--accent));
    color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0;
}
.admin-user-meta{display:grid;line-height:1.2;min-width:0}
.admin-user-meta strong{font-size:13px;color:var(--ink-900);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-user-meta small{font-size:11px;color:var(--ink-500);margin-top:2px}
.admin-logout button{
    width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;
    padding:10px 14px;border-radius:10px;
    background:transparent;color:var(--ink-700);
    border:1px solid var(--ink-200);box-shadow:none;
    font-size:13px;font-weight:600;cursor:pointer;
    transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.admin-logout button:hover{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}

.admin-drawer-backdrop{
    display:none;position:fixed;inset:0;background:rgba(11,16,32,.45);
    z-index:55;border:0;cursor:pointer;backdrop-filter:blur(2px);
}

/* Main column */
.admin-main{
    min-width:0;
    display:flex;flex-direction:column;
    background:#f4f5f9;
}
.admin-topbar{
    position:sticky;top:0;z-index:40;
    display:flex;align-items:center;gap:16px;
    padding:18px 28px;
    background:rgba(255,255,255,.92);
    backdrop-filter:saturate(150%) blur(10px);
    -webkit-backdrop-filter:saturate(150%) blur(10px);
    border-bottom:1px solid var(--ink-100);
}
.admin-menu-toggle{
    display:none;background:#fff;border:1px solid var(--ink-200);
    width:40px;height:40px;border-radius:11px;
    color:var(--ink-700);cursor:pointer;
    align-items:center;justify-content:center;
    box-shadow:var(--shadow-xs);
}
.admin-menu-toggle:hover{background:var(--ink-50);color:var(--ink-900)}
.admin-topbar-title{flex:1;min-width:0;display:grid;line-height:1.2}
.admin-topbar-title small{
    font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
    color:var(--ink-400);
}
.admin-topbar-title h1{
    margin:2px 0 0;font-family:var(--font-serif);
    font-size:clamp(20px,2.4vw,26px);font-weight:400;color:var(--ink-900);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.admin-topbar-actions{display:flex;align-items:center;gap:12px}
.admin-topbar-link{
    display:inline-flex;align-items:center;gap:8px;
    padding:9px 14px;border-radius:10px;
    background:var(--ink-50);color:var(--ink-700);
    border:1px solid var(--ink-200);
    font-size:13px;font-weight:600;text-decoration:none;
    transition:background var(--t-fast),color var(--t-fast);
}
.admin-topbar-link:hover{background:var(--ink-900);color:#fff;border-color:var(--ink-900)}
.admin-topbar-user{
    width:38px;height:38px;border-radius:50%;
    background:linear-gradient(140deg,var(--primary),var(--accent));
    color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;
    box-shadow:var(--shadow-xs);
}
.admin-content{padding:28px;max-width:1400px;width:100%;margin:0 auto}

/* Sections, cards, stats */
.admin-section{display:grid;gap:22px}
.stats-grid{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}
.stat-card{
    position:relative;
    padding:22px;background:#fff;
    border-radius:16px;border:1px solid var(--ink-100);
    box-shadow:0 1px 0 rgba(11,16,32,.02),0 8px 22px -18px rgba(11,16,32,.18);
    transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
    overflow:hidden;
}
.stat-card::after{
    content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
    background:linear-gradient(180deg,var(--primary),var(--accent));
    opacity:.0;transition:opacity var(--t-base);
}
.stat-card:hover{transform:translateY(-2px);border-color:var(--ink-200);box-shadow:0 1px 0 rgba(11,16,32,.02),0 14px 30px -16px rgba(11,16,32,.22)}
.stat-card:hover::after{opacity:1}
.stat-card span{
    display:block;color:var(--ink-500);
    text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:700;
}
.stat-card strong{
    display:block;margin-top:10px;
    font-family:var(--font-serif);font-weight:400;
    font-size:clamp(26px,2.6vw,34px);
    color:var(--ink-900);overflow-wrap:anywhere;line-height:1.1;
}
.admin-grid-two{display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-card{
    padding:24px;background:#fff;
    border-radius:16px;border:1px solid var(--ink-100);
    box-shadow:0 1px 0 rgba(11,16,32,.02),0 8px 22px -18px rgba(11,16,32,.18);
}
.admin-card h1,.admin-card h2{margin:0 0 16px;font-family:var(--font-serif);font-weight:400;color:var(--ink-900)}
.admin-card h1{font-size:24px}
.admin-card h2{font-size:19px}
.admin-card .section-head{margin-bottom:16px;gap:12px;flex-wrap:wrap}
.admin-card .section-head h1,.admin-card .section-head h2{margin:0}
.admin-card .section-head form{display:flex;gap:8px;flex:1;max-width:320px}
.admin-card .section-head input{margin:0;padding:10px 14px;font-size:13px}

.line-row{
    display:flex;justify-content:space-between;gap:16px;align-items:center;
    padding:14px 0;border-bottom:1px solid var(--ink-100);font-size:14px;color:var(--ink-700);
}
.line-row:last-child{border-bottom:0}
.line-row strong{color:var(--ink-900);font-weight:600;text-align:right;flex-shrink:0}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--ink-100);background:#fff;-webkit-overflow-scrolling:touch}
.admin-card .table-wrap{margin:0 -4px}
table{width:100%;border-collapse:collapse;background:#fff}
th,td{padding:14px 16px;border-bottom:1px solid var(--ink-100);text-align:left;vertical-align:middle;font-size:14px;color:var(--ink-700)}
th{font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-500);font-weight:700;background:var(--ink-50);position:sticky;top:0}
tr:last-child td{border-bottom:0}
tbody tr{transition:background var(--t-fast)}
tbody tr:hover{background:var(--ink-50)}
td a{color:var(--primary);font-weight:600;text-decoration:none}
td a:hover{text-decoration:underline}

.admin-detail{padding:14px 0;border-bottom:1px solid var(--ink-100)}
.admin-detail:last-child{border-bottom:0}
.admin-detail summary{
    cursor:pointer;font-weight:600;color:var(--ink-700);font-size:13px;
    padding:8px 12px;border-radius:8px;background:var(--ink-50);
    list-style:none;display:inline-flex;align-items:center;gap:6px;
}
.admin-detail summary::-webkit-details-marker{display:none}
.admin-detail summary::before{content:"›";font-size:16px;transition:transform var(--t-fast);display:inline-block}
.admin-detail[open] summary{background:var(--ink-900);color:#fff}
.admin-detail[open] summary::before{transform:rotate(90deg)}
.admin-detail[open]{padding-bottom:18px}
.admin-detail .admin-form-grid{margin-top:14px}

/* Login */
.admin-login-body{display:grid;place-items:center;min-height:100vh;
    background:radial-gradient(800px 400px at 30% 20%,var(--cream),var(--bg));
    font-family:var(--font-sans);
}
.admin-login{width:min(460px,92vw);padding:36px}
.admin-login h1{font-size:30px;margin-bottom:18px;font-family:var(--font-serif);font-weight:400}

/* Forms */
.stack-form,.admin-form-grid{display:grid;gap:14px}
.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.admin-form-grid > .field-full,
.admin-form-grid > textarea,
.admin-form-grid > label{grid-column:1 / -1}
.admin-form-grid label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-700);font-weight:500}
.admin-form-grid button{grid-column:1 / -1;justify-self:start;background:var(--ink-900);color:#fff;padding:12px 22px;border-radius:10px;font-weight:600;font-size:14px}
.admin-form-grid button:hover{background:var(--primary)}


/* 26. Responsive
   ---------------------------------------------------------- */
@media (max-width:1240px){
    .product-grid,.compact-grid,.category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
    .header-actions{gap:0}
    .header-actions .ha-stack > span{display:none}
    .header-actions .ha-link{padding:8px 10px}
    .top-grid{gap:18px}
}

@media (max-width:1080px){
    .top-grid{grid-template-columns:auto auto;row-gap:14px;justify-content:space-between}
    .search-bar{grid-column:1 / -1;order:3;max-width:none;justify-self:stretch}
    .header-actions{justify-self:end}
    .middle-grid{justify-content:stretch}
    .header-nav{justify-content:center;gap:24px;font-size:11px;letter-spacing:.16em}
    .hero-grid{grid-template-columns:1fr;gap:24px}
    .hero-copy{padding:36px}
    .hero-copy h1{font-size:clamp(34px,5vw,52px)}
    .hero-carousel{aspect-ratio:1.6/1}
    .shop-layout,.product-layout,.cart-layout,.checkout-layout,.account-layout{grid-template-columns:1fr}
    .shop-filters,.buy-card,.summary-card{position:static}
    .footer-grid{grid-template-columns:1fr 1fr}
    .admin-shell{grid-template-columns:1fr}
    .admin-sidebar{
        position:fixed;top:0;left:0;bottom:0;
        width:min(300px,86vw);height:100vh;
        transform:translateX(-100%);
        transition:transform var(--t-base);
        box-shadow:0 30px 60px -20px rgba(11,16,32,.35);
        border-right:1px solid var(--ink-100);
    }
    .admin-shell.drawer-open .admin-sidebar{transform:translateX(0)}
    .admin-shell.drawer-open .admin-drawer-backdrop{display:block}
    .admin-drawer-close{display:inline-flex}
    .admin-menu-toggle{display:inline-flex}
    .admin-grid-two{grid-template-columns:1fr}
    .admin-content{padding:22px}
    .admin-topbar{padding:14px 18px}
    .stats-grid,.why-grid,.testimonial-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .product-grid,.compact-grid,.category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
    .trust-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
    .cta-strip{grid-template-columns:1fr;padding:40px 32px}
    .cta-strip .cta-actions{justify-content:flex-start}
}

@media (max-width:780px){
    .container{width:min(100% - 24px,680px)}
    .header-row.top{padding:12px 0}
    .brand{gap:10px}
    .brand-mark{width:36px;height:36px;font-size:14px}
    .brand-copy strong{font-size:17px}
    .brand-copy small{display:none}
    .header-actions{gap:0}
    .header-actions .ha-link{padding:6px 8px;gap:0}
    .header-actions .ha-stack{display:none}
    .header-actions .cart-link .ha-stack{display:inline-grid;margin-left:6px}
    .header-actions .cart-link .ha-stack > span{display:none}
    .search-bar{display:none}
    .middle-grid{justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch}
    .middle-grid::-webkit-scrollbar{display:none}
    .header-nav{
        flex-wrap:nowrap;justify-content:flex-start;
        padding:12px 4px;gap:20px;
        font-size:10px;letter-spacing:.14em;
        white-space:nowrap;
    }
    .header-nav a{white-space:nowrap}
    .mobile-filter-toggle{display:inline-flex}
    .shop-filters{display:none}
    .shop-filters.open{display:grid}
    .product-grid,.compact-grid,.category-grid,.why-grid,.stats-grid,.testimonial-grid,.trust-strip{grid-template-columns:1fr}
    .grid-two,.field-inline,.thumb-grid{grid-template-columns:1fr}
    .hero-copy{padding:28px}
    .hero-copy h1,.page-intro h1,.buy-card h1,.form-card h1{font-size:34px}
    .hero-carousel{grid-template-columns:1fr;grid-template-rows:none;aspect-ratio:auto;gap:12px}
    .hero-slide:nth-child(n){grid-row:auto;grid-column:auto}
    .hero-slide{aspect-ratio:1.4/1}
    .hero-slide:nth-child(n+2){display:none}
    .footer-grid{grid-template-columns:1fr;gap:32px;text-align:left}
    .cart-item{grid-template-columns:1fr;text-align:center}
    .cart-image-frame{width:100%;height:auto;aspect-ratio:1/1;justify-self:center;max-width:240px}
    .cart-controls{justify-items:stretch}
    .section-inline{flex-direction:column;align-items:flex-start}
    .testimonial-card p{font-size:18px}
    .cta-strip{padding:32px 24px}
    .admin-form-grid{grid-template-columns:1fr}
    .admin-content{padding:16px}
    .admin-topbar{padding:12px 14px;gap:10px}
    .admin-topbar-link span{display:none}
    .admin-topbar-link{padding:9px 11px}
    .admin-topbar-user{width:34px;height:34px;font-size:13px}
    .admin-topbar-title h1{font-size:18px}
    .admin-topbar-title small{font-size:10px;letter-spacing:.14em}
    .admin-card{padding:18px;border-radius:14px}
    .admin-card h1{font-size:21px}
    .admin-card h2{font-size:17px}
    .stat-card{padding:18px;border-radius:14px}
    .stat-card strong{font-size:26px}
    .admin-card .section-head form{max-width:none}
    .admin-card .table-wrap th,.admin-card .table-wrap td{padding:11px 12px;font-size:13px}
    .order-card{flex-direction:column;align-items:flex-start;gap:10px}
    .support-widget{right:14px;bottom:14px}
    .back-to-top{left:14px;bottom:14px;padding:10px 14px}
    .modal-card{padding:28px}
    .section-head{flex-direction:column;align-items:flex-start;gap:8px}
}

@media (max-width:420px){
    h1{font-size:32px}
    .hero-copy h1{font-size:30px}
    .hero-copy{padding:24px}
    .form-card,.gallery-card,.buy-card,.summary-card,.admin-card,.admin-login{padding:22px}
    .info-card{padding:24px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
    .product-card:hover .product-image-frame img{transform:none}
    html{scroll-behavior:auto}
}


/* ============================================================
   27. Homepage Atelier Edition — fresh editorial components
   ============================================================ */

/* 27.1 Atelier hero — cinematic full-bleed
   ---------------------------------------------------------- */
.atelier-hero{
    position:relative;
    margin:0 0 8px;
    border-radius:var(--r-xl);
    overflow:hidden;
    isolation:isolate;
    background:var(--ink-900);
    min-height:clamp(520px,72vh,720px);
    display:grid;align-items:end;
    box-shadow:var(--shadow-lg);
}
.atelier-hero .ah-media{position:absolute;inset:0;z-index:0}
.atelier-hero .ah-media .external-image-frame{height:100%;border-radius:0}
.atelier-hero .ah-media img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.02)}
.atelier-hero .ah-veil{
    position:absolute;inset:0;z-index:1;pointer-events:none;
    background:
        radial-gradient(70% 60% at 20% 100%,rgba(11,16,32,.85),transparent 70%),
        linear-gradient(180deg,rgba(11,16,32,.15) 0%,rgba(11,16,32,.55) 60%,rgba(11,16,32,.9) 100%);
}
.atelier-hero .ah-content{
    position:relative;z-index:2;
    padding:clamp(32px,6vw,80px);
    color:#fff;
    max-width:780px;
    display:grid;gap:18px;
}
.atelier-hero .ah-content .eyebrow{color:var(--accent);margin:0}
.atelier-hero .ah-content h1{
    color:#fff;margin:0;
    font-size:clamp(44px,7vw,96px);
    line-height:1.0;letter-spacing:-.02em;
    text-wrap:balance;
}
.atelier-hero .ah-content h1 em{
    font-style:italic;color:var(--accent);font-weight:400;
}
.atelier-hero .ah-content p{
    color:rgba(255,255,255,.82);
    font-size:clamp(15px,1.4vw,18px);
    max-width:56ch;margin:0;
}
.atelier-hero .ah-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.atelier-hero .ah-actions a{
    padding:16px 28px;border-radius:var(--r-pill);
    font-weight:700;font-size:14px;letter-spacing:.04em;
    background:#fff;color:var(--ink-900);
    border:1px solid rgba(255,255,255,.25);
    transition:transform var(--t-fast),background var(--t-base);
}
.atelier-hero .ah-actions a.ghost{background:transparent;color:#fff}
.atelier-hero .ah-actions a:hover{transform:translateY(-2px)}
.atelier-hero .ah-actions a.ghost:hover{background:rgba(255,255,255,.08)}
.atelier-hero .ah-meta{
    position:absolute;top:clamp(24px,4vw,48px);right:clamp(24px,4vw,48px);
    z-index:2;color:rgba(255,255,255,.7);font-size:12px;letter-spacing:.18em;
    text-transform:uppercase;font-weight:700;
    display:flex;gap:24px;align-items:center;
}
.atelier-hero .ah-meta::before{
    content:"";display:inline-block;width:42px;height:1px;background:var(--accent);
}
.atelier-hero .ah-scroll{
    position:absolute;bottom:24px;right:clamp(24px,4vw,48px);z-index:2;
    color:rgba(255,255,255,.7);font-size:11px;letter-spacing:.22em;
    text-transform:uppercase;font-weight:700;
    display:flex;align-items:center;gap:10px;
    writing-mode:vertical-rl;transform:rotate(180deg);
}
.atelier-hero .ah-scroll::after{
    content:"";width:1px;height:36px;background:rgba(255,255,255,.45);
    animation:ah-scroll-pulse 2s ease-in-out infinite;
}
@keyframes ah-scroll-pulse{0%,100%{opacity:.3;height:24px}50%{opacity:1;height:48px}}

/* 27.2 Marquee credentials strip
   ---------------------------------------------------------- */
.marquee{
    margin:48px 0 0;
    padding:18px 0;
    background:var(--ink-900);
    color:#fff;
    border-radius:var(--r-md);
    overflow:hidden;
    position:relative;
    -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
            mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee-track{
    display:flex;gap:56px;width:max-content;
    animation:marquee-scroll 38s linear infinite;
    will-change:transform;
}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-item{
    display:inline-flex;align-items:center;gap:18px;
    font-family:var(--font-serif);font-size:22px;letter-spacing:.01em;
    white-space:nowrap;
}
.marquee-item span{color:var(--accent);font-size:14px}
@keyframes marquee-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}


/* 27.3 Spotlight — magazine 50/50 featured product
   ---------------------------------------------------------- */
.spotlight{
    margin-top:64px;
    display:grid;grid-template-columns:1.05fr 1fr;gap:0;
    border-radius:var(--r-xl);overflow:hidden;
    background:var(--surface);border:1px solid var(--line);
    box-shadow:var(--shadow);
    min-height:560px;
}
.spotlight .sp-media{position:relative;background:var(--surface-2);overflow:hidden}
.spotlight .sp-media .external-image-frame{height:100%;border-radius:0}
.spotlight .sp-media img{width:100%;height:100%;object-fit:cover}
.spotlight .sp-tag{
    position:absolute;top:24px;left:24px;z-index:2;
    padding:8px 14px;border-radius:var(--r-pill);
    background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
    color:var(--ink-900);font-size:11px;font-weight:800;
    letter-spacing:.18em;text-transform:uppercase;
}
.spotlight .sp-serial{
    position:absolute;bottom:24px;left:24px;z-index:2;
    color:#fff;font-family:var(--font-serif);font-size:42px;line-height:1;
    text-shadow:0 2px 18px rgba(0,0,0,.4);
    letter-spacing:.04em;
}
.spotlight .sp-body{
    padding:clamp(36px,4.5vw,64px);
    display:grid;align-content:center;gap:18px;
}
.spotlight .sp-body .eyebrow{margin:0}
.spotlight .sp-body h2{
    margin:0;font-size:clamp(34px,4vw,56px);line-height:1.05;
}
.spotlight .sp-body h2 a{color:var(--ink-900)}
.spotlight .sp-body h2 a:hover{color:var(--primary)}
.spotlight .sp-body p{margin:0;color:var(--ink-600);font-size:16px;max-width:52ch}
.spotlight .sp-specs{
    display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px 24px;margin:8px 0 4px;padding:18px 0;
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.spotlight .sp-specs > div{display:grid;gap:2px}
.spotlight .sp-specs span{font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--ink-400);font-weight:700}
.spotlight .sp-specs strong{font-size:14px;color:var(--ink-900);font-weight:600}
.spotlight .sp-foot{display:flex;flex-wrap:wrap;align-items:center;gap:18px;margin-top:6px}
.spotlight .sp-foot .price-row strong{font-family:var(--font-serif);font-size:38px;font-weight:400}
.spotlight .sp-foot a.cta{
    margin-left:auto;
    padding:14px 28px;border-radius:var(--r-pill);
    background:var(--ink-900);color:#fff;font-weight:700;font-size:14px;
    transition:background var(--t-base),transform var(--t-fast);
}
.spotlight .sp-foot a.cta:hover{background:var(--primary);transform:translateY(-2px);color:#fff}

/* 27.4 Collection tabs
   ---------------------------------------------------------- */
.collection-tabs{margin-top:64px}
.collection-tabs .ct-head{
    display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;
    margin-bottom:28px;padding-bottom:18px;border-bottom:1px solid var(--line);
}
.collection-tabs .ct-head h2{margin:0;font-size:clamp(28px,3.4vw,44px)}
.collection-tabs .ct-nav{display:flex;flex-wrap:wrap;gap:6px}
.collection-tabs .ct-nav button{
    padding:10px 18px;border-radius:var(--r-pill);
    background:transparent;color:var(--ink-500);
    border:1px solid transparent;
    font-size:13px;font-weight:600;letter-spacing:.04em;
    transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);
}
.collection-tabs .ct-nav button:hover{color:var(--ink-900)}
.collection-tabs .ct-nav button.is-active{
    background:var(--ink-900);color:#fff;border-color:var(--ink-900);
}
.collection-tabs .ct-panel{display:none}
.collection-tabs .ct-panel.is-active{display:block;animation:ct-fade .35s ease-out}
@keyframes ct-fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* 27.5 Magazine category grid
   ---------------------------------------------------------- */
.magazine-grid{
    margin-top:64px;
    display:grid;gap:18px;
    grid-template-columns:repeat(4,minmax(0,1fr));
    grid-auto-rows:240px;
}
.mg-card{
    position:relative;overflow:hidden;
    border-radius:var(--r-lg);
    background:var(--ink-800);color:#fff;
    isolation:isolate;
    transition:transform var(--t-base),box-shadow var(--t-base);
    box-shadow:var(--shadow-sm);
}
.mg-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.mg-card .external-image-frame{position:absolute;inset:0;height:100%;border-radius:0;z-index:0}
.mg-card .external-image-frame img{width:100%;height:100%;object-fit:cover;
    transition:transform 800ms cubic-bezier(.2,.6,.2,1);filter:brightness(.85)}
.mg-card:hover .external-image-frame img{transform:scale(1.06)}
.mg-card::after{
    content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(180deg,transparent 30%,rgba(11,16,32,.78) 100%);
}
.mg-card .mg-body{
    position:relative;z-index:2;height:100%;
    display:grid;align-content:end;padding:22px;gap:6px;
}
.mg-card .mg-body small{
    text-transform:uppercase;letter-spacing:.16em;font-weight:700;font-size:11px;
    color:var(--accent);
}
.mg-card .mg-body h3{margin:0;color:#fff;font-size:24px;line-height:1.15}
.mg-card .mg-body span.arrow{
    margin-top:8px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
    color:rgba(255,255,255,.85);display:inline-flex;align-items:center;gap:8px;
}
.mg-card .mg-body span.arrow::after{content:"\2192";transition:transform var(--t-fast)}
.mg-card:hover .mg-body span.arrow::after{transform:translateX(4px)}
.mg-card.feature{grid-column:span 2;grid-row:span 2}
.mg-card.feature .mg-body h3{font-size:36px;font-family:var(--font-serif);line-height:1.05}
.mg-card.tall{grid-row:span 2}

/* 27.6 Story block — atelier narrative
   ---------------------------------------------------------- */
.story-block{
    margin-top:80px;
    display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:center;
}
.story-block .sb-media{
    position:relative;
    border-radius:var(--r-xl);overflow:hidden;
    aspect-ratio:4/5;
    box-shadow:var(--shadow);
}
.story-block .sb-media .external-image-frame{height:100%;border-radius:0}
.story-block .sb-media img{width:100%;height:100%;object-fit:cover}
.story-block .sb-media .sb-stamp{
    position:absolute;left:24px;bottom:24px;
    padding:10px 16px;border-radius:var(--r-pill);
    background:rgba(255,255,255,.92);backdrop-filter:blur(8px);
    color:var(--ink-900);font-size:11px;font-weight:800;
    letter-spacing:.18em;text-transform:uppercase;
}
.story-block .sb-body{display:grid;gap:18px;max-width:60ch}
.story-block .sb-body h2{
    margin:0;font-size:clamp(34px,4vw,56px);line-height:1.05;
}
.story-block .sb-body h2 em{font-style:italic;color:var(--primary);font-weight:400}
.story-block .sb-body p{margin:0;color:var(--ink-600);font-size:16px;line-height:1.7}
.story-block .sb-body p.lead{
    font-family:var(--font-serif);font-size:22px;line-height:1.4;color:var(--ink-800);
}
.story-block .sb-sign{
    margin-top:8px;display:flex;align-items:center;gap:14px;
    padding-top:18px;border-top:1px solid var(--line);
}
.story-block .sb-sign strong{
    font-family:var(--font-serif);font-size:24px;color:var(--ink-900);font-weight:400;
}
.story-block .sb-sign small{
    color:var(--ink-500);font-size:12px;letter-spacing:.14em;
    text-transform:uppercase;font-weight:700;
}

/* 27.7 Process timeline
   ---------------------------------------------------------- */
.process{margin-top:80px;padding:56px 0;background:var(--surface);
    border-radius:var(--r-xl);border:1px solid var(--line);box-shadow:var(--shadow-xs)}
.process .pr-head{padding:0 clamp(28px,4vw,56px);margin-bottom:36px;max-width:760px}
.process .pr-head h2{margin:0;font-size:clamp(28px,3.4vw,44px)}
.process .pr-head p{margin:10px 0 0;color:var(--ink-600);font-size:16px}
.process .pr-grid{
    padding:0 clamp(28px,4vw,56px);
    display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:32px;
    counter-reset:pr;
}
.process .pr-step{
    position:relative;padding-top:18px;
    border-top:1px solid var(--line);
}
.process .pr-step::before{
    counter-increment:pr;
    content:"0" counter(pr);
    position:absolute;top:-22px;left:0;
    font-family:var(--font-serif);font-size:48px;line-height:1;
    color:var(--primary);font-weight:400;
}
.process .pr-step h3{margin:24px 0 10px;font-size:20px;color:var(--ink-900)}
.process .pr-step p{margin:0;font-size:14px;color:var(--ink-600);line-height:1.6}

/* 27.8 Testimonial spotlight (single quote)
   ---------------------------------------------------------- */
.t-spotlight{
    margin-top:80px;padding:64px clamp(28px,5vw,72px);
    background:
        radial-gradient(800px 320px at 12% 0%,var(--accent-50),transparent 70%),
        var(--surface);
    border-radius:var(--r-xl);border:1px solid var(--line);
    text-align:center;position:relative;overflow:hidden;
}
.t-spotlight::before{
    content:"\201C";position:absolute;top:24px;left:50%;transform:translateX(-50%);
    font-family:var(--font-serif);font-size:160px;line-height:1;
    color:var(--accent);opacity:.25;pointer-events:none;
}
.t-spotlight blockquote{
    margin:0 auto;max-width:780px;
    font-family:var(--font-serif);font-size:clamp(22px,2.6vw,34px);
    line-height:1.35;color:var(--ink-900);font-weight:400;
    position:relative;z-index:1;
}
.t-spotlight cite{
    display:flex;justify-content:center;align-items:center;gap:14px;
    margin-top:28px;font-style:normal;
}
.t-spotlight cite .ts-avatar{
    width:48px;height:48px;border-radius:50%;
    background:linear-gradient(140deg,var(--accent),var(--primary));
    display:grid;place-items:center;color:#fff;font-weight:700;font-size:16px;
}
.t-spotlight cite strong{display:block;color:var(--ink-900);font-size:14px;font-weight:700}
.t-spotlight cite span{display:block;color:var(--ink-500);font-size:12px;letter-spacing:.06em}
.t-spotlight cite > div{text-align:left}

/* 27.9 Press strip
   ---------------------------------------------------------- */
.press-strip{
    margin-top:64px;padding:32px clamp(20px,3vw,40px);
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center;
}
.press-strip .ps-label{
    font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:800;
    color:var(--ink-500);
}
.press-strip .ps-logos{
    display:flex;flex-wrap:wrap;justify-content:space-between;gap:32px;
}
.press-strip .ps-logos span{
    font-family:var(--font-serif);font-size:22px;color:var(--ink-700);
    letter-spacing:.02em;opacity:.85;transition:opacity var(--t-fast),color var(--t-fast);
}
.press-strip .ps-logos span:hover{opacity:1;color:var(--ink-900)}

/* 27.10 Cinematic CTA banner (homepage)
   ---------------------------------------------------------- */
.cta-cinematic{
    margin-top:80px;
    position:relative;border-radius:var(--r-xl);overflow:hidden;
    min-height:480px;display:grid;align-items:center;
    background:var(--ink-900);box-shadow:var(--shadow-lg);
    isolation:isolate;
}
.cta-cinematic .cc-media{position:absolute;inset:0;z-index:0}
.cta-cinematic .cc-media .external-image-frame{height:100%;border-radius:0}
.cta-cinematic .cc-media img{width:100%;height:100%;object-fit:cover;filter:brightness(.55)}
.cta-cinematic::after{
    content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
    background:linear-gradient(110deg,rgba(11,16,32,.85) 0%,rgba(11,16,32,.4) 60%,transparent 100%);
}
.cta-cinematic .cc-body{
    position:relative;z-index:2;
    padding:clamp(36px,5vw,72px);max-width:680px;color:#fff;display:grid;gap:18px;
}
.cta-cinematic .cc-body .eyebrow{color:var(--accent);margin:0}
.cta-cinematic .cc-body h2{
    color:#fff;margin:0;font-size:clamp(32px,4.4vw,56px);line-height:1.05;
}
.cta-cinematic .cc-body p{color:rgba(255,255,255,.78);margin:0;font-size:16px;max-width:50ch}
.cta-cinematic .cc-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.cta-cinematic .cc-actions a{
    padding:14px 26px;border-radius:var(--r-pill);font-weight:700;font-size:14px;
    background:#fff;color:var(--ink-900);transition:transform var(--t-fast),background var(--t-base);
}
.cta-cinematic .cc-actions a.alt{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.45)}
.cta-cinematic .cc-actions a:hover{transform:translateY(-2px)}
.cta-cinematic .cc-actions a.alt:hover{background:rgba(255,255,255,.08)}

/* 27.11 Atelier responsive
   ---------------------------------------------------------- */
@media (max-width:1080px){
    .spotlight{grid-template-columns:1fr;min-height:0}
    .spotlight .sp-media{aspect-ratio:1.4/1}
    .magazine-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:220px}
    .magazine-grid .mg-card.feature{grid-column:span 2;grid-row:span 1}
    .story-block{grid-template-columns:1fr;gap:32px}
    .story-block .sb-media{aspect-ratio:16/10;max-height:520px}
    .process .pr-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:48px 32px}
    .press-strip{grid-template-columns:1fr;gap:18px}
    .press-strip .ps-logos{justify-content:flex-start;gap:24px}
    .atelier-hero .ah-meta{display:none}
    .atelier-hero .ah-scroll{display:none}
    .cta-cinematic{min-height:380px}
    .cta-cinematic::after{
        background:linear-gradient(180deg,rgba(11,16,32,.5) 0%,rgba(11,16,32,.85) 100%);
    }
}

@media (max-width:780px){
    .atelier-hero{min-height:520px;border-radius:var(--r-lg)}
    .marquee-item{font-size:18px}
    .magazine-grid{grid-template-columns:1fr;grid-auto-rows:200px}
    .magazine-grid .mg-card.feature{grid-column:span 1}
    .process .pr-grid{grid-template-columns:1fr;gap:48px}
    .collection-tabs .ct-head{flex-direction:column;align-items:flex-start}
    .spotlight .sp-foot{flex-direction:column;align-items:flex-start;gap:14px}
    .spotlight .sp-foot a.cta{margin-left:0;width:100%;text-align:center}
    .t-spotlight{padding:48px 24px}
    .press-strip .ps-logos span{font-size:18px}
}

