/* ----------------------
   GENERAL STYLES
----------------------- */
:root {
  --candelario-border: #33201d;
  --candelario-bg: #fcf9ed;
  --candelario-accent: #dc5083;
  --candelario-brand: #663d36;
  --candelario-secondary: #cfe1f4;
  --page-padding: var(--wa-space-3xl);
  --candelario-cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='48' viewBox='0 0 24 24'><path fill='%23FFF' stroke='%23000' stroke-width='2' d='M5.5 3.21V20.8c0 .45.54.67.85.35l4.86-4.86a.5.5 0 0 1 .35-.15h6.87a.5.5 0 0 0 .35-.85L6.35 2.85a.5.5 0 0 0-.85.35Z'></path></svg>");
  --candelario-hand: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='28' height='29' fill='none' viewBox='0 0 28 29'%3E%3Cpath fill='%23fff' d='M6.84 21.83c-.47-.6-1.05-1.82-2.07-3.34-.58-.83-2.01-2.41-2.45-3.23a2.1 2.1 0 0 1-.25-1.67 2.2 2.2 0 0 1 2.39-1.67c.85.18 1.63.6 2.25 1.2.43.41.82.85 1.18 1.32.27.34.33.47.63.85.3.39.5.77.35.2-.11-.83-.31-2.23-.6-3.48-.21-.95-.26-1.1-.46-1.82s-.32-1.32-.54-2.13c-.2-.8-.35-1.62-.46-2.44a4.7 4.7 0 0 1 .43-3.08c.58-.55 1.44-.7 2.17-.37a4.4 4.4 0 0 1 1.57 2.17c.43 1.07.72 2.19.86 3.33.27 1.67.79 4.1.8 4.6 0-.61-.11-1.91 0-2.5.12-.6.54-1.1 1.12-1.33.5-.15 1.02-.19 1.53-.1.52.1.98.4 1.29.83.38.98.6 2 .63 3.05.04-.91.2-1.82.47-2.7.28-.39.68-.67 1.15-.8.55-.1 1.11-.1 1.66 0 .46.15.85.44 1.14.82.35.88.56 1.82.63 2.77 0 .23.12-.65.48-1.24a1.67 1.67 0 1 1 3.17 1.07v3.77c-.06.97-.2 1.94-.4 2.9-.29.85-.7 1.65-1.2 2.38-.8.9-1.48 1.92-1.98 3.02a6.67 6.67 0 0 0 .03 3.2c-.68.07-1.37.07-2.05 0-.65-.1-1.45-1.4-1.67-1.8a.63.63 0 0 0-1.13 0c-.37.64-1.18 1.79-1.75 1.85-1.12.14-3.42 0-5.23 0 0 0 .3-1.66-.39-2.27-.68-.6-1.38-1.3-1.9-1.76l-1.4-1.6Z'/%3E%3Cpath stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='2.25' d='M6.84 21.83c-.47-.6-1.05-1.82-2.07-3.34-.58-.83-2.01-2.41-2.45-3.23a2.1 2.1 0 0 1-.25-1.67 2.2 2.2 0 0 1 2.39-1.67c.85.18 1.63.6 2.25 1.2.43.41.82.85 1.18 1.32.27.34.33.47.63.85.3.39.5.77.35.2-.11-.83-.31-2.23-.6-3.48-.21-.95-.26-1.1-.46-1.82s-.32-1.32-.54-2.13c-.2-.8-.35-1.62-.46-2.44a4.7 4.7 0 0 1 .43-3.08c.58-.55 1.44-.7 2.17-.37a4.4 4.4 0 0 1 1.57 2.17c.43 1.07.72 2.19.86 3.33.27 1.67.79 4.1.8 4.6 0-.61-.11-1.91 0-2.5.12-.6.54-1.1 1.12-1.33.5-.15 1.02-.19 1.53-.1.52.1.98.4 1.29.83.38.98.6 2 .63 3.05.04-.91.2-1.82.47-2.7.28-.39.68-.67 1.15-.8.55-.1 1.11-.1 1.66 0 .46.15.85.44 1.14.82.35.88.56 1.82.63 2.77 0 .23.12-.65.48-1.24a1.67 1.67 0 1 1 3.17 1.07v3.77c-.06.97-.2 1.94-.4 2.9-.29.85-.7 1.65-1.2 2.38-.8.9-1.48 1.92-1.98 3.02a6.67 6.67 0 0 0 .03 3.2c-.68.07-1.37.07-2.05 0-.65-.1-1.45-1.4-1.67-1.8a.63.63 0 0 0-1.13 0c-.37.64-1.18 1.79-1.75 1.85-1.12.14-3.42 0-5.23 0 0 0 .3-1.66-.39-2.27-.68-.6-1.38-1.3-1.9-1.76l-1.4-1.6Z' clip-rule='evenodd'/%3E%3Cpath fill='%23000' d='M20.65 22.3v-6.24c0-.38-.31-.68-.7-.68-.37 0-.68.3-.68.68v6.23c0 .38.3.68.69.68.38 0 .69-.3.69-.68ZM17.2 22.3l-.04-6.25a.67.67 0 1 0-1.34.01l.04 6.24a.67.67 0 1 0 1.34 0ZM12.37 16.07l.04 6.22c0 .38.3.68.67.68.37 0 .67-.3.67-.68l-.04-6.23c0-.38-.3-.68-.67-.68-.37 0-.67.31-.67.69Z'/%3E%3C/svg%3E");
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
  --font-heading: "Roboto Mono", "Inter", var(--font-body), monospace;
  --wa-font-body: var(--font-body);
  --wa-font-heading: var(--font-heading);
  --wa-font-display: var(--font-heading);
  --wa-font-title: var(--font-heading);
}

