/* ═══════════════════════════════════════════════════════════
   Trädgårdsservice — shared design system
   ─────────────────────────────────────────────────────────── */

:root{
  --paper:#F2EEE3;
  --paper-2:#EAE4D2;
  --paper-3:#E4DCC4;
  --ink:#121A14;
  --ink-soft:#36432F;
  --forest:#203E22;
  --forest-2:#2E4F31;
  --moss:#6F7A4A;
  --leaf:#A8C86C;
  --frost:#D9E5D7;
  --frost-2:#C7DCE8;
  --frost-3:#AFC4D1;
  --wood:#8A6A3E;
  --rule:#C7BFA8;
  --shadow:rgba(14,24,16,.08);
  --max:1320px;

  /* accent slot — detail pages can override */
  --accent:var(--leaf);
  --accent-ink:var(--forest);
  --accent-soft:rgba(168,200,108,.12);
  --error:#9B4A2E;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{background:var(--paper)}
body{
  font-family:"Newsreader", Georgia, serif;
  color:var(--ink);
  background:var(--paper);
  font-size:17px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* Paper grain + faint atmospheric wash */
body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.07  0 0 0 0 0.10  0 0 0 0 0.08  0 0 0 0.32 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/></svg>");
  mix-blend-mode:multiply;
  opacity:.22;
}
body::after{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(60% 40% at 85% 0%, rgba(168,200,108,.18), transparent 60%),
    radial-gradient(50% 35% at 0% 100%, rgba(32,62,34,.10), transparent 60%);
}
/* page-specific wash override */
body.theme-winter::after{
  background:
    radial-gradient(60% 40% at 10% 0%, rgba(199,220,232,.40), transparent 60%),
    radial-gradient(55% 45% at 95% 95%, rgba(32,62,34,.08), transparent 60%);
}
body.theme-wintermaint::after{
  background:
    radial-gradient(60% 40% at 90% 0%, rgba(175,196,209,.32), transparent 60%),
    radial-gradient(45% 35% at 0% 70%, rgba(138,106,62,.08), transparent 60%);
}

.wrap{position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:32px 48px 80px}

/* ─── top strip ────────────────────────────────────────────── */
.strip{
  display:flex; justify-content:space-between; align-items:center;
  font-family:"Fraunces", serif;
  font-weight:500;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--forest);
  border-bottom:1px solid var(--rule);
  padding-bottom:14px;
}
.strip a{color:inherit; text-decoration:none; transition:color .3s}
.strip a:hover{color:var(--accent-ink); text-decoration:underline; text-underline-offset:4px}
.strip .mark{display:flex; gap:14px; align-items:center}
.mark .dot{
  width:10px; height:10px; border-radius:999px;
  background:var(--forest); position:relative;
}
.mark .dot::after{
  content:""; position:absolute; inset:-4px; border-radius:999px;
  border:1px solid var(--forest); opacity:.4;
}
.crumb{display:flex; gap:10px; align-items:center}
.crumb .sep{opacity:.45}
.crumb .here{color:var(--ink); font-weight:550}
.strip .seasons{display:flex; gap:18px}
.seasons span{opacity:.55}
.seasons span.active{opacity:1; color:var(--ink)}
.seasons span.active::before{
  content:"●"; margin-right:6px; color:var(--accent); font-size:8px; vertical-align:2px;
}

/* ─── typography primitives ───────────────────────────────── */
.eyebrow{
  font-family:"Fraunces", serif;
  font-weight:450;
  font-variation-settings:"SOFT" 60, "opsz" 14;
  font-size:13px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:18px;
  display:flex; align-items:center; gap:14px;
}
.eyebrow::before{
  content:""; width:52px; height:1px; background:var(--forest); display:inline-block;
}

.display{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 144, "SOFT" 100, "WONK" 1;
  font-weight:340;
  line-height:.86;
  letter-spacing:-.04em;
  color:var(--forest);
  margin:0;
}
.display em{
  font-style:italic; font-weight:340;
  color:var(--ink);
  font-variation-settings:"opsz" 144, "SOFT" 100, "WONK" 1;
}
.display .amp{
  font-family:"Newsreader", serif;
  font-style:italic; font-weight:300;
  color:var(--moss);
  padding:0 .04em;
}

.lead{
  font-family:"Newsreader", serif;
  font-size:20px;
  line-height:1.45;
  color:var(--ink-soft);
}
.lead .cap{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 24, "SOFT" 80;
  font-style:italic;
  color:var(--accent-ink);
}

