/* ==========================================================================
   Somnia Concept — pages.css
   Estilos específicos de home / tienda / productos + responsive.
   ========================================================================== */

/* =============================================================== HOME: HERO */
.hero{position:relative;overflow:hidden;background:var(--color-bg-soft);}
.hero__viewport{position:relative;}
.hero__slide{
  display:none;position:relative;
  min-height:560px;
}
.hero__slide.is-active{display:block;}
.hero__slide-inner{
  display:grid;grid-template-columns:1.05fr 1fr;align-items:center;gap:40px;
  min-height:560px;
}
.hero__content{padding:40px 0;max-width:560px;}
.hero__content .eyebrow{color:var(--color-accent);background:var(--color-primary);padding:5px 12px;border-radius:var(--radius-pill);}
.hero__content h1{margin:14px 0 16px;color:var(--color-heading);}
.hero__content p{font-size:1.1rem;margin-bottom:28px;max-width:460px;}
.hero__media{position:relative;height:100%;min-height:560px;}
.hero__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero__arrows{position:absolute;bottom:32px;right:32px;display:flex;gap:10px;z-index:5;}
.hero__arrow{
  width:50px;height:50px;border-radius:50%;background:#fff;box-shadow:var(--shadow-md);
  display:flex;align-items:center;justify-content:center;color:var(--color-heading);transition:all var(--t);
}
.hero__arrow:hover{background:var(--color-primary);color:#fff;}
.hero__dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:9px;z-index:5;}
.hero__dot{width:9px;height:9px;border-radius:50%;background:rgba(24,63,145,.25);transition:all var(--t);}
.hero__dot.is-active{background:var(--color-primary);width:26px;border-radius:5px;}

/* ====================================================== HOME: PROMO BANNER */
.promo-banner{
  display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:0;
  background:var(--color-bg-soft);border-radius:var(--radius-card);overflow:hidden;
}
.promo-banner__media{min-height:380px;position:relative;}
.promo-banner__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.promo-banner__content{padding:56px 60px;}
.promo-banner__content .eyebrow{color:var(--color-sale);}
.promo-banner__content h2{margin-bottom:14px;}

/* ====================================================== HOME: COMMERCE CARDS */
.commerce-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.commerce-card{
  position:relative;border-radius:var(--radius-card);overflow:hidden;min-height:420px;
  display:flex;align-items:flex-end;color:#fff;
  box-shadow:var(--shadow-sm);
}
.commerce-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform var(--t);}
.commerce-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,30,60,0) 35%,rgba(18,30,60,.78));}
.commerce-card:hover img{transform:scale(1.05);}
.commerce-card__body{position:relative;z-index:2;padding:32px;}
.commerce-card__body h3{color:#fff;margin-bottom:6px;}
.commerce-card__body p{color:rgba(255,255,255,.85);margin-bottom:10px;}
.commerce-card__price{font-weight:600;color:var(--color-accent);margin-bottom:16px;display:block;}

/* ====================================================== HOME: CATEGORIES */
.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;}
.cat-card{text-align:center;display:block;transition:transform var(--t);}
.cat-card:hover{transform:translateY(-5px);}
.cat-card__media{
  border-radius:50%;overflow:hidden;aspect-ratio:1/1;margin-bottom:16px;
  background:var(--color-bg-soft);box-shadow:var(--shadow-sm);
  border:6px solid #fff;
}
.cat-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t);}
.cat-card:hover .cat-card__media img{transform:scale(1.07);}
.cat-card h5{margin:0;}
.cat-card span{font-size:.85rem;color:var(--color-text-muted);}

/* ====================================================== HOME: LAYERS */
.layers{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.layers__media{position:relative;}
.layers__media img{border-radius:var(--radius-card);margin-inline:auto;}
.layers__list{display:flex;flex-direction:column;gap:14px;}
.layer-item{
  display:flex;gap:16px;align-items:flex-start;padding:18px 20px;
  border:1px solid var(--color-border);border-radius:var(--radius-card);
  background:#fff;transition:all var(--t);
}
.layer-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);}
.layer-item__num{
  flex:none;width:38px;height:38px;border-radius:50%;
  background:var(--color-primary);color:#fff;font-weight:600;
  display:flex;align-items:center;justify-content:center;
}
.layer-item h5{margin:0 0 3px;}
.layer-item p{margin:0;font-size:.9rem;color:var(--color-text-muted);}

