/* ===========================================================
   Plate Disc — brand marketing site
   Palette sampled from the Petey mascot + license plate art
   =========================================================== */
:root{
  --red:#e11d22;
  --red-dark:#b3141a;
  --blue:#5cc6e0;
  --blue-dark:#1f9fbe;
  --ink:#17171c;
  --ink-soft:#3c3c46;
  --cream:#fff7f0;
  --paper:#ffffff;
  --yellow:#ffce32;
  --orange:#f5821f;
  --purple:#8e44ec;
  --pink:#ff4d9d;
  --line:rgba(23,23,28,.10);
  --shadow:0 18px 45px -20px rgba(23,23,28,.45);
  --shadow-sm:0 8px 22px -12px rgba(23,23,28,.4);
  --radius:26px;
  --radius-sm:16px;
  --maxw:1180px;
  --display:"Fredoka",system-ui,sans-serif;
  --body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--body);color:var(--ink);
  background:var(--cream);line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.05;margin:0 0 .4em;letter-spacing:-.01em}
h1{font-size:clamp(2.6rem,7vw,5rem)}
h2{font-size:clamp(2rem,4.5vw,3.2rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1rem}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--display);font-weight:600;text-transform:uppercase;
  letter-spacing:.18em;font-size:.82rem;color:var(--red);margin-bottom:.6rem;display:inline-block}
.eyebrow.alt{color:var(--blue-dark)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--display);
  font-weight:600;font-size:1.02rem;border:none;cursor:pointer;
  padding:.85rem 1.6rem;border-radius:999px;transition:transform .18s ease,box-shadow .18s ease,background .18s;}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--red);color:#fff;box-shadow:0 10px 0 -2px var(--red-dark),var(--shadow-sm)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 0 -2px var(--red-dark),var(--shadow)}
.btn--ghost{background:#fff;color:var(--ink);box-shadow:inset 0 0 0 2px var(--ink)}
.btn--ghost:hover{transform:translateY(-2px);background:var(--ink);color:#fff}
.btn--blue{background:var(--blue);color:var(--ink);box-shadow:0 10px 0 -2px var(--blue-dark),var(--shadow-sm)}
.btn--blue:hover{transform:translateY(-2px)}
.btn--lg{padding:1.05rem 2rem;font-size:1.12rem}

/* ---------- announcement ---------- */
.topbar{background:var(--ink);color:#fff;font-family:var(--display);
  font-size:.84rem;letter-spacing:.04em;text-align:center;padding:.5rem 16px}
.topbar b{color:var(--yellow)}

/* ---------- header ---------- */
.header{position:sticky;top:0;z-index:60;background:rgba(255,247,240,.82);
  backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border .2s,box-shadow .2s,background .2s}
.header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px -18px rgba(0,0,0,.5);background:rgba(255,247,240,.95)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 24px;max-width:1280px;margin:0 auto}
.nav__logo img{height:46px;width:auto}
.nav__links{display:flex;align-items:center;gap:1.6rem;list-style:none;margin:0;padding:0}
.nav__links a{font-family:var(--display);font-weight:500;font-size:1rem;color:var(--ink-soft);position:relative;padding:.2rem 0}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-2px;height:3px;width:0;background:var(--red);border-radius:3px;transition:width .22s}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{width:100%}
.nav__cta{display:flex;align-items:center;gap:.7rem}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.nav__toggle span{display:block;width:26px;height:3px;background:var(--ink);border-radius:3px;margin:5px 0;transition:.25s}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav.open .nav__toggle span:nth-child(2){opacity:0}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:clamp(2.5rem,6vw,5rem) 0 clamp(3rem,7vw,6rem)}
.hero__bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(60% 70% at 78% 18%,rgba(92,198,224,.4),transparent 60%),
    radial-gradient(50% 60% at 12% 80%,rgba(225,29,34,.12),transparent 60%);
}
.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center}
.hero__title .pop{color:var(--red)}
.hero__title .pop2{color:var(--blue-dark)}
.hero__lead{font-size:clamp(1.05rem,1.6vw,1.25rem);max-width:46ch;color:var(--ink-soft)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}
.hero__badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.7rem}
.chip{font-family:var(--display);font-size:.82rem;font-weight:500;background:#fff;
  border:1px solid var(--line);border-radius:999px;padding:.35rem .85rem;display:inline-flex;align-items:center;gap:.4rem;box-shadow:var(--shadow-sm)}
