/* ================================================================
   WithIbrahim — Public Registration page
   Tokens + shared components (.btn/.form-control/.note/.badge) come
   from admin.css (loaded globally in App.razor). This file styles the
   public shell + registration-specific components on the SAME tokens.
   No old --gray-*/--wi-*/--font/--grad-* — design system only.
================================================================ */

/* ── Public shell ── */
body{font-family:var(--fb);background:var(--bg);color:var(--text);line-height:1.6;display:block;}
.reg-wrap{min-height:100vh;display:flex;flex-direction:column;}

.pub-hdr{
  background:var(--ink);
  padding:18px clamp(20px,5%,60px);
  display:flex;align-items:center;justify-content:space-between;
}
.pub-logo{font-family:var(--fh);font-weight:600;font-size:20px;color:#fff;}
.pub-logo span{color:var(--ocean-bright);}
.pub-hdr-right{display:flex;align-items:center;gap:16px;}
.pub-back{color:rgba(255,255,255,.7);text-decoration:none;font-size:13px;font-weight:600;transition:.15s;white-space:nowrap;}
.pub-back:hover{color:#fff;}

.pub-content{max-width:860px;width:100%;margin:0 auto;padding:36px 20px 80px;flex:1;}
.pub-hero{text-align:center;margin-bottom:30px;}
.pub-hero h1{font-family:var(--fh);font-weight:600;font-size:28px;color:var(--ink);letter-spacing:-.4px;margin-bottom:6px;}
.pub-hero p{font-size:15px;color:var(--soft);}
.pub-footer{text-align:center;padding:24px;font-size:12px;color:var(--mute);border-top:1px solid var(--bsoft);}

/* ── Top stepper (Parent / Children / Configure / Review) ── */
.stepper{display:flex;align-items:flex-start;justify-content:center;margin-bottom:28px;}
.stepper-item{display:flex;flex-direction:column;align-items:center;gap:6px;}
.stepper-num{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-weight:700;font-size:14px;
  background:var(--bsoft);color:var(--mute);transition:.16s;
}
.stepper-num.active{background:var(--ink);color:#fff;}
.stepper-num.done{background:var(--green);color:#fff;}
.stepper-lbl{font-size:11px;font-weight:600;color:var(--mute);}
.stepper-lbl.active{color:var(--ink);font-weight:700;}
.stepper-lbl.done{color:var(--soft);}
.stepper-connector{flex:0 0 48px;height:2px;background:var(--bsoft);margin:18px 6px 0;border-radius:2px;}
.stepper-connector.done{background:var(--green);}

/* ── Cards & step headers ── */
.card{background:var(--surface);border:1.5px solid var(--ink);border-radius:16px;padding:22px;}
.step-hdr{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--bsoft);}
.step-num{
  width:34px;height:34px;border-radius:10px;flex-shrink:0;
  background:var(--ink);color:var(--ocean-bright);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-weight:700;font-size:14px;
}
.step-title{font-family:var(--fh);font-weight:600;font-size:17px;color:var(--ink);}
.step-sub{font-size:12px;color:var(--soft);margin-top:1px;}
.step-hdr-action{margin-left:auto;}

/* ── Forms (extends admin.css form-control) ── */
.form-grid{display:grid;gap:14px;}
.form-grid-2{grid-template-columns:1fr 1fr;}
.full-span{grid-column:1/-1;}
.field-error{font-size:11.5px;color:var(--red);margin-top:2px;}
.form-control.input-error{border-color:var(--red);}
.form-control.input-valid{border-color:var(--green);}

/* ── Phone: country-prefix selector + number (inline searchable, no floating panel) ── */
.phone-row{display:flex;gap:8px;align-items:stretch;}
.phone-prefix{
  display:flex;align-items:center;gap:7px;flex-shrink:0;
  background:var(--surface);border:1.5px solid var(--bsoft);border-radius:10px;
  padding:0 12px;cursor:pointer;font-family:var(--fb);font-size:14px;color:var(--ink);transition:.16s;
}
.phone-prefix:hover{border-color:var(--ink);}
.phone-prefix.open{border-color:var(--ocean);box-shadow:0 0 0 3px rgba(47,111,179,.15);}
.phone-prefix-flag{width:24px;height:18px;border-radius:3px;}
.phone-prefix-dial{font-weight:600;}
.phone-prefix-caret{font-size:10px;color:var(--mute);}
.phone-row .form-control{flex:1;min-width:0;}

.phone-picker{margin-top:8px;border:1.5px solid var(--bsoft);border-radius:11px;overflow:hidden;}
.phone-picker-search{
  width:100%;border:none;border-bottom:1px solid var(--brow);
  padding:10px 12px;font-family:var(--fb);font-size:13.5px;color:var(--ink);
  background:var(--surface);outline:none;
}
.phone-picker-search::placeholder{color:var(--mute);}
.phone-picker-list{max-height:200px;overflow-y:auto;padding:6px;}
.phone-picker-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:8px;cursor:pointer;font-size:14px;color:var(--ink);transition:.12s;
}
.phone-picker-item img{width:24px;height:18px;border-radius:3px;flex-shrink:0;}
.phone-picker-name{flex:1;min-width:0;}
.phone-picker-dial{font-weight:600;color:var(--soft);}
.phone-picker-item:hover,
.phone-picker-item.sel{background:var(--ink);color:#fff;}
.phone-picker-item:hover .phone-picker-dial,
.phone-picker-item.sel .phone-picker-dial{color:rgba(255,255,255,.8);}
.phone-picker-empty{padding:16px;text-align:center;font-size:13px;color:var(--mute);}

/* ── Step 2: child blocks ── */
.child-block{border:1.5px solid var(--bsoft);border-radius:12px;padding:16px;margin-bottom:14px;}
.child-block-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.child-lbl{font-family:var(--fh);font-weight:600;font-size:14px;color:var(--ink);}
.btn-full{width:100%;justify-content:center;}
.btn-dashed{border-style:dashed;border-color:var(--bsoft);color:var(--soft);background:var(--surface);}
.btn-dashed:hover{border-color:var(--ink);color:var(--ink);}

/* ── Returning parent recognition ── */
.returning-prompt{
  display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ocean);
  background:var(--sky);border:1px solid var(--sky-border);border-radius:10px;padding:11px 14px;
}
.returning-welcome{
  display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:var(--green);
  background:var(--green-bg);border:1px solid var(--green);border-radius:10px;padding:11px 14px;
}
.returning-children{margin-bottom:18px;}
.rc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-top:8px;}
.rc-card{
  display:flex;align-items:center;gap:10px;text-align:left;cursor:pointer;
  background:var(--surface);border:1.5px solid var(--bsoft);border-radius:12px;padding:10px 12px;transition:.14s;
}
.rc-card:hover{border-color:var(--sky-border);}
.rc-card.sel{background:var(--sky);border-color:var(--ink);}
.rc-av{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:var(--ink);color:var(--ocean-bright);
  display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:700;font-size:14px;
}
.rc-info{flex:1;min-width:0;display:flex;flex-direction:column;}
.rc-name{font-weight:600;font-size:13.5px;color:var(--ink);}
.rc-age{font-size:11.5px;color:var(--soft);}
.rc-check{font-weight:700;color:var(--ocean);font-size:15px;flex-shrink:0;}
.returning-sub-lbl{font-size:12px;color:var(--soft);font-weight:600;margin:14px 0 4px;}

/* ── Step 3: per-child stepper + avatar ── */
.child-stepper{display:flex;align-items:center;justify-content:center;margin-bottom:6px;}
.child-step-dot{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-weight:700;font-size:12px;
  background:var(--bsoft);color:var(--mute);
}
.child-step-dot.active{background:var(--ink);color:#fff;}
.child-step-dot.done{background:var(--green);color:#fff;}
.child-step-line{width:40px;height:2px;background:var(--bsoft);margin:0 4px;}
.child-step-line.done{background:var(--green);}
.child-stepper-label{text-align:center;font-size:13px;color:var(--soft);margin-bottom:16px;}
.child-stepper-label strong{color:var(--ink);}
.child-avatar{
  width:44px;height:44px;border-radius:11px;flex-shrink:0;
  background:var(--ink);color:var(--ocean-bright);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-weight:700;font-size:16px;
}
.child-avatar.sm{width:38px;height:38px;border-radius:10px;font-size:14px;}

/* ── Package selection cards (navy bar → sky head → white body) ── */
.pkg-section{margin-bottom:20px;}
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:8px;}
.pkg-card{
  position:relative;background:var(--surface);
  border:1.5px solid var(--ink);border-radius:14px;overflow:hidden;
  cursor:pointer;transition:.16s;display:flex;flex-direction:column;
}
.pkg-card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:var(--ink);z-index:1;}
.pkg-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(13,31,45,.13);}
.pkg-card--selected{box-shadow:0 0 0 3px rgba(47,111,179,.22);}
/* FIXED-height sky header — identical whether or not a discount exists */
.pkg-card__head{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;height:128px;
  background:var(--sky);padding:16px;border-bottom:1.5px solid var(--ink);
}
.pkg-card__top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;}
.pkg-card__name{font-family:var(--fh);font-weight:600;font-size:18px;color:var(--ink);}
.pkg-card__sport{font-size:11px;font-weight:600;color:var(--soft);margin-top:2px;text-transform:uppercase;letter-spacing:.5px;}
.pkg-card__country{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--soft);flex-shrink:0;}
.pkg-flag-img{width:24px;height:18px;border-radius:3px;}