body {
  margin: 0;
  padding: 0;
  background: var(--candelario-bg);
  color: var(--wa-color-ink-1000);
  font-family: var(--font-body);
  cursor: var(--candelario-cursor) 2 2, auto;
}

body,
button,
input,
select,
textarea,
.wa-theme-awesome {
  font-family: var(--font-body);
}

h1,
h2,
h3,
h4,
h5,
h6,
.wa-heading-xl,
.wa-heading-l,
.wa-heading-m,
.wa-heading-s {
  font-family: var(--font-heading);
  text-transform: uppercase;
  color: var(--candelario-brand);
}

/* Pointer */
a,
button,
.image,
.scroller,
wa-button,
wa-details::part(summary) {
  cursor: var(--candelario-hand) 6 2, pointer;
}

wa-carousel,
wa-carousel-item,
.faq-list wa-details {
  cursor: var(--candelario-hand) 6 2, pointer;
}

wa-carousel::part(base),
wa-carousel::part(navigation),
wa-carousel::part(pagination),
wa-carousel::part(control),
wa-carousel::part(tab),
wa-carousel::part(tabpanel),
wa-carousel::part(prev-button),
wa-carousel::part(next-button),
wa-carousel::part(navigation-button),
wa-carousel::part(slide),
wa-details::part(base),
wa-details::part(content),
wa-details::part(summary),
wa-details::part(expand-icon) {
  cursor: var(--candelario-hand) 6 2, pointer;
}

wa-button::part(base) {
  cursor: var(--candelario-hand) 6 2, pointer;
}

/* ----------------------
   COMING SOON OVERLAY
----------------------- */
body.is-coming-soon {
  overflow: hidden;
}

body.is-coming-soon .page,
body.is-coming-soon .announcement-bar {
  opacity: 0;
  pointer-events: none;
  height: 0;
  overflow: hidden;
}

.coming-soon-overlay {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--page-padding);
  background: radial-gradient(
      circle at 20% 20%,
      color-mix(in oklab, var(--candelario-accent) 22%, transparent) 0%,
      transparent 34%
    ),
    radial-gradient(
      circle at 80% 40%,
      color-mix(in oklab, var(--candelario-border) 18%, transparent) 0%,
      transparent 36%
    ),
    var(--candelario-bg);
  text-align: center;
}

