:root{
  --color-primary:#2D3A2D;
  --color-secondary:#4A5D4A;
  --color-accent:#9C27B0;
  --color-bg-light:#FAF5FF;
  --color-bg-alt:#F3E8FF;
}

html{scroll-behavior:smooth;scroll-padding-top:5rem}
body{font-family:'DM Sans',system-ui,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%}

/* Images */
img{max-width:100%;height:auto}
::selection{background:rgba(156,39,176,.20)}

/* Animations (context: zoom_in) */
[data-animate]{
  opacity:0;
  transform:scale(.95);
  transition:transform .5s ease-out, opacity .5s ease-out;
  will-change:transform,opacity;
}
[data-animate].is-visible{
  opacity:1;
  transform:scale(1);
}
.rotate-180{transform:rotate(180deg)}

/* Focus rings */
:where(a,button,input,select,textarea,[role="button"]):focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(156,39,176,.25);
  border-radius:.5rem;
}

/* Decorative backgrounds */
.decor-grid-dots{
  background-image:radial-gradient(rgba(156,39,176,.22) 1px, transparent 1px);
  background-size:16px 16px;
}
.decor-grid-lines{
  background-image:
    linear-gradient(to right, rgba(156,39,176,.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(156,39,176,.10) 1px, transparent 1px);
  background-size:28px 28px;
}
.decor-diagonal{
  background-image:repeating-linear-gradient(135deg, rgba(156,39,176,.12), rgba(156,39,176,.12) 1px, transparent 1px, transparent 10px);
}
.decor-mesh{
  background:
    radial-gradient(600px circle at 15% 10%, rgba(156,39,176,.18), transparent 55%),
    radial-gradient(650px circle at 85% 20%, rgba(74,93,74,.18), transparent 55%),
    radial-gradient(700px circle at 40% 90%, rgba(250,245,255,.35), transparent 55%);
}

.decor-gradient-blur::before,
.decor-gradient-blur::after{
  content:"";
  position:absolute;
  width:520px;
  height:520px;
  border-radius:9999px;
  filter:blur(42px);
  opacity:.22;
  pointer-events:none;
}
.decor-gradient-blur::before{
  top:-220px;left:-200px;
  background:radial-gradient(circle at 30% 30%, rgba(156,39,176,.85), transparent 60%);
}
.decor-gradient-blur::after{
  bottom:-240px;right:-220px;
  background:radial-gradient(circle at 30% 30%, rgba(74,93,74,.85), transparent 60%);
}

/* Intensity modifiers */
.decor-subtle{opacity:.06}
.decor-moderate{opacity:.10}
.decor-bold{opacity:.18}

/* Rings SVG helper */
.decor-rings-svg{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='640' height='640' viewBox='0 0 640 640'%3E%3Cg fill='none' stroke='%239C27B0' stroke-opacity='.18'%3E%3Ccircle cx='320' cy='320' r='70'/%3E%3Ccircle cx='320' cy='320' r='140'/%3E%3Ccircle cx='320' cy='320' r='210'/%3E%3Ccircle cx='320' cy='320' r='280'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:center;
  background-size:720px 720px;
}

/* Utility: glass card */
.ui-glass{
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(10px);
  border:1px solid rgba(17,24,39,.10);
}

/* Prevent layout jump for mobile menu */
#mobile-menu{will-change:height}

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