/**
 * product.css
 * Stili SOLO per pagine prodotto.
 * Obiettivo: premium, visual-first, sezioni compatte.
 */

/* =========================================================
   HERO PRODOTTO
   ========================================================= */

.product-hero{
  padding: 84px 0 46px;
}

.product-hero-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 26px;
  align-items:center;
}
.product-hero-grid > *{ min-width:0; }

.kicker{
  margin: 0 0 12px;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(240,138,34,.92);
}

.product-hero-copy h1{
  margin: 0 0 14px;
  font-size: clamp(34px, 5vw, 62px);
  letter-spacing: -0.03em;
  line-height: 1.06;
}

.hero-actions{
  margin-top: 18px;
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

.hero-mini{
  margin-top: 18px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* =========================================================
   MINI PILL
   ========================================================= */

.mini-pill{
  appearance: none;
  border: 1px solid rgba(240,138,34,.22);
  background: rgba(240,138,34,.08);
  border-radius: 999px;
  padding: 8px 12px;
  font-weight: 800;
  font-size: 12px;
  color: var(--text);
  cursor: pointer;
  transition: transform .15s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.mini-pill:hover{
  border-color: rgba(240,138,34,.55);
  box-shadow: 0 0 0 3px rgba(240,138,34,.12), 0 12px 34px rgba(0,0,0,.32);
  background: rgba(240,138,34,.12);
  transform: translateY(-1px);
}

.mini-pill:focus-visible{
  outline: none;
  border-color: rgba(240,138,34,.70);
  box-shadow: 0 0 0 4px rgba(240,138,34,.18), 0 14px 38px rgba(0,0,0,.34);
}

.mini-pill.is-active{
  border-color: rgba(240,138,34,.75);
  background: rgba(240,138,34,.16);
  box-shadow: 0 0 0 4px rgba(240,138,34,.14), 0 14px 38px rgba(0,0,0,.34);
}

/* =========================================================
   HERO MEDIA
   ========================================================= */

.product-hero-media{
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 10px);
  overflow:hidden;
  box-shadow: var(--shadow);
  background: rgba(255,255,255,.02);
  aspect-ratio: 16 / 10;
}

.product-hero-media img{
  width:100%;
  height:100%;
  display:block;
  object-fit: cover;
  object-position: center;
}

/* =========================================================
   MODELLI PRODOTTO
   ========================================================= */

/* Variabili locali SOLO al product scope */
.product{
  --director-card-h: 360px;
  --director-media-w: 360px;
  --director-media-h: 220px;
}

.models-grid{
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.model-card{
  display:grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 18px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  border-radius: calc(var(--radius) + 10px);
  overflow:hidden;
  box-shadow: var(--shadow);
  min-height: var(--director-card-h);
  position: relative;
}
.model-card > *{ min-width:0; }

.model-card.is-highlight{
  border-color: rgba(240,138,34,.55);
  box-shadow: 0 0 0 4px rgba(240,138,34,.14), 0 24px 60px rgba(0,0,0,.42);
}

.model-media{
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.model-media img{
  width: var(--director-media-w);
  height: var(--director-media-h);
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  transition: transform .25s ease;
}

/* tuning singoli modelli */
.model-card#tiny  .model-media img{ transform: scale(1.00); }
.model-card#qube  .model-media img{ transform: scale(1.18); }
.model-card#next  .model-media img{ transform: scale(1.12); }

.model-body{
  padding: 18px;
  display:flex;
  align-items:center;
}

.model-body h3{
  margin: 0 0 10px;
  font-size: 22px;
}

.accent{ color: rgba(240,138,34,.92); }

.specs{
  margin: 14px 0 0;
  padding-left: 16px;
  color: var(--muted);
  line-height: 1.7;
}
.specs strong{ color: var(--text); }

/* =========================================================
   FEATURE GRID
   ========================================================= */

.features-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
}

.feature-box{
  border: 1px solid var(--border);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: 14px;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width: 980px){
  .product-hero-grid{ grid-template-columns: 1fr; }

  .product-hero-media{ aspect-ratio: 16 / 11; }

  .model-card{
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .model-media{ padding: 14px; }

  .model-media img{
    width: min(420px, 100%);
    height: auto;
    aspect-ratio: 16 / 9;
    transform: none !important;
  }

  .model-body{ align-items: flex-start; }

  .features-grid{ grid-template-columns: 1fr; }
}

@media (max-width: 560px){
  .product-hero-media img{
    object-fit: contain;
    background: rgba(255,255,255,.02);
  }
}