/* ─── section-head ────────────────────────────────────────── */
.section-head{
  display:flex; justify-content:space-between; align-items:baseline;
  margin:56px 0 22px;
}
.section-head h2{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 24, "SOFT" 80;
  font-weight:420;
  font-style:italic;
  font-size:22px;
  color:var(--forest);
  margin:0;
  letter-spacing:-.01em;
}
.section-head .ruler{
  flex:1; height:1px; background:var(--rule);
  margin:0 22px; align-self:center;
}
.section-head .meta{
  font-family:"Fraunces", serif;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-soft);
}

/* ─── tags ────────────────────────────────────────────────── */
.tag{
  font-family:"Fraunces", serif;
  font-weight:500;
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:8px 14px;
  border-radius:999px;
  border:1px solid var(--rule);
  color:var(--ink-soft);
  background:transparent;
  display:inline-block;
}
.tag.solid{background:var(--forest); color:var(--paper); border-color:var(--forest)}
.tag.accent{background:var(--accent); color:var(--accent-ink); border-color:transparent}

/* ─── omfattning grid (on detail pages) ───────────────────── */
.omfattning{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--rule);
  border-left:1px solid var(--rule);
  margin-top:8px;
}
.omfattning .cell{
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:30px 28px 32px;
  display:flex; flex-direction:column; gap:14px;
  min-height:180px;
  position:relative;
  transition:background .5s ease;
  cursor:default;
}
.omfattning .cell:hover{
  background:var(--accent-soft);
}
.omfattning .cell .icon{
  width:34px; height:34px; color:var(--forest-2);
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
}
.omfattning .cell:hover .icon{transform:rotate(-8deg) scale(1.06)}
.omfattning .cell h3{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 48, "SOFT" 60;
  font-weight:420;
  font-size:24px;
  margin:0;
  line-height:1.1;
  letter-spacing:-.015em;
  color:var(--ink);
}
.omfattning .cell p{
  font-family:"Newsreader", serif;
  font-size:15px;
  line-height:1.5;
  color:var(--ink-soft);
  margin:0;
}
.omfattning .cell .no{
  position:absolute; top:20px; right:22px;
  font-family:"Fraunces", serif;
  font-size:11px; letter-spacing:.2em;
  color:var(--ink-soft);
  opacity:.6;
}

/* ─── process stege ──────────────────────────────────────── */
.stege{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:28px;
  position:relative;
  padding:10px 0 40px;
}
.stege::before{
  content:""; position:absolute;
  top:46px; left:4%; right:4%; height:1px;
  background:repeating-linear-gradient(90deg, var(--rule) 0, var(--rule) 6px, transparent 6px, transparent 14px);
}
.stege .step{
  position:relative; padding-top:0;
}
.stege .step .bubble{
  width:64px; height:64px; border-radius:999px;
  border:1px solid var(--forest);
  background:var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 48, "SOFT" 80, "WONK" 1;
  font-style:italic; font-weight:380;
  font-size:26px;
  color:var(--forest);
  margin-bottom:20px;
  position:relative; z-index:2;
  transition:background .4s, color .4s, transform .5s;
}
.stege .step:hover .bubble{
  background:var(--forest); color:var(--paper);
  transform:rotate(-5deg);
}
.stege .step h4{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 32, "SOFT" 60;
  font-weight:420;
  font-size:20px;
  margin:0 0 8px;
  color:var(--ink);
  letter-spacing:-.01em;
}
.stege .step p{
  font-family:"Newsreader", serif;
  font-size:15px;
  color:var(--ink-soft);
  margin:0;
  line-height:1.5;
  max-width:240px;
}