.coming-soon-card {
  max-width: 540px;
  width: min(540px, 100%);
  padding: clamp(1.5rem, 4vw, 2.75rem);
  background: var(--wa-color-surface-raised);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  border-radius: var(--wa-radius-l);
  box-shadow: 0 28px 80px rgba(0, 0, 0, 0.12);
}

.coming-soon-card h1 {
  margin: 0 0 var(--wa-space-m);
  font-size: clamp(1.75rem, 5vw, 2.4rem);
  letter-spacing: -0.02em;
}

.coming-soon-card p {
  margin: 0 0 var(--wa-space-s);
}

.coming-soon-kicker {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  font-size: var(--wa-text-xs);
  color: color-mix(in oklab, var(--candelario-border) 70%, black);
}

/* Container */
.page {
  width: 100%;
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  gap: var(--wa-space-4xl);
  padding: var(--page-padding);
}

.text-page {
  max-width: 1200px;
  width: min(1200px, 100%);
  margin: 0 auto;
}

/* ----------------------
   ANNOUNCEMENT BAR
----------------------- */
.announcement-bar {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0;
  padding: var(--wa-space-2xs) var(--page-padding);
  z-index: 10;
  overflow: hidden;
  background: var(--candelario-accent);
  color: var(--wa-color-ink-inverse);
  border-bottom: var(--wa-border-width-s) solid var(--candelario-border);
}

.announcement-marquee {
  --marquee-speed: 28s;
  display: inline-flex;
  align-items: center;
  gap: 0;
  padding: 0;
  width: max-content;
  min-width: 100%;
  animation: marquee var(--marquee-speed) linear infinite;
  will-change: transform;
}

.announcement-track {
  display: inline-flex;
  flex-shrink: 0;
  gap: var(--wa-space-xl);
  padding-inline-end: var(--wa-space-xl);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.announcement-track span::before {
  content: "•";
  margin-right: var(--wa-space-s);
  opacity: 0.6;
}

@keyframes marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .announcement-marquee {
    animation: none;
    transform: none;
  }
}

/* ----------------------
   BOTONES CTA
----------------------- */
wa-button.cta::part(base) {
  background: var(--candelario-secondary);
  border-color: var(--candelario-brand);
  color: var(--candelario-brand);
  width: 100%;
  border-radius: var(--wa-radius-m);
  box-shadow: 6px 8px 0
    color-mix(in oklab, var(--candelario-brand) 35%, transparent);
  transition: border-radius 360ms cubic-bezier(0.25, 0.8, 0.25, 1),
    background 240ms cubic-bezier(0.25, 0.8, 0.25, 1),
    border-color 240ms cubic-bezier(0.25, 0.8, 0.25, 1);
}

wa-button.cta {
  display: block;
  width: 100%;
}

.cta-link {
  text-decoration: none;
  display: block;
}

.cta-content {
  display: inline-flex;
  align-items: center;
  gap: var(--wa-space-xs);
}

wa-button.cta wa-icon {
  display: inline-flex;
  transition: transform 160ms ease, color 160ms ease;
  color: var(--candelario-brand);
}

wa-button.cta::part(base):hover {
  background: color-mix(in oklab, var(--candelario-secondary) 86%, black);
  border-radius: 12px;
  color: #ffffff;
}

wa-button.cta.cta-secondary {
  display: inline-flex;
  width: auto;
}

wa-button.cta.cta-secondary::part(base) {
  background: transparent;
  color: inherit;
  border-color: var(--candelario-brand);
  box-shadow: 2px 4px 0
    color-mix(in oklab, var(--candelario-brand) 35%, transparent);
  border-radius: var(--wa-radius-m);
  transition: background 160ms ease, border-color 160ms ease,
    transform 160ms ease, box-shadow 160ms ease;
}

wa-button.cta.cta-secondary:hover,
wa-button.cta.cta-secondary:focus-visible {
  text-decoration: underline;
}

wa-button.cta.cta-secondary::part(base):hover,
wa-button.cta.cta-secondary::part(base):focus-visible {
  text-decoration: underline;
}

wa-button.cta.cta-secondary .cta-content {
  text-decoration: none;
}

wa-button.cta.cta-secondary:hover .cta-content,
wa-button.cta.cta-secondary:focus-visible .cta-content {
  text-decoration: underline;
  text-decoration-thickness: 2px;
}

