/* ================================================================
   HUSTLEFREEMOVING — Kinetic Fluidity Design System
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600&display=swap');

/* ── Design Tokens ──────────────────────────────────────── */
:root {
  --surface:            #f8f5ff;
  --surface-low:        #f2efff;
  --surface-lowest:     #ffffff;
  --surface-dim:        #d1d0ff;
  --surface-highest:    #dbd9ff;

  --primary:            #0049e6;
  --primary-logo:       #0082C7;
  --primary-container:  #829bff;
  --on-primary:         #ffffff;

  --secondary-vivid:    #F0842A;
  --secondary:          #8d4a00;
  --on-secondary:       #ffffff;

  --on-surface:         #2a2b51;
  --on-surface-variant: #4a4b70;
  --on-surface-muted:   #7a7b9a;
  --on-surface-faint:   #a9a9d7;

  --outline-variant:    rgba(169,169,215,.2);
  --error:              #b41340;
  --error-container:    #f74b6d;

  --grad-primary: linear-gradient(135deg, #0049e6 0%, #829bff 100%);
  --grad-accent:  linear-gradient(135deg, #F0842A 0%, #ffb347 100%);
  --grad-hero:    linear-gradient(160deg, #060620 0%, #0b1a52 55%, #130840 100%);

  --shadow-ambient: 0 20px 40px rgba(42,43,81,.06), 0 10px 10px rgba(42,43,81,.04);
  --shadow-float:   0 32px 64px rgba(42,43,81,.10), 0 8px 16px rgba(42,43,81,.06);
  --shadow-card:    0 4px 16px rgba(42,43,81,.05);

  --r-sm:   .5rem;
  --r-md:   1rem;
  --r-lg:   1.5rem;
  --r-xl:   2rem;
  --r-full: 9999px;

  --f-display: 'Plus Jakarta Sans', sans-serif;
  --f-body:    'Inter', sans-serif;

  --ease-out: cubic-bezier(.16,1,.3,1);
  --t-fast: .18s;
  --t-med:  .32s;
}

/* ── Reset ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--f-body);
  font-size: 1rem;
  line-height: 1.7;
  color: var(--on-surface);
  background: var(--surface);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--primary); text-decoration: none; transition: color var(--t-fast); }
ul { list-style: none; }

/* ── Typography ─────────────────────────────────────────── */
h1,h2,h3,h4,h5 { font-family: var(--f-display); color: var(--on-surface); line-height: 1.12; }
h1 { font-size: clamp(2.8rem,6vw,4.8rem); font-weight: 800; letter-spacing: -.035em; }
h2 { font-size: clamp(2rem,4vw,3rem); font-weight: 700; letter-spacing: -.025em; }
h3 { font-size: 1.3rem; font-weight: 700; }
p  { color: var(--on-surface-variant); line-height: 1.75; }
.lead { font-size: 1.1rem; color: var(--on-surface-variant); max-width: 560px; line-height: 1.8; }

/* ── Layout ─────────────────────────────────────────────── */
.container { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.section { padding: 7rem 0; }
.section--low { padding: 4rem 0; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.75rem; }
@media(max-width:900px){ .grid-3{grid-template-columns:1fr 1fr;} .grid-4{grid-template-columns:1fr 1fr;} }
@media(max-width:640px){ .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;} .section{padding:4rem 0;} .container{padding:0 1.25rem;} }

/* ── Navbar (Glassmorphism) ─────────────────────────────── */
.navbar {
  position: sticky; top: 0; z-index: 200;
  background: rgba(248,245,255,.82);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  transition: box-shadow var(--t-med);
  padding: .9rem 0;
}
.navbar.scrolled { box-shadow: var(--shadow-ambient); }
.navbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; }

.navbar__logo { display: flex; align-items: center; gap: .65rem; text-decoration: none; flex-shrink: 0; }
.navbar__logo img { height: 38px; width: auto; }
.navbar__logo-wordmark { display: flex; flex-direction: column; line-height: 1; }
.navbar__logo-top { font-family: var(--f-display); font-weight: 800; font-size: 1.05rem; letter-spacing: -.03em; color: var(--on-surface); }
.navbar__logo-top .w-hustle { color: var(--primary-logo); }
.navbar__logo-top .w-free   { color: var(--secondary-vivid); }
.navbar__logo-bottom { font-family: var(--f-body); font-size: .65rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: var(--on-surface-muted); margin-top: .1rem; }

.navbar__nav { display: flex; align-items: center; gap: 1.75rem; }
.navbar__nav a { font-size: .875rem; font-weight: 500; color: var(--on-surface-variant); position: relative; transition: color var(--t-fast); }
.navbar__nav a::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:2px; background:var(--grad-primary); border-radius:2px; transition:width var(--t-med) var(--ease-out); }
.navbar__nav a:hover, .navbar__nav a.active { color: var(--primary); }
.navbar__nav a:hover::after, .navbar__nav a.active::after { width: 100%; }
.navbar__cta { margin-left: .5rem; }

.navbar__toggle { display:none; background:none; border:none; cursor:pointer; padding:4px; flex-direction:column; gap:5px; }
.navbar__toggle span { display:block; width:22px; height:2px; background:var(--on-surface); border-radius:2px; }
@media(max-width:820px){
  .navbar__toggle { display:flex; }
  .navbar__menu { display:none; position:absolute; top:100%; left:0; right:0; background:rgba(248,245,255,.97); backdrop-filter:blur(24px); padding:1.75rem 2rem 2rem; box-shadow:var(--shadow-float); }
  .navbar__menu.open { display:block; }
  .navbar__nav { flex-direction:column; align-items:flex-start; gap:1.1rem; }
  .navbar__cta { margin:1rem 0 0; }
}

/* ── Buttons ────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.875rem 2rem; border-radius:var(--r-full);
  font-family:var(--f-display); font-weight:700; font-size:.9rem; letter-spacing:-.01em;
  cursor:pointer; border:none; position:relative; overflow:hidden; white-space:nowrap;
  transition:transform var(--t-fast) var(--ease-out), box-shadow var(--t-fast);
}
.btn::before { content:''; position:absolute; top:0;left:0;right:0; height:45%; background:rgba(255,255,255,.10); border-radius:var(--r-full) var(--r-full) 0 0; pointer-events:none; }
.btn-primary { background:var(--grad-primary); color:#fff; }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,73,230,.38); color:#fff; }
.btn-secondary { background:var(--grad-accent); color:#fff; }
.btn-secondary:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(240,132,42,.38); color:#fff; }
.btn-ghost { background:rgba(0,73,230,.07); color:var(--primary); font-weight:700; }
.btn-ghost:hover { background:rgba(0,73,230,.12); transform:translateY(-1px); }
.btn-ghost::before { display:none; }
.btn-outline-white { background:rgba(255,255,255,.10); color:#fff; border:1.5px solid rgba(255,255,255,.3); }
.btn-outline-white:hover { background:rgba(255,255,255,.18); color:#fff; transform:translateY(-2px); }
.btn-lg { padding:1.1rem 2.6rem; font-size:1rem; }
.btn-sm { padding:.55rem 1.25rem; font-size:.82rem; }
.btn-tertiary { background:none; border:none; padding:0; color:var(--primary); font-family:var(--f-display); font-weight:700; font-size:.9rem; cursor:pointer; display:inline-flex; align-items:center; gap:.35rem; position:relative; }
.btn-tertiary::after { content:''; position:absolute; bottom:-2px; left:0; width:100%; height:2px; background:var(--primary); transform:scaleX(.35); transform-origin:left; transition:transform var(--t-med) var(--ease-out); }
.btn-tertiary:hover::after { transform:scaleX(1); }
.btn-tertiary::before { display:none; }

/* ── Eyebrow label ─────────────────────────────────────── */
.eyebrow { display:inline-flex; align-items:center; gap:.5rem; font-family:var(--f-body); font-size:.75rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--secondary); margin-bottom:.75rem; }
.eyebrow::before { content:''; display:block; width:20px; height:2px; background:var(--grad-accent); border-radius:2px; flex-shrink:0; }
.section-header { margin-bottom: 4rem; }
.section-header--center { text-align: center; }
.section-header--center .lead { margin: .75rem auto 0; }