/* ─── tempo/kalender band ────────────────────────────────── */
.tempo{
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:36px 0 30px;
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:6px;
  align-items:end;
  position:relative;
}
.tempo .month{
  text-align:center;
  position:relative;
  padding-top:50px;
}
.tempo .month .bar{
  position:absolute;
  top:0; left:10%; right:10%;
  height:36px;
  border-radius:4px;
  background:transparent;
  border:1px dashed var(--rule);
  transition:background .5s ease;
}
.tempo .month.active .bar{
  background:var(--accent);
  border-color:transparent;
  box-shadow:0 8px 18px -10px rgba(32,62,34,.25);
}
.tempo .month.peak .bar{
  background:var(--forest);
  border-color:transparent;
}
.tempo .month.standby .bar{
  background:repeating-linear-gradient(45deg, var(--paper-3) 0, var(--paper-3) 4px, transparent 4px, transparent 8px);
  border:1px solid var(--rule);
}
.tempo .month .lbl{
  font-family:"Fraunces", serif;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft);
}
.tempo-legend{
  display:flex; gap:28px; margin-top:18px;
  font-family:"Fraunces", serif;
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-soft);
}
.tempo-legend i{
  display:inline-block; width:18px; height:10px; border-radius:2px;
  margin-right:8px; vertical-align:middle;
}
.tempo-legend .k-peak i{background:var(--forest)}
.tempo-legend .k-active i{background:var(--accent)}
.tempo-legend .k-standby i{
  background:repeating-linear-gradient(45deg, var(--paper-3) 0, var(--paper-3) 3px, transparent 3px, transparent 6px);
  border:1px solid var(--rule);
}

/* ─── cross-nav (other services) ─────────────────────────── */
.cross{
  margin-top:80px;
  padding-top:30px;
  border-top:1px solid var(--rule);
}
.cross .cross-head{
  display:flex; justify-content:space-between; align-items:baseline;
  margin-bottom:28px;
}
.cross .cross-head h2{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 72, "SOFT" 100, "WONK" 1;
  font-style:italic; font-weight:340;
  font-size:clamp(40px, 5vw, 76px);
  line-height:.95;
  letter-spacing:-.02em;
  color:var(--forest);
  margin:0;
}
.cross-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:14px;
}
.cross-card{
  text-decoration:none;
  color:inherit;
  border:1px solid var(--rule);
  padding:22px 22px 20px;
  background:var(--paper);
  border-radius:10px;
  min-height:200px;
  display:flex; flex-direction:column; justify-content:space-between;
  transition:background .5s ease, transform .6s cubic-bezier(.2,.8,.2,1), border-color .4s;
  position:relative; overflow:hidden;
}
.cross-card:hover{
  background:var(--forest);
  color:var(--paper);
  border-color:var(--forest);
  transform:translateY(-3px);
}
.cross-card .no{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 72, "SOFT" 80, "WONK" 1;
  font-style:italic; font-weight:320;
  font-size:36px;
  color:var(--moss);
  line-height:1;
  transition:color .4s;
}
.cross-card:hover .no{color:var(--accent)}
.cross-card .name{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 48, "SOFT" 60;
  font-weight:400;
  font-size:21px;
  line-height:1.1;
  letter-spacing:-.015em;
  margin:26px 0 8px;
}
.cross-card .kind{
  font-family:"Fraunces", serif;
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-soft);
  transition:color .4s;
}
.cross-card:hover .kind{color:var(--frost)}

/* ─── footer ─────────────────────────────────────────────── */
.foot{
  margin-top:80px;
  padding-top:28px;
  border-top:1px solid var(--rule);
  display:grid;
  grid-template-columns:1.1fr 1fr 1fr;
  gap:48px;
  align-items:start;
}
.foot h3{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 72, "SOFT" 80, "WONK" 1;
  font-style:italic;
  font-weight:340;
  font-size:clamp(40px, 5vw, 72px);
  line-height:.95;
  letter-spacing:-.02em;
  color:var(--forest);
  margin:0;
}
.foot h3 a{
  color:inherit; text-decoration:none;
  border-bottom:2px solid transparent;
  transition:border-color .3s ease;
}
.foot h3 a:hover{border-color:var(--accent)}
.foot .meta-col{
  font-family:"Fraunces", serif;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-soft);
}
.foot .meta-col b{
  display:block;
  font-family:"Newsreader", serif;
  font-weight:400; font-style:italic;
  letter-spacing:0; text-transform:none;
  font-size:17px; color:var(--ink);
  margin-top:6px;
}
.foot .meta-col .placeholder{opacity:.5; font-style:normal}

.copyright{
  margin-top:60px;
  font-family:"Fraunces", serif;
  font-size:10px; letter-spacing:.28em; text-transform:uppercase;
  color:var(--ink-soft);
  display:flex; justify-content:space-between;
  opacity:.7;
}