wa-button.cta.cta-secondary::part(base):hover {
  background: color-mix(in oklab, var(--wa-color-surface-default) 80%, white);
  border-color: color-mix(in oklab, var(--candelario-brand) 80%, black);
  transform: translateY(-1px);
  box-shadow: 2px 4px 0
    color-mix(in oklab, var(--candelario-brand) 45%, transparent);
}

wa-button.cta.cta-secondary::part(base):focus-visible {
  outline: 2px solid color-mix(in oklab, var(--candelario-brand) 70%, white);
  outline-offset: 2px;
}

wa-button.cta.cta-secondary wa-icon {
  color: inherit !important;
  transform: none !important;
}

wa-button.cta.cta-secondary:hover wa-icon,
wa-button.cta.cta-secondary:focus-visible wa-icon {
  color: inherit !important;
  transform: none !important;
}

wa-button.cta:hover wa-icon,
wa-button.cta:focus-visible wa-icon {
  color: #ffffff;
  transform: scale(1.08);
}

wa-button.cta::part(base):focus-visible {
  outline: 2px solid color-mix(in oklab, var(--candelario-secondary) 75%, black);
  outline-offset: 2px;
}

/* ----------------------
   HERO
----------------------- */
.hero {
  align-items: center;
  flex-wrap: wrap;
  padding: var(--wa-space-l);
  justify-content: space-evenly;
}

.hero-badge {
  border: var(--wa-border-width-s) solid var(--candelario-border);
  padding: var(--wa-space-2xs) var(--wa-space-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--wa-color-surface-raised);
  transform: rotate(-2deg);
  transform-origin: center;
}

.hero-logo img {
  width: 100%;
  display: block;
}

.hero-copy {
  align-items: flex-start;
  max-width: 440px;
}

.hero-price {
  font-size: 1.3rem;
  font-weight: 700;
}

.hero-animated {
  max-width: 440px;
  width: 100%;
}

/* ----------------------
   DETALLE
----------------------- */
.detalle-section {
  display: grid;
  grid-template-columns: minmax(320px, 1.2fr) minmax(280px, 1fr);
  align-items: start;
  gap: var(--wa-space-xl);
  padding: var(--wa-space-2xl);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  background: var(--wa-color-surface-raised);
  box-shadow: 6px 6px 0
    color-mix(in oklab, var(--wa-color-neutral-20) 35%, transparent);
}

.detalle-gallery {
  width: 100%;
}

.carousel-thumbnails {
  --aspect-ratio: 1 / 1;
  border-radius: var(--wa-radius-m);
  overflow: hidden;
}

.carousel-thumbnails img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.thumbnails {
  display: flex;
  justify-content: center;
}

.scroller {
  display: flex;
  gap: var(--wa-space-s);
  overflow-x: auto;
  scrollbar-width: none;
  scroll-behavior: smooth;
  scroll-padding: var(--wa-space-s);
  cursor: var(--candelario-hand) 6 2, pointer !important;
}

.scroller::-webkit-scrollbar {
  display: none;
}

.image {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border: var(--wa-border-width-s) solid transparent;
  border-radius: var(--wa-radius-m);
  opacity: 0.4;
  will-change: opacity;
  transition: 200ms opacity, 200ms border-color;
  cursor: var(--candelario-hand) 6 2, pointer !important;
}

.image.active {
  opacity: 1;
  border-color: var(--candelario-border);
}

/* ----------------------
   WALLPAPER RECOMMENDATION
----------------------- */
.wallpaper-section {
  padding: var(--wa-space-2xl);
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
  border-top: var(--wa-border-width-s) solid var(--candelario-border);
  border-bottom: var(--wa-border-width-s) solid var(--candelario-border);
  position: relative;
}

.wallpaper-gift-icon {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--candelario-bg);
  border-radius: 50%;
  padding: 12px;
  width: 68px;
  height: 68px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.wallpaper-gift-icon wa-icon {
  font-size: 1.9rem;
  animation: gift-pulse 3.2s ease-in-out infinite;
  transform-origin: 50% 50%;
}

