/* ============================================================
   MOREMEDIA® — Native Formulare (Typeform-/Calendly-Ersatz)
   UI-Schicht für mehrstufige Anfrage-Strecken + Terminbuchung.
   Nutzt die Theme-Tokens aus theme.css. Reines Frontend —
   Versand/Speicherung passiert serverseitig in Drupal 11.
   ============================================================ */

/* ---------- Page scaffold (formulare.html) ---------- */
.mmf-page{padding-top:clamp(120px,16vh,180px);padding-bottom:clamp(72px,11vh,150px);min-height:100vh;}
.mmf-head{max-width:var(--container);margin:0 auto;padding-inline:var(--pad);}
.mmf-eyebrow{font-family:var(--font-ui);font-weight:500;text-transform:uppercase;letter-spacing:.16em;
  font-size:.74rem;color:var(--muted);margin-bottom:clamp(16px,2vw,24px);}
.mmf-h1{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.03;
  font-size:clamp(2.3rem,5.2vw,4.6rem);color:var(--ink);text-wrap:balance;max-width:16ch;}
.mmf-lead{font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.6;color:var(--ink-2);max-width:52ch;
  margin-top:clamp(18px,2.4vw,28px);}

/* ---------- Strecken-Umschalter (segmented) ---------- */
.mmf-switch{display:flex;flex-wrap:wrap;gap:10px;margin-top:clamp(34px,4.5vw,56px);}
.mmf-switch button{font-family:var(--font-ui);font-weight:500;font-size:.95rem;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:.6em;padding:.85em 1.5em;border-radius:var(--r-pill);
  border:1.5px solid var(--line-strong);background:transparent;color:var(--ink);cursor:pointer;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);}
.mmf-switch button .n{font-variant-numeric:tabular-nums;color:var(--muted);font-size:.8rem;}
.mmf-switch button:hover{border-color:var(--ink);}
.mmf-switch button[aria-selected="true"]{background:var(--ink);border-color:var(--ink);color:#fff;}
.mmf-switch button[aria-selected="true"] .n{color:rgba(255,255,255,.6);}

/* ---------- Form card ---------- */
.mmf-stage{max-width:var(--container);margin:clamp(34px,4.5vw,56px) auto 0;padding-inline:var(--pad);}
.mmf-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:clamp(26px,4vw,56px);box-shadow:0 1px 0 rgba(21,20,15,.03),0 30px 70px -52px rgba(21,20,15,.5);
  position:relative;overflow:hidden;}

/* ---------- Progress ---------- */
.mmf-prog{display:flex;align-items:center;gap:10px;margin-bottom:clamp(26px,3.6vw,40px);}
.mmf-prog__steps{display:flex;align-items:center;gap:8px;flex:1;min-width:0;}
.mmf-prog__dot{flex:1;height:4px;border-radius:99px;background:var(--paper-warm-2);overflow:hidden;
  position:relative;}
.mmf-prog__dot::after{content:"";position:absolute;inset:0;width:0;background:var(--ink);
  transition:width .5s var(--ease);}
.mmf-prog__dot.is-done::after{width:100%;}
.mmf-prog__dot.is-active::after{width:60%;}
.mmf-prog__label{font-family:var(--font-ui);font-weight:500;font-size:.78rem;letter-spacing:.04em;
  color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums;flex:0 0 auto;}

/* ---------- Step ---------- */
.mmf-step{display:none;}
.mmf-step.is-active{display:grid;grid-template-columns:minmax(250px,330px) minmax(0,1fr);
  gap:clamp(34px,5vw,96px);align-items:start;animation:mmf-in .45s var(--ease);}
.mmf-step__intro{position:sticky;top:clamp(88px,12vh,120px);}
.mmf-step.is-active>.mmf-fields{margin-top:0;}
.mmf-step.is-booking.is-active{display:block;}
.mmf-step.is-booking .mmf-step__intro{position:static;margin-bottom:clamp(20px,3vw,30px);}
@keyframes mmf-in{from{transform:translateY(10px);}to{transform:none;}}
.mmf-step__eyebrow{font-family:var(--font-ui);font-weight:500;text-transform:uppercase;
  letter-spacing:.14em;font-size:.7rem;color:var(--muted);margin-bottom:14px;}
