/* ============================================================
   1UZ — Products page styles (extends styles.css)
   ============================================================ */

/* page hero */
.page-hero{ position:relative; overflow:hidden; padding-top:calc(var(--nav-h) + 70px); padding-bottom:46px; }
.page-hero .wrap{ position:relative; z-index:2; }
.page-hero h1{ font-size:clamp(40px,5.4vw,72px); max-width:900px; margin-top:18px; }
.page-hero h1 .gradient-text{ display:inline; }
.page-hero p{ font-size:clamp(17px,1.6vw,20px); color:var(--ink-soft); max-width:640px; margin-top:22px; }
.page-hero .crumbs{ display:flex; gap:8px; align-items:center; font-size:14px; color:var(--muted); font-weight:600; margin-bottom:6px; }
.page-hero .crumbs a:hover{ color:var(--c-blue); }

/* filter bar */
.pfilter{ display:flex; flex-wrap:wrap; gap:10px; margin-top:40px; }
.fchip{
  padding:11px 19px; border-radius:var(--r-pill); font-family:var(--font-display);
  font-weight:700; font-size:14.5px; color:var(--ink-soft);
  background:var(--surface); border:1.5px solid var(--line-2); transition:.18s; white-space:nowrap;
}
.fchip:hover{ border-color:var(--c-blue); color:var(--c-blue); }
.fchip.on{ background:var(--grad-brand); color:#fff; border-color:transparent; box-shadow:var(--sh-blue); }
.fchip .n{ opacity:.6; font-weight:600; margin-left:4px; }
.fchip.on .n{ opacity:.8; }

/* product grid */
.cat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.pcard{
  position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:32px; display:flex; flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s, opacity .3s;
  overflow:hidden;
}
.pcard:hover{ transform:translateY(-6px); box-shadow:var(--sh); border-color:transparent; }
.pcard .ic{ width:56px; height:56px; border-radius:16px; display:grid; place-items:center; color:#fff; margin-bottom:22px; flex:none; }
.pcard h3{ font-size:23px; }
.pcard .ptag{ color:var(--muted); font-size:15px; margin-top:9px; line-height:1.45; }
.pcard .pfeat{ margin:22px 0 26px; display:grid; gap:11px; }
.pcard .pfeat li{ display:flex; gap:11px; font-size:14.5px; color:var(--ink-soft); align-items:flex-start; line-height:1.4; }
.pcard .pfeat .dot{ width:7px; height:7px; border-radius:50%; background:var(--grad-brand); margin-top:7px; flex:none; }
.pcard .pcta{ margin-top:auto; display:flex; align-items:center; gap:14px; }
.pcard .plink{ font-family:var(--font-display); font-weight:700; font-size:14.5px; color:var(--c-blue); display:inline-flex; align-items:center; gap:6px; }
.pcard .plink svg{ transition:transform .2s; }
.pcard:hover .plink svg{ transform:translateX(4px); }
.pcard .free{ font-size:13px; font-weight:600; color:var(--c-violet); }

.pbadge{ position:absolute; top:24px; right:24px; font-family:var(--font-display); font-weight:700; font-size:11.5px; letter-spacing:.06em; text-transform:uppercase; padding:6px 12px; border-radius:var(--r-pill); }
.pbadge.hit{ background:var(--c-magenta); color:#fff; }
.pbadge.mod{ background:rgba(124,77,255,.12); color:var(--c-violet); }
.pbadge.free{ background:rgba(31,198,230,.16); color:#0a93b0; }

/* flagship */
.pcard.flag{
  grid-column:span 2; background:var(--grad-hero); color:#fff; border:none;
  display:grid; grid-template-columns:1.05fr .95fr; gap:34px; align-items:center; padding:40px;
}
.pcard.flag:hover{ transform:translateY(-6px); }
.pcard.flag .ic{ background:rgba(255,255,255,.18); }
.pcard.flag h3{ font-size:32px; }
.pcard.flag .ptag{ color:rgba(255,255,255,.85); font-size:16.5px; }
.pcard.flag .pfeat li{ color:rgba(255,255,255,.92); font-size:15.5px; }
.pcard.flag .pfeat .dot{ background:#fff; }
.pcard.flag .plink{ color:#fff; }
.pcard.flag .btn{ margin-top:2px; }
.pcard.flag .flag-media{ align-self:stretch; }
.pcard.flag .shot-ph{ aspect-ratio:4/3; height:100%; box-shadow:0 30px 60px -24px rgba(0,0,0,.5); }
.pcard.flag .shot-ph .label{ color:var(--c-blue); }

.pcard[hidden]{ display:none; }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(18px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion:reduce){ .pcard{ animation:none !important; } }

/* modules band */
.mod-band{ background:var(--bg-2); border-radius:var(--r-xl); padding:clamp(32px,4vw,52px); display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:center; }
.mod-band .mb-copy h2{ font-size:clamp(26px,3vw,38px); }
.mod-band .mb-copy p{ color:var(--muted); font-size:17px; margin-top:16px; max-width:440px; }
.mod-mini{ display:grid; gap:16px; }
.mod-mini .mm{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:22px 24px; display:flex; gap:16px; align-items:center; }
.mod-mini .mm .ic{ width:48px; height:48px; border-radius:13px; display:grid; place-items:center; color:#fff; flex:none; }
.mod-mini .mm b{ font-family:var(--font-display); font-size:18px; display:block; }
.mod-mini .mm span{ font-size:14px; color:var(--muted); }

/* helper / chooser cta */
.chooser{ position:relative; overflow:hidden; border-radius:var(--r-xl); background:var(--surface); border:1px solid var(--line); padding:clamp(36px,4vw,56px); text-align:center; box-shadow:var(--sh-sm); }
.chooser h2{ font-size:clamp(26px,3.2vw,40px); max-width:680px; margin-inline:auto; }
.chooser p{ color:var(--muted); font-size:18px; margin-top:16px; max-width:560px; margin-inline:auto; }
.chooser .cta-row{ display:flex; gap:14px; justify-content:center; margin-top:30px; flex-wrap:wrap; }
.chooser .blob{ opacity:.5; }

@media (max-width:1080px){
  .cat-grid{ grid-template-columns:repeat(2,1fr); }
  .pcard.flag{ grid-column:span 2; grid-template-columns:1fr; }
  .pcard.flag .flag-media{ display:none; }
  .mod-band{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .cat-grid{ grid-template-columns:1fr; }
  .pcard.flag{ grid-column:span 1; padding:30px; }
  .page-hero{ padding-top:calc(var(--nav-h) + 34px); }
  .pfilter{ margin-top:28px; gap:8px; flex-wrap:nowrap; overflow-x:auto; padding-bottom:6px; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .pfilter::-webkit-scrollbar{ display:none; }
  .fchip{ padding:10px 15px; font-size:13.5px; }
  .pcard{ padding:26px; }
}