/* ====================================================== HOME: BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.blog-card{border:1px solid var(--color-border);border-radius:var(--radius-card);overflow:hidden;background:#fff;transition:box-shadow var(--t),transform var(--t);}
.blog-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);}
.blog-card__media{aspect-ratio:16/10;overflow:hidden;}
.blog-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t);}
.blog-card:hover .blog-card__media img{transform:scale(1.05);}
.blog-card__body{padding:24px;}
.blog-card__meta{display:flex;gap:14px;font-size:.8rem;color:var(--color-text-muted);margin-bottom:10px;}
.blog-card__meta .cat{color:var(--color-primary);font-weight:600;}
.blog-card__body h4{margin-bottom:10px;line-height:1.3;}
.blog-card__body h4 a:hover{color:var(--color-primary);}
.blog-card__body p{font-size:.92rem;margin-bottom:16px;}

/* ====================================================== HOME: FINAL CTA */
.final-cta{
  background:var(--color-primary);color:#fff;text-align:center;
  border-radius:var(--radius-card);padding:70px 30px;
  background-image:radial-gradient(circle at 20% 20%,rgba(255,206,82,.18),transparent 40%);
}
.final-cta h2{color:#fff;}
.final-cta p{color:rgba(255,255,255,.85);max-width:520px;margin:0 auto 28px;font-size:1.08rem;}

/* =============================================================== SHOP PAGE */
.shop-titlebar{background:var(--color-bg-soft);padding:48px 0;text-align:center;}
.shop-titlebar h1{margin-bottom:6px;}

.shop-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:22px 0;border-bottom:1px solid var(--color-border);margin-bottom:36px;
}
.shop-toolbar__left{display:flex;align-items:center;gap:18px;}
.filters-toggle{
  display:inline-flex;align-items:center;gap:10px;
  padding:12px 22px;border:1px solid var(--color-border-strong);border-radius:var(--radius-button);
  font-weight:500;color:var(--color-heading);transition:all var(--t);
}
.filters-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);}
.filters-toggle svg{width:18px;height:18px;}
.results-count{color:var(--color-text-muted);font-size:.92rem;}
.results-count strong{color:var(--color-heading);}
.shop-toolbar__right{display:flex;align-items:center;gap:16px;}
.view-toggles{display:flex;gap:6px;}
.view-toggles button{width:38px;height:38px;border-radius:var(--radius-button);border:1px solid var(--color-border);color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;}
.view-toggles button.is-active{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-soft);}
.view-toggles svg{width:18px;height:18px;}
.sort-select{position:relative;}
.sort-select select{
  appearance:none;padding:11px 40px 11px 16px;border:1px solid var(--color-border-strong);
  border-radius:var(--radius-button);background:#fff;color:var(--color-heading);font-weight:500;cursor:pointer;
}
.sort-select::after{content:"";position:absolute;right:16px;top:50%;width:8px;height:8px;border-right:2px solid var(--color-heading);border-bottom:2px solid var(--color-heading);transform:translateY(-70%) rotate(45deg);pointer-events:none;}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px;}
.pagination a,.pagination span{
  min-width:46px;height:46px;padding:0 12px;border-radius:var(--radius-button);
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border:1px solid var(--color-border);font-weight:500;color:var(--color-heading);transition:all var(--t);
}
.pagination a:hover{border-color:var(--color-primary);color:var(--color-primary);}
.pagination .current{background:var(--color-primary);color:#fff;border-color:var(--color-primary);}
.pagination svg{width:16px;height:16px;}

/* Filter drawer */
.filter-drawer{
  position:fixed;top:0;right:0;bottom:0;width:420px;max-width:92vw;z-index:95;
  background:#fff;display:flex;flex-direction:column;
  transform:translateX(105%);transition:transform var(--t);box-shadow:var(--shadow-lg);
}
.filter-drawer.is-open{transform:translateX(0);}
.filter-drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 26px;border-bottom:1px solid var(--color-border);
}
.filter-drawer__head h3{margin:0;}
.filter-drawer__close{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-heading);}
.filter-drawer__close:hover{background:var(--color-bg-soft);}
.filter-drawer__body{flex:1;overflow-y:auto;padding:8px 26px 26px;}
.filter-drawer__foot{display:flex;gap:12px;padding:18px 26px;border-top:1px solid var(--color-border);}
.filter-group{padding:22px 0;border-bottom:1px solid var(--color-border);}
.filter-group:last-child{border-bottom:none;}
.filter-group h4{font-size:1rem;margin-bottom:14px;}
.filter-opt{display:flex;align-items:center;gap:10px;padding:6px 0;cursor:pointer;font-size:.95rem;}
.filter-opt input{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer;}
.filter-opt .count{margin-left:auto;color:var(--color-text-muted);font-size:.85rem;}
.price-inputs{display:flex;align-items:center;gap:10px;}
.price-inputs input{width:100%;padding:10px 12px;border:1px solid var(--color-border-strong);border-radius:var(--radius-button);}
.swatches{display:flex;flex-wrap:wrap;gap:10px;}
.swatch{display:inline-flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;font-size:.75rem;color:var(--color-text-muted);}
.swatch span.dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--color-border-strong);box-shadow:inset 0 0 0 2px #fff;}
.swatch input{display:none;}
.swatch input:checked + .dot{border-color:var(--color-primary);}
.scale-chips,.rating-rows{display:flex;flex-wrap:wrap;gap:8px;}
.chip{padding:8px 14px;border:1px solid var(--color-border-strong);border-radius:var(--radius-pill);font-size:.85rem;cursor:pointer;transition:all var(--t);}
.chip input{display:none;}
.chip:has(input:checked){background:var(--color-primary);color:#fff;border-color:var(--color-primary);}
.rating-row{display:flex;align-items:center;gap:8px;padding:6px 0;cursor:pointer;}

/* =============================================================== PRODUCT PAGE */
.product-top{display:grid;grid-template-columns:1.05fr 1fr;gap:54px;align-items:flex-start;}

/* Gallery */
.gallery__main{position:relative;border-radius:var(--radius-card);overflow:hidden;background:var(--color-bg-soft);border:1px solid var(--color-border);}
.gallery__main img{width:100%;aspect-ratio:1/1;object-fit:cover;}
.gallery__discount{position:absolute;top:18px;left:18px;background:var(--color-sale);color:#fff;font-weight:600;padding:7px 12px;border-radius:var(--radius-badge);z-index:2;}
.gallery__thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:14px;}
.gallery__thumb{border:2px solid var(--color-border);border-radius:10px;overflow:hidden;cursor:pointer;aspect-ratio:1/1;background:var(--color-bg-soft);transition:border var(--t);}
.gallery__thumb img{width:100%;height:100%;object-fit:cover;}
.gallery__thumb.is-active{border-color:var(--color-primary);}

/* Summary */
.summary__badges{display:flex;gap:8px;margin-bottom:14px;}
.summary__meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:12px;color:var(--color-text-muted);font-size:.9rem;}
.summary__meta .sep{width:1px;height:14px;background:var(--color-border-strong);}
.summary h1{margin-bottom:14px;}
.summary__price{display:flex;align-items:baseline;gap:12px;margin-bottom:18px;}
.summary__price .price-now{font-size:1.8rem;}
.summary__price .price-old{font-size:1.2rem;}
.summary__desc{margin-bottom:24px;max-width:90%;}
.attr-group{margin-bottom:20px;}
.attr-group label{display:block;font-weight:500;color:var(--color-heading);margin-bottom:9px;}
.attr-options{display:flex;gap:10px;flex-wrap:wrap;}
.attr-options .chip{user-select:none;}
.attr-options .chip.is-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);}