/* ─── entrance animations ────────────────────────────────── */
.reveal{opacity:0; transform:translateY(16px); transition:opacity 1s ease, transform 1.1s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1; transform:none}
.stagger > *{opacity:0; transform:translateY(10px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1)}
.stagger.in > *{opacity:1; transform:none}
.stagger.in > *:nth-child(1){transition-delay:.05s}
.stagger.in > *:nth-child(2){transition-delay:.12s}
.stagger.in > *:nth-child(3){transition-delay:.19s}
.stagger.in > *:nth-child(4){transition-delay:.26s}
.stagger.in > *:nth-child(5){transition-delay:.33s}
.stagger.in > *:nth-child(6){transition-delay:.40s}
.stagger.in > *:nth-child(7){transition-delay:.47s}
.stagger.in > *:nth-child(8){transition-delay:.54s}

/* ─── responsive ─────────────────────────────────────────── */
@media (max-width:960px){
  .omfattning{grid-template-columns:repeat(2, 1fr)}
  .stege{grid-template-columns:repeat(2, 1fr); gap:36px 22px}
  .stege::before{display:none}
  .cross-grid{grid-template-columns:repeat(2, 1fr)}
}
@media (max-width:640px){
  .wrap{padding:20px 22px 60px}
  .omfattning{grid-template-columns:1fr}
  .tempo{gap:3px}
  .tempo .month .lbl{font-size:9px; letter-spacing:.1em}
  .foot{grid-template-columns:1fr; gap:30px}
  .copyright{flex-direction:column; gap:8px}
  .strip .seasons span:not(.active){display:none}
  .cross-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════════════════
   Wizard — Begär en översyn
   ─────────────────────────────────────────────────────────── */

.wiz-hero{
  display:grid; grid-template-columns:1.3fr .9fr; gap:48px;
  align-items:end; padding:56px 0 40px; border-bottom:1px solid var(--rule);
}
.wiz-hero h1{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 144, "SOFT" 100, "WONK" 1;
  font-weight:340;
  font-size:clamp(56px, 10vw, 140px);
  line-height:.86; letter-spacing:-.035em;
  color:var(--forest); margin:12px 0 0;
}
.wiz-hero h1 em{font-style:italic; color:var(--ink); font-variation-settings:"opsz" 144, "SOFT" 100, "WONK" 1}
.wiz-hero .lead{
  font-family:"Newsreader", serif;
  font-size:19px; line-height:1.5; color:var(--ink-soft);
  max-width:46ch; font-style:italic; font-weight:300;
}

/* Stepper nav */
.wiz-nav{
  display:flex; gap:0; margin:32px 0 44px;
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
  list-style:none; padding:0;
}
.wiz-nav li{flex:1; display:flex}
.wiz-nav button{
  flex:1; appearance:none; background:transparent; border:0;
  padding:18px 14px 16px; text-align:left; cursor:pointer;
  font-family:"Fraunces", serif; font-weight:450;
  font-size:11px; letter-spacing:.26em; text-transform:uppercase;
  color:var(--ink-soft); opacity:.55;
  border-right:1px solid var(--rule);
  transition:opacity .3s, color .3s, background .3s;
  position:relative;
}
.wiz-nav li:last-child button{border-right:0}
.wiz-nav button .num{
  font-variation-settings:"opsz" 72, "SOFT" 80, "WONK" 1;
  font-style:italic; font-weight:320;
  font-size:18px; letter-spacing:0; color:var(--moss);
  display:block; margin-bottom:6px;
}
.wiz-nav button[data-state="done"]{opacity:.75; color:var(--ink)}
.wiz-nav button[aria-current="step"]{
  opacity:1; color:var(--forest);
  background:linear-gradient(180deg, transparent 0%, var(--accent-soft) 100%);
}
.wiz-nav button[aria-current="step"]::after{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background:var(--forest);
}
.wiz-nav button:not([aria-current="step"]):hover{opacity:.9; color:var(--ink)}
.wiz-nav button:disabled{cursor:not-allowed; opacity:.35}
.wiz-nav button:disabled:hover{opacity:.35; color:var(--ink-soft)}

/* Steps */
.wiz-step{padding:8px 0 40px}
.wiz-step[hidden]{display:none}
.wiz-step h2{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 24, "SOFT" 80;
  font-style:italic; font-weight:420; font-size:32px;
  letter-spacing:-.01em; color:var(--forest);
  margin:0 0 8px;
}
.wiz-step h2:focus{outline:none}
.wiz-step .wiz-intro{
  font-family:"Newsreader", serif; color:var(--ink-soft);
  font-size:17px; font-style:italic; max-width:60ch; margin:0 0 36px;
}

/* Field grid */
.wiz-grid{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:28px 40px;
}
.wiz-grid.one{grid-template-columns:1fr}
.wiz-field{display:flex; flex-direction:column; gap:6px; min-width:0}
.wiz-field.span-2{grid-column:span 2}
.wiz-field > label, .wiz-field > .lbl{
  font-family:"Fraunces", serif; font-weight:500;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-soft);
}
.wiz-field > label .req{color:var(--forest); margin-left:4px; font-weight:400}
.wiz-field .hint{
  font-family:"Newsreader", serif; font-style:italic;
  font-size:13px; color:var(--moss); margin-top:2px;
}