@keyframes gift-pulse {
  0%,
  100% {
    transform: scale(1) rotate(0deg);
  }
  8% {
    transform: scale(1.12) rotate(-3deg);
  }
  12% {
    transform: scale(1) rotate(0deg);
  }
  18% {
    transform: scale(1.08) rotate(3deg);
  }
  22% {
    transform: scale(1) rotate(0deg);
  }
}

.wallpaper-layout {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  z-index: 9;
}

.wallpaper-left,
.wallpaper-right {
  flex: 1 1 360px;
  min-width: min(420px, 100%);
}

.wallpaper-right {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.wallpaper-field {
  width: 100%;
  cursor: var(--candelario-hand) 6 2, pointer;
  display: block;
}

.wallpaper-selects {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.wallpaper-selects wa-select {
  width: 100%;
  cursor: var(--candelario-hand) 6 2, pointer;
}

.wallpaper-selects wa-select::part(base),
.wallpaper-selects wa-select::part(control),
.wallpaper-selects wa-select::part(combobox) {
  cursor: var(--candelario-hand) 6 2, pointer;
  border: var(--wa-border-width-s) solid
    color-mix(in oklab, var(--candelario-border) 65%, transparent);
  background: var(--wa-color-surface-default);
  box-shadow: none;
  border-radius: var(--wa-radius-m);
}

.wallpaper-input {
  width: 100%;
  border-radius: var(--wa-radius-m);
  border: none;
  background: transparent;
  font: inherit;
  color: inherit;
  transition: box-shadow 160ms ease;
  position: relative;
  cursor: var(--candelario-hand) 6 2, pointer;
}

.wallpaper-input::-webkit-datetime-edit-year-field,
.wallpaper-input::-webkit-datetime-edit-text:last-of-type {
  display: none;
}

.wallpaper-input::-webkit-datetime-edit {
  padding: 0;
}

.wallpaper-input::placeholder {
  opacity: 0;
}

.wallpaper-input:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 2px
    color-mix(in oklab, var(--candelario-accent) 28%, transparent);
}

.wallpaper-input::-webkit-calendar-picker-indicator {
  background: transparent;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  cursor: var(--candelario-hand) 6 2, pointer;
}

.wallpaper-result {
  max-width: 720px;
  width: 100%;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  justify-items: start;
  gap: var(--wa-space-m);
}

.wallpaper-preview {
  max-width: 240px;
}

.wallpaper-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--wa-radius-l);
  box-shadow: none;
}

.wallpaper-meta {
  display: flex;
  flex-direction: column;
  gap: var(--wa-space-s);
  align-items: flex-start;
  text-align: left;
  justify-content: flex-start;
  align-self: start;
}

.wallpaper-teaser {
  margin: 0;
  color: color-mix(in oklab, var(--wa-color-neutral-1000) 78%, transparent);
}

.wallpaper-download {
  margin-top: var(--wa-space-xs);
}

.wallpaper-error {
  min-height: 1em;
  margin: 0;
  color: color-mix(in oklab, var(--candelario-accent) 90%, black);
}

.wallpaper-download {
  display: inline-flex;
  width: auto;
}

.wallpaper-download.is-disabled {
  pointer-events: none;
  opacity: 0.6;
}

/* ----------------------
   FAQ
----------------------- */
.faq-section {
  margin-block: var(--wa-space-l);
  padding: var(--wa-space-2xl);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  background: color-mix(
    in oklab,
    var(--wa-color-brand-95) 50%,
    var(--wa-color-surface-default)
  );
  box-shadow: 6px 6px 0
    color-mix(in oklab, var(--wa-color-neutral-20) 35%, transparent);
}

.faq-list {
  display: grid;
  grid-template-columns: repeat(
    auto-fit,
    minmax(min(100%, max(20rem, 33vw)), 1fr)
  );
  gap: var(--wa-space-s);
}

/* ----------------------
   FOOTER
----------------------- */
footer {
  padding-block: var(--wa-space-m);
  border-top: --wa-border-width-m solid currentColor;
  margin-top: auto;
}

