:root{
    --purple:#7c3aed; --purple-d:#6d28d9; --ink:#1f2937; --muted:#6b7280;
    --line:#e5e7eb; --bg:#f6f5fb; --ok:#16a34a; --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
    color:var(--ink);background:var(--bg);line-height:1.5}
.wrap{max-width:920px;margin:0 auto;padding:0 16px}
a{color:inherit;text-decoration:none}

/* Topbar */
.topbar{background:#fff;border-bottom:1px solid var(--line)}
.topbar-in{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:12px}
.logo{display:grid;place-items:center;width:40px;height:40px;border-radius:10px;
    background:var(--purple);color:#fff;font-size:20px}
.brand-name{font-weight:700}
.brand-sub{font-size:13px;color:var(--muted)}
.phone{font-weight:600;color:var(--purple)}

/* Hero */
.hero{background:linear-gradient(135deg,var(--purple),#a855f7);color:#fff;padding:46px 0}
.hero h1{margin:0 0 8px;font-size:30px}
.hero p{margin:0;opacity:.9}
.hero-note{margin-top:16px;padding:12px 16px;border-radius:var(--radius);
    background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);
    font-size:14.5px;line-height:1.5}
.hero-note a{text-decoration:underline;font-weight:600;white-space:nowrap}

/* Booking card */
.booking{position:relative;background:#fff;border-radius:var(--radius);
    box-shadow:0 10px 30px rgba(31,41,55,.08);margin:-26px 0 24px;padding:26px}
.card{border:1px solid var(--line)}

/* Steps */
.steps{display:flex;gap:8px;list-style:none;margin:0 0 22px;padding:0;flex-wrap:wrap}
.steps li{display:flex;align-items:center;gap:8px;color:var(--muted);font-weight:600;
    font-size:14px;padding:6px 12px;border-radius:999px;background:#f3f4f6}
.steps li span{display:grid;place-items:center;width:22px;height:22px;border-radius:50%;
    background:#d1d5db;color:#fff;font-size:13px}
.steps li.active{color:var(--purple);background:#f1ebff}
.steps li.active span{background:var(--purple)}
.steps li.done span{background:var(--ok)}

h2{font-size:20px;margin:0 0 16px}

/* Services */
.services{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.svc{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;
    border:1px solid var(--line);border-radius:12px;padding:14px 16px;cursor:pointer;
    transition:.15s;background:#fff;text-align:left}
.svc:hover{border-color:var(--purple);box-shadow:0 4px 14px rgba(124,58,237,.12)}
.svc-name{font-weight:700}
.svc-desc{font-size:13px;color:var(--muted);margin-top:2px}
.svc-meta{white-space:nowrap;text-align:right}
.svc-price{font-weight:800;color:var(--purple)}
.svc-len{font-size:13px;color:var(--muted)}

/* Date bar */
.datebar{display:flex;align-items:center;gap:8px;margin-bottom:18px}
.days{display:flex;gap:8px;overflow:auto;flex:1;padding-bottom:4px}
.day{flex:0 0 auto;min-width:64px;border:1px solid var(--line);border-radius:12px;
    padding:10px 8px;text-align:center;cursor:pointer;background:#fff;transition:.15s}
.day:hover{border-color:var(--purple)}
.day.active{background:var(--purple);color:#fff;border-color:var(--purple)}
.day.closed{opacity:.4;cursor:not-allowed}
.day .dow{font-size:12px;text-transform:uppercase}
.day .num{font-size:18px;font-weight:700}
.day .mon{font-size:11px;color:inherit;opacity:.8}
.nav{width:36px;height:36px;border-radius:10px;border:1px solid var(--line);
    background:#fff;cursor:pointer;font-size:18px;color:var(--purple)}

/* Slots */
.slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:10px}
.slot{padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;
    cursor:pointer;font-weight:600;transition:.15s}
.slot:hover{border-color:var(--purple);color:var(--purple)}
.empty{grid-column:1/-1;color:var(--muted);padding:18px 0;text-align:center}

/* Form */
.form{display:grid;gap:14px;max-width:460px}
.form label{display:grid;gap:6px;font-weight:600;font-size:14px}
.form input,.form textarea{font:inherit;padding:11px 12px;border:1px solid var(--line);
    border-radius:10px;width:100%}
.form input:focus,.form textarea:focus{outline:2px solid #c4b5fd;border-color:var(--purple)}

/* Buttons */
.actions{display:flex;gap:10px;margin-top:6px}
.btn{background:var(--purple);color:#fff;border:0;border-radius:10px;padding:12px 20px;
    font:inherit;font-weight:700;cursor:pointer;transition:.15s}
.btn:hover{background:var(--purple-d)}
.btn:disabled{opacity:.6;cursor:wait}
.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{border-color:var(--purple);color:var(--purple)}

/* Summary */
.summary{position:absolute;top:26px;right:-244px;width:220px;background:#faf9ff;
    border:1px solid var(--line);border-radius:12px;padding:16px}
.summary h3{margin:0 0 10px;font-size:15px}
.summary dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:6px 10px;font-size:14px}
.summary dt{color:var(--muted)}
.summary dd{margin:0;text-align:right;font-weight:600}

/* Done */
.done{text-align:center;padding:14px}
.check{width:64px;height:64px;border-radius:50%;background:var(--ok);color:#fff;
    font-size:34px;display:grid;place-items:center;margin:0 auto 14px}
.done-box{display:inline-grid;gap:6px;text-align:left;background:#f6f5fb;
    border-radius:12px;padding:16px 20px;margin:8px 0 14px}
.done-box b{color:var(--purple)}
.muted{color:var(--muted)}
.err{color:#dc2626;font-size:14px;min-height:18px}
.loading{color:var(--muted)}
.hidden{display:none}
.foot{color:var(--muted);font-size:13px;text-align:center;padding:8px 0 30px}

@media(max-width:980px){.summary{position:static;width:auto;right:auto;margin-top:18px}}
@media(max-width:560px){.services{grid-template-columns:1fr}.hero h1{font-size:24px}}
