/* ============================================================
   MISHIKAS ELECTRONICS — Product Page CSS (cooler-page.php)
   ============================================================ */

:root {
  --pp-blue: #003995;
  --pp-blue-deep: #002A6E;
  --pp-blue-soft: #4D7BD6;
  --pp-amber: #F5B042;
  --pp-amber-warm: #E89A2B;
  --pp-amber-soft: #FFE9C2;
  --pp-ink: #0A1730;
  --pp-ink-mid: #45527A;
  --pp-ink-soft: #7B8499;
  --pp-bg: #FAFBFE;
  --pp-bg-cream: #FFF8EE;
  --pp-border: #E5EAF5;
  --pp-border-warm: #F2E4C8;
  --pp-shadow-sm: 0 2px 8px -2px rgba(10,23,48,.06);
  --pp-shadow-md: 0 12px 32px -12px rgba(10,23,48,.14);
  --pp-shadow-lg: 0 28px 56px -20px rgba(0,57,149,.22);
  --pp-shadow-amber: 0 16px 32px -12px rgba(245,176,66,.45);
  --pp-shadow-blue: 0 16px 32px -12px rgba(0,57,149,.32);
}

.pp-shell { background: var(--pp-bg); color: var(--pp-ink); font-family: 'Poppins', system-ui, -apple-system, sans-serif; min-height: 100vh; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
.pp-shell h1, .pp-shell h2, .pp-shell h3, .pp-shell h4 { font-family: "Playfair Display", serif; letter-spacing: -0.01em; line-height: 1.1; color: var(--pp-ink); text-wrap: balance; }
.pp-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* ─── NAV ─────────────────────────────────────────────── */
.pp-nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.88); backdrop-filter: blur(14px) saturate(140%); border-bottom: 1px solid var(--pp-border); }
.pp-nav__inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.pp-nav__logo img { height: 36px; width: auto; }
.pp-nav__links { display: flex; gap: 1.75rem; align-items: center; }
.pp-nav__links a:not(.pp-btn) { color: var(--pp-ink-mid); font-size: 0.88rem; font-weight: 500; text-decoration: none; transition: color 0.2s; }
.pp-nav__links a:not(.pp-btn):hover { color: var(--pp-blue); }

/* ─── BREADCRUMBS ─────────────────────────────────────── */
.pp-crumbs { padding-top: 1.5rem; padding-bottom: 0.5rem; font-size: 0.82rem; color: var(--pp-ink-soft); display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem; }
.pp-crumbs a { color: var(--pp-ink-mid); text-decoration: none; transition: color .2s; }
.pp-crumbs a:hover { color: var(--pp-blue); }
.pp-crumbs strong { color: var(--pp-ink); font-weight: 600; }

