/* DNW Registration — stylesheet (v2: clean / Vercel-Notion aesthetic) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --dnw-bg:        #F7F7F5;
  --dnw-card:      #FFFFFF;
  --dnw-ink:       #0A0A0A;
  --dnw-ink-2:     #3F3F46;
  --dnw-muted:     #6B6B70;
  --dnw-muted-2:   #9A9AA0;
  --dnw-line:      #EAEAEA;
  --dnw-line-2:    #F0F0F0;
  --dnw-soft:      #F4F4F2;
  --dnw-accent:    #C9A24A;       /* DNW gold, used sparingly */
  --dnw-accent-2:  #E9D9AE;
  --dnw-success:   #16A34A;
  --dnw-danger:    #DC2626;
  --dnw-focus:     0 0 0 3px rgba(10,10,10,.08);
  --dnw-radius:    10px;
  --dnw-radius-lg: 16px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body.dnw-registration-page {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--dnw-bg);
  color: var(--dnw-ink);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'ss01','cv11';
}

/* ── Screen ── */
.dnw-screen { display: none; width: 100vw; height: 100vh; overflow: hidden; }
.dnw-screen.on { display: flex; }
.dnw-split { display: flex; width: 100%; height: 100vh; padding: 24px; gap: 24px; background: var(--dnw-bg); }

/* ── Form panel (left card) ── */
.dnw-form-panel {
  flex: 0 0 calc(52% - 12px);
  background: var(--dnw-card);
  border: 1px solid var(--dnw-line);
  border-radius: var(--dnw-radius-lg);
  display: flex; flex-direction: column;
  padding: 56px 64px 48px;
  overflow-y: auto;
  position: relative;
}
.dnw-form-panel::-webkit-scrollbar { width: 6px; }
.dnw-form-panel::-webkit-scrollbar-thumb { background: #E0E0E0; border-radius: 4px; }

/* Thin progress bar pinned to top of card */
.dnw-form-panel::before {
  content: ''; position: absolute; top: 0; left: 0; height: 2px;
  width: var(--dnw-progress, 0%);
  background: var(--dnw-ink);
  border-top-left-radius: var(--dnw-radius-lg);
  transition: width .4s cubic-bezier(.4,0,.2,1);
}

/* ── Logo ── */
.dnw-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 56px; }
.dnw-logo-icon { width: 32px; height: 32px; border-radius: 8px; background: var(--dnw-ink); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.dnw-logo-icon svg { width: 18px; height: 18px; }
.dnw-logo-name { font-size: 14px; font-weight: 600; color: var(--dnw-ink); letter-spacing: -0.01em; }

/* ── Step badge ── */
.dnw-step-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; padding: 0;
  font-size: 12px; font-weight: 500; color: var(--dnw-muted);
  letter-spacing: 0; margin-bottom: 16px; text-transform: none;
  width: fit-content;
}
.dnw-step-pill {
  background: var(--dnw-soft); color: var(--dnw-ink);
  font-size: 11px; font-weight: 600; padding: 2px 8px;
  border-radius: 6px; letter-spacing: 0;
}

.dnw-heading {
  font-size: 34px; font-weight: 600; color: var(--dnw-ink);
  line-height: 1.15; margin-bottom: 10px; letter-spacing: -0.025em;
}
.dnw-subheading {
  font-size: 15px; color: var(--dnw-muted);
  line-height: 1.6; margin-bottom: 36px; max-width: 520px;
}

/* ── Progress dots (legacy fallback, hidden behind top bar) ── */
.dnw-progress { display: flex; align-items: center; gap: 4px; margin-bottom: 36px; }
.dnw-pdot { height: 4px; border-radius: 2px; background: var(--dnw-line); transition: all .3s ease; width: 24px; }
.dnw-pdot.active { background: var(--dnw-ink); }
.dnw-pdot.done { background: var(--dnw-ink); }