.chip svg{width:15px;height:15px}

.hero__art{position:relative;display:flex;justify-content:center;align-items:flex-end;min-height:340px}
.hero__plate{position:absolute;z-index:1;width:min(108%,560px);top:50%;left:50%;
  transform:translate(-50%,-46%) rotate(-4deg);
  filter:drop-shadow(0 30px 40px rgba(0,0,0,.28));border-radius:14px;border:6px solid #111}
.hero__petey{position:relative;z-index:3;width:min(74%,360px);
  filter:drop-shadow(0 22px 22px rgba(0,0,0,.22));
  transform-origin:bottom center;animation:bob 3.4s ease-in-out infinite}
.hero__petey .arm{display:none}
.hero__disc-spin{position:absolute;z-index:0;width:120px;height:120px;border-radius:50%;
  background:repeating-conic-gradient(var(--blue) 0 18deg,#bdeaf5 18deg 36deg);
  opacity:.5;top:-10px;right:6%;animation:spin 18s linear infinite}

@keyframes bob{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-16px) rotate(1deg)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* floating stickers */
.float{position:absolute;border-radius:50%;z-index:2;box-shadow:var(--shadow);animation:float 6s ease-in-out infinite}
.float--a{width:64px;height:64px;background:var(--yellow);top:8%;left:4%;animation-delay:.2s}
.float--b{width:42px;height:42px;background:var(--pink);bottom:14%;left:12%;animation-delay:1.1s}
.float--c{width:54px;height:54px;background:var(--orange);top:18%;right:8%;animation-delay:.6s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}

/* ---------- clip-on banner ---------- */
.clipon{margin-top:clamp(2.2rem,5vw,3.6rem);text-align:center}
.clipon img{width:100%;max-width:780px;height:auto;margin:0 auto;display:block;filter:drop-shadow(0 16px 24px rgba(0,0,0,.12))}
.clipon__cap{margin:1rem 0 0;color:var(--ink-soft);font-family:var(--display);font-size:1.02rem}

/* ---------- video embed ---------- */
.video-wrap{position:relative;width:100%;max-width:1100px;margin:0 auto;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:5px solid #fff;background:#000}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}

/* ---------- marquee ---------- */
.marquee{background:var(--ink);color:#fff;padding:.9rem 0;overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:2.5rem;align-items:center;animation:scroll 28s linear infinite;font-family:var(--display);
  font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase}
.marquee__track span{display:inline-flex;align-items:center;gap:2.5rem}
.marquee .dot{width:10px;height:10px;border-radius:50%;background:var(--red);display:inline-block}
@keyframes scroll{to{transform:translateX(-50%)}}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ---------- sections ---------- */
section{position:relative}
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section--cream{background:var(--cream)}
.section--paper{background:var(--paper)}
.section__head{max-width:62ch;margin:0 auto 2.6rem;text-align:center}
.section__head p{color:var(--ink-soft);font-size:1.08rem}

/* what-is split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split__media{position:relative}
.split__media picture{display:block}
.split__media img{display:block;width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow)}
.split__media .tag{position:absolute;font-family:var(--display);font-weight:600;background:var(--red);color:#fff;
  padding:.5rem 1rem;border-radius:999px;box-shadow:var(--shadow-sm);top:-14px;left:-10px;transform:rotate(-6deg)}
.lead-list{list-style:none;padding:0;margin:1.2rem 0 0;display:grid;gap:.7rem}
.lead-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:1.02rem}
.lead-list svg{flex:0 0 auto;width:24px;height:24px;color:var(--blue-dark);margin-top:2px}

/* feature cards */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;
  box-shadow:var(--shadow-sm);transition:transform .22s,box-shadow .22s}
.feature:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.feature__ic{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:1rem;color:#fff}
.feature__ic svg{width:28px;height:28px}
.feature:nth-child(6n+1) .feature__ic{background:var(--red)}
.feature:nth-child(6n+2) .feature__ic{background:var(--blue-dark)}
.feature:nth-child(6n+3) .feature__ic{background:var(--orange)}
.feature:nth-child(6n+4) .feature__ic{background:var(--purple)}
.feature:nth-child(6n+5) .feature__ic{background:var(--pink)}
.feature:nth-child(6n+6) .feature__ic{background:var(--yellow);color:var(--ink)}
.feature h3{margin-bottom:.3rem}
.feature p{margin:0;color:var(--ink-soft);font-size:.98rem}

/* run strip */
.runstrip{background:linear-gradient(180deg,var(--blue) 0%,#bfe9f3 100%);overflow:hidden;position:relative;padding:clamp(2.2rem,5vw,3.5rem) 0}
.runstrip__road{position:absolute;left:0;right:0;bottom:38px;height:4px;background:repeating-linear-gradient(90deg,var(--ink) 0 28px,transparent 28px 56px);opacity:.5}
.runstrip__inner{position:relative;text-align:center;color:var(--ink)}
.runstrip h2{margin-bottom:.2rem}
.runner{position:absolute;bottom:18px;right:-180px;width:150px;z-index:2;will-change:transform;animation:run-across 9s linear infinite}
.runner img{filter:drop-shadow(0 12px 10px rgba(0,0,0,.18))}
@keyframes run-across{0%{transform:translateX(0)}100%{transform:translateX(calc(-100vw - 360px))}}
@media (prefers-reduced-motion:reduce){.runner{animation:none;right:auto;left:6%}}

/* collections */
.collections{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.col-card{position:relative;border-radius:var(--radius-sm);padding:1.4rem 1.2rem;min-height:128px;
  display:flex;flex-direction:column;justify-content:space-between;color:#fff;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;font-family:var(--display)}
.col-card:hover{transform:translateY(-5px) rotate(-1deg);box-shadow:var(--shadow)}
.col-card h3{margin:0;font-size:1.25rem}
.col-card .arrow{align-self:flex-end;font-size:1.4rem;opacity:.85;transition:transform .2s}
.col-card:hover .arrow{transform:translateX(4px)}
.col-card::after{content:"";position:absolute;width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.18);right:-26px;bottom:-26px}
.c-safety{background:linear-gradient(135deg,#e11d22,#ff5a3c)}
.c-custom{background:linear-gradient(135deg,#1f9fbe,#5cc6e0)}
.c-emoji{background:linear-gradient(135deg,#ffb300,#ffce32);color:var(--ink)}
.c-political{background:linear-gradient(135deg,#3a4a8c,#5a6fd0)}
.c-patriotic{background:linear-gradient(135deg,#0b2d6b,#c8102e)}
.c-sports{background:linear-gradient(135deg,#f5821f,#ffae4d)}
.c-chicago{background:linear-gradient(135deg,#0b2d6b,#c8102e)}
.c-flags{background:linear-gradient(135deg,#b3141a,#e11d22)}
.c-funny{background:linear-gradient(135deg,#8e44ec,#b06bff)}
.c-fishing{background:linear-gradient(135deg,#0c7d8c,#2bb5c4)}
.c-symbols{background:linear-gradient(135deg,#2b2b34,#55555f)}

/* customize */
.customize{background:linear-gradient(135deg,#fff,#fff2e8);border-radius:var(--radius);
  padding:clamp(1.6rem,4vw,3rem);box-shadow:var(--shadow-sm);border:1px solid var(--line)}

/* family */
.family{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.fam-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1rem 1.6rem;text-align:center;
  box-shadow:var(--shadow-sm);transition:transform .25s}
.fam-card img{height:200px;width:auto;margin:0 auto .6rem;object-fit:contain;transition:transform .3s}
.fam-card:hover{transform:translateY(-6px)}
.fam-card:hover img{transform:scale(1.06) rotate(-2deg)}
.fam-card h3{margin:.2rem 0 .1rem}
.fam-card p{margin:0;color:var(--ink-soft);font-size:.92rem}
.fam-petey{border-color:rgba(225,29,34,.35)}
.fam-patty{border-color:rgba(142,68,236,.35)}
.fam-pauly{border-color:rgba(245,130,31,.35)}
.fam-peggy{border-color:rgba(255,77,157,.35)}

/* about */
.about{background:var(--ink);color:#fff;border-radius:var(--radius);padding:clamp(2rem,5vw,3.5rem);position:relative;overflow:hidden}
.about::before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,var(--red),transparent 70%);right:-60px;top:-60px;opacity:.5}
.about__grid{position:relative;display:grid;grid-template-columns:1.4fr 1fr;gap:2rem;align-items:center}
.about h2{color:#fff}
.about p{color:rgba(255,255,255,.82)}
.about__stats{display:grid;gap:1rem}
.stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);padding:1.1rem 1.3rem}
.stat b{font-family:var(--display);font-size:1.9rem;display:block;color:var(--yellow)}
.stat span{color:rgba(255,255,255,.7);font-size:.9rem}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.form{display:grid;gap:.9rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm)}
.form label{font-family:var(--display);font-weight:500;font-size:.92rem;display:block;margin-bottom:.3rem}
.form input,.form select,.form textarea{width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:12px;
  font-family:var(--body);font-size:1rem;background:var(--cream);transition:border .18s,box-shadow .18s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--blue-dark);box-shadow:0 0 0 4px rgba(92,198,224,.25)}
.form textarea{min-height:120px;resize:vertical}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.form__status{font-size:.92rem;min-height:1.2em;font-family:var(--display)}
.form__status.ok{color:var(--blue-dark)}
.form__status.err{color:var(--red)}
.contact-aside .card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm);margin-bottom:1rem}
.contact-aside .card h3{margin-bottom:.4rem}
.socials{display:flex;gap:.6rem;flex-wrap:wrap}
.socials a{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:var(--ink);color:#fff;transition:transform .18s,background .18s}
.socials a:hover{transform:translateY(-3px);background:var(--red)}
.socials svg{width:20px;height:20px}

/* footer */
.footer{background:var(--ink);color:rgba(255,255,255,.72);padding:3rem 0 1.6rem}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
.footer img.flogo{height:58px;width:auto;display:inline-block;margin-bottom:1rem;background:#fff;padding:10px 16px;border-radius:14px;box-shadow:0 8px 22px -12px rgba(0,0,0,.6)}
.footer h4{font-family:var(--display);color:#fff;font-size:1rem;margin:0 0 .8rem}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.footer a:hover{color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.3rem;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.85rem}
.footer__bottom .usa{color:var(--yellow)}

/* Exioite credit ribbon — sits below the footer-bottom row */
.exioite-credit{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);text-align:center;font-size:.78rem;letter-spacing:.04em;color:rgba(255,255,255,.55)}
.exioite-credit__link{display:inline-flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;text-decoration:none;color:inherit;opacity:.82;transition:opacity .18s ease}
.exioite-credit__link:hover{opacity:1}
.exioite-credit__caption{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.exioite-credit__logo{display:block;height:34px;width:auto}
.exioite-credit__sep{color:rgba(255,255,255,.3)}
.exioite-credit__url{font-size:.82rem;color:rgba(255,255,255,.65);letter-spacing:.02em}
@media (max-width:480px){.exioite-credit__logo{height:28px}}

/* reveal animation */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .hero__petey,.float,.hero__disc-spin,.marquee__track{animation:none}
}

/* ---------- responsive ---------- */
@media (max-width:960px){
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__lead{margin-inline:auto}
  .hero__cta,.hero__badges{justify-content:center}
  .hero__art{order:-1;min-height:300px;margin-bottom:1rem}
  .split{grid-template-columns:1fr}
  .features{grid-template-columns:repeat(2,1fr)}
  .collections{grid-template-columns:repeat(2,1fr)}
  .family{grid-template-columns:repeat(2,1fr)}
  .about__grid,.contact-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .nav__links,.nav__cta .btn--ghost{display:none}
  .nav__toggle{display:block}
  .nav.open .nav__links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:var(--cream);padding:1rem 24px 1.4rem;gap:1rem;box-shadow:var(--shadow);border-bottom:1px solid var(--line)}
  .nav{position:relative}
  .features{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
}

/* =========================================================
   STORE
   ========================================================= */
.nav__cart{position:relative;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 2px var(--ink);transition:transform .18s,background .18s,color .18s;color:var(--ink)}
.nav__cart:hover{transform:translateY(-2px);background:var(--ink);color:#fff}
.nav__cart svg{width:20px;height:20px}
.nav__cart .count{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:var(--red);color:#fff;font-family:var(--display);font-size:.72rem;font-weight:600;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.nav__cart .count[data-c="0"]{display:none}

.shop-hero{background:var(--cream);padding:clamp(2rem,5vw,3.2rem) 0 1.4rem;text-align:center}
.shop-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);margin-bottom:.3rem}
.shop-hero p{color:var(--ink-soft);max-width:54ch;margin:0 auto}

.shop-filters{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;padding:1.4rem 0 0}
.filter-chip{font-family:var(--display);font-weight:500;font-size:.92rem;border:1.5px solid var(--line);background:#fff;color:var(--ink-soft);border-radius:999px;padding:.5rem 1.05rem;cursor:pointer;transition:.16s;text-decoration:none}
.filter-chip:hover{border-color:var(--ink);color:var(--ink)}
.filter-chip.active{background:var(--red);border-color:var(--red);color:#fff}

.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.3rem;padding:2rem 0 1rem}
.pcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.pcard__img{aspect-ratio:4/3;background:#f4f4f6;overflow:hidden}
.pcard__img img{width:100%;height:100%;object-fit:contain;transition:transform .3s}
.pcard:hover .pcard__img img{transform:scale(1.05)}
.pcard__body{padding:.9rem 1rem 1.1rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.pcard__cat{font-family:var(--display);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-dark)}
.pcard__title{font-family:var(--display);font-weight:600;font-size:1.02rem;line-height:1.15;flex:1}
.pcard__row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.3rem}
.pcard__price{font-family:var(--display);font-weight:600;font-size:1.15rem;color:var(--ink)}
.pcard__add{border:none;cursor:pointer;background:var(--red);color:#fff;font-family:var(--display);font-weight:600;font-size:.9rem;padding:.5rem .9rem;border-radius:999px;transition:.16s;box-shadow:0 6px 0 -2px var(--red-dark)}
.pcard__add:hover{transform:translateY(-1px)}
.pcard__add:active{transform:translateY(1px);box-shadow:none}
.pcard__add.added{background:var(--blue-dark);box-shadow:0 6px 0 -2px #157d96}
.shop-empty{text-align:center;padding:3rem 0;color:var(--ink-soft)}

.pdp{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3rem);padding:clamp(1.5rem,4vw,2.5rem) 0;align-items:start}
.pdp__gallery{position:sticky;top:90px}
.pdp__main{aspect-ratio:1/1;background:#f4f4f6;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.pdp__main img{width:100%;height:100%;object-fit:contain}
.pdp__thumbs{display:flex;gap:.6rem;margin-top:.8rem;flex-wrap:wrap}
.pdp__thumb{width:74px;height:74px;border-radius:12px;overflow:hidden;border:2px solid var(--line);background:#f4f4f6;cursor:pointer;padding:0}
.pdp__thumb.active{border-color:var(--red)}
.pdp__thumb img{width:100%;height:100%;object-fit:contain}
.pdp__cat{color:var(--blue-dark)}
.pdp__price{font-family:var(--display);font-weight:600;font-size:2rem;margin:.3rem 0 1rem}
.pdp__desc{color:var(--ink-soft);margin:1rem 0 1.4rem;line-height:1.7}
.pdp__desc p{margin:0 0 .7rem}
.pdp__buy{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden}
.qty button{width:42px;height:46px;border:none;background:#fff;font-size:1.3rem;cursor:pointer;color:var(--ink);transition:background .15s}
.qty button:hover{background:var(--cream)}
.qty input{width:46px;height:46px;border:none;text-align:center;font-family:var(--display);font-size:1.05rem;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.pdp__note{font-size:.9rem;color:var(--ink-soft);margin-top:1rem;display:flex;align-items:center;gap:.5rem}
.pdp__note svg{width:18px;height:18px;color:var(--blue-dark);flex:0 0 auto}

.custom-box{margin:1.2rem 0;padding:1.2rem;border:1.5px dashed var(--blue-dark);border-radius:var(--radius-sm);background:rgba(92,198,224,.08)}
.custom-box h3{margin:0 0 .4rem}
.custom-box label{font-family:var(--display);font-weight:500;font-size:.9rem;display:block;margin:.6rem 0 .25rem}
.custom-box input[type=text],.custom-box textarea{width:100%;padding:.7rem .8rem;border:1.5px solid var(--line);border-radius:10px;font-family:var(--body);font-size:.95rem}
.custom-box input[type=file]{font-size:.9rem}
.custom-box .filehint{font-size:.82rem;color:var(--ink-soft);margin-top:.3rem}

.cart-wrap{padding:clamp(1.5rem,4vw,2.5rem) 0;min-height:50vh}
.cart-grid{display:grid;grid-template-columns:1.6fr .9fr;gap:2rem;align-items:start}
.cart-items{display:flex;flex-direction:column;gap:1rem}
.citem{display:grid;grid-template-columns:88px 1fr auto;gap:1rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:.9rem;box-shadow:var(--shadow-sm)}
.citem__img{width:88px;height:88px;border-radius:12px;background:#f4f4f6;overflow:hidden}
.citem__img img{width:100%;height:100%;object-fit:contain}
.citem__t{font-family:var(--display);font-weight:600}
.citem__meta{font-size:.82rem;color:var(--ink-soft)}
.citem__rm{background:none;border:none;color:var(--red);cursor:pointer;font-size:.82rem;font-family:var(--display);padding:0;margin-top:.3rem}
.citem__right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.citem__price{font-family:var(--display);font-weight:600;font-size:1.05rem}
.cart-summary{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm);position:sticky;top:90px}
.cart-summary h2{font-size:1.4rem}
.sumrow{display:flex;justify-content:space-between;padding:.5rem 0;color:var(--ink-soft)}
.sumrow.total{border-top:1px solid var(--line);margin-top:.5rem;padding-top:.9rem;color:var(--ink);font-family:var(--display);font-weight:600;font-size:1.25rem}
.cart-summary .btn{width:100%;justify-content:center;margin-top:1rem}
.ship-note{font-size:.85rem;color:var(--blue-dark);margin-top:.6rem;text-align:center}
.cart-empty{text-align:center;padding:3rem 0}
.cart-empty img{width:180px;margin:0 auto 1rem;opacity:.9}
.checkout-status{font-size:.9rem;margin-top:.6rem;text-align:center;min-height:1.2em;font-family:var(--display)}
.checkout-status.err{color:var(--red)}

@media (max-width:1000px){.pgrid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:820px){
  .pdp{grid-template-columns:1fr}.pdp__gallery{position:static}
  .cart-grid{grid-template-columns:1fr}.cart-summary{position:static}
}
@media (max-width:680px){.pgrid{grid-template-columns:repeat(2,1fr)}.citem{grid-template-columns:64px 1fr}.citem__right{grid-column:2;align-items:flex-start;text-align:left}.citem__img{width:64px;height:64px}}

/* live customizer */
.customizer{margin:1.2rem 0 .4rem;padding:1.2rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:linear-gradient(135deg,#fff,#fff5ef)}
.cz-wrap{position:relative;width:100%;max-width:420px;margin:0 auto;border-radius:18px;background:repeating-conic-gradient(#f3f3f6 0 25%,#eaeaef 0 50%) 0 0/24px 24px;outline:2px dashed transparent;transition:outline-color .15s}
.cz-wrap.dragging{outline-color:var(--blue-dark)}
.cz-wrap canvas{width:100%!important;height:auto!important;display:block;border-radius:18px;touch-action:none}
.cz-tools{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin:.9rem 0 .2rem}
.cz-upload{cursor:pointer}
.cz-tool{font-family:var(--display);font-weight:500;font-size:.92rem;min-width:42px;height:42px;padding:0 .9rem;border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:999px;cursor:pointer;transition:.15s}
.cz-tool:hover{border-color:var(--ink);background:var(--cream)}
.cz-hint{font-size:.84rem;color:var(--ink-soft);text-align:center;margin:.5rem 0 0}

/* Petey characters anchored into the sections */
.pd-peek{position:absolute;pointer-events:none;z-index:3;height:auto;animation:bob 4.6s ease-in-out infinite}
.split__media img.pd-peek--what{left:-26px;bottom:-34px;width:130px;filter:drop-shadow(0 14px 16px rgba(0,0,0,.2));animation-delay:.2s}
.customize{position:relative}
.pd-peek--customize{right:-8px;bottom:-30px;width:124px;filter:drop-shadow(0 14px 16px rgba(0,0,0,.2));animation-delay:.7s}
.pd-peek--about{right:20px;bottom:0;width:120px;filter:drop-shadow(0 12px 12px rgba(0,0,0,.4));animation:none}
.contact-greeter{display:block;width:min(72%,200px);height:auto;margin:0 auto 1.1rem;filter:drop-shadow(0 14px 16px rgba(0,0,0,.16));animation:bob 4.6s .3s ease-in-out infinite}
@media (max-width:900px){
  .split__media img.pd-peek--what{width:96px;left:-12px;bottom:-22px}
  .pd-peek--customize{width:98px;right:0;bottom:-20px}
  .pd-peek--about{width:100px;right:10px}
}
@media (max-width:600px){.pd-peek--what,.pd-peek--customize{display:none}}
@media (prefers-reduced-motion:reduce){.pd-peek,.contact-greeter{animation:none}}
