/* =============================================================
   arbusteo — bespoke section layouts
   ============================================================= */

/* ---------- PROBLÈME : dispersion schema ------------------------------- */
.probleme-intro { max-width: 660px; }
.probleme-intro .h2 { text-align: left; }
.probleme-intro .lead { margin-top: 18px; }

.dispersion {
  margin-top: clamp(40px, 5vw, 64px);
  display: grid; grid-template-columns: repeat(12, 1fr);
  gap: 18px; align-items: start;
}
.frag {
  background: var(--paper); border-radius: var(--r-card);
  border: 1px solid var(--line); box-shadow: var(--shadow-1);
  padding: 22px 22px 24px;
}
.frag .frag-ico {
  width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center;
  background: var(--cream); color: var(--ink-soft); margin-bottom: 14px;
}
.frag .frag-ico .material-symbols-outlined { font-size: 24px; }
.frag h3 { font-size: 17px; font-weight: 700; color: var(--green-dark); }
.frag p { margin-top: 6px; font-size: 14.5px; line-height: 1.5; color: var(--ink-soft); }

/* scattered placement + slight rotations for the "éparpillement" feel.
   --rot is the resting tilt; scrolltext.js composes translate/scale on top via --fy/--fs. */
.frag:nth-child(1) { grid-column: 1 / 5; --rot: -1.2deg; }
.frag:nth-child(2) { grid-column: 5 / 9; margin-top: 26px; --rot: .8deg; }
.frag:nth-child(3) { grid-column: 9 / 13; --rot: 1.4deg; }
.frag:nth-child(4) { grid-column: 2 / 6; margin-top: 8px; --rot: 1deg; }
.frag:nth-child(5) { grid-column: 7 / 11; margin-top: 18px; --rot: -1.1deg; }
.frag { transform: rotate(var(--rot, 0deg)); }
.frag.frag-anim {
  will-change: transform, opacity; transform-origin: center 65%;
  transform: translateY(var(--fy, 0px)) scale(var(--fs, 1)) rotate(var(--rot, 0deg));
}
.frag .frag-ico.fade { position: relative; }
.frag .frag-ico.fade::after {
  content: ""; position: absolute; inset: 0; border-radius: 14px;
  background: linear-gradient(120deg, transparent, var(--cream) 85%);
}

.sigh {
  margin: 40px auto 0; text-align: center; max-width: 640px;
  font-size: clamp(17px, 1.7vw, 20px); font-style: italic;
  color: var(--ocre); line-height: 1.5;
}

@media (max-width: 860px) {
  .dispersion { display: flex; flex-direction: column; gap: 14px; }
  .frag { --rot: 0deg !important; margin-top: 0 !important; }
}

/* ---------- PROMESSE : radial schema ----------------------------------- */
.promesse-grid {
  display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(36px, 5vw, 72px);
  align-items: center;
}
.promesse-text .h2 { text-align: left; }
.promesse-text p { margin-top: 18px; font-size: 17px; line-height: 1.6; color: var(--ink-soft); }
.promesse-text p strong { color: var(--green-dark); }
.promesse-text .pivot { color: var(--green-title); }

