/* ============================================================
   VERSAL MEDIA — form pages (Quote / Consultation)
   Builds on versal.css tokens
   ============================================================ */

.page-form{background:var(--mist);min-height:100vh}

/* slim nav variant */
.nav.slim{position:sticky;background:rgba(255,255,255,.86);backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);border-bottom:1px solid var(--line)}
.nav.slim .nav-inner{padding:14px 32px}
.back-link{margin-left:auto;display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--body);padding:9px 14px;border-radius:9px;transition:color .2s,background .2s}
.back-link:hover{color:var(--ink);background:var(--mist)}
.back-link .ar{transition:transform .3s var(--ease)}
.back-link:hover .ar{transform:translateX(-4px)}

/* page hero band */
.form-hero{padding:120px 0 40px;position:relative;overflow:hidden}
.form-hero .blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.55;pointer-events:none}
.form-hero .b1{width:480px;height:480px;background:radial-gradient(circle,var(--cyan-tint),transparent 70%);top:-200px;right:-100px}
.form-hero .b2{width:380px;height:380px;background:radial-gradient(circle,var(--lav-tint),transparent 70%);top:-120px;left:-160px}
.form-hero .wrap{position:relative;z-index:2}
.form-hero h1{font-size:clamp(2.2rem,4.4vw,3.4rem);max-width:14ch;margin-top:16px}
.form-hero .lead{margin-top:18px;max-width:52ch}

/* layout */
.form-layout{display:grid;grid-template-columns:1fr 360px;gap:48px;padding:20px 0 110px;align-items:start}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-md);overflow:hidden}

/* stepper */
.stepper{display:flex;align-items:center;gap:0;padding:24px 34px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff,var(--mist))}
.stepper .st{display:flex;align-items:center;gap:11px;flex:1;min-width:0}
.stepper .st .dot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  font-family:var(--mono);font-size:13px;font-weight:500;border:1.5px solid var(--line);background:#fff;color:var(--muted);transition:all .35s var(--ease)}
.stepper .st .lab{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap;transition:color .35s;overflow:hidden;text-overflow:ellipsis}
.stepper .st .bar{height:2px;background:var(--line);flex:1;margin:0 12px;border-radius:2px;position:relative;overflow:hidden}
.stepper .st .bar::after{content:"";position:absolute;inset:0;width:0;background:var(--cyan);transition:width .45s var(--ease)}
.stepper .st.active .dot{border-color:var(--ink);background:var(--ink);color:#fff}
.stepper .st.done .dot{border-color:var(--cyan);background:var(--cyan);color:var(--ink)}
.stepper .st.active .lab,.stepper .st.done .lab{color:var(--ink)}
.stepper .st.done .bar::after{width:100%}

/* form body */
.form-body{padding:38px 34px 34px}
.fstep{display:none;animation:stepIn .45s var(--ease)}
.fstep.on{display:block}
@keyframes stepIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.fstep h2{font-size:1.7rem;margin-bottom:6px}
.fstep .step-sub{font-size:15px;color:var(--body);margin-bottom:26px}
.step-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan-ink);margin-bottom:10px}