.buy-row{display:flex;gap:14px;align-items:stretch;margin-bottom:14px;flex-wrap:wrap;}
.qty{display:inline-flex;align-items:center;border:1px solid var(--color-border-strong);border-radius:var(--radius-button);overflow:hidden;}
.qty button{width:46px;height:52px;font-size:1.2rem;color:var(--color-heading);}
.qty button:hover{background:var(--color-bg-soft);}
.qty input{width:52px;height:52px;text-align:center;border:none;border-inline:1px solid var(--color-border);}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.buy-row .btn{flex:1;min-width:160px;}
.summary__wishrow{display:flex;gap:18px;margin:18px 0 24px;}
.summary__wishrow a{display:inline-flex;align-items:center;gap:8px;font-weight:500;color:var(--color-heading);}
.summary__wishrow a:hover{color:var(--color-primary);}
.summary__wishrow svg{width:18px;height:18px;}

/* Trust blocks */
.trust-box{border:1px solid var(--color-border);border-radius:var(--radius-card);padding:22px;margin-bottom:18px;background:var(--color-bg-soft);}
.trust-box__row{display:flex;gap:12px;align-items:flex-start;padding:10px 0;border-bottom:1px dashed var(--color-border-strong);}
.trust-box__row:last-child{border-bottom:none;}
.trust-box__row svg{width:22px;height:22px;flex:none;color:var(--color-primary);margin-top:2px;}
.trust-box__row strong{color:var(--color-heading);}
.safe-checkout{text-align:center;border:1px solid var(--color-border);border-radius:var(--radius-card);padding:20px;}
.safe-checkout p{font-weight:500;color:var(--color-heading);margin-bottom:12px;}
.safe-checkout .pay-methods{justify-content:center;}
.safe-checkout .pay-methods img{background:#fff;border:1px solid var(--color-border);}

.product-extra{display:flex;flex-direction:column;gap:16px;}

/* Benefits grid (product tab) */
.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.benefit-block{padding:28px;border:1px solid var(--color-border);border-radius:var(--radius-card);text-align:center;transition:all var(--t);}
.benefit-block:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm);}
.benefit-block__icon{width:62px;height:62px;margin:0 auto 16px;border-radius:50%;background:var(--color-primary-soft);display:flex;align-items:center;justify-content:center;}
.benefit-block__icon img{width:30px;height:30px;}
.benefit-block h5{margin-bottom:8px;}
.benefit-block p{font-size:.9rem;color:var(--color-text-muted);margin:0;}