.radial { position: relative; aspect-ratio: 1 / 1; width: 100%; max-width: 520px; margin: 0 auto; }
.radial svg.links { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.radial .core {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 38%; aspect-ratio: 1; border-radius: 50%;
  background: var(--olive-light); border: 2px solid var(--olive);
  display: grid; place-items: center; text-align: center; padding: 10px;
  box-shadow: var(--shadow-2); z-index: 2;
}
.radial .core .material-symbols-outlined { font-size: 40px; color: var(--green-deep); }
.radial .core .lbl { font-size: 14px; font-weight: 700; color: var(--green-title); margin-top: 4px; line-height: 1.2; }
.sat {
  position: absolute; transform: translate(-50%,-50%);
  width: 96px; display: flex; flex-direction: column; align-items: center; gap: 7px; z-index: 2;
}
.sat .bub {
  width: 56px; height: 56px; border-radius: 50%; background: var(--paper);
  border: 1px solid var(--line); box-shadow: var(--shadow-1);
  display: grid; place-items: center; color: var(--olive);
}
.sat .bub .material-symbols-outlined { font-size: 27px; }
.sat .sat-lbl { font-size: 12.5px; font-weight: 600; color: var(--green-dark); text-align: center; line-height: 1.15; }

@media (max-width: 860px) {
  .promesse-grid { grid-template-columns: 1fr; }
  .promesse-text .h2 { text-align: left; }
}

/* ---------- PARCOURS : serpentine steps -------------------------------- */
.parcours-thread { position: relative; margin-top: clamp(36px, 4vw, 56px); }
/* the running vine line */
.parcours-thread::before {
  content: ""; position: absolute; left: 50%; top: 0; bottom: 0; width: 2px;
  background: repeating-linear-gradient(var(--olive) 0 8px, transparent 8px 16px);
  transform: translateX(-50%); opacity: .5;
}
.step {
  position: relative; display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 64px); align-items: center;
  padding: clamp(28px, 3.5vw, 48px) 0;
}
.step-text { max-width: 460px; }
.step:nth-child(even) .step-text { order: 2; margin-left: auto; }
.step:nth-child(even) .step-visual { order: 1; }
.step-num {
  display: inline-flex; align-items: center; gap: 12px; margin-bottom: 14px;
}
.step-num .badge {
  width: 44px; height: 44px; border-radius: 50%; background: var(--green-deep);
  color: var(--cream-light); display: grid; place-items: center;
  font-size: 20px; font-weight: 700; box-shadow: var(--shadow-2);
}
.step-num .material-symbols-outlined { color: var(--olive); font-size: 26px; }
.step-text h3 { font-size: clamp(22px, 2.4vw, 28px); font-weight: 600; color: var(--green-title); letter-spacing: -.4px; }
.step-text .benefit { margin-top: 10px; font-size: 18px; font-weight: 700; color: var(--green-deep); line-height: 1.35; }
.step-text p { margin-top: 12px; font-size: 15.5px; line-height: 1.6; color: var(--ink-soft); }

/* central numbered node on the vine */
.step-node {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  width: 14px; height: 14px; border-radius: 50%; background: var(--olive);
  border: 3px solid var(--cream); z-index: 2;
}

