:root{--bg:#f6f8fb;--card:#fff;--card-soft:#f8fafc;--text:#0f172a;--muted:#64748b;--border:#dbe3ee;--blue:#2563eb;--hero-1:#020617;--hero-2:#172554;--hero-3:#0f172a;--shadow:0 10px 30px #0f172a14}*{box-sizing:border-box}html,body,#root{min-height:100%;color:var(--text);background:var(--bg);margin:0;font-family:Arial,Helvetica,sans-serif}button,input,select,textarea{font:inherit}.container{width:min(1200px,100% - 32px);margin:0 auto}.hero{background:linear-gradient(135deg, var(--hero-1), var(--hero-2), var(--hero-3));color:#fff;padding:64px 0}.hero-grid,.two-col{grid-template-columns:1.1fr .9fr;gap:24px;display:grid}.badge{background:#ffffff1f;border-radius:999px;margin-bottom:18px;padding:10px 16px;display:inline-block}.hero h1{margin:0 0 18px;font-size:46px;line-height:1.05}.hero-copy{color:#dbe7ff;line-height:1.6}.summary-card,.panel,.service-card,.booking-item,.notice,.add-panel,.info-row{box-shadow:var(--shadow)}.summary-card,.panel{color:var(--text);background:#fff;border-radius:28px;padding:28px}.summary-card h2,.summary-card h3,.summary-card strong,.summary-card div,.summary-card span,.summary-card p{color:var(--text)}.summary-card .summary-sub,.summary-card .muted{color:var(--muted)}.summary-total,.summary-total strong,.summary-total p,.summary-total div{color:#fff}.summary-box,.summary-total{border-radius:20px;margin-top:16px;padding:18px}.summary-box{background:#f1f5f9}.summary-total{background:var(--blue);color:#fff}.summary-total strong{margin:6px 0;font-size:38px;display:block}.section{padding:56px 0}.section-alt{padding-top:0;padding-bottom:64px}.section-copy,.muted{color:var(--muted);line-height:1.6}.services-grid{grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px;display:grid}.service-card{border:1px solid var(--border);text-align:left;cursor:pointer;background:#fff;border-radius:26px;padding:22px}.service-card.selected{border-color:var(--blue);background:#eff6ff}.service-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.pill,.status{border-radius:999px;padding:7px 12px;font-size:12px;font-weight:700;display:inline-block}.pill{color:#334155;background:#f1f5f9}.status{color:#475569;background:#e2e8f0}.status.on{background:var(--blue);color:#fff}.service-card h3{margin:16px 0 10px;font-size:20px}.service-card p{color:var(--muted);line-height:1.6}.service-card .price{color:var(--blue);margin-top:14px;font-weight:700}.notice{color:#1d4ed8;background:#eff6ff;border:1px dashed #93c5fd;border-radius:20px;margin-top:18px;padding:16px}.add-panel{background:var(--card-soft);border:1px solid var(--border);border-radius:20px;justify-content:space-between;align-items:center;gap:18px;margin-top:18px;padding:18px;display:flex}.btn{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:16px;padding:12px 18px}.btn-outline{color:#1d4ed8;background:#eff6ff;border-style:dashed;border-color:#93c5fd;font-weight:700}.btn-small{padding:10px 14px}.booking-list{flex-direction:column;gap:18px;margin-top:20px;display:flex}.booking-item{background:var(--card-soft);border:1px solid var(--border);border-radius:24px;padding:20px}.booking-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.small-label{color:var(--muted);margin-bottom:8px;font-size:13px}.form-grid,.customer-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.field>span{color:#334155;margin-bottom:8px;font-size:14px;font-weight:700;display:block}.input{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:16px;padding:14px 16px}.line-total{background:#fff;border:1px solid #edf2f7;border-radius:18px;justify-content:space-between;align-items:center;gap:16px;margin-top:16px;padding:16px;display:flex}.customer-grid{margin-top:24px}.side-stack{flex-direction:column;gap:20px;display:flex}.info-list{flex-direction:column;gap:12px;margin-top:18px;display:flex}.info-row{background:var(--card-soft);border:1px solid #edf2f7;border-radius:18px;padding:16px}.info-row strong{margin-bottom:6px;display:block}.info-row p{color:var(--muted);margin:0;line-height:1.6}@media (width<=1000px){.hero-grid,.two-col,.services-grid{grid-template-columns:1fr}.hero h1{font-size:38px}}@media (width<=700px){.container{width:min(100% - 20px,1200px)}.form-grid,.customer-grid{grid-template-columns:1fr}.add-panel,.booking-head,.line-total{flex-direction:column;align-items:stretch}.stairs-box{grid-column:span 1}}.stairs-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:20px;grid-column:span 2;padding:16px}.stairs-box p{color:var(--muted);margin:6px 0 0}.checkbox-line{align-items:center;gap:10px;margin-top:12px;display:flex}.stairs-count{max-width:260px;margin-top:12px}.summary-breakdown{background:#f8fafc;border-radius:20px;margin-top:20px;padding:16px}.summary-breakdown h3{margin:0 0 12px;font-size:16px}.summary-line{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:flex-start;padding:10px 0;display:flex}.summary-line:last-child{border-bottom:none}.summary-sub{color:var(--muted);margin-top:4px;font-size:13px}.modal-overlay{z-index:1000;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:24px;width:min(720px,100%);max-height:90vh;padding:24px;overflow:auto;box-shadow:0 20px 50px #0f172a33}.review-section{border-top:1px solid #e2e8f0;margin-top:20px;padding-top:16px}.review-section h3{margin:0 0 10px;font-size:18px}.review-section p{color:var(--text);margin:6px 0}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);font-weight:700}.btn-secondary{color:var(--text);border:1px solid var(--border);background:#fff;font-weight:700}.review-action-wrap{margin-top:24px}.btn-review{width:100%;padding:16px;font-weight:700}.form-help{color:var(--muted);margin-top:10px;font-size:14px}.inline-add-service{border-top:1px solid #dbe3ee;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-top:18px;padding-top:14px;display:flex}.floating-estimate{box-shadow:var(--shadow);background:#fff;border:1px solid #bfdbfe;border-radius:20px;margin-top:16px;padding:16px}.time-option{text-align:left;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:14px;width:100%;padding:14px;transition:all .2s}.time-option.recommended{background:#ecfdf5;border:2px solid #22c55e}.time-option.active{box-shadow:0 0 0 3px #2563eb2e}.time-option.recommended.active{background:#ecfdf5;border-color:#22c55e;box-shadow:0 0 0 2px #22c55e2e,0 0 0 5px #2563eb29}.time-option-top{justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px;display:flex}.time-option-title{font-weight:700}.time-option-selected-badge{color:#1d4ed8;background:#dbeafe;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:700;display:inline-block}.time-option-reason{color:var(--muted);margin-top:6px;font-size:14px}.time-option-discount{color:#166534;margin-top:6px;font-size:14px}.upholstery-type-field{grid-column:span 2}.upholstery-qty-field{grid-column:span 1}@media (width<=700px){.upholstery-type-field{grid-column:span 1}.upholstery-type-field .input{min-width:0;font-size:15px}.upholstery-qty-field .input{max-width:120px}}.selected-addons-note{color:#1d4ed8;margin-top:6px;font-size:14px;font-weight:600}.success-services-list{flex-direction:column;gap:12px;margin-top:18px;display:flex}.success-service-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:12px 14px}