/* single price line sits just under the name; slack falls BELOW it (no dead gap).
   line height is constant → the fixed 140px header height never changes */
.pkg-price-line{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-top:12px;margin-bottom:auto;}
.pkg-was{font-size:13px;color:var(--mute);text-decoration:line-through;}
.pkg-now{font-family:var(--fh);font-weight:600;font-size:24px;color:var(--ink);}
.pkg-now small{font-family:var(--fb);font-size:12px;font-weight:400;color:var(--soft);}

/* diagonal discount ribbon — bottom-right of the sky header, clipped by overflow:hidden */
.pkg-ribbon{
  position:absolute;bottom:14px;right:-34px;transform:rotate(-45deg);
  padding:6px 42px;white-space:nowrap;z-index:2;
  background:linear-gradient(135deg,#c8102e,#e63950);
  color:#fff;font-size:10.5px;font-weight:800;letter-spacing:.6px;
  box-shadow:0 3px 10px rgba(13,31,45,.22);
}
.pkg-card__body{padding:14px 16px;display:flex;flex-direction:column;gap:10px;flex:1;}
.pkg-card__days{display:flex;flex-wrap:wrap;gap:6px;}
.pkg-chip{font-size:11px;font-weight:600;padding:3px 10px;border-radius:7px;background:var(--surface2);color:var(--steel);border:1px solid var(--bsoft);}
.pkg-card__meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--soft);}
.pkg-card__hours{font-size:12px;color:var(--soft);}
.pkg-card__footer{padding:0 16px 16px;}
.pkg-card__btn{
  text-align:center;padding:11px;border-radius:10px;
  background:var(--surface);border:1.5px solid var(--ink);color:var(--ink);
  font-weight:700;font-size:13.5px;transition:.16s;
}
.pkg-card--selected .pkg-card__btn,
.pkg-card__btn--selected{background:var(--ink);color:var(--ocean-bright);}

