<style>
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#FAF9F6;--card:#FFFFFF;--text:#1A1A1A;--text2:#6B6B6B;--text3:#999;
  --accent:#8B6914;--accent2:#C49B2C;--accent-bg:#F5F0E3;
  --border:#E8E5DE;--border2:#D4D0C8;
  --badge-bg:#1A1A1A;--badge-text:#FAF9F6;
  --price-bg:#F0EDE5;--hover:#F7F5F0;
  --green:#2D6A4F;--green-bg:#E8F3ED;
  --orange:#B45309;--orange-bg:#FEF0E3;
  --modal-bg:rgba(26,26,26,0.6);
  --shadow-sm:0 2px 8px rgba(0,0,0,0.04);
  --shadow-md:0 8px 24px rgba(0,0,0,0.07);
  --shadow-lg:0 16px 48px rgba(0,0,0,0.1);
  --radius:12px;--radius-sm:8px;--radius-lg:16px;
}
html{scroll-behavior:smooth;overflow-x:clip;width:100%;max-width:100vw}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5;overflow-x:clip;width:100%;max-width:100vw;position:relative}
#app{width:100%;max-width:100vw;overflow-x:clip}
/* Zone containers — prevent reflow during partial re-renders */
#ud-topbar,#ud-header,#ud-footer{contain:layout style}
#ud-content{contain:style;min-height:200px}
#ud-overlays{contain:style}
*{box-sizing:border-box;min-width:0}
/* Disable image saving/dragging */
img{-webkit-user-drag:none;user-select:none;-webkit-touch-callout:none;pointer-events:none}
a img,.product-card img,.cat-card img,.cat-grid-card img{pointer-events:none}
.product-image-main{-webkit-touch-callout:none;user-select:none}
.serif{font-family:'Cormorant Garamond',serif}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:inherit;border:none;background:none;-webkit-tap-highlight-color:transparent}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}

/* ========== TOPBAR ========== */
.topbar{background:var(--text);color:var(--badge-text);font-size:12px;padding:9px 0;text-align:center;letter-spacing:1.8px;text-transform:uppercase;position:relative;overflow:hidden}
.topbar::before{content:'';position:absolute;top:0;left:0;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.03),transparent);animation:topbarShine 8s infinite;pointer-events:none;transform:translateX(-100%)}
@keyframes topbarShine{0%{transform:translateX(-100%)}100%{transform:translateX(300%)}}

/* ========== HEADER ========== */
header{background:var(--card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);background:rgba(255,255,255,0.95)}
.header-inner{max-width:1320px;margin:0 auto;padding:14px 40px;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:600;letter-spacing:1.5px;cursor:pointer;transition:opacity .2s}
.logo:hover{opacity:.8}
.logo span{color:var(--accent)}
nav{display:flex;gap:24px;align-items:center}
nav .nav-link{font-size:13px;font-weight:500;letter-spacing:.6px;text-transform:uppercase;color:var(--text2);transition:color .2s;padding:4px 0;position:relative;text-decoration:none;white-space:nowrap}
nav .nav-link:hover,nav .nav-link.active{color:var(--text)}
nav .nav-link.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--accent);border-radius:1px}
.logo{text-decoration:none;display:inline-flex}
.nav-cart{position:relative;display:flex;align-items:center;gap:8px;background:var(--text);color:var(--badge-text);padding:9px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:all .2s}
.nav-cart:hover{background:#333}
.cart-count{background:var(--accent2);color:#FFF;font-size:10px;font-weight:600;width:19px;height:19px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:absolute;top:-7px;right:-7px;animation:cartPop .3s ease}
@keyframes cartPop{0%{transform:scale(0)}50%{transform:scale(1.3)}100%{transform:scale(1)}}

/* ========== HERO — V4B Minimal Left ========== */
.hero-banner{position:relative;height:560px;overflow:hidden;background:#1A1A1A}
.hero-banner .hero-bg{position:absolute;inset:0}
.hero-banner .hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.hero-banner .hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(12,10,6,0.94) 0%,rgba(12,10,6,0.75) 35%,rgba(12,10,6,0.2) 70%,transparent 100%)}
.hero-banner .hero-gold-bar{position:absolute;left:48px;top:50%;transform:translateY(-50%);width:3px;height:200px;background:linear-gradient(to bottom,transparent,var(--accent2),transparent);z-index:3;border-radius:2px}
.hero-banner .hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 48px 0 72px;display:flex;flex-direction:column;justify-content:center;height:100%}
.hero-banner .hero-eyebrow{font-size:11px;letter-spacing:3.5px;text-transform:uppercase;color:var(--accent2);font-weight:600;margin-bottom:20px}
.hero-banner .hero-heading{font-family:'Cormorant Garamond',serif;font-size:56px;font-weight:300;color:#fff;line-height:1.06;margin-bottom:20px;max-width:520px}
.hero-banner .hero-heading em{color:var(--accent2);font-style:italic;font-weight:400}
.hero-banner .hero-sub{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.7;max-width:400px;margin-bottom:36px}
.hero-banner .hero-btns{display:flex;gap:14px}
.hero-banner .hero-btn-gold{display:inline-flex;align-items:center;gap:8px;padding:15px 34px;background:var(--accent2);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s;font-family:inherit;letter-spacing:.5px}
.hero-banner .hero-btn-gold:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,155,44,0.3)}
.hero-banner .hero-btn-white{display:inline-flex;align-items:center;gap:8px;padding:15px 34px;background:rgba(255,255,255,0.1);color:#fff;border:1.5px solid rgba(255,255,255,0.25);border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s;font-family:inherit;letter-spacing:.5px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.hero-banner .hero-btn-white:hover{background:var(--accent2);border-color:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,155,44,0.3)}

/* Keep .hero-cta for other pages (catalog CTA, shipping, etc.) */
.hero-cta{display:inline-flex;align-items:center;gap:10px;background:var(--accent2);color:#FFF;padding:16px 40px;border-radius:var(--radius-sm);font-size:15px;font-weight:500;transition:all .25s;letter-spacing:.3px}
.hero-cta:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,155,44,0.35)}

@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.no-anim .hero-eyebrow,.no-anim .hero-heading,.no-anim .hero-sub,.no-anim .hero-btn-gold,.no-anim .hero-btn-white,.no-anim .cart-count{animation:none!important}

/* ========== HERO — Responsive ========== */
@media(max-width:768px){
  .hero-banner{height:auto;min-height:480px}
  .hero-banner .hero-inner{padding:48px 24px 48px 32px}
  .hero-banner .hero-gold-bar{left:16px;height:140px}
  .hero-banner .hero-heading{font-size:36px}
  .hero-banner .hero-btns{flex-direction:column;gap:10px}
  .hero-banner .hero-btn-gold,.hero-banner .hero-btn-white{width:100%;justify-content:center}
}

/* ========== USP STRIP ========== */
.usp-strip{background:var(--card);border-bottom:1px solid var(--border)}
.usp-inner{max-width:1320px;margin:0 auto;padding:28px 40px;display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.usp-item{display:flex;align-items:center;gap:16px}
.usp-icon{width:48px;height:48px;border-radius:var(--radius-sm);background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;color:var(--accent)}
.usp-item h4{font-size:13px;font-weight:600;margin-bottom:2px}
.usp-item p{font-size:12px;color:var(--text2);line-height:1.4}

/* ========== SECTION ========== */
.section{max-width:1320px;margin:0 auto;padding:64px 40px}
.section.catalog-section{padding-top:24px}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px}
.section-title{font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:400;line-height:1.15}
.section-sub{color:var(--text2);font-size:14px;max-width:420px;line-height:1.6;margin-top:6px}

/* ========== CATEGORY CARDS (HOME) ========== */
.cats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .3s ease;position:relative}
.cat-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.cat-img{height:220px;overflow:hidden;position:relative;background:linear-gradient(135deg,#F5F0E3 0%,#EDE8DA 100%);display:flex;align-items:center;justify-content:center;padding:12px}
.cat-img img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .3s ease}
.cat-card:hover .cat-img img{transform:scale(1.06)}
.cat-count{position:absolute;top:12px;right:12px;background:rgba(0,0,0,0.65);color:#FFF;font-size:11px;padding:5px 12px;border-radius:20px;font-weight:500;backdrop-filter:blur(4px)}
.cat-body{padding:14px 18px}
.cat-body h3{font-size:14px;font-weight:600;margin-bottom:3px}
.cat-body p{font-size:12px;color:var(--text2)}

/* ========== FILTERS ========== */
.filters{display:flex;gap:10px;margin-bottom:32px;flex-wrap:wrap}
.filter-btn{padding:9px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--card);color:var(--text2);transition:all .2s}
.filter-btn:hover{border-color:var(--text);color:var(--text)}
.filter-btn.active{background:var(--text);color:var(--badge-text);border-color:var(--text)}

/* ========== PRODUCT CARDS ========== */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.product-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .3s ease;cursor:pointer}
.product-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.product-img{height:240px;background:var(--price-bg);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.product-badges{position:absolute;top:12px;left:12px;display:flex;gap:6px;flex-wrap:wrap;z-index:2}
.badge{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px}
.badge-new{background:var(--green-bg);color:var(--green)}
.badge-sale{background:var(--orange-bg);color:var(--orange)}
.badge-stock{background:var(--accent-bg);color:var(--accent)}
.product-body{padding:18px 20px}
.product-name{font-size:16px;font-weight:600;margin-bottom:4px}
.product-manufacturer{font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.6px;margin-bottom:6px;display:flex;align-items:center;gap:5px}
.product-manufacturer::before{content:'';display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--accent2)}
.product-material{font-size:12px;color:var(--text2);margin-bottom:12px}
.modal-mfg-line{font-size:13px;color:var(--accent);font-weight:500;margin-top:8px;letter-spacing:.3px}
.product-price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
.product-price{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--accent)}
.product-price-from{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.8px}
.product-sizes{display:flex;gap:5px;flex-wrap:wrap}
.size-tag{font-size:10px;padding:4px 9px;border-radius:4px;background:var(--price-bg);color:var(--text2);font-weight:500}
.product-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.btn-configure{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--accent);transition:color .2s}
.btn-configure:hover{color:var(--text)}
.btn-view{background:var(--text);color:var(--badge-text);padding:9px 18px;border-radius:6px;font-size:12px;font-weight:600;transition:all .2s;letter-spacing:.3px}
.btn-view:hover{background:var(--accent)}

/* ========== MODAL ========== */
.modal-overlay{position:fixed;inset:0;background:var(--modal-bg);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .35s ease;backdrop-filter:blur(4px)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--card);border-radius:var(--radius-lg);max-width:920px;width:100%;max-height:92vh;overflow:hidden;position:relative;box-shadow:var(--shadow-lg);transform:translateY(20px) scale(.98);transition:transform .35s ease;display:grid;grid-template-columns:380px 1fr;min-height:0;min-width:0}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;background:var(--price-bg);display:flex;align-items:center;justify-content:center;font-size:20px;z-index:10;transition:all .2s;color:var(--text2)}
.modal-close:hover{background:var(--border);color:var(--text)}
.modal-image{background:linear-gradient(160deg,#E8E3D8,#F0EDE5);display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden;min-height:0}
.modal-image::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(196,155,44,0.06),transparent 60%)}
.modal-image::after{content:'AAW DOORS  \00a9';position:absolute;bottom:14px;left:50%;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;letter-spacing:3px;color:rgba(139,105,20,.45);pointer-events:none;white-space:nowrap}
.modal-scroll{padding:32px;padding-bottom:0;overflow-y:auto;overflow-x:hidden;max-height:92vh;min-height:0;min-width:0;display:flex;flex-direction:column;gap:18px;-webkit-overflow-scrolling:touch}
.modal-scroll .config-section{min-width:0;word-wrap:break-word}
.modal-scroll .config-options{min-width:0}
.modal-sticky-bottom{position:sticky;bottom:0;background:var(--card);padding:18px 0 24px;margin-top:auto;z-index:5;box-shadow:0 -8px 12px -8px rgba(0,0,0,0.08)}
.modal-scroll h2{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;line-height:1.2}
.modal-scroll .mat-info{font-size:13px;color:var(--text2);line-height:1.7}

