.cfg-hero{padding:80px 0 30px;background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%)}
.cfg-hero h1{margin:14px 0 16px}.cfg-hero h1 em{color:var(--terra);font-style:italic}
.cfg-hero p{max-width:620px;color:var(--ink-2);font-size:1.08rem}
.cfg-wrap{padding:30px 0 100px}
.cfg-tabs{display:flex;gap:10px;background:var(--cream);padding:8px;border-radius:999px;width:fit-content;margin:0 auto 36px;box-shadow:var(--shadow)}
.cfg-tab{background:none;border:none;padding:14px 32px;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;color:var(--ink-2);transition:all .25s;font-family:inherit}
.cfg-tab.active{background:var(--ink);color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.cfg-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:36px;align-items:start}
@media(max-width:960px){.cfg-grid{grid-template-columns:1fr}}
.cfg-preview{position:sticky;top:100px;display:flex;flex-direction:column;gap:24px}
.cfg-room{position:relative;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);background:#2b221b;perspective:900px}
.cfg-room-walls{position:absolute;inset:0;background:linear-gradient(180deg,#f3ebdd 0%,#e6dcc8 55%,transparent 55%);}
.cfg-room-walls::after{content:"";position:absolute;left:0;right:0;top:55%;height:1px;background:rgba(0,0,0,.08)}
.cfg-room-floor{position:absolute;left:-10%;right:-10%;bottom:0;height:48%;transform:rotateX(58deg);transform-origin:top;background:var(--floor-c,#c9a06b);background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.18) 0 1px,transparent 1px 78px),repeating-linear-gradient(0deg,rgba(0,0,0,.1) 0 1px,transparent 1px 14px),linear-gradient(180deg,rgba(255,255,255,.1),transparent 40%);box-shadow:inset 0 30px 60px rgba(0,0,0,.25);transition:background-color .4s}
.cfg-room-furn{position:absolute;left:50%;bottom:18%;transform:translateX(-50%);font-size:3rem;filter:drop-shadow(0 8px 14px rgba(0,0,0,.3))}
.cfg-stair{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);background:linear-gradient(180deg,#f3ebdd,#e6dcc8);display:flex;align-items:flex-end;justify-content:center;padding:30px}
.cfg-stair-stack{display:flex;flex-direction:column-reverse;gap:0}
.cfg-stair-stack .step{width:var(--w,180px);height:14px;background:var(--floor-c,#c9a06b);border-top:2px solid rgba(0,0,0,.2);box-shadow:0 2px 0 rgba(0,0,0,.15)}
.cfg-summary{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.cfg-summary h3{font-size:1.1rem;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.cfg-summary ul{list-style:none;margin:0 0 18px}
.cfg-summary li{display:flex;justify-content:space-between;padding:7px 0;font-size:.9rem;color:var(--ink-2)}
.cfg-summary li strong{color:var(--ink)}
.cfg-total{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-top:2px solid var(--ink);margin-bottom:14px}
.cfg-total strong{font-family:'Fraunces',serif;font-size:1.7rem;color:var(--terra)}
.cfg-summary .btn{width:100%;margin-bottom:10px}
.cfg-summary small{display:block;text-align:center;color:var(--ink-2);font-size:.78rem}
.cfg-steps{display:flex;flex-direction:column;gap:22px}
.cfg-step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.cfg-step h3{display:flex;align-items:center;gap:14px;font-size:1.15rem;margin-bottom:18px}
.cfg-step h3 span{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;background:var(--terra);color:#fff;font-family:'Inter',sans-serif;font-size:.9rem;font-weight:700}
.cfg-opts{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.cfg-opts-row{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}
.cfg-opts button{background:var(--bg);border:2px solid var(--line);border-radius:12px;padding:16px 14px;cursor:pointer;font-family:inherit;font-weight:600;color:var(--ink);transition:all .2s;display:flex;flex-direction:column;gap:4px;text-align:center;font-size:.92rem}
.cfg-opts button small{font-weight:400;color:var(--ink-2);font-size:.78rem}
.cfg-opts button:hover{border-color:var(--wood);background:var(--cream)}
.cfg-opts button.sel{border-color:var(--terra);background:#fff;box-shadow:0 0 0 4px rgba(201,97,63,.12)}
.cfg-decors{display:grid;grid-template-columns:repeat(auto-fit,minmax(95px,1fr));gap:10px}
.cfg-decors button{background:var(--d);border:3px solid transparent;border-radius:12px;padding:50px 8px 10px;cursor:pointer;color:#fff;font-weight:600;font-size:.78rem;text-shadow:0 1px 3px rgba(0,0,0,.5);transition:all .2s;font-family:inherit;background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.18) 0 1px,transparent 1px 22px),repeating-linear-gradient(0deg,rgba(0,0,0,.1) 0 1px,transparent 1px 8px)}
.cfg-decors button.sel{border-color:var(--terra);transform:scale(1.04);box-shadow:0 6px 18px rgba(0,0,0,.2)}
.cfg-m2{display:flex;align-items:center;gap:20px;margin-bottom:14px}
.cfg-m2 input{flex:1;accent-color:var(--terra)}
.cfg-m2-val strong{font-family:'Fraunces',serif;font-size:2rem;color:var(--terra)}
.cfg-rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.cfg-rooms button{background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:12px;cursor:pointer;font-family:inherit;font-weight:600;font-size:.85rem;display:flex;flex-direction:column;gap:2px}
.cfg-rooms button small{font-weight:400;color:var(--ink-2);font-size:.75rem}
.cfg-rooms button:hover{background:var(--wood);color:#fff}
/* Cookie banner */
.cookie-banner{position:fixed;bottom:20px;left:20px;right:20px;max-width:540px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-lg);z-index:9999;display:none}
.cookie-banner.show{display:block;animation:slideUp .4s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner h4{font-family:'Fraunces',serif;font-size:1.2rem;margin-bottom:8px}
.cookie-banner p{font-size:.88rem;color:var(--ink-2);margin-bottom:14px}
.cookie-banner a{color:var(--terra);text-decoration:underline}
.cookie-actions{display:flex;gap:8px;flex-wrap:wrap}
.cookie-actions .btn{padding:11px 18px;font-size:.85rem}
.cookie-cats{display:none;margin:14px 0;padding:14px;background:var(--bg);border-radius:10px;font-size:.85rem}
.cookie-cats.show{display:block}
.cookie-cats label{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--line)}
.cookie-cats label:last-child{border-bottom:none}

/* Quote modal */
.cfg-modal{position:fixed;inset:0;background:rgba(25,15,8,.75);backdrop-filter:blur(6px);z-index:9998;display:grid;place-items:center;padding:20px;animation:fadeUp .3s ease}
.cfg-modal[hidden]{display:none}
.cfg-modal-panel{background:#fff;border-radius:var(--radius);padding:36px 32px;max-width:460px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.3);position:relative;max-height:90vh;overflow-y:auto}
.cfg-modal-panel h3{font-family:'Fraunces',serif;font-size:1.5rem;margin-bottom:4px;color:var(--ink)}
.cfg-modal-close{position:absolute;top:14px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--cream);border:none;font-size:1.6rem;line-height:1;cursor:pointer;color:var(--ink);display:grid;place-items:center}
.cfg-modal-close:hover{background:var(--terra);color:#fff}
.cfg-modal .field{margin-bottom:14px}
.cfg-modal .field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px;color:var(--ink)}
.cfg-modal .field input,.cfg-modal .field textarea{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:var(--bg);transition:border .2s}
.cfg-modal .field input:focus,.cfg-modal .field textarea:focus{outline:none;border-color:var(--terra);background:#fff}

/* Fix: ensure hidden attribute actually hides (overrides display on flex/grid contexts) */
.cfg-mode[hidden]{display:none !important}
.cfg-room[hidden],.cfg-stair[hidden],.cfg-vv[hidden]{display:none !important}

/* VV preview visual */
.cfg-vv{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);background:linear-gradient(180deg,#f3ebdd,#e6dcc8);display:flex;align-items:center;justify-content:center;padding:30px;position:relative}
.cfg-vv::before{content:"";position:absolute;inset:20% 15%;background:
  repeating-linear-gradient(90deg,var(--terra) 0 3px,transparent 3px 22px),
  repeating-linear-gradient(180deg,var(--terra) 0 3px,transparent 3px 22px);
  opacity:.35;border-radius:8px;animation:vvHeat 3s ease-in-out infinite}
.cfg-vv-label{position:relative;z-index:2;background:#fff;padding:14px 22px;border-radius:999px;font-family:'Fraunces',serif;color:var(--ink);box-shadow:var(--shadow)}
@keyframes vvHeat{0%,100%{opacity:.25}50%{opacity:.55}}

/* === Product browser in configurator === */
.cfg-filters{display:flex;flex-direction:column;gap:12px;margin-bottom:18px;padding:16px;background:var(--bg);border-radius:10px;border:1px solid var(--line)}
.cfg-filters input[type=search]{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:.92rem;background:#fff}
.cfg-filters input[type=search]:focus{outline:none;border-color:var(--terra)}
.cfg-filter-group{display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.cfg-filter-group small{font-size:.75rem;color:var(--ink-2);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-right:4px;min-width:46px}
.cfg-fbtn{padding:6px 14px;border:1px solid var(--line);background:#fff;border-radius:999px;font:inherit;font-size:.82rem;cursor:pointer;transition:all .18s;font-weight:500;color:var(--ink-2)}
.cfg-fbtn:hover{border-color:var(--wood);color:var(--ink)}
.cfg-fbtn.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.cfg-opts-type button[data-cat].sel{background:var(--terra);color:#fff;border-color:var(--terra)}

.cfg-prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;max-height:520px;overflow-y:auto;padding:4px;scroll-behavior:smooth}
.cfg-prod-grid::-webkit-scrollbar{width:8px}
.cfg-prod-grid::-webkit-scrollbar-track{background:var(--bg);border-radius:4px}
.cfg-prod-grid::-webkit-scrollbar-thumb{background:var(--wood);border-radius:4px}

.cfg-prod{background:#fff;border:2px solid var(--line);border-radius:10px;padding:8px;cursor:pointer;font-family:inherit;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:8px;overflow:hidden}
.cfg-prod:hover{border-color:var(--wood);transform:translateY(-2px);box-shadow:0 6px 14px rgba(60,40,20,.08)}
.cfg-prod.sel{border-color:var(--terra);box-shadow:0 0 0 3px rgba(201,97,63,.2)}
.cfg-prod-img{aspect-ratio:1/1;overflow:hidden;border-radius:6px;background:var(--cream)}
.cfg-prod-img img{width:100%;height:100%;object-fit:cover;display:block}
.cfg-prod-info{padding:0 4px 4px}
.cfg-prod-info small{font-size:.7rem;color:var(--wood-dark);text-transform:uppercase;letter-spacing:.08em;font-weight:600;display:block;margin-bottom:2px}
.cfg-prod-info strong{font-size:.82rem;color:var(--ink);display:block;line-height:1.25;margin-bottom:4px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.cfg-prod-price{font-family:'Fraunces',serif;font-size:.95rem;color:var(--terra);font-weight:500}
.cfg-prod-empty{padding:40px 20px;text-align:center;color:var(--ink-2);background:var(--bg);border-radius:10px}
.cfg-prod-count{margin-top:10px;font-size:.82rem;color:var(--ink-2);text-align:right}

@media(max-width:640px){
  .cfg-prod-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));max-height:440px}
}

/* === V16: Aliases for product picker (match new HTML class names) === */
.cfg-filter-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.cfg-filter-row small{font-size:.75rem;color:var(--ink-2);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-right:4px;min-width:46px}
.cfg-opts-type{display:flex;flex-wrap:wrap;gap:8px;grid-template-columns:none !important}
.cfg-opts-type button{padding:10px 20px;border:2px solid var(--line);background:#fff;border-radius:999px;font:inherit;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .2s;color:var(--ink);flex:0 0 auto}
.cfg-opts-type button:hover{border-color:var(--wood)}
.cfg-opts-type button.sel{background:var(--terra);color:#fff;border-color:var(--terra)}

.cfg-prod-tile{background:#fff;border:2px solid var(--line);border-radius:10px;padding:8px;cursor:pointer;font-family:inherit;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:8px;overflow:hidden}
.cfg-prod-tile:hover{border-color:var(--wood);transform:translateY(-2px);box-shadow:0 6px 14px rgba(60,40,20,.08)}
.cfg-prod-tile.sel{border-color:var(--terra);box-shadow:0 0 0 3px rgba(201,97,63,.2)}
.cfg-prod-tile .cfg-prod-info{padding:0 4px 4px}
.cfg-prod-brand{font-size:.7rem;color:var(--wood-dark);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-bottom:2px}
.cfg-prod-name{font-size:.82rem;color:var(--ink);line-height:1.25;margin-bottom:6px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.4em}
.cfg-prod-price{font-family:'Fraunces',serif;font-size:1.05rem;color:var(--terra);font-weight:500}
.cfg-prod-price small{font-size:.7rem;color:var(--ink-2);margin-left:2px;font-weight:400}

/* === V16: Product picker in configurator === */
.cfg-opts-type{display:flex;gap:10px;flex-wrap:wrap}
.cfg-opts-type button{padding:10px 22px;border-radius:999px;border:2px solid var(--line);background:#fff;cursor:pointer;font-weight:600;font-size:.9rem;font-family:inherit;color:var(--ink);transition:all .2s}
.cfg-opts-type button:hover{border-color:var(--wood)}
.cfg-opts-type button.sel{background:var(--ink);border-color:var(--ink);color:#fff}

.cfg-filters{margin-bottom:14px;display:flex;flex-direction:column;gap:10px}
#cfgProdSearch{width:100%;padding:12px 16px;border:2px solid var(--line);border-radius:12px;font-size:.95rem;font-family:inherit;background:var(--bg);transition:all .2s}
#cfgProdSearch:focus{outline:none;border-color:var(--terra);background:#fff}
.cfg-filter-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.cfg-filter-row small{font-weight:600;color:var(--ink-2);font-size:.78rem;min-width:42px;text-transform:uppercase;letter-spacing:.05em}
.cfg-fbtn{padding:6px 12px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer;font-size:.8rem;font-family:inherit;color:var(--ink-2);transition:all .2s;font-weight:500}
.cfg-fbtn:hover{border-color:var(--wood);color:var(--ink)}
.cfg-fbtn.active{background:var(--terra);border-color:var(--terra);color:#fff}

.cfg-prod-count{font-size:.82rem;color:var(--ink-2);margin:8px 0 14px;font-weight:500}
.cfg-prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;max-height:540px;overflow-y:auto;padding:4px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg)}
.cfg-prod-grid::-webkit-scrollbar{width:8px}
.cfg-prod-grid::-webkit-scrollbar-track{background:transparent}
.cfg-prod-grid::-webkit-scrollbar-thumb{background:var(--wood);border-radius:4px}

.cfg-prod-tile{background:#fff;border:2px solid transparent;border-radius:10px;padding:0;cursor:pointer;font-family:inherit;text-align:left;transition:all .2s;overflow:hidden;display:flex;flex-direction:column}
.cfg-prod-tile:hover{border-color:var(--wood);transform:translateY(-2px);box-shadow:var(--shadow)}
.cfg-prod-tile.sel{border-color:var(--terra);box-shadow:0 0 0 4px rgba(201,97,63,.15)}
.cfg-prod-tile[hidden]{display:none !important}
.cfg-prod-tile .cfg-prod-img{aspect-ratio:1/1;overflow:hidden;background:var(--cream)}
.cfg-prod-tile .cfg-prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.cfg-prod-tile:hover .cfg-prod-img img{transform:scale(1.05)}
.cfg-prod-tile .cfg-prod-info{padding:10px;display:flex;flex-direction:column;gap:3px}
.cfg-prod-brand{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--wood-dark);font-weight:600}
.cfg-prod-name{font-size:.82rem;font-weight:600;color:var(--ink);line-height:1.25;min-height:2.1em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.cfg-prod-tile .cfg-prod-price{font-family:'Fraunces',serif;font-size:1rem;color:var(--terra);font-weight:600;margin-top:4px}
.cfg-prod-tile .cfg-prod-price small{font-weight:400;color:var(--ink-2);font-size:.7rem}

.cfg-no-results{padding:40px 20px;text-align:center;color:var(--ink-2);background:var(--cream);border-radius:10px;margin-top:10px}

/* === V17: Fixes === */
/* Force hide all preview panels when hidden attribute is set */
.cfg-vv[hidden],.cfg-room[hidden],.cfg-stair[hidden]{display:none !important}
/* Force hide filtered product tiles */
.cfg-prod-tile[hidden]{display:none !important}

/* Image error fallback */
.cfg-prod-img{position:relative;background:var(--cream)}
.cfg-prod-img::before{content:"";position:absolute;inset:0;background:
  linear-gradient(135deg,var(--cream) 0%,var(--wood) 100%);
  background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.08) 0 1px,transparent 1px 24px),repeating-linear-gradient(180deg,rgba(0,0,0,.05) 0 1px,transparent 1px 12px);
  opacity:1;z-index:0}
.cfg-prod-img img{position:relative;z-index:1}

/* V16.1: Image fallback styling */
.cfg-prod-tile .cfg-prod-img{position:relative;background:linear-gradient(135deg,var(--cream),var(--bg-2))}
.cfg-prod-tile .cfg-prod-img::before{content:"";position:absolute;inset:0;background:var(--cream);opacity:.3;pointer-events:none}
.cfg-prod-tile .cfg-prod-img img{position:relative;z-index:1}

/* === V18: Fallback for products without images === */
.cfg-prod-tile .cfg-prod-img{position:relative;overflow:hidden}
.cfg-prod-tile .cfg-prod-img:not(:has(img)),
.cfg-prod-tile .cfg-prod-img img[src=""],
.cfg-prod-tile .cfg-prod-img:empty{
  background:linear-gradient(135deg,var(--wood) 0%,var(--wood-dark) 100%);
}
/* Draw a subtle plank pattern + product initials on missing-image tiles */
.cfg-prod-tile[data-img=""] .cfg-prod-img::before,
.cfg-prod-tile:not([data-img]) .cfg-prod-img::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,var(--wood) 0%,var(--wood-dark) 60%,#6b4423 100%);
  background-image:
    linear-gradient(135deg,var(--wood) 0%,var(--wood-dark) 60%,#6b4423 100%),
    repeating-linear-gradient(90deg,rgba(0,0,0,.12) 0 1px,transparent 1px 18px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 1px,transparent 1px 9px);
  background-blend-mode:normal,overlay,normal;
  z-index:0;
}
.cfg-prod-tile[data-img=""] .cfg-prod-img::after,
.cfg-prod-tile:not([data-img]) .cfg-prod-img::after{
  content:attr(data-name);
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:'Fraunces',serif;font-weight:500;font-size:.9rem;
  text-align:center;padding:10px;text-shadow:0 1px 3px rgba(0,0,0,.4);
  z-index:1;line-height:1.2;
}

/* Cleaner fallback — use parent .cfg-prod-img with data-name */
.cfg-prod-img[data-name]{position:relative}
.cfg-prod-img[data-name]:not(:has(img))::before{
  content:"";position:absolute;inset:0;
  background:
    repeating-linear-gradient(90deg,rgba(0,0,0,.12) 0 1px,transparent 1px 18px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0 1px,transparent 1px 9px),
    linear-gradient(135deg,var(--wood) 0%,var(--wood-dark) 60%,#5d3a1f 100%);
  z-index:0;
}
.cfg-prod-img[data-name]:not(:has(img))::after{
  content:attr(data-name);
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:'Fraunces',serif;font-weight:500;font-size:.85rem;
  text-align:center;padding:8px;text-shadow:0 1px 4px rgba(0,0,0,.5);
  z-index:1;line-height:1.25;
}
.cfg-prod-img[data-name] img{position:relative;z-index:2}

/* Bump up version */

/* === V19: Configurator mobile === */
@media(max-width:768px){
  .cfg-hero{padding:50px 0 20px}
  .cfg-hero h1{font-size:1.8rem}
  .cfg-hero p{font-size:.95rem}
  
  .cfg-tabs{flex-direction:column;border-radius:14px;padding:6px}
  .cfg-tab{padding:12px;font-size:.88rem;text-align:center}
  
  .cfg-wrap{padding:20px 0 60px}
  .cfg-grid{grid-template-columns:1fr !important;gap:20px}
  .cfg-preview{position:static !important}
  
  /* Smaller preview panels */
  .cfg-room,.cfg-stair,.cfg-vv{aspect-ratio:16/9}
  
  /* Steps */
  .cfg-step{padding:18px;border-radius:12px}
  .cfg-step h3{font-size:1rem;margin-bottom:14px;gap:10px}
  .cfg-step h3 span{width:28px;height:28px;font-size:.85rem}
  
  /* Option buttons row-layout becomes stacked */
  .cfg-opts,.cfg-opts-row{grid-template-columns:1fr 1fr !important;gap:8px}
  .cfg-opts button{padding:12px 10px;font-size:.85rem}
  .cfg-opts button small{font-size:.72rem}
  
  .cfg-opts-type{flex-wrap:wrap}
  .cfg-opts-type button{padding:8px 14px;font-size:.85rem;flex:1;min-width:fit-content}
  
  /* Search + filter pills */
  #cfgProdSearch{padding:10px 14px;font-size:.9rem}
  .cfg-filter-row{gap:4px}
  .cfg-filter-row small{min-width:40px;font-size:.7rem}
  .cfg-fbtn{padding:5px 10px;font-size:.72rem}
  .cfg-fbtn small{font-size:.65rem}
  
  /* Product grid — 2 cols on phone */
  .cfg-prod-grid{grid-template-columns:repeat(2,1fr) !important;max-height:420px;gap:10px;padding:6px}
  .cfg-prod-tile .cfg-prod-info{padding:8px}
  .cfg-prod-brand{font-size:.6rem}
  .cfg-prod-name{font-size:.72rem;min-height:1.8em}
  .cfg-prod-tile .cfg-prod-price{font-size:.88rem}
  
  /* m² slider + room shortcuts */
  .cfg-m2{flex-direction:column;align-items:stretch;gap:14px}
  .cfg-m2-val{text-align:center}
  .cfg-m2-val strong{font-size:1.8rem}
  .cfg-rooms{grid-template-columns:repeat(3,1fr) !important;gap:6px}
  .cfg-rooms button{padding:10px 6px;font-size:.75rem}
  .cfg-rooms button small{font-size:.65rem}
  
  /* Decor row (step 2 on trap mode) */
  .cfg-decors{grid-template-columns:repeat(2,1fr) !important}
  .cfg-decors button{padding:40px 6px 8px;font-size:.72rem}
  
  /* Summary sticky → normal flow on mobile */
  .cfg-summary{padding:18px}
  .cfg-summary h3{font-size:1rem}
  .cfg-total strong{font-size:1.4rem}
  
  /* Modal */
  .cfg-modal-panel{padding:24px 18px;max-height:88vh}
  .cfg-modal-panel h3{font-size:1.25rem}
  .cfg-modal .field input,.cfg-modal .field textarea{padding:10px 12px;font-size:.9rem}
}

@media(max-width:480px){
  .cfg-prod-grid{grid-template-columns:repeat(2,1fr) !important}
  .cfg-opts,.cfg-opts-row{grid-template-columns:1fr !important}
  .cfg-hero h1{font-size:1.5rem}
}