/* ── Hero ───────────────────────────────────────────────── */
.hero {
  background: var(--grad-hero);
  min-height: 90vh;
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding: 5rem 0 6rem;
}
.hero__grid {
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(130,155,255,.06) 1px,transparent 1px), linear-gradient(90deg,rgba(130,155,255,.06) 1px,transparent 1px);
  background-size: 56px 56px;
  animation: gridDrift 24s linear infinite;
  pointer-events:none;
}
@keyframes gridDrift { from{transform:translateY(0)} to{transform:translateY(56px)} }
.hero__blob-1 { position:absolute; width:800px; height:800px; border-radius:50%; background:radial-gradient(circle,rgba(0,130,199,.28) 0%,transparent 65%); right:-180px; top:-160px; pointer-events:none; animation:blob1 9s ease-in-out infinite; }
.hero__blob-2 { position:absolute; width:500px; height:500px; border-radius:50%; background:radial-gradient(circle,rgba(240,132,42,.16) 0%,transparent 65%); left:-80px; bottom:0; pointer-events:none; animation:blob2 12s ease-in-out infinite; }
@keyframes blob1 { 0%,100%{transform:scale(1) translate(0,0)} 50%{transform:scale(1.1) translate(-30px,25px)} }
@keyframes blob2 { 0%,100%{transform:scale(1) translate(0,0)} 50%{transform:scale(1.12) translate(20px,-20px)} }

