:root{
  --bg:#fbf7f2;
  --bg-2:#f4ead9;
  --surface:#ffffff;
  --ink:#2b1d18;
  --ink-2:#5b4a42;
  --muted:#8a7a72;
  --line:#e9dcc9;
  --accent:#b1543a;
  --accent-2:#8a3f2b;
  --cream:#fff4e3;
  --rose:#f5d6cb;
  --pistachio:#c9d8b6;
  --gold:#c9a24a;
  --shadow:0 18px 60px rgba(80,40,20,.10);
  --shadow-sm:0 6px 20px rgba(80,40,20,.08);
  --radius:18px;
  --radius-sm:10px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  margin:0;max-width:100%;overflow-x:hidden;padding-top:68px;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--accent-2);text-decoration:none}

/* Fancy link hover — sliding glaze underline */
.prose a,.callout a,footer a,.breadcrumbs a,.faq-body a,.faq p a,.form-card a,.check a,.info-card a,.legal a{
  background-image:linear-gradient(120deg,var(--accent),var(--gold),var(--accent-2));
  background-repeat:no-repeat;
  background-position:0 100%;
  background-size:0% 2px;
  padding-bottom:2px;
  transition:background-size .4s cubic-bezier(.2,.7,.2,1),color .2s ease;
}
.prose a:hover,.callout a:hover,footer a:hover,.breadcrumbs a:hover,.faq-body a:hover,.faq p a:hover,.form-card a:hover,.check a:hover,.info-card a:hover,.legal a:hover{
  background-size:100% 2px;
  text-decoration:none;
}
h1,h2,h3{font-weight:700;letter-spacing:-.01em;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.15}
h2{font-size:clamp(1.5rem,2.6vw,2rem);line-height:1.2;margin-top:0}
h3{font-size:1.15rem}
p{margin:0 0 1em;color:var(--ink-2)}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.skip-link{position:absolute;left:-9999px;top:-9999px}
.skip-link:focus{left:12px;top:12px;background:var(--ink);color:#fff;padding:8px 14px;border-radius:8px;z-index:9999}
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}

