/* =========================================================
   ARISTAS — Prototipo de experiencia
   Tipografía real (Montserrat) · tokens reales del selector
   + capa cálida editorial (elevar) · visualizador de telas
   ========================================================= */
:root{
  --white:#ffffff;
  --ink:#1a1a1a;
  --bg-light:#f8f8f8;
  --border:#e7e2d9;
  --text-2:#5a5a5a;
  --text-3:#8a8177;
  --cream:#f6f2ec;
  --sand:#ece3d5;
  --taupe:#b9a98f;
  --clay:#8c7357;
  --espresso:#1a1a1a;
  --accent:#8c7357;
  --accent-ink:#6f5a44;
  --ease:cubic-bezier(.4,0,.2,1);
  --sans:'FuturaPT','Montserrat',-apple-system,'Helvetica Neue',Arial,sans-serif;
  --display:'Amadine','Montserrat',-apple-system,sans-serif;
  --maxw:1360px;
}
@font-face{font-family:'Amadine';src:url('../assets/fonts/Amandine_Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Amadine';src:url('../assets/fonts/Amandine_Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Amadine';src:url('../assets/fonts/Amandine_Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'FuturaPT';src:url('../assets/fonts/FuturaPTLight.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'FuturaPT';src:url('../assets/fonts/FuturaPTBook.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'FuturaPT';src:url('../assets/fonts/FuturaPTMedium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'FuturaPT';src:url('../assets/fonts/FuturaPTDemi.ttf') format('truetype');font-weight:600;font-style:normal;font-display:swap}
*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--white);font-weight:400;font-size:15px;line-height:1.62}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px}
.linky{background:none;border:none;color:var(--accent);border-bottom:1px solid currentColor;padding:0 0 1px;font-size:inherit}
.section-title{font-weight:600;font-size:28px;line-height:1.15;letter-spacing:-.01em;margin:0}
.section-sub{color:var(--text-2);margin:.6em 0 0;max-width:54ch;font-weight:400}
.eyebrow{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin:0 0 14px;font-weight:600}

/* ================= HEADER ================= */
.site-header{position:sticky;top:0;z-index:60;background:var(--white);border-bottom:1px solid var(--border)}
.topbar{background:var(--espresso);color:#e9e2d7;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase}
.topbar__inner{max-width:var(--maxw);margin:0 auto;padding:9px 40px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.topbar__nav a,.topbar__utils a{color:#cfc6b8;margin-right:20px;transition:color .3s var(--ease);font-weight:400}
.topbar__utils a{margin:0 0 0 20px}
.topbar__nav a:hover,.topbar__utils a:hover{color:#fff}
.topbar__promo{opacity:.85;letter-spacing:.16em}
.mainbar{max-width:var(--maxw);margin:0 auto;padding:20px 40px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.mainbar__nav{display:flex;gap:26px;font-size:12px;letter-spacing:.13em;text-transform:uppercase;font-weight:500}
.mainbar__nav--right{justify-content:flex-end}
.mainbar__nav a{color:#413b34;transition:color .3s var(--ease)}
.mainbar__nav a:hover{color:var(--accent)}
.mainbar__cta{color:var(--accent)!important;font-weight:600}
.brand{display:flex;justify-content:center}
.brand img{width:200px;height:auto;max-width:100%}

/* ================= BREADCRUMB ================= */
.breadcrumb{border-bottom:1px solid var(--border);background:var(--white)}
.breadcrumb .wrap{display:flex;gap:10px;align-items:center;padding-top:14px;padding-bottom:14px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3)}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb em{color:var(--ink);font-style:normal}

/* ================= CONFIG GRID ================= */
.config__grid{display:grid;grid-template-columns:1.12fr .88fr;align-items:start}
.stage{position:sticky;top:94px;background:var(--white);min-height:calc(100vh - 94px);display:flex;align-items:center;border-right:1px solid var(--border)}
.stage__inner{width:100%;padding:44px 56px}
.stage__frame{position:relative;aspect-ratio:2752/1536;width:100%}
.stage__img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;transition:opacity .55s var(--ease)}
.stage__img.is-active{opacity:1}
.stage__shadow{position:absolute;left:12%;right:12%;bottom:7%;height:26px;background:radial-gradient(ellipse at center,rgba(42,36,32,.16),transparent 70%);filter:blur(3px);z-index:-1}
.stage__chip{position:absolute;left:10px;bottom:6px;margin:0;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.86);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:99px;padding:6px 16px 6px 6px;box-shadow:0 8px 24px -14px rgba(42,36,32,.5)}
.stage__chip-tex{width:34px;height:34px;border-radius:50%;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1)}
.stage__chip figcaption{font-size:11px;letter-spacing:.06em;color:var(--espresso);font-weight:500}
.stage__caption{margin-top:26px;text-align:center}
.stage__live{font-size:15px;font-weight:600;letter-spacing:.02em;color:var(--espresso)}
.stage__hint{font-size:13.5px;color:var(--text-2);letter-spacing:.03em;margin-top:10px}
.stage__hint .linky{font-size:14px;font-weight:600;color:var(--accent-ink)}
.stage__hint .linky:hover{color:var(--accent)}
/* Ver en ambiente (modo Sims) */
.ambient{position:absolute;inset:0;z-index:6;background:var(--bg-light);border-radius:4px;overflow:hidden}
.ambient[hidden]{display:none}
.ambient__img{width:100%;height:100%;object-fit:cover;display:block;animation:ambFade .5s var(--ease)}
@keyframes ambFade{from{opacity:.4}to{opacity:1}}
.ambient__close{position:absolute;top:12px;right:12px;background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:99px;padding:8px 16px;font-size:11px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;color:var(--espresso);backdrop-filter:blur(6px)}
.ambient__close:hover{background:#fff}
.ambient__nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.9);border:1px solid var(--border);font-size:20px;color:var(--espresso);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px);transition:.25s var(--ease)}
.ambient__nav:hover{background:#fff}
.ambient__nav--prev{left:12px}.ambient__nav--next{right:12px}
.ambient__dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px}
.ambient__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.65);border:none;box-shadow:0 0 0 1px rgba(0,0,0,.15)}
.ambient__dot.is-sel{background:var(--espresso)}

