:root{
  --color-primary:#3D2914;
  --color-secondary:#5C4020;
  --color-accent:#FF8C00;
  --color-bg-light:#FFFBF0;
  --color-bg-alt:#FEF0C7;
}

html{scroll-behavior:smooth;scroll-padding-top:5rem}
body{font-family:'Source Sans 3',system-ui,sans-serif}
img{max-width:100%;height:auto}

::selection{background:rgba(255,140,0,.25)}

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%
}

a{outline-offset:4px}
:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}

/* Scroll animations (context: slide_left) */
[data-animate]{
  opacity:0;
  transform:translateX(2rem);
  transition:opacity .6s ease-out,transform .6s ease-out
}
[data-animate].is-visible{
  opacity:1;
  transform:translateX(0)
}

.rotate-180{transform:rotate(180deg)}

/* Subtle premium utilities */
.glass{
  background:rgba(255,255,255,.7);
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
  border:1px solid rgba(17,24,39,.08)
}

.text-balance{text-wrap:balance}

/* Decorative backgrounds */
.decor-grid-dots{
  background-image:radial-gradient(rgba(17,24,39,.18) 1px, transparent 1px);
  background-size:16px 16px
}
.decor-grid-lines{
  background-image:
    linear-gradient(to right, rgba(17,24,39,.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(17,24,39,.10) 1px, transparent 1px);
  background-size:40px 40px
}
.decor-diagonal{
  background-image:repeating-linear-gradient(135deg, rgba(17,24,39,.10) 0, rgba(17,24,39,.10) 1px, transparent 1px, transparent 12px)
}
.decor-mesh{
  background:
    radial-gradient(800px 400px at 10% 10%, rgba(255,140,0,.18), transparent 60%),
    radial-gradient(600px 300px at 90% 20%, rgba(92,64,32,.18), transparent 60%),
    radial-gradient(700px 350px at 40% 110%, rgba(61,41,20,.14), transparent 55%)
}
.decor-gradient-blur::before,
.decor-gradient-blur::after{
  content:"";
  position:absolute;
  inset:auto;
  width:420px;
  height:420px;
  border-radius:9999px;
  filter:blur(40px);
  opacity:.35;
  pointer-events:none
}
.decor-gradient-blur::before{
  top:-140px;
  left:-160px;
  background:radial-gradient(circle at 30% 30%, rgba(255,140,0,.7), transparent 60%)
}
.decor-gradient-blur::after{
  bottom:-160px;
  right:-170px;
  background:radial-gradient(circle at 50% 50%, rgba(92,64,32,.65), transparent 62%)
}
.decor-corner-tr::before{
  content:"";
  position:absolute;
  top:0;right:0;
  width:180px;height:180px;
  background:radial-gradient(circle at 100% 0%, rgba(255,140,0,.25), transparent 70%);
  pointer-events:none
}
.decor-corner-bl::before{
  content:"";
  position:absolute;
  bottom:0;left:0;
  width:180px;height:180px;
  background:radial-gradient(circle at 0% 100%, rgba(92,64,32,.22), transparent 70%);
  pointer-events:none
}
.decor-glow-element::before{
  content:"";
  position:absolute;
  inset:0;
  margin:auto;
  width:520px;
  height:520px;
  border-radius:9999px;
  background:radial-gradient(circle, rgba(255,140,0,.22), transparent 60%);
  filter:blur(34px);
  pointer-events:none
}
.decor-rings-svg{
  background-image:
    radial-gradient(circle at center, transparent 0 64%, rgba(17,24,39,.10) 65% 66%, transparent 67% 74%, rgba(17,24,39,.08) 75% 76%, transparent 77%);
  background-size:520px 520px;
  background-repeat:no-repeat;
  background-position:center
}

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

/* Hide number input arrows (if used) */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button{
  -webkit-appearance:none;
  margin:0
}
input[type="number"]{appearance:textfield}

/* Toast (used by JS validation) */
#toast{
  position:fixed;
  left:50%;
  bottom:20px;
  transform:translateX(-50%);
  z-index:120;
  max-width:min(560px,calc(100% - 2rem));
  display:none
}
#toast.is-open{display:block}
#toast .toast-inner{
  background:rgba(17,24,39,.96);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:1rem;
  padding:.9rem 1rem;
  box-shadow:0 20px 50px rgba(0,0,0,.25)
}