:root {
  --cream: #fff1fc;
  --paper: #fffaff;
  --ink: #29152f;
  --orange: #ee28b7;
  --orange-dark: #9b24d3;
  --yellow: #ff8de1;
  --pink: #ffb4ec;
  --green: #6327b5;
  --line: rgba(65, 24, 79, .2);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "Nunito Sans", sans-serif; }
a { color: inherit; }
button, .button { font: inherit; }

.site-header { height: 84px; padding: 0 clamp(22px, 5vw, 76px); display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); background: var(--paper); }
.brand { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; font-family: "Shrikhand", cursive; font-size: 20px; font-weight: 400; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; border: 2px solid var(--ink); border-radius: 7px; background: linear-gradient(145deg, #ffb4ec, #ed42cc); box-shadow: 3px 3px 0 var(--ink); font-family: "Nunito Sans", sans-serif; font-size: 13px; font-weight: 900; letter-spacing: -.04em; transform: rotate(-4deg); }
nav { display: flex; gap: 32px; }
nav a { text-decoration: none; font-size: 14px; font-weight: 600; }
nav a:hover { color: var(--orange-dark); }
.language-link { min-width: 34px; padding: 5px 12px; border: 1.5px solid var(--ink); border-radius: 50px; background: var(--pink); text-align: center; box-shadow: 2px 2px 0 var(--ink); font-weight: 800; white-space: nowrap; }

.hero { min-height: 620px; display: grid; grid-template-columns: 1.04fr .96fr; background: linear-gradient(135deg, #fff0fb, #f9c9f0); overflow: hidden; }
.hero-copy { padding: clamp(70px, 9vw, 130px) clamp(28px, 8vw, 120px); align-self: center; }
.eyebrow { margin: 0 0 18px; font-size: 12px; letter-spacing: .17em; font-weight: 700; color: var(--orange-dark); }
h1, h2 { font-family: "Shrikhand", cursive; font-weight: 400; margin: 0; line-height: 1.02; letter-spacing: -.025em; }
h1 { font-size: clamp(58px, 7.4vw, 105px); }
h1 em { color: var(--orange); font-weight: 400; font-style: normal; text-shadow: 3px 3px 0 #fff, 5px 5px 0 var(--green); }
.intro { max-width: 520px; margin: 30px 0; font-size: 18px; line-height: 1.65; }
.button { min-height: 48px; display: inline-flex; align-items: center; justify-content: center; gap: 20px; padding: 12px 22px; border: 0; text-decoration: none; font-weight: 700; font-size: 14px; cursor: pointer; transition: transform .18s, background .18s; }
.button:hover { transform: translateY(-2px); }
.primary { color: white; background: var(--orange); box-shadow: 5px 5px 0 var(--ink); }
.primary:hover { background: var(--orange-dark); }

.hero-art { position: relative; min-height: 560px; display: grid; place-items: center; background: linear-gradient(145deg, #8e35da, #f33cc7); overflow: hidden; }
.photo-hero > img { width: 100%; height: 100%; position: absolute; inset: 0; object-fit: cover; object-position: center; }
.photo-hero::after { content: ""; position: absolute; inset: 0; transform: none; background: linear-gradient(180deg, transparent 55%, rgba(41,21,47,.36)); text-shadow: none; font-size: 0; }
.hero-sticker { position: absolute; z-index: 4; display: grid; place-items: center; border: 2px solid var(--ink); color: var(--ink); box-shadow: 5px 5px 0 var(--ink); font-weight: 900; text-align: center; }
.sticker-one { top: 8%; right: 7%; width: 108px; height: 108px; border-radius: 50%; background: #fff36d; transform: rotate(9deg); }
.sticker-two { left: 7%; bottom: 8%; padding: 14px 19px; background: #ff9fe5; transform: rotate(-5deg); }
.sunburst { position: absolute; width: 150%; aspect-ratio: 1; background: repeating-conic-gradient(from -5deg, rgba(255,255,255,.19) 0 9deg, transparent 9deg 22deg); border-radius: 50%; }
.hero-art::before, .hero-art::after { position: absolute; z-index: 2; color: #fff5a8; font-size: 64px; text-shadow: 4px 4px 0 var(--ink); }
.hero-art::before { content: "✦"; top: 9%; left: 9%; transform: rotate(-12deg); }
.hero-art::after { content: "♥"; right: 8%; top: 12%; transform: rotate(10deg); }
.plate { position: relative; width: min(62%, 430px); aspect-ratio: 1; border-radius: 50%; background: #ffeafa; box-shadow: 10px 12px 0 var(--ink), inset 0 0 0 18px #fff, inset 0 0 0 22px #d13cb9; transform: rotate(-5deg); }
.flan { position: absolute; inset: 21%; border-radius: 48% 48% 42% 42%; background: linear-gradient(#b94719 0 12%, #f7b732 13% 72%, #e99324); box-shadow: 0 18px 20px rgba(96, 49, 15, .25); }
.flan::before { content: ""; position: absolute; inset: -4% 2% 72%; border-radius: 50%; background: radial-gradient(ellipse at 45% 40%, #ed8343, #8f2d12 66%); }
.flan span { position: absolute; width: 72%; height: 19%; left: 15%; top: 5%; border-radius: 50%; background: rgba(255, 201, 85, .28); filter: blur(5px); }
.art-note { position: absolute; right: 7%; bottom: 7%; width: 104px; height: 104px; display: grid; place-items: center; margin: 0; border: 2px solid var(--ink); border-radius: 42% 58% 49% 51%; background: #fff36d; color: var(--ink); box-shadow: 5px 5px 0 var(--ink); text-align: center; font-family: "Shrikhand", cursive; font-size: 14px; line-height: 1.2; transform: rotate(8deg); }

.promise { padding: 20px clamp(25px, 6vw, 90px); display: flex; justify-content: space-between; gap: 20px; background: var(--ink); color: white; }
.promise p { margin: 0; font-size: 13px; font-weight: 600; }
.promise span { color: var(--yellow); margin-right: 7px; }

.shop { padding: clamp(80px, 10vw, 145px) clamp(22px, 6vw, 90px); }
.section-heading { margin-bottom: 45px; display: flex; align-items: end; justify-content: space-between; gap: 30px; }
.section-heading h2, .delivery-section h2, .cta h2 { font-size: clamp(43px, 5vw, 68px); }
.filters { display: flex; gap: 6px; padding: 5px; border: 1px solid var(--line); border-radius: 50px; }
.filter { padding: 9px 15px; border: 0; border-radius: 50px; background: transparent; color: var(--ink); cursor: pointer; font-size: 13px; font-weight: 600; }
.filter.active { background: var(--orange); color: white; box-shadow: 2px 2px 0 var(--ink); }
.product-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 50px 24px; }
.catalog-grid { grid-template-columns: repeat(3, 1fr); }
.product-card[hidden] { display: none; }
.product-image { position: relative; min-height: 380px; display: grid; place-items: center; overflow: hidden; }
.product-photo { width: 100%; height: 100%; position: absolute; inset: 0; object-fit: cover; object-position: center; transition: transform .35s ease; }
.product-card:hover .product-photo { transform: scale(1.025); }
.flan-image { background: #ff9cdd; }
.celebration-image { background: #c79bff; }
.topper-image { background: #ff67cf; }
.decor-image { background: #a879ea; }
.badge { position: absolute; top: 18px; left: 18px; z-index: 2; padding: 8px 11px; border-radius: 30px; color: white; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; }
.badge.delivery { background: var(--green); }
.badge.shipping { background: var(--orange-dark); }
.mini-plate { width: 250px; height: 250px; display: grid; place-items: center; border-radius: 50%; background: #fff0fb; box-shadow: inset 0 0 0 12px white, inset 0 0 0 15px var(--ink), 8px 9px 0 rgba(45,20,48,.88); transform: rotate(-7deg); }
.mini-flan { width: 145px; height: 108px; display: grid; place-items: center; border-radius: 50% 50% 42% 42%; background: linear-gradient(#a73816 0 14%, #efad2e 15%); color: var(--cream); font-size: 30px; box-shadow: 0 14px 16px rgba(45,36,30,.2); }
.topper { position: relative; padding: 25px; color: #fff36d; font-family: "Shrikhand", cursive; font-size: 74px; font-weight: 400; text-shadow: 3px 3px 0 white, 6px 6px 0 var(--ink); transform: rotate(-6deg); }
.topper::before, .topper::after { content: "✦"; position: absolute; color: var(--green); font-size: 34px; }
.topper::before { left: -20px; top: 0; }.topper::after { right: -20px; bottom: 0; }
.topper i { position: absolute; left: 50%; top: 90%; height: 140px; width: 4px; background: var(--ink); z-index: -1; }
.bunting { position: absolute; top: 28%; width: 120%; display: flex; justify-content: center; border-top: 3px solid var(--ink); transform: rotate(-7deg); }
.bunting i { width: 52px; height: 64px; margin: -1px 8px; background: var(--orange); clip-path: polygon(0 0, 100% 0, 50% 100%); }
.bunting i:nth-child(2n) { background: var(--yellow); }.bunting i:nth-child(3) { background: var(--green); }
.confetti { margin-top: 90px; color: var(--orange-dark); font-size: 32px; letter-spacing: 10px; }
.product-info { padding: 20px 3px 0; }
.product-info > div { display: flex; justify-content: space-between; gap: 15px; }
.product-info h3, .delivery-options h3 { margin: 0; font-family: "Shrikhand", cursive; font-weight: 400; font-size: 25px; }
.price { margin: 5px 0 0; white-space: nowrap; font-weight: 700; }
.product-info > p { min-height: 52px; margin: 12px 0 20px; color: #6c5f56; line-height: 1.6; }
.checkout { width: 100%; justify-content: space-between; border: 1px solid var(--ink); background: transparent; }
.checkout:hover { color: white; background: var(--ink); }
.details-link { color: var(--ink); }

.product-page { padding: clamp(48px, 7vw, 100px) clamp(22px, 7vw, 100px) clamp(80px, 10vw, 140px); background: linear-gradient(135deg, #fff0fb, #ecd3ff); }
.back-link { display: inline-block; margin-bottom: 30px; color: var(--orange-dark); font-weight: 800; text-decoration: none; }
.product-detail { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr); gap: clamp(40px, 7vw, 100px); align-items: start; }
.product-detail-photo { position: relative; background: var(--pink); border: 2px solid var(--ink); box-shadow: 12px 12px 0 var(--ink); overflow: hidden; }
.product-detail-photo img { display: block; width: 100%; aspect-ratio: 1; object-fit: cover; }
.product-gallery { min-width: 0; }
.gallery-thumbs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 22px; }
.gallery-thumbs img { width: 100%; aspect-ratio: 1; border: 2px solid var(--ink); object-fit: cover; }
.product-detail-copy { padding-top: 14px; }
.product-detail-copy h1 { font-size: clamp(47px, 6vw, 78px); }
.product-price { margin: 24px 0; color: var(--orange-dark); font-size: 30px; font-weight: 900; }
.product-lead { font-size: 18px; line-height: 1.7; }
.feature-box { margin: 30px 0; padding: 24px 28px; border: 2px solid var(--ink); background: rgba(255,255,255,.7); box-shadow: 6px 6px 0 var(--orange); }
.feature-box h2 { margin-bottom: 12px; font-size: 26px; }
.feature-box ul { margin: 0; padding-left: 20px; line-height: 1.85; }
.product-notes { color: #624c68; line-height: 1.7; }
.product-order { width: 100%; margin-top: 18px; font-size: 16px; }
.materials-section { padding: clamp(75px, 9vw, 130px) clamp(22px, 6vw, 90px); background: #fff36d; }
.material-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.material-grid article { min-height: 270px; padding: 28px; border: 2px solid var(--ink); background: var(--paper); box-shadow: 7px 7px 0 var(--ink); }
.material-grid span { color: var(--orange-dark); font-family: "Shrikhand", cursive; }
.material-grid h3 { margin: 30px 0 10px; font-family: "Shrikhand", cursive; font-size: 26px; font-weight: 400; }
.material-grid p { color: #624c68; line-height: 1.65; }
.material-grid strong { display: block; margin-top: 22px; color: var(--orange-dark); }
.setup-feature { display: grid; grid-template-columns: 1.05fr .95fr; background: var(--ink); color: white; overflow: hidden; }
.setup-feature-copy { padding: clamp(70px, 9vw, 130px) clamp(25px, 8vw, 120px); }
.setup-feature-copy h2 { font-size: clamp(44px, 5.5vw, 76px); }
.setup-feature-copy > p:not(.eyebrow) { max-width: 650px; margin: 25px 0; color: #f1dff2; font-size: 18px; line-height: 1.7; }
.service-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 32px; }
.service-tags span { padding: 8px 12px; border: 1px solid #f2a1e2; border-radius: 30px; color: #ffd9f5; font-size: 12px; font-weight: 800; }
.setup-feature-art { position: relative; min-height: 560px; display: grid; place-items: center; background: linear-gradient(145deg, #ff72d1, #8d3bd1); overflow: hidden; }
.party-backdrop { width: min(66%, 390px); aspect-ratio: 1; display: grid; place-items: center; border: 3px solid var(--ink); border-radius: 50%; background: #fff36d; box-shadow: 12px 12px 0 var(--ink); color: var(--orange-dark); font-family: "Shrikhand", cursive; font-size: clamp(48px, 6vw, 82px); line-height: .85; text-align: center; transform: rotate(-4deg); }
.party-table { position: absolute; left: 9%; right: 9%; bottom: 8%; height: 105px; display: flex; align-items: end; justify-content: center; gap: 28px; border: 3px solid var(--ink); background: #fff6fe; box-shadow: 8px 8px 0 var(--ink); }
.party-table i { width: 40px; height: 65px; display: block; background: var(--pink); clip-path: polygon(50% 0, 100% 100%, 0 100%); }
.party-cake { width: 100px; height: 90px; display: grid; place-items: center; border: 3px solid var(--ink); border-radius: 50% 50% 15% 15%; background: var(--orange); color: #fff36d; font-size: 30px; }
.setup-spark { position: absolute; color: #fff36d; font-size: 58px; text-shadow: 4px 4px 0 var(--ink); }.spark-a { top: 8%; left: 7%; }.spark-b { top: 13%; right: 8%; }
.service-page { background: linear-gradient(135deg, #fff0fb, #ead3ff); }
.service-page > .back-link { margin: 40px clamp(22px, 7vw, 100px) 0; }
.service-hero { padding: clamp(35px, 6vw, 80px) clamp(22px, 7vw, 100px) clamp(80px, 9vw, 130px); display: grid; grid-template-columns: 1.2fr .8fr; gap: clamp(40px, 7vw, 100px); align-items: center; }
.service-hero h1 { font-size: clamp(56px, 7.5vw, 106px); }.service-hero h1 em { color: var(--orange); font-style: normal; text-shadow: 3px 3px 0 white, 5px 5px 0 var(--green); }
.service-area-card { padding: 36px; border: 2px solid var(--ink); background: #fff36d; box-shadow: 10px 10px 0 var(--ink); transform: rotate(2deg); }
.service-area-card h2 { font-size: 42px; }.service-area-card p { line-height: 1.65; }.service-area-card strong { color: var(--orange-dark); }
.service-details { padding: clamp(75px, 9vw, 130px) clamp(22px, 7vw, 100px); display: grid; grid-template-columns: .8fr 1.2fr; gap: 8vw; background: var(--paper); }
.service-details h2, .scope-section h2, .quote-note h2 { font-size: clamp(40px, 4.5vw, 64px); }
.service-checklist article { padding: 25px 0; display: grid; grid-template-columns: 55px 1fr; border-top: 1px solid var(--line); }.service-checklist article:last-child { border-bottom: 1px solid var(--line); }
.service-checklist span { color: var(--orange-dark); font-family: "Shrikhand", cursive; }.service-checklist h3 { margin: 0; font-family: "Shrikhand", cursive; font-size: 24px; font-weight: 400; }.service-checklist p { color: #624c68; line-height: 1.65; }
.scope-section { padding: clamp(70px, 8vw, 110px) clamp(22px, 7vw, 100px); display: grid; grid-template-columns: 1fr 1fr; gap: 24px; background: #fff36d; }
.scope-section article { padding: clamp(30px, 5vw, 60px); border: 2px solid var(--ink); background: var(--paper); box-shadow: 8px 8px 0 var(--ink); }.scope-section .not-included { background: #ffe4f7; }.scope-section ul { padding-left: 20px; line-height: 2; }
.quote-note { padding: clamp(80px, 10vw, 140px) 24px; text-align: center; background: linear-gradient(120deg, #d328bd, #7827c8); color: white; }.quote-note h2 { max-width: 850px; margin: 0 auto; }.quote-note > p:not(.eyebrow) { max-width: 750px; margin: 25px auto 30px; line-height: 1.7; }
.spanish-products { padding-bottom: 100px; background: linear-gradient(135deg, #fff0fb, #ead3ff); }
.spanish-products-header { padding: clamp(70px, 9vw, 130px) clamp(22px, 7vw, 100px); background: var(--ink); color: white; }
.spanish-products-header h1 { max-width: 1050px; font-size: clamp(55px, 7vw, 100px); }.spanish-products-header h1 em { color: var(--yellow); font-style: normal; }.spanish-products-header > p:last-child { max-width: 680px; margin: 26px 0 0; color: #edd9ee; font-size: 18px; line-height: 1.7; }
.spanish-product { margin: 55px auto 0; width: min(1180px, calc(100% - 44px)); display: grid; grid-template-columns: .9fr 1.1fr; border: 2px solid var(--ink); background: var(--paper); box-shadow: 9px 9px 0 var(--ink); overflow: hidden; scroll-margin-top: 30px; }
.spanish-product > img { width: 100%; height: 100%; min-height: 460px; object-fit: cover; }
.spanish-product > div { padding: clamp(30px, 5vw, 65px); }.spanish-product h2 { font-size: clamp(38px, 4.5vw, 60px); }.spanish-product > div > p:not(.eyebrow):not(.product-price) { color: #624c68; line-height: 1.7; }.spanish-product ul { padding-left: 21px; line-height: 1.9; }.spanish-product .button { margin-top: 12px; margin-right: 8px; }

.delivery-section { padding: clamp(75px, 9vw, 130px) clamp(25px, 8vw, 120px); display: grid; grid-template-columns: .8fr 1.2fr; gap: 8vw; background: linear-gradient(135deg, #fff0fb, #e6c9ff); }
.delivery-options article { padding: 28px 0; display: grid; grid-template-columns: 55px 1fr; border-top: 1px solid var(--line); }
.delivery-options article:last-child { border-bottom: 1px solid var(--line); }
.option-number { color: var(--orange-dark); font-family: "Shrikhand", cursive; font-weight: 400; }
.delivery-options p { margin: 10px 0 0; color: #6c5f56; line-height: 1.65; }
.cta { padding: clamp(80px, 11vw, 150px) 24px; text-align: center; background: linear-gradient(120deg, #d328bd, #7827c8); color: white; }
.cta .eyebrow { color: var(--yellow); }.cta h2 { max-width: 760px; margin: 0 auto 30px; }.light { background: var(--cream); color: var(--ink); }
footer { padding: 30px clamp(22px, 5vw, 76px); display: flex; align-items: center; justify-content: space-between; gap: 20px; font-size: 12px; }

dialog { width: min(500px, calc(100% - 36px)); padding: 38px; border: 0; box-shadow: 0 25px 80px rgba(45,36,30,.28); background: var(--paper); }
dialog::backdrop { background: rgba(45,36,30,.58); }
dialog h2 { font-size: 38px; } dialog p:not(.eyebrow) { line-height: 1.65; }
.dialog-close { position: absolute; right: 12px; top: 8px; border: 0; background: none; font-size: 30px; cursor: pointer; }

.confirmation-page { min-height: calc(100vh - 84px); padding: clamp(52px, 8vw, 110px) clamp(18px, 5vw, 76px); background: radial-gradient(circle at 12% 18%, rgba(255, 141, 225, .45), transparent 28%), radial-gradient(circle at 88% 76%, rgba(99, 39, 181, .2), transparent 30%), var(--cream); }
.confirmation-card { position: relative; max-width: 1120px; margin: 0 auto; padding: clamp(38px, 7vw, 88px); border: 2px solid var(--ink); background: var(--paper); box-shadow: 10px 10px 0 var(--ink); overflow: hidden; }
.confirmation-card::after { content: "✦"; position: absolute; right: clamp(18px, 4vw, 54px); top: clamp(22px, 5vw, 54px); color: var(--orange); font-size: clamp(38px, 6vw, 74px); transform: rotate(13deg); }
.confirmation-burst { width: 64px; height: 64px; margin-bottom: 28px; display: grid; place-items: center; border: 2px solid var(--ink); border-radius: 50%; background: var(--yellow); box-shadow: 4px 4px 0 var(--ink); font-size: 30px; font-weight: 900; }
.confirmation-card h1 { max-width: 850px; font-size: clamp(48px, 7vw, 88px); }
.confirmation-lead { max-width: 720px; margin: 30px 0 0; font-size: clamp(17px, 2vw, 21px); line-height: 1.7; }
.confirmation-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; margin: clamp(38px, 6vw, 66px) 0; border: 1px solid var(--line); background: var(--line); }
.confirmation-steps article { padding: 28px; background: var(--paper); }
.confirmation-steps span { color: var(--orange-dark); font-family: "Shrikhand", cursive; font-size: 24px; }
.confirmation-steps h2 { margin: 12px 0; font-family: "Nunito Sans", sans-serif; font-size: 18px; font-weight: 900; letter-spacing: 0; }
.confirmation-steps p { margin: 0; color: #6c5f56; line-height: 1.65; }
.confirmation-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.confirmation-note { margin: 24px 0 0; color: #6c5f56; font-size: 13px; }

@media (max-width: 800px) {
  .site-header { padding-inline: 18px; }
  nav { gap: 12px; }
  nav a:not(.language-link) { display: none; }
  .hero { grid-template-columns: 1fr; }
  .hero-copy { padding-top: 75px; padding-bottom: 75px; }
  .hero-art { min-height: 430px; }
  .promise { flex-wrap: wrap; justify-content: center; }
  .promise p { width: calc(50% - 20px); text-align: center; }
  .section-heading { align-items: start; flex-direction: column; }
  .filters { max-width: 100%; overflow-x: auto; }
  .product-grid { grid-template-columns: 1fr; }
  .catalog-grid, .material-grid { grid-template-columns: 1fr; }
  .setup-feature, .service-hero, .service-details, .scope-section { grid-template-columns: 1fr; }
  .spanish-product { grid-template-columns: 1fr; }
  .spanish-product > img { min-height: 330px; aspect-ratio: 1; }
  .confirmation-card { box-shadow: 6px 6px 0 var(--ink); }
  .confirmation-card::after { display: none; }
  .confirmation-steps { grid-template-columns: 1fr; }
  .setup-feature-art { min-height: 430px; }
  .product-image { min-height: 330px; }
  .delivery-section { grid-template-columns: 1fr; }
  .product-detail { grid-template-columns: 1fr; }
  footer { flex-direction: column; text-align: center; }
}

@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } .button { transition: none; } }