/* ================= PANEL ================= */
.panel__inner{padding:36px 60px 48px;max-width:660px}
.ptitle{font-weight:600;font-size:40px;line-height:1.02;letter-spacing:-.02em;margin:0 0 16px}
.price{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}
.price__label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);font-weight:500}
.price__amount{font-size:26px;font-weight:600;color:var(--espresso);transition:opacity .3s var(--ease)}
.price__amount.flash{opacity:.28}
.pintro{color:var(--text-2);margin:0 0 8px}
.pintro strong{color:var(--accent-ink);font-weight:600}

/* Resumen de configuración (vivo + navegable) */
.summary{display:flex;margin-bottom:30px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.sumitem{flex:1;display:flex;flex-direction:column;gap:4px;align-items:flex-start;text-align:left;padding:12px 16px;background:var(--white);border:none;border-right:1px solid var(--border);transition:.25s var(--ease)}
.sumitem:last-child{border-right:none}
.sumitem:hover{background:var(--cream)}
.sumitem__k{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--text-3);font-weight:600}
.sumitem__v{font-size:13.5px;font-weight:500;color:var(--ink);transition:color .2s var(--ease)}
.sumitem.flash .sumitem__v{color:var(--accent)}

/* Groups */
.group{padding:16px 0}
.group + .group{border-top:1px solid var(--border)}
.pintro + .group{padding-top:4px}
.group__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}
.group__label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);font-weight:600}
.group__value{font-size:15px;color:var(--ink);font-weight:500}
.group__meta{font-size:12.5px;color:var(--text-3);margin:9px 0 0}
.group__meta--note{color:var(--clay)}

