/* ═══════════════════════════════════════
   L'épilation Probebehandlung – Form CSS
   ═══════════════════════════════════════ */

.ob-msf * { box-sizing: border-box; }
.ob-msf { max-width: 640px; margin: 0 auto; padding: 60px 24px 80px; }

.ob-msf-header { text-align: center; margin-bottom: 36px; }
.ob-msf-header .ob-overline { font-family: ui-sans-serif, system-ui, sans-serif; font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 3px; color: #E9BCB9; margin: 0 0 12px; }
.ob-msf-header .ob-h2 { font-family: 'Playfair Display', Georgia, serif; font-size: clamp(22px, 3vw, 28px); font-weight: 400; color: #2a2a2a; margin: 0 0 8px; line-height: 1.3; }
.ob-msf-header .ob-h2-sub { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; font-weight: 400; color: #707475; margin: 0; }

/* Stepper */
.ob-msf-stepper { display: flex; align-items: center; justify-content: center; margin-bottom: 36px; }
.ob-msf-dot { width: 32px; height: 32px; border-radius: 50%; border: 2px solid #e5e5e5; display: flex; align-items: center; justify-content: center; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 12px; font-weight: 600; color: #ccc; transition: all .3s ease; background: #fff; }
.ob-msf-dot--active { border-color: #E9BCB9; background: #E9BCB9; color: #fff; }
.ob-msf-dot--done { border-color: #27ae60; background: #27ae60; color: #fff; }
.ob-msf-line { width: 40px; height: 2px; background: #e5e5e5; transition: background .3s ease; }
.ob-msf-line--done { background: #27ae60; }

/* Steps */
.ob-msf-step { display: none; }
.ob-msf-step--active { display: block; }
.ob-msf-q { font-family: 'Playfair Display', Georgia, serif; font-size: 18px; font-weight: 400; color: #2a2a2a; text-align: center; margin: 0 0 20px; }

/* Tiles */
.ob-msf-tiles { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 24px; }
.ob-msf-tiles--wide { grid-template-columns: repeat(4, 1fr); }
.ob-msf-tile { display: flex; align-items: center; justify-content: center; background: #fff; border: 1.5px solid #f0eeee; border-radius: 8px; padding: 14px 12px; cursor: pointer; transition: all .2s ease; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 13px; font-weight: 400; color: #444; text-align: center; user-select: none; }
.ob-msf-tile:hover { border-color: #E9BCB9; }
.ob-msf-tile--selected { border-color: #E9BCB9 !important; background: rgba(233, 188, 185, .08) !important; color: #2a2a2a !important; font-weight: 500 !important; }

/* Inputs */
.ob-msf-input-group { margin-bottom: 14px; }
.ob-msf-label { display: block; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 12px; font-weight: 500; color: #2a2a2a; margin-bottom: 6px; text-align: left; }
.ob-msf-input { width: 100%; padding: 12px 16px; border: 1.5px solid #e5e5e5; border-radius: 8px; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 14px; font-weight: 300; color: #2a2a2a; outline: none; transition: border-color .2s ease; background: #fff; }
.ob-msf-input:focus { border-color: #E9BCB9; }
.ob-msf-input-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ob-msf-select { width: 100%; padding: 12px 16px; border: 1.5px solid #e5e5e5; border-radius: 8px; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 14px; font-weight: 300; color: #2a2a2a; outline: none; background: #fff; cursor: pointer; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; }
.ob-msf-select:focus { border-color: #E9BCB9; }
.ob-msf-textarea { width: 100%; padding: 12px 16px; border: 1.5px solid #e5e5e5; border-radius: 8px; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 14px; font-weight: 300; color: #2a2a2a; outline: none; resize: vertical; min-height: 80px; background: #fff; }
.ob-msf-textarea:focus { border-color: #E9BCB9; }

/* Summary */
.ob-msf-summary { text-align: left; background: #fff; border: 1px solid #f0eeee; border-radius: 8px; padding: 20px 24px; margin-bottom: 16px; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 13px; font-weight: 300; color: #707475; line-height: 1.8; }

/* Checkbox */
.ob-msf-check { display: flex; align-items: flex-start; gap: 10px; margin: 16px 0 24px; text-align: left; }
.ob-msf-check input[type="checkbox"] { margin-top: 3px; accent-color: #E9BCB9; cursor: pointer; width: 16px; height: 16px; }
.ob-msf-check label { font-family: ui-sans-serif, system-ui, sans-serif; font-size: 12px; font-weight: 300; color: #707475; line-height: 1.5; cursor: pointer; }
.ob-msf-check label a { color: #E9BCB9; text-decoration: underline; }

/* Nav */
.ob-msf-nav { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 8px; }

.ob-msf-btn-back, .ob-msf-btn-back:hover, .ob-msf-btn-back:focus, .ob-msf-btn-back:active { display: inline-flex !important; align-items: center !important; gap: 6px !important; padding: 12px 20px !important; background: transparent !important; color: #999 !important; font-family: ui-sans-serif, system-ui, sans-serif !important; font-size: 12px !important; font-weight: 400 !important; border: none !important; box-shadow: none !important; cursor: pointer !important; text-decoration: none !important; outline: none !important; }
.ob-msf-btn-back:hover { color: #444 !important; }
.ob-msf-btn-back svg { width: 14px; height: 14px; stroke: currentColor; fill: none; stroke-width: 2; stroke-linecap: round; }

.ob-msf-btn-next, .ob-msf-btn-next:hover, .ob-msf-btn-next:focus, .ob-msf-btn-next:active, .ob-msf-btn-next:visited { display: inline-block !important; padding: 14px 32px !important; font-family: ui-sans-serif, system-ui, sans-serif !important; font-size: 11px !important; font-weight: 600 !important; letter-spacing: 2px !important; text-transform: uppercase !important; text-decoration: none !important; box-shadow: none !important; outline: none !important; cursor: pointer !important; border-radius: 0 !important; }
.ob-msf-btn-next { background: #E9BCB9 !important; color: #fff !important; border: 1px solid #E9BCB9 !important; }
.ob-msf-btn-next:hover { background: #d4a49f !important; border-color: #d4a49f !important; color: #fff !important; }
.ob-msf-btn-next:disabled { background: #e5e5e5 !important; border-color: #e5e5e5 !important; color: #bbb !important; cursor: not-allowed !important; }

/* Success */
.ob-msf-success { text-align: center; padding: 40px 20px; }
.ob-msf-success-icon { width: 56px; height: 56px; border-radius: 50%; background: rgba(39, 174, 96, .1); display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.ob-msf-success-icon svg { width: 28px; height: 28px; stroke: #27ae60; fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.ob-msf-success h3 { font-family: 'Playfair Display', Georgia, serif; font-size: 22px; font-weight: 400; color: #2a2a2a; margin: 0 0 8px; }
.ob-msf-success p { font-family: ui-sans-serif, system-ui, sans-serif; font-size: 14px; font-weight: 300; color: #707475; line-height: 1.7; margin: 0; }

.ob-msf-footer-hint { text-align: center; margin-top: 24px; font-family: ui-sans-serif, system-ui, sans-serif; font-size: 11px; font-weight: 300; color: #bbb; font-style: italic; }

/* Responsive */
@media (max-width: 767px) {
  .ob-msf { padding: 40px 20px 60px; }
  .ob-msf-tiles { grid-template-columns: 1fr 1fr; }
  .ob-msf-tiles--wide { grid-template-columns: 1fr 1fr; }
  .ob-msf-input-row { grid-template-columns: 1fr; }
  .ob-msf-nav { flex-direction: column-reverse; gap: 8px; }
  .ob-msf-btn-next { width: 100% !important; text-align: center !important; }
}
