:root {
  --ink: #171721;
  --blue: #2117c8;
  --blue-dark: #160e96;
  --red: #f52b4d;
  --cream: #fff9e8;
  --lime: #c8ff63;
  --lilac: #e9e4ff;
  --line: rgba(23, 23, 33, .14);
  --white: #fff;
  --shadow: 0 24px 70px rgba(31, 22, 111, .16);
  --radius: 28px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: "DM Sans", sans-serif; overflow-x: hidden; }
body.locked { overflow: hidden; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { color: inherit; }
section { scroll-margin-top: 94px; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; z-index: 5000; left: 18px; top: -80px; padding: 12px 18px; background: var(--white); border-radius: 12px; font-weight: 700; transition: top .2s; }
.skip-link:focus { top: 18px; }

.announcement { height: 34px; overflow: hidden; display: flex; align-items: center; background: var(--ink); color: white; font: 700 10px/1 "Figtree", sans-serif; letter-spacing: .15em; }
.announcement__track { display: flex; align-items: center; width: max-content; animation: marquee 30s linear infinite; }
.announcement__track span { white-space: nowrap; padding: 0 40px; }
.announcement__track span:nth-child(3n + 1) { color: var(--lime); }

.site-header { position: sticky; top: 0; z-index: 1000; height: 78px; padding: 0 clamp(20px, 4vw, 68px); display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; background: rgba(255, 249, 232, .88); border-bottom: 1px solid transparent; backdrop-filter: blur(18px); transition: height .25s, border .25s, box-shadow .25s; }
.site-header.scrolled { height: 68px; border-color: var(--line); box-shadow: 0 10px 35px rgba(25, 22, 50, .06); }
.brand { width: 138px; display: block; }
.brand img { width: 100%; }
.desktop-nav { display: flex; align-items: center; gap: 35px; font: 700 13px/1 "Figtree", sans-serif; }
.desktop-nav a { position: relative; padding: 12px 0; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 5px; height: 2px; background: var(--red); transition: right .2s; }
.desktop-nav a:hover::after { right: 0; }
.header-actions { justify-self: end; display: flex; align-items: center; gap: 10px; }
.icon-button, .menu-button { width: 42px; height: 42px; border: 1px solid var(--line); background: rgba(255,255,255,.55); border-radius: 50%; display: grid; place-items: center; cursor: pointer; transition: transform .2s, background .2s; }
.icon-button:hover, .menu-button:hover { transform: rotate(-5deg); background: white; }
.icon-button svg { width: 19px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.cart-button { height: 43px; padding: 0 8px 0 19px; border: 0; border-radius: 99px; display: flex; gap: 13px; align-items: center; background: var(--blue); color: white; font-weight: 700; cursor: pointer; transition: transform .2s, background .2s; }
.cart-button:hover { transform: translateY(-2px); background: var(--blue-dark); }
.cart-count { width: 29px; height: 29px; border-radius: 50%; display: grid; place-items: center; background: var(--lime); color: var(--ink); font-size: 12px; }
.menu-button { display: none; position: relative; }
.menu-button span { position: absolute; width: 17px; height: 2px; background: currentColor; transition: transform .25s, top .25s; top: 17px; }
.menu-button span:last-child { top: 23px; }
.menu-button.active span:first-child { top: 20px; transform: rotate(45deg); }
.menu-button.active span:last-child { top: 20px; transform: rotate(-45deg); }
.mobile-menu { display: none; }

.hero { min-height: calc(100vh - 112px); position: relative; padding: clamp(65px, 8vw, 120px) clamp(22px, 6vw, 96px) 102px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(420px, .9fr); align-items: center; gap: 6vw; overflow: hidden; background: radial-gradient(circle at 64% 25%, #fff 0, transparent 26%), linear-gradient(135deg, #fff9e8 0%, #f6f0ff 58%, #e8e1ff 100%); }
#sprinkles-canvas { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 1; }
.hero__glow { position: absolute; border-radius: 50%; filter: blur(3px); opacity: .6; }
.hero__glow--one { width: 360px; height: 360px; left: -240px; top: 6%; background: #ffd7dd; }
.hero__glow--two { width: 240px; height: 240px; right: -100px; bottom: 8%; background: var(--lime); opacity: .35; }
.hero__copy, .hero__art { position: relative; z-index: 3; }
.eyebrow, .kicker { margin: 0 0 20px; text-transform: uppercase; letter-spacing: .16em; font: 700 11px/1.2 "Figtree", sans-serif; }
.eyebrow { display: flex; gap: 10px; align-items: center; }
.eyebrow span { width: 8px; height: 8px; border-radius: 50%; background: var(--red); box-shadow: 0 0 0 5px rgba(245,43,77,.12); }
.hero h1 { max-width: 760px; margin: 0; font: 400 clamp(57px, 6.4vw, 108px)/.89 "Paytone One", sans-serif; letter-spacing: -.055em; text-wrap: balance; }
.hero h1 em { position: relative; color: var(--blue); font-style: normal; display: inline-block; }
.hero h1 em::after { content: ""; position: absolute; z-index: -1; left: 2%; right: -3%; bottom: -8px; height: 22px; background: var(--red); border-radius: 50%; clip-path: polygon(0 39%, 99% 7%, 100% 43%, 1% 92%); }
.hero__lead { max-width: 570px; margin: 34px 0 30px; color: #4d4b59; font-size: clamp(16px, 1.4vw, 20px); line-height: 1.6; }
.hero__lead strong { color: var(--ink); }
.hero__actions { display: flex; align-items: center; gap: 27px; }
.button { min-height: 51px; padding: 0 22px; border: 0; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; gap: 18px; font: 700 14px/1 "Figtree", sans-serif; cursor: pointer; transition: transform .2s, box-shadow .2s, background .2s; }
.button span { transition: transform .2s; }
.button:hover { transform: translateY(-3px); }
.button:hover span { transform: translate(2px, -2px); }
.button--primary { background: var(--blue); color: white; box-shadow: 0 12px 25px rgba(33,23,200,.22); }
.button--primary:hover { background: var(--blue-dark); box-shadow: 0 16px 32px rgba(33,23,200,.3); }
.button--cream { background: var(--cream); color: var(--ink); }
.button--full { width: 100%; }
.text-link { display: inline-flex; align-items: center; gap: 9px; padding: 8px 0; border-bottom: 1px solid currentColor; font-weight: 700; font-size: 14px; }
.text-link span { transition: transform .2s; }
.text-link:hover span { transform: translateX(4px); }
.text-link--bold { margin-top: 25px; color: var(--blue); }
.hero__proof { margin-top: 35px; display: flex; align-items: center; gap: 14px; }
.hero__proof p { margin: 0; color: #67636f; font-size: 11px; line-height: 1.5; }
.hero__proof strong { color: var(--ink); }
.avatar-stack { display: flex; }
.avatar-stack span { width: 31px; height: 31px; margin-left: -7px; border: 2px solid var(--cream); border-radius: 50%; display: grid; place-items: center; color: white; background: var(--red); font-size: 12px; }
.avatar-stack span:first-child { margin: 0; background: var(--blue); }.avatar-stack span:last-child { background: #14a86a; }

.hero__art { min-height: 570px; display: grid; place-items: center; perspective: 900px; }
.hero__art::before { content: ""; position: absolute; width: min(36vw, 515px); aspect-ratio: 1; border-radius: 50%; background: var(--blue); box-shadow: inset 0 0 0 18px rgba(255,255,255,.07), 0 35px 70px rgba(40,25,140,.26); }
.hero__art::after { content: ""; position: absolute; width: min(30vw, 430px); height: 50px; bottom: 7%; border-radius: 50%; background: rgba(23,23,33,.2); filter: blur(18px); }
.product-fan { position: absolute; z-index: 3; width: min(18vw, 250px); aspect-ratio: .77; overflow: hidden; border: 9px solid white; border-radius: 21px; background: white; box-shadow: 0 20px 45px rgba(15,10,57,.28); transition: transform .5s cubic-bezier(.2,.8,.2,1); }
.product-fan img { width: 100%; height: 100%; object-fit: cover; }
.product-fan--center { transform: translateY(-5px) rotate(1.5deg); z-index: 5; }
.product-fan--left { transform: translate(-43%, 28px) rotate(-16deg); }
.product-fan--right { transform: translate(44%, 28px) rotate(15deg); }
.hero__art:hover .product-fan--center { transform: translateY(-18px) rotate(-1deg); }
.hero__art:hover .product-fan--left { transform: translate(-52%, 17px) rotate(-21deg); }
.hero__art:hover .product-fan--right { transform: translate(53%, 17px) rotate(20deg); }
.orbit { position: absolute; z-index: 1; border: 1px solid rgba(255,255,255,.35); border-radius: 50%; }
.orbit--one { width: min(42vw, 590px); aspect-ratio: 1; }.orbit--two { width: min(47vw, 670px); aspect-ratio: 1; }
.sticker-note { position: absolute; z-index: 7; display: grid; place-items: center; text-align: center; background: var(--lime); border: 4px solid var(--ink); color: var(--ink); font: 700 14px/1.05 "Figtree", sans-serif; box-shadow: 7px 7px 0 var(--ink); }
.sticker-note--top { width: 108px; height: 108px; padding: 10px; border-radius: 46% 54% 61% 39% / 39% 35% 65% 61%; right: 3%; top: 12%; font-size: 11px; line-height: 1.1; transform: rotate(11deg); animation: bob 4s ease-in-out infinite; }
.sticker-note--bottom { width: 124px; height: 78px; left: 2%; bottom: 16%; border-radius: 50%; background: #ffacc1; transform: rotate(-9deg); }
.spark { position: absolute; z-index: 6; color: white; font-size: 42px; animation: spin 9s linear infinite; }.spark--one { top: 6%; left: 13%; }.spark--two { bottom: 9%; right: 13%; font-size: 31px; animation-direction: reverse; }
.hero__ticker { position: absolute; z-index: 10; left: -2%; right: -2%; bottom: 0; height: 46px; display: flex; align-items: center; overflow: hidden; background: var(--red); color: white; transform: rotate(-1deg); border-block: 2px solid var(--ink); }
.hero__ticker div { width: max-content; display: flex; align-items: center; animation: marquee 23s linear infinite; }
.hero__ticker span { padding: 0 28px; white-space: nowrap; font: 700 12px/1 "Figtree", sans-serif; letter-spacing: .12em; }
.hero__ticker i { font-style: normal; color: var(--lime); }

.shop-search { padding: 66px clamp(22px, 7vw, 120px) 45px; background: var(--cream); }
.search-shell { max-width: 970px; height: 72px; margin: 0 auto; padding: 0 18px 0 23px; display: flex; align-items: center; border: 2px solid var(--ink); border-radius: 99px; background: white; box-shadow: 8px 8px 0 var(--ink); transition: box-shadow .2s, transform .2s; }
.search-shell:focus-within { box-shadow: 11px 11px 0 var(--blue); transform: translate(-2px,-2px); }
.search-icon svg { width: 24px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.search-shell input { flex: 1; width: 100%; border: 0; outline: 0; padding: 0 18px; background: transparent; color: var(--ink); font-size: clamp(15px, 1.5vw, 19px); }
.search-shell input::placeholder { color: #96919c; }
#clear-search { border: 0; background: #efedf5; border-radius: 99px; padding: 9px 14px; cursor: pointer; font-size: 12px; font-weight: 700; opacity: 0; pointer-events: none; transition: opacity .2s; }
#clear-search.visible { opacity: 1; pointer-events: auto; }
.quick-tags { max-width: 970px; margin: 22px auto 0; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 8px; color: #65616c; font-size: 12px; }
.quick-tags span { font-weight: 700; margin-right: 5px; }.quick-tags button { padding: 8px 13px; border: 1px solid var(--line); border-radius: 99px; background: transparent; cursor: pointer; transition: background .2s, border .2s; }.quick-tags button:hover { background: var(--lilac); border-color: var(--blue); }

.section-pad { padding: clamp(75px, 9vw, 135px) clamp(22px, 6vw, 96px); }
.collection, .shop { background: var(--cream); }
.section-heading { max-width: 1380px; margin: 0 auto 48px; display: flex; align-items: end; justify-content: space-between; gap: 40px; }
.section-heading .kicker, .about .kicker, .contact .kicker { color: var(--red); }
.section-heading h2, .about h2, .contact h2 { margin: 0; font: 400 clamp(42px, 5vw, 72px)/.96 "Paytone One", sans-serif; letter-spacing: -.04em; }
.section-heading > p { max-width: 410px; margin: 0 0 4px; color: #6b6670; font-size: 15px; line-height: 1.6; }
.section-heading--light { color: white; position: relative; z-index: 2; }.section-heading--light .kicker { color: var(--lime); }
.product-grid { max-width: 1380px; margin: 0 auto; display: grid; gap: 22px; }
.product-grid--featured { grid-template-columns: repeat(3, 1fr); }
.product-card { position: relative; min-width: 0; cursor: pointer; }
.product-card__media { position: relative; aspect-ratio: .92; padding: clamp(20px, 3vw, 45px); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; display: grid; place-items: center; background: #f0edff; transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s; }
.product-card:nth-child(3n+2) .product-card__media { background: #ffe9a9; }.product-card:nth-child(3n+3) .product-card__media { background: #dff6e6; }
.product-card__media::before { content: ""; position: absolute; width: 75%; height: 75%; border-radius: 50%; background: rgba(255,255,255,.55); filter: blur(2px); transition: transform .35s; }
.product-card__media img { position: relative; z-index: 2; width: 70%; height: 88%; object-fit: cover; border: 6px solid white; border-radius: 13px; box-shadow: 0 18px 35px rgba(24,20,69,.18); transform: rotate(-3deg); transition: transform .4s cubic-bezier(.2,.8,.2,1); }
.product-card:hover .product-card__media { transform: translateY(-6px); box-shadow: var(--shadow); }.product-card:hover .product-card__media::before { transform: scale(1.08); }.product-card:hover .product-card__media img { transform: rotate(2deg) scale(1.04); }
.product-badge { position: absolute; z-index: 5; top: 15px; left: 15px; padding: 8px 12px; border-radius: 99px; background: white; border: 1px solid rgba(23,23,33,.11); font: 700 10px/1 "Figtree", sans-serif; letter-spacing: .08em; text-transform: uppercase; }
.quick-add { position: absolute; z-index: 6; right: 15px; bottom: 15px; width: 49px; height: 49px; border: 0; border-radius: 50%; background: var(--ink); color: white; cursor: pointer; font-size: 24px; opacity: 0; transform: translateY(8px) rotate(-10deg); transition: opacity .25s, transform .25s, background .2s; }
.product-card:hover .quick-add, .quick-add:focus { opacity: 1; transform: none; }.quick-add:hover { background: var(--blue); }
.product-card__info { padding: 18px 5px 0; display: grid; grid-template-columns: 1fr auto; gap: 8px; }
.product-card__info h3 { margin: 0; font: 700 clamp(15px, 1.3vw, 18px)/1.25 "Figtree", sans-serif; }.product-card__info p { margin: 0; font-weight: 700; color: var(--blue); }.product-card__meta { grid-column: 1 / -1; color: #77727d !important; font-size: 12px !important; font-weight: 500 !important; }

.trend-band { position: relative; overflow: hidden; background: var(--blue); }
.trend-band::before { content: ""; position: absolute; width: 450px; height: 450px; right: -180px; top: -180px; border: 80px solid rgba(255,255,255,.05); border-radius: 50%; }
.trend-band__shape { position: absolute; left: -170px; bottom: -300px; width: 600px; height: 600px; border-radius: 50%; background: var(--red); opacity: .18; }
.live-pill { flex: 0 0 auto; display: flex; align-items: center; gap: 8px; padding: 9px 13px; border: 1px solid rgba(255,255,255,.26); border-radius: 99px; font-size: 11px; font-weight: 700; }.live-pill span { width: 7px; height: 7px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 0 5px rgba(200,255,99,.12); animation: pulse 1.7s infinite; }
.trend-layout { position: relative; z-index: 2; max-width: 1380px; margin: 0 auto; display: grid; grid-template-columns: .72fr 1.5fr; gap: clamp(30px, 5vw, 85px); align-items: center; }
.trend-editorial { color: white; }.trend-number { color: var(--lime); font: 700 11px/1 "Figtree", sans-serif; letter-spacing: .15em; }.trend-editorial h3 { margin: 23px 0; font: 400 clamp(40px, 4.6vw, 67px)/.96 "Paytone One", sans-serif; letter-spacing: -.04em; }.trend-editorial > p:not(.trend-number) { max-width: 320px; margin: 0 0 30px; color: rgba(255,255,255,.7); line-height: 1.6; }
.product-grid--trending { grid-template-columns: repeat(2, 1fr); width: 100%; }.product-grid--trending .product-card__media { background: var(--cream); }.product-grid--trending .product-card:nth-child(2) .product-card__media { background: #ffb4c4; }.product-grid--trending .product-card__info h3 { color: white; }.product-grid--trending .product-card__info p { color: var(--lime); }.product-grid--trending .product-card__meta { color: rgba(255,255,255,.58) !important; }

.shop-controls { display: flex; gap: 9px; }.shop-controls select { min-height: 43px; padding: 0 38px 0 14px; border: 1px solid var(--line); border-radius: 99px; background: white; color: var(--ink); cursor: pointer; font-size: 12px; font-weight: 600; }.result-count { max-width: 1380px; margin: -28px auto 24px; color: #77717c; font-size: 12px; }.product-grid--shop { grid-template-columns: repeat(3, 1fr); }.product-grid--shop .product-card__media { aspect-ratio: 1.05; }.empty-state { max-width: 600px; margin: 30px auto; text-align: center; padding: 60px 20px; }.empty-state > span { font-size: 42px; }.empty-state h3 { margin: 20px 0 8px; font: 400 28px/1 "Paytone One", sans-serif; }.empty-state p { color: #716c77; }.empty-state .button { margin-top: 15px; }

.about { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, .88fr); gap: clamp(55px, 8vw, 135px); align-items: center; background: #f0ecff; }
.about__visual { position: relative; max-width: 620px; justify-self: end; }.about__frame { padding: 16px; background: white; border: 2px solid var(--ink); border-radius: 35px; box-shadow: 13px 13px 0 var(--blue); transform: rotate(-2.5deg); }.about__frame img { width: 100%; border-radius: 22px; }.about__seal { position: absolute; right: -47px; top: -52px; width: 145px; height: 145px; padding: 20px; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--lime); border: 2px solid var(--ink); box-shadow: 7px 7px 0 var(--ink); transform: rotate(9deg); font: 700 10px/1.25 "Figtree", sans-serif; letter-spacing: .08em; text-align: center; }.about__seal strong { color: var(--red); font-size: 30px; line-height: 1; }.about__scribble { position: absolute; left: -42px; bottom: -64px; color: var(--blue); font: 700 19px/1.2 "Figtree", sans-serif; transform: rotate(-8deg); }.about__copy { max-width: 630px; }.about__copy h2 em { color: var(--blue); font-style: normal; }.about__copy > p:not(.kicker) { color: #5f5a67; font-size: 16px; line-height: 1.75; }.about__stats { margin: 35px 0 5px; padding: 25px 0; border-block: 1px solid rgba(23,23,33,.15); display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }.about__stats div { display: flex; flex-direction: column; }.about__stats strong { font: 400 27px/1 "Paytone One", sans-serif; color: var(--blue); }.about__stats span { margin-top: 7px; color: #6f6975; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }

.promise-strip { display: grid; grid-template-columns: repeat(3, 1fr); background: var(--ink); color: white; }.promise-strip article { min-height: 165px; padding: 38px clamp(25px,4vw,68px); display: flex; gap: 20px; align-items: flex-start; border-right: 1px solid rgba(255,255,255,.15); }.promise-strip article:last-child { border: 0; }.promise-strip article > span { color: var(--lime); font: 700 11px/1 "Figtree", sans-serif; }.promise-strip strong { font: 400 21px/1.2 "Paytone One", sans-serif; }.promise-strip p { margin: 10px 0 0; color: rgba(255,255,255,.6); font-size: 12px; line-height: 1.5; }

.contact { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(50px, 8vw, 135px); background: var(--cream); }.contact__intro { max-width: 550px; }.contact__intro h2 { font-size: clamp(40px, 4.7vw, 69px); }.contact__intro > p:not(.kicker) { color: #625d68; line-height: 1.7; }.contact__intro > a { display: inline-flex; gap: 12px; margin-top: 15px; padding-bottom: 5px; border-bottom: 2px solid var(--red); color: var(--blue); font-weight: 700; }.contact-form { padding: clamp(26px, 4vw, 48px); border: 2px solid var(--ink); border-radius: 30px; background: white; box-shadow: 10px 10px 0 var(--ink); }.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }.contact-form label { display: block; margin-bottom: 20px; }.contact-form label > span { display: block; margin-bottom: 8px; font: 700 11px/1 "Figtree", sans-serif; text-transform: uppercase; letter-spacing: .08em; }.contact-form input, .contact-form select, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 13px; padding: 14px 15px; outline: none; background: #faf9fc; resize: vertical; transition: border .2s, box-shadow .2s; }.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { border-color: var(--blue); box-shadow: 0 0 0 3px rgba(33,23,200,.1); }.form-status { min-height: 20px; margin: 14px 0 0; color: var(--blue); font-size: 13px; font-weight: 700; }

.site-footer { padding: 55px clamp(22px, 6vw, 96px) 25px; background: var(--blue); color: white; }.footer__top { min-height: 120px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; border-bottom: 1px solid rgba(255,255,255,.2); }.footer__top img { width: min(240px, 100%); filter: brightness(0) invert(1); }.footer__top p { font: 400 clamp(23px, 2.5vw, 38px)/1.1 "Paytone One", sans-serif; text-align: center; max-width: 520px; }.footer__top > a { justify-self: end; font-size: 12px; font-weight: 700; }.footer__bottom { padding-top: 22px; display: flex; justify-content: space-between; color: rgba(255,255,255,.62); font-size: 11px; }

.scrim { position: fixed; z-index: 1990; inset: 0; background: rgba(13,10,30,.48); backdrop-filter: blur(4px); opacity: 0; pointer-events: none; transition: opacity .3s; }.scrim.active { opacity: 1; pointer-events: auto; }
.cart-drawer { position: fixed; z-index: 2000; inset: 0 0 0 auto; width: min(470px, 100%); padding: 27px; display: flex; flex-direction: column; background: var(--cream); box-shadow: -20px 0 70px rgba(15,10,40,.25); transform: translateX(103%); visibility: hidden; transition: transform .35s cubic-bezier(.2,.8,.2,1), visibility .35s; }.cart-drawer.open { transform: none; visibility: visible; }.drawer__header { display: flex; align-items: flex-start; justify-content: space-between; }.drawer__header p { margin: 0 0 7px; color: var(--red); font: 700 10px/1 "Figtree", sans-serif; letter-spacing: .15em; }.drawer__header h2 { margin: 0; font: 400 34px/1 "Paytone One", sans-serif; }.close-button { width: 42px; height: 42px; border: 1px solid var(--line); border-radius: 50%; background: white; cursor: pointer; font-size: 25px; transition: transform .2s; }.close-button:hover { transform: rotate(8deg); }.shipping-meter { margin: 25px 0 10px; }.shipping-meter p { margin: 0 0 9px; font-size: 11px; font-weight: 600; }.shipping-meter > div { height: 6px; background: #ddd9cd; border-radius: 99px; overflow: hidden; }.shipping-meter span { display: block; width: 0; height: 100%; background: var(--red); border-radius: inherit; transition: width .35s; }.cart-items { flex: 1; overflow-y: auto; padding-right: 4px; }.cart-line { padding: 18px 0; border-bottom: 1px solid var(--line); display: grid; grid-template-columns: 78px 1fr auto; gap: 14px; align-items: center; }.cart-line__image { width: 78px; height: 91px; padding: 7px; border-radius: 13px; background: var(--lilac); }.cart-line__image img { width: 100%; height: 100%; object-fit: cover; border-radius: 7px; }.cart-line h3 { margin: 0 0 7px; font: 700 13px/1.3 "Figtree", sans-serif; }.cart-line p { margin: 0; color: var(--blue); font-size: 13px; font-weight: 700; }.cart-line__remove { border: 0; background: transparent; color: #807a86; text-decoration: underline; font-size: 10px; cursor: pointer; }.mini-qty { margin-top: 10px; display: inline-flex; align-items: center; border: 1px solid var(--line); border-radius: 99px; }.mini-qty button { width: 27px; height: 25px; border: 0; background: transparent; cursor: pointer; }.mini-qty span { min-width: 20px; text-align: center; font-size: 11px; }.cart-empty { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; }.cart-empty > span { color: var(--red); font-size: 38px; }.cart-empty h3 { margin: 20px 0 6px; font: 400 26px/1 "Paytone One", sans-serif; }.cart-empty p { margin: 0 0 25px; color: #77717c; font-size: 13px; }.cart-footer { padding-top: 19px; border-top: 1px solid var(--line); }.cart-subtotal { display: flex; align-items: center; justify-content: space-between; font-weight: 700; }.cart-subtotal strong { font-size: 21px; color: var(--blue); }.cart-footer > p { color: #77717c; font-size: 10px; margin: 7px 0 16px; }

.product-modal { position: fixed; z-index: 2010; inset: 50% auto auto 50%; width: min(990px, calc(100% - 34px)); max-height: min(720px, calc(100vh - 34px)); display: grid; grid-template-columns: 1.08fr .92fr; overflow: auto; border-radius: 30px; background: white; box-shadow: 0 35px 100px rgba(11,8,38,.35); transform: translate(-50%,-47%) scale(.95); opacity: 0; visibility: hidden; transition: opacity .3s, transform .3s, visibility .3s; }.product-modal.open { transform: translate(-50%,-50%) scale(1); opacity: 1; visibility: visible; }.product-modal__close { position: absolute; z-index: 4; right: 18px; top: 18px; }.product-modal__media { padding: 40px; display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--lilac); }.product-modal__media > img { width: min(330px, 82%); max-height: 410px; object-fit: cover; border: 7px solid white; border-radius: 16px; box-shadow: 0 23px 45px rgba(29,20,90,.19); transform: rotate(-2deg); }.modal-gallery { margin-top: 25px; display: flex; gap: 9px; }.modal-gallery button { width: 54px; height: 54px; padding: 3px; border: 1px solid transparent; border-radius: 9px; background: white; cursor: pointer; }.modal-gallery button.active { border-color: var(--blue); }.modal-gallery img { width: 100%; height: 100%; object-fit: cover; border-radius: 5px; }.product-modal__copy { padding: clamp(40px, 6vw, 80px) clamp(30px, 5vw, 65px) 45px; display: flex; flex-direction: column; justify-content: center; }.product-modal__copy .kicker { color: var(--red); }.product-modal__copy h2 { margin: 0; font: 400 clamp(31px, 4vw, 48px)/1.03 "Paytone One", sans-serif; letter-spacing: -.035em; }.modal-price { margin: 18px 0; color: var(--blue); font-size: 23px; font-weight: 700; }.modal-description { color: #69636f; line-height: 1.65; }.modal-details { padding: 18px 0; margin: 8px 0 24px; border-block: 1px solid var(--line); list-style: none; display: grid; gap: 8px; color: #4f4a56; font-size: 12px; }.modal-details li::before { content: "✓"; margin-right: 9px; color: #16a367; font-weight: 700; }.modal-buy-row { display: grid; grid-template-columns: auto 1fr; gap: 10px; }.qty-picker { height: 51px; display: flex; align-items: center; border: 1px solid var(--line); border-radius: 99px; }.qty-picker button { width: 39px; height: 100%; border: 0; background: transparent; cursor: pointer; font-size: 18px; }.qty-picker span { min-width: 22px; text-align: center; font-weight: 700; }
.toast { position: fixed; z-index: 3000; left: 50%; bottom: 28px; padding: 12px 18px 12px 12px; display: flex; gap: 11px; align-items: center; border-radius: 99px; background: var(--ink); color: white; box-shadow: 0 15px 40px rgba(0,0,0,.25); transform: translate(-50%, 150%); opacity: 0; transition: transform .3s, opacity .3s; }.toast.show { transform: translate(-50%,0); opacity: 1; }.toast span { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 50%; background: var(--lime); color: var(--ink); }.toast p { margin: 0; font-size: 12px; font-weight: 700; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .75s ease, transform .75s cubic-bezier(.2,.8,.2,1); }.reveal.visible { opacity: 1; transform: none; }
@keyframes marquee { to { transform: translateX(-50%); } }
@keyframes bob { 50% { transform: rotate(7deg) translateY(-12px); } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse { 50% { opacity: .35; } }

@media (max-width: 1050px) {
  .hero { grid-template-columns: 1fr .8fr; padding-inline: 40px; }
  .hero h1 { font-size: clamp(54px, 7vw, 80px); }.hero__art { min-height: 480px; }.product-fan { width: min(20vw, 220px); }
  .trend-layout { grid-template-columns: .55fr 1.45fr; }.trend-editorial h3 { font-size: 42px; }
  .about { gap: 65px; }.about__seal { right: -25px; }.about__scribble { left: 0; }
}

@media (max-width: 800px) {
  .site-header { height: 67px; grid-template-columns: 1fr auto; padding-inline: 18px; }.site-header.scrolled { height: 62px; }.brand { width: 116px; }.desktop-nav, .search-jump { display: none; }.menu-button { display: grid; }.header-actions { gap: 7px; }.cart-button { padding-left: 15px; }.mobile-menu { position: fixed; z-index: 990; inset: 101px 0 auto; padding: 25px 22px 35px; display: grid; gap: 0; background: var(--cream); box-shadow: 0 25px 50px rgba(20,15,45,.18); transform: translateY(-130%); visibility: hidden; transition: transform .3s, visibility .3s; }.mobile-menu.open { transform: none; visibility: visible; }.mobile-menu a { padding: 16px 3px; border-bottom: 1px solid var(--line); font: 400 25px/1 "Paytone One", sans-serif; }
  .hero { min-height: auto; padding: 70px 22px 100px; grid-template-columns: 1fr; gap: 25px; text-align: center; }.eyebrow { justify-content: center; }.hero h1 { margin-inline: auto; font-size: clamp(51px, 13vw, 81px); }.hero__lead { margin-inline: auto; }.hero__actions, .hero__proof { justify-content: center; }.hero__art { min-height: 500px; }.hero__art::before { width: min(78vw, 470px); }.product-fan { width: min(39vw, 230px); }.orbit--one { width: min(88vw, 530px); }.orbit--two { width: min(100vw, 600px); }
  .section-heading { align-items: flex-start; }.section-heading > p { display: none; }.product-grid--featured, .product-grid--shop { grid-template-columns: repeat(2, 1fr); }.trend-layout { grid-template-columns: 1fr; }.trend-editorial { display: grid; grid-template-columns: 1fr auto; align-items: end; }.trend-editorial h3 { grid-column: 1 / -1; }.trend-editorial > p:not(.trend-number) { margin: 0; }.product-grid--trending { width: 100%; }
  .about, .contact { grid-template-columns: 1fr; }.about__visual { justify-self: center; max-width: 560px; }.about__copy { max-width: none; }.promise-strip { grid-template-columns: 1fr; }.promise-strip article { min-height: auto; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.15); }.contact__intro { max-width: 650px; }
  .footer__top { grid-template-columns: 1fr auto; gap: 25px; }.footer__top p { grid-column: 1 / -1; grid-row: 2; text-align: left; }.footer__bottom span:nth-child(2) { display: none; }
}

@media (max-width: 560px) {
  .announcement { height: 30px; }.announcement__track span { padding: 0 24px; }.mobile-menu { inset-block-start: 97px; }
  .cart-button > span:first-child { display: none; }.cart-button { padding: 6px; background: transparent; }.cart-count { background: var(--blue); color: white; }
  .hero { padding-top: 55px; }.hero h1 { font-size: clamp(46px, 14vw, 67px); }.hero__lead { margin-top: 25px; font-size: 15px; }.hero__actions { flex-direction: column; gap: 13px; }.hero__art { min-height: 400px; }.product-fan { width: min(39vw, 185px); border-width: 6px; }.sticker-note--top { width: 82px; height: 82px; right: 0; top: 9%; font-size: 11px; box-shadow: 4px 4px 0 var(--ink); }.sticker-note--bottom { width: 100px; height: 65px; left: 0; bottom: 12%; font-size: 11px; box-shadow: 4px 4px 0 var(--ink); }.spark { display: none; }
  .shop-search { padding-inline: 16px; }.search-shell { height: 62px; padding-inline: 16px 9px; box-shadow: 5px 5px 0 var(--ink); }.search-shell input { padding-inline: 10px; font-size: 13px; }.quick-tags { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 5px; }.quick-tags > * { flex: 0 0 auto; }
  .section-pad { padding: 80px 18px; }.section-heading { margin-bottom: 35px; flex-direction: column; gap: 22px; }.section-heading h2, .about h2, .contact h2 { font-size: clamp(39px, 12vw, 54px); }.product-grid--featured, .product-grid--shop, .product-grid--trending { grid-template-columns: 1fr; gap: 35px; }.product-card__media, .product-grid--shop .product-card__media { aspect-ratio: 1.07; }.product-card__media img { width: 65%; }.quick-add { opacity: 1; transform: none; }
  .trend-editorial { display: block; }.trend-editorial > p:not(.trend-number) { margin-bottom: 25px; }.shop-controls { width: 100%; flex-direction: column; }.shop-controls select { width: 100%; }.result-count { margin-top: -12px; }
  .about { gap: 70px; }.about__seal { width: 110px; height: 110px; right: -5px; top: -50px; }.about__scribble { font-size: 15px; bottom: -50px; }.about__stats { gap: 10px; }.about__stats strong { font-size: 22px; }.about__stats span { font-size: 9px; }
  .field-row { grid-template-columns: 1fr; gap: 0; }.contact-form { padding: 24px 18px; box-shadow: 6px 6px 0 var(--ink); }.footer__top img { width: 150px; }.footer__top > a { font-size: 10px; }.footer__bottom { gap: 20px; }
  .product-modal { grid-template-columns: 1fr; max-height: calc(100vh - 22px); }.product-modal__media { min-height: 330px; padding: 35px 20px 25px; }.product-modal__media > img { max-height: 260px; width: 190px; }.modal-gallery { margin-top: 16px; }.product-modal__copy { padding: 35px 23px 28px; }.product-modal__copy h2 { font-size: 32px; }.modal-buy-row { grid-template-columns: 1fr; }.qty-picker { justify-content: space-between; }.product-modal__close { position: fixed; }.cart-drawer { padding: 22px 18px; }
}

.cart-empty[hidden] { display: none !important; }

@media (max-width: 560px) {
  .sticker-note--top { padding: 7px; font-size: 9px; }
}

.modal-buy-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.modal-buy-actions .button {
  padding-inline: 18px;
}

.modal-buy-actions .button--cream {
  border: 1px solid var(--line);
}

@media (max-width: 760px) {
  .modal-buy-actions {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
