/* ============================================================
   SUBPÁGINA · POLICARBONATO ALVEOLAR (B2B + B2C) — componentes
   Reutiliza ../styles.css (sistema vfinal · vidrio ahumado).
   ============================================================ */

/* la píldora pide más ancho: marca + switcher + nav + WhatsApp */
.top{ max-width:900px; }

/* CTA doble en el hero (primario WA + secundario de línea) */
.hero__cta{ display:flex; flex-wrap:wrap; gap:12px; align-items:center; }

/* ---- Featured · alveolar con espesores y precios ---- */
.thick{ margin-top:22px; display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--hair); border:1px solid var(--hair); border-radius:10px; overflow:hidden; }
.thick__cell{ background:var(--bg-2); padding:14px 12px; }
.thick__t{ font-family:var(--serif); font-size:20px; }
.thick__p{ margin-top:3px; font-family:var(--mono); font-size:12px; color:var(--accent); }
.feature__note{ margin-top:14px; font-size:13px; color:var(--muted); }

/* ---- Cards del catálogo ---- */
.card{ flex:0 0 clamp(240px,24vw,300px); background:var(--bg-2); border:1px solid var(--hair);
  border-radius:var(--radius); overflow:hidden; }
.card__fig{ aspect-ratio:4/3; overflow:hidden; background:var(--bg); }
.card__fig img{ width:100%; height:100%; object-fit:cover; transform:scale(1.02);
  transition:transform 900ms var(--ease); }
.card:hover .card__fig img{ transform:scale(1.08); }
.card__body{ padding:16px 18px 18px; }
.card__name{ font-family:var(--serif); font-size:20px; }
.card__desc{ margin-top:6px; font-size:13.5px; color:var(--muted); line-height:1.5; }
.card__price{ margin-top:12px; font-family:var(--mono); font-size:15px; color:var(--accent); }
.card__price small{ font-size:11px; color:var(--muted); }

/* ---- Corte 3D · visor de placa ---- */
.lab{ display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(24px,4vw,56px); align-items:stretch; }
.lab__stage{ background:var(--bg-2); border:1px solid var(--hair); border-radius:var(--radius);
  padding:clamp(18px,2.4vw,30px); display:flex; flex-direction:column; }
.lab__svg{ width:100%; height:auto; flex:1; }
.lab__legend{ display:flex; flex-wrap:wrap; gap:10px 20px; margin-top:14px; font-size:12.5px; color:var(--muted); }
.lab__legend i{ display:inline-block; width:11px; height:11px; border-radius:3px; margin-right:7px; vertical-align:-1px; }
.lab__controls{ display:flex; flex-direction:column; gap:22px; }
.ctl__head{ display:flex; justify-content:space-between; align-items:baseline; }
.ctl__label{ font-family:var(--mono); font-size:11.5px; letter-spacing:0.07em; text-transform:uppercase; color:var(--muted); }
.ctl output{ font-family:var(--serif); font-size:22px; color:var(--accent); }
.ctl input[type=range]{ width:100%; margin-top:10px; accent-color:oklch(81% 0.13 165); }
.ctl__ticks{ display:flex; justify-content:space-between; font-family:var(--mono); font-size:11px; color:var(--muted); margin-top:4px; }
.swatches{ display:flex; gap:10px; margin-top:10px; }
.swatches label{ position:relative; }
.swatches input{ position:absolute; opacity:0; inset:0; }
.swatches span{ display:block; width:34px; height:34px; border-radius:999px; border:1px solid var(--hair);
  cursor:pointer; transition:border-color var(--dur) var(--ease), transform var(--dur) var(--ease); }
