/* ===== Shared tokens + base (standalone) ===== */
:root{
  --blue:#005BBB; --text:#0b1324; --muted:#5b6780; --grey-bg:#f7f9fc;
  --card:#fff; --radius:18px; --shadow:0 8px 24px rgba(9,23,42,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,"Helvetica Neue",Arial,"Noto Sans",sans-serif;color:var(--text);background:#fff}

/* Layout + utilities */
.container{width:min(1100px,calc(100% - 32px));margin:0 auto}
section{padding:56px 0}
section h2{text-align:center;margin:0 0 18px}
.muted{color:var(--muted)}
.card{background:#fff;border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}

/* Nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#fff;border-bottom:1px solid #eef2f6}
.nav a{text-decoration:none;color:var(--text);margin-left:16px;font-weight:600}
.nav a:hover{color:var(--blue)}

/* Add this AFTER the two above */
.nav a.active {
  color: var(--blue);
  font-weight:700; /* optional: make it stand out more */
}

/* Logo */
.logo-round{height:44px;width:44px;border-radius:50%;object-fit:cover}

/* Buttons (consistent with other pages) */
.btn{display:inline-block;padding:12px 18px;border-radius:999px;border:2px solid transparent;text-decoration:none;font-weight:700;transition:.15s ease-in-out;box-shadow:var(--shadow);cursor:pointer}
.btn.white{background:#fff;color:var(--blue);border-color:#fff}
.btn.white:hover{transform:translateY(-1px)}
.btn.blue{background:transparent;color:#fff;border-color:#fff}
.btn.blue:hover{background:#ffffff20;transform:translateY(-1px)}
.cta-row{display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap}

/* Hero */
header.hero{background:var(--blue);color:#fff;text-align:center;padding:72px 0 64px;position:relative;overflow:hidden}
header.hero .logo-round{height:80px;width:80px;margin-bottom:12px}
header.hero h1{margin:10px 0 8px;font-size:clamp(26px,3.4vw,40px);line-height:1.15}
header.hero p{margin:0 auto 16px;opacity:.95;max-width:820px}

/* Footer */
footer{padding:36px 0}
footer .container{text-align:center}
footer img.logo-round{display:block;margin:0 auto 10px}
footer p{margin:0 0 6px}
footer p:last-child{margin:0}

/* ===== Driver sign-up page specific ===== */

/* Page wrapper */
.wrap{width:min(1000px,calc(100% - 32px));margin:16px auto}

/* Form card */
form{background:#fff;border-radius:18px;padding:16px;box-shadow:var(--shadow)}
fieldset{border:1px solid #e7edf6;border-radius:14px;padding:14px;margin:14px 0;background:#fff}
legend{font-weight:800;padding:0 6px}

/* Grid */
.grid{display:flex;flex-wrap:wrap;gap:12px}
.col-12{flex:0 0 100%}
.col-8{flex:1 1 66%}
.col-6{flex:1 1 calc(50% - 8px);min-width:260px}
.col-4{flex:1 1 calc(33.333% - 8px);min-width:220px}
.flex{display:flex;gap:10px;align-items:flex-start}
.required::after{content:" *";color:#c00}

/* Inputs — scoped so checkboxes/radios keep natural size */
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="number"],
input[type="date"],
input[type="password"],
input[type="search"],
input[type="url"],
select{
  width:100%;
  height:42px;
  border:1px solid #dfe6ef;
  border-radius:10px;
  padding:0 10px;
}
input[type="checkbox"],
input[type="radio"]{
  width:auto;height:auto;margin-right:8px;accent-color:var(--blue);
}

/* Chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid #dfe6ef;background:#fff;cursor:pointer}
.chip input{width:auto;height:auto;margin-right:8px}
.chip:hover,.chip:focus{border-color:#bcd0f0}
.chip input:checked + span,
.chip input:checked{ /* visual hint when selected (labels may vary) */ background:transparent }

/* Wage / rate card */
.rate-card{background:#fff;border-radius:18px;padding:16px;box-shadow:var(--shadow)}
.rate-top{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.rate-title{font-weight:800}
.rate-sub{font-size:.95rem;color:var(--muted)}
.rate-display-lg{font-size:2.2rem;font-weight:900}
.rate-display-lg .rate-unit{font-size:1.2rem;font-weight:700;margin-left:6px;opacity:.9}

/* Range + numeric input row */
.rate-controls{display:grid;grid-template-columns:1fr minmax(160px,220px);gap:16px;align-items:center;margin-top:6px}
.rate-controls .numbers label{display:block;font-size:.9rem;opacity:.75;margin-bottom:6px}

/* Ticks under slider (Safari-friendly) */
.ticks{display:flex;justify-content:space-between;font-size:12px;color:#6b7280;margin-top:6px;user-select:none}

/* KPIs under slider */
.kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:10px}
.kpi{border:1px solid #e7edf6;border-radius:12px;padding:10px;text-align:center;background:#f9fbff}
.kpis-prominent .kpi{border-color:#d7e6fb;background:#fff}

/* Sticky card on desktop */
@media (min-width:900px){
  .rate-card{position:sticky;top:80px;z-index:2}
  #driverForm fieldset + fieldset{margin-top:28px}
}

/* ===== Slider with CSS var fill (blue, rounded) ===== */
input[type=range]{--fill:50%;-webkit-appearance:none;background:transparent;width:100%}
input[type=range]::-webkit-slider-runnable-track{
  height:14px;border-radius:999px;border:1px solid #d4d7dc;
  background:linear-gradient(90deg,var(--blue) 0%,var(--blue) var(--fill),#e5e7eb var(--fill));
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:28px;height:28px;border-radius:50%;background:#fff;border:3px solid var(--blue);box-shadow:0 4px 10px rgba(0,0,0,.15);margin-top:-8px
}
input[type=range]::-moz-range-track{
  height:14px;border-radius:999px;border:1px solid #d4d7dc;
  background:linear-gradient(90deg,var(--blue) 0%,var(--blue) var(--fill),#e5e7eb var(--fill));
}
input[type=range]::-moz-range-thumb{
  width:28px;height:28px;border-radius:50%;background:#fff;border:3px solid var(--blue);box-shadow:0 4px 10px rgba(0,0,0,.15)
}

/* Consent row tidy */
.col-12.flex > input[type="checkbox"]{margin-top:3px}
.flex label{white-space:normal}

/* Terms */
.terms{font-size:.9rem;color:#56627a}

/* Preview block spacing (no inline needed) */
#preview{white-space:pre-wrap;margin-top:16px}

/* -----------------------------------------------------------------
   Success panel card styling
   ----------------------------------------------------------------- */
#signupSuccess.success-panel {
  display: none;               /* stays hidden until JS shows it */
  max-width: 680px;
  margin: 32px auto;
  padding: 24px 24px 20px;
  background: #fff;
  border: 1px solid #e7eef8;
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  text-align: center;
}

#signupSuccess.success-panel h2 {
  margin: 0 0 8px;
  color: var(--blue);
  font-weight: 700;
}

#signupSuccess.success-panel p {
  margin: 0 0 10px;
  color: #243145;
}

#signupSuccess .btn.blue {
  display: inline-block;
  margin-top: 14px;
  color: var(--blue);
  border-color: var(--blue);
  background: transparent;
  box-shadow: none;
}
#signupSuccess .btn.blue:hover {
  background: rgba(0,91,187,.06);
}

/* Hide empty preview block */
#preview:empty { display: none; }

/* -----------------------------------------------------------------
   Hero alignment tweak (keep original sizing, centre the heading)
   ----------------------------------------------------------------- */
header.hero h1 {
  text-align: center;
  margin: 0.5rem 0;
}

/* Driver-signup page: match other hero sizes */
.page-driver-signup header.hero{
  min-height: auto !important;      /* ensure no stretch */
  padding: 72px 0 64px !important;  /* same as global hero */
  text-align: center;
}
.page-driver-signup header.hero .logo-round{
  width: 80px !important;
  height: 80px !important;
  margin-bottom: 12px;
}
.page-driver-signup header.hero h1 {
  text-align: center;
  margin: 0.5rem 0;
}

/* ===== CTA band (match index.html) ===== */
.cta-band{
  background: var(--blue);
  color: #fff;
  text-align: center;
  padding: 60px 20px;
}
.cta-band h2{
  margin: 0 0 18px;
  font-weight: 800;
}
.cta-band .cta-row{
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

/* Footer strip (white links area) */
footer#contact{
  background: #fff;
  border-top: 1px solid #e7eef8;
  padding: 20px 0;
}
footer#contact .container{ text-align: center; }
footer#contact a{
  color: var(--blue);
  text-decoration: none;
  font-weight: 600;
}
footer#contact a:hover{ text-decoration: underline; }

/* Hide the redundant "Sign Up" button in CTA band on driver-signup page */
.page-driver-signup .cta-band .btn.white[href*="driver-signup"] {
  display: none;
}

/* --- Highlight Sign Up button --- */
.signup-btn {
  border: 2px solid var(--blue);   /* bold blue border */
  color: var(--blue) !important;   /* blue text */
  background: #fff;
  font-size: 1.1rem;               /* slightly larger text */
  padding: 14px 28px;              /* slightly bigger button */
}

.signup-btn:hover {
  background: var(--blue);
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(0,0,0,.15);
}

/* Ensure Sign Up button always has a blue border */
.btn.primary {
  background: #005BBB;
  color: #fff;
  border: 2px solid #005BBB; /* force border blue instead of white */
}

.btn.primary:hover {
  background: #004799;       /* slightly darker blue on hover */
  border-color: #004799;
}

/* --- Hamburger nav (shared) --- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.nav{display:flex;align-items:center;gap:24px;padding:10px 16px;position:relative;background:#fff}
.logo-round{width:36px;height:36px}
.menu{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.menu a{font-weight:600;text-decoration:none}
.menu a.active{color:var(--blue,#1f4fa1)}

.menu-toggle{
  display:none;background:none;border:0;font-size:28px;line-height:1;
  padding:6px 8px;cursor:pointer;border-radius:10px
}
.menu-toggle:focus-visible{outline:2px solid var(--blue,#1f4fa1);outline-offset:3px}

/* Mobile dropdown */
@media (max-width:768px){
  .nav{position:sticky;top:0;z-index:100}
  .menu-toggle{display:block}
  .menu{
    position:absolute;left:0;right:0;top:56px;display:none;flex-direction:column;gap:12px;
    padding:12px 16px;background:#fff;border-top:1px solid #eef2f6;box-shadow:0 10px 24px rgba(0,0,0,.06)
  }
  .menu.open{display:flex}
}