/* ── Fields ── */
.dnw-frow { display: flex; gap: 12px; }
.dnw-frow > .dnw-fld { flex: 1; min-width: 0; }
.dnw-fld { margin-bottom: 18px; }
.dnw-fld label {
  display: block; font-size: 13px; font-weight: 500;
  color: var(--dnw-ink-2); letter-spacing: 0;
  text-transform: none; margin-bottom: 6px;
}
.dnw-fld input, .dnw-fld select, .dnw-fld textarea {
  width: 100%; padding: 11px 13px;
  border: 1px solid var(--dnw-line); border-radius: var(--dnw-radius);
  font-size: 14px; color: var(--dnw-ink); background: var(--dnw-card);
  font-family: inherit;
  transition: border-color .15s, box-shadow .15s;
  outline: none; appearance: none;
}
.dnw-fld input::placeholder, .dnw-fld textarea::placeholder { color: var(--dnw-muted-2); }
.dnw-fld input:hover, .dnw-fld select:hover, .dnw-fld textarea:hover { border-color: #D4D4D4; }
.dnw-fld input:focus, .dnw-fld select:focus, .dnw-fld textarea:focus {
  border-color: var(--dnw-ink); box-shadow: var(--dnw-focus);
}
.dnw-fld input:disabled { background: var(--dnw-soft); color: var(--dnw-muted-2); }
.dnw-fld textarea { resize: vertical; min-height: 76px; line-height: 1.55; }
.dnw-fld .hint { font-size: 12px; color: var(--dnw-muted-2); margin-top: 6px; }
.dnw-fld label .req { color: var(--dnw-danger); margin-left: 2px; font-weight: 400; }
.dnw-fld select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236B6B70' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px;
}
.dnw-strength { display: flex; gap: 4px; margin-top: 8px; }
.dnw-sbar { height: 3px; flex: 1; border-radius: 2px; background: var(--dnw-line); }
.dnw-sbar.ok { background: var(--dnw-success); }

/* ── Error message ── */
.dnw-error-msg {
  background: #FEF2F2; border: 1px solid #FCA5A5;
  border-radius: var(--dnw-radius); padding: 12px 14px;
  font-size: 13px; color: #991B1B; margin-bottom: 16px; display: none;
}
.dnw-error-msg.show { display: block; }
.dnw-loading-btn { opacity: .6; pointer-events: none; }

/* ── Address autocomplete ── */
.dnw-addr-wrap { position: relative; }
.dnw-addr-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 500;
  background: #fff; border: 1px solid var(--dnw-line);
  border-radius: var(--dnw-radius);
  box-shadow: 0 6px 24px rgba(0,0,0,.08); overflow: hidden; display: none;
}
.dnw-addr-dropdown.open { display: block; }
.dnw-addr-option {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 11px 14px; cursor: pointer; transition: background .1s;
  border-bottom: 1px solid var(--dnw-line-2); font-size: 13px;
}
.dnw-addr-option:last-child { border-bottom: none; }
.dnw-addr-option:hover { background: var(--dnw-soft); }
.dnw-addr-pin { font-size: 14px; flex-shrink: 0; margin-top: 1px; color: var(--dnw-muted); }
.dnw-addr-main { font-weight: 500; color: var(--dnw-ink); }
.dnw-addr-sub { font-size: 12px; color: var(--dnw-muted-2); margin-top: 2px; }
.dnw-addr-loading { padding: 12px 14px; font-size: 13px; color: var(--dnw-muted-2); text-align: center; }
.dnw-addr-selected { display: flex; align-items: center; gap: 8px; margin-top: 6px; font-size: 12px; color: var(--dnw-success); font-weight: 500; }
.dnw-addr-selected .dnw-addr-clear { color: var(--dnw-muted-2); cursor: pointer; margin-left: auto; font-size: 12px; text-decoration: underline; }

