/* GoodGreet — booking funnel styles. */
.funnel{padding:42px 0 90px}
.funnel-wrap{max-width:720px}
.funnel-head h1{font-size:clamp(28px,4.4vw,40px);margin-bottom:20px}

.stepper{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0 0 26px;counter-reset:s}
.stepper li{counter-increment:s;font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.04em;color:#aeb6e0;
  display:flex;align-items:center;gap:7px;background:rgba(255,255,255,.07);border:1.5px solid var(--line);border-radius:30px;padding:6px 12px 6px 8px}
.stepper li::before{content:counter(s);display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;
  background:rgba(255,255,255,.14);color:#cfd3ee;font-size:11px}
.stepper li.active{color:#fff;background:var(--blue-bright);border-color:var(--blue-bright)}
.stepper li.active::before{background:#fff;color:var(--blue)}
.stepper li.done{color:#fff;border-color:var(--status)}
.stepper li.done::before{background:var(--status);color:#06351f;content:"\2713"}

.card{background:#fff;color:var(--ink);border-radius:16px;padding:30px 30px 26px;box-shadow:0 22px 60px rgba(0,0,0,.3)}
.card h2{font-size:23px;color:var(--ink);margin-bottom:18px}
.card h2.mt{margin-top:30px;padding-top:24px;border-top:1.5px solid #e6eaf4}
.hint{font-size:13.5px;color:var(--muted);margin:8px 0 0}

.fld{display:block;font-weight:700;font-size:13px;color:var(--ink);margin:16px 0 6px}
.input,textarea.input,select.input{width:100%;border:1.5px solid #cfd5e8;border-radius:9px;background:#f7f9fe;padding:12px 13px;font-size:15px;color:var(--ink);font-family:'Hanken Grotesk'}
.input:focus,textarea.input:focus,select.input:focus{outline:none;border-color:var(--blue);background:#fff}
.mono-in{font-family:'DM Mono',monospace;text-transform:uppercase}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.choice{position:relative;cursor:pointer;display:block}
.choice input{position:absolute;opacity:0;inset:0}
.choice-body{display:block;border:1.5px solid #d4d9ea;border-radius:12px;padding:20px 18px;background:#f7f9fe;transition:border-color .12s,background .12s}
.choice input:checked + .choice-body{border-color:var(--blue);background:#eef1fb;box-shadow:0 0 0 3px rgba(37,64,198,.12)}
.choice input:focus-visible + .choice-body{outline:3px solid var(--blue);outline-offset:2px}
.choice-ic{display:inline-flex;width:44px;height:44px;border-radius:10px;background:var(--blue);align-items:center;justify-content:center;margin-bottom:12px}
.choice-ic svg{width:24px;height:24px;stroke:#fff}
.choice-t{display:block;font-weight:800;font-size:17px}
.choice-d{display:block;font-size:13.5px;color:var(--muted);margin-top:4px}

.ac-wrap{position:relative}
.ac-list{list-style:none;margin:4px 0 0;padding:6px;position:absolute;left:0;right:0;z-index:20;background:#fff;border:1.5px solid #cfd5e8;border-radius:10px;box-shadow:0 14px 36px rgba(0,0,0,.16);max-height:240px;overflow:auto}
.ac-list li{padding:10px 12px;border-radius:7px;font-size:14px;cursor:pointer}
.ac-list li:hover,.ac-list li.sel{background:var(--paper)}

.safe-list{margin:10px 0 18px;padding-left:20px}
.safe-list li{font-size:14.5px;color:#3a3f55;margin:8px 0;line-height:1.5}
.ack{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;font-weight:600;background:var(--paper);border:1.5px solid #d4d9ea;border-radius:10px;padding:14px 16px;cursor:pointer}
.ack input{margin-top:3px;width:18px;height:18px;flex:0 0 auto}

.summary{margin:0 0 20px;display:grid;grid-template-columns:auto 1fr;gap:10px 18px}
.summary dt{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase}
.summary dd{margin:0;font-size:15px;color:var(--ink)}
.summary .edit{font-size:12px;color:var(--blue);font-weight:600;text-decoration:none;margin-left:8px;cursor:pointer}

.price-box{background:var(--paper);border:1.5px solid #d4d9ea;border-radius:12px;padding:16px 18px;margin-bottom:6px}
.pb-line{display:flex;justify-content:space-between;font-size:14.5px;color:#3a3f55;padding:5px 0}
.pb-line.total{font-weight:800;font-size:19px;color:var(--ink);border-top:1.5px solid #d4d9ea;margin-top:8px;padding-top:12px}

.fnav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:26px}
.card .btn{background:var(--blue);color:#fff;border-color:var(--blue);text-decoration:none}
.card .btn:hover{background:var(--blue-bright);border-color:var(--blue-bright);transform:none}
.card .btn--ghost{background:transparent;color:var(--blue)}
.card .btn--ghost:hover{background:var(--blue);color:#fff}
.btn .ar.rev{transition:transform .12s}
.btn--ghost:hover .ar.rev{transform:translateX(-4px)}

.err{color:#c0392b;font-size:13px;font-weight:600;margin-top:6px}
.input.bad{border-color:#c0392b;background:#fdf3f2}

.pay-total{display:flex;justify-content:space-between;align-items:baseline;font-size:16px;margin-bottom:18px;padding-bottom:14px;border-bottom:1.5px solid #e6eaf4}
.pay-total strong{font-size:24px}
#payment-element{margin-bottom:18px;min-height:40px}
.pay-btn{width:100%;justify-content:center;font-size:16px}
.pay-error{background:#fdf3f2;border:1.5px solid #e2a9a2;color:#9a1d1d;border-radius:9px;padding:12px 14px;font-size:14px;font-weight:600;margin-bottom:14px}
.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width:560px){
  .card{padding:22px 18px}
  .choice-grid,.row2{grid-template-columns:1fr}
}