.wiz-field input:not([type="checkbox"]):not([type="radio"]),
.wiz-field select,
.wiz-field textarea{
  width:100%;
  appearance:none; -webkit-appearance:none;
  font-family:"Newsreader", serif;
  font-size:17px; line-height:1.45; color:var(--ink);
  background:transparent;
  border:0; border-bottom:1px solid var(--rule);
  padding:10px 0 8px;
  border-radius:0;
  transition:border-color .3s;
}
.wiz-field select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%2336432F' stroke-width='1.4'><path d='M1 1l5 5 5-5'/></svg>");
  background-repeat:no-repeat;
  background-position:right 2px center;
  padding-right:22px;
  cursor:pointer;
}
.wiz-field textarea{resize:vertical; min-height:92px}
.wiz-field input:focus, .wiz-field select:focus, .wiz-field textarea:focus{
  outline:none; border-bottom-color:var(--forest);
}
.wiz-field.is-invalid input,
.wiz-field.is-invalid select,
.wiz-field.is-invalid textarea{border-bottom-color:var(--error)}
.wiz-field .err{
  font-family:"Newsreader", serif; font-style:italic;
  font-size:13px; color:var(--error); margin-top:2px; min-height:0;
}

/* Checkbox / radio groups */
.wiz-options{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:10px 24px;
  margin-top:8px;
}
.wiz-options.one{grid-template-columns:1fr}
.wiz-opt{
  display:flex; align-items:flex-start; gap:12px;
  padding:12px 14px;
  border:1px solid var(--rule); border-radius:6px;
  cursor:pointer;
  transition:border-color .25s, background .25s;
  font-family:"Newsreader", serif; font-size:16px; color:var(--ink);
  line-height:1.35;
}
.wiz-opt input{
  appearance:none; -webkit-appearance:none;
  flex:0 0 auto; margin:2px 0 0;
  width:16px; height:16px;
  border:1px solid var(--ink-soft); background:transparent;
  border-radius:3px;
  display:grid; place-content:center;
  transition:background .25s, border-color .25s;
  cursor:pointer;
}
.wiz-opt input[type="radio"]{border-radius:999px}
.wiz-opt input:checked{background:var(--forest); border-color:var(--forest)}
.wiz-opt input[type="checkbox"]:checked::after{
  content:""; width:8px; height:4px;
  border:1.6px solid var(--paper); border-top:0; border-right:0;
  transform:rotate(-45deg) translate(1px,-1px);
}
.wiz-opt input[type="radio"]:checked::after{
  content:""; width:6px; height:6px; border-radius:999px; background:var(--paper);
}
.wiz-opt:has(input:checked){
  border-color:var(--forest);
  background:var(--accent-soft);
}
.wiz-opt:hover{border-color:var(--ink-soft)}

/* Actions row */
.wiz-actions{
  display:flex; justify-content:space-between; align-items:center;
  gap:24px; margin-top:44px; padding-top:28px;
  border-top:1px solid var(--rule);
}
.wiz-back{
  appearance:none; background:transparent; border:0; cursor:pointer;
  font-family:"Fraunces", serif; font-weight:450;
  font-size:12px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-soft); padding:12px 0;
  transition:color .25s;
}
.wiz-back:hover{color:var(--forest)}
.wiz-back[hidden]{display:none}
.wiz-btn{
  appearance:none; cursor:pointer;
  font-family:"Fraunces", serif; font-weight:500;
  font-size:13px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--paper); background:var(--forest);
  border:1px solid var(--forest);
  padding:16px 28px; border-radius:999px;
  transition:background .3s, color .3s, transform .3s;
}
.wiz-btn:hover{background:var(--forest-2); transform:translateY(-1px)}
.wiz-btn .ar{display:inline-block; margin-left:10px; transition:transform .3s}
.wiz-btn:hover .ar{transform:translateX(4px)}