/* ── Student cards ── */
.dnw-students-list { margin-bottom: 4px; }
.dnw-student-card {
  border: 1px solid var(--dnw-line); border-radius: 12px;
  overflow: hidden; margin-bottom: 10px; background: var(--dnw-card);
  transition: border-color .15s, box-shadow .15s;
}
.dnw-student-card:hover { border-color: #D4D4D4; }
.dnw-sc-summary { display: flex; align-items: center; gap: 14px; padding: 14px 16px; }
.dnw-sc-avatar {
  width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: #fff;
  background: var(--dnw-ink);
}
.dnw-sc-info { flex: 1; min-width: 0; }
.dnw-sc-name { font-size: 14px; font-weight: 600; color: var(--dnw-ink); }
.dnw-sc-detail { font-size: 12px; color: var(--dnw-muted); margin-top: 2px; }
.dnw-sc-actions { display: flex; gap: 6px; flex-shrink: 0; }
.dnw-sc-btn {
  font-size: 12px; font-weight: 500; padding: 6px 10px;
  border-radius: 6px; cursor: pointer; border: 1px solid;
  font-family: inherit; transition: all .15s; background: #fff;
}
.dnw-sc-edit { color: var(--dnw-ink); border-color: var(--dnw-line); }
.dnw-sc-edit:hover { border-color: var(--dnw-ink); }
.dnw-sc-del { color: var(--dnw-danger); border-color: var(--dnw-line); }
.dnw-sc-del:hover { border-color: var(--dnw-danger); background: #FEF2F2; }
.dnw-sc-form { padding: 0 16px 16px; border-top: 1px solid var(--dnw-line); display: none; background: var(--dnw-card); }
.dnw-sc-form.open { display: block; }
.dnw-sc-form-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 0 16px; }
.dnw-sc-form-label { font-size: 12px; font-weight: 500; color: var(--dnw-muted); text-transform: none; letter-spacing: 0; }
.dnw-sc-save {
  font-size: 12px; font-weight: 500; color: #fff; background: var(--dnw-ink);
  border: none; padding: 7px 14px; border-radius: 6px; cursor: pointer; font-family: inherit;
}
.dnw-sc-save:hover { background: #1A1A1A; }
.dnw-add-card {
  width: 100%; padding: 14px 18px;
  border: 1px dashed #D4D4D4; border-radius: 12px;
  background: transparent; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-size: 13px; font-weight: 500; color: var(--dnw-muted);
  transition: all .15s; margin-bottom: 22px; font-family: inherit;
}
.dnw-add-card:hover { border-color: var(--dnw-ink); color: var(--dnw-ink); background: var(--dnw-soft); }

/* ── D2D ── */
.dnw-d2d-card {
  border: 1px solid var(--dnw-line); border-radius: 12px;
  padding: 18px 20px; margin-bottom: 10px; transition: all .15s; background: var(--dnw-card);
}
.dnw-d2d-card.selected { border-color: var(--dnw-ink); background: var(--dnw-soft); }
.dnw-d2d-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.dnw-d2d-info { flex: 1; }
.dnw-d2d-route { font-size: 14px; font-weight: 600; color: var(--dnw-ink); margin-bottom: 3px; }
.dnw-d2d-students { font-size: 12px; color: var(--dnw-muted); }
.dnw-d2d-pricing-note { font-size: 12px; color: var(--dnw-muted-2); margin-top: 5px; }
.dnw-d2d-toggle-wrap { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.dnw-d2d-price { font-size: 13px; font-weight: 600; color: var(--dnw-ink); white-space: nowrap; }
.dnw-d2d-price.off { color: var(--dnw-muted-2); font-weight: 400; }
.dnw-toggle {
  width: 44px; height: 24px; border-radius: 12px; background: #E4E4E4;
  position: relative; cursor: pointer; border: none; flex-shrink: 0; transition: background .2s;
}
.dnw-toggle.on { background: var(--dnw-ink); }
.dnw-toggle::after {
  content: ''; position: absolute; width: 18px; height: 18px; border-radius: 50%;
  background: #fff; top: 3px; left: 3px; transition: left .2s;
  box-shadow: 0 1px 2px rgba(0,0,0,.15);
}
.dnw-toggle.on::after { left: 23px; }
.dnw-d2d-expand { display: none; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--dnw-line); }
.dnw-d2d-expand.show { display: block; }

/* ── Policy boxes ── */
.dnw-policy-box {
  border: 1px solid var(--dnw-line); border-radius: 12px;
  padding: 24px 26px; height: 420px; overflow-y: auto;
  margin-bottom: 18px; font-size: 14px; color: var(--dnw-ink-2); line-height: 1.75;
  background: var(--dnw-card); width: 100%;
}
.dnw-policy-box::-webkit-scrollbar { width: 5px; }
.dnw-policy-box::-webkit-scrollbar-track { background: transparent; }
.dnw-policy-box::-webkit-scrollbar-thumb { background: #D4D4D4; border-radius: 4px; }
.dnw-policy-box h4 {
  font-size: 13px; font-weight: 600; color: var(--dnw-ink);
  text-transform: none; letter-spacing: 0; margin: 22px 0 8px;
}
.dnw-policy-box h4:first-child { margin-top: 0; }
.dnw-policy-box p { margin-bottom: 10px; }

.dnw-agree-btn {
  width: 100%; padding: 13px; border: 1px solid var(--dnw-ink);
  border-radius: var(--dnw-radius); background: #fff; color: var(--dnw-ink);
  font-size: 14px; font-weight: 500; cursor: pointer;
  transition: all .15s; font-family: inherit;
  margin-bottom: 8px; display: flex; align-items: center; justify-content: center; gap: 8px;
}
.dnw-agree-btn:hover { background: var(--dnw-soft); }
.dnw-agree-btn.agreed { background: var(--dnw-ink); color: #fff; border-color: var(--dnw-ink); cursor: default; }
.dnw-agreed-label { font-size: 12px; color: var(--dnw-success); font-weight: 500; text-align: center; margin-bottom: 6px; }

/* ── Review blocks ── */
.dnw-review-block {
  border: 1px solid var(--dnw-line); border-radius: 12px;
  overflow: hidden; margin-bottom: 10px; background: var(--dnw-card);
}
.dnw-review-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: var(--dnw-soft); border-bottom: 1px solid var(--dnw-line);
}
.dnw-review-header-label { font-size: 12px; font-weight: 600; color: var(--dnw-ink); text-transform: none; letter-spacing: 0; }
.dnw-edit-link { font-size: 12px; font-weight: 500; color: var(--dnw-muted); text-decoration: none; cursor: pointer; transition: color .15s; }
.dnw-edit-link:hover { color: var(--dnw-ink); text-decoration: underline; }
.dnw-review-row {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 10px 16px; font-size: 13px; border-bottom: 1px solid var(--dnw-line-2); gap: 10px;
}
.dnw-review-row:last-child { border-bottom: none; }
.dnw-review-row .lbl { color: var(--dnw-muted); flex-shrink: 0; font-weight: 400; }
.dnw-review-row .val { color: var(--dnw-ink); font-weight: 500; text-align: right; }
.dnw-total-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px; background: var(--dnw-ink); font-size: 15px;
  font-weight: 600; color: #fff;
}
.dnw-total-row .amt { color: var(--dnw-accent-2); font-weight: 600; }

/* ── Buttons ── */
.dnw-btn-row { display: flex; gap: 10px; margin-top: auto; padding-top: 28px; }
.dnw-btn {
  padding: 12px 22px; border-radius: 8px;
  font-size: 14px; font-weight: 500; cursor: pointer;
  border: none; transition: all .15s ease;
  font-family: inherit; letter-spacing: -0.005em;
}
.dnw-btn-dark { background: var(--dnw-ink); color: #fff; flex: 1; }
.dnw-btn-dark:hover { background: #1A1A1A; }
.dnw-btn-dark:active { transform: translateY(1px); }
.dnw-btn-outline {
  background: #fff; color: var(--dnw-ink);
  border: 1px solid var(--dnw-line); flex-shrink: 0;
}
.dnw-btn-outline:hover { border-color: #B0B0B0; background: var(--dnw-soft); }
.dnw-btn-gold { background: var(--dnw-ink); color: #fff; flex: 1; }
.dnw-btn-gold:hover { background: #1A1A1A; }

.dnw-link-hint { font-size: 13px; color: var(--dnw-muted); margin-top: 22px; text-align: center; }
.dnw-link-hint a { color: var(--dnw-ink); font-weight: 500; text-decoration: none; cursor: pointer; }
.dnw-link-hint a:hover { text-decoration: underline; }

/* ── Alert ── */
.dnw-alert {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 12px 14px; border-radius: var(--dnw-radius);
  font-size: 13px; margin-bottom: 16px; line-height: 1.55;
  border: 1px solid var(--dnw-line); background: var(--dnw-soft); color: var(--dnw-ink-2);
}
.dnw-alert-amber { background: #FFFBEB; border-color: #FDE68A; color: #78350F; }
.dnw-alert-blue  { background: #F0F7FF; border-color: #BFDBFE; color: #1E3A8A; }
.dnw-alert-green { background: #F0FDF4; border-color: #BBF7D0; color: #14532D; }
.dnw-alert-icon  { flex-shrink: 0; }

/* ── Success ── */
.dnw-success-icon {
  width: 64px; height: 64px; border-radius: 16px;
  background: var(--dnw-ink); display: flex;
  align-items: center; justify-content: center;
  font-size: 28px; color: #fff; margin-bottom: 24px;
}

/* ── Deco panel (right side) ── */
.dnw-deco-panel {
  flex: 1; position: relative; overflow: hidden;
  border-radius: var(--dnw-radius-lg);
  background:
    radial-gradient(ellipse 80% 60% at 70% 20%, rgba(201,162,74,.10), transparent 60%),
    radial-gradient(ellipse 70% 50% at 30% 80%, rgba(180,200,230,.18), transparent 60%),
    linear-gradient(160deg, #F7F7F5 0%, #EFEFEC 100%);
  border: 1px solid var(--dnw-line);
}
.dnw-blob {
  position: absolute; border-radius: 50%; filter: blur(60px); opacity: .55;
}
.dnw-b1 { width: 420px; height: 420px; background: rgba(201,162,74,.30); top: -120px; right: -80px; }
.dnw-b2 { width: 360px; height: 360px; background: rgba(180,200,230,.45); top: 30%; right: 10%; }
.dnw-b3 { width: 440px; height: 440px; background: rgba(220,210,190,.50); bottom: -140px; right: -60px; }
.dnw-b4 { display: none; }

/* Single floating card (replaces testimonial wall) */
.dnw-deco-card {
  position: absolute; bottom: 40px; left: 40px; right: 40px; z-index: 10;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.9);
  border-radius: 14px; padding: 22px 24px;
  box-shadow: 0 4px 24px rgba(0,0,0,.06);
}
.dnw-deco-card__eyebrow {
  font-size: 11px; font-weight: 500; color: var(--dnw-muted);
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: 10px;
}
.dnw-deco-card__quote {
  font-size: 17px; font-weight: 500; color: var(--dnw-ink);
  line-height: 1.45; margin-bottom: 14px; letter-spacing: -0.015em;
}
.dnw-deco-card__author { display: flex; align-items: center; gap: 10px; }
.dnw-deco-card__avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--dnw-ink); display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600; color: #fff; flex-shrink: 0;
}
.dnw-deco-card__name { font-size: 13px; font-weight: 500; color: var(--dnw-ink); }
.dnw-deco-card__school { font-size: 12px; color: var(--dnw-muted); }

.dnw-deco-steps {
  position: absolute; top: 50%; transform: translateY(-65%);
  left: 40px; right: 40px; z-index: 10;
}
.dnw-deco-step {
  display: flex; align-items: center; gap: 13px;
  padding: 11px 0; border-bottom: 1px solid rgba(0,0,0,.06);
}
.dnw-deco-step:last-child { border-bottom: none; }
.dnw-deco-step-n {
  width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 500;
  background: rgba(255,255,255,.85); color: var(--dnw-muted);
  border: 1px solid var(--dnw-line);
}
.dnw-deco-step-n.done { background: var(--dnw-ink); color: #fff; border-color: var(--dnw-ink); }
.dnw-deco-step-n.cur  { background: var(--dnw-ink); color: #fff; border-color: var(--dnw-ink); }
.dnw-deco-step-label { font-size: 13px; font-weight: 500; color: var(--dnw-ink); }
.dnw-deco-step-sub   { font-size: 12px; color: var(--dnw-muted); margin-top: 1px; }

/* ── Map panel (s3) ── */
.dnw-map-panel {
  flex: 1; position: relative; overflow: hidden;
  border-radius: var(--dnw-radius-lg);
  border: 1px solid var(--dnw-line);
  background: var(--dnw-soft);
}
#dnw-route-map { position: absolute; inset: 0; width: 100%; height: 100%; border-radius: var(--dnw-radius-lg); }

/* Route preview / legend at bottom — fixed cut-off issue */
.dnw-map-legend {
  position: absolute; bottom: 20px; left: 20px; right: 20px; z-index: 500;
  background: rgba(255,255,255,.95);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 12px; padding: 16px 20px;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  font-size: 13px; max-width: 320px;
  max-height: 30vh; overflow-y: auto;
}
.dnw-map-legend-title {
  font-weight: 600; color: var(--dnw-ink);
  margin-bottom: 10px; font-size: 12px;
  text-transform: none; letter-spacing: 0;
}
.dnw-map-legend-item { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; font-size: 13px; color: var(--dnw-ink-2); }
.dnw-map-legend-item:last-child { margin-bottom: 0; }
.dnw-map-dot  { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }

/* ── Confirmation modal ── */
.dnw-modal-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(10,10,10,.40); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.dnw-modal-overlay.show { opacity: 1; pointer-events: all; }
.dnw-modal {
  background: #fff; border-radius: var(--dnw-radius-lg);
  padding: 36px 32px; max-width: 440px; width: 100%;
  box-shadow: 0 20px 60px rgba(0,0,0,.20);
  border: 1px solid var(--dnw-line);
  transform: translateY(12px) scale(.98);
  transition: transform .22s cubic-bezier(.34,1.2,.64,1);
}
.dnw-modal-overlay.show .dnw-modal { transform: translateY(0) scale(1); }
.dnw-modal-icon  { font-size: 32px; margin-bottom: 14px; }
.dnw-modal-title {
  font-size: 22px; font-weight: 600; color: var(--dnw-ink);
  margin-bottom: 10px; letter-spacing: -0.02em;
}
.dnw-modal-body  { font-size: 14px; color: var(--dnw-muted); line-height: 1.6; margin-bottom: 28px; }
.dnw-modal-checklist { list-style: none; margin-bottom: 24px; }
.dnw-modal-checklist li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; color: var(--dnw-ink-2);
  padding: 8px 0; border-bottom: 1px solid var(--dnw-line-2);
}
.dnw-modal-checklist li:last-child { border-bottom: none; }
.dnw-modal-checklist .check {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--dnw-ink); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 10px; color: #fff; margin-top: 1px;
}
.dnw-modal-btns { display: flex; gap: 10px; }
.dnw-modal-btn-back {
  flex: 1; padding: 12px; border-radius: 8px;
  border: 1px solid var(--dnw-line); background: #fff; color: var(--dnw-ink);
  font-size: 14px; font-weight: 500; cursor: pointer; font-family: inherit;
}
.dnw-modal-btn-back:hover { background: var(--dnw-soft); }
.dnw-modal-btn-confirm {
  flex: 2; padding: 12px; border-radius: 8px; border: none;
  background: var(--dnw-ink); color: #fff;
  font-size: 14px; font-weight: 500; cursor: pointer; font-family: inherit;
}
.dnw-modal-btn-confirm:hover { background: #1A1A1A; }
.dnw-modal-btn-confirm.gold { background: var(--dnw-ink); color: #fff; }
.dnw-modal-btn-confirm.gold:hover { background: #1A1A1A; }

/* ── Mobile ── */
@media (max-width: 768px) {
  .dnw-screen.on { display: block; height: auto; overflow: auto; }
  .dnw-split { flex-direction: column; height: auto; min-height: 100vh; padding: 12px; gap: 12px; }
  .dnw-form-panel { flex: none; width: 100%; padding: 28px 22px 40px; border-radius: 12px; }
  .dnw-deco-panel, .dnw-map-panel { display: none; }
  .dnw-heading { font-size: 26px; }
  .dnw-subheading { font-size: 14px; margin-bottom: 24px; }
  .dnw-logo { margin-bottom: 32px; }
  .dnw-frow { flex-direction: column; gap: 0; }
  .dnw-frow > .dnw-fld { flex: none; width: 100%; }
  .dnw-fld input, .dnw-fld select, .dnw-fld textarea { font-size: 16px; }
  .dnw-policy-box { height: 320px; padding: 18px; font-size: 13px; }
  .dnw-btn-row { flex-wrap: wrap; }
  .dnw-btn-outline { flex: 1; }
  .dnw-modal { padding: 26px 22px; }
}
@media (min-width: 769px) and (max-width: 1100px) {
  .dnw-split { padding: 16px; gap: 16px; }
  .dnw-form-panel { flex: 0 0 calc(58% - 8px); padding: 40px 42px; }
  .dnw-heading { font-size: 26px; }
  .dnw-frow { flex-direction: column; gap: 0; }
  .dnw-frow > .dnw-fld { flex: none; width: 100%; }
}

/* ── Section label ── */
.dnw-section-label {
  font-size: 12px; font-weight: 500; color: var(--dnw-muted);
  text-transform: none; letter-spacing: 0;
  margin-bottom: 14px; margin-top: 8px;
  padding-bottom: 10px; border-bottom: 1px solid var(--dnw-line);
}

/* ── Policy checkboxes ── */
.dnw-policy-checks { margin-bottom: 18px; }
.dnw-policy-item {
  display: flex; align-items: flex-start;
  padding: 12px 14px; border: 1px solid var(--dnw-line);
  border-radius: var(--dnw-radius); margin-bottom: 8px;
  background: var(--dnw-card); transition: border-color .15s, background .15s;
  cursor: pointer;
}
.dnw-policy-item:hover { border-color: #C9C9C9; background: var(--dnw-soft); }
.dnw-policy-item label {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 13px; color: var(--dnw-ink-2); line-height: 1.55;
  cursor: pointer; width: 100%;
  font-weight: 400; text-transform: none; letter-spacing: 0;
}
.dnw-policy-item input[type="checkbox"] {
  width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px;
  accent-color: var(--dnw-ink); cursor: pointer;
  border: 1px solid var(--dnw-line); border-radius: 4px;
}
.dnw-policy-item:has(input:checked) {
  border-color: var(--dnw-ink); background: var(--dnw-soft);
}
.dnw-policy-item:has(input:checked) label { color: var(--dnw-ink); }

/* ── Inline-checkbox policy layout ── */
.dnw-policy-inline .dnw-policy-section {
  padding: 16px 0; border-bottom: 1px solid var(--dnw-line-2);
}
.dnw-policy-inline .dnw-policy-section:last-child { border-bottom: none; }
.dnw-policy-inline .dnw-policy-section h4 {
  margin: 0 0 6px; padding: 0;
  text-transform: none; letter-spacing: 0;
  font-size: 14px; font-weight: 600; color: var(--dnw-ink);
}
.dnw-policy-inline .dnw-policy-section p { margin: 0; font-size: 13px; color: var(--dnw-ink-2); line-height: 1.6; }
.dnw-inline-check {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 600; color: var(--dnw-ink);
  cursor: pointer; text-transform: none; letter-spacing: 0;
}
.dnw-inline-check input[type="checkbox"] {
  width: 18px; height: 18px; margin: 0; flex-shrink: 0;
  accent-color: var(--dnw-ink); cursor: pointer;
}
.dnw-policy-inline .dnw-policy-section:has(input:checked) h4 .dnw-inline-check { color: var(--dnw-success); }

.dnw-policy-final {
  margin: 18px 0;
  padding: 14px 16px;
  background: var(--dnw-soft);
  border: 1px solid var(--dnw-ink);
  border-radius: var(--dnw-radius);
}
.dnw-policy-final-label {
  display: flex; align-items: center; gap: 12px;
  font-size: 14px; color: var(--dnw-ink); cursor: pointer; font-weight: 500;
}
.dnw-policy-final-label input[type="checkbox"] {
  width: 20px; height: 20px; margin: 0; flex-shrink: 0;
  accent-color: var(--dnw-ink); cursor: pointer;
}
.dnw-policy-final:has(input:checked) { background: #F0FDF4; border-color: var(--dnw-success); }

/* ── Route Loading Screen (mobile only) ── */
#s-routeloading {
  display: none; align-items: center; justify-content: center;
  background: var(--dnw-bg); min-height: 100vh;
}
#s-routeloading.on { display: flex; }

.dnw-route-loading-wrap {
  display: flex; flex-direction: column; align-items: center;
  padding: 48px 32px; text-align: center; gap: 16px;
}
.dnw-route-loading-icon { width: 88px; height: 88px; margin-bottom: 8px; }
.dnw-route-loading-icon svg { width: 100%; height: 100%; }
.dnw-spinner-arc { transform-origin: center; animation: dnw-spin 1.2s linear infinite; }
@keyframes dnw-spin { to { transform: rotate(360deg); } }

.dnw-route-loading-title {
  font-size: 22px; font-weight: 600; color: var(--dnw-ink); letter-spacing: -0.02em;
}
.dnw-route-loading-msg {
  font-size: 14px; color: var(--dnw-muted); font-weight: 400;
  min-height: 20px; transition: opacity .3s ease;
}
.dnw-route-progress-track {
  width: 220px; height: 4px; background: var(--dnw-line);
  border-radius: 100px; overflow: hidden; margin-top: 8px;
}
.dnw-route-progress-bar {
  height: 100%; width: 0%; background: var(--dnw-ink);
  border-radius: 100px; transition: width 2s cubic-bezier(.4,0,.2,1);
}

/* ── Signature canvas (s5b) ── */
.dnw-sig-wrap { margin: 4px 0 18px; }
.dnw-sig-label {
  font-size: 13px; font-weight: 500; color: var(--dnw-ink-2);
  text-transform: none; letter-spacing: 0; margin-bottom: 8px;
}
.dnw-sig-canvas-wrap {
  position: relative; background: var(--dnw-card);
  border: 1px dashed #C9C9C9; border-radius: 12px;
  height: 180px; overflow: hidden; cursor: crosshair;
}
.dnw-sig-canvas { position: absolute; inset: 0; width: 100%; height: 100%; touch-action: none; }
.dnw-sig-baseline { position: absolute; left: 24px; right: 24px; bottom: 38px; border-bottom: 1px solid #C9C9C9; pointer-events: none; }
.dnw-sig-x { position: absolute; left: 18px; bottom: 28px; font-size: 18px; color: var(--dnw-muted-2); pointer-events: none; }
.dnw-sig-actions { display: flex; align-items: center; gap: 14px; margin-top: 10px; flex-wrap: wrap; }
.dnw-sig-hint { font-size: 12px; color: var(--dnw-muted); }