/* Pills (tamaño) */
.pills{display:flex;gap:12px;flex-wrap:wrap}
.pill{border:1px solid var(--border);background:var(--white);padding:12px 22px;border-radius:99px;font-size:13px;color:var(--text-2);transition:.28s var(--ease)}
.pill:hover{border-color:var(--taupe);color:var(--ink)}
.pill.is-sel{background:var(--espresso);border-color:var(--espresso);color:#fff}

/* Trigger de tela (abre el panel) */
.trigger{display:flex;align-items:center;gap:16px;width:100%;text-align:left;background:var(--cream);border:1px solid var(--border);border-radius:8px;padding:12px 16px;transition:.28s var(--ease)}
.trigger:hover{border-color:var(--taupe);background:#f3ece1}
.trigger__thumb{width:52px;height:52px;border-radius:8px;background-size:cover;background-position:center;flex:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.trigger__text{flex:1;display:flex;flex-direction:column;gap:3px}
.trigger__text strong{font-size:15px;font-weight:600;color:var(--espresso)}
.trigger__text small{font-size:11.5px;color:var(--text-3)}
.trigger__arrow{color:var(--accent);font-size:18px}

/* Dots / bolitas */
.dots{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px;align-items:center}
.dot{width:38px;height:38px;border-radius:50%;background-size:cover;background-position:center;border:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1);position:relative;transition:transform .22s var(--ease)}
.dot::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px solid transparent;transition:.22s var(--ease)}
.dot:hover{transform:translateY(-2px)}
.dot.is-sel::after{border-color:var(--accent)}
/* enlace sutil "Ver todas las telas" (reemplaza el antiguo círculo +N) */
.fabric-all{align-self:center;margin-left:6px;background:none;border:0;padding:2px 0;cursor:pointer;
  font-family:inherit;font-size:12.5px;font-weight:600;letter-spacing:.02em;color:var(--text-2);
  border-bottom:1px solid var(--border);transition:color .22s var(--ease),border-color .22s var(--ease)}
.fabric-all:hover{color:var(--accent);border-bottom-color:var(--accent)}
.fabric-all:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.dot.is-disabled{opacity:.3;pointer-events:none;filter:grayscale(1)}

/* CTA */
.cta{display:flex;gap:12px;margin:22px 0 0;flex-wrap:wrap}
.btn{border:1px solid var(--espresso);padding:16px 26px;border-radius:3px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;transition:.3s var(--ease)}
.btn--primary{background:var(--espresso);color:#fff;flex:1;min-width:230px}
.btn--primary:hover{background:var(--accent-ink);border-color:var(--accent-ink)}
.btn--ghost{background:transparent;color:var(--espresso);border-color:var(--border)}
.btn--ghost:hover{border-color:var(--espresso)}

/* Fit / m² */
.fit{margin-top:22px;padding:18px 20px;background:var(--cream);border-radius:8px}
.fit__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.fit__title{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.fit__verdict{font-size:12px;font-weight:700;letter-spacing:.03em;padding:3px 11px;border-radius:99px;background:var(--sand);color:var(--accent-ink)}
.fit__verdict:empty{display:none}
.fit__presets{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.fit__preset{border:1px solid var(--border);background:var(--white);border-radius:99px;padding:8px 15px;font-size:12px;color:var(--text-2);transition:.25s var(--ease)}
.fit__preset:hover{border-color:var(--taupe)}
.fit__preset.is-sel{background:var(--accent);border-color:var(--accent);color:#fff}
.fit__scale{background:transparent;padding:0}
/* mini plano (vista de planta): tu sala vista desde arriba, el sofá contra la pared */
.fit__plan{position:relative;height:130px;overflow:hidden;border-radius:5px;
  background:var(--white);border:1px solid var(--border);border-top:2px solid var(--taupe);
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:26px 26px;background-position:center}
.fit__plan.is-empty{filter:grayscale(.35) opacity(.9)}
.fit__wall{position:absolute;top:7px;left:50%;transform:translateX(-50%);z-index:3;white-space:nowrap;
  font-size:11px;font-weight:600;letter-spacing:.04em;color:var(--text-2);background:var(--white);padding:1px 9px;border-radius:99px}
.fit__sofa{position:absolute;top:32px;height:56px;z-index:2;background:var(--clay);border-radius:4px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:600;letter-spacing:.03em;white-space:nowrap;
  box-shadow:0 4px 12px rgba(0,0,0,.14);transition:left .5s var(--ease),width .5s var(--ease),background .3s var(--ease)}
.fit__gap{position:absolute;top:53px;z-index:3;white-space:nowrap;font-size:10.5px;color:var(--text-3);background:var(--white);padding:0 5px;border-radius:3px}
.fit__gap:empty{display:none}
.fit__gap--l{left:9px}
.fit__gap--r{right:9px}
.fit__floor{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);z-index:1;
  font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-3);opacity:.65}
.fit__hint{font-size:12px;color:var(--text-3);margin:12px 0 0}

/* Trust */
.trust{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:24px 0 0;padding:20px 0 0;border-top:1px solid var(--border)}
.trust li{display:flex;flex-direction:column;gap:3px;text-align:center;align-items:center}
.trust strong{font-size:12px;font-weight:600}
.trust span{font-size:11px;color:var(--text-3)}

/* ================= SPECS ================= */
.specs{padding:80px 40px 20px}
.specs__table{width:100%;border-collapse:collapse;margin-top:30px}
.specs__table tr{border-top:1px solid var(--border)}
.specs__table tr:last-child{border-bottom:1px solid var(--border)}
.specs__table th{text-align:left;width:230px;padding:18px 0;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--text-3);font-weight:600;vertical-align:top}
.specs__table td{padding:18px 0;color:var(--text-2);font-size:14px}

/* ================= CROSS-SELL ================= */
.cross{padding:70px 40px 100px}
.cross__head{margin-bottom:34px}
.cross__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.cross-card{border:1px solid var(--border);border-radius:6px;overflow:hidden;transition:.35s var(--ease);background:var(--white)}
.cross-card:hover{border-color:var(--taupe);transform:translateY(-3px);box-shadow:0 18px 40px -24px rgba(42,36,32,.4)}
.cross-card__img{aspect-ratio:4/3;background:var(--bg-light);display:flex;align-items:center;justify-content:center;color:var(--taupe);font-weight:600;font-size:14px;letter-spacing:.02em}
.cross-card__body{padding:18px 20px 22px}
.cross-card__name{font-size:16px;font-weight:600;color:var(--espresso)}
.cross-card__price{font-size:13px;color:var(--text-2);margin-top:4px}
.cross-card__add{margin-top:14px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid currentColor;display:inline-block;padding-bottom:2px;font-weight:600}
.cross__guide{display:block;margin-top:40px;padding:26px 30px;background:var(--espresso);color:#f2ece2;border-radius:8px;font-size:15px;transition:.3s var(--ease)}
.cross__guide:hover{background:var(--accent-ink)}

/* ================= FOOTER ================= */
.site-footer{background:var(--espresso);color:#cfc6b8;padding:66px 0}
.site-footer__inner{text-align:center}
.site-footer__logo{height:26px;width:auto;margin:0 auto;filter:invert(1) brightness(2.2)}
.site-footer__note{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;margin-top:22px;opacity:.5}

/* ================= SHEET (visualizador de telas) ================= */
.sheet__backdrop{position:fixed;inset:0;background:rgba(26,22,19,.42);backdrop-filter:blur(2px);z-index:90;opacity:0;transition:opacity .4s var(--ease)}
.sheet__backdrop.is-open{opacity:1}
.sheet{position:fixed;top:0;right:0;height:100vh;width:460px;max-width:92vw;background:var(--white);z-index:95;transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;box-shadow:-30px 0 80px -40px rgba(42,36,32,.5)}
.sheet.is-open{transform:translateX(0)}
.sheet__head{display:flex;justify-content:space-between;align-items:flex-start;padding:30px 30px 18px;border-bottom:1px solid var(--border)}
.sheet__title{font-size:22px;font-weight:600;margin:0;letter-spacing:-.01em}
.sheet__sub{font-size:12.5px;color:var(--text-3);margin:6px 0 0}
.sheet__close{background:none;border:none;font-size:28px;line-height:1;color:var(--text-3)}
.sheet__close:hover{color:var(--ink)}
.sheet__filters{display:flex;gap:8px;padding:16px 30px;border-bottom:1px solid var(--border);align-items:center}
.sheet__select{flex:1;border:1px solid var(--border);border-radius:4px;padding:9px 12px;font-family:inherit;font-size:12.5px;color:var(--text-2);background:var(--white)}
.sheet__reset{background:none;border:none;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);font-weight:600}
.sheet__body{flex:1;overflow:hidden;position:relative}
.sheet__grid{position:absolute;inset:0;overflow-y:auto;padding:24px 30px 40px;display:grid;grid-template-columns:1fr 1fr;gap:18px;align-content:start}
.fabric-card{display:flex;flex-direction:column;width:100%;padding:0;border:none;background:none;text-align:left;transition:transform .22s var(--ease)}
.fabric-card:hover{transform:translateY(-3px)}
.fabric-card__img{display:block;width:100%;aspect-ratio:1;border-radius:10px;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);position:relative}
.fabric-card.is-sel .fabric-card__img{box-shadow:inset 0 0 0 1px rgba(0,0,0,.08),0 0 0 2px var(--accent)}
.fabric-card__badge{position:absolute;top:8px;left:8px;background:rgba(42,36,32,.82);color:#fff;font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;padding:3px 8px;border-radius:99px;font-weight:600;white-space:nowrap}
.fabric-card__name{display:block;font-size:12.5px;font-weight:500;margin-top:9px;color:var(--espresso)}
.fabric-card__meta{display:block;font-size:10.5px;color:var(--text-3)}
.fabric-card.is-hidden{display:none}

/* Detail view dentro del sheet */
.sheet__detail{position:absolute;inset:0;overflow-y:auto;padding:24px 30px 40px;background:var(--white)}
.detail__back{background:none;border:none;color:var(--accent);font-size:12.5px;font-weight:600;padding:0 0 18px}
.detail__img{width:100%;aspect-ratio:4/3;border-radius:12px;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08)}
.detail__name{font-size:24px;font-weight:600;margin:20px 0 10px;letter-spacing:-.01em}
.detail__chips{display:flex;gap:8px;margin-bottom:16px}
.detail__chip{font-size:11px;letter-spacing:.04em;background:var(--cream);color:var(--accent-ink);padding:5px 12px;border-radius:99px;font-weight:500}
.detail__desc{color:var(--text-2);font-size:14px;line-height:1.7;margin:0 0 18px}
.detail__note{font-size:12px;color:var(--clay);background:var(--cream);border-radius:6px;padding:12px 14px;margin-bottom:20px;display:none}
.detail__note.show{display:block}
.detail__choose{width:100%}

/* ================= MODAL QR ================= */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(26,22,19,.55);backdrop-filter:blur(3px)}
.modal__card{position:relative;background:var(--white);border-radius:10px;padding:44px 46px;max-width:420px;width:90%;text-align:center;box-shadow:0 40px 80px -30px rgba(0,0,0,.5)}
.modal__x{position:absolute;top:14px;right:18px;background:none;border:none;font-size:26px;color:var(--text-3);line-height:1}
.modal__title{font-size:26px;font-weight:600;margin:0 0 6px}
.modal__sub{color:var(--accent-ink);font-size:14px;margin:0 0 22px;font-weight:500}
.modal__qr{width:150px;height:150px;margin:0 auto 20px;border-radius:10px;background-size:cover;image-rendering:pixelated;border:1px solid var(--border)}
.modal__hint{font-size:12.5px;color:var(--text-3);margin:0}

/* Modal Añadido al carrito */
.cartcard{position:relative;background:var(--white);border-radius:12px;padding:32px 36px;max-width:540px;width:92%;text-align:left;box-shadow:0 40px 80px -30px rgba(0,0,0,.5);max-height:92vh;overflow-y:auto}
.cartcard__check{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:600;color:var(--espresso);margin-bottom:22px}
.cartcard__tick{width:26px;height:26px;border-radius:50%;background:#6f7d4a;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px}
.cartcard__item{display:flex;gap:16px;align-items:center;padding-bottom:18px;border-bottom:1px solid var(--border)}
.cartcard__thumb{width:100px;height:72px;border-radius:8px;background:var(--bg-light);background-size:cover;background-position:center;flex:none;border:1px solid var(--border)}
.cartcard__info{display:flex;flex-direction:column;gap:3px}
.cartcard__info strong{font-size:16px;font-weight:600}
.cartcard__info span{font-size:12.5px;color:var(--text-3)}
.cartcard__price{color:var(--espresso)!important;font-weight:600;font-size:14px!important;margin-top:2px}
.cartcard__summary{font-size:13px;color:var(--text-2);padding:16px 0}
.cartcard__summary strong{color:var(--espresso)}
.cartcard__cross{border-top:1px solid var(--border);padding-top:18px}
.cartcard__crosstitle{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);font-weight:600;margin:0 0 14px}
.cartcard__crossgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cartcross{border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center}
.cartcross__img{aspect-ratio:4/3;border-radius:5px;background:var(--bg-light);display:flex;align-items:center;justify-content:center;color:var(--taupe);font-size:10.5px;font-weight:600;margin-bottom:8px;text-align:center;line-height:1.2;padding:4px}
.cartcross__name{font-size:11.5px;font-weight:500;color:var(--espresso);line-height:1.2}
.cartcross__price{font-size:10.5px;color:var(--text-3);margin-top:2px}
.cartcross__add{margin-top:8px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);border:1px solid var(--border);border-radius:99px;padding:6px 0;width:100%;font-weight:600;background:#fff}
.cartcross__add:hover{border-color:var(--accent)}
.cartcard__cta{display:flex;gap:12px;margin-top:24px}
.cartcard__cta .btn{flex:1;min-width:0}

/* Títulos con la fuente de marca (Amadine) */
.ptitle,.section-title,.sheet__title,.detail__name,.modal__title,.cross-card__name{font-family:var(--display);font-weight:500;letter-spacing:normal}
.ptitle,.section-title{text-transform:uppercase;letter-spacing:.02em}

/* ================= RESPONSIVE ================= */
@media(max-width:1080px){
  .mainbar__nav{gap:16px;font-size:11px}
  .panel__inner{padding:42px 40px 60px}
  .stage__inner{padding:34px}
}
@media(max-width:900px){
  .config__grid{grid-template-columns:1fr}
  .stage{position:relative;top:0;min-height:0;border-right:none;border-bottom:1px solid var(--border)}
  .mainbar__nav{display:none}
  .trust,.cross__grid,.specs__table{grid-template-columns:1fr}
  /* topbar: colapsa nav/utils y deja solo el promo centrado (franja limpia) */
  .topbar__nav,.topbar__utils{display:none}
  .topbar__inner{justify-content:center}
  .topbar__promo{letter-spacing:.08em;text-align:center}
}
@media(max-width:640px){
  .wrap,.topbar__inner,.mainbar{padding-left:20px;padding-right:20px}
  .ptitle{font-size:32px}
  .panel__inner{padding:32px 20px 50px}
  .specs__table th{width:auto;display:block;padding-bottom:4px}
  .specs__table td{display:block;padding-top:0}
  .sheet{width:100%}
}