/* ── Time slots (capacity-aware) ── */
.timing-child-lbl{font-size:11.5px;font-weight:700;color:var(--mute);text-transform:uppercase;letter-spacing:.8px;}
.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:10px;}
.slot-btn{
  border:1.5px solid var(--bsoft);border-radius:10px;
  padding:12px 8px;text-align:center;cursor:pointer;transition:.14s;background:var(--surface);
}
.slot-btn:hover{border-color:var(--ink);}
.slot-btn.active{border-color:var(--ocean);background:var(--sky);box-shadow:0 0 0 3px rgba(47,111,179,.15);}
.slot-btn.full{opacity:.55;cursor:not-allowed;background:var(--surface2);}
.slot-time{font-family:var(--fh);font-weight:600;font-size:14px;color:var(--ink);}
.slot-cnt{font-size:10px;font-weight:600;color:var(--soft);margin-top:2px;}
.slot-cnt--warn{color:var(--amber);}

/* ── Consent + health ── */
.consent-block{border:1.5px solid var(--bsoft);border-radius:12px;padding:14px 16px;}
.consent-row{display:flex;align-items:flex-start;gap:10px;}
.chk{width:18px;height:18px;accent-color:var(--ink);margin-top:2px;flex-shrink:0;cursor:pointer;}
.consent-lbl{font-size:13px;color:var(--text);line-height:1.5;cursor:pointer;}
.consent-lbl strong{color:var(--ink);}
.health-options{display:flex;gap:10px;}
.health-option-lbl{
  flex:1;display:flex;align-items:center;gap:8px;
  border:1.5px solid var(--bsoft);border-radius:10px;padding:11px 14px;
  font-size:14px;color:var(--ink);cursor:pointer;transition:.14s;
}
.health-option-lbl:hover{border-color:var(--ink);}
.health-option-lbl:has(.radio-input:checked){border-color:var(--ocean);background:var(--sky);}
.radio-input{accent-color:var(--ink);cursor:pointer;}

/* ── Navigation ── */
.child-nav,.step-nav{display:flex;gap:12px;margin-top:10px;}
.child-nav .btn-primary,.step-nav .btn-primary{margin-left:auto;}
.child-nav .btn-full,.step-nav .btn-full{margin-left:0;}
.pay-redirect-note{text-align:center;font-size:12px;color:var(--soft);margin-top:12px;}