.step-visual { position: relative; }
.mock {
  background: var(--paper); border-radius: var(--r-card); border: 1px solid var(--line);
  box-shadow: var(--shadow-2); padding: 18px; overflow: hidden;
}
.mock-head { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.mock-head .material-symbols-outlined { font-size: 18px; color: var(--olive); }
.mock-head .t { font-size: 12.5px; font-weight: 700; color: var(--ink-soft); letter-spacing: .3px; }
.mock-head .spacer { flex: 1; }

/* mock 1 — mini map */
.mini-map { position: relative; height: 188px; border-radius: var(--r-md); overflow: hidden;
  background: linear-gradient(180deg, #f4f6e9, #eaf0dc); }
.mini-map svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.mini-map .pin { position: absolute; width: 14px; height: 14px; border-radius: 50%;
  background: var(--green-deep); border: 2.5px solid #fff; transform: translate(-50%,-50%); box-shadow: 0 1px 3px rgba(0,0,0,.3); }
.mini-map .pin.t { background: var(--ocre); }
.mini-map .tag {
  position: absolute; background: #fff; border: 1px solid var(--line); border-radius: 10px;
  padding: 6px 9px; font-size: 11px; font-weight: 600; color: var(--green-dark); box-shadow: var(--shadow-1);
}
.mini-map .tag small { display: block; font-weight: 500; color: var(--ink-soft); font-size: 10px; }

/* mock 2 — observation */
.obs-row { display: flex; gap: 12px; align-items: flex-start; }
.obs-photo { width: 64px; height: 64px; border-radius: 12px; flex: none;
  background: linear-gradient(160deg, #e7efd2, #cfe2a9); display: grid; place-items: center; }
.obs-photo .material-symbols-outlined { color: var(--olive); font-size: 28px; }
.obs-main { flex: 1; min-width: 0; }
.obs-top { display: flex; align-items: center; gap: 8px; }
.sev {
  font-size: 10.5px; font-weight: 700; padding: 3px 9px; border-radius: 999px;
}
.sev.info { background: #e3efce; color: #4a5a23; }
.sev.warn { background: #ffe6c2; color: #6c3a00; }
.sev.urgent { background: #ffd9cc; color: #8a1a08; }
.obs-date { font-size: 11px; color: var(--ink-soft); margin-left: auto; }
.obs-main p { font-size: 13.5px; color: var(--ink); margin-top: 7px; line-height: 1.45; }
.watch-stack { margin-top: 14px; display: flex; flex-direction: column; gap: 7px; }
.watch {
  display: flex; align-items: center; gap: 9px; font-size: 12.5px; font-weight: 600; color: var(--green-dark);
  background: var(--cream-light); border: 1px solid var(--line); border-radius: 10px; padding: 8px 11px;
}
.watch .material-symbols-outlined { font-size: 17px; color: var(--ocre); }

/* mock 3 — recurring series */
.rec-rule {
  display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px;
  padding: 11px 13px; border-radius: 12px;
  background: var(--olive-light); border: 1px solid color-mix(in srgb, var(--olive) 35%, transparent);
}
.rec-rule .rec-title { font-size: 13px; font-weight: 700; color: var(--green-title); line-height: 1.2; }
.rec-rule .rec-when { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; color: var(--green-dark); }
.rec-rule .rec-when .material-symbols-outlined { font-size: 15px; color: var(--olive); }

.agenda { display: flex; flex-direction: column; gap: 8px; }
.agenda .occ {
  display: flex; align-items: center; gap: 11px; padding: 9px 12px;
  border: 1px solid var(--line); border-radius: 12px; background: var(--cream-light);
}
.agenda .occ.next { border-color: var(--olive); background: #f3f7e6; }
.agenda .occ .when { font-size: 11px; font-weight: 700; color: var(--green-deep); width: 50px; flex: none; }
.agenda .occ .what { font-size: 12.5px; color: var(--ink); }
.agenda .occ .st { margin-left: auto; font-size: 18px; }
.agenda .occ.done .st { color: #4f9a57; font-variation-settings: "FILL" 1; }
.agenda .occ.skip .st { color: var(--ocre); }
.agenda .occ.skip .what { color: var(--ink-soft); }
.agenda .occ.next .st { color: var(--olive); }
.agenda .occ.next .what { font-weight: 600; color: var(--green-deep); }

.rec-meta { display: flex; gap: 16px; margin-top: 13px; padding-top: 12px; border-top: 1px solid var(--line); }
.rec-meta .m { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; color: var(--green-dark); }
.rec-meta .m .material-symbols-outlined { font-size: 16px; color: var(--olive); }

/* mock 4 — completed ops */
.op-list { display: flex; flex-direction: column; gap: 8px; }
.op-done { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: var(--ink); }
.op-done .material-symbols-outlined { font-size: 20px; color: #4f9a57; font-variation-settings: "FILL" 1; }
.op-foot { display: flex; align-items: center; gap: 10px; margin-top: 14px; padding-top: 13px; border-top: 1px solid var(--line); }
.op-foot .chrono { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 600; color: var(--green-dark); }
.op-foot .chrono .material-symbols-outlined { font-size: 17px; color: var(--olive); }
.op-foot .thumb { width: 38px; height: 38px; border-radius: 9px; margin-left: auto;
  background: linear-gradient(160deg, #e7efd2, #cfe2a9); display: grid; place-items: center; }
.op-foot .thumb .material-symbols-outlined { font-size: 19px; color: var(--olive); }
.op-foot .auto { font-size: 11px; font-style: italic; color: var(--ink-soft); }

/* mock 5 — trend graph */
.trend { position: relative; height: 168px; }
.trend svg { width: 100%; height: 100%; overflow: visible; }
.trend .alert-bubble {
  position: absolute; top: 6px; right: 0; background: #fff; border: 1px solid var(--ocre);
  color: var(--ocre); font-size: 11px; font-weight: 700; border-radius: 10px; padding: 5px 10px;
  box-shadow: var(--shadow-1); display: inline-flex; align-items: center; gap: 5px;
}
.trend .alert-bubble .material-symbols-outlined { font-size: 15px; }
.trend-legend { display: flex; gap: 16px; margin-top: 10px; font-size: 11px; color: var(--ink-soft); }
.trend-legend span { display: inline-flex; align-items: center; gap: 5px; }
.trend-legend .k { width: 14px; height: 2px; border-radius: 2px; }

@media (max-width: 860px) {
  .parcours-thread::before { left: 27px; }
  .step { grid-template-columns: 1fr; padding-left: 56px; }
  .step:nth-child(even) .step-text { order: 1; margin-left: 0; }
  .step:nth-child(even) .step-visual { order: 2; }
  .step-node { left: 27px; }
}

/* rémanents band */
.remanents {
  margin-top: clamp(36px, 4vw, 56px);
  background: var(--ocre-bg); border: 1px solid #f0dcbf; border-left: 5px solid var(--ocre);
  border-radius: var(--r-card); padding: clamp(24px, 3vw, 36px);
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 32px; align-items: center;
}
.remanents .rem-text h3 { font-size: 22px; font-weight: 700; color: #6c3a00; }
.remanents .rem-text p { margin-top: 10px; font-size: 15.5px; line-height: 1.6; color: #6b4d2a; }
.rem-flow { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: center; }
.rem-node { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.rem-node .ic { width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center;
  background: #fff; border: 1px solid #f0dcbf; color: var(--ocre); }
.rem-node .ic .material-symbols-outlined { font-size: 28px; }
.rem-node .cap { font-size: 11.5px; font-weight: 600; color: #6c3a00; }
.rem-flow .arr { color: var(--ocre); font-size: 22px; }
.rem-tags { display: flex; gap: 8px; margin-top: 14px; justify-content: center; }
.rem-tags .rt { font-size: 11px; font-weight: 700; padding: 4px 11px; border-radius: 999px; }
.rem-tags .attendu { background: #fff; border: 1px dashed var(--ocre); color: var(--ocre); }
.rem-tags .constate { background: var(--ocre); color: #fff; }

@media (max-width: 760px) { .remanents { grid-template-columns: 1fr; } }

/* ---------- IA ---------------------------------------------------------- */
.ia-head { text-align: center; max-width: 820px; margin: 0 auto clamp(40px,5vw,60px); }
.ia-signature {
  font-weight: 700; letter-spacing: -1px; line-height: 1.05;
  font-size: clamp(32px, 4.6vw, 54px); color: var(--green-title); margin-top: 14px;
}
.ia-signature .always { color: var(--green-deep); }
.ia-head .lead { margin: 20px auto 0; }
.ia-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }

/* card 2 — proposé vs validé */
.pv { display: flex; align-items: stretch; gap: 12px; margin-top: 16px; }
.pv .pv-card { flex: 1; border-radius: 16px; padding: 14px 12px; text-align: center; }
.pv .proposed { background: #fff; border: 1.5px dashed var(--ocre); }
.pv .validated { background: #e7f2dd; border: 1.5px solid var(--olive); }
.pv .pv-card .material-symbols-outlined { font-size: 26px; }
.pv .proposed .material-symbols-outlined { color: var(--ocre); }
.pv .validated .material-symbols-outlined { color: #3f7a45; font-variation-settings: "FILL" 1; }
.pv .pv-card .t { font-size: 11.5px; font-weight: 700; margin-top: 6px; }
.pv .proposed .t { color: var(--ocre); }
.pv .validated .t { color: var(--green-deep); }
.pv .vs { align-self: center; font-size: 12px; color: var(--ink-soft); font-weight: 600; }

/* card 3 — enclosure */
.enclosure { margin-top: 16px; position: relative; border: 1.5px solid var(--olive);
  border-radius: 16px; padding: 14px; background: #f3f7e6; }
.enclosure .tagline { font-size: 11px; font-weight: 700; color: var(--green-deep); margin-bottom: 10px;
  display: inline-flex; align-items: center; gap: 5px; }
.enclosure .tagline .material-symbols-outlined { font-size: 15px; }
.enclosure .inside { display: flex; gap: 8px; flex-wrap: wrap; }
.enclosure .inside .chip-d { font-size: 11px; font-weight: 600; color: var(--green-dark);
  background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 4px 10px;
  display: inline-flex; align-items: center; gap: 5px; }
.enclosure .inside .chip-d .material-symbols-outlined { font-size: 14px; color: var(--olive); }
.enclosure .out {
  margin-top: 12px; display: flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--ink-soft);
}
.enclosure .out .ghost { font-size: 11px; color: #9a9c8e; background: #ededdf; border-radius: 999px; padding: 4px 10px;
  display: inline-flex; align-items: center; gap: 5px; }
.enclosure .out .ghost .material-symbols-outlined { font-size: 14px; }
.enclosure .out .arr { color: var(--ink-soft); font-size: 18px; }

@media (max-width: 900px) { .ia-cards { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; } }

/* ---------- POUR QUI --------------------------------------------------- */
.audience { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.aud-card { padding: clamp(26px, 3vw, 38px); }
.aud-card .aud-ico {
  width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center;
  background: var(--olive-light); color: var(--ocre); margin-bottom: 18px;
}
.aud-card .aud-ico .material-symbols-outlined { font-size: 30px; }
.aud-card h3 { font-size: 24px; font-weight: 600; color: var(--green-title); }
.aud-card .recog { margin-top: 10px; font-size: 16px; line-height: 1.55; color: var(--ink); font-weight: 500; }
.aud-card ul { margin-top: 18px; display: flex; flex-direction: column; gap: 11px; }
.aud-card li { display: flex; gap: 10px; align-items: flex-start; font-size: 15px; line-height: 1.45; color: var(--ink-soft); }
.aud-card li .material-symbols-outlined { font-size: 20px; color: var(--olive); flex: none; margin-top: 1px; }

.common {
  margin-top: 24px; background: var(--olive-light); border-radius: var(--r-card);
  padding: clamp(24px, 3vw, 36px);
}
.common h4 { font-size: 14px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--green-deep); text-align: center; }
.common-grid { margin-top: 22px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.common-item { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 10px; }
.common-item .ci {
  width: 52px; height: 52px; border-radius: 50%; background: var(--cream-light);
  display: grid; place-items: center; color: var(--green-deep); box-shadow: var(--shadow-1);
}
.common-item .ci .material-symbols-outlined { font-size: 26px; }
.common-item .cl { font-size: 13.5px; font-weight: 600; color: var(--green-dark); line-height: 1.3; }

@media (max-width: 860px) {
  .audience { grid-template-columns: 1fr; }
  .common-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
}

/* ---------- GARANTIES -------------------------------------------------- */
.guard-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 20px; }
.guard { grid-column: span 2; text-align: left; }
/* 3 + 2 layout: last two centered */
.guard:nth-child(4) { grid-column: 2 / 4; }
.guard:nth-child(5) { grid-column: 4 / 6; }
.guard .g-ico {
  width: 54px; height: 54px; border-radius: 50%; background: var(--olive-light);
  display: grid; place-items: center; color: var(--green-deep); margin-bottom: 16px;
}
.guard .g-ico .material-symbols-outlined { font-size: 28px; }
.guard h3 { font-size: 18px; font-weight: 700; color: var(--green-dark); }
.guard p { margin-top: 8px; font-size: 14.5px; line-height: 1.5; color: var(--ink-soft); }

@media (max-width: 980px) {
  .guard-grid { grid-template-columns: repeat(2, 1fr); }
  .guard, .guard:nth-child(4), .guard:nth-child(5) { grid-column: auto; }
}
@media (max-width: 560px) { .guard-grid { grid-template-columns: 1fr; } }

/* ---------- CTA FINAL -------------------------------------------------- */
.cta-final {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, #34663a, var(--green-title));
  color: var(--cream-light); text-align: center;
  padding: clamp(72px, 9vw, 120px) 0;
}
.cta-final .h-big {
  font-weight: 700; letter-spacing: -1px; line-height: 1.07;
  font-size: clamp(32px, 4.6vw, 54px); color: var(--cream-light); text-wrap: balance;
  max-width: 18ch; margin: 0 auto;
}
.cta-final .sub { margin: 22px auto 0; max-width: 52ch; font-size: clamp(17px,1.6vw,20px);
  line-height: 1.55; color: rgba(255,255,255,.82); }
.cta-final .btn { margin-top: 36px; }
.cta-final .reassure { margin-top: 18px; font-size: 14px; color: rgba(255,255,255,.62); }
.cta-final .leaf { color: #fff; opacity: .06; }

/* ---------- FOOTER ----------------------------------------------------- */
.site-footer { background: var(--cream-light); color: var(--green-dark); padding: clamp(48px,6vw,72px) 0 0; }
.foot-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 36px; }
.foot-brand .brand { margin-bottom: 14px; }
.foot-brand p { font-size: 14.5px; line-height: 1.55; color: var(--ink-soft); max-width: 30ch; }
.foot-col h4 { font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: var(--olive); margin-bottom: 16px; }
.foot-col ul { display: flex; flex-direction: column; gap: 11px; }
.foot-col a { font-size: 14.5px; color: var(--green-dark); transition: color .2s var(--ease);
  display: inline-flex; align-items: center; gap: 7px; }
.foot-col a:hover { color: var(--green-deep); }
.foot-col a .material-symbols-outlined { font-size: 17px; color: var(--olive); }
.foot-bar {
  margin-top: clamp(40px,5vw,56px); border-top: 1px solid var(--line);
  padding: 22px 0; display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.foot-bar .copy { font-size: 13px; color: var(--ink-soft); }
.foot-bar .legal { display: flex; gap: 20px; }
.foot-bar .legal a { font-size: 13px; color: var(--ink-soft); }
.foot-bar .legal a:hover { color: var(--green-deep); }

@media (max-width: 860px) {
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .foot-brand { grid-column: 1 / -1; }
  .foot-bar { flex-direction: column; text-align: center; }
}

/* =============================================================
   DEMO / CONTACT PAGE
   ============================================================= */
.demo-main { padding-top: 112px; padding-bottom: clamp(64px, 8vw, 110px);
  background: radial-gradient(1000px 500px at 12% -5%, rgba(213,234,176,.4), transparent 60%), var(--cream); min-height: 100vh; }
.demo-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(36px, 5vw, 72px); align-items: start; }

.demo-intro .h2 { text-align: left; font-size: clamp(32px,4vw,48px); }
.demo-intro .lead { margin-top: 20px; max-width: 42ch; }
.demo-intro .lead + .lead { margin-top: 14px; }

.next-steps { margin-top: clamp(36px, 4vw, 52px); position: relative; }
.next-steps h3 { font-size: 15px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: var(--olive); margin-bottom: 22px; }
.ns-line { position: relative; display: flex; flex-direction: column; gap: 8px; }
.ns-step { display: flex; gap: 18px; position: relative; padding-bottom: 26px; }
.ns-step:last-child { padding-bottom: 0; }
.ns-step .num {
  width: 44px; height: 44px; flex: none; border-radius: 50%; background: var(--olive);
  color: #fff; display: grid; place-items: center; font-size: 18px; font-weight: 700; z-index: 1;
}
.ns-step::before {
  content: ""; position: absolute; left: 21px; top: 44px; bottom: 0; width: 2px; background: var(--olive); opacity: .35;
}
.ns-step:last-child::before { display: none; }
.ns-body h4 { font-size: 17px; font-weight: 700; color: var(--green-title); }
.ns-body p { margin-top: 5px; font-size: 14.5px; line-height: 1.5; color: var(--ink-soft); }

/* form card */
.form-card { background: var(--cream-light); border-radius: var(--r-card); box-shadow: var(--shadow-3);
  border: 1px solid var(--line); padding: clamp(26px, 3.2vw, 40px); }
.form-card > h2 { font-size: 24px; font-weight: 600; color: var(--green-title); margin-bottom: 8px; }
.field { margin-top: 18px; }
.field label { display: block; font-size: 14px; font-weight: 600; color: var(--green-dark); margin-bottom: 7px; }
.field label .opt { font-weight: 500; color: var(--ink-soft); font-size: 12.5px; }
.field .req { color: var(--ocre); }
.field input, .field select, .field textarea {
  width: 100%; font-family: var(--font); font-size: 15px; color: var(--ink);
  background: var(--paper); border: 1.5px solid var(--outline, #bdbfb4); border-radius: 12px;
  padding: 13px 15px; transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field textarea { resize: vertical; min-height: 92px; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--olive); box-shadow: 0 0 0 3px rgba(123,142,92,.18);
}
.field-hint { display: block; margin-top: 6px; font-size: 12.5px; color: var(--ink-soft); }
.form-card .btn { margin-top: 24px; }
.priv-note { display: flex; gap: 9px; margin-top: 16px; font-size: 12.5px; line-height: 1.5; color: var(--ink-soft); }
.priv-note .material-symbols-outlined { font-size: 18px; color: var(--olive); flex: none; }
.alt-write { margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); font-size: 14px; color: var(--ink-soft); }
.alt-write a { color: var(--green-deep); font-weight: 600; }
.alt-write .placeholder { font-size: 12px; color: #9a9c8e; font-style: italic; }

/* form submission status (js/site.js) */
.form-status { margin-top: 14px; font-size: 13.5px; line-height: 1.5; font-weight: 600; }
.form-status[hidden] { display: none; }
.form-status.is-error { color: var(--md-sys-color-error, #940000); }
.form-status.is-ok { color: var(--green-deep); }

@media (max-width: 860px) { .demo-grid { grid-template-columns: 1fr; } }
