:root{
  --color-primary:#2E2440;
  --color-secondary:#453660;
  --color-accent:#A78BFA;
  --bg-light:#FAF5FF;
  --bg-alt:#F3E8FF;
}

html{scroll-behavior:smooth;scroll-padding-top:5rem}
body{font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}

/* Button fixes */
button,.btn,[class*="btn-"],a[href="#order_form"]{
  white-space:nowrap;
  min-width:fit-content;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
}
form button[type="submit"]{
  white-space:normal;
  width:100%;
}

/* Focus styles */
:focus-visible{
  outline:3px solid rgba(167,139,250,.45);
  outline-offset:2px;
  border-radius:12px;
}

/* Animations */
[data-animate]{
  opacity:0;
  transform:translateY(20px);
  transition:opacity .7s ease-out, transform .7s ease-out;
  will-change:opacity,transform;
}
[data-animate].is-visible{
  opacity:1;
  transform:translateY(0);
}
.rotate-180{transform:rotate(180deg)}

/* Premium helpers */
.glass-card{
  background:rgba(255,255,255,.75);
  border:1px solid rgba(243,232,255,.9);
  backdrop-filter:blur(14px);
}
.text-balance{ text-wrap:balance; }

/* Decorative elements */
.decor-subtle{opacity:.06}
.decor-moderate{opacity:.12}
.decor-bold{opacity:.18}

.decor-grid-dots{
  background-image: radial-gradient(rgba(46,36,64,.22) 1px, transparent 1px);
  background-size: 18px 18px;
  background-position: 0 0;
}
.decor-grid-lines{
  background-image:
    linear-gradient(to right, rgba(46,36,64,.12) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(46,36,64,.12) 1px, transparent 1px);
  background-size: 42px 42px;
}
.decor-diagonal{
  background-image: repeating-linear-gradient(135deg, rgba(167,139,250,.22) 0, rgba(167,139,250,.22) 1px, transparent 1px, transparent 10px);
}
.decor-mesh{
  background:
    radial-gradient(50% 55% at 20% 10%, rgba(167,139,250,.28) 0%, rgba(167,139,250,0) 60%),
    radial-gradient(55% 55% at 80% 20%, rgba(69,54,96,.18) 0%, rgba(69,54,96,0) 60%),
    radial-gradient(60% 70% at 50% 100%, rgba(46,36,64,.14) 0%, rgba(46,36,64,0) 60%);
}

.decor-gradient-blur::before,
.decor-gradient-blur::after{
  content:"";
  position:absolute;
  inset:auto;
  width:380px;
  height:380px;
  border-radius:9999px;
  filter:blur(54px);
  pointer-events:none;
}
.decor-gradient-blur::before{
  top:-140px;
  left:-140px;
  background:rgba(167,139,250,.28);
}
.decor-gradient-blur::after{
  bottom:-160px;
  right:-160px;
  background:rgba(69,54,96,.22);
}

.decor-corner-tr::after{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:140px;
  height:140px;
  background:linear-gradient(135deg, rgba(167,139,250,.25), rgba(167,139,250,0));
  border-bottom-left-radius:48px;
  pointer-events:none;
}
.decor-corner-bl::after{
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  width:160px;
  height:160px;
  background:linear-gradient(315deg, rgba(46,36,64,.22), rgba(46,36,64,0));
  border-top-right-radius:56px;
  pointer-events:none;
}

.decor-glow-element{
  position:absolute;
  width:420px;
  height:420px;
  border-radius:9999px;
  background:radial-gradient(circle at 30% 30%, rgba(167,139,250,.40), rgba(167,139,250,0) 62%);
  filter:blur(22px);
  pointer-events:none;
}

.decor-rings-svg{
  background-image:
    radial-gradient(circle at center, rgba(167,139,250,.22) 0 1px, transparent 1px),
    radial-gradient(circle at center, rgba(46,36,64,.12) 0 1px, transparent 1px);
  background-size: 72px 72px, 120px 120px;
  background-position:center;
}

/* Slider niceties */
.slider-track{
  display:flex;
  gap:1rem;
  overflow:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding-bottom:.25rem;
}
.slider-track > *{
  scroll-snap-align:start;
}
.slider-track::-webkit-scrollbar{height:10px}
.slider-track::-webkit-scrollbar-thumb{
  background:rgba(17,24,39,.12);
  border-radius:9999px;
}
.slider-track::-webkit-scrollbar-track{
  background:transparent;
}

/* Forms */
.input-premium{
  background:#fff;
  border:1px solid rgba(229,231,235,1);
  border-radius:16px;
  padding:.85rem 1rem;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.input-premium:focus{
  border-color:rgba(167,139,250,.75);
  box-shadow:0 0 0 4px rgba(167,139,250,.18);
  outline:none;
}
.form-error{
  color:#b91c1c;
  font-size:.875rem;
  margin-top:.35rem;
}
.form-success{
  color:#065f46;
  font-size:.875rem;
  margin-top:.35rem;
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  [data-animate]{transition:none}
}