/*!
 * iFix Cellfone — Booking Wizard Premium CSS v12.4
 * Design: Refined dark-accented luxury · Sora + DM Sans
 */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700;800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&family=DM+Mono:wght@400;500&display=swap');

/* ════ TOKENS ════════════════════════════════════════════════════ */
#techpro-booking-widget {
  --bg:#fff;--bg-2:#f9fafb;--bg-3:#f2f3f8;--surface:#fff;
  --border:#e5e7ef;--border-2:#d0d4e0;
  --txt:#09090f;--txt-2:#4a5168;--txt-3:#8b93a8;
  --accent:#1860f0;--accent-dk:#0d4dd4;--accent-lite:#ebf0ff;
  --green:#059669;--green-lite:#ecfdf5;
  --amber:#d97706;--amber-lite:#fffbeb;
  --red:#dc2626;--red-lite:#fef2f2;
  --purple:#7c3aed;
  --radius:18px;--radius-md:13px;--radius-sm:9px;--radius-xs:6px;
  --shadow-xs:0 1px 2px rgba(9,9,15,.04);
  --shadow-sm:0 2px 8px rgba(9,9,15,.06),0 1px 2px rgba(9,9,15,.04);
  --shadow-md:0 4px 20px rgba(9,9,15,.08),0 1px 4px rgba(9,9,15,.05);
  --shadow-lg:0 12px 40px rgba(9,9,15,.12),0 2px 8px rgba(9,9,15,.06);
  --shadow-accent:0 8px 28px rgba(24,96,240,.30);
  --ease:cubic-bezier(.4,0,.2,1);--spring:cubic-bezier(.34,1.56,.64,1);--dur:180ms;
  --font-h:'Sora',-apple-system,sans-serif;
  --font-b:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-m:'DM Mono','SF Mono',monospace;
}
#techpro-booking-widget[data-color-scheme="dark"],.dark #techpro-booking-widget,.dark-mode #techpro-booking-widget,[data-theme="dark"] #techpro-booking-widget {
  --bg:#0a0b12;--bg-2:#111320;--bg-3:#191c2d;--surface:#111320;
  --border:#242840;--border-2:#2e3354;
  --txt:#edf0fa;--txt-2:#8e96b5;--txt-3:#545b78;
  --accent:#4d87ff;--accent-dk:#3a75f0;--accent-lite:#0f1e42;
  --green:#34d399;--green-lite:#052e1c;--amber:#fbbf24;--amber-lite:#1c1204;
  --red:#f87171;--red-lite:#2a0c0c;
  --shadow-xs:0 1px 2px rgba(0,0,0,.3);--shadow-sm:0 2px 8px rgba(0,0,0,.35);
  --shadow-md:0 4px 20px rgba(0,0,0,.45);--shadow-lg:0 12px 40px rgba(0,0,0,.55);
}
@media(prefers-color-scheme:dark){
  #techpro-booking-widget:not([data-color-scheme="light"]){
    --bg:#0a0b12;--bg-2:#111320;--bg-3:#191c2d;--surface:#111320;
    --border:#242840;--border-2:#2e3354;--txt:#edf0fa;--txt-2:#8e96b5;--txt-3:#545b78;
    --accent:#4d87ff;--accent-dk:#3a75f0;--accent-lite:#0f1e42;
    --green:#34d399;--green-lite:#052e1c;--amber:#fbbf24;--amber-lite:#1c1204;
    --red:#f87171;--red-lite:#2a0c0c;
  }
}

/* ════ RESET ═══════════════════════════════════════════════════ */
#techpro-booking-widget,#techpro-booking-widget *{box-sizing:border-box!important;-webkit-font-smoothing:antialiased;}
#techpro-booking-widget{font-family:var(--font-b);color:var(--txt);background:transparent;width:100%;max-width:900px;margin:0 auto;position:relative;font-size:16px;line-height:1.5;}

/* ════ OUTER SHELL ══════════════════════════════════════════════ */
#techpro-booking-widget .tp-card-shell{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;}