.footer-links {
  flex: 1;
  min-width: 260px;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}

.footer-bottom {
  font-size: 0.8rem;
  opacity: 0.8;
}

a {
  text-decoration: none;
  color: inherit;
}

a:hover {
  text-decoration: underline;
}

.wa-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}

/* ----------------------
   COOKIE BANNER
----------------------- */
.cookie-banner {
  position: fixed;
  left: 50%;
  bottom: var(--wa-space-m);
  transform: translate(-50%, 18px);
  width: min(540px, calc(100% - var(--wa-space-xl)));
  padding: var(--wa-space-m);
  background: var(--wa-color-surface-raised);
  color: var(--wa-color-ink-1000);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  border-radius: var(--wa-radius-l);
  box-shadow: 0 18px 54px rgba(0, 0, 0, 0.12);
  z-index: 120;
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
}

.cookie-banner.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.cookie-banner__content {
  display: flex;
  flex-direction: column;
  gap: var(--wa-space-s);
}

.cookie-banner__text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.4;
}

.cookie-banner__text a {
  color: var(--candelario-brand);
  font-weight: 600;
}

.cookie-banner__actions {
  display: flex;
  gap: var(--wa-space-xs);
  flex-wrap: wrap;
}

.cookie-banner__button {
  border: none;
  border-radius: var(--wa-radius-full);
  padding: var(--wa-space-2xs) var(--wa-space-s);
  font-weight: 700;
  cursor: var(--candelario-hand) 6 2, pointer;
  background: var(--candelario-secondary);
  color: var(--candelario-brand);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.08);
}

.cookie-banner__button:hover,
.cookie-banner__button:focus-visible {
  background: #ffffff;
  color: var(--candelario-brand);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.12);
}

.cookie-banner__button.ghost {
  background: transparent;
  color: var(--candelario-brand);
  border: var(--wa-border-width-s) solid
    color-mix(in oklab, var(--candelario-border) 60%, transparent);
  box-shadow: none;
}

.cookie-banner__button.ghost:hover,
.cookie-banner__button.ghost:focus-visible {
  background: color-mix(in oklab, var(--candelario-secondary) 55%, transparent);
  border-color: color-mix(in oklab, var(--candelario-brand) 80%, black);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
}

@media (max-width: 600px) {
  .cookie-banner {
    width: calc(100% - (var(--wa-space-m) * 2));
    padding: var(--wa-space-s);
  }

  .cookie-banner__actions {
    flex-direction: column;
  }

  .cookie-banner__button {
    width: 100%;
    justify-content: center;
  }
}

/* ----------------------
   404 PAGE
----------------------- */
.not-found {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--page-padding);
  background: radial-gradient(
      circle at 12% 18%,
      color-mix(in oklab, var(--candelario-accent) 14%, transparent) 0%,
      transparent 32%
    ),
    radial-gradient(
      circle at 86% 28%,
      color-mix(in oklab, var(--candelario-border) 12%, transparent) 0%,
      transparent 34%
    ),
    var(--candelario-bg);
}

.not-found-card {
  max-width: 760px;
  width: min(760px, 100%);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  border-radius: var(--wa-radius-l);
  background: var(--wa-color-surface-raised);
  box-shadow: 8px 12px 0
    color-mix(in oklab, var(--wa-color-neutral-20) 35%, transparent);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--wa-space-l);
  align-items: center;
}

.not-found-copy h1 {
  margin: 0 0 var(--wa-space-s);
  letter-spacing: -0.02em;
}

.not-found-copy p {
  margin: 0 0 var(--wa-space-m);
}

.not-found-kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--wa-space-2xs);
  padding: var(--wa-space-3xs) var(--wa-space-xs);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  border-radius: var(--wa-radius-m);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  font-size: var(--wa-text-xs);
  background: color-mix(in oklab, var(--wa-color-surface-raised) 85%, white);
}

.not-found-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--wa-space-s);
}