/* Header */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(251,247,242,.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(233,220,201,.7);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset,0 6px 24px rgba(80,40,20,.04);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:16px}
.brand{display:inline-flex;align-items:center;font-weight:800;color:var(--ink);text-decoration:none;font-size:1.12rem;letter-spacing:.2px;flex:0 0 auto;line-height:1;white-space:nowrap}
.brand:hover{text-decoration:none}
.brand-mark{
  display:inline-block;vertical-align:middle;
  width:44px;height:44px;
  padding:0;border:0;border-radius:0;
  background:transparent;box-shadow:none;
  position:relative;line-height:0;margin-right:12px;
  transition:transform .4s cubic-bezier(.2,.7,.3,1.4);
}
.brand-mark svg{display:block;width:44px;height:44px;filter:drop-shadow(0 4px 12px rgba(177,84,58,.22));transition:filter .35s ease}
.brand-text{display:inline-block;vertical-align:middle;line-height:1}
.brand:hover .brand-mark{transform:rotate(-8deg) scale(1.08)}
.brand:hover .brand-mark svg{filter:drop-shadow(0 8px 22px rgba(177,84,58,.4))}
.brand-mark .pa-flame{transform-origin:24px 3px;animation:paFlame 1.6s ease-in-out infinite}
@keyframes paFlame{0%,100%{transform:scale(1) rotate(-3deg)}50%{transform:scale(1.15) rotate(3deg)}}
.nav ul{
  display:flex;gap:4px;list-style:none;margin:0;padding:6px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(233,220,201,.7);
  border-radius:100px;
  box-shadow:0 1px 0 rgba(255,255,255,.9) inset, var(--shadow-sm);
}
.nav a{
  color:var(--ink-2);font-weight:600;font-size:.92rem;
  padding:9px 16px;border-radius:100px;
  transition:color .18s ease,background .18s ease;
  display:inline-block;white-space:nowrap;
}
.nav a:hover{color:var(--ink);background:rgba(255,244,227,.8);text-decoration:none}
.nav a.is-active{color:#fff;background:var(--accent);box-shadow:0 6px 16px rgba(177,84,58,.28)}
.nav a.is-active:hover{background:var(--accent-2);color:#fff}
.nav-toggle{
  display:none;background:var(--surface);border:1px solid var(--line);
  width:44px;height:44px;border-radius:10px;padding:0;cursor:pointer;
  position:relative;margin-left:auto;flex:0 0 auto;
}
.nav-toggle .nav-toggle-label{
  font-size:0;line-height:0;position:absolute;left:50%;top:50%;
  width:22px;height:2px;background:var(--ink);
  transform:translate(-50%,-50%);transition:opacity .2s ease;
}
.nav-toggle::before,.nav-toggle::after{
  content:"";position:absolute;left:50%;width:22px;height:2px;background:var(--ink);
  transform:translateX(-50%);transition:top .2s ease,transform .2s ease;
}
.nav-toggle::before{top:13px}
.nav-toggle::after{top:29px}
.nav-toggle[aria-expanded="true"] .nav-toggle-label{opacity:0}
.nav-toggle[aria-expanded="true"]::before{top:50%;transform:translate(-50%,-50%) rotate(45deg)}
.nav-toggle[aria-expanded="true"]::after{top:50%;transform:translate(-50%,-50%) rotate(-45deg)}
@media (max-width:480px){
  .brand{font-size:.92rem;gap:8px}
  .site-header .container.nav{padding-left:14px;padding-right:14px;gap:8px}
}
@media (max-width:980px){
  .site-header .container.nav{padding-left:18px;padding-right:18px;gap:10px}
  .brand{padding-left:0;font-size:1rem;gap:10px;min-width:0;flex:0 1 auto;max-width:calc(100% - 60px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .nav{padding:10px 0}
  .nav-toggle{display:block}
  .nav ul{
    position:fixed;left:16px;right:16px;top:72px;
    background:var(--surface);border:1px solid var(--line);
    flex-direction:column;padding:14px;gap:4px;
    border-radius:18px;box-shadow:var(--shadow);
    display:flex;
    opacity:0;pointer-events:none;
    transform:translateY(-8px) scale(.97);transform-origin:top right;
    transition:opacity .22s ease-out,transform .22s ease-out;
    transition-delay:0s;
  }
  .nav ul.open{
    opacity:1;pointer-events:auto;transform:none;
    transition:opacity .22s ease-out,transform .22s ease-out;
    transition-delay:0s;
  }
  .nav a{
    display:block;padding:13px 16px;font-size:1rem;border-radius:12px;
    border-bottom:1px solid transparent;
  }
  .nav a:hover{background:var(--bg-2)}
  .nav a.is-active{background:var(--accent);color:#fff}
}

/* Hero */
.hero{position:relative;overflow:hidden;padding:70px 0 80px;background:
  radial-gradient(1200px 500px at 80% -10%,var(--rose) 0%,transparent 60%),
  radial-gradient(900px 400px at -10% 10%,var(--pistachio) 0%,transparent 60%),
  linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;position:relative;z-index:2}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr;gap:28px}}
.eyebrow{display:inline-block;background:var(--surface);border:1px solid var(--line);padding:6px 12px;border-radius:100px;font-size:.82rem;color:var(--ink-2);margin-bottom:16px;letter-spacing:.3px;text-transform:uppercase}
.hero p.lead{font-size:1.08rem;max-width:56ch;color:var(--ink-2)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--accent);color:#fff;padding:14px 22px;border-radius:12px;
  font-weight:700;border:none;cursor:pointer;transition:transform .15s ease,background .2s ease,box-shadow .2s ease;
  box-shadow:var(--shadow-sm);
}
.btn:hover{background:var(--accent-2);color:#fff;text-decoration:none;transform:translateY(-1px)}
.btn.secondary{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.secondary:hover{background:var(--surface)}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.hero-meta{display:flex;gap:22px;margin-top:26px;flex-wrap:wrap;color:var(--muted);font-size:.92rem}
.hero-meta span{display:inline-flex;align-items:center;gap:8px}
.hero-meta .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* Vitrin card illustration */
.vitrin{
  position:relative;height:420px;border-radius:24px;
  background:
    linear-gradient(160deg,rgba(255,255,255,.8),rgba(255,255,255,.25)),
    linear-gradient(180deg,var(--cream),var(--rose));
  border:1px solid rgba(255,255,255,.6);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.8);
  overflow:hidden;
}
.vitrin::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(300px 160px at 20% 20%,rgba(255,255,255,.6),transparent 60%),
    radial-gradient(220px 120px at 80% 30%,rgba(255,255,255,.45),transparent 60%);
  pointer-events:none;
}
.cake{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);width:260px;height:260px}
.cake .tier{
  position:absolute;left:50%;transform:translateX(-50%);
  border-radius:50% 50% 10px 10px/60% 60% 10px 10px;
  box-shadow:inset 0 -10px 18px rgba(140,80,60,.18), 0 10px 22px rgba(140,80,60,.12);
}
.cake .t1{width:240px;height:110px;bottom:0;background:linear-gradient(180deg,#fff 0%,#fff0de 100%)}
.cake .t2{width:170px;height:90px;bottom:100px;background:linear-gradient(180deg,#ffe1d4 0%,#f4a58d 100%)}
.cake .t3{width:110px;height:70px;bottom:178px;background:linear-gradient(180deg,#fff 0%,#f6e3c2 100%)}
.cake .candle{position:absolute;left:50%;bottom:240px;transform:translateX(-50%);width:6px;height:24px;background:var(--accent);border-radius:2px}
.cake .flame{position:absolute;left:50%;bottom:262px;transform:translateX(-50%);width:8px;height:12px;background:radial-gradient(circle at 50% 70%,var(--gold),#ff8b3d);border-radius:50% 50% 50% 50%/60% 60% 40% 40%;animation:flicker 1.6s ease-in-out infinite}
@keyframes flicker{0%,100%{transform:translateX(-50%) scale(1)}50%{transform:translateX(-50%) scale(1.08)}}
@media (prefers-reduced-motion:reduce){.cake .flame{animation:none}}
.vitrin .shine{
  position:absolute;top:-20%;left:-10%;width:60%;height:140%;
  background:linear-gradient(110deg,transparent 40%,rgba(255,255,255,.55) 50%,transparent 60%);
  transform:skewX(-15deg);
  pointer-events:none;
}

/* Sections */
section{padding:72px 0;border-top:1px solid var(--line)}
.section-head{max-width:60ch;margin-bottom:36px}
.grid{display:grid;gap:22px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:860px){.grid.cols-3,.grid.cols-4,.grid.cols-2{grid-template-columns:1fr}}
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px;
  box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .25s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card h3{margin-top:6px}
.card .tag{display:inline-block;background:var(--bg-2);color:var(--ink-2);padding:4px 10px;border-radius:100px;font-size:.78rem;text-transform:uppercase;letter-spacing:.4px}

/* Process steps */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(5,1fr);gap:18px;list-style:none;padding:0;margin:0}
@media (max-width:960px){.steps{grid-template-columns:repeat(2,1fr)}}
.step{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:relative}
.step::before{
  counter-increment:step;content:counter(step);
  position:absolute;top:-16px;left:22px;width:32px;height:32px;border-radius:50%;
  background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.92rem;box-shadow:var(--shadow-sm);
}
.step h3{margin-top:10px;font-size:1rem}
.step p{font-size:.92rem;margin:0}

/* Price calculator */
.calc{
  background:linear-gradient(180deg,var(--surface),#fffaf1);
  border:1px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm);
}
.calc-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:30px;align-items:center}
@media (max-width:860px){.calc-grid{grid-template-columns:1fr}}
.calc label{display:block;font-weight:700;margin-bottom:8px;color:var(--ink)}
.calc .row{margin-bottom:22px}
.calc input[type=range]{width:100%}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg button{
  background:var(--surface);border:1px solid var(--line);padding:10px 14px;border-radius:10px;cursor:pointer;font-weight:600;color:var(--ink-2);
}
.seg button[aria-pressed=true]{background:var(--accent);color:#fff;border-color:var(--accent)}
.calc-out{
  background:var(--ink);color:#fff;border-radius:var(--radius);padding:24px;text-align:center;
}
.calc-out .range{font-size:1.7rem;font-weight:800;display:block;margin:6px 0}
.calc-out small{opacity:.75;display:block;margin-top:6px;font-size:.82rem}

/* Price table */
.prices{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:960px){.prices{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.prices{grid-template-columns:1fr}}
.price{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center;
}
.price .p{font-size:1.35rem;font-weight:800;color:var(--accent-2);margin-top:6px}
.price small{color:var(--muted)}

/* FAQ accordion */
.faq{display:grid;gap:10px;max-width:820px}
.faq details{
  background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:16px 20px;
  transition:box-shadow .25s ease;
}
.faq details[open]{box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:1.4rem;color:var(--accent);line-height:1;
  transition:transform .25s ease;display:inline-block;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details>summary~*{overflow:hidden;will-change:height}
.faq p{margin:10px 0 0}

/* Footer */
footer{background:var(--ink);color:#e9dcc9;padding:56px 0 24px;margin-top:40px}
footer h4{color:#fff;margin:0 0 14px;font-size:1rem}
footer a{color:#e9dcc9}
footer a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:30px}
@media (max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}.foot-grid>div:first-child{grid-column:1/-1}}
.foot-links{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:.94rem}
.legal{border-top:1px solid rgba(255,255,255,.12);margin-top:32px;padding-top:18px;font-size:.86rem;color:#c9b8a8;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* Forms */
form.contact{display:grid;gap:16px;max-width:640px}
form.contact label{font-weight:700;color:var(--ink);display:block;margin-bottom:6px}
form.contact input,form.contact textarea{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;
  background:var(--surface);font:inherit;color:var(--ink);
}
form.contact textarea{min-height:140px;resize:vertical}
form.contact input:focus,form.contact textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px rgba(177,84,58,.15)}
.hp{position:absolute;left:-9999px;top:-9999px}
.form-msg{padding:14px;border-radius:10px;font-weight:600;display:none}
.form-msg.ok{display:block;background:#e9f5e1;color:#2b5e1e;border:1px solid #c6e4b1}
.form-msg.err{display:block;background:#fbe3df;color:#7a2819;border:1px solid #f4bcb2}
.check{display:flex;align-items:center;gap:10px;font-size:.92rem;color:var(--ink-2);line-height:1.4}
.check input{width:auto;margin:0;flex:0 0 auto}
.check span{flex:1 1 auto}

/* Cookie banner */
.cookie{
  position:fixed;left:20px;right:20px;bottom:20px;max-width:720px;margin:0 auto;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px;display:none;z-index:100;
}
.cookie.show{display:block}
.cookie h3{margin:0 0 8px;font-size:1rem}
.cookie p{margin:0 0 14px;font-size:.92rem}
.cookie .actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie button{
  background:var(--surface);border:1px solid var(--line);padding:10px 16px;border-radius:10px;cursor:pointer;font-weight:700;color:var(--ink);
}
.cookie button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.cookie-settings{display:none;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.cookie-settings.show{display:block}
.cookie-settings label{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:.92rem;color:var(--ink-2)}

/* Prose for text pages */
.prose{max-width:780px}
.prose h2{margin-top:36px}
.prose h3{margin-top:24px}
.prose ul{padding-left:20px;color:var(--ink-2)}
.prose li{margin-bottom:6px}
.callout{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin:20px 0}
.callout strong{color:var(--ink)}

/* Page header */
.page-head{background:linear-gradient(180deg,var(--bg-2),var(--bg));padding:60px 0 40px;border-bottom:1px solid var(--line)}
.breadcrumbs{font-size:.86rem;color:var(--muted);margin-bottom:10px}
.breadcrumbs a{color:var(--muted)}

/* 404 */
.err{text-align:center;padding:90px 0}
.err h1{font-size:4rem;color:var(--accent-2);margin-bottom:6px}

/* Image layouts */
.media-row{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;margin:30px 0}
.media-row.reverse{grid-template-columns:.9fr 1.1fr}
.media-row.reverse .media-img{order:-1}
@media (max-width:760px){.media-row,.media-row.reverse{grid-template-columns:1fr}.media-row.reverse .media-img{order:0}}
.media-img{
  width:100%;max-width:480px;aspect-ratio:4/3;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.media-img img{width:100%;height:100%;object-fit:cover;display:block}
.card .card-img{
  width:100%;aspect-ratio:16/10;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:14px;background:var(--bg-2);border:1px solid var(--line);
}
.card .card-img img{width:100%;height:100%;object-fit:cover;display:block}

/* Standalone form block */
.form-section{padding:72px 0;border-top:1px solid var(--line);background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.form-card{
  max-width:720px;margin:0 auto;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:36px;box-shadow:var(--shadow);
}
.form-card h2{margin-bottom:6px}
.form-card .lead{color:var(--ink-2);margin-bottom:22px}
.form-card form.contact{max-width:none}

/* ========= Thematic reveal & load-in ========= */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .85s cubic-bezier(.2,.7,.2,1),transform .85s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal-left{transform:translateX(-28px)}
.reveal-right{transform:translateX(28px)}
.reveal-left.in,.reveal-right.in{transform:none}
.reveal-scale{transform:scale(.92)}
.reveal-scale.in{transform:scale(1)}

/* Hero text staggered rise on load */
.hero .eyebrow{animation:riseFade .8s .05s both cubic-bezier(.2,.7,.2,1)}
.hero h1{animation:riseFade 1s .15s both cubic-bezier(.2,.7,.2,1)}
.hero p.lead{animation:riseFade 1s .3s both cubic-bezier(.2,.7,.2,1)}
.hero-ctas{animation:riseFade 1s .45s both cubic-bezier(.2,.7,.2,1)}
.hero-meta{animation:riseFade 1s .6s both cubic-bezier(.2,.7,.2,1)}
@keyframes riseFade{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

/* Vitrin glass entrance */
.vitrin{animation:vitrinIn 1.1s .2s both cubic-bezier(.2,.7,.2,1)}
@keyframes vitrinIn{
  from{opacity:0;transform:translateY(30px) scale(.96);filter:blur(6px)}
  to{opacity:1;transform:none;filter:none}
}

/* Cake tiers stack into place (like a baker assembling it) */
.cake .t1{animation:tierIn 1s .55s both cubic-bezier(.2,.8,.3,1.15)}
.cake .t2{animation:tierIn 1s .8s both cubic-bezier(.2,.8,.3,1.15)}
.cake .t3{animation:tierIn 1s 1.05s both cubic-bezier(.2,.8,.3,1.15)}
.cake .candle{animation:candleIn .55s 1.3s both}
.cake .flame{animation:flameIn .5s 1.7s both, flicker 1.6s 2.2s ease-in-out infinite}
@keyframes tierIn{
  0%{opacity:0;transform:translateX(-50%) translateY(-90px) scaleY(.5);filter:blur(4px)}
  60%{opacity:1;filter:none}
  100%{opacity:1;transform:translateX(-50%) translateY(0) scaleY(1)}
}
@keyframes candleIn{
  from{opacity:0;transform:translateX(-50%) scaleY(0);transform-origin:bottom}
  to{opacity:1;transform:translateX(-50%) scaleY(1)}
}
@keyframes flameIn{
  from{opacity:0;transform:translateX(-50%) scale(0)}
  to{opacity:1;transform:translateX(-50%) scale(1)}
}

/* Vitrin shine sweep — glass reflection */
.vitrin .shine{animation:shineSweep 7s 2.4s ease-in-out infinite}
@keyframes shineSweep{
  0%,12%{left:-40%;opacity:0}
  18%{opacity:1}
  46%,54%{left:120%;opacity:1}
  60%{opacity:0}
  100%{left:120%;opacity:0}
}

/* Sprinkles floating in hero (confectionery accents) */
.sprinkles{position:absolute;inset:0;pointer-events:none;z-index:1}
.sprinkles span{
  position:absolute;left:var(--x);top:var(--y);width:12px;height:12px;
  animation:floatBob 5.5s var(--d,0s) ease-in-out infinite, sprinkleFade .8s calc(var(--d,0s) + .4s) both;
}
.sprinkles span::before{
  content:"";display:block;width:12px;height:4px;border-radius:4px;
  background:var(--c);transform:rotate(var(--r,40deg));
  box-shadow:0 2px 4px rgba(80,40,20,.12);
}
@keyframes floatBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes sprinkleFade{from{opacity:0}to{opacity:.92}}

/* Button glaze sweep on hover */
.btn{position:relative;overflow:hidden;isolation:isolate}
.btn::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-130%);transition:transform .7s cubic-bezier(.2,.7,.2,1);
}
.btn:hover::after{transform:translateX(130%)}

/* Card glaze sweep on hover (vitrin light passing over) */
.card{position:relative;overflow:hidden}
.card::after{
  content:"";position:absolute;top:-50%;left:-70%;width:60%;height:200%;
  background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);
  transform:skewX(-18deg);transition:left .9s cubic-bezier(.2,.7,.2,1);
  pointer-events:none;z-index:1;
}
.card:hover::after{left:130%}
.card>*{position:relative;z-index:2}

/* Price cards: pulse accent on reveal */
.price{transition:transform .35s ease,box-shadow .35s ease,border-color .35s ease}
.price:hover{transform:translateY(-4px);border-color:var(--rose);box-shadow:var(--shadow)}
.price .p{background:linear-gradient(120deg,var(--accent-2),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}

/* Steps: piping connector line */
.steps{position:relative}
.steps::before{
  content:"";position:absolute;top:0;left:6%;right:6%;height:2px;
  background:repeating-linear-gradient(90deg,var(--accent) 0 6px,transparent 6px 14px);
  opacity:0;transform:scaleX(.2);transform-origin:left center;
  transition:opacity .8s ease .3s,transform 1.2s cubic-bezier(.2,.7,.2,1) .3s;
}
.steps.in::before{opacity:.55;transform:scaleX(1)}
@media (max-width:960px){.steps::before{display:none}}

/* Step counter pop */
.step::before{transition:transform .4s cubic-bezier(.2,.7,.3,1.4)}
.step:hover::before{transform:scale(1.12) rotate(-4deg)}

/* Section head underline drawn like frosting */
.section-head h2{display:inline-block;position:relative;padding-bottom:10px}
.section-head h2::after{
  content:"";position:absolute;left:0;bottom:0;width:60px;height:4px;border-radius:4px;
  background:linear-gradient(90deg,var(--accent),var(--rose));
  transform:scaleX(0);transform-origin:left center;
  transition:transform .9s cubic-bezier(.2,.7,.2,1) .2s;
}
.reveal.in .section-head h2::after,.section-head.in h2::after,section.in .section-head h2::after{transform:scaleX(1)}
.section-head:not(.reveal) h2::after{transform:scaleX(1)}

/* Hero-meta dots pulse */
.hero-meta .dot{animation:dotPulse 2.4s ease-in-out infinite}
.hero-meta span:nth-child(2) .dot{animation-delay:.6s}
.hero-meta span:nth-child(3) .dot{animation-delay:1.2s}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 rgba(177,84,58,.45)}50%{box-shadow:0 0 0 7px rgba(177,84,58,0)}}

/* Calc output counter shimmer */
.calc-out{position:relative;overflow:hidden}
.calc-out::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(255,244,227,.18),transparent 60%);
  pointer-events:none;
}
.calc-out .range{transition:transform .3s ease}
.calc-out .range.pulse{animation:rangePulse .5s ease}
@keyframes rangePulse{0%{transform:scale(1)}40%{transform:scale(1.07)}100%{transform:scale(1)}}

/* FAQ summary smooth rotation already handled; add hover tint */
.faq details:hover{border-color:var(--rose)}
.faq details[open]{border-color:var(--rose)}

/* Footer subtle top frosting ribbon */
footer{position:relative}
footer::before{
  content:"";position:absolute;left:0;right:0;top:0;height:6px;
  background:repeating-linear-gradient(90deg,var(--rose) 0 14px,var(--cream) 14px 28px,var(--pistachio) 28px 42px,var(--gold) 42px 56px);
  opacity:.55;
}

/* ========= Scroll progress bar (top) ========= */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:60;
  background:linear-gradient(90deg,var(--accent),var(--gold),var(--accent));
  background-size:200% 100%;
  box-shadow:0 2px 10px rgba(177,84,58,.35);
  animation:progressShimmer 3s linear infinite;
  transition:width .08s linear;
}
@keyframes progressShimmer{to{background-position:200% 0}}

/* ========= Title shimmer gradient ========= */
.title-glow{
  background:linear-gradient(110deg,var(--ink) 30%,var(--accent) 50%,var(--ink) 70%);
  background-size:250% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:titleShimmer 6s ease-in-out infinite;
}
@keyframes titleShimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* ========= Wave divider (SVG frosting drip) ========= */
.wave-divider{position:absolute;left:0;right:0;bottom:-1px;width:100%;height:70px;display:block;pointer-events:none}
.wave-divider path{fill:var(--bg)}

/* ========= Contact page hero ========= */
.contact-hero{
  position:relative;padding:100px 0 130px;overflow:hidden;margin-bottom:-60px;
  background:
    radial-gradient(900px 460px at 85% 5%,var(--rose),transparent 60%),
    radial-gradient(700px 380px at 12% 80%,var(--pistachio),transparent 60%),
    radial-gradient(500px 260px at 50% 50%,var(--cream),transparent 70%),
    linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%);
  border-bottom:0;
}
.contact-hero .container{position:relative;z-index:2;max-width:820px;text-align:center}
.contact-hero .breadcrumbs{justify-content:center;display:flex;gap:6px;margin-bottom:14px}
.contact-hero h1{
  font-size:clamp(2rem,4.2vw,3.3rem);line-height:1.1;margin-bottom:16px;
}
.contact-hero .lead{font-size:1.1rem;color:var(--ink-2);max-width:60ch;margin:0 auto}
.contact-hero .sprinkles span{animation-duration:6s}

/* Decorative floating shapes in contact hero */
.float-shape{position:absolute;pointer-events:none;opacity:.8;animation:floatY 6s ease-in-out infinite}
.float-shape.s1{top:18%;left:7%;width:60px;height:60px;animation-delay:0s}
.float-shape.s2{top:60%;left:85%;width:80px;height:80px;animation-delay:1s}
.float-shape.s3{top:72%;left:9%;width:50px;height:50px;animation-delay:2s}
.float-shape.s4{top:12%;left:80%;width:54px;height:54px;animation-delay:1.5s}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-18px) rotate(6deg)}}

/* ========= Info cards (contact) ========= */
.info-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media (max-width:980px){.info-cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.info-cards{grid-template-columns:1fr}}
.info-card{
  background:var(--surface);border:1px solid var(--line);border-radius:20px;
  padding:28px 22px;text-align:center;transition:transform .35s cubic-bezier(.2,.7,.3,1.1),box-shadow .35s ease,border-color .35s ease;
  position:relative;overflow:hidden;
}
.info-card::before{
  content:"";position:absolute;top:-40%;left:-40%;width:100%;height:100%;
  background:radial-gradient(circle,var(--rose),transparent 65%);
  opacity:0;transition:opacity .4s ease;pointer-events:none;
}
.info-card:hover{transform:translateY(-8px);border-color:var(--rose);box-shadow:0 22px 50px rgba(80,40,20,.12)}
.info-card:hover::before{opacity:.45}
.info-icon{
  width:60px;height:60px;margin:0 auto 16px;border-radius:50%;
  background:linear-gradient(135deg,var(--cream),var(--rose));
  display:flex;align-items:center;justify-content:center;
  box-shadow:inset 0 -5px 10px rgba(180,120,80,.18), 0 8px 18px rgba(177,84,58,.14);
  transition:transform .5s cubic-bezier(.2,.7,.3,1.4);
  position:relative;z-index:1;
}
.info-card:hover .info-icon{transform:rotate(-10deg) scale(1.1)}
.info-icon svg{width:28px;height:28px;color:var(--accent-2);stroke:var(--accent-2);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.info-card h3{font-size:.78rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:0 0 8px;position:relative;z-index:1}
.info-card p{margin:0;color:var(--ink);font-weight:600;word-break:break-word;position:relative;z-index:1;font-size:.96rem}

/* ========= Mini timeline (contact process) ========= */
.mini-timeline{
  list-style:none;padding:0;margin:0;display:grid;
  grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:t;
}
@media (max-width:860px){.mini-timeline{grid-template-columns:repeat(2,1fr)}}
.mini-timeline li{
  background:var(--surface);border:1px solid var(--line);border-radius:16px;
  padding:34px 22px 22px;position:relative;
  transition:transform .35s ease,box-shadow .35s ease;
}
.mini-timeline li::before{
  counter-increment:t;content:"0" counter(t);
  position:absolute;top:-16px;left:22px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  padding:6px 12px;border-radius:10px;font-weight:800;font-size:.78rem;letter-spacing:.8px;
  box-shadow:0 8px 18px rgba(177,84,58,.32);
}
.mini-timeline li h3{font-size:1rem;margin:4px 0 8px;color:var(--ink)}
.mini-timeline li p{margin:0;font-size:.9rem;color:var(--ink-2)}
.mini-timeline li:hover{transform:translateY(-6px);box-shadow:var(--shadow)}

/* ========= Advanced form card ========= */
.form-card.advanced{
  max-width:760px;margin:0 auto;position:relative;z-index:3;
  background:linear-gradient(180deg,#fff,#fffaf1);
  border:1px solid var(--line);border-radius:24px;
  padding:44px 40px;box-shadow:0 30px 80px rgba(80,40,20,.14);
}
.form-card.advanced::before{
  content:"";position:absolute;inset:-2px;border-radius:26px;z-index:-1;
  background:linear-gradient(135deg,var(--rose),var(--cream),var(--pistachio),var(--rose));
  background-size:300% 300%;opacity:0;
  animation:borderGlow 8s ease-in-out infinite;
  transition:opacity .4s ease;
}
.form-card.advanced:focus-within::before{opacity:.7}
@keyframes borderGlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.form-card-head{margin-bottom:30px;text-align:center}
.form-card-head h2{margin-bottom:8px}
.form-card-head p{color:var(--ink-2);margin:0}
@media (max-width:560px){.form-card.advanced{padding:32px 22px}}

/* Floating labels */
.field{position:relative;margin-bottom:22px}
.field input,.field textarea{
  width:100%;padding:16px 16px 14px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--surface);font:inherit;color:var(--ink);
  transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
.field textarea{min-height:150px;resize:vertical}
.field input:focus,.field textarea:focus{
  border-color:var(--accent);outline:none;background:#fff;
  box-shadow:0 0 0 4px rgba(177,84,58,.12);
}
.field label{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--muted);font-weight:500;font-size:1rem;
  pointer-events:none;transition:top .22s cubic-bezier(.2,.7,.2,1),transform .22s cubic-bezier(.2,.7,.2,1),font-size .22s ease,color .22s ease;
  background:transparent;padding:0 6px;
}
.field textarea ~ label{top:22px;transform:none}
.field input:focus+label,
.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,
.field textarea:not(:placeholder-shown)+label{
  top:0;left:12px;transform:translateY(-50%);
  font-size:.72rem;color:var(--accent);font-weight:700;
  background:#fff;
}
.field .field-hint{display:block;margin-top:6px;font-size:.8rem;color:var(--muted)}
.field .char-counter{position:absolute;right:14px;bottom:10px;font-size:.74rem;color:var(--muted);pointer-events:none}
.field .char-counter.warn{color:var(--accent-2)}

/* Form row 2 cols */
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:560px){.form-row-2{grid-template-columns:1fr}}

/* Submit with shine */
.form-card.advanced .btn[type=submit]{
  width:100%;justify-content:center;padding:16px 22px;font-size:1.02rem;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  box-shadow:0 14px 30px rgba(177,84,58,.35);
}
.form-card.advanced .btn[type=submit]:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(177,84,58,.42);
}

/* ========= Confetti ========= */
.confetti-piece{
  position:fixed;left:var(--x,50%);top:var(--y,50%);width:10px;height:14px;
  background:var(--c,#b1543a);pointer-events:none;z-index:999;border-radius:2px;
  animation:confettiBurst 1.6s var(--d,0s) cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes confettiBurst{
  0%{transform:translate(0,0) rotate(0);opacity:1}
  100%{transform:translate(var(--tx,0),var(--ty,-300px)) rotate(var(--rot,720deg));opacity:0}
}

/* ========= Cake idle sway (after load) ========= */
.cake{animation:cakeSway 6s ease-in-out 2.3s infinite}
@keyframes cakeSway{0%,100%{transform:translateX(-50%) rotate(0)}50%{transform:translateX(-50%) rotate(1.2deg)}}

/* ========= 3D tilt prep ========= */
.vitrin{transform-style:preserve-3d;will-change:transform;transition:transform .4s ease}

/* ========= Magnet effect button ========= */
.btn.magnetic{transition:transform .2s cubic-bezier(.2,.7,.3,1.4),background .2s ease,box-shadow .2s ease}

/* ========= Focus ring for form inputs =========*/
.field input::placeholder,.field textarea::placeholder{color:transparent}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1!important;transform:none!important}
}