/* ════ STEPPER ══════════════════════════════════════════════════ */
#techpro-booking-widget .tp-stepper{padding:0 24px;background:var(--bg);border-bottom:1.5px solid var(--border);position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
#techpro-booking-widget .tp-track{position:relative;height:56px;display:flex;align-items:center;}
#techpro-booking-widget .tp-track-rail{position:absolute;left:15px;right:15px;height:2px;background:var(--border);border-radius:99px;top:50%;transform:translateY(-50%);}
#techpro-booking-widget .tp-track-fill{position:absolute;left:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--purple));border-radius:99px;transition:width .4s var(--ease);z-index:1;}
#techpro-booking-widget .tp-nodes{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:space-between;}
#techpro-booking-widget .tp-node{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:var(--font-h);background:var(--bg-3);color:var(--txt-3);border:2px solid var(--border);transition:all .3s var(--spring);cursor:default;flex-shrink:0;position:relative;z-index:2;}
#techpro-booking-widget .tp-node.is-active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 0 4px rgba(24,96,240,.18);transform:scale(1.1);}
#techpro-booking-widget .tp-node.is-done{background:var(--green);color:#fff;border-color:var(--green);}
#techpro-booking-widget .tp-labels{display:flex;justify-content:space-between;padding:0 0 8px;}
#techpro-booking-widget .tp-lbl{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-3);text-align:center;flex:1;transition:color .2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 2px;}
#techpro-booking-widget .tp-lbl.is-active{color:var(--accent);}
#techpro-booking-widget .tp-lbl.is-done{color:var(--green);}
@media(max-width:600px){#techpro-booking-widget .tp-labels{display:none;}#techpro-booking-widget .tp-stepper{padding:0 14px;}#techpro-booking-widget .tp-node{width:24px;height:24px;font-size:10px;}}

/* ════ PANELS ═══════════════════════════════════════════════════ */
#techpro-booking-widget .tp-panel{padding:28px 28px 24px;animation:tp-panel-in .22s ease;}
#techpro-booking-widget .tp-panel.tp-hidden{display:none!important;}
#techpro-booking-widget .tp-panel[data-step="7"]{padding:0;}
@keyframes tp-panel-in{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
@media(max-width:540px){#techpro-booking-widget .tp-panel{padding:20px 16px 18px;}}

/* ════ STEP HEADER ══════════════════════════════════════════════ */
#techpro-booking-widget .tp-step-head{margin-bottom:22px;}
#techpro-booking-widget .tp-step-eyebrow{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);background:var(--accent-lite);padding:4px 10px;border-radius:99px;margin-bottom:9px;}
#techpro-booking-widget .tp-step-title{font-family:var(--font-h);font-size:22px;font-weight:800;color:var(--txt);letter-spacing:-.4px;line-height:1.2;margin:0 0 7px;}
#techpro-booking-widget .tp-step-sub{font-size:14px;color:var(--txt-2);line-height:1.6;margin:0;}
@media(max-width:540px){#techpro-booking-widget .tp-step-title{font-size:19px;}}

/* ════ BACK ════════════════════════════════════════════════════ */
#techpro-booking-widget .tp-back-row{margin-bottom:14px;}
#techpro-booking-widget .tp-back{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--txt-3);background:none;border:none;padding:3px 0;cursor:pointer;font-family:var(--font-b);transition:color var(--dur) var(--ease);-webkit-tap-highlight-color:transparent;}
#techpro-booking-widget .tp-back:hover{color:var(--accent);}

/* ════ CARDS GRID (steps 1-3) ═══════════════════════════════════ */
#techpro-booking-widget .tp-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
#techpro-booking-widget .tp-card{position:relative;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:18px 14px 16px;cursor:pointer;transition:all var(--dur) var(--ease);text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:var(--shadow-xs);-webkit-tap-highlight-color:transparent;outline:none;}
#techpro-booking-widget .tp-card:hover{border-color:var(--accent);background:var(--accent-lite);transform:translateY(-2px);box-shadow:var(--shadow-md);}
#techpro-booking-widget .tp-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px rgba(24,96,240,.22);}
#techpro-booking-widget .tp-card.selected{border-color:var(--accent);background:var(--accent-lite);box-shadow:0 0 0 2px var(--accent),var(--shadow-md);}
#techpro-booking-widget .tp-card.selected::after{content:'✓';position:absolute;top:7px;right:9px;width:19px;height:19px;background:var(--accent);color:#fff;font-size:10px;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;}
#techpro-booking-widget .tp-card-ico{font-size:30px;line-height:1;}
#techpro-booking-widget .tp-card-img{width:52px;height:52px;border-radius:11px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-3);}
#techpro-booking-widget .tp-card-img img{width:100%;height:100%;object-fit:cover;}
#techpro-booking-widget .tp-card-body{width:100%;}
#techpro-booking-widget .tp-card-name{font-size:13px;font-weight:700;color:var(--txt);font-family:var(--font-h);line-height:1.3;letter-spacing:-.1px;}
#techpro-booking-widget .tp-card-desc{font-size:11px;color:var(--txt-3);margin-top:3px;line-height:1.4;}
#techpro-booking-widget .tp-card-price{font-size:13px;font-weight:700;color:var(--accent);margin-top:5px;}

/* ════ SERVICE CARDS (step 4) ═══════════════════════════════════ */
#techpro-booking-widget .tp-svc-grid{display:flex;flex-direction:column;gap:8px;}
#techpro-booking-widget .tp-svc-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--dur) var(--ease);box-shadow:var(--shadow-xs);-webkit-tap-highlight-color:transparent;}
#techpro-booking-widget .tp-svc-card:hover{border-color:var(--accent);background:var(--accent-lite);}
#techpro-booking-widget .tp-svc-card.selected{border-color:var(--accent);background:var(--accent-lite);box-shadow:0 0 0 2px var(--accent);}
#techpro-booking-widget .tp-svc-ico-wrap{width:40px;height:40px;border-radius:10px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;}
.tp-svc-card.selected .tp-svc-ico-wrap{background:rgba(24,96,240,.15);}
#techpro-booking-widget .tp-svc-body{flex:1;min-width:0;}
#techpro-booking-widget .tp-svc-name{font-size:14px;font-weight:700;color:var(--txt);font-family:var(--font-h);letter-spacing:-.1px;}
#techpro-booking-widget .tp-svc-desc{font-size:12px;color:var(--txt-3);margin-top:2px;line-height:1.4;}
#techpro-booking-widget .tp-svc-price{font-size:15px;font-weight:800;color:var(--accent);font-family:var(--font-h);white-space:nowrap;flex-shrink:0;}
#techpro-booking-widget .tp-svc-check{width:21px;height:21px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--dur);font-size:10px;color:transparent;}
.tp-svc-card.selected .tp-svc-check{background:var(--accent);border-color:var(--accent);color:#fff;}
#techpro-booking-widget .tp-custom-issue-wrap{background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-top:10px;}

/* ════ LOADING/EMPTY ════════════════════════════════════════════ */
#techpro-booking-widget .tp-loading-wrap{display:flex;align-items:center;justify-content:center;gap:12px;padding:32px 20px;color:var(--txt-3);font-size:14px;}
@keyframes tp-spin{to{transform:rotate(360deg);}}
#techpro-booking-widget .tp-spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:tp-spin .7s linear infinite;flex-shrink:0;}
#techpro-booking-widget .tp-empty{text-align:center;padding:28px 20px;color:var(--txt-3);font-size:14px;line-height:1.6;}

/* ════ STEP 5 ESTIMATE ══════════════════════════════════════════ */
#techpro-booking-widget .tp-est-wrap{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px;}
@media(max-width:600px){#techpro-booking-widget .tp-est-wrap{grid-template-columns:1fr;}}
#techpro-booking-widget .tp-est-left{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:22px;background:linear-gradient(135deg,var(--accent-lite),var(--bg-2));border:1.5px solid var(--border);border-radius:var(--radius-md);text-align:center;gap:9px;}
#techpro-booking-widget .tp-est-icon{font-size:42px;line-height:1;}
#techpro-booking-widget .tp-est-device{font-family:var(--font-h);font-size:15px;font-weight:800;color:var(--txt);letter-spacing:-.2px;line-height:1.3;}
#techpro-booking-widget .tp-est-service{font-size:13px;color:var(--txt-2);}
#techpro-booking-widget .tp-est-badges{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-top:4px;}
#techpro-booking-widget .tp-est-badge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:99px;background:var(--green-lite);color:var(--green);border:1px solid rgba(5,150,105,.2);white-space:nowrap;}
#techpro-booking-widget .tp-price-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);}
#techpro-booking-widget .tp-price-hd{background:linear-gradient(135deg,var(--accent),var(--purple));padding:20px 20px 16px;text-align:center;position:relative;overflow:hidden;}
#techpro-booking-widget .tp-price-hd::before{content:'';position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.1);}
#techpro-booking-widget .tp-price-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.75);margin-bottom:6px;}
#techpro-booking-widget .tp-price-amt{font-family:var(--font-h);font-size:40px;font-weight:900;color:#fff;letter-spacing:-2px;line-height:1;}
#techpro-booking-widget .tp-price-note{font-size:11px;color:rgba(255,255,255,.7);margin-top:6px;line-height:1.4;}
#techpro-booking-widget .tp-price-rows{padding:12px 16px;display:flex;flex-direction:column;}
#techpro-booking-widget .tp-price-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;font-size:13px;color:var(--txt-2);border-bottom:1px solid var(--border);}
#techpro-booking-widget .tp-price-row:last-child{border-bottom:none;}
#techpro-booking-widget .tp-price-val{font-weight:700;color:var(--txt);}
#techpro-booking-widget .tp-price-discount .tp-price-val{color:var(--green);}
#techpro-booking-widget .tp-diag-note{padding:11px 16px;background:var(--amber-lite);border-top:1px solid var(--border);font-size:12px;color:var(--amber);line-height:1.5;}

/* Coupon */
#techpro-booking-widget .tp-coupon-section{border:1.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden;}
#techpro-booking-widget .tp-coupon-toggle{display:flex;align-items:center;gap:10px;padding:12px 15px;cursor:pointer;font-size:14px;font-weight:600;color:var(--txt-2);background:var(--bg-2);transition:background var(--dur);user-select:none;-webkit-tap-highlight-color:transparent;}
#techpro-booking-widget .tp-coupon-toggle:hover{background:var(--bg-3);}
#techpro-booking-widget .tp-coupon-toggle-ico{font-size:16px;}
#techpro-booking-widget .tp-coupon-toggle-txt{flex:1;}
#techpro-booking-widget .tp-coupon-toggle-arrow{font-size:17px;color:var(--txt-3);display:inline-block;transition:transform .2s;line-height:1;}
#techpro-booking-widget .tp-coupon-body{padding:13px 15px;border-top:1px solid var(--border);background:var(--bg);}
#techpro-booking-widget .tp-coupon-body.tp-hidden{display:none;}
#techpro-booking-widget .tp-coupon-row{display:flex;gap:8px;}
#techpro-booking-widget .tp-coupon-msg{margin-top:8px;font-size:13px;font-weight:600;padding:8px 11px;border-radius:var(--radius-xs);}
#techpro-booking-widget .tp-coupon-msg.tp-hidden{display:none;}
#techpro-booking-widget .tp-coupon-msg--ok{background:var(--green-lite);color:var(--green);}
#techpro-booking-widget .tp-coupon-msg--error{background:var(--red-lite);color:var(--red);}

/* ════ STEP 6 FORM ══════════════════════════════════════════════ */
#techpro-booking-widget .tp-strip{display:flex;align-items:center;padding:13px 18px;background:linear-gradient(to right,var(--accent-lite),var(--bg-2));border:1.5px solid var(--border);border-radius:var(--radius-md);margin-bottom:20px;overflow-x:auto;}
#techpro-booking-widget .tp-strip-item{display:flex;flex-direction:column;gap:2px;flex:1;min-width:70px;}
#techpro-booking-widget .tp-strip-div{width:1px;height:32px;background:var(--border);margin:0 14px;flex-shrink:0;}
#techpro-booking-widget .tp-strip-key{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--txt-3);}
#techpro-booking-widget .tp-strip-val{font-size:13px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
#techpro-booking-widget .tp-strip-price{font-size:15px;font-weight:900;color:var(--accent);font-family:var(--font-h);}
#techpro-booking-widget .tp-returning{display:flex;align-items:center;gap:10px;padding:11px 15px;background:var(--accent-lite);border:1.5px solid var(--accent);border-radius:var(--radius-md);margin-bottom:16px;font-size:13px;font-weight:600;color:var(--accent);}
#techpro-booking-widget .tp-returning.tp-hidden{display:none;}
#techpro-booking-widget .tp-form-section{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px;overflow:hidden;}
#techpro-booking-widget .tp-form-section-hd{display:flex;align-items:center;gap:8px;padding:11px 16px;background:var(--bg-2);border-bottom:1px solid var(--border);}
#techpro-booking-widget .tp-form-section-ico{font-size:16px;}
#techpro-booking-widget .tp-form-section-title{font-size:13px;font-weight:700;color:var(--txt);font-family:var(--font-h);flex:1;}
#techpro-booking-widget .tp-form-section-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--txt-3);background:var(--bg-3);padding:2px 8px;border-radius:99px;}
#techpro-booking-widget .tp-form-section>.tp-row,#techpro-booking-widget .tp-form-section>.tp-field{padding:15px 16px 0;}
#techpro-booking-widget .tp-form-section>.tp-field:last-child,#techpro-booking-widget .tp-form-section>.tp-row:last-child{padding-bottom:16px;}
#techpro-booking-widget .tp-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:520px){#techpro-booking-widget .tp-row{grid-template-columns:1fr;}}
#techpro-booking-widget .tp-field{display:flex;flex-direction:column;gap:5px;}
#techpro-booking-widget .tp-label{font-size:12px;font-weight:700;color:var(--txt-2);}
#techpro-booking-widget .tp-req{color:var(--red);margin-left:2px;}
#techpro-booking-widget .tp-label-opt{font-weight:400;color:var(--txt-3);font-size:11px;}
#techpro-booking-widget .tp-input{width:100%;padding:10px 13px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-b);color:var(--txt);transition:border-color var(--dur),box-shadow var(--dur);outline:none;-webkit-appearance:none;}
#techpro-booking-widget .tp-input::placeholder{color:var(--txt-3);}
#techpro-booking-widget .tp-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(24,96,240,.14);}
#techpro-booking-widget .tp-input[aria-invalid="true"],#techpro-booking-widget .tp-input.tp-input-error{border-color:var(--red);box-shadow:0 0 0 3px rgba(220,38,38,.1);}
#techpro-booking-widget textarea.tp-input{resize:vertical;min-height:78px;line-height:1.5;}
#techpro-booking-widget .tp-input-mono{font-family:var(--font-m);letter-spacing:.4px;}
#techpro-booking-widget .tp-input-hint{font-size:11px;color:var(--txt-3);line-height:1.5;}
#techpro-booking-widget .tp-field-err{font-size:12px;font-weight:600;color:var(--red);min-height:16px;display:block;}
#techpro-booking-widget .ifix-zip-status{display:block;font-size:12px;font-weight:600;margin-top:5px;min-height:16px;}
#techpro-booking-widget .ifix-zip-row{position:relative;}

/* Photos */
#techpro-booking-widget .ifix-photo-uploader{border:2px dashed var(--border);border-radius:var(--radius-md);padding:20px;text-align:center;cursor:pointer;transition:all var(--dur);position:relative;}
#techpro-booking-widget .ifix-photo-uploader:hover,#techpro-booking-widget .ifix-photo-uploader.is-dragover{border-color:var(--accent);background:var(--accent-lite);}
#techpro-booking-widget .ifix-photo-uploader.is-disabled{opacity:.6;pointer-events:none;background:var(--bg-2);}
#techpro-booking-widget .ifix-photo-icon{font-size:26px;margin-bottom:6px;}
#techpro-booking-widget .ifix-photo-label{font-size:13px;font-weight:600;color:var(--txt-2);}
#techpro-booking-widget .ifix-photo-hint{font-size:11px;color:var(--txt-3);margin-top:3px;}
#techpro-booking-widget .ifix-photo-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
#techpro-booking-widget .ifix-photo-thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;}
#techpro-booking-widget .ifix-thumb{width:68px;height:68px;border-radius:var(--radius-sm);overflow:hidden;position:relative;border:1.5px solid var(--border);}
#techpro-booking-widget .ifix-thumb img{width:100%;height:100%;object-fit:cover;}
#techpro-booking-widget .ifix-thumb-rm{position:absolute;top:2px;right:2px;background:rgba(0,0,0,.65);color:#fff;border:none;border-radius:50%;width:17px;height:17px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;}

/* Error / disclaimer */
#techpro-booking-widget .tp-err{padding:11px 15px;background:var(--red-lite);border:1.5px solid var(--red);border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--red);margin-top:12px;line-height:1.5;}
#techpro-booking-widget .tp-err.tp-hidden{display:none;}
#techpro-booking-widget .tp-disclaimer{font-size:11px;color:var(--txt-3);text-align:center;margin-top:11px;line-height:1.6;}

/* ════ BUTTONS ══════════════════════════════════════════════════ */
#techpro-booking-widget .tp-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 22px;border-radius:var(--radius-sm);font-family:var(--font-b);font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all var(--dur) var(--ease);-webkit-tap-highlight-color:transparent;white-space:nowrap;outline:none;}
#techpro-booking-widget .tp-btn:focus-visible{box-shadow:0 0 0 3px rgba(24,96,240,.3);}
#techpro-booking-widget .tp-btn-primary{background:linear-gradient(135deg,var(--accent),var(--purple));color:#fff;box-shadow:var(--shadow-accent);}
#techpro-booking-widget .tp-btn-primary:hover{transform:translateY(-1px);box-shadow:0 12px 36px rgba(24,96,240,.38);}
#techpro-booking-widget .tp-btn-primary:active{transform:translateY(0);}
#techpro-booking-widget .tp-btn-secondary{background:var(--bg-2);color:var(--txt-2);border:1.5px solid var(--border);}
#techpro-booking-widget .tp-btn-secondary:hover{background:var(--bg-3);border-color:var(--border-2);}
#techpro-booking-widget .tp-btn-full{width:100%;}
#techpro-booking-widget .tp-btn-lg{padding:14px 26px;font-size:15px;border-radius:var(--radius-md);}
#techpro-booking-widget .tp-btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important;box-shadow:none!important;}
#techpro-booking-widget .tp-btn-text,#techpro-booking-widget .tp-btn-loader{display:flex;align-items:center;gap:7px;}
#techpro-booking-widget .tp-btn-loader.tp-hidden{display:none;}
@keyframes tp-spin2{to{transform:rotate(360deg);}}
#techpro-booking-widget .tp-btn-spinner{width:16px;height:16px;animation:tp-spin2 .65s linear infinite;}

/* ════ STEP 8 CONFIRMATION ══════════════════════════════════════ */
#techpro-booking-widget .tp-done-wrap{padding:32px 28px 36px;text-align:center;max-width:520px;margin:0 auto;}
@media(max-width:520px){#techpro-booking-widget .tp-done-wrap{padding:24px 16px 28px;}}
#techpro-booking-widget .tp-check-ring{width:76px;height:76px;margin:0 auto 20px;}
#techpro-booking-widget .tp-check-svg{width:76px;height:76px;}
@keyframes tp-check-circle{to{stroke-dashoffset:0;}}
@keyframes tp-check-tick{to{stroke-dashoffset:0;}}
#techpro-booking-widget .tp-check-circle{stroke:var(--green);stroke-width:2.5;fill:none;stroke-dasharray:166;stroke-dashoffset:166;animation:tp-check-circle .65s ease .1s forwards;}
#techpro-booking-widget .tp-check-tick{stroke:var(--green);stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:tp-check-tick .35s ease .85s forwards;}
#techpro-booking-widget .tp-done-h{font-family:var(--font-h);font-size:26px;font-weight:900;color:var(--txt);letter-spacing:-.5px;margin:0 0 8px;}
#techpro-booking-widget .tp-done-sub{font-size:14px;color:var(--txt-2);line-height:1.6;margin:0 0 20px;}
#techpro-booking-widget .tp-ref-box{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 18px;background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-md);margin-bottom:18px;text-align:left;}
#techpro-booking-widget .tp-ref-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--txt-3);margin-bottom:4px;}
#techpro-booking-widget .tp-ref-num{font-family:var(--font-m);font-size:20px;font-weight:700;color:var(--accent);letter-spacing:1.5px;}
#techpro-booking-widget .tp-copy-btn{background:var(--bg-3);border:1.5px solid var(--border);border-radius:var(--radius-xs);padding:7px 10px;cursor:pointer;font-size:15px;color:var(--txt-3);transition:all var(--dur);flex-shrink:0;}
#techpro-booking-widget .tp-copy-btn:hover{background:var(--accent-lite);color:var(--accent);}
#techpro-booking-widget .tp-appt-hero{background:linear-gradient(135deg,#09090f 0%,#1a1c2e 100%);border-radius:var(--radius-md);padding:22px 20px;margin-bottom:18px;text-align:center;position:relative;overflow:hidden;}
#techpro-booking-widget .tp-appt-hero::before{content:'';position:absolute;top:-25px;right:-25px;width:90px;height:90px;border-radius:50%;background:rgba(255,255,255,.05);}
#techpro-booking-widget .tp-appt-icon{font-size:32px;display:block;margin-bottom:9px;}
#techpro-booking-widget .tp-appt-date{font-family:var(--font-h);font-size:18px;font-weight:900;color:#fff;letter-spacing:-.3px;margin-bottom:5px;}
#techpro-booking-widget .tp-appt-time{font-size:14px;color:rgba(255,255,255,.8);margin-bottom:7px;}
#techpro-booking-widget .tp-appt-addr{font-size:12px;color:rgba(255,255,255,.6);line-height:1.5;word-break:break-word;}
#techpro-booking-widget .tp-done-sum{text-align:left;border:1.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:20px;}
#techpro-booking-widget .tp-done-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:10px 15px;font-size:13px;border-bottom:1px solid var(--border);}
#techpro-booking-widget .tp-done-row:last-child{border-bottom:none;}
#techpro-booking-widget .tp-done-key{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-3);flex-shrink:0;min-width:78px;padding-top:1px;}
#techpro-booking-widget .tp-done-val{font-weight:600;color:var(--txt);text-align:right;word-break:break-word;}
#techpro-booking-widget .tp-done-row.is-total .tp-done-val{font-family:var(--font-m);color:var(--accent);font-size:14px;}
#techpro-booking-widget .ifix-done-actions{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;margin-bottom:18px;}
#techpro-booking-widget .ifix-done-action{display:inline-flex;align-items:center;gap:6px;padding:9px 14px;background:var(--bg-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:12px;font-weight:700;color:var(--txt-2);text-decoration:none;cursor:pointer;font-family:var(--font-b);transition:all var(--dur);-webkit-tap-highlight-color:transparent;}
#techpro-booking-widget .ifix-done-action svg{width:14px;height:14px;flex-shrink:0;}
#techpro-booking-widget .ifix-done-action:hover{background:var(--accent-lite);border-color:var(--accent);color:var(--accent);}
#techpro-booking-widget .tp-done-warranty{background:var(--green-lite);border:1.5px solid rgba(5,150,105,.25);border-radius:var(--radius-sm);padding:12px 15px;font-size:13px;color:var(--green);font-weight:600;text-align:center;}

/* ════ PROMO / FAB / TOAST / CONFETTI ══════════════════════════ */
#techpro-booking-widget .tp-promo{border-radius:var(--radius-sm);padding:13px 18px;font-weight:700;font-size:14px;text-align:center;margin-bottom:18px;letter-spacing:-.1px;}
.ifix-fab{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:9px;z-index:9990;}
.ifix-fab-wa{width:50px;height:50px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.38);transition:transform .15s;text-decoration:none;}
.ifix-fab-wa:hover{transform:scale(1.08);}
.ifix-fab-call{width:50px;height:50px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(24,96,240,.35);transition:transform .15s;text-decoration:none;}
.ifix-fab-call:hover{transform:scale(1.08);}
.ifix-toast-stack{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:99999;display:flex;flex-direction:column;gap:7px;align-items:center;pointer-events:none;}
.ifix-toast{background:#1a1c28;color:#fff;padding:11px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;font-family:'DM Sans',sans-serif;box-shadow:0 8px 28px rgba(0,0,0,.28);display:flex;align-items:center;gap:9px;pointer-events:auto;opacity:0;transform:translateY(10px) scale(.96);transition:opacity .22s,transform .22s;max-width:360px;}
.ifix-toast.is-visible{opacity:1;transform:none;}
.ifix-toast.is-success{background:#052e1c;color:#34d399;border:1px solid rgba(52,211,153,.3);}
.ifix-toast.is-error{background:#2a0c0c;color:#f87171;border:1px solid rgba(248,113,113,.3);}
.ifix-toast.is-warn{background:#1c1204;color:#fbbf24;border:1px solid rgba(251,191,36,.3);}
.ifix-toast-x{background:none;border:none;color:inherit;opacity:.6;cursor:pointer;font-size:15px;padding:0;margin-left:auto;flex-shrink:0;}
.ifix-confetti{position:fixed;inset:0;pointer-events:none;z-index:99998;}
#techpro-booking-widget #tp-step-7{padding:0;}
#techpro-booking-widget .tp-step7-shell{padding:18px 22px 0;background:linear-gradient(180deg,var(--bg) 0%,rgba(24,96,240,.03) 100%);}
#techpro-booking-widget .tp-step7-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:0 0 14px;}
#techpro-booking-widget .tp-step7-copy{font-size:13px;color:var(--txt-3);line-height:1.5;}
#techpro-booking-widget .ifix-sched-mount-panel{margin:0;text-align:left;}
#techpro-booking-widget #tp-step-7 .ifsc-wrap{border-radius:0;border:none;box-shadow:none;border-top:1.5px solid var(--border);}

/* ════════════════════════════════════════════════════════════════════
   DESIGN PANEL COMPATIBILITY BRIDGE
   build_design_css() writes --tp-accent, --tp-card-bg, --font-h etc.
   This section maps them to the new token names so both work.
════════════════════════════════════════════════════════════════════ */
#techpro-booking-widget {
  /* Map old design-panel vars → new token names */
  --accent:          var(--tp-accent,      var(--accent,      #1860f0));
  --bg:              var(--tp-card-bg,     var(--bg,          #ffffff));
  --border:          var(--tp-card-border, var(--border,      #e5e7ef));
  --txt:             var(--tp-heading-clr, var(--txt,         #09090f));
  --txt-2:           var(--tp-sub-clr,     var(--txt-2,       #4a5168));
  --radius-md:       var(--tp-card-radius, var(--radius-md,   13px));
  --radius-sm:       var(--tp-btn-radius,  var(--radius-sm,   9px));
  --font-h:          var(--tp-head-font,   var(--font-h, 'Sora', sans-serif));
  --font-b:          var(--tp-body-font,   var(--font-b, 'DM Sans', sans-serif));
  max-width:         var(--ifx-widget-max-width, 900px);
}

/* ════ LEGACY CLASS NAMES (used by booking.js and old CSS) ══════════ */

/* tp-hd = step header wrapper */
#techpro-booking-widget .tp-hd { margin-bottom: 22px; }

/* tp-h1 = step main heading — targeted by build_design_css font-size overrides */
#techpro-booking-widget .tp-h1 {
  font-family: var(--font-h);
  font-size: clamp(22px, 3.5vw, 32px);
  font-weight: 800;
  color: var(--txt);
  letter-spacing: -.4px;
  line-height: 1.2;
  margin: 0 0 7px;
}

/* tp-sub = step subtitle — targeted by build_design_css */
#techpro-booking-widget .tp-sub {
  font-size: 15px;
  color: var(--txt-2);
  line-height: 1.65;
  margin: 0 0 18px;
}

/* tp-crumb = breadcrumb trail shown in steps 2-4 */
#techpro-booking-widget .tp-crumb {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--txt-2);
  background: var(--bg-2);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 5px 12px;
  margin-top: 8px;
  min-height: 20px;
}
#techpro-booking-widget .tp-crumb:empty { display: none; }

/* tp-custom-box + tp-custom-lbl + tp-custom-row (steps 3 & 4 custom entry) */
#techpro-booking-widget .tp-custom-box {
  background: var(--bg-2);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: 18px;
  margin-top: 14px;
}
#techpro-booking-widget .tp-custom-lbl {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 600;
  color: var(--txt-2);
  margin-bottom: 10px;
}
#techpro-booking-widget .tp-custom-row {
  display: flex;
  gap: 8px;
}
#techpro-booking-widget .tp-textarea {
  width: 100%;
  padding: 10px 13px;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 14px;
  font-family: var(--font-b);
  color: var(--txt);
  resize: vertical;
  min-height: 80px;
  line-height: 1.5;
  outline: none;
  -webkit-appearance: none;
  display: block;
}
#techpro-booking-widget .tp-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(24,96,240,.14);
}

/* tp-loading (inside grids while fetching) */
#techpro-booking-widget .tp-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 32px 20px;
  color: var(--txt-3);
  font-size: 14px;
  grid-column: 1 / -1;
}

/* tp-saving-badge (coupon savings pill shown on step 5) */
#techpro-booking-widget .tp-saving-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--green-lite);
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 99px;
  margin-top: 8px;
  border: 1px solid rgba(5,150,105,.2);
}

/* tp-err-card (error cards inside grids) */
#techpro-booking-widget .tp-err-card {
  text-align: center;
  padding: 24px 20px;
  font-size: 14px;
  color: var(--txt-2);
  line-height: 1.6;
  grid-column: 1 / -1;
}
#techpro-booking-widget .tp-refresh-page {
  display: inline-block;
  margin-top: 10px;
  padding: 8px 16px;
  background: var(--accent);
  color: #fff;
  border-radius: var(--radius-xs);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  font-family: var(--font-b);
}

/* tp-price-tag + badges in service cards */
#techpro-booking-widget .tp-price-tag {
  font-weight: 800;
  color: var(--accent);
  font-family: var(--font-h);
}
#techpro-booking-widget .tp-price-from {
  font-size: .8em;
  font-weight: 600;
  opacity: .8;
}
#techpro-booking-widget .tp-badge-free,
#techpro-booking-widget .tp-badge-quote {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 99px;
}
#techpro-booking-widget .tp-badge-free  { background: var(--green-lite); color: var(--green); }
#techpro-booking-widget .tp-badge-quote { background: var(--amber-lite); color: var(--amber); }

/* ════ TRUST STRIP & RECENT TICKER ══════════════════════════════════ */
.ifix-trust-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 6px 20px;
  padding: 12px 20px;
  background: #f0f7ff;
  border: 1px solid #dce8f8;
  border-radius: 10px;
  margin-bottom: 16px;
  font-size: 13px;
  color: #2563eb;
}
.ifix-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.ifix-trust-ico { font-size: 14px; }
.ifix-recent-ticker {
  text-align: center;
  padding: 8px 16px;
  background: #f0fdf4;
  border: 1px solid #a7f3d0;
  border-radius: 8px;
  margin-bottom: 14px;
  font-size: 13px;
  color: #065f46;
}

/* ════ CUSTOMER EXPERIENCE v12.1 ════════════════════════════════════ */
/* The ifix-booking-v111 class enables the premium layered design */
#techpro-booking-widget.ifix-booking-v111 {
  padding: 40px clamp(16px, 3vw, 36px) 56px;
  background: linear-gradient(180deg, #f6f9ff 0%, #ffffff 50%);
  border-radius: 16px;
  max-width: var(--ifx-widget-max-width, 900px);
}
#techpro-booking-widget.ifix-booking-v111 .tp-card-shell {
  background: transparent;
  border: none;
  box-shadow: none;
}
#techpro-booking-widget.ifix-booking-v111 .tp-hd { margin-bottom: 24px; }
#techpro-booking-widget.ifix-booking-v111 .tp-h1 {
  font-size: clamp(28px, 4vw, 44px);
  color: #10233f !important;
}
#techpro-booking-widget.ifix-booking-v111 .tp-sub {
  font-size: 16px;
  color: #516179 !important;
  max-width: 680px;
}
#techpro-booking-widget.ifix-booking-v111 .tp-stepper {
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(199,214,236,.85);
  border-radius: 10px;
  padding: 16px 18px 8px;
  box-shadow: 0 12px 30px rgba(16,35,63,.07);
  margin-bottom: 24px;
}
#techpro-booking-widget.ifix-booking-v111 .tp-track-rail { background: #d9e5f6; }
#techpro-booking-widget.ifix-booking-v111 .tp-track-fill { background: linear-gradient(90deg,#1860f0,#0d9488); }
#techpro-booking-widget.ifix-booking-v111 .tp-node {
  width: 34px; height: 34px; border-radius: 8px; border-color: #c9d8ee;
  box-shadow: 0 8px 18px rgba(16,35,63,.08);
}
#techpro-booking-widget.ifix-booking-v111 .tp-node.is-active {
  background: #1860f0; border-color: #1860f0;
  box-shadow: 0 0 0 5px rgba(24,96,240,.14), 0 14px 28px rgba(24,96,240,.28);
  transform: none;
}
#techpro-booking-widget.ifix-booking-v111 .tp-node.is-done { background: #0d9488; border-color: #0d9488; }
#techpro-booking-widget.ifix-booking-v111 .tp-back {
  height: 34px; padding: 0 12px;
  border: 1px solid #dbe5f5; border-radius: 8px;
  background: #fff; color: #516179;
}
#techpro-booking-widget.ifix-booking-v111 .tp-back:hover { border-color: #1860f0; background: #eaf1ff; }
#techpro-booking-widget.ifix-booking-v111 .tp-crumb { border-color: #c7d6ec; background: #fff; color: #1860f0; }
#techpro-booking-widget.ifix-booking-v111 .tp-grid { gap: 14px; }
#techpro-booking-widget.ifix-booking-v111 .tp-card {
  border-radius: 10px !important;
  border: 1px solid #dbe5f5;
  background: #fff;
  box-shadow: 0 1px 2px rgba(16,35,63,.04), 0 12px 26px rgba(16,35,63,.06);
}
#techpro-booking-widget.ifix-booking-v111 .tp-card:hover {
  transform: translateY(-4px);
  border-color: #1860f0;
  box-shadow: 0 18px 44px rgba(24,96,240,.17);
}
#techpro-booking-widget.ifix-booking-v111 .tp-card.selected {
  background: #f7fbff;
  border-color: #1860f0;
  box-shadow: inset 0 0 0 1px #1860f0, 0 20px 46px rgba(24,96,240,.18);
}
#techpro-booking-widget.ifix-booking-v111 .tp-card-name {
  font-size: max(13px, var(--ifx-card-title-size, 15px)) !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: #10233f !important;
}
#techpro-booking-widget.ifix-booking-v111 .tp-card-desc { font-size: 12px; color: #63758f !important; }
#techpro-booking-widget.ifix-booking-v111 .tp-custom-box,
#techpro-booking-widget.ifix-booking-v111 .tp-form-section,
#techpro-booking-widget.ifix-booking-v111 .tp-coupon-section,
#techpro-booking-widget.ifix-booking-v111 .tp-strip,
#techpro-booking-widget.ifix-booking-v111 .tp-est-left,
#techpro-booking-widget.ifix-booking-v111 .tp-price-card,
#techpro-booking-widget.ifix-booking-v111 .tp-done-wrap {
  border-radius: 10px !important;
  border: 1px solid #dbe5f5 !important;
  background: rgba(255,255,255,.95) !important;
  box-shadow: 0 1px 2px rgba(16,35,63,.05), 0 18px 42px rgba(24,96,240,.09) !important;
}
#techpro-booking-widget.ifix-booking-v111 .tp-panel { padding: 0; }
#techpro-booking-widget.ifix-booking-v111 .tp-price-hd { background: #1860f0; border-radius: 10px 10px 0 0; }
#techpro-booking-widget.ifix-booking-v111 .tp-price-amt { font-size: 48px; }
#techpro-booking-widget.ifix-booking-v111 .tp-btn {
  border-radius: 8px !important; min-height: 46px;
  font-weight: 800;
}
#techpro-booking-widget.ifix-booking-v111 .tp-btn-primary {
  background: #1860f0 !important; color: #fff !important;
  border: 1px solid #1860f0 !important;
  box-shadow: 0 16px 32px rgba(24,96,240,.24) !important;
}
#techpro-booking-widget.ifix-booking-v111 .tp-btn-primary:hover {
  background: #0b4fd7 !important;
}
#techpro-booking-widget.ifix-booking-v111 .tp-input,
#techpro-booking-widget.ifix-booking-v111 .tp-textarea {
  border-radius: 8px; border: 1px solid #c7d6ec; background: #fff !important; min-height: 46px;
}
#techpro-booking-widget.ifix-booking-v111 .tp-input:focus,
#techpro-booking-widget.ifix-booking-v111 .tp-textarea:focus {
  border-color: #1860f0; box-shadow: 0 0 0 4px rgba(24,96,240,.13);
}

@media(max-width:640px){
  #techpro-booking-widget .tp-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px;}
  #techpro-booking-widget .tp-card{padding:16px 12px 14px;}
  #techpro-booking-widget .tp-card-name{font-size:12px;}
  #techpro-booking-widget .tp-card-desc{font-size:11px;}
  #techpro-booking-widget .tp-step7-shell{padding:14px 16px 0;}
}
@media(max-width:380px){
  #techpro-booking-widget .tp-grid{grid-template-columns:1fr!important;}
}
