/* ═══════════════════════════════════════════════════════════
   WASP Global ISP — Signup Platform Styles
   Premium ISP aesthetic: deep navy, warm gold, clean whites
   ═══════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --primary:#24344C;
  --primary-light:#2d4162;
  --secondary:#54595F;
  --text:#3d4349;
  --text-light:#6b7280;
  --accent:#475468;
  --gold:#E6B12B;
  --gold-light:#f0cb5a;
  --gold-dark:#c99a1a;
  --blue:#13A7F7;
  --blue-light:#e8f6ff;
  --red:#e74c3c;
  --light-bg:#ECEEF2;
  --dark-bg:#0C1C30;
  --mid-dark:#30323D;
  --success:#22c55e;
  --success-light:#dcfce7;
  --warning:#f59e0b;
  --radius:10px;
  --radius-lg:16px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);
  --shadow:0 4px 20px rgba(0,0,0,.06),0 1px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.05);
  --shadow-gold:0 4px 20px rgba(230,177,43,.25);
  --max-w:1100px;
  --transition:all .35s cubic-bezier(.22,1,.36,1);
}

html{scroll-behavior:smooth}
body{
  font-family:'Roboto',sans-serif;font-weight:400;color:var(--text);
  background:var(--light-bg);
  background-image:
    radial-gradient(ellipse at 20% 0%,rgba(36,52,76,.04) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 100%,rgba(230,177,43,.03) 0%,transparent 50%);
  min-height:100vh;line-height:1.65
}
h1,h2,h3{font-family:'Roboto Slab',serif;color:var(--primary);letter-spacing:-.01em}
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}

/* ─── Header ─────────────────────────────────────────────── */
.site-header{
  background:linear-gradient(160deg, var(--dark-bg) 0%, #162a42 35%, var(--primary) 65%, #2d4a6a 100%);
  padding:48px 0 40px;text-align:center;position:relative;overflow:hidden
}
.site-header::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 80%,rgba(230,177,43,.08) 0%,transparent 50%),
    radial-gradient(circle at 70% 20%,rgba(19,167,247,.06) 0%,transparent 40%),
    url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.025'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none
}
.site-header .container{position:relative;z-index:1}
.site-header img{height:120px;margin-bottom:16px;filter:drop-shadow(0 6px 20px rgba(0,0,0,.4))}
.site-header h1{color:#fff;font-size:clamp(1.6rem,4vw,2.5rem);margin-bottom:6px;text-shadow:0 2px 8px rgba(0,0,0,.25);font-weight:700}
.site-header p{color:rgba(255,255,255,.7);font-size:1.05rem;font-weight:300;letter-spacing:.02em}
.header-accent{width:48px;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));margin:14px auto 0;border-radius:2px}