/* ========== PRODUCT PAGE ========== */
.product-page{max-width:1200px;margin:0 auto;padding:24px 24px 80px}
.product-breadcrumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2);margin-bottom:24px;flex-wrap:wrap}
.product-breadcrumbs a{color:var(--text2);text-decoration:none;transition:color .2s}
.product-breadcrumbs a:hover{color:var(--accent)}
.bc-sep{color:var(--border2);font-size:11px}
.bc-current{color:var(--text);font-weight:500}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.product-image-col{position:sticky;top:24px}
.product-image-main{background:linear-gradient(160deg,#E8E3D8,#F0EDE5);border-radius:var(--radius-lg);padding:48px;display:flex;align-items:center;justify-content:center;min-height:480px;position:relative;overflow:hidden}
.product-image-main::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 70%,rgba(196,155,44,0.06),transparent 60%)}
.product-image-main::after{content:'AAW DOORS  \00a9';position:absolute;bottom:14px;left:50%;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;letter-spacing:3px;color:rgba(139,105,20,.45);pointer-events:none;white-space:nowrap}
.product-image-main img{max-width:100%;max-height:500px;object-fit:contain;position:relative;z-index:1;filter:drop-shadow(0 8px 24px rgba(0,0,0,0.12))}
.product-src-links{margin-top:12px;text-align:center}
.product-src-links a{font-size:12px;color:var(--accent);text-decoration:none;transition:color .2s;font-weight:500}
.product-src-links a:hover{color:var(--text);text-decoration:underline}
.product-info-col{display:flex;flex-direction:column;gap:18px}
.product-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:6px}
.product-header-left{flex:1;min-width:0}
.product-title{font-size:32px;font-weight:400;line-height:1.15;margin-bottom:4px}
.product-meta-row{margin-bottom:2px}
.product-sku-line{font-size:11px;color:var(--text2);letter-spacing:.4px}
.product-sku-line strong{color:var(--accent);font-weight:600}
.product-type-badge{font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;padding:4px 10px;border-radius:20px;white-space:nowrap;margin-top:6px;flex-shrink:0}
.product-type-badge.exterior{background:#E8F3ED;color:#2D6A4F}
.product-type-badge.interior{background:#FEF0E3;color:#B45309}
.product-material{font-size:12px;color:var(--text2);line-height:1.4;margin-bottom:1px}
.product-mfg{font-size:11px;color:var(--accent);font-weight:500;letter-spacing:.3px}
.product-description{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px}
.product-desc-title{font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text)}
.product-desc-list{margin:0;padding-left:18px;font-size:13px;color:var(--text2);line-height:1.8;list-style:disc}
.product-desc-list li{margin-bottom:2px}
.product-config-section{border-top:1px solid var(--border);padding-top:18px}
.config-step-title{font-size:14px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.product-call-price{font-size:15px;color:var(--accent);font-weight:500;padding:12px 0}
.product-summary{background:var(--text);color:#FFF;border-radius:var(--radius);padding:24px;margin-top:8px}
.product-summary-breakdown{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.ps-row{display:flex;justify-content:space-between;font-size:13px;color:rgba(255,255,255,0.6)}
.product-summary-total{display:flex;justify-content:space-between;font-size:22px;font-weight:600;border-top:1px solid rgba(255,255,255,0.15);padding-top:14px;margin-bottom:18px;font-family:'Cormorant Garamond',serif}
.ps-total-price{color:#FFF}
.product-add-btn{display:block;width:100%;padding:16px;border-radius:var(--radius-sm);background:var(--accent2);color:#FFF;font-size:16px;font-weight:600;text-align:center;transition:all .25s;letter-spacing:.4px;border:none;cursor:pointer;text-decoration:none}
.product-add-btn:hover{background:var(--accent);transform:translateY(-1px);box-shadow:0 6px 20px rgba(196,155,44,0.3)}

/* ===== Product page responsive ===== */
@media(max-width:900px){
  .product-layout{grid-template-columns:1fr;gap:24px}
  .product-image-col{position:static}
  .product-image-main{min-height:320px;padding:32px}
  .product-title{font-size:26px}
}
@media(max-width:480px){
  .product-page{padding:16px 16px 60px}
  .product-image-main{min-height:240px;padding:20px}
  .product-title{font-size:22px}
  .product-header{gap:10px}
  .product-summary{padding:18px}
  .product-summary-total{font-size:18px}
  .product-page .info-trigger .ph-preview{display:none}
  .product-page .info-trigger.info-open .ph-preview{display:block;opacity:1;pointer-events:auto;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;width:240px;box-shadow:0 16px 48px rgba(0,0,0,0.25)}
  .product-page .info-trigger.info-open .ph-preview::after{display:none}
}

/* ========== CONFIG SECTIONS ========== */
.config-section{border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;background:var(--bg)}
.config-section h4{font-size:13px;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:9px}
.step-num{width:24px;height:24px;border-radius:50%;background:var(--text);color:var(--badge-text);font-size:11px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.config-label{font-size:11px;color:var(--text2);margin:10px 0 6px;text-transform:uppercase;letter-spacing:.8px;font-weight:500}
/* Prehung config row: options left, preview right */
.ph-config-row{display:flex;gap:20px;align-items:flex-start}
.ph-config-opts{flex:1;min-width:0}
/* Preview panel: animation area + jamb/hinge photos */
.ph-config-preview{flex:0 0 240px;position:sticky;top:12px;align-self:flex-start;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px;transition:border-color .3s;max-height:calc(100vh - 24px);overflow-y:auto}
.ph-side-photo{margin-top:12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:border-color .2s;background:var(--card)}
.ph-side-photo:hover{border-color:var(--accent)}
.ph-side-photo img{width:100%;height:auto;max-height:180px;object-fit:contain;display:block;background:#fff}
.ph-side-label{display:block;padding:6px 8px;font-size:11px;font-weight:500;text-align:center;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:var(--bg);border-top:1px solid var(--border)}
.ph-config-preview[data-type="slab"]{border-style:dashed;border-color:var(--border2)}
.ph-config-preview:not([data-type="slab"]){border-color:rgba(196,155,44,0.3)}
.ph-anim-area{display:flex;align-items:center;justify-content:center;min-height:180px}
.ph-anim-area svg{max-width:100%;height:auto;display:block;margin:0 auto}
/* Auto-play door swing animation: 2 cycles, ends open */
@keyframes doorSwingLeft{0%{transform:rotate(0)}40%{transform:rotate(-75deg)}60%{transform:rotate(-75deg)}75%{transform:rotate(0)}90%{transform:rotate(-75deg)}100%{transform:rotate(-75deg)}}
@keyframes doorSwingRight{0%{transform:rotate(0)}40%{transform:rotate(75deg)}60%{transform:rotate(75deg)}75%{transform:rotate(0)}90%{transform:rotate(75deg)}100%{transform:rotate(75deg)}}
@keyframes hdotGlow{0%{r:2.5;fill:#8B6914}40%{r:4;fill:#C49B2C}100%{r:4;fill:#C49B2C}}
.ph-config-preview .d-1A{animation:doorSwingLeft 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-1B{animation:doorSwingRight 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-1C{animation:doorSwingLeft 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-1D{animation:doorSwingRight 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2A-L{animation:doorSwingLeft 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2A-R{animation:doorSwingRight 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2B-L{animation:doorSwingLeft 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2B-R{animation:doorSwingRight 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2C-L{animation:doorSwingRight 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2C-R{animation:doorSwingLeft 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2D-L{animation:doorSwingRight 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .d-2D-R{animation:doorSwingLeft 1.8s cubic-bezier(.4,.15,.2,1) forwards}
.ph-config-preview .hdot{animation:hdotGlow 1.8s forwards}
.ph-anim-area{cursor:pointer}
/* Lightbox for zoomed preview */
.ph-lightbox{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .25s;pointer-events:none}
.ph-lightbox.active{opacity:1;pointer-events:auto}
.ph-lightbox-inner{max-width:90vw;max-height:85vh;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.4);position:relative}
.ph-lightbox-inner img{display:block;max-width:90vw;max-height:80vh;object-fit:contain}
.ph-lightbox-inner svg{display:block;max-width:90vw;max-height:80vh}
.ph-lightbox-inner .ph-lb-label{padding:8px 16px;font-size:13px;font-weight:600;text-align:center;color:var(--text);background:var(--bg);border-top:1px solid var(--border)}
.ph-lightbox-close{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1}
/* Warning modal for "None" selection */
.ph-warn-modal{position:fixed;inset:0;z-index:10001;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .2s;pointer-events:none}
.ph-warn-modal.active{opacity:1;pointer-events:auto}
.ph-warn-inner{max-width:440px;width:100%;background:#fff;border-radius:14px;padding:28px 24px 22px;box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:center;transform:scale(.95);transition:transform .2s}
.ph-warn-modal.active .ph-warn-inner{transform:scale(1)}
.ph-warn-icon{font-size:44px;line-height:1;margin-bottom:10px}
.ph-warn-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 12px;letter-spacing:.2px}
.ph-warn-body{font-size:14px;line-height:1.55;color:var(--text2);margin:0 0 22px}
.ph-warn-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.ph-warn-btn{padding:10px 22px;font-size:13px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;border:1.5px solid transparent;transition:all .18s;min-width:120px}
.ph-warn-cancel{background:var(--card);border-color:var(--border);color:var(--text)}
.ph-warn-cancel:hover{border-color:var(--text);background:var(--bg)}
.ph-warn-confirm{background:var(--accent);color:#fff;border-color:var(--accent)}
.ph-warn-confirm:hover{filter:brightness(.92)}
@media(max-width:480px){.ph-warn-inner{padding:24px 18px 18px}.ph-warn-btn{width:100%}}
@media(max-width:768px){
  .ph-config-row{gap:10px}
  .ph-config-opts{flex:1;min-width:0}
  .ph-config-preview{flex:0 0 160px;position:sticky;top:8px;padding:10px;max-height:calc(100vh - 16px)}
  .ph-anim-area{min-height:110px}
  .ph-anim-area svg{width:120px}
  /* Hide side panel photos on mobile — shown inline next to config buttons instead */
  .ph-side-photo{display:none}
  .config-options{flex-direction:column;gap:4px}
  .config-opt{padding:6px 10px;font-size:11px;width:100%;text-align:left}
}
/* In modal: smaller preview */
.modal-scroll .ph-config-preview{flex:0 0 200px;padding:10px}
.modal-scroll .ph-anim-area{min-height:140px}
.modal-scroll .ph-anim-area svg{width:160px}
.modal-scroll .ph-side-photo img{max-height:150px}
.config-options{display:flex;gap:8px;flex-wrap:wrap}
.config-opt{padding:8px 15px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;border:1.5px solid var(--border);background:var(--card);transition:all .2s;cursor:pointer}
.config-opt:hover{border-color:var(--accent)}
.config-opt.selected{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}
/* Config row with inline photo preview */
.config-with-photo{display:flex;gap:12px;align-items:flex-start}
.config-with-photo .config-options{flex:1;min-width:0}
.config-photo{flex:0 0 90px;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;transition:border-color .2s;background:#fff}
.config-photo:hover{border-color:var(--accent)}
.config-photo img{width:100%;height:auto;max-height:110px;object-fit:contain;display:block;background:#fff}
.config-photo span{display:block;padding:4px 6px;font-size:10px;font-weight:500;text-align:center;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:var(--bg)}
/* Show inline photo only on mobile; hide on desktop (photo is in side panel) */
.config-photo.mobile-only{display:none}
@media(max-width:768px){
  .config-photo.mobile-only{display:block}
}
@media(max-width:768px){
  .config-with-photo{gap:8px}
  .config-photo{flex:0 0 80px}
  .config-photo img{height:60px}
  .config-photo span{font-size:9px;padding:3px 4px}
}

/* ========== SIZE MATRIX (Variant 3) ========== */
.size-matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -4px;padding:0 4px 4px}
.size-matrix{display:grid;gap:5px;min-width:min-content}
.size-cell{padding:9px 6px;border-radius:6px;font-size:11px;font-weight:500;text-align:center;border:1.5px solid var(--border);background:var(--card);min-width:60px;display:flex;flex-direction:column;justify-content:center;align-items:center;line-height:1.2}
.size-header-corner{background:transparent;border:none;color:var(--text3);font-size:9px;text-transform:uppercase;letter-spacing:.4px;font-weight:600;min-width:auto;padding:4px}
.size-header-row{background:var(--text);color:#FAF9F6;border-color:var(--text);font-weight:700;font-size:11px}
.size-header-col{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-bg);font-weight:700;font-size:12px;min-width:auto;padding:8px 10px}
.size-empty{background:transparent;border:1.5px dashed var(--border);color:var(--text3);cursor:not-allowed}
button.size-data{cursor:pointer;transition:all .2s;font-family:inherit;color:var(--text)}
button.size-data:hover{border-color:var(--accent);background:var(--hover);transform:translateY(-1px)}
button.size-data.selected{border-color:var(--accent);background:var(--accent);color:#FFF;box-shadow:0 4px 12px rgba(139,105,20,0.25)}
.size-data .size-dim{font-weight:600;font-size:11px}
.size-data .size-price{font-size:10px;opacity:.75;margin-top:2px}
.size-data.selected .size-price{opacity:1}
.size-data{position:relative}
.admin-edit-price{position:absolute;top:2px;right:2px;font-size:9px;width:16px;height:16px;line-height:16px;text-align:center;background:rgba(139,105,20,0.15);color:var(--accent);border-radius:50%;cursor:pointer;opacity:0;transition:opacity .2s;z-index:2}
.size-data:hover .admin-edit-price{opacity:1}
.admin-edit-price:hover{background:var(--accent);color:#fff}
.admin-price-editor{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:center;justify-content:center}
.ape-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.4)}
.ape-box{position:relative;background:#fff;border-radius:12px;padding:24px 28px;box-shadow:0 20px 60px rgba(0,0,0,0.25);min-width:260px;text-align:center}
.ape-label{font-size:14px;font-weight:600;color:var(--text);margin-bottom:16px}
.ape-row{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:18px}
.ape-dollar{font-size:20px;font-weight:600;color:var(--text2)}
.ape-input{width:120px;font-size:20px;font-weight:600;text-align:center;padding:8px 12px;border:2px solid var(--border);border-radius:8px;outline:none;font-family:inherit;color:var(--text)}
.ape-input:focus{border-color:var(--accent)}
.ape-actions{display:flex;gap:10px;justify-content:center}
.ape-cancel{padding:8px 20px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;font-size:13px;font-family:inherit;color:var(--text2)}
.ape-cancel:hover{background:var(--bg)}
.ape-save{padding:8px 20px;border:none;border-radius:8px;background:var(--accent);color:#fff;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit}
.ape-save:hover{background:var(--accent2)}

/* ========== PRICE SUMMARY ========== */
.price-summary{background:var(--text);color:#FFF;border-radius:var(--radius-sm);padding:18px}
.price-line{display:flex;justify-content:space-between;font-size:13px;margin-bottom:8px;color:rgba(255,255,255,0.6)}
.price-line.total{font-size:20px;font-weight:600;color:#FFF;border-top:1px solid rgba(255,255,255,0.15);padding-top:12px;margin-top:6px;margin-bottom:0;font-family:'Cormorant Garamond',serif}
.btn-order{width:100%;padding:15px;border-radius:var(--radius-sm);background:var(--accent2);color:#FFF;font-size:15px;font-weight:600;transition:all .25s;letter-spacing:.4px}
.btn-order:hover{background:var(--accent);transform:translateY(-1px);box-shadow:0 6px 20px rgba(196,155,44,0.3)}

/* ========== CART PANEL ========== */
.cart-panel{position:fixed;top:0;right:0;width:400px;max-width:100%;height:100%;background:var(--card);z-index:200;box-shadow:var(--shadow-lg);overflow-y:auto;padding:28px;transform:translateX(110%);transition:transform .35s ease;visibility:hidden;pointer-events:none}
.cart-panel.open{transform:translateX(0);visibility:visible;pointer-events:all}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:199;opacity:0;pointer-events:none;transition:opacity .3s;visibility:hidden}
.cart-overlay.open{opacity:1;pointer-events:all;visibility:visible}
.cart-item{border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;margin-bottom:12px;transition:all .2s}
.cart-item:hover{border-color:var(--border2)}

/* ========== CHECKOUT FORM ========== */
.checkout-form{display:none}
.checkout-form.active{display:block;animation:slideIn .35s ease}
.checkout-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.checkout-header button{background:none;border:none;cursor:pointer;color:var(--text2);font-size:18px;transition:color .2s}
.checkout-header button:hover{color:var(--text)}
.checkout-header h3{font-size:20px;font-weight:600;margin:0}
.checkout-section{margin-bottom:24px}
.checkout-section h4{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-row.full{grid-template-columns:1fr}
.form-group{display:flex;flex-direction:column}
.form-group label{font-size:12px;font-weight:500;color:var(--text);margin-bottom:6px}
.form-group input,.form-group textarea{padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;color:var(--text);background:var(--card);transition:all .2s}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(139,105,20,0.1)}
.form-group textarea{resize:vertical;min-height:80px}
.order-summary{background:var(--accent-bg);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:14px;margin-bottom:20px;font-size:13px}
.order-summary-item{display:flex;justify-content:space-between;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(139,105,20,0.2)}
.order-summary-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;font-weight:600;color:var(--accent);font-size:14px}
.checkout-actions{display:flex;gap:10px;margin-top:20px}
.btn-checkout{background:var(--accent);color:#FFF;padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.4px}
.btn-checkout:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(139,105,20,0.25)}
.btn-checkout:disabled{opacity:.5;cursor:not-allowed}
.btn-checkout.secondary{background:var(--border);color:var(--text);padding:10px 16px;font-size:12px}
.btn-checkout.secondary:hover{background:var(--border2)}
.confirmation-message{background:var(--green-bg);border:1px solid var(--green);border-radius:var(--radius-sm);padding:16px;text-align:center;margin-bottom:20px}
.confirmation-message h3{color:var(--green);font-size:18px;margin-bottom:6px}
.confirmation-message p{color:var(--text2);font-size:13px}
.order-number{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:var(--accent);margin:10px 0}
@keyframes slideIn{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}

/* ========== PRICING PAGE ========== */
.price-table-section{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;overflow-x:auto}
.price-table{width:100%;border-collapse:collapse}
.price-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text2);padding:12px 16px;border-bottom:2px solid var(--border);font-weight:500}
.price-table td{padding:13px 16px;border-bottom:1px solid var(--border);font-size:14px;transition:background .15s}
.price-table tbody tr{cursor:pointer}
.price-table tbody tr:hover td{background:var(--hover)}
.price-table tbody tr:last-child td{border-bottom:none}
.price-cell{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--accent)}
.price-cell.na{color:var(--border2);font-size:16px}

/* ========== PREHUNG GUIDE ========== */
.cta-banner{background:var(--accent-bg);border:1px solid var(--accent);border-radius:var(--radius);padding:32px;text-align:center}
.ph-hero{background:linear-gradient(135deg,#2C2418,#4A3D2A,#1A1A1A);border-radius:var(--radius-lg);padding:48px;color:#FFF;position:relative;overflow:hidden;margin-bottom:48px}
.ph-hero::before{content:'';position:absolute;inset:0;opacity:.05;background-image:radial-gradient(circle at 20% 80%,#C49B2C 1px,transparent 1px);background-size:40px 40px}
.ph-hero h2{font-family:'Cormorant Garamond',serif;font-size:42px;font-weight:400;margin-bottom:12px;position:relative;z-index:1}
.ph-hero p{color:rgba(255,255,255,.6);font-size:15px;max-width:520px;line-height:1.7;position:relative;z-index:1}
.ph-tabs{display:flex;gap:6px;margin-bottom:32px;flex-wrap:wrap}
.ph-tab{padding:10px 22px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--card);color:var(--text2);transition:all .2s;cursor:pointer}
.ph-tab:hover{border-color:var(--text);color:var(--text)}
.ph-tab.active{background:var(--text);color:var(--badge-text);border-color:var(--text)}
.ph-section-title{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:400;margin-bottom:8px}
.ph-section-sub{font-size:14px;color:var(--text2);margin-bottom:28px;line-height:1.7;max-width:600px}
.ph-instruction{background:var(--accent-bg);border-radius:var(--radius-sm);padding:14px 20px;font-size:13px;color:var(--accent);margin-bottom:24px;display:flex;align-items:center;gap:10px;font-weight:500}
.ph-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:48px}
.hand-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .3s}
.hand-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}
.hand-card .hc-visual{height:220px;background:var(--price-bg);display:flex;align-items:center;justify-content:center;position:relative;overflow:visible}
.hand-card .hc-visual svg{overflow:visible}
.hand-card .hc-body{padding:16px;border-top:1px solid var(--border)}
.hand-card .hc-body h4{font-size:14px;font-weight:600;margin-bottom:4px}
.hand-card .hc-body p{font-size:11px;color:var(--text2);line-height:1.5}
.hand-card .hc-code{display:inline-block;margin-top:8px;font-size:11px;padding:3px 10px;border-radius:4px;background:var(--price-bg);color:var(--accent);font-weight:600}
/* Door swing transitions */
.hand-card .door{transition:transform .6s cubic-bezier(.4,.15,.2,1)}
.hand-card:hover .d-1A{transform:rotate(-75deg)}
.hand-card:hover .d-1B{transform:rotate(75deg)}
.hand-card:hover .d-1C{transform:rotate(-75deg)}
.hand-card:hover .d-1D{transform:rotate(75deg)}
.hand-card:hover .d-2A-L{transform:rotate(-75deg)}
.hand-card:hover .d-2A-R{transform:rotate(75deg)}
.hand-card:hover .d-2B-L{transform:rotate(-75deg)}
.hand-card:hover .d-2B-R{transform:rotate(75deg)}
.hand-card:hover .d-2C-L{transform:rotate(75deg)}
.hand-card:hover .d-2C-R{transform:rotate(-75deg)}
.hand-card:hover .d-2D-L{transform:rotate(75deg)}
.hand-card:hover .d-2D-R{transform:rotate(-75deg)}
.hand-card .hdot{transition:all .3s}
.hand-card:hover .hdot{r:4;fill:#C49B2C}
/* Prehung option with info icon */
.config-opt{display:inline-flex;align-items:center;gap:8px}
.info-trigger{position:relative;width:18px;height:18px;border-radius:50%;background:var(--price-bg);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--accent);cursor:help;transition:all .2s;flex-shrink:0;font-style:italic;font-family:'Cormorant Garamond',serif}
.config-opt.selected .info-trigger{background:rgba(139,105,20,0.15)}
.info-trigger:hover{background:var(--accent2);color:#FFF;transform:scale(1.1)}
.info-trigger .ph-preview{position:absolute;bottom:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(6px);opacity:0;pointer-events:none;transition:all .3s ease;z-index:50;background:#FFF;border:1px solid #E8E5DE;border-radius:12px;padding:10px;box-shadow:0 12px 36px rgba(0,0,0,0.14);width:220px}
.info-trigger .ph-preview::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:7px solid transparent;border-top-color:#E8E5DE}
.info-trigger:hover .ph-preview{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.info-trigger.info-open .ph-preview{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto;display:block}
.info-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:9998}
.info-trigger .door{transition:transform .6s cubic-bezier(.4,.15,.2,1)}
.info-trigger:hover .d-1A{transform:rotate(-75deg)}
.info-trigger:hover .d-1B{transform:rotate(75deg)}
.info-trigger:hover .d-2A-L{transform:rotate(-75deg)}
.info-trigger:hover .d-2B-R{transform:rotate(75deg)}
.info-trigger .hdot{transition:all .3s}
.info-trigger:hover .hdot{r:3.5;fill:#C49B2C}
/* Anatomy, Jamb, Hinges, etc — kept from before */
.ph-step-num{width:36px;height:36px;border-radius:50%;background:var(--accent2);color:#FFF;font-size:15px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ph-step-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.ph-step-header h3{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:400}
.ph-step-divider{width:100%;height:1px;background:var(--border);margin:44px 0}
.anatomy-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:32px}
.anatomy-svg-area{display:flex;justify-content:center;padding:40px 20px;background:linear-gradient(180deg,var(--price-bg),var(--card))}
.anatomy-labels{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px}
.anatomy-label{padding:14px;border-radius:var(--radius-sm);background:var(--bg);border-left:3px solid var(--accent2);transition:all .2s}
.anatomy-label:hover{background:var(--accent-bg)}
.anatomy-label h5{font-size:13px;font-weight:600;margin-bottom:3px}
.anatomy-label p{font-size:11px;color:var(--text2);line-height:1.5}
.jamb-vis{display:flex;gap:16px;align-items:stretch}
.jamb-option{flex:1;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;transition:all .2s}
.jamb-option:hover{border-color:var(--accent);background:var(--accent-bg)}
.jamb-option h5{font-size:14px;font-weight:600}
.jamb-option p{font-size:11px;color:var(--text2)}
.jamb-option .jamb-price{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--accent);font-weight:600;margin-top:6px}
.hinge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.hinge-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;transition:all .2s}
.hinge-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.hinge-swatch{width:36px;height:36px;border-radius:50%;margin:0 auto 10px;border:2px solid var(--border)}
.hinge-card h5{font-size:13px;font-weight:600;margin-bottom:2px}
.hinge-card .hinge-price{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--accent);font-weight:600;margin-top:6px}
.thresh-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.thresh-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;text-align:center;transition:all .2s}
.thresh-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.ph-compare{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;margin:40px 0}
.ph-compare table{width:100%;border-collapse:collapse}
.ph-compare th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text2);padding:12px 14px;border-bottom:2px solid var(--border);font-weight:500}
.ph-compare td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px}
.ph-compare .check{color:var(--green);font-weight:600}
.ph-compare .na{color:var(--border2)}

/* ========== FOOTER ========== */
footer{background:var(--text);color:rgba(255,255,255,0.6);padding:56px 0 28px;margin-top:48px}
.footer-inner{max-width:1320px;margin:0 auto;padding:0 40px}
.footer-grid{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:44px}
.footer-grid h4{color:#FFF;font-size:14px;margin-bottom:18px;font-weight:500;letter-spacing:.3px}
.footer-grid p,.footer-grid a{font-size:13px;line-height:2.2;display:block;transition:color .2s}
.footer-grid a:hover{color:var(--accent2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:22px;font-size:12px;display:flex;justify-content:space-between;letter-spacing:.3px}
.footer-copyright-notice{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,0.06);font-size:11px;line-height:1.6;color:rgba(255,255,255,0.55);letter-spacing:.2px;font-style:italic}

/* ========== RESPONSIVE ========== */
@media(max-width:1100px){
  .products-grid{grid-template-columns:repeat(2,1fr)}
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .modal{grid-template-columns:1fr;max-width:560px;max-height:94vh;grid-template-rows:auto 1fr}
  .modal-image{height:240px;flex-shrink:0;padding:24px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .modal-scroll{max-height:none;min-height:0;padding:24px;padding-bottom:0}
  .modal-sticky-bottom{padding:14px 0 18px}
}
/* Override 1100px grid with flex on actual phones */
@media(max-width:800px){
  .modal{display:flex!important;flex-direction:column!important;grid-template-columns:unset!important;grid-template-rows:unset!important}
}
@media(max-width:800px){
  .topbar{font-size:11px;letter-spacing:.6px;padding:8px 14px;line-height:1.45}
  .header-inner{padding:11px 16px;gap:10px}
  .logo{font-size:22px;letter-spacing:.8px;flex:0 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  nav{display:flex;align-items:center;gap:8px;flex-shrink:0}
  nav .nav-link{display:none}
  .nav-search{width:34px;height:34px;margin-left:0}
  .nav-search svg{width:16px;height:16px}
  .nav-cart{padding:8px 14px;font-size:12px;gap:6px}
  .nav-cart svg{width:14px;height:14px}
  .cart-count{width:17px;height:17px;font-size:9px;top:-6px;right:-6px}
  .hero h1{font-size:38px;max-width:none}
  .hero p{font-size:15px;max-width:none;line-height:1.6;margin-bottom:26px}
  .hero-content{padding:40px 20px}
  .hero-badge{font-size:11px;padding:8px 16px;margin-bottom:18px;letter-spacing:.3px}
  .hero-cta{padding:14px 28px;font-size:14px}
  .hero-stats{gap:18px;margin-top:32px;flex-wrap:wrap}
  .hero-stat{padding-left:14px}
  .hero-stat strong{font-size:26px}
  .hero-stat span{font-size:10px;letter-spacing:1px;color:rgba(255,255,255,.65)}
  .usp-inner{grid-template-columns:repeat(2,1fr);padding:20px}
  .section{padding:40px 16px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-inner{padding:0 20px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center}
  .cart-panel{width:100%;max-width:100%;right:0;padding:20px;overflow-x:hidden}
  /* ---- Mobile modal: full-screen single-scroll layout ---- */
  .modal-overlay{padding:0;overflow:hidden;width:100%;max-width:100%}
  .modal{
    /* RESET all grid props from wider breakpoints */
    display:flex!important;flex-direction:column!important;
    grid-template-columns:unset!important;grid-template-rows:unset!important;
    max-height:100vh;height:100vh;height:100dvh;
    border-radius:0;max-width:100%;width:100%;overflow:hidden
  }
  .modal-image{
    height:auto;min-height:0;max-height:35vh;flex-shrink:0;
    padding:16px;border-radius:0;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden
  }
  .modal-image img{max-height:30vh;max-width:90%;width:auto;object-fit:contain}
  .modal-scroll{
    flex:1 1 0%;min-height:0;overflow-y:auto;overflow-x:hidden;
    padding:18px 16px 0;gap:12px;
    max-width:100%;width:100%;max-height:none;
    -webkit-overflow-scrolling:touch;
    /* Reset grid leftovers */
    display:flex;flex-direction:column
  }
  .modal-scroll h2{font-size:20px}
  .modal-scroll .mat-info{font-size:12px}
  .info-trigger .ph-preview{display:none}
  .info-trigger.info-open .ph-preview{display:block;opacity:1;pointer-events:auto;position:fixed;bottom:auto;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;width:240px;box-shadow:0 16px 48px rgba(0,0,0,0.25)}
  .info-trigger.info-open .ph-preview::after{display:none}
  .modal-scroll .config-section{padding:12px}
  .modal-scroll .config-section h4{font-size:12px;margin-bottom:10px}
  .modal-scroll .config-opt{font-size:11px;padding:7px 10px;white-space:nowrap}
  .modal-scroll .config-options{gap:5px}
  /* Size matrix: horizontal scroll, keep grid intact */
  .size-matrix-wrap{margin:0;padding:0 0 6px;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
  .size-matrix{display:grid!important;min-width:min-content;font-size:10px;gap:4px}
  .size-cell{min-width:52px;padding:6px 4px;font-size:10px}
  .size-data .size-dim{font-size:10px}
  .size-data .size-price{font-size:9px}
  .size-header-row{font-size:10px;padding:5px 4px;min-width:52px}
  .size-header-col{padding:5px 6px;font-size:10px}
  .size-header-corner{font-size:8px;min-width:36px;padding:4px 2px}
  /* Sticky bottom: stays visible, never covers content */
  .modal-sticky-bottom{position:sticky;bottom:0;padding:10px 0 14px;margin-top:auto;flex-shrink:0}
  .price-summary{padding:10px 12px}
  .price-line{font-size:12px;margin-bottom:5px}
  .price-line.total{font-size:17px;padding-top:8px}
  .btn-order{padding:13px;font-size:14px}
  /* Close button */
  .modal-close{top:8px;right:8px;width:32px;height:32px;font-size:16px;background:rgba(255,255,255,.9);backdrop-filter:blur(4px);z-index:20;box-shadow:0 2px 8px rgba(0,0,0,.15)}

  /* Cart page (cart.html) mobile fixes */
  .cart-checkout{padding:20px!important;max-width:100%!important}
  .cart-checkout h2{font-size:22px!important}
  .cart-checkout input{font-size:16px!important;padding:12px!important}
  .cart-csz-grid{grid-template-columns:1fr!important}
  .cart-items > div{flex-wrap:wrap}
}

@media(max-width:520px){
  .cart-checkout{padding:16px!important}
  .section h1{font-size:24px!important}
  .cart-items{margin-bottom:24px!important}
}

/* ========== GLOBAL MOBILE OVERFLOW GUARD ========== */
@media(max-width:800px){
  /* Kill any horizontal scroll on narrow screens */
  html,body,#app{overflow-x:clip;max-width:100vw}
  /* Every top-level wrapper stays inside the viewport */
  .topbar,header,.hero,.usp-strip,.section,footer,.cta-banner,.product-page,.product-layout{max-width:100%;overflow-x:clip}
  .hero-content,.usp-inner,.footer-inner,.header-inner{max-width:100%;width:100%;padding-left:16px;padding-right:16px}
  /* Prevent any block-level content from poking out */
  .hero h1,.hero p,.section h1,.section h2,.section p,.cta-banner h3,.cta-banner p{max-width:100%;word-wrap:break-word;overflow-wrap:anywhere}
  /* Tables that must scroll should do so inside their own container */
  .admin-table,.price-table{display:block;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .size-matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;margin:0}
  .size-matrix{display:grid;max-width:none}
  /* Images never overflow */
  img,video,svg{max-width:100%;height:auto}
  /* Remove negative margins that can push beyond edges */
  .hero-svg-decor{max-width:100%;overflow:hidden}
  /* Product page info must not overflow */
  .product-info-col,.product-image-col{max-width:100%;overflow-x:hidden}
  .product-config-section{max-width:100%}
}

/* ========== PHONE-TIGHT FIXES (<=480px) ========== */
@media(max-width:480px){
  .topbar{font-size:10px;letter-spacing:.3px;padding:7px 12px;line-height:1.5}
  .header-inner{padding:10px 14px;gap:8px}
  .logo{font-size:19px;letter-spacing:.6px}
  .nav-search{width:32px;height:32px;border-radius:var(--radius-sm)}
  .nav-cart{padding:7px 12px;font-size:11px}
  .nav-cart svg{width:13px;height:13px}

  .hero{min-height:auto}
  .hero-content{padding:32px 18px 44px}
  .hero-badge{font-size:10px;padding:7px 14px;margin-bottom:16px}
  .hero h1{font-size:30px;line-height:1.1;margin-bottom:16px}
  .hero p{font-size:14px;margin-bottom:22px}
  .hero-cta{padding:13px 24px;font-size:13px;width:auto}
  .hero-stats{gap:14px 20px;margin-top:26px}
  .hero-stat{padding-left:12px;flex:0 0 auto;min-width:0}
  .hero-stat::before{top:2px;bottom:2px}
  .hero-stat strong{font-size:22px}
  .hero-stat span{font-size:9px;letter-spacing:.8px;color:rgba(255,255,255,.7);white-space:nowrap}

  /* Hide heavy hero decor on tiny screens — keeps text crisp */
  .hero-svg-decor{display:none}
  .hero-photo-2{display:none}
  .hero-overlay{background:linear-gradient(180deg,rgba(12,10,6,0.88) 0%,rgba(12,10,6,0.72) 100%)}

  /* Phone modal: even tighter */
  .modal-image{max-height:30vh;padding:12px}
  .modal-image img{max-height:25vh}
  .modal-scroll{padding:14px 14px 0;gap:10px}
  .modal-scroll h2{font-size:18px}
  .modal-sku{font-size:10px;padding:3px 8px}
  .size-cell{min-width:46px;padding:5px 2px;font-size:9px}
  .size-header-col{padding:4px 4px;font-size:9px}
  .size-header-row{font-size:9px;min-width:46px}
  .price-line.total{font-size:16px}
  .btn-order{padding:12px;font-size:13px}
}

@media(max-width:360px){
  .logo{font-size:17px}
  .nav-cart{padding:6px 10px;font-size:10px}
  .hero h1{font-size:26px}
  .hero-stat strong{font-size:20px}
  .modal-image{max-height:25vh;padding:10px}
  .modal-scroll h2{font-size:17px}
  .size-cell{min-width:40px;padding:4px 2px;font-size:8px}
  .size-header-corner{min-width:28px;font-size:7px}
}

/* ========== CATEGORY GRID VIEW (CATALOG) ========== */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:32px}
.cat-grid-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column}
.cat-grid-card:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:var(--shadow-md)}
.cat-grid-img{height:280px;width:100%;overflow:hidden;position:relative;background:linear-gradient(135deg,#F5F0E3 0%,#EDE8DA 100%);display:flex;align-items:center;justify-content:center;padding:16px}
.cat-grid-img img{max-width:100%;max-height:100%;object-fit:contain;transition:transform .3s ease}
.cat-grid-card:hover .cat-grid-img img{transform:scale(1.06)}
.cat-grid-info{padding:16px 18px;flex-grow:1;display:flex;flex-direction:column;justify-content:space-between}
.cat-grid-info h3{font-size:15px;font-weight:600;margin-bottom:6px;color:var(--text)}
.cat-grid-count{font-size:12px;color:var(--text2)}

/* ========== BREADCRUMB & BANNER ========== */
.cat-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:24px;font-size:14px;color:var(--text2)}
.breadcrumb-back{background:none;color:var(--accent);font-weight:500;cursor:pointer;transition:color .2s;border:none;padding:0}
.breadcrumb-back:hover{color:var(--accent2)}
.cat-banner{height:240px;background-size:cover;background-position:center;border-radius:var(--radius);overflow:hidden;margin-bottom:32px;position:relative}
.cat-banner-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.15);opacity:0}
.cat-banner:hover .cat-banner-overlay{opacity:1}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .cats-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .cats-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .cat-grid-img{height:220px;padding:12px}
  .cat-img{height:180px;padding:10px}
  .cat-grid-info{padding:12px 14px}
  .cat-grid-info h3{font-size:13px}
  .cat-body{padding:12px 14px}
  .cat-body h3{font-size:13px}
}
@media(max-width:600px){
  .products-grid,.cats-grid,.cat-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .usp-inner{grid-template-columns:1fr}
  .hero{min-height:auto}
  .cat-grid-img{height:160px;padding:8px}
  .cat-img{height:140px;padding:8px}
  .cat-grid-info{padding:10px 12px}
  .cat-grid-info h3{font-size:12px}
  .cat-grid-count{font-size:11px}
  .cat-body{padding:10px 12px}
  .cat-body h3{font-size:12px}
  .cat-body p{font-size:11px}
  .cat-banner{height:160px}
  .cat-breadcrumb{font-size:13px}
}

/* ========== ADMIN PANEL ========== */
.admin-overlay{position:fixed;inset:0;z-index:10000;background:#FFFFFF;display:flex;opacity:0;visibility:hidden;transition:all .3s ease}
.admin-overlay.open{opacity:1;visibility:visible}
.admin-sidebar{width:240px;background:#1a1a1a;color:#FFFFFF;padding:24px;overflow-y:auto;box-shadow:-2px 0 8px rgba(0,0,0,0.1)}
.admin-logo{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;margin-bottom:32px;letter-spacing:1px}
.admin-tabs{display:flex;flex-direction:column;gap:0}
.admin-tab{padding:12px 16px;cursor:pointer;border-radius:8px;margin-bottom:8px;font-size:14px;font-weight:500;color:#999;background:none;border:none;text-align:left;transition:all .2s}
.admin-tab:hover{background:rgba(255,255,255,0.08);color:#DDD}
.admin-tab.active{background:rgba(255,255,255,0.12);color:#FFFFFF;border-left:3px solid #C49B2C;padding-left:13px}
.admin-close-btn{position:absolute;bottom:24px;left:24px;background:none;border:none;color:#666;font-size:14px;cursor:pointer;padding:8px 12px}
.admin-close-btn:hover{color:#999}
.admin-content{flex:1;padding:32px;overflow-y:auto;background:#FAF9F6}
.admin-section{margin-bottom:32px}
.admin-section h3{font-family:'Cormorant Garamond',serif;font-size:20px;margin-bottom:16px;color:#1a1a1a}
.admin-section h4{font-size:14px;font-weight:600;margin-bottom:12px;color:#1a1a1a}
.admin-section p{font-size:13px;color:#6B6B6B;line-height:1.6;margin-bottom:12px}
.admin-input{border:1px solid #ddd;padding:10px 12px;border-radius:6px;font-size:14px;width:100%;max-width:250px;font-family:inherit;color:#1a1a1a}
.admin-input:focus{outline:none;border-color:#8B6914;box-shadow:0 0 0 3px rgba(139,105,20,0.1)}
.admin-btn{background:#1a1a1a;color:#FFFFFF;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}
.admin-btn:hover{background:#333}
.admin-btn.secondary{background:#E8E5DE;color:#1a1a1a}
.admin-btn.secondary:hover{background:#D4D0C8}
.admin-radio-group{display:flex;gap:16px;margin-bottom:16px}
.admin-radio{display:flex;align-items:center;gap:8px;cursor:pointer}
.admin-radio input{cursor:pointer;accent-color:#8B6914}
.admin-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer;margin-bottom:12px;font-size:14px}
.admin-checkbox input{cursor:pointer;accent-color:#8B6914;width:18px;height:18px}
.admin-table{width:100%;border-collapse:collapse;margin-top:12px;font-size:13px}
.admin-table th,.admin-table td{padding:12px 14px;border-bottom:1px solid #eee;text-align:left}
.admin-table th{background:#f0ede5;font-weight:600;color:#1a1a1a}
.admin-table tbody tr:hover{background:#f7f5f0}
.admin-table .price-col{font-family:'Cormorant Garamond',serif;font-size:16px;color:#8B6914;font-weight:600}
.admin-preview{background:#f0ede5;padding:12px 14px;border-radius:6px;margin-top:12px;font-size:13px;color:#6B6B6B}
.admin-search{width:100%;max-width:300px;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;margin-bottom:16px}
.admin-product-row{border:1px solid #eee;padding:16px;margin-bottom:12px;border-radius:6px;background:#FFFFFF}
.admin-product-row h5{font-size:14px;font-weight:600;margin-bottom:10px;color:#1a1a1a}
.admin-price-edit{display:flex;gap:10px;align-items:center;margin-bottom:8px;font-size:13px}
.admin-price-edit input{width:80px;padding:6px 8px;border:1px solid #ddd;border-radius:4px;font-size:12px}
.admin-price-edit button{padding:6px 12px;font-size:12px;background:#f0ede5;border:none;border-radius:4px;cursor:pointer;color:#1a1a1a}
.admin-price-edit button:hover{background:#e8e3da}
.src-link{position:absolute;bottom:10px;right:10px;background:#1a1a1a;color:#FAF9F6;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:12px;opacity:.7;transition:all .2s;z-index:10}
.src-link:hover{opacity:1;transform:scale(1.1)}

/* ===================== ADMIN MOBILE ===================== */
@media(max-width:800px){
  .admin-overlay{flex-direction:column;overflow-y:auto}
  .admin-sidebar{width:100%;padding:14px 16px;box-shadow:0 2px 8px rgba(0,0,0,0.15);position:sticky;top:0;z-index:5;flex-shrink:0}
  .admin-sidebar h2,.admin-sidebar .admin-logo{font-size:16px;margin-bottom:12px}
  .admin-tabs{flex-direction:row;overflow-x:auto;gap:6px;-webkit-overflow-scrolling:touch;padding-bottom:4px;margin:0 -4px;padding-left:4px;padding-right:4px}
  .admin-tabs::-webkit-scrollbar{height:0}
  .admin-tab{flex-shrink:0;padding:8px 14px;font-size:13px;margin-bottom:0;white-space:nowrap;border-radius:6px}
  .admin-tab.active{border-left:none;border-bottom:3px solid #C49B2C;padding-left:14px;border-radius:6px 6px 0 0}
  .admin-close-btn{position:static;margin-top:10px;padding:8px 12px;background:rgba(255,255,255,0.06);border-radius:6px;width:100%;text-align:center}
  .admin-content{padding:18px 14px;flex:1 1 auto}
  .admin-input{max-width:100%;width:100%;font-size:16px;padding:11px 12px}
  .admin-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;font-size:12px;white-space:nowrap}
  .admin-table th,.admin-table td{padding:9px 10px}
  .admin-product-row{padding:14px 12px;margin-bottom:10px}
  .admin-product-row h5{font-size:13px}
  .admin-price-edit{flex-wrap:wrap;gap:6px;font-size:12px}
  .admin-price-edit input{width:72px;font-size:14px;padding:7px 8px}
  .admin-price-edit button{padding:7px 12px;font-size:13px}
  .admin-content h2,.admin-content h3{font-size:18px}
  .admin-content > div,.admin-content > section{max-width:100%;overflow-x:hidden}
}

/* ========== SKU on cards / modal ========== */
.product-sku{color:var(--accent);font-weight:500;font-size:11px;letter-spacing:.5px;margin-left:4px;white-space:nowrap}
.modal-sku{display:inline-block;margin:6px 0 12px;padding:4px 10px;background:var(--accent-bg);color:var(--accent);border-radius:3px;font-size:12px;font-weight:500;letter-spacing:.5px}
.modal-sku strong{font-weight:600}

/* ========== NAV SEARCH TRIGGER ========== */
.nav-search{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-sm);background:transparent;color:var(--text2);border:1px solid var(--border);transition:all .2s;cursor:pointer;margin-left:4px}
.nav-search:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}

/* ========== SEARCH OVERLAY ========== */
.search-overlay{position:fixed;inset:0;background:rgba(12,10,6,0.72);backdrop-filter:blur(4px);z-index:9500;display:flex;align-items:flex-start;justify-content:center;padding:80px 20px 40px;animation:searchFadeIn .2s ease}
@keyframes searchFadeIn{from{opacity:0}to{opacity:1}}
.search-panel{background:var(--card);width:100%;max-width:820px;max-height:calc(100vh - 120px);border-radius:var(--radius);box-shadow:0 24px 80px rgba(0,0,0,0.45);display:flex;flex-direction:column;overflow:hidden;animation:searchSlideDown .25s ease}
@keyframes searchSlideDown{from{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}
.search-bar{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border);flex-shrink:0}
.search-bar-icon{color:var(--accent);flex-shrink:0}
.search-bar input{flex:1;border:none;outline:none;font-size:18px;font-family:inherit;color:var(--text);background:transparent;padding:4px 0}
.search-bar input::placeholder{color:var(--text3)}
.search-close{background:transparent;border:none;color:var(--text3);font-size:28px;cursor:pointer;padding:0 6px;line-height:1;transition:color .2s}
.search-close:hover{color:var(--text)}
.search-results{padding:18px 20px 22px;overflow-y:auto;flex:1}
.search-empty{text-align:center;color:var(--text2);font-size:14px;padding:40px 20px;line-height:1.7}
.search-empty code{background:var(--accent-bg);color:var(--accent);padding:2px 8px;border-radius:3px;font-size:12px;font-weight:500}
.search-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3);margin:4px 0 12px;display:flex;align-items:center;gap:8px}
.search-count{color:var(--accent);font-weight:500}
.search-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.search-cat-pill{background:var(--accent-bg);color:var(--accent);border:1px solid transparent;border-radius:999px;padding:7px 14px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}
.search-cat-pill:hover{border-color:var(--accent);background:#fff}
.search-cat-pill span{opacity:.65;margin-left:4px}
.search-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:10px}
.search-result{display:flex;gap:12px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;cursor:pointer;text-align:left;transition:all .2s;font-family:inherit;align-items:center}
.search-result:hover{border-color:var(--accent);background:var(--accent-bg)}
.search-result-img{width:56px;height:56px;flex-shrink:0;background:var(--bg);border-radius:3px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.search-result-img img{max-width:100%;max-height:100%;object-fit:contain}
.search-result-body{flex:1;min-width:0}
.search-result-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-meta{font-size:11px;color:var(--text2);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-result-price{font-size:13px;color:var(--accent);font-weight:600}

/* ========== TYPE TABS (Interior / Exterior) ========== */
.type-tabs{display:flex;gap:0;margin:0 0 28px;border-bottom:1px solid var(--border);overflow:hidden;flex-wrap:wrap}
.type-tab{background:transparent;border:none;padding:14px 24px;font-size:14px;font-weight:500;color:var(--text2);cursor:pointer;font-family:inherit;position:relative;transition:color .2s;white-space:nowrap;letter-spacing:.2px}
.type-tab:hover{color:var(--text)}
.type-tab.active{color:var(--text)}
.type-tab.active::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--accent);border-radius:1px}
.type-tab-count{display:inline-block;margin-left:6px;background:var(--accent-bg);color:var(--accent);padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}

/* ========== CATEGORY TYPE BADGE ========== */
.cat-grid-img{position:relative}
.cat-type-badge{position:absolute;top:10px;left:10px;background:rgba(255,255,255,0.94);backdrop-filter:blur(6px);color:var(--text);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;padding:4px 10px;border-radius:3px;border:1px solid rgba(0,0,0,0.06)}
.cat-type-interior{color:#2D5E3E;border-color:rgba(45,94,62,0.2)}
.cat-type-exterior{color:#8B2E1F;border-color:rgba(139,46,31,0.2)}

/* ========== CATALOG FILTERS ========== */
.catalog-layout{display:flex;gap:28px;margin-top:20px}
.catalog-filters{width:230px;flex-shrink:0;align-self:flex-start;padding-right:8px}
.catalog-products{flex:1;min-width:0}
.filter-group{margin-bottom:20px}
.filter-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text2);margin-bottom:8px}
.filter-options{display:flex;flex-wrap:wrap;gap:6px}
.filter-chip{display:inline-block;padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:var(--card);font-size:12px;font-family:inherit;color:var(--text);cursor:pointer;transition:all .2s;white-space:nowrap}
.filter-chip:hover{border-color:var(--accent);color:var(--accent)}
.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.filter-clear{display:block;width:100%;padding:8px;border:1px solid var(--border);border-radius:8px;background:var(--bg);font-size:12px;font-family:inherit;color:var(--text2);cursor:pointer;margin-bottom:16px;transition:all .2s}
.filter-clear:hover{border-color:#c00;color:#c00}
.filter-toggle{display:none;width:100%;padding:10px 16px;border:1px solid var(--border);border-radius:8px;background:var(--card);font-size:13px;font-weight:500;font-family:inherit;color:var(--text);cursor:pointer;margin-top:12px;text-align:center;gap:8px;align-items:center;justify-content:center}
.filter-toggle svg{vertical-align:middle;margin-left:6px}
.no-results{text-align:center;padding:60px 20px}
.no-results h3{font-size:20px;margin-bottom:8px;color:var(--text)}
.no-results p{font-size:14px;color:var(--text2);margin-bottom:20px}
.popular-badge{position:absolute;top:8px;right:8px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:10px;z-index:2}
.popular-chip{font-weight:600;color:var(--accent)}
.popular-chip.active{background:var(--accent);color:#fff}
.admin-popular-toggle{position:absolute;bottom:8px;right:8px;z-index:3;background:rgba(255,255,255,0.92);border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:10px;font-family:inherit;color:var(--text2);cursor:pointer;display:flex;align-items:center;gap:4px}
.admin-popular-toggle input{margin:0}
.load-more-wrap{text-align:center;padding:32px 0 16px}
.load-more-btn{background:var(--card);border:1.5px solid var(--accent);color:var(--accent);font-family:inherit;font-size:15px;font-weight:600;padding:12px 36px;border-radius:8px;cursor:pointer;transition:all .2s}
.load-more-btn:hover{background:var(--accent);color:#fff}
.load-more-count{font-weight:400;font-size:13px;opacity:.7}
.load-more-done{font-size:13px;color:var(--text2)}
.product-attrs{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.attr-tag{font-size:10px;padding:2px 7px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--text2);line-height:1.3}
.attr-glass{color:#2e7d32;border-color:#c8e6c9;background:#f1f8e9}
.attr-style{color:#5d4037;border-color:#d7ccc8;background:#efebe9}
.admin-attrs-editor{background:rgba(255,255,255,0.92);border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin:8px 0;display:flex;flex-wrap:wrap;gap:8px}
.admin-attr-row{display:flex;flex-direction:column;gap:2px;flex:1;min-width:100px}
.admin-attr-row label{font-size:10px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.admin-attr-row select{font-family:inherit;font-size:13px;padding:4px 6px;border:1px solid var(--border);border-radius:5px;background:var(--card);color:var(--text);cursor:pointer}

@media(max-width:800px){
  .filter-toggle{display:flex}
  .catalog-layout{flex-direction:column;gap:0}
  .catalog-filters{display:none;width:100%;position:static;max-height:none;padding:16px;background:var(--card);border:1px solid var(--border);border-radius:10px;margin-bottom:16px}
  .catalog-filters.open{display:block}
}

@media(max-width:700px){
  .search-overlay{padding:60px 12px 20px}
  .search-panel{max-height:calc(100vh - 80px)}
  .search-bar input{font-size:16px}
  .search-results-grid{grid-template-columns:1fr}
  .type-tab{padding:12px 16px;font-size:13px}
  .nav-search{margin-left:auto}
}

/* ===== LIVE CARTS (admin) ===== */
.carts-stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}
.carts-stat-num{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:500;color:var(--text);line-height:1.1}
.carts-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#6B6B6B;margin-top:4px}
.carts-list{display:flex;flex-direction:column;gap:12px}
.cart-row{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}
.cart-row-named{border-left:3px solid #C49B2C}
.cart-row-anon{border-left:3px solid #D0D0D0}
.cart-row-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.cart-row-title{font-weight:600;font-size:15px;color:var(--text)}
.cart-tag{font-size:10px;text-transform:uppercase;letter-spacing:0.5px;padding:3px 8px;border-radius:3px;font-weight:500}
.cart-tag-named{background:rgba(196,155,44,0.15);color:#8a6a15}
.cart-tag-anon{background:rgba(0,0,0,0.06);color:#6B6B6B}
.cart-row-updated{margin-left:auto;font-size:12px;color:#6B6B6B}
.cart-del-btn{background:transparent;border:1px solid var(--border);color:#6B6B6B;width:26px;height:26px;border-radius:3px;cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0}
.cart-del-btn:hover{background:#FEF2F2;color:#991B1B;border-color:#FCA5A5}
.cart-row-contact{font-size:13px;color:#444;margin-bottom:10px}
.cart-row-contact a{color:var(--accent,#C49B2C);text-decoration:none}
.cart-row-contact a:hover{text-decoration:underline}
.cart-row-items{border-top:1px dashed var(--border);padding-top:10px;display:flex;flex-direction:column;gap:4px}
.cart-line{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;font-size:13px;align-items:center}
.cart-line-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cart-line-size{color:#6B6B6B;font-size:12px}
.cart-line-price{color:var(--text);font-variant-numeric:tabular-nums;min-width:70px;text-align:right}
.cart-line-src{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;background:var(--accent-bg);color:var(--accent);font-size:11px;font-weight:600;text-decoration:none;border:1px solid transparent;transition:all .18s;white-space:nowrap}
.cart-line-src:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-1px)}
.cart-line-src svg{flex-shrink:0}
.cart-row-foot{display:flex;align-items:center;gap:12px;justify-content:space-between;border-top:1px solid var(--border);margin-top:10px;padding-top:10px;font-size:13px;color:#6B6B6B}
.cart-row-total{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--text)}
@media(max-width:700px){
  .cart-row-updated{width:100%;margin-left:0;order:5}
  .cart-line{grid-template-columns:1fr auto;row-gap:6px}
  .cart-line-size{grid-column:1/-1;margin-top:-2px}
  .cart-line-src{grid-column:1/-1;justify-self:start;margin-top:2px}
}

/* ===== Shipping page ===== */
.ship-hero{text-align:center;padding:40px 0 48px;border-bottom:1px solid var(--border);margin-bottom:56px}
.ship-hero-eyebrow{font-size:12px;font-weight:600;letter-spacing:2.4px;color:var(--accent);margin-bottom:18px}
.ship-hero-title{font-size:52px;font-weight:400;line-height:1.1;margin-bottom:20px;color:var(--text)}
.ship-hero-title em{font-style:italic;color:var(--accent2)}
.ship-hero-sub{font-size:17px;color:var(--text2);max-width:600px;margin:0 auto;line-height:1.7}

.ship-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:64px}
.ship-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;text-align:center;position:relative;transition:all .3s ease}
.ship-card:hover{border-color:var(--accent2);transform:translateY(-4px);box-shadow:0 16px 40px rgba(139,105,20,.12)}
.ship-card-free{background:linear-gradient(180deg,#FFFBF2 0%,var(--card) 100%);border-color:var(--accent2)}
.ship-card-icon{width:80px;height:80px;border-radius:50%;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 22px}
.ship-card-free .ship-card-icon{background:rgba(196,155,44,.15);color:var(--accent2)}
.ship-card-label{font-size:11px;font-weight:600;letter-spacing:1.8px;color:var(--text3);margin-bottom:14px}
.ship-card-label-free{color:var(--accent2)}
.ship-card-price{font-family:'Cormorant Garamond',serif;font-size:56px;font-weight:500;color:var(--text);line-height:1;margin-bottom:18px}
.ship-card-free .ship-card-price{color:var(--accent2)}
.ship-card-price span{display:block;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:400;color:var(--text2);letter-spacing:.3px;margin-top:8px}
.ship-card-desc{font-size:14px;color:var(--text2);line-height:1.7;max-width:320px;margin:0 auto}

.ship-section-title{font-size:36px;font-weight:400;margin-bottom:10px;color:var(--text);text-align:center}
.ship-section-sub{text-align:center;color:var(--text2);font-size:15px;max-width:540px;margin:0 auto 36px;line-height:1.6}

.ship-area{margin-bottom:72px}
.ship-area-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:28px}
.ship-area-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px 30px}
.ship-area-card h3{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:500;color:var(--accent);margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.ship-area-card ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 20px}
.ship-area-card li{font-size:14px;color:var(--text2);padding-left:16px;position:relative;line-height:1.5}
.ship-area-card li::before{content:'';position:absolute;left:0;top:7px;width:6px;height:6px;background:var(--accent2);border-radius:50%}
.ship-area-note{text-align:center;font-size:14px;color:var(--text2);line-height:1.7;max-width:640px;margin:0 auto}
.ship-area-note a{color:var(--accent);font-weight:500;border-bottom:1px solid var(--accent2);transition:color .2s}
.ship-area-note a:hover{color:var(--accent2)}

.ship-how{margin-bottom:72px}
.ship-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ship-step{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;position:relative;transition:all .3s ease}
.ship-step:hover{border-color:var(--accent2);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.ship-step-num{font-family:'Cormorant Garamond',serif;font-size:40px;font-weight:500;color:var(--accent2);line-height:1;margin-bottom:14px}
.ship-step h4{font-size:17px;font-weight:600;margin-bottom:10px;color:var(--text)}
.ship-step p{font-size:14px;color:var(--text2);line-height:1.7}

.ship-faq{max-width:760px;margin:0 auto 24px}
.ship-faq-item{border-bottom:1px solid var(--border);padding:22px 4px;cursor:pointer;transition:background .2s}
.ship-faq-item:hover{background:rgba(245,240,227,.3)}
.ship-faq-item summary{font-size:16px;font-weight:500;color:var(--text);list-style:none;display:flex;justify-content:space-between;align-items:center;padding-right:8px}
.ship-faq-item summary::-webkit-details-marker{display:none}
.ship-faq-item summary::after{content:'+';font-family:'Cormorant Garamond',serif;font-size:28px;color:var(--accent2);font-weight:400;transition:transform .25s;line-height:1}
.ship-faq-item[open] summary::after{transform:rotate(45deg)}
.ship-faq-item p{margin-top:14px;font-size:14px;color:var(--text2);line-height:1.75;padding-right:32px}

@media(max-width:800px){
  .ship-hero{padding:24px 0 32px;margin-bottom:40px}
  .ship-hero-title{font-size:34px}
  .ship-hero-sub{font-size:15px}
  .ship-cards{grid-template-columns:1fr;gap:18px;margin-bottom:48px}
  .ship-card{padding:32px 24px}
  .ship-card-price{font-size:46px}
  .ship-section-title{font-size:28px}
  .ship-area{margin-bottom:52px}
  .ship-area-grid{grid-template-columns:1fr;gap:16px}
  .ship-area-card{padding:22px 22px}
  .ship-area-card ul{grid-template-columns:1fr 1fr;gap:8px 14px}
  .ship-how{margin-bottom:52px}
  .ship-steps{grid-template-columns:1fr;gap:14px}
  .ship-step{padding:24px 22px}
  .ship-faq-item summary{font-size:15px}
}

@media(max-width:480px){
  .ship-hero-title{font-size:28px}
  .ship-card-price{font-size:40px}
  .ship-section-title{font-size:24px}
  .ship-area-card ul{grid-template-columns:1fr}
}

/* ===== Save cart as image ===== */
.btn-save-cart{
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:var(--text);
  border:1.5px solid var(--accent2);
  padding:14px 24px;border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;
  letter-spacing:.4px;text-transform:uppercase;
  cursor:pointer;transition:all .25s ease;
}
.btn-save-cart:hover{
  background:var(--accent2);color:#fff;
  box-shadow:0 8px 20px rgba(196,155,44,.25);
  transform:translateY(-1px);
}

.cart-img-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:cartImgFadeIn .25s ease}
@keyframes cartImgFadeIn{from{opacity:0}to{opacity:1}}
.cart-img-modal-backdrop{position:absolute;inset:0;background:rgba(20,18,14,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.cart-img-modal-box{
  position:relative;background:var(--bg);
  border-radius:18px;max-width:520px;width:100%;
  max-height:92vh;overflow:hidden;display:flex;flex-direction:column;
  box-shadow:0 30px 80px rgba(0,0,0,.45),0 0 0 1px rgba(196,155,44,.2);
  animation:cartImgPop .35s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes cartImgPop{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
.cart-img-modal-close{
  position:absolute;top:14px;right:14px;width:36px;height:36px;
  border-radius:50%;background:rgba(0,0,0,.06);border:none;
  font-size:24px;line-height:1;color:var(--text2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;z-index:2;
  transition:all .2s;
}
.cart-img-modal-close:hover{background:rgba(0,0,0,.12);color:var(--text);transform:rotate(90deg)}
.cart-img-modal-head{padding:28px 32px 14px;text-align:center}
.cart-img-modal-title{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--text);letter-spacing:.2px}
.cart-img-modal-sub{font-size:13px;color:var(--text2);margin-top:6px;line-height:1.5;max-width:380px;margin-left:auto;margin-right:auto}
.cart-img-modal-preview{padding:0 32px;overflow-y:auto;flex:1;min-height:0}
.cart-img-modal-preview img{
  display:block;width:100%;height:auto;
  border-radius:10px;
  box-shadow:0 12px 32px rgba(0,0,0,.18),0 0 0 1px var(--border);
}
.cart-img-modal-actions{padding:20px 32px 8px;display:flex;gap:10px}
.cart-img-btn{
  flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 18px;border-radius:var(--radius-sm);
  font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;
  cursor:pointer;border:1.5px solid transparent;transition:all .2s;
}
.cart-img-btn-primary{background:var(--accent2);color:#fff}
.cart-img-btn-primary:hover{background:var(--accent);box-shadow:0 8px 22px rgba(139,105,20,.35);transform:translateY(-1px)}
.cart-img-btn-ghost{background:transparent;color:var(--text);border-color:var(--border2)}
.cart-img-btn-ghost:hover{border-color:var(--text);background:rgba(0,0,0,.03)}
.cart-img-modal-hint{padding:6px 32px 24px;text-align:center;font-size:12px;color:var(--text3);line-height:1.5}
.cart-img-modal-hint strong{color:var(--accent)}
@media(max-width:520px){
  .cart-img-modal-head{padding:24px 20px 10px}
  .cart-img-modal-title{font-size:24px}
  .cart-img-modal-preview{padding:0 20px}
  .cart-img-modal-actions{padding:18px 20px 6px;flex-direction:column}
  .cart-img-modal-hint{padding:6px 20px 20px}
}
/* Contact buttons (WhatsApp / Telegram) */
.contact-btns{display:flex;gap:8px;margin:12px 0 10px;flex-wrap:wrap}
.contact-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.3px;text-decoration:none;color:#fff;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 2px 6px rgba(0,0,0,0.12)}
.contact-btn:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,0.18);color:#fff}
.contact-btn-wa{background:#25D366}
.contact-btn-wa:hover{background:#1fb855}
.contact-btn-tg{background:#229ED9}
.contact-btn-tg:hover{background:#1b88bb}
.contact-btn svg{flex:0 0 auto}
@media(max-width:520px){
  .contact-btn{padding:7px 12px;font-size:11px}
}
/* Prevent filter block from having its own scrollbar */
.type-tabs{overflow-y:visible!important;max-height:none!important}
/* Prevent horizontal swipe / overflow on mobile */
html,body{overflow-x:hidden;max-width:100vw}

/* ========== FLOATING CONTACT BUTTONS (WhatsApp / Telegram) ========== */
.floating-contacts{position:fixed;right:18px;bottom:22px;display:flex;flex-direction:column;gap:12px;z-index:9999;pointer-events:none}
.float-btn{pointer-events:auto;width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;box-shadow:0 6px 18px rgba(0,0,0,.22);transition:transform .18s ease,box-shadow .18s ease;will-change:transform}
.float-btn:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 10px 24px rgba(0,0,0,.28)}
.float-btn:active{transform:translateY(-1px) scale(1.02)}
.float-wa{background:#25D366}
.float-tg{background:#229ED9}
.float-btn svg{display:block}
@media(max-width:520px){
  .floating-contacts{right:12px;bottom:14px;gap:10px}
  .float-btn{width:48px;height:48px}
  .float-btn svg{width:24px;height:24px}
}

/* ========== SEO STATIC CONTENT (visible to crawlers + users) ========== */
.seo-content{max-width:1080px;margin:60px auto 80px;padding:0 40px;font-family:'DM Sans',sans-serif;color:var(--text)}
.seo-content section{margin-bottom:56px}
.seo-content h1{font-family:'Cormorant Garamond',serif;font-size:46px;font-weight:500;line-height:1.15;margin-bottom:20px;color:var(--text);letter-spacing:-.5px}
.seo-content h2{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:500;margin-bottom:18px;color:var(--text);letter-spacing:-.3px}
.seo-content .lead{font-size:18px;line-height:1.65;color:var(--text);max-width:760px;font-weight:400}
.seo-content p{font-size:15.5px;line-height:1.7;color:var(--text2);margin-bottom:14px;max-width:780px}
.seo-content ul{list-style:none;padding:0;margin-bottom:8px}
.seo-content ul li{font-size:15.5px;line-height:1.6;color:var(--text2);padding:10px 0 10px 28px;border-bottom:1px solid var(--border);position:relative}
.seo-content ul li::before{content:'';position:absolute;left:0;top:18px;width:14px;height:1px;background:var(--accent)}
.seo-content ul li:last-child{border-bottom:none}
.seo-content strong{color:var(--text);font-weight:600}
.seo-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
.seo-content a:hover{color:var(--accent2)}
.seo-content .seo-areas{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:20px}
.seo-content .seo-area-card{padding:20px 22px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm)}
.seo-content .seo-area-card h3{font-family:'DM Sans',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);font-weight:600;margin-bottom:10px}
.seo-content .seo-area-card p{font-size:14.5px;color:var(--text2);margin:0;line-height:1.6}
.seo-content details{border-bottom:1px solid var(--border);padding:18px 0;transition:background .15s}
.seo-content details:first-of-type{border-top:1px solid var(--border)}
.seo-content details summary{cursor:pointer;font-weight:500;font-size:16px;color:var(--text);list-style:none;display:flex;justify-content:space-between;align-items:center;padding-right:8px}
.seo-content details summary::-webkit-details-marker{display:none}
.seo-content details summary::after{content:'+';font-size:24px;color:var(--accent);font-weight:300;transition:transform .25s ease;line-height:1;margin-left:16px;flex-shrink:0}
.seo-content details[open] summary::after{transform:rotate(45deg)}
.seo-content details p{margin-top:14px;margin-bottom:6px}
.seo-content .seo-cta{background:var(--accent-bg);padding:48px 40px;border-radius:var(--radius);text-align:center;margin-top:80px;margin-bottom:0}
.seo-content .seo-cta h2{margin-bottom:14px}
.seo-content .seo-cta p{margin:0 auto 20px;max-width:560px;font-size:16px}
.seo-content .seo-cta .seo-tel{display:inline-block;font-family:'Cormorant Garamond',serif;font-size:32px;font-weight:500;color:var(--text);text-decoration:none;letter-spacing:.5px;margin:8px 0}
.seo-content .seo-cta .seo-tel:hover{color:var(--accent)}
.seo-content .seo-cta .seo-email{display:block;color:var(--text2);font-size:14px;margin-top:6px;text-decoration:none}
.seo-content .seo-cta .seo-email:hover{color:var(--accent)}
@media(max-width:768px){
  .seo-content{padding:0 24px;margin:40px auto 60px}
  .seo-content h1{font-size:32px;letter-spacing:-.3px}
  .seo-content h2{font-size:24px}
  .seo-content .lead{font-size:16px}
  .seo-content .seo-cta{padding:36px 24px;margin-top:56px}
  .seo-content .seo-cta .seo-tel{font-size:26px}
}

</style>

</style>
</head>
<body>

<div id="app"></div>

<script>
// ===================== DATA =====================
// Slug to category ID mapping
const COVER_MAP = {
  'entry-doors': 'classicentriesmahoga',
  'contemporary': 'moderncontemporary',
  'entry-doors-7-foot': 'entrydoors84tall',
  'artistic-glass': 'artisticbeveledglass',
  'southwest-rustic': 'southwestrusticsanta',
  'carved-doors': 'handcarveddoors',
  'artistic-beveled-glass-84-tall': 'artisticdoors84tall',
  'contractor-doors': 'buildercontractordoo',
  '2-new-world-2': 'newworlddoors',
  'iron-doors': 'irondoorsfrenchiron',
  'grand-entrance': 'grandentrancemansion',
  'interior-doors': 'interiordoors80tall',
  'decorative-iron-wood': 'decorativeironwood',
  'modern-interior': 'interiordoorsmodern',
  'premium-interior-doors-8-0-tall': 'interiordoors96tall',
  'fiberglass-entry-doors': 'fiberglassprehungent',
  'shaker-style-interior': 'interiordoorsshakers',
  'arch-and-segment': 'archsegmententries',
  'mega-doors-2': 'megaextralargedoors',
  'barn-doors': 'barndoorseclectic',
  'art-nouveau-2': 'artnouveau19thcentur',
  '7-0-interior': 'interiordoors84tall',
  'retro-doors': 'retrodoorsrustic',
  'entry-doors-red-oak': 'entriesamericanredoa',
  'bamboo-doors': 'interiordoorsbamboo',
  'arts-and-crafts': 'artscraftscraftsman',
  'french-doors': 'frenchpatiodutchdoor',
  'interior-doors-decor-glass': 'interiordoorsdecorgl',
  'ethnic-carved-doors': 'ethnictribalcarveddo',
  'white-oak-exterior-modern': 'whiteoakexteriormode',
  'interior-doors-white-oak': 'interiordoorswhiteoa',
  'interior-doors-walnut': 'interiordoorswalnut',
  'interior-doors-shaker-delux': 'interiordoorsshakerd',
  'interior-doors-white-lami': 'interiordoorswhitela',
  'rustic-contemporary': 'rusticcontemporaryfl',
  'walnut-exterior': 'walnutexteriormodern',
  'interior-doors-shaker-7-foot': 'interiorshaker84tall',
  'moroccan-doors': 'moroccanmoorishdoors',
  'asian-pacific-doors': 'asiansouthpacificdoo',
  'mediterranean-doors': 'mediterraneanspanish'
};

// Data is loaded dynamically from /data/products.json and /data/categories.json
let CATEGORIES = [];
let PRODUCTS = [];

// Load product and category data on startup
async function loadProductData() {
  try {
    const [catsRes, prodsRes] = await Promise.all([
      fetch('/data/categories.json'),
      fetch('/data/products.json')
    ]);
    CATEGORIES = await catsRes.json();
    PRODUCTS = await prodsRes.json();
    initMarkups();
    render();
  } catch (error) {
    console.error('Failed to load product data:', error);
    alert('Error loading product catalog. Please refresh the page.');
  }
}


const PREHUNG = {
  type:[{id:'slab',name:'Slab only (no frame)',price:0},{id:'sl',name:'Single / Left swing',price:350},{id:'sr',name:'Single / Right swing',price:350},{id:'dl',name:'Double / Left active',price:650},{id:'dr',name:'Double / Right active',price:650}],
  jamb:[{id:'j1',name:'4-9/16"',price:0},{id:'j2',name:'5-1/4"',price:40},{id:'j3',name:'6-9/16"',price:75},{id:'j4',name:'Custom',price:120}],
  hinges:[{id:'h1',name:'Satin Nickel',price:0},{id:'h2',name:'Oil Rubbed Bronze',price:35},{id:'h3',name:'Matte Black',price:35},{id:'h4',name:'Antique Brass',price:45}],
  threshold:[{id:'t0',name:'None (interior)',price:0},{id:'t1',name:'Oak Adjustable',price:65},{id:'t2',name:'Aluminum',price:85},{id:'t3',name:'Marble',price:150}],
  weather:[{id:'w0',name:'None',price:0},{id:'w1',name:'Standard Seal',price:45},{id:'w2',name:'Premium Q-Lon',price:85}]
};

const FINISHES = [
  {id:'none',name:'Unfinished',price:0},{id:'natural',name:'Natural Clear',price:195},{id:'dw',name:'Dark Walnut',price:245},
  {id:'ebony',name:'Ebony',price:245},{id:'white',name:'White Paint',price:275},{id:'custom',name:'Custom Color',price:350}
];

// ===================== STATE =====================
let S = {page:'home',filter:'all',catView:null,modal:null,selSize:null,ph:{type:'slab',jamb:'j1',hinges:'h1',threshold:'t0',weather:'w0'},finish:'none',cart:[],cartOpen:false,admin:false,adminTab:'prices',showSrcLinks:false,checkoutMode:false,checkoutData:{fullName:'',email:'',phone:'',street:'',city:'',state:'',zip:''},orderConfirmed:false,lastOrderId:null,selectedOrder:null,adminToken:sessionStorage.getItem('ud_admin_token')||null,_cachedOrders:[],_ordersLoaded:false,_ordersLoading:false};
const fmt = n => '$'+n.toLocaleString();
const minPrice = p => { const vals=Object.values(p.prices).filter(v=>v>0); return vals.length?Math.min(...vals):0; };
const find = (arr,id) => arr.find(x=>x.id===id);

function doorSVG(color,glass,w=80,h=180){
  const gw=Math.round(w*.3),gh=Math.round(h*.45),gx=Math.round((w-gw)/2),gy=Math.round(h*.12);
  let s=`<svg width="${w}" height="${h}" viewBox="0 0 ${w} ${h}" xmlns="http://www.w3.org/2000/svg">`;
  s+=`<defs><linearGradient id="dg${w}" x1="0" y1="0" x2="1" y2="1"><stop offset="0%" stop-color="rgba(255,255,255,0.06)"/><stop offset="100%" stop-color="rgba(0,0,0,0.1)"/></linearGradient></defs>`;
  s+=`<rect x="0" y="0" width="${w}" height="${h}" rx="4" fill="${color}"/>`;
  s+=`<rect x="0" y="0" width="${w}" height="${h}" rx="4" fill="url(#dg${w})"/>`;
  s+=`<rect x="4" y="4" width="${w-8}" height="${h-8}" rx="2" fill="none" stroke="rgba(255,255,255,0.07)" stroke-width="1"/>`;
  if(glass==='clear'){
    s+=`<rect x="${gx}" y="${gy}" width="${gw}" height="${gh}" rx="3" fill="rgba(180,215,240,0.28)"/>`;
    s+=`<rect x="${gx}" y="${gy}" width="${gw}" height="${gh}" rx="3" fill="none" stroke="rgba(255,255,255,0.12)"/>`;
    s+=`<line x1="${gx+2}" y1="${gy+2}" x2="${gx+gw-2}" y2="${gy+gh-2}" stroke="rgba(255,255,255,0.08)" stroke-width="0.5"/>`;
  } else if(glass==='frosted'){
    s+=`<rect x="${gx}" y="${gy}" width="${gw}" height="${gh}" rx="3" fill="rgba(225,225,225,0.32)"/>`;
    s+=`<rect x="${gx}" y="${gy}" width="${gw}" height="${gh}" rx="3" fill="none" stroke="rgba(255,255,255,0.08)"/>`;
  } else if(glass==='decorative'){
    s+=`<rect x="${gx}" y="${gy}" width="${gw}" height="${gh}" rx="3" fill="rgba(180,215,240,0.18)"/>`;
    const cx=gx+gw/2,cy=gy+gh/2,r=Math.min(gw,gh)*.28;
    s+=`<circle cx="${cx}" cy="${cy}" r="${r}" fill="none" stroke="rgba(255,255,255,0.14)" stroke-width="1"/>`;
    s+=`<circle cx="${cx}" cy="${cy}" r="${r*.5}" fill="none" stroke="rgba(255,255,255,0.08)" stroke-width="0.5"/>`;
  }
  // panels for no-glass doors
  if(!glass){
    const pw=Math.round(w*.6),ph2=Math.round(h*.2),px=Math.round((w-pw)/2);
    s+=`<rect x="${px}" y="${Math.round(h*.1)}" width="${pw}" height="${ph2}" rx="2" fill="none" stroke="rgba(255,255,255,0.05)" stroke-width="1"/>`;
    s+=`<rect x="${px}" y="${Math.round(h*.38)}" width="${pw}" height="${Math.round(h*.3)}" rx="2" fill="none" stroke="rgba(255,255,255,0.05)" stroke-width="1"/>`;
  }
  s+=`<circle cx="${w-12}" cy="${Math.round(h*.52)}" r="3.5" fill="rgba(210,185,130,0.55)"/>`;
  s+=`<circle cx="${w-12}" cy="${Math.round(h*.52)}" r="1.5" fill="rgba(255,255,255,0.15)"/>`;
  s+=`</svg>`;
  return s;
}

// ===================== RENDER ENGINE =====================
function render(){
  let h='';
  h+=renderTopbar();
  h+=renderHeader();
  if(S.page==='home') h+=renderHome();
  else if(S.page==='catalog') h+=renderCatalog();
  else if(S.page==='pricing') h+=renderPricing();
  else if(S.page==='prehung') h+=renderPrehungGuide();
  h+=renderFooter();
  h+=renderModal();
  h+=renderCartPanel();
  h+=renderAdmin();
  // Save modal scroll position before re-render
  const modalScroll=document.querySelector('.modal-scroll');
  const savedScroll=modalScroll?modalScroll.scrollTop:0;
  document.getElementById('app').innerHTML=h;
  // Restore modal scroll position
  if(savedScroll>0){
    const ms=document.querySelector('.modal-scroll');
    if(ms) ms.scrollTop=savedScroll;
  }
  // Bind catType radio listeners for admin panel currency toggle
  document.querySelectorAll("input[name='catType']").forEach(r=>r.addEventListener("change",e=>{
    const el=document.getElementById("catCurrency");
    if(el) el.textContent=e.target.value==="percent"?"%":"$";
  }));
}