/* fields */
.field{margin-bottom:20px}
.field.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label,.fl{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:8px}
.fl .req{color:var(--purple);margin-left:2px}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);background:var(--paper);
  border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;transition:border-color .2s,box-shadow .2s;
}
.field textarea{min-height:120px;resize:vertical;line-height:1.5}
.field input::placeholder,.field textarea::placeholder{color:#aeb6bd}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 4px rgba(0,220,227,.14)}
.field input.err,.field select.err,.field textarea.err{border-color:#e0607a;box-shadow:0 0 0 4px rgba(224,96,122,.12)}
.field .hint{font-size:12px;color:var(--muted);margin-top:7px}
.errmsg{font-size:12px;color:#cf4b66;margin-top:7px;display:none}
.errmsg.show{display:block}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2314171A' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}

/* choice cards (service / type) */
.choice-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.choice{
  position:relative;border:1.5px solid var(--line);border-radius:14px;padding:18px;cursor:pointer;
  transition:border-color .25s,background .25s,transform .2s;display:flex;gap:14px;align-items:flex-start;background:#fff;
}
.choice:hover{border-color:var(--cyan);transform:translateY(-2px)}
.choice.sel{border-color:var(--ink);background:var(--mist)}
.choice .ci{width:42px;height:42px;border-radius:11px;background:var(--cyan-tint);display:grid;place-items:center;flex-shrink:0;transition:background .25s}
.choice.sel .ci{background:var(--cyan)}
.choice .ci svg{width:21px;height:21px;stroke:var(--cyan-ink);fill:none;stroke-width:1.7}
.choice b{display:block;font-size:14.5px;color:var(--ink);font-weight:600}
.choice span{display:block;font-size:12.5px;color:var(--muted);margin-top:3px;line-height:1.4}
.choice .tick{position:absolute;top:14px;right:14px;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;transition:all .25s}
.choice .tick svg{width:11px;height:11px;stroke:#fff;stroke-width:2.4;fill:none;opacity:0;transition:opacity .2s}
.choice.sel .tick{background:var(--cyan);border-color:var(--cyan)}
.choice.sel .tick svg{opacity:1;stroke:var(--ink)}

/* segmented pills (format / budget quick) */
.seg{display:flex;gap:9px;flex-wrap:wrap}
.seg .opt{font-size:14px;font-weight:500;padding:11px 18px;border-radius:999px;border:1.5px solid var(--line);background:#fff;cursor:pointer;transition:all .22s var(--ease);color:var(--body)}
.seg .opt:hover{border-color:var(--cyan);color:var(--ink)}
.seg .opt.sel{background:var(--ink);color:#fff;border-color:var(--ink)}

/* actions */
.form-actions{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.form-actions .spacer{flex:1}
.btn-text{background:none;border:none;font-family:var(--sans);font-size:15px;font-weight:600;color:var(--body);cursor:pointer;display:inline-flex;align-items:center;gap:8px;padding:10px 4px;transition:color .2s}
.btn-text:hover{color:var(--ink)}
.btn-text .ar{transition:transform .3s var(--ease)}
.btn-text:hover .ar{transform:translateX(-4px)}

/* ---- calendar ---- */
.cal-wrap{display:grid;grid-template-columns:1fr 280px;gap:28px}
.cal{user-select:none}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cal-head .mname{font-family:var(--serif);font-size:1.3rem;color:var(--ink);white-space:nowrap}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:36px;height:36px;border-radius:10px;border:1.5px solid var(--line);background:#fff;cursor:pointer;display:grid;place-items:center;transition:all .2s}
.cal-nav button:hover:not(:disabled){border-color:var(--ink)}
.cal-nav button:disabled{opacity:.35;cursor:not-allowed}
.cal-nav button svg{width:14px;height:14px;stroke:var(--ink);fill:none;stroke-width:2}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-dow span{text-align:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-day{aspect-ratio:1;border:1.5px solid transparent;border-radius:11px;background:var(--mist);color:var(--ink);font-size:14px;font-weight:500;cursor:pointer;display:grid;place-items:center;transition:all .2s var(--ease)}
.cal-day:hover:not(.disabled):not(.empty){border-color:var(--cyan);background:#fff}
.cal-day.empty{background:transparent;cursor:default}
.cal-day.disabled{color:#c4ccd1;background:transparent;cursor:not-allowed;text-decoration:line-through}
.cal-day.today{box-shadow:inset 0 0 0 1.5px var(--cyan-deep)}
.cal-day.sel{background:var(--ink);color:#fff;border-color:var(--ink)}

.slots{}
.slots h4{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:14px}
.slots .slots-none{font-size:13px;color:var(--muted);line-height:1.5}
.slot-list{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.slot{font-family:var(--mono);font-size:13px;padding:11px 8px;border-radius:10px;border:1.5px solid var(--line);background:#fff;cursor:pointer;text-align:center;transition:all .2s;color:var(--ink)}
.slot:hover{border-color:var(--cyan)}
.slot.sel{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---- aside ---- */
.aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:18px}
.aside-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow-sm)}
.aside-card.dark{background:linear-gradient(160deg,#0E1416,#13211f);border-color:transparent;color:#cdd9da;position:relative;overflow:hidden}
.aside-card.dark .a-svg{position:absolute;inset:0;opacity:.5}
.aside-card.dark .a-inner{position:relative;z-index:2}
.aside-card h3{font-size:1.15rem;margin-bottom:14px}
.aside-card.dark h3{color:#fff}
.a-step{display:flex;gap:13px;padding:11px 0;align-items:flex-start}
.a-step .n{width:24px;height:24px;border-radius:50%;background:rgba(0,220,227,.14);border:1px solid rgba(0,220,227,.3);color:var(--cyan);font-family:var(--mono);font-size:11px;display:grid;place-items:center;flex-shrink:0}
.a-step b{display:block;font-size:14px;color:#fff;font-weight:600}
.a-step span{display:block;font-size:12.5px;color:#8fa1a2;margin-top:2px;line-height:1.45}
.assure{display:flex;gap:12px;align-items:flex-start;padding:10px 0}
.assure svg{width:20px;height:20px;stroke:var(--cyan-ink);fill:none;stroke-width:1.7;flex-shrink:0;margin-top:1px}
.assure b{font-size:14px;color:var(--ink);font-weight:600;display:block}
.assure span{font-size:13px;color:var(--body)}
.aside-contact{font-size:14px}
.aside-contact a{display:flex;gap:10px;align-items:center;padding:7px 0;color:var(--body);transition:color .2s}
.aside-contact a:hover{color:var(--cyan-ink)}

/* ---- review list ---- */
.review{display:flex;flex-direction:column}
.review .rrow{display:flex;justify-content:space-between;gap:20px;padding:15px 0;border-bottom:1px solid var(--line)}
.review .rrow:last-child{border-bottom:none}
.review .rk{font-size:13px;color:var(--muted);font-family:var(--mono);letter-spacing:.03em;flex-shrink:0}
.review .rv{font-size:15px;color:var(--ink);font-weight:500;text-align:right}
.consent{display:flex;gap:11px;align-items:flex-start;margin-top:22px;font-size:13.5px;color:var(--body);line-height:1.5}
.consent input{width:19px;height:19px;margin-top:2px;accent-color:var(--cyan-deep);flex-shrink:0}
.consent a{color:var(--cyan-ink);text-decoration:underline}

/* ---- success ---- */
.success{text-align:center;padding:30px 20px}
.success .check{width:78px;height:78px;border-radius:50%;background:var(--cyan-tint);display:grid;place-items:center;margin:0 auto 26px;position:relative}
.success .check svg{width:38px;height:38px;stroke:var(--cyan-ink);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:40;stroke-dashoffset:40;animation:drawcheck .6s var(--ease) .2s forwards}
@keyframes drawcheck{to{stroke-dashoffset:0}}
.success .check::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--cyan);animation:ringpop .7s var(--ease) forwards;opacity:0}
@keyframes ringpop{0%{transform:scale(.7);opacity:.8}100%{transform:scale(1.35);opacity:0}}
.success h2{font-size:2rem;margin-bottom:12px}
.success p{font-size:16px;color:var(--body);max-width:46ch;margin:0 auto}
.success .ref{display:inline-block;margin-top:22px;font-family:var(--mono);font-size:13px;color:var(--ink);background:var(--mist);border:1px solid var(--line);border-radius:999px;padding:9px 18px}
.success .summary-box{margin:30px auto 0;max-width:440px;text-align:left;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 26px;background:var(--mist)}
.success-actions{display:flex;gap:12px;justify-content:center;margin-top:30px;flex-wrap:wrap}

@media (max-width:980px){
  .form-layout{grid-template-columns:1fr;gap:30px}
  .aside{position:static;flex-direction:row;flex-wrap:wrap}
  .aside-card{flex:1;min-width:240px}
  .cal-wrap{grid-template-columns:1fr}
}
@media (max-width:600px){
  .form-body{padding:28px 20px}
  .stepper{padding:18px 16px;gap:0}
  .stepper .st .lab{display:none}
  .stepper .st{flex:0 0 auto}
  .stepper .st .bar{flex:1;min-width:18px;margin:0 8px}
  .stepper .st:last-child{flex:0 0 auto}
  .choice-grid,.field.row2,.slot-list{grid-template-columns:1fr}
  .form-hero{padding:90px 0 24px}
  .aside-card{min-width:100%}
}