.mmf-step__title{font-family:var(--font-display);font-weight:700;letter-spacing:-.015em;line-height:1.08;
  font-size:clamp(1.5rem,3vw,2.3rem);color:var(--ink);text-wrap:balance;}
.mmf-step__sub{font-size:1.02rem;line-height:1.6;color:var(--ink-2);margin-top:12px;max-width:50ch;}
.mmf-fields{display:flex;flex-direction:column;gap:clamp(20px,2.6vw,30px);margin-top:clamp(24px,3.2vw,38px);}

/* ---------- Grouped details (Mehrfachauswahl) ---------- */
.mmf-group{padding-top:clamp(22px,3vw,32px);border-top:1px solid var(--line);}
.mmf-group:first-child{padding-top:0;border-top:0;}
.mmf-group__head{font-family:var(--font-display);font-weight:700;font-size:clamp(1.12rem,1.6vw,1.3rem);
  letter-spacing:-.01em;color:var(--ink);display:flex;align-items:center;gap:.55em;}
.mmf-group__head::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--ink);flex:0 0 auto;}
.mmf-group__info{font-size:.9rem;color:var(--muted);line-height:1.55;margin:6px 0 0 1.05em;max-width:54ch;}
.mmf-group .mmf-fields{margin-top:clamp(16px,2vw,22px);}

/* ---------- "Andere" Freitext (inline) ---------- */
.mmf-otherinput{display:none;margin-top:12px;}
.mmf-field.show-other .mmf-otherinput{display:block;}

/* ---------- Field block ---------- */
.mmf-field>.mmf-label{display:block;font-family:var(--font-ui);font-weight:500;font-size:1.02rem;
  color:var(--ink);margin-bottom:12px;}
.mmf-field .req{color:var(--ink);}
.mmf-field .opt{color:var(--muted);font-weight:400;font-size:.86em;}
.mmf-help{font-size:.86rem;color:var(--muted);margin-top:9px;line-height:1.5;}

/* text inputs */
.mmf-input,.mmf-textarea,.mmf-select{width:100%;max-width:640px;font-family:var(--font-ui);font-size:1.05rem;
  color:var(--ink);background:var(--paper-warm);border:1.5px solid transparent;border-radius:var(--r-md);
  padding:.92em 1.05em;line-height:1.5;transition:border-color .25s var(--ease),background .25s var(--ease);
  -webkit-appearance:none;appearance:none;}
.mmf-textarea{min-height:130px;resize:vertical;}
.mmf-input::placeholder,.mmf-textarea::placeholder{color:var(--muted-2);}
.mmf-input:focus,.mmf-textarea:focus,.mmf-select:focus{outline:none;border-color:var(--ink);
  background:var(--paper);}
.mmf-input:focus-visible{outline:none;}
.mmf-row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.mmf-row2 .mmf-input,.mmf-row2 .mmf-select{max-width:none;}
.mmf-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2315140F' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1.05em center;padding-right:2.6em;cursor:pointer;}

/* chips */
.mmf-chips{display:flex;flex-wrap:wrap;gap:10px;}
.mmf-chip{font-family:var(--font-ui);font-weight:500;font-size:.95rem;padding:.7em 1.25em;
  border-radius:var(--r-pill);border:1.5px solid var(--line-strong);background:transparent;color:var(--ink);
  cursor:pointer;transition:background .22s var(--ease),color .22s var(--ease),border-color .22s var(--ease);
  display:inline-flex;align-items:center;gap:.5em;}
.mmf-chip:hover{border-color:var(--ink);}
.mmf-chip[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:#fff;}
.mmf-chip[aria-pressed="true"] .mmf-chip__tick{opacity:1;width:14px;margin-right:-2px;}
.mmf-chip__tick{opacity:0;width:0;height:14px;overflow:hidden;transition:opacity .2s,width .2s;}

/* choice cards */
.mmf-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;}
.mmf-cardopt{text-align:left;font-family:var(--font-ui);background:var(--paper-warm);
  border:1.5px solid transparent;border-radius:var(--r-md);padding:1.1em 1.2em;cursor:pointer;
  transition:border-color .22s var(--ease),background .22s var(--ease),transform .22s var(--ease);
  display:flex;flex-direction:column;gap:6px;position:relative;}