/* Review step */
.wiz-review{
  display:grid; grid-template-columns:1fr; gap:0;
  border-top:1px solid var(--rule);
}
.wiz-review-row{
  display:grid; grid-template-columns:180px 1fr auto;
  gap:28px; align-items:start;
  padding:22px 0; border-bottom:1px solid var(--rule);
}
.wiz-review-row .k{
  font-family:"Fraunces", serif; font-weight:500;
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-soft); padding-top:3px;
}
.wiz-review-row .v{
  font-family:"Newsreader", serif; font-size:17px; color:var(--ink);
  line-height:1.5;
}
.wiz-review-row .v .empty{color:var(--moss); font-style:italic; opacity:.7}
.wiz-review-row .edit{
  appearance:none; background:transparent; border:0; cursor:pointer;
  font-family:"Fraunces", serif; font-weight:450;
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--forest); padding:4px 0;
  border-bottom:1px solid transparent;
  transition:border-color .25s;
}
.wiz-review-row .edit:hover{border-bottom-color:var(--forest)}

/* GDPR */
.wiz-gdpr{
  margin-top:36px; padding:20px 0 0;
  border-top:1px solid var(--rule);
  font-family:"Newsreader", serif;
  font-size:13px; line-height:1.55; color:var(--ink-soft);
  max-width:72ch;
}
.wiz-gdpr a{color:var(--forest); text-decoration:none; border-bottom:1px solid var(--rule)}
.wiz-gdpr a:hover{border-bottom-color:var(--forest)}

/* Honeypot */
.wiz-honeypot{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}

/* Thank-you */
.wiz-thankyou{padding:56px 0 24px}
.wiz-thankyou[hidden]{display:none}
.wiz-thankyou h2{
  font-family:"Fraunces", serif;
  font-variation-settings:"opsz" 144, "SOFT" 100, "WONK" 1;
  font-weight:340; font-style:italic;
  font-size:clamp(48px, 8vw, 104px);
  line-height:.9; letter-spacing:-.03em;
  color:var(--forest); margin:0 0 24px;
}
.wiz-thankyou p{
  font-family:"Newsreader", serif;
  font-size:19px; line-height:1.55; color:var(--ink-soft);
  max-width:54ch; margin:0 0 18px;
}
.wiz-thankyou .demo-note{
  margin-top:40px; padding:18px 20px;
  background:var(--accent-soft); border:1px dashed var(--rule);
  font-size:13px; font-style:italic; color:var(--ink-soft);
}

/* Conditional reveal */
.wiz-cond{
  display:grid; grid-template-rows:0fr;
  transition:grid-template-rows .35s ease, margin .35s ease, opacity .35s ease;
  opacity:0; margin-top:0;
}
.wiz-cond > div{overflow:hidden; min-height:0}
.wiz-cond.open{grid-template-rows:1fr; opacity:1; margin-top:24px}

@media (max-width:960px){
  .wiz-hero{grid-template-columns:1fr; gap:20px; align-items:start}
  .wiz-grid{grid-template-columns:1fr; gap:22px}
  .wiz-field.span-2{grid-column:auto}
  .wiz-options{grid-template-columns:1fr}
  .wiz-review-row{grid-template-columns:1fr; gap:4px}
  .wiz-review-row .edit{justify-self:start; margin-top:4px}
}
@media (max-width:640px){
  .wiz-nav{flex-wrap:wrap}
  .wiz-nav li{flex:1 1 50%}
  .wiz-nav button{padding:14px 10px}
  .wiz-nav li button{border-right:1px solid var(--rule); border-bottom:1px solid var(--rule)}
  .wiz-nav li:nth-child(2n) button{border-right:0}
  .wiz-nav li:nth-child(n+3) button{border-bottom:0}
  .wiz-actions{flex-direction:row-reverse; flex-wrap:wrap; gap:16px}
  .wiz-btn{flex:1; text-align:center}
  .wiz-hero h1{font-size:clamp(44px, 14vw, 80px)}
}

@media (prefers-reduced-motion:reduce){
  .wiz-nav button, .wiz-btn, .wiz-btn .ar, .wiz-back, .wiz-cond,
  .wiz-opt, .wiz-review-row .edit, .wiz-field input,
  .wiz-field select, .wiz-field textarea{transition:none}
}
