/* Reutiliza el estilo general */
@import url("styles.css");

.page-hero{
  padding:70px 0 40px;
  background:
    radial-gradient(1000px 450px at 50% 10%, rgba(255,255,255,.09), transparent 65%),
    #000;
}
.page-hero .wrap{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.page-hero h1{
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight:950;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.page-hero p{ margin-top:10px; opacity:.78; max-width:680px; }
.size-tag{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:12px;
  padding:10px 14px;
  border:1px solid var(--border);
  border-radius:14px;
  background: linear-gradient(120deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: 0 12px 38px rgba(0,0,0,.45);
  font-weight:850;
  letter-spacing:.10em;
  text-transform:uppercase;
  opacity:.92;
}
.page-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
}

.gallery{
  padding:40px 0 80px;
}
.gallery-head{
  text-align:center;
  margin-bottom:18px;
}
.gallery-head h2{
  font-weight:950;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.gallery-head p{ opacity:.75; margin-top:8px; }

.gallery-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:16px;
  margin-top:20px;
  justify-items:center;
}
.size-row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:12px;
}
.size-picker{
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  background: rgba(255,255,255,.04);
  max-width:360px;
  min-width:280px;
  box-shadow:0 12px 38px rgba(0,0,0,.45);
}
.size-picker__label{
  font-size:14px;
  opacity:.8;
  margin-bottom:8px;
}
.size-picker__options{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.size-btn{
  padding:10px 14px;
  border-radius:10px;
  border:1px solid #444;
  background:#0d0d0d;
  color:#fff;
  cursor:pointer;
  transition:all .15s ease;
  letter-spacing:.04em;
  font-weight:700;
}
.size-btn:hover{ border-color:#888; transform:translateY(-1px); }
.size-btn.is-active{ background:#fff; color:#0d0d0d; border-color:#fff; box-shadow:0 8px 26px rgba(0,0,0,.35); }
.size-guide-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06);
  font-weight:750;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.75rem;
  gap:6px;
}
.size-guide-btn:hover{
  border-color:rgba(255,255,255,.28);
  transform:translateY(-1px);
}
.photo{
  display:grid;
  place-items:center;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  box-shadow: 0 18px 60px rgba(0,0,0,.55);
}
.photo a{ width:100%; height:100%; display:block; }
.photo img{
  width:100%;
  aspect-ratio: 4 / 3;
  object-fit:cover;
  object-position:center;
}
.face-focus{
  aspect-ratio: 3 / 4;
  object-position:center 0%;
}

.size-guide{
  padding:40px 0 70px;
}
.guide-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:12px;
  margin-top:16px;
}
.guide-card{
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px 16px;
  background: rgba(255,255,255,.04);
  box-shadow:0 12px 34px rgba(0,0,0,.45);
}
.guide-card h4{
  margin-bottom:8px;
  letter-spacing:.12em;
  font-weight:900;
}
.guide-card ul{ list-style:none; padding:0; margin:0; }
.guide-card li{
  font-size:.95rem;
  opacity:.88;
  display:flex;
  justify-content:space-between;
}
.guide-note{
  margin-top:12px;
  opacity:.75;
  font-size:.9rem;
}

/* ============ CART ============ */
#cart-root{
  position:fixed;
  top:68px;
  right:16px;
  z-index:120;
  font-family: inherit;
}
.cart-toggle{
  all:unset;
  display:inline-flex;
  align-items:center;
  gap:4px;
  color:#fff;
  font-weight:850;
  letter-spacing:.08em;
  cursor:pointer;
  line-height:1;
  background:none !important;
  border:none !important;
  box-shadow:none !important;
  padding:0 !important;
  margin:0 !important;
}
.cart-toggle:focus{ outline:none; }
.cart-toggle::-moz-focus-inner{ border:0; padding:0; }
.cart-icon svg{
  display:block;
  stroke:#fff;
  width:22px;
  height:22px;
  fill:none;
  background:none !important;
}
.cart-count{
  font-weight:850;
  letter-spacing:.08em;
  color:#fff;
}
.navlinks .cart-toggle{
  padding:0;
  background:transparent;
  border:none;
  box-shadow:none;
  color:#fff;
}
.cart-drawer{
  position:absolute;
  right:0;
  top:46px;
  width:340px;
  max-height:75vh;
  background: rgba(12,12,12,.96);
  border:1px solid var(--border);
  border-radius:16px;
  padding:16px;
  box-shadow:0 18px 50px rgba(0,0,0,.65);
  flex-direction:column;
  gap:14px;
  transform: translateX(110%);
  transition: transform .28s ease, opacity .28s ease;
  opacity:0;
  pointer-events:none;
}
#cart-root.is-open .cart-drawer{
  transform: translateX(0);
  opacity:1;
  pointer-events:auto;
}
.cart-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  font-weight:900;
  letter-spacing:.1em;
  gap:10px;
}
.cart-title-row{
  display:flex;
  align-items:center;
  gap:10px;
}
.cart-close{
  border:none;
  background:transparent;
  color:var(--fg);
  font-size:1.4rem;
  cursor:pointer;
}
.cart-title{ text-transform:uppercase; }
.cart-pill{
  padding:6px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  font-size:.8rem;
  letter-spacing:.05em;
}
.cart-items{
  display:flex;
  flex-direction:column;
  gap:10px;
  overflow:auto;
  max-height:45vh;
  padding-right:4px;
}
.cart-item{
  display:grid;
  grid-template-columns: 56px 1fr auto;
  gap:10px;
  align-items:center;
  border:1px solid var(--border);
  border-radius:12px;
  padding:8px;
  background: rgba(255,255,255,.03);
}
.cart-thumb{
  display:block;
  width:56px;
  height:56px;
  overflow:hidden;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.12);
}
.cart-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.cart-meta{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.cart-name{
  font-weight:800;
  letter-spacing:.04em;
}
.cart-size{
  opacity:.8;
}
.cart-remove{
  border:none;
  background:transparent;
  color:var(--fg);
  font-size:1.2rem;
  cursor:pointer;
}
.cart-info{
  padding:10px 12px;
  border-radius:12px;
  background: rgba(255,255,255,.04);
  border:1px solid var(--border);
}
.cart-alert{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  letter-spacing:.02em;
}
.dot{
  width:10px; height:10px; border-radius:50%;
  display:inline-block;
}
.dot-success{ background:#28c76f; }
.cart-code{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.cart-code label{ font-weight:800; letter-spacing:.05em; font-size:.9rem; }
.cart-code-row{
  display:flex;
  gap:8px;
}
.cart-code input{
  flex:1;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.06);
  color:#fff;
}
.cart-apply{
  padding:10px 14px;
  border-radius:10px;
  background:#fff;
  color:#000;
  font-weight:800;
  letter-spacing:.08em;
  border:1px solid rgba(255,255,255,.2);
  cursor:pointer;
}
.cart-code-hint{
  font-size:.85rem;
  opacity:.7;
}
.cart-summary{
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  background:rgba(255,255,255,.03);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.summary-line{
  display:flex;
  justify-content:space-between;
  font-weight:750;
  letter-spacing:.03em;
}
.cart-footer{ display:flex; }
.cart-empty{ opacity:.75; text-align:center; padding:6px; }
.cart-checkout{ width:100%; }

@media (max-width: 900px){
  .gallery-grid{ grid-template-columns: 1fr; }
}