/* ── Non-Kuwait: contact/offline success screen ── */
.contact-success{
  max-width:560px;margin:10px auto;
  background:var(--surface);border:1.5px solid var(--ink);border-radius:18px;overflow:hidden;
}
.cs-head{background:var(--sky);padding:32px 24px;text-align:center;border-bottom:1.5px solid var(--ink);}
.cs-emoji{font-size:48px;line-height:1;}
.cs-title{font-family:var(--fh);font-weight:600;font-size:26px;color:var(--ink);margin-top:10px;}
.cs-sub{font-size:14px;color:var(--soft);margin-top:6px;}
.cs-body{padding:24px;display:flex;flex-direction:column;gap:16px;}
.cs-summary{border:1.5px solid var(--bsoft);border-radius:12px;overflow:hidden;}
.cs-row{display:flex;justify-content:space-between;gap:12px;padding:11px 16px;border-bottom:1px solid var(--brow);font-size:14px;}
.cs-row-child{font-weight:600;color:var(--ink);}
.cs-row-pkg{color:var(--soft);text-align:right;}
.cs-total{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:var(--surface2);}
.cs-total-amt{font-family:var(--fh);font-weight:600;font-size:20px;color:var(--ocean);}

/* ── Step 4: review ── */
.review-row{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--brow);font-size:14px;}
.review-row:last-child{border-bottom:none;}
.review-lbl{color:var(--soft);font-weight:600;}
.review-val{color:var(--ink);font-weight:600;text-align:right;}
.review-child-card{background:var(--surface);border:1.5px solid var(--ink);border-radius:14px;padding:18px;margin-bottom:14px;}
.review-card-hdr{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--bsoft);}
.review-card-hdr-info{flex:1;min-width:0;}
.review-card-title{font-family:var(--fh);font-weight:600;font-size:16px;color:var(--ink);}
.review-card-sub{font-size:12px;color:var(--soft);}
.review-total{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--sky);border:1.5px solid var(--ink);border-radius:14px;
  padding:18px 22px;margin-top:4px;
}
.review-total > span:last-child{font-family:var(--fh);color:var(--ocean);}

/* ── Promo / discount code ── */
.promo-box{display:flex;flex-direction:column;gap:6px;margin:18px 0 10px;}
.promo-row{display:flex;gap:8px;}
.promo-row .form-control{flex:1;text-transform:uppercase;}
.promo-applied{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--green-bg);border:1px solid var(--green);border-radius:10px;padding:10px 14px;
}
.promo-applied-text{font-size:13px;font-weight:600;color:var(--green);}
.promo-applied-text strong{font-family:ui-monospace,monospace;}
.promo-remove{
  border:none;background:none;cursor:pointer;color:var(--green);
  font-size:13px;line-height:1;padding:0 2px;flex-shrink:0;
}
.promo-remove:hover{color:var(--red);}

.review-totals{display:flex;flex-direction:column;gap:8px;}
.review-subrow{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:var(--soft);}
.review-discount{color:var(--green);font-weight:600;}
.cs-discount{color:var(--green);}

/* ── Compatibility utilities used by this page's markup (new tokens only) ── */
.u-mb-4{margin-bottom:4px;}.u-mb-6{margin-bottom:6px;}.u-mb-10{margin-bottom:10px;}
.u-mb-12{margin-bottom:12px;}.u-mb-14{margin-bottom:14px;}.u-mb-16{margin-bottom:16px;}.u-mb-20{margin-bottom:20px;}
.u-mt-4{margin-top:4px;}.u-mt-8{margin-top:8px;}.u-mt-16{margin-top:16px;}
.u-pb-14{padding-bottom:14px;}.u-bb{border-bottom:1px solid var(--bsoft);}
.u-flex{display:flex;}.u-center{align-items:center;}.u-gap-12{gap:12px;}
.u-fs-9{font-size:9px;}.u-fs-11{font-size:11px;}.u-fs-12{font-size:12px;}.u-fs-13{font-size:13px;}
.u-fs-14{font-size:14px;}.u-fs-15{font-size:15px;}.u-fs-16{font-size:16px;}.u-fs-26{font-size:26px;}
.u-fw-6{font-weight:600;}.u-fw-7{font-weight:700;}.u-fw-8{font-weight:700;}.u-fw-9{font-weight:700;}
.u-c-g400{color:var(--mute);}.u-c-g500{color:var(--soft);}.u-c-g700{color:var(--ink);}.u-c-g800{color:var(--ink);}
.u-c-royal{color:var(--ocean);}.u-c-success{color:var(--green);}.u-c-danger{color:var(--red);}
.u-ls-n5{letter-spacing:-.5px;}.u-nowrap-pre{white-space:pre-wrap;}.u-mono{font-family:ui-monospace,monospace;}

/* ── Mobile ── */
@media (max-width:640px){
  .pub-content{padding:24px 16px 60px;}
  .pub-hero h1{font-size:23px;}
  .form-grid-2{grid-template-columns:1fr;}
  .pkg-grid{grid-template-columns:1fr;}
  .health-options{flex-direction:column;}
  .stepper-connector{flex-basis:24px;}
  .stepper-lbl{font-size:10px;}
  .step-nav,.child-nav{flex-wrap:wrap;}
}