.not-found-ghost {
  display: inline-flex;
  align-items: center;
  gap: var(--wa-space-2xs);
  padding: var(--wa-space-xs) var(--wa-space-m);
  border: var(--wa-border-width-s) solid var(--candelario-brand);
  border-radius: var(--wa-radius-m);
  background: var(--candelario-secondary);
  color: var(--candelario-brand);
  text-decoration: none;
  font-weight: 700;
  box-shadow: 2px 4px 0
    color-mix(in oklab, var(--candelario-brand) 35%, transparent);
  transition: transform 160ms ease, box-shadow 160ms ease,
    border-color 160ms ease, color 160ms ease, background 160ms ease;
}

.not-found-ghost:hover {
  color: #ffffff;
  background: color-mix(in oklab, var(--candelario-brand) 85%, black);
  border-color: color-mix(in oklab, var(--candelario-brand) 90%, black);
  transform: translateY(-1px);
  box-shadow: 2px 4px 0
    color-mix(in oklab, var(--candelario-brand) 45%, transparent);
}

.not-found-ghost wa-icon {
  color: inherit;
  transition: color 160ms ease;
}

.not-found-illustration {
  display: flex;
  justify-content: center;
}

.not-found-illustration img {
  max-width: 100%;
  width: min(420px, 100%);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--wa-radius-m);
  border: var(--wa-border-width-s) solid var(--candelario-border);
  box-shadow: 6px 8px 0
    color-mix(in oklab, var(--wa-color-neutral-20) 35%, transparent);
}

/* ----------------------
   MEDIA QUERIES
----------------------- */

@media (min-width: 1440px) {
  .hero-copy,
  .hero-animated {
    max-width: 600px;
  }
}

@media (min-width: 721px) and (max-width: 1080px) {
  .hero {
    flex-direction: column;
    text-align: center;
    gap: var(--wa-space-xl);
  }

  .hero-copy {
    align-items: center;
    max-width: none;
    width: 100%;
  }

  .hero-animated {
    max-width: none;
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .hero-animated img {
    width: 100%;
  }
}

@media (max-width: 720px) {
  body {
    --page-padding: var(--wa-space-m);
  }

  .page {
    padding: var(--page-padding);
  }

  .hero,
  .detalle-section,
  .faq-section {
    padding: var(--wa-space-m);
  }

  .hero {
    flex-direction: column;
    text-align: center;
    gap: var(--wa-space-l);
  }

  .hero-copy {
    align-items: center;
    max-width: none;
    width: 100%;
  }

  .hero-animated {
    max-width: none;
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .hero-animated img {
    width: 100%;
  }

  .detalle-section {
    grid-template-columns: 1fr;
    gap: var(--wa-space-l);
  }

  .wallpaper-section {
    padding: var(--wa-space-m);
    width: 100%;
    max-width: none;
  }

  .wallpaper-layout {
    flex-direction: column;
    align-items: stretch;
    gap: var(--wa-space-l);
  }

  .wallpaper-preview {
    width: min(260px, 100%);
  }

  wa-button.cta.cta-secondary {
    width: 100%;
  }

  .wallpaper-submit {
    width: 100%;
  }

  .wallpaper-submit::part(base) {
    width: 100%;
    justify-content: center;
  }

  .wallpaper-download {
    width: 100%;
  }

  .wallpaper-input {
    padding: var(--wa-space-3xs) var(--wa-space-2xs);
    min-height: 34px;
  }

  .wallpaper-input::-webkit-calendar-picker-indicator {
    position: static;
    width: 0.9em;
    height: 0.9em;
  }

  .wallpaper-field {
    max-width: 100%;
    margin-inline: 0;
  }

  .wallpaper-selects {
    grid-template-columns: 1fr;
  }

  .wallpaper-result,
  .wallpaper-right,
  .wallpaper-left,
  .wallpaper-meta {
    align-items: center;
    text-align: center;
  }

  .wallpaper-result {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: var(--wa-space-s);
  }

  .wallpaper-preview {
    margin-inline: auto;
  }

  .not-found {
    padding: var(--wa-space-xl) var(--wa-space-m);
    align-items: start;
  }

  .not-found-card {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .not-found-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .not-found-ghost {
    justify-content: center;
    width: 100%;
  }

  .not-found-illustration img {
    width: min(420px, 100%);
  }
}