.swatches span:hover{ transform:scale(1.08); }
.swatches input:checked + span{ border-color:var(--accent); box-shadow:0 0 0 3px oklch(81% 0.13 165 / 0.25); }
.swatches span[data-c=cristal]{ background:linear-gradient(135deg,#cfd9d5,#8fa39d); }
.swatches span[data-c=bronce]{ background:linear-gradient(135deg,#c9a06c,#6b4a22); }
.swatches span[data-c=opal]{ background:linear-gradient(135deg,#f0ece0,#b9b5a9); }
.lab__specs{ margin:0; display:grid; gap:10px; border-top:1px solid var(--hair); padding-top:18px; }
.lab__specs > div{ display:flex; justify-content:space-between; gap:14px; }
.lab__specs dt{ font-size:13.5px; color:var(--muted); }
.lab__specs dd{ margin:0; font-family:var(--mono); font-size:13.5px; }

/* ---- Calculadora ---- */
.calc{ display:grid; grid-template-columns:0.9fr 1.4fr; gap:clamp(28px,5vw,72px); align-items:start; }
.calc__intro h2{ font-size:clamp(28px,3.6vw,48px); }
.calc__intro > p{ margin-top:16px; color:var(--ink-2); font-size:clamp(15px,1.3vw,17px); line-height:1.55; max-width:40ch; }
.calc__intro .small{ font-size:13.5px; color:var(--muted); }
.calc__form{ display:grid; gap:22px; background:var(--bg-2); border:1px solid var(--hair);
  border-radius:var(--radius); padding:clamp(20px,2.6vw,32px); }
.calc__field{ border:0; margin:0; padding:0; }
.calc__field legend{ font-weight:600; font-size:15.5px; margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.calc__step{ width:24px; height:24px; flex:none; display:grid; place-items:center; border-radius:999px;
  background:var(--accent); color:var(--accent-ink); font-family:var(--mono); font-size:12px; }
.chips{ display:flex; flex-wrap:wrap; gap:8px; }
.chips label{ position:relative; }
.chips input{ position:absolute; opacity:0; inset:0; }
.chips span{ display:inline-block; padding:8px 14px; border-radius:999px; border:1px solid var(--hair);
  font-size:14px; cursor:pointer;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease); }
.chips span:hover{ border-color:oklch(95% 0.006 200 / 0.5); }
.chips input:checked + span{ background:var(--ink); color:oklch(15% 0.012 240); border-color:transparent; font-weight:600; }
.calc__dims{ display:flex; gap:18px; flex-wrap:wrap; }
.calc__dims label{ display:flex; align-items:center; gap:8px; font-size:14px; color:var(--ink-2); }
.calc__dims input{ width:84px; padding:9px 10px; border-radius:8px; border:1px solid var(--hair);
  background:var(--bg); color:var(--ink); font:inherit; font-family:var(--mono); font-size:14px; }
.calc__dims input:focus-visible{ outline:2px solid var(--accent); outline-offset:1px; }
.calc__area{ display:block; margin-top:10px; font-size:13.5px; color:var(--muted); }
.calc__area b{ color:var(--ink); font-family:var(--mono); font-weight:500; }
.calc__result{ border-top:1px solid var(--hair); padding-top:20px; }
.calc__hint{ font-family:var(--mono); font-size:11.5px; letter-spacing:0.07em; text-transform:uppercase; color:var(--muted); }
.calc__product{ margin-top:6px; font-family:var(--serif); font-size:clamp(22px,2.4vw,30px); color:var(--accent); }
.calc__detail{ margin-top:4px; font-size:15px; color:var(--ink-2); }
.calc__result .btn-solid{ margin-top:18px; }

/* ---- Mayorista ---- */
.mayorista__grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(28px,5vw,72px); align-items:center; }
.mayorista h2{ font-size:clamp(28px,3.6vw,48px); }
.mayorista__lead{ margin:16px 0 24px; color:var(--ink-2); font-size:clamp(15px,1.3vw,17px); line-height:1.55; max-width:40ch; }
.perks{ list-style:none; margin:0; padding:0; display:grid; gap:1px; background:var(--hair);
  border:1px solid var(--hair); border-radius:var(--radius); overflow:hidden; }
.perks li{ background:var(--bg); padding:18px 22px; }
.perks strong{ display:block; font-size:15.5px; }
.perks span{ font-size:13.5px; color:var(--muted); }

/* ---- FAQ ---- */
.faq__list{ border-top:1px solid var(--hair); }
.faq__item{ border-bottom:1px solid var(--hair); }
.faq__item summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between;
  align-items:center; gap:18px; padding:18px 2px; font-weight:600; font-size:clamp(15.5px,1.3vw,17.5px); }
.faq__item summary::-webkit-details-marker{ display:none; }
.faq__plus{ position:relative; width:14px; height:14px; flex:none; }
.faq__plus::before, .faq__plus::after{ content:""; position:absolute; inset:0; margin:auto;
  background:var(--accent); transition:transform var(--dur) var(--ease); }
.faq__plus::before{ width:14px; height:1.5px; }
.faq__plus::after{ width:1.5px; height:14px; }
.faq__item[open] .faq__plus::after{ transform:rotate(90deg); }
.faq__a{ padding:0 2px 20px; color:var(--ink-2); font-size:15px; line-height:1.55; max-width:70ch; }

@media (max-width:900px){
  .lab, .calc, .mayorista__grid{ grid-template-columns:1fr; }
}
@media (max-width:600px){
  .thick{ grid-template-columns:1fr 1fr; }
}