/* Info table */
.info-table{width:100%;border-collapse:collapse;}
.info-table tr{border-bottom:1px solid var(--color-border);}
.info-table th{text-align:left;padding:14px 0;width:40%;color:var(--color-heading);font-weight:500;}
.info-table td{padding:14px 0;color:var(--color-text-main);}

/* Reviews */
.reviews-summary{display:flex;gap:36px;align-items:center;margin-bottom:34px;flex-wrap:wrap;}
.reviews-score{text-align:center;}
.reviews-score .big{font-size:3rem;font-weight:600;color:var(--color-heading);line-height:1;}
.review{display:flex;gap:16px;padding:22px 0;border-bottom:1px solid var(--color-border);}
.review img{width:52px;height:52px;border-radius:50%;flex:none;}
.review__head{display:flex;align-items:center;gap:12px;margin-bottom:6px;}
.review__head strong{color:var(--color-heading);}
.review__head .date{font-size:.82rem;color:var(--color-text-muted);}

.description-tab p{max-width:760px;}

/* =============================================================== RESPONSIVE */
@media (max-width:1100px){
  .product-grid{grid-template-columns:repeat(3,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:34px;}
  .benefit{padding:26px 18px;}
}
@media (max-width:1024px){
  :root{--section-y:64px;}
  .main-nav,.header-search{display:none;}
  .nav-toggle{display:flex;}
  .hero__slide-inner,.hero__media{min-height:460px;}
  .hero__slide{min-height:460px;}
  .layers{grid-template-columns:1fr;gap:34px;}
  .cat-grid{grid-template-columns:repeat(3,1fr);}
  .benefit-grid{grid-template-columns:repeat(2,1fr);}
  .product-top{grid-template-columns:1fr;gap:34px;}
}
@media (max-width:860px){
  .benefits-bar__grid{grid-template-columns:repeat(2,1fr);}
  .benefit{border-bottom:1px solid var(--color-border);}
  .benefit:nth-child(2){border-right:none;}
  .promo-banner{grid-template-columns:1fr;}
  .promo-banner__media{min-height:260px;}
  .promo-banner__content{padding:36px 28px;}
  .commerce-cards,.blog-grid{grid-template-columns:1fr;}
  .product-grid,.product-grid--3{grid-template-columns:repeat(2,1fr);gap:18px;}
  .hero__slide-inner{grid-template-columns:1fr;}
  .hero__media{display:none;}
  .hero__content{text-align:center;margin-inline:auto;padding:48px 0;}
  .hero__content p{margin-inline:auto;}
  .footer-cta__inner{flex-direction:column;text-align:center;}
  .benefit-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  :root{--gutter:18px;}
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr;}
  .topbar__promo{display:none;}
  .shop-toolbar__right .view-toggles{display:none;}
  .filter-drawer{width:100vw;max-width:100vw;}
  .mobile-nav{inset:0 12% 0 0;}
  .gallery__thumbs{grid-template-columns:repeat(4,1fr);}
  .buy-row .btn{min-width:100%;}
  .product-card__choose{font-size:.85rem;}
}
@media (max-width:380px){
  .product-grid,.product-grid--3{grid-template-columns:1fr;}
}