/* ─── HERO ────────────────────────────────────────────── */
.pp-hero { padding: 1.5rem 0 4rem; position: relative; isolation: isolate; overflow: hidden; }
.pp-hero__bg { position: absolute; inset: 0; z-index: -1; background: radial-gradient(60% 70% at 80% 20%, rgba(0,57,149,.10), transparent 60%), radial-gradient(50% 60% at 10% 90%, rgba(245,176,66,.14), transparent 60%), linear-gradient(180deg, #FFFFFF 0%, #FAFBFE 100%); }
.pp-hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at top left, rgba(245,176,66,.10), transparent 55%), radial-gradient(ellipse at top right, rgba(0,57,149,.08), transparent 55%); pointer-events: none; z-index: 0; }
.pp-hero > * { position: relative; z-index: 1; }
.pp-hero__grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 3.5rem; align-items: center; }
.pp-hero__media { position: relative; border-radius: 1.5rem; overflow: hidden; background: linear-gradient(135deg, #FFF6E8 0%, #FFE4BC 100%); box-shadow: var(--pp-shadow-lg); border: 1px solid var(--pp-border-warm); aspect-ratio: 4 / 3.2; }
.pp-hero__media img { width: 100%; height: 100%; display: block; object-fit: contain; padding: 1.5rem; transition: transform .6s cubic-bezier(.2,.8,.2,1); }
.pp-hero__media:hover img { transform: scale(1.03); }
.pp-hero__badge { position: absolute; top: 1rem; left: 1rem; background: rgba(255,255,255,0.95); backdrop-filter: blur(8px); color: var(--pp-blue); font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; padding: 0.4rem 0.9rem; border-radius: 2rem; border: 1px solid rgba(0,57,149,.12); box-shadow: var(--pp-shadow-sm); }

.pp-hero__gallery { display: flex; flex-direction: column; gap: 14px; position: relative; }
.pp-hero__gallery-item { position: relative; border-radius: 18px; overflow: hidden; background: linear-gradient(135deg, #FFF6E8 0%, #FFE4BC 100%); border: 1px solid var(--pp-border-warm); box-shadow: var(--pp-shadow-md); }
.pp-hero__gallery-item--main { aspect-ratio: 4 / 3.2; }
.pp-hero__gallery-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.pp-hero__gallery-row .pp-hero__gallery-item { aspect-ratio: 1 / 1; }
.pp-hero__media--gallery .pp-hero__gallery-item img { width: 100%; height: 100%; object-fit: contain; padding: 1rem; display: block; transition: transform .5s cubic-bezier(.2,.8,.2,1); }
.pp-hero__media--gallery .pp-hero__gallery-item--main img { padding: 1.5rem; }
.pp-hero__gallery-item:hover img { transform: scale(1.04); }

.pp-hero__media--gallery { aspect-ratio: auto; background: transparent; border: none; box-shadow: none; padding: 0; overflow: visible; border-radius: 0; }
.pp-hero__media--gallery:hover img { transform: none; }

.pp-eyebrow { color: var(--pp-amber-warm); font-size: 0.76rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: 0.7rem; font-family: 'Poppins', sans-serif; }
.pp-hero__info h1 { font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 600; color: var(--pp-ink); margin: 0 0 0.6rem; line-height: 1.08; }
.pp-tagline { font-size: 1.12rem; color: var(--pp-blue); margin: 0 0 1.1rem; font-weight: 500; font-style: italic; font-family: "Playfair Display", serif; }
.pp-desc { font-size: 0.97rem; color: var(--pp-ink-mid); line-height: 1.7; margin: 0 0 1.75rem; }
.pp-usage-badge { display: inline-block; margin-left: 10px; padding: 3px 10px; font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #fff; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.22); border-radius: 999px; vertical-align: middle; }

/* Thumbs */
.pp-hero__thumbs { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.pp-hero__thumb { width: 72px; height: 72px; border-radius: 10px; overflow: hidden; border: 2px solid rgba(255,255,255,0.15); background: rgba(255,255,255,0.04); cursor: pointer; padding: 0; transition: border-color .2s ease, transform .2s ease; }
.pp-hero__thumb:hover { transform: translateY(-2px); }
.pp-hero__thumb--active { border-color: #d4a24a; }
.pp-hero__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ─── BUTTONS ─────────────────────────────────────────── */
.pp-btn { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; font-weight: 600; font-family: 'Poppins', sans-serif; border-radius: 0.6rem; cursor: pointer; text-decoration: none; transition: transform 0.18s ease, box-shadow 0.22s ease, background 0.22s ease, color 0.22s ease; border: 2px solid transparent; font-size: 0.92rem; padding: 0.7rem 1.4rem; white-space: nowrap; letter-spacing: 0.01em; will-change: transform; }
.pp-btn:hover:not(:disabled) { transform: translateY(-2px); }
.pp-btn:active:not(:disabled) { transform: translateY(0); }
.pp-btn--sm { padding: 0.45rem 1rem; font-size: 0.82rem; }
.pp-btn--lg { padding: 0.95rem 1.9rem; font-size: 1rem; }
.pp-btn--block { width: 100%; }
.pp-btn--primary { background: var(--pp-blue); color: #fff; box-shadow: var(--pp-shadow-blue); }
.pp-btn--primary:hover { background: var(--pp-blue-deep); box-shadow: 0 22px 40px -14px rgba(0,57,149,.5); }
.pp-btn--wa { background: #25d366; color: #fff; box-shadow: 0 16px 32px -12px rgba(37,211,102,.45); }
.pp-btn--wa:hover { background: #1cb854; }
.pp-btn--outline { background: #fff; color: var(--pp-blue); border: 2px solid var(--pp-blue); }
.pp-btn--outline:hover { background: var(--pp-blue); color: #fff; }
.pp-btn--ghost { background: transparent; color: var(--pp-ink-mid); }
.pp-btn--ghost:hover { color: var(--pp-blue); background: rgba(0,57,149,.05); }

/* ─── CTAS ────────────────────────────────────────────── */
.pp-ctas { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-bottom: 1.75rem; }
.pp-trust { display: flex; flex-wrap: wrap; gap: 1.1rem; font-size: 0.83rem; color: var(--pp-ink-mid); padding-top: 1rem; border-top: 1px solid var(--pp-border); }
.pp-trust span { display: inline-flex; align-items: center; gap: 0.35rem; font-weight: 500; }

/* ─── VARIANTS ────────────────────────────────────────── */
.pp-variants { margin-bottom: 1.75rem; }
.pp-variants__label { display: block; font-size: 0.74rem; color: var(--pp-ink-soft); margin-bottom: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; }
.pp-variants__chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.pp-chip { padding: 0.55rem 1.1rem; border-radius: 999px; background: #fff; border: 1.5px solid var(--pp-border); color: var(--pp-ink-mid); font-size: 0.88rem; font-weight: 600; font-family: 'Poppins', sans-serif; cursor: pointer; transition: all 0.2s ease; min-height: 40px; }
.pp-chip:hover { border-color: var(--pp-blue); color: var(--pp-blue); }
.pp-chip--active { background: var(--pp-blue); border-color: var(--pp-blue); color: #fff; box-shadow: 0 6px 16px -6px rgba(0,57,149,.4); }

/* ─── SECTIONS ────────────────────────────────────────── */
.pp-section { padding: 5rem 0; }
.pp-section--alt { background: var(--pp-bg-cream); }
.pp-section__head { text-align: center; margin-bottom: 3rem; }
.pp-section__head h2 { font-size: clamp(1.7rem, 3.4vw, 2.4rem); font-weight: 600; color: var(--pp-ink); margin: 0.4rem auto 0; max-width: 720px; }
.pp-section__sub { max-width: 620px; margin: 12px auto 0; color: var(--pp-ink-mid); font-size: 1rem; line-height: 1.55; text-align: center; }

/* ─── FEATURES ────────────────────────────────────────── */
.pp-features { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.5rem; }
.pp-feature { background: #fff; border: 1px solid var(--pp-border); border-radius: 1.25rem; padding: 1.75rem; transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease; position: relative; }
.pp-feature:hover { transform: translateY(-6px); border-color: rgba(245,176,66,.4); box-shadow: var(--pp-shadow-md); }
.pp-feature__num { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: 999px; background: linear-gradient(135deg, var(--pp-amber) 0%, var(--pp-amber-warm) 100%); color: #fff; font-size: 0.95rem; font-weight: 800; font-family: 'Poppins', sans-serif; margin-bottom: 1rem; box-shadow: 0 6px 14px -6px rgba(245,176,66,.5); }
.pp-feature p { font-size: 0.95rem; color: var(--pp-ink-mid); margin: 0; line-height: 1.6; font-weight: 500; }

/* ─── SPECS ───────────────────────────────────────────── */
.pp-specs { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.25rem; }
.pp-spec-card { background: #fff; border: 1px solid var(--pp-border); border-radius: 1.25rem; padding: 1.75rem; display: flex; flex-direction: column; transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease; }
.pp-spec-card:hover { box-shadow: var(--pp-shadow-md); border-color: rgba(0,57,149,.18); }
.pp-spec-card__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.6rem; gap: 0.6rem; }
.pp-spec-card__top h3 { font-size: 1.15rem; font-weight: 600; color: var(--pp-ink); margin: 0; font-family: "Playfair Display", serif; }
.pp-cap { background: rgba(0,57,149,.08); color: var(--pp-blue); font-size: 0.78rem; font-weight: 700; padding: 0.3rem 0.75rem; border-radius: 0.4rem; white-space: nowrap; }
.pp-spec-card__desc { font-size: 0.88rem; color: var(--pp-ink-mid); line-height: 1.55; margin: 0 0 1.4rem; flex-grow: 1; }
.pp-spec-card__price { display: flex; align-items: baseline; gap: 0.5rem; margin-bottom: 1rem; padding-top: 1rem; border-top: 1px dashed var(--pp-border); }
.pp-spec-card__price .lbl { font-size: 0.72rem; color: var(--pp-ink-soft); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.pp-spec-card__price strong { font-size: 1.5rem; font-weight: 700; color: var(--pp-blue); font-family: "Playfair Display", serif; }
.pp-spec-card__cta { display: flex; align-items: center; justify-content: center; text-align: center; padding: 0.75rem; border-radius: 0.6rem; background: linear-gradient(135deg, rgba(245,176,66,.12), rgba(245,176,66,.08)); color: var(--pp-amber-warm); font-size: 0.86rem; font-weight: 600; text-decoration: none; transition: all 0.2s ease; min-height: 44px; }
.pp-spec-card__cta:hover { background: var(--pp-amber); color: #fff; box-shadow: 0 8px 18px -8px rgba(245,176,66,.5); }

/* ─── TECH SPECS ──────────────────────────────────────── */
.pp-techspecs { background: linear-gradient(180deg, #FFFFFF 0%, #FFF8EE 100%); }
.pp-techspecs__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 2.5rem; }
.pp-techspecs__group { background: #fff; border: 1px solid var(--pp-border); border-radius: 18px; padding: 28px 28px 22px; box-shadow: var(--pp-shadow-sm); transition: transform .3s ease, box-shadow .3s ease; }
.pp-techspecs__group:hover { transform: translateY(-4px); box-shadow: var(--pp-shadow-md); border-color: var(--pp-border-warm); }
.pp-techspecs__title { font-family: "Playfair Display",serif; font-size: 1.35rem; font-weight: 600; color: var(--pp-blue-deep); margin: 0 0 1rem; padding-bottom: 0.7rem; border-bottom: 2px solid var(--pp-amber-soft); }
.pp-techspecs__list { margin: 0; padding: 0; }
.pp-techspecs__row { display: flex; justify-content: space-between; gap: 1rem; padding: 0.7rem 0; border-bottom: 1px dashed var(--pp-border); font-size: 0.95rem; }
.pp-techspecs__row:last-child { border-bottom: none; }
.pp-techspecs__row dt { color: var(--pp-ink-mid); font-weight: 500; flex: 0 0 auto; max-width: 55%; }
.pp-techspecs__row dd { margin: 0; color: var(--pp-ink); font-weight: 600; text-align: right; }

/* ─── LEAD FORM ───────────────────────────────────────── */
.pp-lead { background: var(--pp-bg-cream); }
.pp-lead__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3.5rem; align-items: center; }
.pp-lead__copy h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 600; color: var(--pp-ink); margin: 0.4rem 0 1rem; }
.pp-lead__copy > p { font-size: 0.98rem; color: var(--pp-ink-mid); line-height: 1.7; margin: 0 0 1.5rem; }
.pp-lead__list { list-style: none; padding: 0; margin: 0; }
.pp-lead__list li { font-size: 0.93rem; color: var(--pp-ink); padding: 0.5rem 0; display: flex; align-items: center; gap: 0.5rem; font-weight: 500; }

/* Form */
.pp-form { background: #fff; border: 1px solid var(--pp-border); border-radius: 1.25rem; padding: 2rem; box-shadow: var(--pp-shadow-md); }
.pp-form__title { font-size: 1.25rem; font-weight: 600; color: var(--pp-ink); margin: 0 0 0.3rem; font-family: "Playfair Display", serif; }
.pp-form__sub { font-size: 0.85rem; color: var(--pp-ink-soft); margin: 0 0 1.5rem; }
.pp-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1rem; }
.pp-form__field { display: flex; flex-direction: column; gap: 0.4rem; }
.pp-form__field--full { grid-column: 1 / -1; }
.pp-form__field span { font-size: 0.82rem; color: var(--pp-ink); font-weight: 600; }
.pp-form__field span em { color: var(--pp-amber-warm); font-style: normal; }
.pp-form__field input, .pp-form__field select, .pp-form__field textarea { background: var(--pp-bg); border: 1.5px solid var(--pp-border); border-radius: 0.55rem; padding: 0.75rem 0.9rem; color: var(--pp-ink); font-size: 16px; outline: none; font-family: 'Poppins', sans-serif; transition: border-color 0.2s, box-shadow 0.2s, background 0.2s; }
.pp-form__field input:focus, .pp-form__field select:focus, .pp-form__field textarea:focus { border-color: var(--pp-blue); background: #fff; box-shadow: 0 0 0 3px rgba(0,57,149,.12); }
.pp-form__field input::placeholder, .pp-form__field textarea::placeholder { color: var(--pp-ink-soft); }
.pp-form__field select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237B8499' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0.75rem center; padding-right: 2rem; }
.pp-form__field small { color: #d6422a; font-size: 0.78rem; }
.pp-form__legal { font-size: 0.74rem; color: var(--pp-ink-soft); text-align: center; margin: 0.85rem 0 0; }
.pp-form--success { text-align: center; padding: 2.5rem 1.75rem; }
.pp-form__success-icon { width: 60px; height: 60px; border-radius: 50%; background: linear-gradient(135deg, #34d399 0%, #10b981 100%); color: #fff; font-size: 1.7rem; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.1rem; box-shadow: 0 12px 24px -10px rgba(16,185,129,.5); }
.pp-form--success h3 { font-size: 1.35rem; font-weight: 600; color: var(--pp-ink); margin: 0 0 0.5rem; font-family: "Playfair Display", serif; }
.pp-form--success p { font-size: 0.94rem; color: var(--pp-ink-mid); margin: 0 0 1.4rem; line-height: 1.6; }

/* ─── COLOUR SWATCHES ────────────────────────────────── */
.pp-colors {
  display: inline-flex;
  flex-direction: column;
  gap: 0;
  margin: 1.2rem 0 0.8rem;
  padding: 0.85rem 1.1rem 0.9rem;
  background: #f4f7ff;
  border: 1.5px solid #dce6f7;
  border-radius: 12px;
}
.pp-colors__label {
  font-size: 0.67rem;
  font-weight: 700;
  color: #8a9bbf;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  margin-bottom: 0.65rem;
}
.pp-colors__swatches { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.pp-color-swatch {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 3px solid #fff;
  box-shadow: 0 0 0 1.5px rgba(0,0,0,0.18);
  cursor: pointer;
  display: inline-block;
  transition: transform 0.18s, box-shadow 0.18s;
}
.pp-color-swatch--active, .pp-color-swatch:hover {
  transform: scale(1.2);
  box-shadow: 0 0 0 2.5px var(--pp-blue), 0 3px 10px rgba(0,57,149,0.25);
}
.pp-colors__name {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--pp-blue);
  margin-top: 0.6rem;
  letter-spacing: 0.01em;
}

/* ─── RELATED ─────────────────────────────────────────── */

.pp-related { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 1.5rem; }
.pp-related__card { display: block; text-decoration: none; background: #fff; border: 1px solid var(--pp-border); border-radius: 1.1rem; overflow: hidden; transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease; }
.pp-related__card:hover { transform: translateY(-6px); border-color: rgba(0,57,149,.18); box-shadow: var(--pp-shadow-md); }
.pp-related__media { aspect-ratio: 1 / 1; overflow: hidden; background: #f4f7ff; display: flex; align-items: center; justify-content: center; padding: 12px; }
.pp-related__media img { width: 100%; height: 100%; object-fit: contain; display: block; transition: transform 0.4s ease; }
.pp-related__card:hover .pp-related__media img { transform: scale(1.04); }
.pp-related__body { padding: 1.25rem; }
.pp-related__body h4 { font-size: 1.1rem; font-weight: 600; color: var(--pp-ink); margin: 0 0 0.3rem; font-family: "Playfair Display", serif; }
.pp-related__body p { font-size: 0.85rem; color: var(--pp-ink-soft); margin: 0 0 0.7rem; line-height: 1.45; }
.pp-related__link { font-size: 0.78rem; color: var(--pp-blue); font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; transition: color 0.2s; }
.pp-related__card:hover .pp-related__link { color: var(--pp-amber-warm); }

/* ─── STICKY MOBILE CTA ───────────────────────────────── */
.pp-sticky { position: fixed; bottom: 12px; left: 12px; right: 12px; display: none; grid-template-columns: auto 1.4fr auto; gap: 0.5rem; padding: 0.5rem; background: rgba(255,255,255,0.85); backdrop-filter: blur(18px) saturate(150%); border: 1px solid rgba(0,57,149,.12); border-radius: 999px; box-shadow: 0 18px 40px -16px rgba(10,23,48,.25); z-index: 60; }
.pp-sticky__btn { display: flex; align-items: center; justify-content: center; font-size: 0.85rem; font-weight: 600; font-family: 'Poppins', sans-serif; padding: 0.7rem 1rem; border-radius: 999px; text-decoration: none; min-height: 44px; transition: transform 0.15s ease, box-shadow 0.2s ease; }
.pp-sticky__btn:active { transform: scale(0.96); }
.pp-sticky__btn--outline { background: transparent; color: var(--pp-blue); border: 1.5px solid rgba(0,57,149,.25); padding: 0.7rem 0.95rem; }
.pp-sticky__btn--wa { background: #25d366; color: #fff; box-shadow: 0 8px 18px -6px rgba(37,211,102,.5); }
.pp-sticky__btn--primary { background: var(--pp-amber); color: #fff; box-shadow: 0 8px 18px -6px rgba(245,176,66,.55); padding: 0.7rem 0.95rem; }

/* ─── PARALLAX ────────────────────────────────────────── */
.pp-parallax-wrap { position: relative; overflow: hidden; isolation: isolate; }
.pp-parallax-bg { position: absolute; inset: -20% -5% -20% -5%; z-index: -1; background: radial-gradient(60% 50% at 20% 20%, rgba(245,176,66,.10), transparent 60%), radial-gradient(50% 60% at 85% 80%, rgba(0,57,149,.08), transparent 60%), linear-gradient(180deg, #FAFBFE 0%, #FFF6E8 100%); pointer-events: none; }
.pp-parallax-bg--warm { background: radial-gradient(70% 60% at 80% 20%, rgba(245,176,66,.18), transparent 65%), radial-gradient(50% 50% at 10% 90%, rgba(232,154,43,.14), transparent 65%), linear-gradient(180deg, #FFF8EE 0%, #FFE9C2 100%); }
@media (prefers-reduced-motion: reduce) { .pp-parallax-bg { transform: none !important; } }

/* ─── FOCUS RINGS ─────────────────────────────────────── */
.pp-btn:focus-visible, .pp-nav__links a:focus-visible, .pp-related__card:focus-visible { outline: 2px solid var(--pp-amber); outline-offset: 3px; border-radius: 6px; }

/* ─── RESPONSIVE: TABLET ─────────────────────────────── */
@media (max-width: 860px) {
  .pp-hero__grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .pp-lead__grid { grid-template-columns: 1fr; gap: 2rem; }
}

/* ─── RESPONSIVE: MOBILE ─────────────────────────────── */
@media (max-width: 720px) {
  .pp-container { padding: 0 16px; }
  .pp-nav__inner { height: 56px; }
  .pp-nav__logo img { height: 30px; }
  .pp-nav__links { gap: 0.5rem; }
  .pp-nav__links a:not(.pp-btn) { display: none; }
  .pp-nav__links .pp-btn { padding: 0.5rem 0.9rem; font-size: 0.78rem; }
  .pp-section { padding: 56px 0; }
  .pp-hero { padding: 1rem 0 2.5rem; }
  .pp-hero__media { aspect-ratio: 4 / 3.4; border-radius: 1.1rem; }
  .pp-hero__media img { padding: 1rem; }
  .pp-section__head { margin-bottom: 2rem; }
  .pp-ctas { flex-direction: column; gap: 0.6rem; }
  .pp-ctas .pp-btn { width: 100%; }
  .pp-features { grid-template-columns: 1fr; gap: 1rem; }
  .pp-feature { padding: 1.4rem; }
  .pp-specs { grid-template-columns: 1fr; gap: 1rem; }
  .pp-spec-card { padding: 1.4rem; }
  .pp-techspecs__grid { grid-template-columns: 1fr; gap: 14px; margin-top: 1.5rem; }
  .pp-techspecs__group { padding: 22px 20px 18px; border-radius: 16px; }
  .pp-techspecs__title { font-size: 1.2rem; }
  .pp-techspecs__row { font-size: 0.88rem; padding: 0.55rem 0; }
  .pp-related { grid-template-columns: repeat(2, 1fr); gap: 0.9rem; }
  .pp-related__body { padding: 0.9rem; }
  .pp-related__body h4 { font-size: 0.95rem; }
  .pp-related__body p { font-size: 0.78rem; }
  .pp-shell { padding-bottom: 80px; }
  .pp-trust { gap: 0.75rem; font-size: 0.78rem; }
  .pp-btn--lg { padding: 0.85rem 1.3rem; font-size: 0.95rem; }
  .pp-sticky { display: grid; }
  .pp-hero__gallery { gap: 10px; }
  .pp-hero__gallery-row { gap: 10px; }
  .pp-hero__gallery-item--main { aspect-ratio: 4 / 3.4; }
  .pp-hero__media--gallery .pp-hero__gallery-item img { padding: 0.7rem; }
  .pp-hero__media--gallery .pp-hero__gallery-item--main img { padding: 1rem; }
}

@media (max-width: 480px) {
  .pp-related { grid-template-columns: 1fr; }
  .pp-hero__info h1 { font-size: clamp(1.7rem, 7vw, 2.2rem); }
  .pp-tagline { font-size: 1rem; }
  .pp-sticky__btn { font-size: 0.78rem; padding: 0.65rem 0.7rem; }
  .pp-sticky__btn--outline { padding: 0.65rem 0.7rem; }
  .pp-form__row { grid-template-columns: 1fr; }
  .pp-form { padding: 1.5rem; }
}

/* ─── SCROLL REVEAL (product pages) ──────────── */
.pp-reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1); }
.pp-reveal.pp-in { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) { .pp-reveal { opacity: 1 !important; transform: none !important; transition: none !important; } }