.hero__inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 400px; gap:4rem; align-items:center; }
.hero__kicker { display:inline-flex; align-items:center; gap:.6rem; background:rgba(130,155,255,.13); border:1px solid rgba(130,155,255,.22); border-radius:var(--r-full); padding:.4rem 1rem .4rem .6rem; font-size:.78rem; font-weight:500; color:rgba(200,210,255,.9); letter-spacing:.03em; margin-bottom:1.75rem; width:fit-content; }
.hero__kicker-dot { width:7px; height:7px; border-radius:50%; background:var(--secondary-vivid); animation:dotPulse 2s ease-in-out infinite; }
@keyframes dotPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.75)} }
.hero h1 { color:#fff; margin-bottom:1.5rem; }
.hero h1 .accent-blue   { color:var(--primary-container); }
.hero h1 .accent-orange { color:var(--secondary-vivid); }
.hero .lead { color:rgba(255,255,255,.65); margin-bottom:2.5rem; }
.hero__actions { display:flex; gap:1rem; flex-wrap:wrap; align-items:center; }
.hero__proof { display:flex; gap:2rem; margin-top:3.5rem; padding-top:2.5rem; border-top:1px solid rgba(255,255,255,.1); flex-wrap:wrap; }
.hero__proof-stat strong { font-family:var(--f-display); font-size:1.5rem; font-weight:800; color:#fff; display:block; line-height:1; }
.hero__proof-stat span { font-size:.78rem; color:rgba(255,255,255,.45); margin-top:.3rem; display:block; }

.hero__glass-card { background:rgba(255,255,255,.06); backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px); border:1px solid rgba(255,255,255,.11); border-radius:var(--r-xl); padding:2.5rem; box-shadow:var(--shadow-float); }
.hero__glass-label { font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--secondary-vivid); margin-bottom:1.5rem; }
.hero__glass-rate { font-family:var(--f-display); font-weight:800; font-size:3rem; color:#fff; line-height:1; letter-spacing:-.04em; }
.hero__glass-rate sup { font-size:1.1rem; vertical-align:super; font-weight:600; letter-spacing:0; }
.hero__glass-rate sub { font-size:.9rem; color:rgba(255,255,255,.45); font-weight:400; letter-spacing:0; }
.hero__glass-sub { font-size:.85rem; color:rgba(255,255,255,.5); margin-top:.45rem; }
.hero__glass-divider { height:1px; background:rgba(255,255,255,.1); margin:1.75rem 0; }
.hero__glass-list { display:flex; flex-direction:column; gap:.8rem; }
.hero__glass-list li { display:flex; align-items:center; gap:.75rem; font-size:.875rem; color:rgba(255,255,255,.72); }
.hero__glass-list .chk { width:20px; height:20px; background:var(--grad-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:.6rem; color:#fff; font-weight:700; }
@media(max-width:1000px){ .hero__inner{grid-template-columns:1fr;} .hero__glass-card{display:none;} }
@media(max-width:640px){ .hero{min-height:80vh;padding:4rem 0;} }

/* ── Trust Strip ────────────────────────────────────────── */
.trust-strip { background:var(--surface-lowest); padding:2.5rem 0; box-shadow:var(--shadow-card); }
.trust-strip__inner { display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center; }
.trust-item__icon { font-size:1.5rem; margin-bottom:.5rem; }
.trust-item__title { font-family:var(--f-display); font-size:.9rem; font-weight:700; color:var(--on-surface); }
.trust-item__desc  { font-size:.8rem; color:var(--on-surface-muted); margin-top:.2rem; }
@media(max-width:640px){ .trust-strip__inner{grid-template-columns:1fr 1fr;} }

/* ── Cards ──────────────────────────────────────────────── */
.card { background:var(--surface-lowest); border-radius:var(--r-lg); padding:2.25rem; box-shadow:var(--shadow-card); transition:transform var(--t-med) var(--ease-out),box-shadow var(--t-med); }
.card:hover { transform:translateY(-5px); box-shadow:var(--shadow-float); }
.card__icon { width:52px; height:52px; background:var(--surface-low); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:1.25rem; transition:background var(--t-fast),transform var(--t-fast); }
.card:hover .card__icon { background:var(--grad-primary); transform:scale(1.08); }
.card h3 { margin-bottom:.6rem; }
.card p { font-size:.93rem; }

/* ── Feature list ───────────────────────────────────────── */
.feature-list { display:flex; flex-direction:column; gap:1.25rem; }
.feature-item { display:flex; gap:1rem; align-items:flex-start; }
.feature-item__dot { width:24px; height:24px; min-width:24px; background:var(--grad-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; margin-top:.2rem; font-size:.62rem; color:#fff; box-shadow:0 4px 10px rgba(0,73,230,.28); }
.feature-item__dot::after { content:'✓'; }
.feature-item__text strong { display:block; font-family:var(--f-display); font-size:.95rem; font-weight:700; color:var(--on-surface); }
.feature-item__text span   { font-size:.875rem; color:var(--on-surface-muted); }

/* ── Steps ──────────────────────────────────────────────── */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:2.5rem; position:relative; }
.steps::before { content:''; position:absolute; top:27px; left:14%; right:14%; height:2px; background:linear-gradient(90deg,var(--primary),var(--primary-container)); opacity:.25; }
.step { text-align:center; position:relative; z-index:1; }
.step__num { width:56px; height:56px; margin:0 auto 1rem; border-radius:50%; background:var(--grad-primary); display:flex; align-items:center; justify-content:center; font-family:var(--f-display); font-weight:800; font-size:1.1rem; color:#fff; box-shadow:0 6px 20px rgba(0,73,230,.28); }
.step h3 { font-size:1rem; margin-bottom:.4rem; }
.step p { font-size:.875rem; }
@media(max-width:768px){ .steps{grid-template-columns:1fr 1fr;} .steps::before{display:none;} }
@media(max-width:480px){ .steps{grid-template-columns:1fr;} }

/* ── Testimonials ───────────────────────────────────────── */
.testimonial { background:var(--surface-lowest); border-radius:var(--r-lg); padding:2rem; box-shadow:var(--shadow-card); transition:transform var(--t-med) var(--ease-out),box-shadow var(--t-med); }
.testimonial:hover { transform:translateY(-4px); box-shadow:var(--shadow-float); }
.testimonial__stars { font-size:1rem; margin-bottom:.75rem; letter-spacing:2px; }
.testimonial__quote { font-size:.95rem; font-style:italic; color:var(--on-surface-variant); margin-bottom:1.25rem; }
.testimonial__author { display:flex; align-items:center; gap:.75rem; }
.testimonial__avatar { width:42px; height:42px; border-radius:50%; background:var(--surface-low); display:flex; align-items:center; justify-content:center; font-family:var(--f-display); font-weight:800; font-size:.85rem; color:var(--primary); }
.testimonial__name { font-weight:700; font-size:.9rem; font-family:var(--f-display); color:var(--on-surface); }
.testimonial__location { font-size:.8rem; color:var(--on-surface-muted); }

/* ── Page header ────────────────────────────────────────── */
.page-header { background:var(--grad-hero); padding:5rem 0 4rem; position:relative; overflow:hidden; }
.page-header::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(130,155,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(130,155,255,.05) 1px,transparent 1px); background-size:48px 48px; pointer-events:none; }
.page-header::after { content:''; position:absolute; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(0,130,199,.22) 0%,transparent 70%); right:-100px; top:-150px; pointer-events:none; }
.page-header__content { position:relative; z-index:1; }
.page-header h1 { color:#fff; font-size:clamp(2rem,5vw,3.2rem); margin-bottom:.5rem; }
.page-header p  { color:rgba(255,255,255,.6); }
.breadcrumb { display:flex; gap:.5rem; align-items:center; font-size:.78rem; color:rgba(255,255,255,.38); margin-bottom:.85rem; }
.breadcrumb a { color:var(--primary-container); }

/* ── Forms ──────────────────────────────────────────────── */
.form-card { background:var(--surface-lowest); border-radius:var(--r-xl); padding:3rem; box-shadow:var(--shadow-float); }
@media(max-width:640px){ .form-card{padding:2rem 1.5rem;} }
.form-group { margin-bottom:1.5rem; }
.form-group label { display:block; font-family:var(--f-body); font-size:.75rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--on-surface-muted); margin-bottom:.5rem; }
.form-group label .req { color:var(--secondary-vivid); }
.form-control { width:100%; padding:.875rem 1.1rem; border:1px solid var(--outline-variant); border-radius:var(--r-md); font-family:var(--f-body); font-size:.95rem; color:var(--on-surface); background:var(--surface-lowest); outline:none; transition:border-color var(--t-fast),box-shadow var(--t-fast); -webkit-appearance:none; }
.form-control:focus { border-color:var(--primary-container); box-shadow:0 0 0 4px rgba(130,155,255,.16); }
.form-control.input-validation-error { border-color:transparent; border-bottom:2px solid var(--error-container); border-radius:var(--r-md) var(--r-md) 0 0; box-shadow:none; }
textarea.form-control { resize:vertical; min-height:130px; }
select.form-control { cursor:pointer; }
.field-validation-error { display:block; font-size:.8rem; color:var(--error); margin-top:.3rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
@media(max-width:540px){ .form-row{grid-template-columns:1fr;} }
.form-hint { font-size:.8rem; color:var(--on-surface-faint); margin-top:.3rem; }
.validation-summary-errors { background:#fff0f4; border-left:3px solid var(--error-container); border-radius:0 var(--r-sm) var(--r-sm) 0; padding:1rem 1.25rem; margin-bottom:1.5rem; color:var(--error); font-size:.9rem; }
.validation-summary-valid { display:none; }

/* ── Pricing ────────────────────────────────────────────── */
.pricing-tabs { display:flex; gap:.3rem; margin-bottom:3rem; background:var(--surface-dim); border-radius:var(--r-full); padding:5px; }
.pricing-tab { flex:1; padding:.8rem 1.25rem; border:none; border-radius:var(--r-full); font-family:var(--f-display); font-size:.88rem; font-weight:700; cursor:pointer; background:transparent; color:var(--on-surface-muted); transition:all var(--t-med) var(--ease-out); }
.pricing-tab.active { background:var(--grad-primary); color:#fff; box-shadow:0 4px 16px rgba(0,73,230,.3); }
.pricing-panel { display:none; }
.pricing-panel.active { display:block; animation:fadeUp .35s var(--ease-out); }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:none} }

.counter-input { display:flex; align-items:center; background:var(--surface-low); border-radius:var(--r-full); overflow:hidden; width:fit-content; }
.counter-input button { width:44px; height:44px; border:none; background:transparent; font-size:1.2rem; font-family:var(--f-display); font-weight:700; cursor:pointer; color:var(--on-surface); transition:background var(--t-fast); }
.counter-input button:hover { background:var(--grad-primary); color:#fff; }
.counter-input input { width:64px; height:44px; border:none; background:transparent; text-align:center; font-family:var(--f-display); font-size:1rem; font-weight:800; color:var(--on-surface); outline:none; }
.counter-input input::-webkit-inner-spin-button, .counter-input input::-webkit-outer-spin-button { -webkit-appearance:none; }

.pricing-result { background:var(--surface-low); border-radius:var(--r-lg); padding:2rem; margin-top:2.5rem; display:none; animation:fadeUp .3s var(--ease-out); }
.pricing-result.visible { display:block; }
.pricing-result__label { font-size:.73rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--secondary); margin-bottom:.5rem; }
.pricing-result__rate { font-family:var(--f-display); font-size:3rem; font-weight:800; color:var(--primary); letter-spacing:-.04em; line-height:1; }
.pricing-result__rate span { font-size:1rem; font-weight:500; color:var(--on-surface-muted); }
.pricing-result__breakdown { margin-top:1.25rem; padding-top:1.25rem; border-top:1px solid var(--surface-dim); }
.pricing-result__line { display:flex; justify-content:space-between; font-size:.9rem; padding:.35rem 0; }
.pricing-result__line strong { font-family:var(--f-display); font-weight:600; color:var(--on-surface); }
.pricing-result__line span  { color:var(--on-surface-muted); }
.pricing-result__total { display:flex; justify-content:space-between; padding:.75rem 0 0; margin-top:.5rem; border-top:2px solid var(--surface-dim); }
.pricing-result__total strong:first-child { font-family:var(--f-display); font-weight:700; color:var(--on-surface); font-size:1rem; }
.pricing-result__total strong:last-child  { font-family:var(--f-display); font-weight:800; color:var(--primary); font-size:1.2rem; }

/* ── Rate card ───────────────────────────────────────────── */
.rate-card { background:var(--surface-low); border-radius:var(--r-xl); padding:2.5rem; }
.rate-card__label { font-size:.73rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--secondary); margin-bottom:1.25rem; }
.rate-row { background:var(--surface-lowest); border-radius:var(--r-md); padding:1.25rem 1.5rem; display:flex; justify-content:space-between; align-items:center; margin-bottom:.75rem; box-shadow:var(--shadow-card); }
.rate-row:last-of-type { margin-bottom:0; }
.rate-row__name { font-family:var(--f-display); font-weight:700; font-size:.95rem; color:var(--on-surface); }
.rate-row__price { font-family:var(--f-display); font-weight:800; font-size:1.3rem; color:var(--primary); }

/* ── Info box ────────────────────────────────────────────── */
.info-box { background:var(--grad-hero); border-radius:var(--r-xl); padding:2.5rem; color:#fff; position:relative; overflow:hidden; }
.info-box::before { content:''; position:absolute; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(0,73,230,.22) 0%,transparent 70%); right:-80px; top:-80px; pointer-events:none; }
.info-box > * { position:relative; z-index:1; }
.info-box h3 { color:#fff; margin-bottom:.75rem; }
.info-box > p { color:rgba(255,255,255,.65); margin-bottom:1.5rem; }
.info-box ul { display:flex; flex-direction:column; gap:.6rem; margin-bottom:1.75rem; }
.info-box li { display:flex; align-items:center; gap:.65rem; font-size:.88rem; color:rgba(255,255,255,.75); }
.info-box li::before { content:'→'; color:var(--secondary-vivid); font-weight:700; }

/* ── Coverage grid ───────────────────────────────────────── */
.coverage-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; }
.coverage-item { background:rgba(255,255,255,.06); border-radius:var(--r-md); padding:1.1rem; text-align:center; transition:background var(--t-fast); }
.coverage-item:hover { background:rgba(255,255,255,.1); }
.coverage-item__flag { font-size:1.4rem; margin-bottom:.4rem; }
.coverage-item__name { font-family:var(--f-display); font-size:.8rem; font-weight:700; color:#fff; }
.coverage-item__tag  { font-size:.72rem; color:var(--secondary-vivid); margin-top:.15rem; }
@media(max-width:540px){ .coverage-grid{grid-template-columns:1fr 1fr;} }

/* ── Service card ────────────────────────────────────────── */
.service-card { background:var(--surface-lowest); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-card); transition:transform var(--t-med) var(--ease-out),box-shadow var(--t-med); }
.service-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-float); }
.service-card__header { background:var(--grad-hero); padding:2rem; display:flex; align-items:center; gap:1rem; }
.service-card__header-icon { width:52px; height:52px; background:var(--grad-primary); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; font-size:1.5rem; color:#fff; flex-shrink:0; }
.service-card__header h3 { color:#fff; }
.service-card__header p { color:rgba(255,255,255,.55); font-size:.85rem; margin-top:.15rem; }
.service-card__body { padding:2rem; }
.service-card__features { display:flex; flex-direction:column; gap:.6rem; margin-bottom:1.5rem; }
.service-card__features li { display:flex; align-items:center; gap:.65rem; font-size:.9rem; color:var(--on-surface-variant); }
.service-card__features li::before { content:'✓'; color:var(--primary); font-weight:700; font-size:.85rem; }

/* ── Stat bar ────────────────────────────────────────────── */
.stat-bar { display:grid; grid-template-columns:repeat(4,1fr); background:var(--surface-dim); border-radius:var(--r-xl); overflow:hidden; gap:2px; margin:3rem 0; }
.stat-bar__item { background:var(--surface-lowest); padding:2.5rem 2rem; text-align:center; }
.stat-bar__num { font-family:var(--f-display); font-size:2.2rem; font-weight:800; background:var(--grad-primary); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; display:block; line-height:1; }
.stat-bar__label { font-size:.82rem; color:var(--on-surface-muted); margin-top:.4rem; }
@media(max-width:640px){ .stat-bar{grid-template-columns:1fr 1fr;} }

/* ── Value cards ─────────────────────────────────────────── */
.value-card { text-align:center; padding:2rem 1.5rem; }
.value-card__icon { width:64px; height:64px; background:var(--surface-low); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:1.6rem; margin:0 auto 1.25rem; }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-item { background:var(--surface-lowest); border-radius:var(--r-md); overflow:hidden; margin-bottom:.75rem; box-shadow:var(--shadow-card); }
.faq-item summary { padding:1.2rem 1.5rem; font-family:var(--f-display); font-weight:700; font-size:.975rem; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; color:var(--on-surface); user-select:none; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary .arrow { color:var(--primary); font-size:1.1rem; transition:transform var(--t-fast); }
.faq-item[open] summary .arrow { transform:rotate(45deg); }
.faq-item__body { padding:0 1.5rem 1.5rem; font-size:.95rem; color:var(--on-surface-variant); }

/* ── Alert ───────────────────────────────────────────────── */
.alert { padding:1rem 1.25rem; border-radius:var(--r-md); font-size:.93rem; margin-bottom:1.5rem; }
.alert-info { background:var(--surface-low); color:var(--on-surface-variant); }
.alert-info a { color:var(--primary); font-weight:600; }

/* ── CTA section ─────────────────────────────────────────── */
.cta-section { background:var(--grad-primary); padding:5rem 0; position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px); background-size:48px 48px; pointer-events:none; }
.cta-section > .container { position:relative; z-index:1; }

/* ── Success ─────────────────────────────────────────────── */
.success-card { max-width:520px; margin:0 auto; text-align:center; padding:4rem 2rem; }
.success-icon { width:80px; height:80px; background:var(--grad-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:2rem; margin:0 auto 1.5rem; color:#fff; box-shadow:0 8px 24px rgba(0,73,230,.3); }

/* ── Footer ──────────────────────────────────────────────── */
.footer { background:#07071a; color:rgba(255,255,255,.4); padding:5rem 0 2.5rem; }
.footer__grid { display:grid; grid-template-columns:1.8fr 1fr 1fr 1.4fr; gap:3rem; padding-bottom:3.5rem; border-bottom:1px solid rgba(255,255,255,.06); margin-bottom:2rem; }
.footer__logo { display:flex; align-items:center; gap:.65rem; margin-bottom:1.25rem; text-decoration:none; }
.footer__logo img { height:36px; width:auto; }
.footer__logo-wordmark { display:flex; flex-direction:column; line-height:1; }
.footer__logo-top { font-family:var(--f-display); font-weight:800; font-size:1.05rem; letter-spacing:-.03em; color:#fff; }
.footer__logo-top .w-hustle { color:var(--primary-container); }
.footer__logo-top .w-free   { color:var(--secondary-vivid); }
.footer__logo-bottom { font-size:.65rem; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-top:.1rem; }
.footer p { font-size:.88rem; color:rgba(255,255,255,.4); line-height:1.7; }
.footer__heading { font-family:var(--f-body); font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:1.1rem; }
.footer__links { display:flex; flex-direction:column; gap:.6rem; }
.footer__links a { font-size:.88rem; color:rgba(255,255,255,.4); transition:color var(--t-fast); }
.footer__links a:hover { color:var(--primary-container); }
.footer__contact-item { display:flex; gap:.6rem; align-items:flex-start; font-size:.88rem; margin-bottom:.7rem; color:rgba(255,255,255,.4); }
.footer__contact-item .ic { color:var(--secondary-vivid); margin-top:.1rem; }
.footer__contact-item a { color:rgba(255,255,255,.4); transition:color var(--t-fast); }
.footer__contact-item a:hover { color:var(--primary-container); }
.footer__bottom { display:flex; justify-content:space-between; align-items:center; font-size:.82rem; flex-wrap:wrap; gap:1rem; color:rgba(255,255,255,.25); }
.footer__legal { display:flex; gap:1.25rem; }
.footer__legal a { color:rgba(255,255,255,.25); transition:color var(--t-fast); }
.footer__legal a:hover { color:rgba(255,255,255,.5); }
@media(max-width:900px){ .footer__grid{grid-template-columns:1fr 1fr;} }
@media(max-width:540px){ .footer__grid{grid-template-columns:1fr;gap:2rem;} .footer__bottom{flex-direction:column;text-align:center;} }

/* ── Utility ─────────────────────────────────────────────── */
.text-center { text-align:center; }
.mt-1 { margin-top:.5rem; }
.mt-2 { margin-top:1rem; }
.mt-3 { margin-top:1.75rem; }
.divider { height:1px; background:var(--surface-dim); margin:2rem 0; }
.reveal { opacity:0; transform:translateY(18px); transition:opacity .5s var(--ease-out),transform .5s var(--ease-out); }
.reveal.in-view { opacity:1; transform:none; }

/* ================================================================
   PATCH — Centered nav, service checkbox cards, settings banner
   ================================================================ */

/* ── Centered navbar (3-column grid: logo | links | cta) ──── */
.navbar__inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1.5rem;
}
.navbar__nav-wrap {
  display: flex;
  justify-content: center;
}
.navbar__nav { gap: 2rem; }

@media (max-width: 820px) {
  .navbar__inner { grid-template-columns: 1fr auto; }
  .navbar__nav-wrap { display: none; } /* hidden; menu shown via toggle */
}

/* ── Service checkbox cards ──────────────────────────────── */
.service-checks {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .75rem;
  margin-top: .6rem;
}
@media (max-width: 700px) { .service-checks { grid-template-columns: 1fr 1fr; } }
@media (max-width: 420px) { .service-checks { grid-template-columns: 1fr; } }

.service-check-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .4rem;
  padding: 1rem .75rem;
  background: var(--surface-low);
  border-radius: var(--r-md);
  cursor: pointer;
  text-align: center;
  transition: background var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
  user-select: none;
  position: relative;
}
.service-check-label:hover {
  background: var(--surface-highest);
  transform: translateY(-2px);
}
.service-check-label input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}
.service-check-label.checked {
  background: var(--grad-primary);
  box-shadow: 0 4px 16px rgba(0,73,230,.28);
  transform: translateY(-2px);
}
.service-check-label.checked .svc-icon,
.service-check-label.checked .svc-name { color: #fff; }
.svc-icon { font-size: 1.5rem; line-height: 1; }
.svc-name {
  font-family: var(--f-display);
  font-size: .78rem;
  font-weight: 700;
  color: var(--on-surface);
  line-height: 1.2;
}

/* Validation error state for service checks */
.service-checks.is-invalid ~ .field-validation-error { display: block; }

/* ── Calculator settings info banner ─────────────────────── */
.settings-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  background: var(--surface-low);
  border-radius: var(--r-md);
  padding: .9rem 1.25rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}
.settings-banner__rates {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  align-items: center;
}
.settings-banner__rate {
  display: flex;
  flex-direction: column;
  gap: .1rem;
}
.settings-banner__rate-value {
  font-family: var(--f-display);
  font-size: 1rem;
  font-weight: 800;
  background: var(--grad-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.settings-banner__rate-label {
  font-size: .7rem;
  color: var(--on-surface-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
}

/* ── Junk-removal toggle ──────────────────────────────────── */
.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--surface-low);
  border-radius: var(--r-md);
  padding: 1rem 1.25rem;
  margin-top: .6rem;
}
.toggle-row__info strong {
  font-family: var(--f-display);
  font-size: .95rem;
  font-weight: 700;
  color: var(--on-surface);
  display: block;
}
.toggle-row__info span { font-size: .82rem; color: var(--on-surface-muted); }

/* iOS-style toggle switch */
.toggle-switch { position: relative; width: 48px; height: 26px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-switch .slider {
  position: absolute; inset: 0;
  background: var(--surface-dim);
  border-radius: var(--r-full);
  cursor: pointer;
  transition: background var(--t-fast);
}
.toggle-switch .slider::before {
  content: '';
  position: absolute;
  width: 20px; height: 20px;
  left: 3px; top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform var(--t-fast);
  box-shadow: 0 1px 4px rgba(42,43,81,.2);
}
.toggle-switch input:checked + .slider { background: var(--grad-primary); }
.toggle-switch input:checked + .slider::before { transform: translateX(22px); }
