/* ═══════════════════════════════════════════════
   UPC Pest Booking — Public CSS  v5.0
   Brand: #9b1c1c  |  Compact Premium UI
   ═══════════════════════════════════════════════ */

:root{
  --r:  #9b1c1c;
  --rd: #7a1515;
  --rl: #b91c1c;
  --rb: rgba(155,28,28,.14);
  --g:  #15803d;
  --bd: #e5e7eb;
  --bg: #f8f9fa;
  --tx: #111827;
  --mt: #6b7280;
  --cr: 10px;
  --cs: 7px;
  --sh: 0 1px 4px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);
}

.upc-booking-wrap *,.upc-booking-wrap *::before,.upc-booking-wrap *::after{box-sizing:border-box}
.upc-booking-wrap{
  max-width:660px; margin:0 auto;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--tx); font-size:16px; line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

/* ── Stepper ── */
.upc-stepper{display:flex;align-items:center;margin-bottom:24px}
.upc-stepper__item{display:flex;flex-direction:column;align-items:center;gap:4px;flex:0 0 auto}
.upc-stepper__circle{
  width:32px;height:32px;border-radius:50%;
  border:2px solid var(--bd);background:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:all .25s;
}
.upc-stepper__num{font-size:15px;font-weight:700;color:var(--mt)}
.upc-stepper__check{width:14px;height:14px;color:#fff;position:absolute;opacity:0;transition:opacity .2s}
.upc-stepper__item.is-active .upc-stepper__circle{border-color:var(--r);background:var(--r);box-shadow:0 0 0 4px var(--rb)}
.upc-stepper__item.is-active .upc-stepper__num{color:#fff}
.upc-stepper__item.is-active .upc-stepper__label{color:var(--r);font-weight:700}
.upc-stepper__item.is-done .upc-stepper__circle{border-color:var(--r);background:var(--r);position:relative}
.upc-stepper__item.is-done .upc-stepper__num{opacity:0;position:absolute}
.upc-stepper__item.is-done .upc-stepper__check{opacity:1;position:relative}
.upc-stepper__label{font-size:12px;color:var(--mt);white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}
.upc-stepper__line{flex:1;height:2px;background:var(--bd);margin:0 4px 20px;border-radius:2px;overflow:hidden;position:relative}
.upc-stepper__line::after{content:'';position:absolute;inset:0;background:var(--r);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.upc-stepper__line.is-done::after{transform:scaleX(1)}

/* ── Panel ── */
.upc-panel{animation:upc-in .22s ease}
@keyframes upc-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.upc-ph{margin-bottom:16px}
.upc-pt{font-size:20px;font-weight:800;margin:0 0 2px;color:var(--tx)}
.upc-ps{color:var(--mt);margin:0;font-size:15px}
.upc-pf{margin-top:20px}
.upc-pf--nav{display:flex;gap:10px;align-items:center}
.upc-pay-footer{position:sticky;bottom:0;background:#fff;padding:12px 0 4px;z-index:10;border-top:1px solid var(--bd);margin-top:16px}

/* ── Skeleton ── */
.upc-sk{height:90px;border-radius:var(--cr);background:linear-gradient(90deg,#f0f0f0 25%,#fafafa 50%,#f0f0f0 75%);background-size:200% 100%;animation:upc-sh 1.3s infinite}
@keyframes upc-sh{from{background-position:200% 0}to{background-position:-200% 0}}

/* ── Section labels ── */
.upc-sec{margin-bottom:16px}
.upc-sec__label{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--mt);margin-bottom:8px;display:flex;align-items:center;gap:6px}

/* ── Service grid ── */
.upc-service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.upc-service-card{
  background:#fff;border:2px solid var(--bd);border-radius:var(--cr);
  padding:14px 10px 12px;text-align:center;cursor:pointer;
  transition:border-color .18s,box-shadow .18s,transform .15s;
  -webkit-tap-highlight-color:transparent;position:relative;
}
.upc-service-card:hover{border-color:var(--rl);transform:translateY(-1px);box-shadow:var(--sh)}
.upc-service-card.is-selected{border-color:var(--r);background:#fff9f9;box-shadow:0 0 0 3px var(--rb)}
.upc-service-card.is-selected::after{content:'✓';position:absolute;top:6px;right:8px;width:18px;height:18px;background:var(--r);color:#fff;border-radius:50%;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:18px}
.upc-service-card__icon{font-size:30px;display:block;margin-bottom:6px;line-height:1}
.upc-service-card__name{font-size:14px;font-weight:700;line-height:1.3}
.upc-service-card__note{font-size:12px;color:var(--mt);margin-top:3px;line-height:1.3}

/* ── Plan grid ── */
.upc-plan-grid{display:flex;flex-wrap:wrap;gap:6px}
.upc-plan-btn{
  border:2px solid var(--bd);border-radius:var(--cs);background:#fff;
  padding:8px 14px;cursor:pointer;text-align:left;
  transition:border-color .18s,background .18s;-webkit-tap-highlight-color:transparent;
}
.upc-plan-btn__name{font-size:15px;font-weight:700;display:block}
.upc-plan-btn__validity{font-size:13px;color:var(--mt);display:block}
.upc-plan-btn:hover{border-color:var(--rl)}
.upc-plan-btn.is-selected{border-color:var(--r);background:var(--r);box-shadow:0 0 0 3px var(--rb)}
.upc-plan-btn.is-selected .upc-plan-btn__name{color:#fff;font-weight:800}
.upc-plan-btn.is-selected .upc-plan-btn__validity{color:rgba(255,255,255,.8)}

/* ── BHK grid ── */
.upc-bhk-grid{display:flex;flex-wrap:wrap;gap:6px}
.upc-bhk-btn{
  min-width:66px;padding:8px 12px;border:2px solid var(--bd);
  border-radius:var(--cs);background:#fff;cursor:pointer;
  font-size:14px;font-weight:700;transition:border-color .18s,background .18s;
  -webkit-tap-highlight-color:transparent;
}
.upc-bhk-btn:hover{border-color:var(--rl)}
.upc-bhk-btn.is-selected{
  border-color:var(--r);background:var(--r);color:#fff;
  font-weight:800;box-shadow:0 0 0 3px var(--rb);
}

/* ── Gel card ── */
.upc-gel-card{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:#fffbeb;border:1.5px solid #fcd34d;border-radius:var(--cr);
  padding:12px 14px;margin-bottom:12px;
}
.upc-gel-card__left{display:flex;align-items:center;gap:10px;flex:1;min-width:180px;font-size:26px}
.upc-gel-card__title{font-size:15px;font-weight:700;margin-bottom:2px}
.upc-gel-card__desc{font-size:13px;color:var(--mt)}
.upc-gel-card__price{font-size:16px;font-weight:800;color:#92400e;margin-left:auto;white-space:nowrap}
.upc-switch{position:relative;display:inline-flex;cursor:pointer;flex-shrink:0}
.upc-switch input{position:absolute;opacity:0;width:0;height:0}
.upc-switch__track{width:42px;height:24px;background:#d1d5db;border-radius:12px;position:relative;transition:background .2s}
.upc-switch__track::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;box-shadow:0 1px 4px rgba(0,0,0,.25);transition:left .2s}
.upc-switch input:checked~.upc-switch__track{background:var(--r)}
.upc-switch input:checked~.upc-switch__track::after{left:21px}

/* ── Price box ── */
.upc-price-box{background:linear-gradient(135deg,var(--r) 0%,var(--rd) 100%);border-radius:var(--cr);padding:16px 20px;color:#fff}
.upc-price-box__inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.upc-price-box__label{font-size:14px;font-weight:600;opacity:.85;display:block;margin-bottom:2px}
.upc-price-box__note{font-size:12px;opacity:.7;display:block}
.upc-price-box__amount{font-size:32px;font-weight:800;letter-spacing:-.5px}
.upc-price-box__breakdown{font-size:13px;opacity:.75;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.2);display:none}
.upc-price-box__breakdown.has-items{display:block}

/* ── Zone grid ── */
.upc-zone-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.upc-zone-card{
  background:#fff;border:2px solid var(--bd);border-radius:var(--cr);
  padding:14px;cursor:pointer;position:relative;
  transition:border-color .18s,box-shadow .18s;-webkit-tap-highlight-color:transparent;
}
.upc-zone-card:hover{border-color:var(--rl);box-shadow:var(--sh)}
.upc-zone-card.is-selected{border-color:var(--r);background:#fff9f9}
.upc-zone-card.is-selected::after{content:'✓';position:absolute;top:10px;right:12px;color:var(--r);font-weight:800;font-size:17px}
.upc-zone-card__icon{font-size:24px;display:block;margin-bottom:6px}
.upc-zone-card__name{font-size:15px;font-weight:700;margin-bottom:3px}
.upc-zone-card__areas{font-size:13px;color:var(--mt);line-height:1.4}

/* ── Input / Textarea ── */
.upc-input,.upc-textarea{
  width:100%;padding:9px 12px;border:1.5px solid var(--bd);border-radius:var(--cs);
  font-size:16px;font-family:inherit;color:var(--tx);background:#fff;
  transition:border-color .18s,box-shadow .18s;appearance:none;
}
.upc-input:focus,.upc-textarea:focus{outline:none;border-color:var(--r);box-shadow:0 0 0 3px var(--rb)}
.upc-textarea{resize:vertical;min-height:64px}
.upc-input-icon-wrap{position:relative}
.upc-input-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--mt);pointer-events:none}
.upc-input--icon{padding-left:36px}
.upc-date-input{max-width:200px;cursor:pointer}
.upc-hint{font-size:13px;color:var(--mt);margin:4px 0 0}

/* ── Date picker ── */
.upc-date-sec{margin-bottom:20px}
.upc-date-picker-wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.upc-date-input{
  max-width:none;width:auto;padding:10px 16px;
  font-size:17px;font-weight:600;cursor:pointer;
  border:2px solid var(--bd);border-radius:var(--cs);
  background:#fff;color:var(--tx);
  transition:border-color .18s;
}
.upc-date-input:focus{border-color:var(--r);box-shadow:0 0 0 3px var(--rb);outline:none}
.upc-date-hint{font-size:14px;color:var(--mt)}

/* ── Time slots — vertical premium ── */
.upc-slots-sec{animation:upc-in .22s ease}
.upc-slot-groups{display:flex;flex-direction:column;gap:16px}
.upc-slot-group{background:#fafafa;border:1px solid var(--bd);border-radius:var(--cr);overflow:hidden}
.upc-slot-grp-header{
  display:flex;align-items:center;gap:8px;
  padding:10px 14px;background:#fff;
  border-bottom:1px solid var(--bd);
  font-size:15px;font-weight:700;color:var(--tx);
}
.upc-slot-grp-icon{font-size:18px}
.upc-slot-grp-range{margin-left:auto;font-size:13px;font-weight:400;color:var(--mt)}
.upc-slots{display:flex;flex-wrap:wrap;gap:8px;padding:12px 14px}
.upc-slot-btn{
  padding:5px 12px !important;
  border:1.5px solid #9b1c1c !important;border-radius:var(--cs);
  background:#fff;font-size:14px;font-weight:600;cursor:pointer;
  transition:all .2s ease;
  -webkit-tap-highlight-color:transparent;min-width:78px;text-align:center;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
  letter-spacing:.2px;
  color:#9b1c1c;
}
.upc-slot-btn:hover{
  border-color:#9b1c1c !important;color:#9b1c1c;background:#fff9f9 !important;
  transform:translateY(-1px);
  box-shadow:0 4px 10px rgba(155,28,28,.12);
}
.upc-slot-btn.is-selected{
  border-color:#9b1c1c !important;background:#9b1c1c !important;color:#fff;
  font-weight:700;
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(155,28,28,.3);
}
.upc-slot-btn.is-booked{opacity:.35;cursor:not-allowed;pointer-events:none;text-decoration:line-through}

/* ── Fields ── */
.upc-fields-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.upc-field{margin-bottom:12px}
.upc-lbl{display:block;font-size:14px;font-weight:700;margin-bottom:5px;color:var(--tx)}
.upc-req{color:var(--r);margin-left:1px}
.upc-opt{font-weight:400;color:var(--mt);font-size:13px}
.upc-field-error{display:block;font-size:13px;color:#dc2626;margin-top:4px}
.upc-input--error{border-color:#ef4444!important;box-shadow:0 0 0 3px rgba(239,68,68,.12)!important}

/* ── Payment method selector ── */
.upc-pay-methods{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.upc-pay-method{
  display:flex;align-items:center;gap:10px;
  border:2px solid var(--bd);border-radius:var(--cr);padding:12px 14px;
  cursor:pointer;transition:border-color .18s,background .18s;
  -webkit-tap-highlight-color:transparent;
}
.upc-pay-method input[type="radio"]{display:none}
.upc-pay-method:hover{border-color:var(--rl)}
.upc-pay-method.is-selected{border-color:var(--r);background:#fff9f9}
.upc-pay-method__icon{font-size:24px;flex-shrink:0}
.upc-pay-method__name{font-size:15px;font-weight:700}
.upc-pay-method__sub{font-size:13px;color:var(--mt)}

/* ── Summary card ── */
.upc-summary-card{background:var(--bg);border:1.5px solid var(--bd);border-radius:var(--cr);overflow:hidden;margin-bottom:14px}
.upc-summary-card__header{background:var(--r);color:#fff;padding:9px 16px;font-size:13px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}
.upc-summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-bottom:1px solid #f3f4f6;font-size:15px}
.upc-summary-row:last-child{border-bottom:none}
.upc-summary-row__label{color:var(--mt)}
.upc-summary-row__val{font-weight:600;text-align:right;max-width:55%}
.upc-summary-row--total{background:#fff9f9;font-size:17px}
.upc-summary-row--total .upc-summary-row__label{font-weight:700;color:var(--tx)}
.upc-summary-row--total .upc-summary-row__val{color:var(--r);font-size:20px;font-weight:800}

/* ── Trust badges ── */
.upc-trust-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.upc-trust-item{font-size:13px;color:var(--mt);background:#f3f4f6;border-radius:20px;padding:4px 10px}

/* ── Error box ── */
.upc-err-box{background:#fef2f2;border:1.5px solid #fca5a5;border-radius:var(--cs);padding:10px 14px;font-size:15px;color:#991b1b;margin-bottom:12px}
.upc-err-box::before{content:'⚠️ '}

/* ── Buttons ── */
.upc-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:11px 20px;border-radius:var(--cs);border:none;cursor:pointer;
  font-size:16px;font-weight:700;font-family:inherit;
  transition:background .18s,opacity .18s,transform .15s,box-shadow .18s;
  text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent;
}
.upc-btn--next{background:var(--r);color:#fff;box-shadow:0 4px 12px var(--rb)}
.upc-btn--next:hover:not(:disabled){background:var(--rd);transform:translateY(-1px);box-shadow:0 6px 18px var(--rb)}
.upc-btn--next:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.upc-btn--back{background:#fff;color:var(--mt);border:1.5px solid var(--bd);padding:11px 14px}
.upc-btn--back:hover{background:var(--bg);color:var(--tx)}
.upc-btn--pay{flex:1;justify-content:center;background:#15803d;color:#fff;box-shadow:0 4px 12px rgba(21,128,61,.25);font-size:17px}
.upc-btn--pay:hover:not(:disabled){background:#166534;transform:translateY(-1px)}
.upc-btn--pay:disabled{opacity:.45;cursor:not-allowed}
.upc-arr{font-size:17px;transition:transform .18s}
.upc-btn--next:hover:not(:disabled) .upc-arr{transform:translateX(3px)}
.upc-btn__lock{width:16px;height:16px;flex-shrink:0}

/* Loading state */
.upc-btn--loading{pointer-events:none;opacity:.75;position:relative;padding-right:40px}
.upc-btn--loading::after{content:'';position:absolute;right:12px;top:50%;width:15px;height:15px;margin-top:-7.5px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:upc-spin .7s linear infinite}
@keyframes upc-spin{to{transform:rotate(360deg)}}

.upc-pay-note{text-align:center;font-size:13px;color:var(--mt);margin:8px 0 0}

/* ── Thank You ── */
.upc-ty-wrap{display:flex;justify-content:center;padding:40px 16px}
.upc-ty-card{max-width:500px;width:100%;background:#fff;border-radius:14px;box-shadow:0 4px 6px rgba(0,0,0,.07),0 10px 30px rgba(0,0,0,.1);overflow:hidden;text-align:center}
.upc-ty-card__top{background:linear-gradient(135deg,var(--r) 0%,var(--rd) 100%);padding:30px 28px 24px}
.upc-ty-card__icon{font-size:50px;display:block;margin-bottom:10px}
.upc-ty-card__heading{font-size:23px;font-weight:800;color:#fff;margin:0 0 6px}
.upc-ty-card__sub{color:rgba(255,255,255,.8);font-size:15px;margin:0}
.upc-ty-card__body{padding:24px}
.upc-ty-details{text-align:left;background:var(--bg);border-radius:var(--cs);padding:4px 0;margin-bottom:18px}
.upc-ty-row{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;border-bottom:1px solid var(--bd);font-size:15px}
.upc-ty-row:last-child{border-bottom:none}
.upc-ty-row__label{color:var(--mt)}
.upc-ty-row__val{font-weight:700;text-align:right}
.upc-ty-row--amount .upc-ty-row__val{color:var(--r);font-size:19px}
.upc-ty-num{font-family:monospace;letter-spacing:1px;color:var(--r)}
.upc-ty-next{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:var(--cs);padding:14px 16px;margin-bottom:16px;text-align:left}
.upc-ty-next__title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--g);margin-bottom:10px}
.upc-ty-next__steps{display:flex;flex-direction:column;gap:8px}
.upc-ty-next__step{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:#374151}
.upc-ty-next__num{width:20px;height:20px;flex-shrink:0;background:var(--g);color:#fff;border-radius:50%;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}
.upc-ty-contact{font-size:14px;color:var(--mt);margin:0 0 16px}
.upc-ty-invoice{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:#fff;border:1.5px solid var(--bd);border-radius:var(--cs);font-size:14px;font-weight:600;color:var(--tx);text-decoration:none;margin-bottom:12px;transition:border-color .18s,color .18s}
.upc-ty-invoice:hover{border-color:var(--r);color:var(--r)}
.upc-ty-home{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:var(--r);color:#fff;border-radius:var(--cs);font-weight:700;font-size:15px;text-decoration:none;transition:background .18s}
.upc-ty-home:hover{background:var(--rd)}

/* ── Responsive ── */
@media(max-width:540px){
  .upc-stepper__label{display:none}
  .upc-service-grid{grid-template-columns:repeat(2,1fr)}
  .upc-zone-grid{grid-template-columns:1fr}
  .upc-fields-grid{grid-template-columns:1fr}
  .upc-plan-grid{grid-template-columns:1fr 1fr}
  .upc-pay-methods{grid-template-columns:1fr}
  .upc-datetime-row{flex-direction:column;gap:12px}
  .upc-pt{font-size:18px}
  .upc-price-box__amount{font-size:28px}
  .upc-ty-card__top{padding:24px 20px 18px}
  .upc-ty-card__body{padding:18px}
}
@media(max-width:360px){
  .upc-service-grid{grid-template-columns:1fr 1fr}
  .upc-bhk-btn{min-width:56px;padding:7px 10px}
}

/* ════════════════════════════════
   THANK YOU PAGE — Final Design
   ════════════════════════════════ */
.upc-ty-wrap{
  max-width:640px; margin:0 auto; padding:24px 16px 10px;
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;
  font-size:16px; color:#1a1a1a; line-height:1.55;
  display:block; /* force single column */
}

/* ── Confirmation Banner ── */
.upc-ty-banner{
  display:flex; align-items:flex-start; gap:14px;
  background:#fff; border:1.5px solid #d1fae5;
  border-radius:10px; padding:18px 20px;
  margin-bottom:20px;
  box-shadow:0 2px 12px rgba(21,128,61,.08);
  animation:upc-ty-in .4s ease;
}
@keyframes upc-ty-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.upc-ty-banner__check{width:40px;height:40px;flex-shrink:0;margin-top:2px}
.upc-ty-banner__check svg{width:40px;height:40px}
.upc-ty-banner__heading{
  font-size:17px;font-weight:700;color:#111827;margin-bottom:6px;line-height:1.4;
}
.upc-ty-name{color:#9b1c1c;font-weight:800}
.upc-ty-banner__sub{font-size:15px;color:#6b7280;line-height:1.55}

/* ── 4 Meta cards ── */
.upc-ty-meta-grid{
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:1px; background:#e5e7eb;
  border:1px solid #e5e7eb; border-radius:10px;
  overflow:hidden; margin-bottom:12px;
}
.upc-ty-meta-card{
  background:#fff; padding:14px 12px; text-align:center;
}
.upc-ty-meta-card__label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;margin-bottom:6px}
.upc-ty-meta-card__val{font-size:16px;font-weight:700;color:#111827;line-height:1.3}
.upc-ty-meta-card__val--red{color:#9b1c1c;font-size:17px}

.upc-ty-cod-note{font-size:15px;color:#6b7280;margin-bottom:16px;padding:0 4px}

/* ── Cards (Order Details + Billing) ── */
.upc-ty-card{
  border:1px solid #e5e7eb; border-radius:10px;
  overflow:hidden; margin-bottom:16px;
  box-shadow:0 1px 4px rgba(0,0,0,.05);
}
.upc-ty-card__header{
  background:#9b1c1c; color:#fff;
  padding:10px 18px; font-size:14px;
  font-weight:800; letter-spacing:1.2px;
  text-transform:uppercase; text-align:center;
}

/* ── Table ── */
.upc-ty-table{width:100%;border-collapse:collapse}
.upc-ty-th{
  background:#1a1a1a; color:#fff;
  padding:9px 16px; font-size:13px;
  font-weight:700; text-transform:uppercase;
  letter-spacing:.5px; text-align:left;
}
.upc-ty-th--right{text-align:right}
.upc-ty-td{padding:14px 16px;vertical-align:top;border-bottom:1px solid #f3f4f6;font-size:15px}
.upc-ty-td--right{text-align:right;white-space:nowrap;font-weight:600}
.upc-ty-product-name{font-weight:700;color:#9b1c1c;margin-bottom:8px;font-size:15px}
.upc-ty-product-details{display:flex;flex-direction:column;gap:3px;font-size:12.5px;color:#374151}
.upc-ty-product-details strong{color:#111827}

/* ── Totals ── */
.upc-ty-totals{border-top:1px solid #e5e7eb}
.upc-ty-totals__row{
  display:flex;justify-content:space-between;align-items:center;
  padding:10px 16px; font-size:15px; color:#374151;
  border-bottom:1px solid #f9fafb;
}
.upc-ty-totals__row:last-child{border-bottom:none}
.upc-ty-totals__row--total{
  font-size:17px; font-weight:700; color:#9b1c1c;
  background:#fff9f9; padding:12px 16px;
}

/* ── Billing ── */
.upc-ty-billing{padding:16px 18px}
.upc-ty-billing__name{font-weight:700;font-size:16px;margin-bottom:6px}
.upc-ty-billing__line{font-size:15px;color:#374151;margin-bottom:6px;line-height:1.6}
.upc-ty-billing__contact{
  display:flex;align-items:center;gap:7px;
  font-size:15px;margin-top:4px;
}
.upc-ty-billing__contact a{color:#9b1c1c;text-decoration:none;font-weight:500}
.upc-ty-billing__contact a:hover{text-decoration:underline}
.upc-ty-billing__contact svg{color:#9b1c1c;flex-shrink:0}

/* ── Invoice ── */
.upc-ty-invoice-row{text-align:center;margin-bottom:20px}
.upc-ty-invoice-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 20px;border:1.5px solid #e5e7eb;
  border-radius:7px;font-size:15px;font-weight:600;
  color:#374151;text-decoration:none;
  transition:border-color .18s,color .18s;
}
.upc-ty-invoice-btn:hover{border-color:#9b1c1c;color:#9b1c1c}

/* ── CTA Button ── */
.upc-ty-cta{text-align:center;margin-top:8px}
.upc-ty-cta-btn{
  display:inline-block; padding:12px 32px;
  background:#9b1c1c; color:#fff;
  border-radius:7px; font-size:16px;
  font-weight:700; text-decoration:none;
  letter-spacing:.3px;
  transition:background .18s,transform .15s,box-shadow .18s;
  box-shadow:0 4px 14px rgba(155,28,28,.25);
}
.upc-ty-cta-btn:hover{background:#7a1515;transform:translateY(-1px);box-shadow:0 6px 20px rgba(155,28,28,.3)}

/* ── Responsive ── */
@media(max-width:520px){
  .upc-ty-meta-grid{grid-template-columns:repeat(2,1fr)}
  .upc-ty-banner{flex-direction:row;gap:12px;align-items:flex-start}
  .upc-ty-banner__check{width:32px;height:32px;flex-shrink:0}
  .upc-ty-banner__check svg{width:32px;height:32px}
  .upc-ty-banner__heading{font-size:16px}
}

/* ════════════════════════════════
   THANK YOU — Premium Order + Billing Cards
   ════════════════════════════════ */

/* Section title with lines */
.upc-ty-section-title{
  display:flex; align-items:center; gap:12px;
  margin-bottom:18px;
}
.upc-ty-section-title__line{
  flex:1; height:1px; background:var(--bd);
}
.upc-ty-section-title__text{
  font-size:13px; font-weight:800;
  letter-spacing:1.5px; text-transform:uppercase;
  color:var(--r); white-space:nowrap;
}

/* Order card */
.upc-ty-order-card{
  background:#fff;
  border:1px solid var(--bd); border-radius:12px;
  padding:20px; margin-bottom:16px;
  box-shadow:0 1px 4px rgba(0,0,0,.05);
}

/* Service summary row */
.upc-ty-service-row{
  display:flex; align-items:center; gap:14px;
  background:var(--bg); border-radius:10px;
  padding:14px 16px; margin-bottom:18px;
}
.upc-ty-service-icon{font-size:34px;flex-shrink:0;line-height:1}
.upc-ty-service-info{flex:1;min-width:0}
.upc-ty-service-name{font-size:17px;font-weight:800;color:var(--tx);margin-bottom:3px}
.upc-ty-service-plan{font-size:14px;color:var(--mt)}
.upc-ty-service-amount{
  font-size:20px; font-weight:800;
  color:var(--r); white-space:nowrap;
}

/* Details grid — 2 cols */
.upc-ty-details-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:10px; margin-bottom:18px;
}
.upc-ty-detail-item{
  display:flex; flex-direction:column; gap:3px;
  background:var(--bg); border-radius:8px;
  padding:10px 12px;
}
.upc-ty-detail-item--full{grid-column:1/-1}
.upc-ty-detail-label{font-size:13px;color:var(--mt);font-weight:600}
.upc-ty-detail-val{font-size:15px;font-weight:700;color:var(--tx)}
.upc-ty-detail-val--green{color:#15803d}

/* Price summary */
.upc-ty-price-summary{
  border-top:1px solid var(--bd); padding-top:14px;
}
.upc-ty-price-row{
  display:flex; justify-content:space-between;
  padding:6px 0; font-size:15px; color:#374151;
  border-bottom:1px solid #f9fafb;
}
.upc-ty-price-row:last-child{border-bottom:none}
.upc-ty-price-row--total{
  font-size:18px; font-weight:800;
  color:var(--r); padding-top:10px;
  border-top:2px solid var(--bd); margin-top:4px;
  border-bottom:none;
}

/* Billing card */
.upc-ty-billing-card{
  background:#fff;
  border:1px solid var(--bd); border-radius:12px;
  padding:20px; margin-bottom:16px;
  box-shadow:0 1px 4px rgba(0,0,0,.05);
  max-width:640px; margin-left:auto; margin-right:auto;
}

.upc-ty-billing-inner{
  display:flex; gap:20px; align-items:flex-start;
  flex-wrap:wrap;
}
.upc-ty-billing-left{flex:1;min-width:200px}
.upc-ty-billing-right{
  display:flex; flex-direction:column; gap:8px;
  flex-shrink:0;
}
.upc-ty-billing__name{font-size:17px;font-weight:800;margin-bottom:6px}
.upc-ty-billing__address{font-size:15px;color:#374151;line-height:1.6}

/* Contact chips */
.upc-ty-contact-chip{
  display:inline-flex; align-items:center; gap:7px;
  padding:8px 14px;
  background:var(--bg); border:1px solid var(--bd);
  border-radius:20px; font-size:15px; font-weight:600;
  color:var(--r); text-decoration:none;
  transition:background .18s, border-color .18s;
  white-space:nowrap;
}
.upc-ty-contact-chip:hover{background:#fff9f9;border-color:var(--r)}
.upc-ty-contact-chip svg{color:var(--r);flex-shrink:0}

/* Remove old card styles that conflict */
.upc-ty-card .upc-ty-card__header,
.upc-ty-card .upc-ty-table,
.upc-ty-card .upc-ty-th { display:revert; }

@media(max-width:480px){
  .upc-ty-details-grid{grid-template-columns:1fr}
  .upc-ty-billing-inner{flex-direction:column;gap:14px}
  .upc-ty-billing-right{flex-direction:row;flex-wrap:wrap}
}

/* ── Compact Booking Summary (Step 5) ── */
.upc-sum-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:1px; background:var(--bd);
  border-bottom:1px solid var(--bd);
}
.upc-sum-item{
  background:#fff; padding:9px 14px;
  display:flex; flex-direction:column; gap:2px;
}
.upc-sum-lbl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--mt)}
.upc-sum-val{font-size:15px;font-weight:600;color:var(--tx)}
.upc-sum-row{
  display:flex; justify-content:space-between; align-items:flex-start;
  padding:9px 14px; border-bottom:1px solid #f3f4f6;
  gap:12px; font-size:15px;
}
.upc-sum-row .upc-sum-lbl{font-size:14px;font-weight:600;color:var(--mt);flex-shrink:0;text-transform:none;letter-spacing:0}
.upc-sum-row .upc-sum-val{text-align:right;color:var(--tx);font-weight:500}
.upc-sum-total{
  display:flex; justify-content:space-between;
  padding:12px 14px; background:#fff9f9;
  font-size:17px; font-weight:800; color:var(--r);
}

@media(max-width:400px){
  .upc-sum-grid{grid-template-columns:1fr}
}

/* ── Payment Failed / Cancelled Box ── */
.upc-fail-box{
  text-align:center; padding:4px 0;
}
.upc-fail-box__icon{font-size:34px;margin-bottom:8px}
.upc-fail-box__title{font-size:17px;font-weight:800;color:#991b1b;margin-bottom:6px}
.upc-fail-box__msg{font-size:15px;color:#374151}

/* ── Coupon Code ── */
.upc-coupon-row { margin-bottom: 14px; }
.upc-coupon-input-wrap {
  display: flex; gap: 8px; align-items: center;
}
.upc-coupon-input-wrap .upc-input {
  flex: 1; font-family: monospace; font-weight: 700;
  letter-spacing: 1px; text-transform: uppercase;
}
.upc-btn--coupon {
  background: #374151; color: #fff;
  padding: 9px 18px; font-size: 14px;
  border-radius: var(--cs); border: none;
  cursor: pointer; font-weight: 700; white-space: nowrap;
  transition: background .18s;
}
.upc-btn--coupon:hover { background: #1f2937; }
.upc-btn--coupon:disabled { opacity: .5; cursor: not-allowed; }
.upc-btn--coupon-done { background: #15803d !important; }
.upc-coupon-remove {
  background: none; border: none; color: var(--mt);
  font-size: 13px; cursor: pointer; padding: 0 4px;
  margin-left: 4px;
}
.upc-coupon-remove:hover { color: #dc2626; }
.upc-coupon-msg {
  font-size: 13px; font-weight: 600;
  padding: 7px 12px; border-radius: var(--cs);
  margin-top: 8px;
}
.upc-coupon-msg--success { background: #f0fdf4; color: #15803d; }
.upc-coupon-msg--error   { background: #fef2f2; color: #dc2626; }

/* ── Online Pay Offer Banner ── */
.upc-offer-banner {
  background: var(--offer-color, #15803d);
  color: #fff;
  border-radius: var(--cs);
  padding: 11px 16px;
  margin-bottom: 14px;
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  animation: upc-pulse-banner 2s ease-in-out infinite;
}
.upc-offer-banner__text {
  font-size: 14px; font-weight: 700; text-align: center; line-height: 1.4;
}
@keyframes upc-pulse-banner {
  0%,100% { opacity: 1; }
  50%      { opacity: .88; }
}

/* ── Coupon Suggestions ── */
.upc-coupon-suggestions { margin-top: 10px; }
.upc-coupon-list-label {
  font-size: 12px; font-weight: 700; color: var(--mt);
  text-transform: uppercase; letter-spacing: .4px;
  margin-bottom: 8px;
}
.upc-coupon-chips {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.upc-coupon-chip {
  display: flex; flex-direction: column;
  background: #fff; border: 1.5px dashed var(--r);
  border-radius: var(--cs); padding: 8px 12px;
  cursor: pointer; transition: background .18s, border-color .18s;
  min-width: 120px;
}
.upc-coupon-chip:hover { background: #fff9f9; border-color: var(--rd); }
.upc-coupon-chip__code {
  font-family: monospace; font-weight: 800;
  font-size: 14px; color: var(--r); letter-spacing: 1px;
}
.upc-coupon-chip__val {
  font-size: 13px; font-weight: 700; color: #15803d;
  margin-top: 2px;
}
.upc-coupon-chip__desc {
  font-size: 11px; color: var(--mt); margin-top: 2px;
}

/* ── Coupon chip applied state ── */
.upc-coupon-chip.is-applied {
  background: #f0fdf4;
  border-color: #15803d;
  border-style: solid;
}
.upc-coupon-chip.is-applied .upc-coupon-chip__code {
  color: #15803d;
}
.upc-coupon-chip.is-applied::after {
  content: '✓ Applied';
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: #15803d;
  margin-top: 4px;
}

/* ── Coupon chip muted (wrong payment method) ── */
.upc-coupon-chip--muted {
  opacity: .45; cursor: not-allowed;
  border-style: dashed; filter: grayscale(.5);
}
.upc-coupon-chip--muted:hover { background: #fff; border-color: var(--r); }


/* Flatpickr Custom Theme */
.flatpickr-calendar {
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,.12);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
  background: #9b1c1c;
  border-color: #9b1c1c;
}
.flatpickr-day:hover {
  background: #fff9f9;
  border-color: #9b1c1c;
}
.flatpickr-months .flatpickr-month {
  background: #9b1c1c;
  color: #fff;
}
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
  color: #fff;
}
.flatpickr-weekday {
  color: #9b1c1c;
  font-weight: 700;
}
.flatpickr-day.today {
  border-color: #9b1c1c;
  color: #9b1c1c;
}
.flatpickr-prev-month svg,
.flatpickr-next-month svg {
  fill: #fff;
}

.upc-btn--coupon-done {
    color: white;
    border: 1px solid #15803d;
}

button#upc-coupon-apply {
    color: #ffffff;
    border: 1px solid #15803d;
    background: #4CAF50 !important;
}

button#upc-coupon-apply:hover {
    color: white !important;
    background: #4CAF50 !important;
}
button#upc-coupon-remove:hover {
    background: #bd2020 !important;
}

button.upc-btn.upc-btn--back {
    border: 1px solid #bd2020;
    color: #bd2020;
}

button.upc-btn.upc-btn--back:hover {
    background: #bd2020 !important;
	color: white !important
}

.upc-btn--pay:hover:not(:disabled) {
    border: 1px solid #166534 !important;
	color: #bd2020 !important;
}

button#upc-pay-btn:hover {
    color: white !important;
}

button#upc-pay-btn {
    border: 1px solid #bd2020;
    color: #bd2020;
}

button.upc-slot-btn {
    border: 1px solid #9b1c1c !important;
    color: #bd2020;
}

button.upc-slot-btn:hover {
    border: 1px solid #9b1c1c !important;
    color: #9b1c1c !important;
}

button#upc-step2-next {
    border: 1px solid #bd2020;
    color: #bd2020;
}

button.upc-plan-btn {
    border: 1px solid #bd2020;
    color: #bd2020;
}

button.upc-plan-btn:hover {
    background: #bd2020 !important;
}

button.upc-plan-btn:hover span.upc-plan-btn__validity {
    color: white;
}

button.upc-bhk-btn {
    border: 1px solid #bd2020;
    color: #bd2020;
}

button.upc-bhk-btn:hover {
    background: #bd2020 !important;
}

[type=button]:focus {
	background: #bd2020 !important;
}

button#upc-step1-next {
    border: 1px solid #bd2020;
    color: #bd2020;
}

button#upc-step1-next:hover {    
    color: white;
}

button#upc-step2-next:hover{
	color: white;
}

a.upc-ty-cta-btn {
    color: white !important;
}


.upc-booking-wrap {
    border: 1px solid #ccc;
    padding: 40px;
    border-radius: 20px;
    box-shadow: 5px 5px 8px #ccc;
}