.mmf-cardopt:hover{border-color:var(--line-strong);}
.mmf-cardopt[aria-pressed="true"]{border-color:var(--ink);background:var(--paper);}
.mmf-cardopt__t{font-weight:500;font-size:1.06rem;color:var(--ink);letter-spacing:-.005em;padding-right:30px;}
.mmf-cardopt__d{font-size:.86rem;color:var(--muted);line-height:1.45;}
.mmf-cardopt__check{position:absolute;top:12px;right:12px;width:20px;height:20px;border-radius:50%;
  border:1.5px solid var(--line-strong);display:grid;place-items:center;transition:all .22s var(--ease);}
.mmf-cardopt__check svg{width:12px;height:12px;opacity:0;transform:scale(.5);transition:all .22s var(--ease);
  stroke:#fff;}
.mmf-cardopt[aria-pressed="true"] .mmf-cardopt__check{background:var(--ink);border-color:var(--ink);}
.mmf-cardopt[aria-pressed="true"] .mmf-cardopt__check svg{opacity:1;transform:none;}

/* consent */
.mmf-consent{display:flex;gap:13px;align-items:flex-start;cursor:pointer;font-size:.95rem;
  line-height:1.55;color:var(--ink-2);}
.mmf-consent input{position:absolute;opacity:0;width:1px;height:1px;}
.mmf-consent__box{flex:0 0 auto;width:22px;height:22px;border-radius:6px;border:1.5px solid var(--line-strong);
  margin-top:1px;display:grid;place-items:center;transition:all .2s var(--ease);}
.mmf-consent__box svg{width:13px;height:13px;stroke:#fff;opacity:0;transform:scale(.5);transition:all .2s var(--ease);}
.mmf-consent input:checked+.mmf-consent__box{background:var(--ink);border-color:var(--ink);}
.mmf-consent input:checked+.mmf-consent__box svg{opacity:1;transform:none;}
.mmf-consent input:focus-visible+.mmf-consent__box{outline:2px solid var(--ink);outline-offset:2px;}
.mmf-consent a{text-decoration:underline;text-underline-offset:2px;}

/* validation */
/* validation — roter Rahmen DIREKT an den Controls (folgt dem Radius, wird NICHT vom
   overflow:hidden der Card links/rechts beschnitten – kein „offener" Offset-Rahmen mehr) */
.mmf-field.has-error .mmf-input,.mmf-field.has-error .mmf-textarea,.mmf-field.has-error .mmf-select{
  background:#fbf2f0;border-color:#a3331f;}
.mmf-field.has-error .mmf-chip,.mmf-field.has-error .mmf-cardopt{border-color:#a3331f;}
/* Pflicht-Checkbox bei Fehler ebenfalls rot markieren */
.mmf-field.has-error .mmf-consent__box{border-color:#a3331f;background:#fbf2f0;}
.mmf-field.has-error .mmf-consent{color:#a3331f;}
.mmf-err{display:none;color:#a3331f;font-size:.84rem;margin-top:9px;font-weight:500;}
.mmf-field.has-error .mmf-err{display:block;}

/* ---------- Footer nav ---------- */
.mmf-nav{display:flex;align-items:center;justify-content:space-between;gap:16px;
  margin-top:clamp(30px,4vw,46px);padding-top:clamp(22px,3vw,30px);border-top:1px solid var(--line);}
.mmf-btn{font-family:var(--font-ui);font-weight:500;font-size:.98rem;letter-spacing:.01em;
  display:inline-flex;align-items:center;gap:.6em;padding:1em 2em;border-radius:var(--r-pill);
  border:1.5px solid var(--ink);cursor:pointer;background:transparent;color:var(--ink);
  transition:background .3s var(--ease),color .3s var(--ease),opacity .3s var(--ease),transform .15s var(--ease);}
.mmf-btn svg{width:17px;height:17px;}
.mmf-btn--primary{background:var(--ink);color:#fff;}
.mmf-btn--primary:hover{background:#000;}
.mmf-btn--ghost:hover{background:var(--ink);color:#fff;}
.mmf-btn:disabled{opacity:.32;cursor:not-allowed;}
.mmf-btn--ghost[hidden]{display:none;}
.mmf-nav__spacer{flex:1;}

/* ---------- Calendar (Terminbuchung) ---------- */
.mmf-booking{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,3.4vw,44px);align-items:start;}
.mmf-cal{}
.mmf-cal__bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.mmf-cal__month{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--ink);
  letter-spacing:-.01em;}
.mmf-cal__nav{display:flex;gap:8px;}
.mmf-cal__nav button{width:38px;height:38px;border-radius:50%;border:1.5px solid var(--line-strong);
  background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--ink);
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s,opacity .2s;}
.mmf-cal__nav button:hover{border-color:var(--ink);background:var(--ink);color:#fff;}
.mmf-cal__nav button:disabled{opacity:.3;cursor:not-allowed;}
.mmf-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;}
.mmf-cal__wd{text-align:center;font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);padding-bottom:8px;}
.mmf-day{aspect-ratio:1;border:1.5px solid transparent;border-radius:var(--r-md);background:transparent;
  font-family:var(--font-ui);font-size:1rem;font-weight:500;color:var(--ink);cursor:pointer;position:relative;
  display:grid;place-items:center;transition:background .18s var(--ease),color .18s var(--ease),border-color .18s;}
.mmf-day.is-empty{cursor:default;}
.mmf-day.is-unavail{color:var(--muted-2);cursor:not-allowed;}
.mmf-day.is-avail:hover{border-color:var(--ink);}
.mmf-day.is-avail::after{content:"";position:absolute;bottom:7px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--ink);opacity:.55;}
.mmf-day.is-today{border-color:var(--line-strong);}
.mmf-day.is-selected{background:var(--ink);color:#fff;border-color:var(--ink);}
.mmf-day.is-selected::after{background:#fff;opacity:1;}

/* slots */
.mmf-slots{}
.mmf-slots__head{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--ink);
  margin-bottom:4px;}
.mmf-slots__type{font-size:.86rem;color:var(--muted);margin-bottom:16px;display:flex;align-items:center;gap:.5em;}
.mmf-slots__type svg{width:1.15em;height:1.15em;flex:0 0 auto;}
.mmf-cal__nav button svg{width:18px;height:18px;}
.mmf-slots__list{display:flex;flex-direction:column;gap:9px;max-height:300px;overflow:auto;
  padding-right:4px;}
.mmf-slot{font-family:var(--font-ui);font-weight:500;font-size:1rem;text-align:left;width:100%;
  padding:.85em 1.1em;border-radius:var(--r-md);border:1.5px solid var(--line-strong);background:transparent;
  color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s;}
.mmf-slot:hover{border-color:var(--ink);}
.mmf-slot[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:#fff;}
.mmf-slot.is-booked{opacity:.4;text-decoration:line-through;cursor:not-allowed;}
.mmf-slot .dur{font-size:.82rem;color:var(--muted);font-weight:400;}
.mmf-slot[aria-pressed="true"] .dur{color:rgba(255,255,255,.6);}
.mmf-slots__empty{color:var(--muted);font-size:.95rem;padding:30px 0;text-align:center;line-height:1.6;}

/* ---------- Success ---------- */
.mmf-done{text-align:center;padding:clamp(20px,4vw,46px) 0;animation:mmf-in .45s var(--ease);max-width:780px;margin-inline:auto;}
.mmf-done>*{animation:mmf-rise .6s var(--ease) both;}
.mmf-done>*:nth-child(2){animation-delay:.16s;}
.mmf-done>*:nth-child(3){animation-delay:.26s;}
.mmf-done>*:nth-child(4){animation-delay:.36s;}
.mmf-done>*:nth-child(5){animation-delay:.46s;}
@keyframes mmf-rise{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
.mmf-done.is-settled>*{opacity:1!important;transform:none!important;}
.mmf-done.is-settled .mmf-done__mark svg path{stroke-dashoffset:0!important;}
.mmf-done__mark{width:74px;height:74px;border-radius:50%;background:var(--ink);margin:0 auto 26px;
  display:grid;place-items:center;position:relative;animation:mmf-pop .6s var(--ease) both;}
.mmf-done__mark svg{width:34px;height:34px;stroke:#fff;position:relative;}
.mmf-done__mark svg path{stroke-dasharray:34;stroke-dashoffset:0;animation:mmf-draw .55s var(--ease) .34s both;}
@keyframes mmf-draw{from{stroke-dashoffset:34;}to{stroke-dashoffset:0;}}
.mmf-done__burst{position:absolute;inset:-5px;border-radius:50%;border:2px solid var(--ink);opacity:0;
  animation:mmf-burst .8s var(--ease) .12s;}
@keyframes mmf-burst{0%{transform:scale(.62);opacity:.5;}100%{transform:scale(1.55);opacity:0;}}
@keyframes mmf-pop{0%{transform:scale(.5);}60%{transform:scale(1.08);}100%{transform:scale(1);}}
.mmf-done__t{font-family:var(--font-display);font-weight:700;font-size:clamp(1.6rem,3.2vw,2.5rem);
  letter-spacing:-.015em;color:var(--ink);line-height:1.1;text-wrap:balance;}
.mmf-done__p{font-size:1.05rem;color:var(--ink-2);line-height:1.6;max-width:44ch;margin:14px auto 0;}
.mmf-summary{margin:clamp(26px,3.4vw,38px) auto 0;max-width:420px;text-align:left;
  background:var(--paper-warm);border-radius:var(--r-md);padding:22px 24px;}
.mmf-summary__row{display:flex;justify-content:space-between;gap:18px;padding:9px 0;
  border-bottom:1px solid var(--line);font-size:.96rem;}
.mmf-summary__row:last-child{border-bottom:0;}
.mmf-summary__row .k{color:var(--muted);}
.mmf-summary__row .v{color:var(--ink);font-weight:500;text-align:right;}
.mmf-done__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:clamp(26px,3.4vw,38px);}

/* ---------- Interner Lead-Score (Demo / CRM-Vorschau) ---------- */
.mmf-intern{margin-top:clamp(26px,3.4vw,40px);text-align:left;background:var(--ink);color:#fff;
  border-radius:var(--r-lg);padding:clamp(18px,2.4vw,26px);}
.mmf-intern__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px;}
.mmf-intern__tag{font-family:var(--font-ui);font-weight:600;font-size:.72rem;letter-spacing:.05em;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:.5em;}
.mmf-intern__tag::before{content:"";width:7px;height:7px;border-radius:50%;background:#f0c000;}
.mmf-intern__note{font-size:.78rem;color:rgba(255,255,255,.5);}
.mmf-intern__grid{display:flex;align-items:center;gap:20px;}
.mmf-intern__ring{position:relative;width:74px;height:74px;flex:0 0 auto;display:grid;place-items:center;}
.mmf-intern__ring svg{position:absolute;inset:0;width:100%;height:100%;}
.mmf-intern__ring b{position:relative;font-family:var(--font-display);font-weight:700;font-size:1.5rem;}
.mmf-intern__tier{font-weight:600;font-size:1.04rem;display:flex;align-items:center;gap:.5em;}
.mmf-intern__tier .dot{width:9px;height:9px;border-radius:50%;background:#fff;flex:0 0 auto;}
.mmf-intern[data-tier="A"] .mmf-intern__tier .dot{background:#37d27a;}
.mmf-intern[data-tier="B"] .mmf-intern__tier .dot{background:#8fd14f;}
.mmf-intern[data-tier="C"] .mmf-intern__tier .dot{background:#f0c000;}
.mmf-intern[data-tier="D"] .mmf-intern__tier .dot{background:#e0795a;}
.mmf-intern__val{font-size:.9rem;color:rgba(255,255,255,.72);margin-top:6px;}
.mmf-intern__val b{color:#fff;}
.mmf-intern__val span{color:rgba(255,255,255,.5);}
.mmf-intern__ai{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.14);}
.mmf-intern__ai-head{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.55);
  font-weight:600;margin-bottom:12px;}
.mmf-intern__ai-body{font-size:.92rem;color:rgba(255,255,255,.85);line-height:1.55;
  display:flex;align-items:center;gap:.6em;flex-wrap:wrap;}
.mmf-intern__ai-body em{color:rgba(255,255,255,.6);font-style:italic;}
.mmf-spin{width:15px;height:15px;border-radius:50%;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;
  display:inline-block;animation:mmf-spin .7s linear infinite;}
@keyframes mmf-spin{to{transform:rotate(360deg);}}
.mmf-intern__bars{display:flex;flex-direction:column;gap:9px;width:100%;margin-bottom:13px;}
.mmf-intern__bar2{display:grid;grid-template-columns:132px 1fr 42px;align-items:center;gap:10px;font-size:.84rem;}
.mmf-intern__bar2 .l{color:rgba(255,255,255,.7);}
.mmf-intern__bar2 .t{height:7px;border-radius:99px;background:rgba(255,255,255,.16);overflow:hidden;}
.mmf-intern__bar2 .t i{display:block;height:100%;background:#fff;border-radius:99px;}
.mmf-intern__bar2 .v{text-align:right;font-variant-numeric:tabular-nums;color:#fff;}
.mmf-intern__assess{width:100%;margin:0;}
.mmf-intern__next{width:100%;margin:9px 0 0;color:rgba(255,255,255,.75);font-size:.88rem;}
.mmf-intern__next b{color:#fff;}
@media(max-width:520px){
  .mmf-intern__bar2{grid-template-columns:1fr 42px;}
  .mmf-intern__bar2 .t{grid-column:1 / -1;order:3;}
}

/* note / prototype hint */
.mmf-note{display:flex;align-items:flex-start;gap:10px;margin-top:18px;font-size:.82rem;color:var(--muted);
  line-height:1.5;}
.mmf-note svg{flex:0 0 auto;width:16px;height:16px;margin-top:1px;stroke:var(--muted);}

/* trust strip below card */
.mmf-trust{max-width:var(--container);margin:22px auto 0;padding-inline:var(--pad);display:flex;flex-wrap:wrap;
  gap:clamp(16px,3vw,40px);color:var(--muted);font-size:.9rem;}
.mmf-trust span{display:inline-flex;align-items:center;gap:.55em;}
.mmf-trust svg{width:16px;height:16px;stroke:var(--muted);}

/* ---------- Overlay mode ---------- */
.mmf-overlay{position:fixed;inset:0;z-index:2000;display:none;}
.mmf-overlay.is-open{display:block;}
.mmf-overlay__scrim{position:absolute;inset:0;background:rgba(21,20,15,.55);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .4s var(--ease);}
.mmf-overlay.is-open .mmf-overlay__scrim{opacity:1;}
.mmf-overlay__panel{position:absolute;top:0;right:0;height:100%;width:min(640px,100%);
  background:var(--paper);box-shadow:-30px 0 80px -40px rgba(21,20,15,.6);
  transform:translateX(100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;}
.mmf-overlay.is-open .mmf-overlay__panel{transform:none;}
.mmf-overlay__bar{display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,3vw,34px);border-bottom:1px solid var(--line);flex:0 0 auto;}
.mmf-overlay__brand{font-family:var(--font-display);font-weight:700;letter-spacing:-.01em;font-size:1.05rem;}
.mmf-overlay__brand sup{font-size:.6em;}
.mmf-overlay__title{font-family:var(--font-ui);font-weight:600;font-size:.95rem;letter-spacing:.01em;color:var(--ink);margin-right:auto;}
.mmf-overlay__close{width:42px;height:42px;border-radius:50%;border:1.5px solid var(--line-strong);
  background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--ink);
  transition:background .2s var(--ease),color .2s var(--ease);}
.mmf-overlay__close:hover{background:var(--ink);color:#fff;}
.mmf-overlay__close svg{width:18px;height:18px;}
.mmf-overlay__body{flex:1;overflow:auto;padding:clamp(22px,3.4vw,40px) clamp(20px,3vw,34px);
  -webkit-overflow-scrolling:touch;}
.mmf-overlay .mmf-card{border:0;box-shadow:none;padding:0;background:transparent;}
.mmf-overlay .mmf-step.is-active{display:block;}
.mmf-overlay .mmf-step__intro{position:static;margin-bottom:clamp(18px,3vw,26px);}
.mmf-overlay .mmf-booking{grid-template-columns:1fr;}
html.mmf-lock,body.mmf-lock{overflow:hidden;}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .mmf-step.is-active{display:block;}
  .mmf-step__intro{position:static;margin-bottom:clamp(18px,3vw,26px);}
  .mmf-step.is-active>.mmf-fields{margin-top:clamp(20px,3vw,30px);}
}
@media(max-width:760px){
  .mmf-booking{grid-template-columns:1fr;}
  .mmf-row2{grid-template-columns:1fr;}
  .mmf-cards{grid-template-columns:1fr 1fr;}
  .mmf-nav{flex-wrap:wrap;}
  .mmf-btn{flex:1;justify-content:center;}
  .mmf-prog__label{display:none;}
}
@media(max-width:460px){
  .mmf-cards{grid-template-columns:1fr;}
}