/* ─── Progress Bar ───────────────────────────────────────── */
.progress-bar{
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(0,0,0,.06);
  position:sticky;top:0;z-index:999;padding:14px 0;
  box-shadow:0 2px 12px rgba(0,0,0,.04)
}
.progress-steps{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.progress-step{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--text-light);opacity:.5;transition:var(--transition);padding:4px 0}
.progress-step.active{opacity:1;color:var(--primary);font-weight:600}
.progress-step.completed{opacity:1;color:var(--success)}
.progress-step .num{
  width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;background:#dfe3e8;color:#fff;
  transition:var(--transition)
}
.progress-step.active .num{
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--primary);
  box-shadow:0 3px 14px rgba(230,177,43,.4),0 0 0 4px rgba(230,177,43,.12)
}
.progress-step.completed .num{
  background:linear-gradient(135deg,var(--success),#16a34a);
  box-shadow:0 2px 10px rgba(34,197,94,.3)
}
.progress-step .chevron{font-size:11px;color:#d0d4da;margin:0 2px}

/* ─── Form Sections ──────────────────────────────────────── */
.form-section{
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  border:1px solid rgba(0,0,0,.04);
  margin:20px auto;padding:36px 32px;
  max-width:var(--max-w);
  animation:fadeUp .5s cubic-bezier(.22,1,.36,1) both;
  transition:box-shadow .3s ease,transform .25s ease
}
.form-section:hover{box-shadow:var(--shadow-lg)}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.form-section h2{font-size:1.6rem;margin-bottom:8px;display:flex;align-items:center;gap:10px;font-weight:700}
.form-section h3{font-size:1.05rem;font-weight:600;color:var(--primary);margin-bottom:12px}
.form-section h2 .icon{width:24px;height:24px;flex-shrink:0;color:var(--gold)}
.form-section h2 svg.icon{display:inline-block}
.form-section .subtitle{color:var(--text-light);font-size:.9rem;margin-bottom:28px;line-height:1.5}
.lbl-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;vertical-align:middle;color:var(--accent);opacity:.6}
.lbl-icon svg{width:16px;height:16px}

/* ─── Verification Status ────────────────────────────────── */
.verification-status{position:absolute;right:12px;top:32px;font-size:16px;pointer-events:none;opacity:0;transition:opacity .3s}
.verification-status.passed{color:var(--success);opacity:1}
.verification-status.warning{color:var(--warning);opacity:1}
.verification-status.failed{color:var(--red);opacity:1}

/* ─── Tabs ───────────────────────────────────────────────── */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:28px}
.tab{
  padding:11px 22px;border-radius:30px;border:2px solid #e2e5eb;
  background:#fff;cursor:pointer;font-weight:500;font-size:.88rem;
  transition:var(--transition);color:var(--secondary)
}
.tab:hover{border-color:var(--primary-light);color:var(--primary);background:#f8f9fb}
.tab.active{
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:#fff;border-color:transparent;
  box-shadow:0 4px 16px rgba(36,52,76,.2)
}

/* ─── Term Toggle ────────────────────────────────────────── */
.term-toggle{display:flex;gap:0;margin-bottom:24px;background:#eef0f4;border-radius:30px;overflow:hidden;width:fit-content}
.term-toggle .term-opt{padding:10px 24px;cursor:pointer;font-weight:500;font-size:.88rem;transition:var(--transition);color:var(--secondary);border:none;background:transparent;font-family:'Roboto',sans-serif}
.term-toggle .term-opt.active{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:var(--primary);font-weight:600;border-radius:30px;box-shadow:var(--shadow-gold)}
.term-toggle .term-opt:hover:not(.active){color:var(--primary)}

/* ─── Package Cards ──────────────────────────────────────── */
.pkg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-bottom:20px;padding:8px 0}
.pkg-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;
  border:2px solid transparent;
  box-shadow:0 2px 12px rgba(0,0,0,.04);
  transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s ease,border-color .3s ease;
  position:relative;display:flex;flex-direction:column
}
.pkg-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px rgba(0,0,0,.12)}
.pkg-card.selected{border-color:var(--gold);box-shadow:0 8px 32px rgba(230,177,43,.18)}
.pkg-card.selected::after{
  content:'✓';position:absolute;top:12px;right:12px;width:28px;height:28px;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.85rem;font-weight:700;box-shadow:0 3px 10px rgba(230,177,43,.4);z-index:2
}
.pkg-card .card-header{
  background:linear-gradient(150deg,var(--dark-bg) 0%,var(--primary) 60%,var(--primary-light) 100%);
  padding:28px 16px 24px;text-align:center;position:relative;overflow:hidden
}
.pkg-card .card-header::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)
}
.pkg-card .card-header .speed-badge{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;margin-bottom:10px;background:rgba(230,177,43,.1);padding:4px 16px;border-radius:20px;border:1px solid rgba(230,177,43,.2)}
.pkg-card .card-header .pkg-title{font-family:'Roboto Slab',serif;font-size:1.05rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:1.5px;line-height:1.3;margin:0}
.pkg-card .card-body{padding:24px 18px 22px;text-align:center;flex:1;display:flex;flex-direction:column;align-items:center}
.pkg-card .price{font-size:2.6rem;font-weight:800;color:var(--primary);line-height:1;margin-bottom:14px;letter-spacing:-1px}
.pkg-card .price span{font-size:.85rem;font-weight:700;color:var(--gold-dark);vertical-align:super;margin-left:2px;letter-spacing:1px}
.pkg-card .uncapped-badge{
  display:inline-block;
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#fff;font-size:.62rem;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;
  padding:5px 18px;border-radius:20px;margin-bottom:14px;
  box-shadow:0 2px 10px rgba(230,177,43,.25)
}
.pkg-card .pkg-desc{font-size:.8rem;color:var(--text-light);line-height:1.65;margin-bottom:12px;flex:1}
.pkg-card .install-fee{font-size:.82rem;font-weight:700;color:var(--secondary);padding-top:12px;border-top:1px solid #f0f1f3;width:100%;margin-top:auto}
.pkg-card .install-fee.free{color:var(--success);font-weight:700}

.selected-summary{background:linear-gradient(135deg,#fef9eb,#fdf3d7);border-left:4px solid var(--gold);padding:14px 18px;border-radius:0 var(--radius) var(--radius) 0;font-weight:500;color:var(--primary);display:none;font-size:.92rem}
.selected-summary.show{display:block}

/* ─── Contract Info Box ──────────────────────────────────── */
.contract-info-box{background:linear-gradient(135deg,#f4f6fa,#edf0f5);border-left:4px solid var(--gold);padding:18px 22px;border-radius:0 var(--radius) var(--radius) 0;margin-top:16px;font-size:.85rem;color:var(--secondary);line-height:1.7;display:none}
.contract-info-box.show{display:block}
.contract-info-box h4{font-family:'Roboto Slab',serif;font-size:.92rem;color:var(--primary);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.contract-info-box ul{list-style:none;padding:0;margin:0}
.contract-info-box ul li{padding:3px 0;position:relative;padding-left:20px}
.contract-info-box ul li::before{content:'';position:absolute;left:4px;top:12px;width:6px;height:6px;border-radius:50%;background:var(--gold)}

/* ─── Form ───────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}
.form-row{display:flex;gap:18px;grid-column:1/-1}
.form-row .form-group{flex:1}
@media(max-width:600px){.form-row{flex-direction:column;gap:10px}}
.form-group{display:flex;flex-direction:column;gap:5px;position:relative}
.form-group label{min-height:22px}
.form-group.full{grid-column:1/-1}
.form-group label{font-weight:500;font-size:.875rem;color:var(--secondary);display:flex;align-items:center;gap:6px}
.form-group label .req{color:var(--red)}
.form-group input,.form-group select,.form-group textarea{
  padding:13px 16px;border:1.5px solid #dfe3e8;border-radius:var(--radius);
  font-size:.95rem;font-family:'Roboto',sans-serif;
  transition:var(--transition);outline:none;background:#fafbfc;width:100%
}
.form-group input:hover,.form-group select:hover{border-color:#c4cad4;background:#fff}
.form-group input:focus,.form-group select:focus{
  border-color:var(--blue);background:#fff;
  box-shadow:0 0 0 3px rgba(19,167,247,.1),0 2px 10px rgba(19,167,247,.06)
}
.form-group input.valid{border-color:var(--success);background:#fafff8}
.form-group input.invalid,.form-group select.invalid{border-color:var(--red);background:#fff8f8}
.form-group .error-msg{color:var(--red);font-size:.85rem;min-height:18px;transition:all .2s ease}
.form-group .info-msg{color:var(--blue);font-size:.78rem;min-height:18px}
.form-group .hint{color:var(--text-light);font-size:.75rem;font-style:italic}
.form-group .extracted{background:var(--blue-light);padding:8px 12px;border-radius:6px;font-size:.8rem;color:var(--primary);margin-top:2px;border:1px solid rgba(19,167,247,.1)}

/* ─── Autocomplete ───────────────────────────────────────── */
.autocomplete-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid var(--blue);border-top:none;border-radius:0 0 var(--radius) var(--radius);max-height:220px;overflow-y:auto;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.12);display:none}
.autocomplete-list.show{display:block}
.autocomplete-item{padding:12px 16px;font-size:.88rem;cursor:pointer;border-bottom:1px solid #f4f5f7;transition:background .15s;color:var(--secondary);line-height:1.4}
.autocomplete-item:hover,.autocomplete-item.active{background:var(--blue-light);color:var(--primary)}
.autocomplete-item:last-child{border-bottom:none}

/* ─── Spinners ───────────────────────────────────────────── */
.spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid #ddd;border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-left:6px}
.spinner-inline{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── Copy Details Row ───────────────────────────────────── */
.copy-details-row{background:linear-gradient(135deg,#f8f9fb,#f0f2f6);padding:14px 18px;border-radius:var(--radius);margin-bottom:20px;border:1px solid #e8eaee}
.copy-details-row label{font-weight:600;color:var(--primary);cursor:pointer;display:flex;align-items:center;gap:10px;font-size:.9rem}
.copy-details-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold)}

/* ─── Upload Zones ───────────────────────────────────────── */
.upload-zone{
  border:2px dashed #d0d5dd;border-radius:var(--radius-lg);padding:32px 20px;
  text-align:center;cursor:pointer;transition:var(--transition);
  position:relative;background:#fafbfc
}
.upload-zone:hover,.upload-zone.dragover{
  border-color:var(--blue);background:var(--blue-light);
  box-shadow:0 4px 20px rgba(19,167,247,.08);transform:translateY(-2px)
}
.upload-zone .uz-icon{font-size:2rem;margin-bottom:8px;opacity:.7}
.upload-zone p{font-size:.85rem;color:var(--text-light)}
.upload-zone input[type=file]{display:none}
.upload-preview{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f8f9fb;border-radius:var(--radius);margin-top:10px;border:1px solid #eef0f3}
.upload-preview img{width:48px;height:48px;object-fit:cover;border-radius:6px}
.upload-preview .file-info{flex:1;font-size:.8rem}
.upload-preview .file-info .fname{font-weight:600;color:var(--primary);word-break:break-all}
.upload-preview .file-info .fsize{color:var(--text-light)}
.upload-preview .remove-btn{background:var(--red);color:#fff;border:none;border-radius:50%;width:26px;height:26px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.upload-preview .remove-btn:hover{background:#c0392b;transform:scale(1.1)}

/* ─── Signature ──────────────────────────────────────────── */
.signature-section{margin:24px 0}
.signature-canvas{
  border:2px solid #dfe3e8;border-radius:var(--radius-lg);width:100%;height:200px;
  cursor:crosshair;touch-action:none;
  transition:var(--transition);background:#fafbfc
}
.signature-canvas:hover{border-color:#c4cad4;background:#fff}
.signature-canvas.signed{border-color:var(--success);background:#fafff8;box-shadow:0 2px 14px rgba(34,197,94,.1)}
.signature-controls{display:flex;gap:10px;margin-top:12px}
.signature-controls button{padding:9px 18px;border:1.5px solid #dfe3e8;background:#fff;border-radius:var(--radius);cursor:pointer;font-size:.85rem;transition:var(--transition);font-weight:500}
.signature-controls button:hover{background:#f8f9fb;border-color:#c4cad4}
.signature-controls .clear-btn{background:var(--red);color:#fff;border-color:var(--red)}
.signature-controls .clear-btn:hover{background:#c0392b}
.signature-metadata{background:#f8f9fb;padding:14px 16px;border-radius:var(--radius);margin-top:12px;font-size:.8rem;color:var(--text-light);border:1px solid #eef0f3}
.signature-metadata .meta-item{margin:3px 0}

/* ─── Checkboxes ─────────────────────────────────────────── */
.checkbox-group{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;padding:8px 0}
.checkbox-group input[type=checkbox]{margin-top:3px;width:20px;height:20px;accent-color:var(--primary);flex-shrink:0;cursor:pointer}
.checkbox-group label{font-size:.88rem;color:var(--secondary);cursor:pointer;line-height:1.5}
.checkbox-group label a{color:var(--blue);text-decoration:none;font-weight:500}
.checkbox-group label a:hover{text-decoration:underline}

/* ─── Debit Note ─────────────────────────────────────────── */
.debit-note{font-size:.8rem;color:var(--text-light);font-style:italic;margin-top:10px;padding:10px 14px;background:#f8f9fb;border-radius:6px;border:1px solid #eef0f3}

/* ─── Submit ─────────────────────────────────────────────── */
.submit-area{text-align:center;padding:36px}
.submit-btn{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);
  color:var(--primary);border:none;
  padding:18px 64px;font-size:1.15rem;font-weight:700;
  border-radius:50px;cursor:pointer;
  transition:var(--transition);
  font-family:'Roboto Slab',serif;
  box-shadow:0 6px 24px rgba(230,177,43,.3),0 2px 8px rgba(230,177,43,.15);
  position:relative;overflow:hidden
}
.submit-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  pointer-events:none
}
.submit-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 36px rgba(230,177,43,.4),0 4px 12px rgba(230,177,43,.2)}
.submit-btn:active:not(:disabled){transform:translateY(-1px)}
.submit-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.3)}

/* ─── Modal ──────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(12,28,48,.65);backdrop-filter:blur(4px);z-index:2000;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:20px;max-width:700px;width:100%;max-height:85vh;overflow-y:auto;padding:36px;box-shadow:0 32px 80px rgba(0,0,0,.2),0 8px 24px rgba(0,0,0,.1)}
.modal h2{margin-bottom:16px}
.modal pre{background:#f8f9fb;padding:16px;border-radius:var(--radius);font-size:.78rem;overflow-x:auto;max-height:400px}
.modal-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}
.modal-actions button{padding:13px 30px;border-radius:var(--radius);border:none;cursor:pointer;font-weight:600;font-size:.9rem;transition:var(--transition)}
.btn-confirm{background:linear-gradient(135deg,var(--success),#16a34a);color:#fff;box-shadow:0 3px 12px rgba(34,197,94,.25)}
.btn-confirm:hover{box-shadow:0 6px 20px rgba(34,197,94,.35);transform:translateY(-1px)}
.btn-cancel{background:#f0f2f5;color:var(--secondary)}
.btn-cancel:hover{background:#e4e7eb}

/* ─── Success ────────────────────────────────────────────── */
.success-message{text-align:center;padding:60px 20px}
.success-message .check{font-size:4rem;color:var(--success);margin-bottom:16px}
.success-message h2{color:var(--success);margin-bottom:8px;font-size:2rem}

/* ─── Back to Top ────────────────────────────────────────── */
.back-top{
  position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;
  background:var(--primary);color:#fff;border:none;cursor:pointer;font-size:20px;
  display:none;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(36,52,76,.25);transition:var(--transition);z-index:999
}
.back-top.show{display:flex}
.back-top:hover{background:var(--gold);color:var(--primary);transform:translateY(-2px)}

/* ─── Help Float ─────────────────────────────────────────── */
.help-float{position:fixed;bottom:24px;left:24px;z-index:998}
.help-float a{
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;padding:12px 20px;border-radius:50px;text-decoration:none;
  font-weight:600;font-size:.85rem;
  box-shadow:0 4px 20px rgba(37,211,102,.3);transition:var(--transition)
}
.help-float a:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(37,211,102,.4)}

/* ─── Footer ─────────────────────────────────────────────── */
.site-footer{background:linear-gradient(180deg,var(--dark-bg),#091520);color:rgba(255,255,255,.65);padding:52px 0 28px;margin-top:48px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:36px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr;gap:24px}}
.footer-col h4{color:#fff;font-family:'Roboto Slab',serif;font-size:1rem;margin-bottom:14px;position:relative;padding-bottom:8px}
.footer-col h4::after{content:'';position:absolute;bottom:0;left:0;width:24px;height:2px;background:var(--gold);border-radius:1px}
.footer-col a{display:block;color:rgba(255,255,255,.55);text-decoration:none;font-size:.9rem;margin-bottom:8px;transition:.2s}
.footer-col a:hover{color:var(--gold);padding-left:4px}
.footer-col p{font-size:.9rem;margin-bottom:8px}
.footer-logo{height:50px;margin-bottom:14px;opacity:.85}
.footer-tagline{font-size:.85rem;line-height:1.55;margin-bottom:14px;color:rgba(255,255,255,.5)}
.footer-social{display:flex;gap:10px}
.footer-social a{display:inline-block;padding:7px 16px;border:1px solid rgba(255,255,255,.15);border-radius:20px;font-size:.8rem;color:rgba(255,255,255,.6);transition:var(--transition)}
.footer-social a:hover{border-color:var(--gold);color:var(--gold);background:rgba(230,177,43,.05)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;text-align:center;font-size:.8rem;color:rgba(255,255,255,.4)}

/* ─── Responsive ─────────────────────────────────────────── */
@media(max-width:768px){
  .form-section{margin:12px 8px;padding:24px 18px}
  .pkg-grid{grid-template-columns:1fr 1fr}
  .tabs{gap:4px}.tab{padding:12px 14px;font-size:.85rem;min-height:44px}
  .help-float a span.help-text{display:none}
  .term-toggle .term-opt{padding:12px 16px;font-size:.85rem;min-height:44px}
  .submit-btn{padding:16px 40px;font-size:1.05rem}
}
@media(max-width:600px){
  .progress-steps{gap:2px;overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;padding:0 12px;scrollbar-width:none}
  .progress-steps::-webkit-scrollbar{display:none}
  .progress-step{white-space:nowrap}
}
@media(max-width:480px){
  .pkg-grid{grid-template-columns:1fr}
  .site-header{padding:32px 0 28px}
  .site-header img{height:90px}
  .form-section{padding:20px 16px}
}
/* ─── Trust Strip ────────────────────────────────────────── */
.trust-strip{background:var(--primary);padding:9px 0;text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.7)}
.trust-strip .container{display:flex;justify-content:center;gap:28px;flex-wrap:wrap}
.trust-strip span::before{content:'✓ ';color:var(--gold);font-weight:700}
@media(max-width:600px){.trust-strip .container{gap:12px;font-size:.72rem}}

/* ─── Recommended Package Badge ──────────────────────────── */
.pkg-card.recommended::before{
  content:'Most Popular';position:absolute;top:-1px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:var(--primary);font-size:.68rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;
  padding:4px 18px;border-radius:0 0 10px 10px;box-shadow:0 2px 10px rgba(230,177,43,.35);z-index:3
}

/* Google Places autocomplete */
.pac-container{z-index:10000!important}
