/* ── NordicLead Plugin Styles ── */
:root {
  --nl-primary: #162E2C;
  --nl-accent: #56958E;
  --nl-accent-hover: #47807A;
  --nl-bg: #f8f9fc;
  --nl-white: #ffffff;
  --nl-border: #e2e8f0;
  --nl-text: #1e293b;
  --nl-muted: #64748b;
  --nl-success: #16a34a;
  --nl-error: #dc2626;
  --nl-radius: 10px;
}

/* ── Layout ── */
.nl-wrap {
  display: flex !important;
  gap: 48px !important;
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 8px 24px 20px !important;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  color: var(--nl-text) !important;
  background: transparent !important;
}
.nl-form-side { flex: 1 !important; min-width: 0 !important; }
.nl-info-side {
  flex: 1 !important;
  min-width: 0 !important;
  background: #162E2C !important;
  color: #fff !important;
  border-radius: 16px !important;
  padding: 40px !important;
}
.nl-full { max-width: 480px !important; margin: 0 auto !important; }

/* ── Logo ── */
.nl-logo { font-size: 22px !important; font-weight: 800 !important; color: #56958E !important; margin-bottom: 24px !important; }

/* ── Headings ── */
.nl-form-side h1, .nl-ob-wrap h2 { font-size: 26px !important; font-weight: 800 !important; margin: 0 0 8px !important; }
.nl-subtitle { color: var(--nl-muted) !important; margin: 0 0 28px !important; }
.nl-info-side h2 { font-size: 22px !important; font-weight: 700 !important; margin: 0 0 24px !important; color: #fff !important; }

/* ── Fields ── */
.nl-field { margin-bottom: 18px !important; }
.nl-field label { display: block !important; font-weight: 600 !important; font-size: 14px !important; margin-bottom: 6px !important; }
.nl-field label small { font-weight: 400 !important; color: var(--nl-muted) !important; }
.nl-field input[type="text"],
.nl-field input[type="email"],
.nl-field input[type="url"],
.nl-field input[type="tel"],
.nl-field input[type="password"],
.nl-field textarea,
.nl-field select {
  width: 100% !important;
  padding: 11px 14px !important;
  border: 1.5px solid var(--nl-border) !important;
  border-radius: var(--nl-radius) !important;
  font-size: 15px !important;
  color: var(--nl-text) !important;
  background: #ffffff !important;
  transition: border-color .2s !important;
  box-sizing: border-box !important;
  font-family: inherit !important;
}
.nl-field input:focus,
.nl-field textarea:focus,
.nl-field select:focus {
  outline: none !important;
  border-color: #56958E !important;
  box-shadow: 0 0 0 3px rgba(86,149,142,.12) !important;
}
.nl-err { display: block !important; color: var(--nl-error) !important; font-size: 13px !important; margin-top: 4px !important; min-height: 18px !important; }

/* ── Buttons ── */
.nl-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 13px 24px !important;
  border-radius: var(--nl-radius) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  border: none !important;
  transition: background .2s, transform .1s !important;
  font-family: inherit !important;
}
.nl-btn-primary { background: #56958E !important; color: #fff !important; width: 100% !important; }
.nl-btn-primary:hover { background: #47807A !important; }
.nl-btn-secondary { background: transparent !important; color: #56958E !important; border: 1.5px solid #56958E !important; }
.nl-btn-secondary:hover { background: rgba(86,149,142,.06) !important; }
.nl-btn:disabled { opacity: .6 !important; cursor: not-allowed !important; }
.nl-btn:active { transform: scale(.98) !important; }

/* ── Notices ── */
.nl-notice { padding: 14px 16px !important; border-radius: var(--nl-radius) !important; margin-bottom: 20px !important; font-size: 15px !important; }
.nl-notice-success { background: #dcfce7 !important; color: #15803d !important; border: 1px solid #bbf7d0 !important; }
.nl-notice-error   { background: #fee2e2 !important; color: var(--nl-error) !important; border: 1px solid #fecaca !important; }

/* ── Fine print ── */
.nl-fine-print { font-size: 13px !important; color: var(--nl-muted) !important; text-align: center !important; margin: 12px 0 6px !important; }
.nl-login-link  { font-size: 14px !important; text-align: center !important; color: var(--nl-muted) !important; margin: 0 !important; }
.nl-login-link a { color: #56958E !important; text-decoration: none !important; font-weight: 600 !important; }

/* ── Info side steps ── */
.nl-steps { display: flex !important; flex-direction: column !important; gap: 24px !important; }
.nl-step  { display: flex !important; gap: 16px !important; align-items: flex-start !important; }
.nl-step-num {
  width: 36px !important; height: 36px !important; border-radius: 50% !important;
  background: rgba(255,255,255,.15) !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  font-weight: 800 !important; font-size: 15px !important; flex-shrink: 0 !important;
  color: #fff !important;
}
.nl-step p { margin: 4px 0 0 !important; font-size: 14px !important; opacity: .8 !important; color: #fff !important; }
.nl-step strong { color: #fff !important; }
.nl-badges { display: flex !important; flex-wrap: wrap !important; gap: 10px !important; margin-top: 32px !important; }
.nl-badges span { background: rgba(255,255,255,.12) !important; padding: 6px 14px !important; border-radius: 100px !important; font-size: 13px !important; font-weight: 600 !important; color: #fff !important; }

/* ── Onboarding wrapper ── */
.nl-ob-wrap { flex-direction: column !important; max-width: 680px !important; }

/* ── Progress bar — Stil 3 ── */
.nl-progress-bar { margin-bottom: 20px !important; }
.nl-progress-track {
  height: 4px !important;
  background: var(--nl-border) !important;
  border-radius: 10px !important;
  overflow: hidden !important;
}
.nl-progress-fill {
  height: 100% !important;
  background: #56958E !important;
  border-radius: 10px !important;
  transition: width .4s ease !important;
  width: 0% !important;
}

/* ── Step panels ── */
.nl-step-panel { animation: nlFadeIn .3s ease !important; }
@keyframes nlFadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:none; } }
.nl-step-desc { color: var(--nl-muted) !important; margin: 0 0 24px !important; }
.nl-step-actions { display: flex !important; gap: 12px !important; margin-top: 28px !important; }
.nl-step-actions .nl-btn { flex: 1 !important; }

/* ── Checkboxes ── */
.nl-checkboxes { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; }
.nl-checkbox-label {
  display: flex !important; align-items: center !important; gap: 6px !important;
  padding: 7px 14px !important; border: 1.5px solid var(--nl-border) !important;
  border-radius: 100px !important; font-size: 14px !important; cursor: pointer !important;
  transition: border-color .2s, background .2s !important;
  background: #fff !important; color: var(--nl-text) !important;
}
.nl-checkbox-label:hover { border-color: #56958E !important; }
.nl-checkbox-label input { display: none !important; }
.nl-checkbox-label.selected { background: #56958E !important; color: #fff !important; border-color: #56958E !important; }

/* ── Tag input ── */
.nl-tag-input { display: flex !important; align-items: center !important; flex-wrap: wrap !important; gap: 6px !important; padding: 8px 12px !important; border: 1.5px solid var(--nl-border) !important; border-radius: var(--nl-radius) !important; background: #ffffff !important; }
.nl-tag-input input { border: none !important; outline: none !important; font-size: 15px !important; flex: 1 !important; min-width: 150px !important; font-family: inherit !important; background: transparent !important; }
.nl-tags { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; margin-top: 8px !important; }
.nl-tag { display: inline-flex !important; align-items: center !important; gap: 4px !important; background: #56958E !important; color: #fff !important; padding: 4px 12px !important; border-radius: 100px !important; font-size: 13px !important; }
.nl-tag button { background: none !important; border: none !important; color: #fff !important; cursor: pointer !important; font-size: 16px !important; line-height: 1 !important; padding: 0 !important; opacity: .8 !important; }
.nl-tag button:hover { opacity: 1 !important; }

/* ── Mål-kort (trin 4) ── */
.nl-maal-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 16px !important;
  margin-top: 8px !important;
  justify-content: center !important;
}
.nl-maal-kort {
  flex: 1 1 calc(33.333% - 16px) !important;
  min-width: 180px !important;
  max-width: calc(33.333% - 16px) !important;
  border: 2px solid var(--nl-border) !important;
  border-radius: 12px !important;
  padding: 24px 16px !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: border-color .2s, background .2s, transform .1s !important;
  user-select: none !important;
  background: #fff !important;
}
.nl-maal-kort:hover { border-color: #56958E !important; background: rgba(86,149,142,.04) !important; }
.nl-maal-kort.valgt  { border-color: #56958E !important; background: rgba(86,149,142,.08) !important; }
.nl-maal-kort.valgt .nl-maal-ikon { transform: scale(1.15) !important; }
.nl-maal-ikon  { font-size: 36px !important; margin-bottom: 12px !important; transition: transform .2s !important; }
.nl-maal-titel { font-weight: 700 !important; font-size: 16px !important; margin-bottom: 6px !important; }
.nl-maal-desc  { font-size: 13px !important; color: var(--nl-muted) !important; line-height: 1.4 !important; }
@media (max-width: 600px) { .nl-maal-grid { grid-template-columns: 1fr !important; } }

/* ── Prisberegner (trin 5) ── */
.nl-pris-kort {
  background: #f8f9fc !important;
  border: 1.5px solid var(--nl-border) !important;
  border-radius: 14px !important;
  padding: 28px !important;
}
.nl-pris-header { margin-bottom: 20px !important; }
.nl-pris-label  { font-size: 11px !important; font-weight: 700 !important; letter-spacing: .08em !important; color: var(--nl-muted) !important; text-transform: uppercase !important; }
.nl-pris-total  { font-size: 48px !important; font-weight: 800 !important; color: #56958E !important; line-height: 1.1 !important; margin-top: 4px !important; }
.nl-pris-dkk    { font-size: 22px !important; font-weight: 600 !important; color: var(--nl-muted) !important; }
.nl-slider-wrap { margin-bottom: 24px !important; }
.nl-slider {
  -webkit-appearance: none !important;
  width: 100% !important; height: 6px !important;
  border-radius: 10px !important;
  background: linear-gradient(to right, #56958E 0%, #56958E 12%, #e2e8f0 12%, #e2e8f0 100%) !important;
  outline: none !important; cursor: pointer !important;
  margin-bottom: 8px !important;
}
.nl-slider::-webkit-slider-thumb {
  -webkit-appearance: none !important;
  width: 22px !important; height: 22px !important;
  border-radius: 50% !important;
  background: #56958E !important;
  box-shadow: 0 2px 6px rgba(86,149,142,.4) !important;
  cursor: pointer !important;
}
.nl-slider::-moz-range-thumb {
  width: 22px !important; height: 22px !important;
  border-radius: 50% !important; border: none !important;
  background: #56958E !important;
  box-shadow: 0 2px 6px rgba(86,149,142,.4) !important;
}
.nl-slider-labels { display: flex !important; justify-content: space-between !important; font-size: 12px !important; color: var(--nl-muted) !important; }
.nl-pris-breakdown { display: flex !important; flex-direction: column !important; gap: 0 !important; border: 1.5px solid var(--nl-border) !important; border-radius: 10px !important; overflow: hidden !important; background: #fff !important; }
.nl-pris-linje { display: flex !important; justify-content: space-between !important; align-items: center !important; padding: 12px 16px !important; font-size: 14px !important; border-bottom: 1px solid var(--nl-border) !important; }
.nl-pris-linje:last-child { border-bottom: none !important; }
.nl-pris-linje em { font-style: normal !important; font-size: 12px !important; color: var(--nl-muted) !important; }
.nl-pris-linje--fee   { color: var(--nl-muted) !important; background: #fafafa !important; }
.nl-pris-linje--total { background: #56958E !important; color: #fff !important; font-size: 15px !important; }
.nl-pris-linje--total strong { color: #fff !important; }
.nl-pris-note { font-size: 13px !important; color: var(--nl-muted) !important; text-align: center !important; margin-top: 16px !important; font-style: italic !important; line-height: 1.5 !important; }

/* ── Betaling ── */
.nl-betal-next { background: #f8f9fc !important; border: 1.5px solid var(--nl-border) !important; border-radius: 12px !important; padding: 20px !important; margin-bottom: 24px !important; }
.nl-betal-next-titel { font-size: 14px !important; font-weight: 700 !important; margin-bottom: 12px !important; }
.nl-betal-next-step { display: flex !important; gap: 12px !important; align-items: flex-start !important; font-size: 14px !important; margin-bottom: 8px !important; color: var(--nl-muted) !important; }
.nl-betal-next-step span { width: 22px !important; height: 22px !important; border-radius: 50% !important; background: #56958E !important; color: #fff !important; display: flex !important; align-items: center !important; justify-content: center !important; font-size: 12px !important; font-weight: 700 !important; flex-shrink: 0 !important; }
.nl-trust-badges { display: flex !important; gap: 16px !important; font-size: 13px !important; color: var(--nl-muted) !important; margin-top: 16px !important; flex-wrap: wrap !important; }
.nl-card-element { border: 1.5px solid var(--nl-border) !important; border-radius: var(--nl-radius) !important; padding: 14px !important; background: #fff !important; }
.nl-kort-ikoner { display: flex !important; gap: 8px !important; margin-bottom: 12px !important; }

/* ── Tak-skærm ── */
.nl-tak { text-align: center !important; padding: 40px 24px !important; }
.nl-tak-icon { font-size: 64px !important; margin-bottom: 16px !important; }
.nl-tak h2 { font-size: 28px !important; margin: 0 0 12px !important; }
.nl-tak p  { color: var(--nl-muted) !important; margin: 0 0 32px !important; font-size: 16px !important; }
.nl-tak-steps { display: flex !important; flex-direction: column !important; gap: 16px !important; text-align: left !important; max-width: 400px !important; margin: 0 auto !important; }
.nl-tak-step { display: flex !important; gap: 12px !important; align-items: flex-start !important; background: var(--nl-bg) !important; padding: 14px 18px !important; border-radius: var(--nl-radius) !important; }
.nl-tak-step span { font-size: 20px !important; }

/* ── Spinner ── */
.nl-spinner { animation: nlPulse 1s infinite !important; letter-spacing: 2px !important; }
@keyframes nlPulse { 0%,100% { opacity:.3; } 50% { opacity:1; } }

/* ── Responsive ── */
@media (max-width: 768px) {
  .nl-wrap { flex-direction: column !important; padding: 16px !important; }
  .nl-info-side { padding: 28px 20px !important; }
}

/* ── Dashboard ── */
.nl-dash-header { display: flex !important; justify-content: space-between !important; align-items: flex-start !important; margin-bottom: 32px !important; padding-bottom: 24px !important; border-bottom: 2px solid var(--nl-border) !important; }
.nl-dash-titel { font-size: 28px !important; font-weight: 800 !important; margin: 0 0 4px !important; }
.nl-dash-sub   { color: var(--nl-muted) !important; margin: 0 !important; font-size: 15px !important; }
.nl-dash-logout { background: transparent !important; border: 1.5px solid var(--nl-border) !important; color: var(--nl-muted) !important; padding: 8px 18px !important; border-radius: var(--nl-radius) !important; font-size: 14px !important; font-weight: 600 !important; text-decoration: none !important; cursor: pointer !important; }
.nl-dash-logout:hover { border-color: var(--nl-accent) !important; color: var(--nl-accent) !important; }
.nl-dash-grid { display: grid !important; grid-template-columns: 2fr 1fr 1fr 1fr !important; gap: 16px !important; margin-bottom: 32px !important; }
@media (max-width: 768px) { .nl-dash-grid { grid-template-columns: 1fr 1fr !important; } }
.nl-dash-kort { background: #fff !important; border: 1.5px solid var(--nl-border) !important; border-radius: 12px !important; padding: 20px !important; }
.nl-dash-kort-label { font-size: 12px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .06em !important; color: var(--nl-muted) !important; margin-bottom: 10px !important; }
.nl-dash-stor { font-size: 32px !important; font-weight: 800 !important; color: #56958E !important; line-height: 1.1 !important; }
.nl-dash-lille { font-size: 14px !important; font-weight: 600 !important; color: var(--nl-muted) !important; }
.nl-dash-status { grid-column: 1 !important; }
.nl-dash-status-badge { display: inline-block !important; background: #f0faf9 !important; color: #56958E !important; border: 1.5px solid #56958E !important; border-radius: 100px !important; padding: 6px 14px !important; font-size: 14px !important; font-weight: 700 !important; margin-bottom: 10px !important; }
.nl-dash-status-tekst { font-size: 13px !important; color: var(--nl-muted) !important; margin: 0 !important; line-height: 1.5 !important; }
.nl-dash-sektion { background: #fff !important; border: 1.5px solid var(--nl-border) !important; border-radius: 12px !important; padding: 28px !important; margin-bottom: 20px !important; }
.nl-dash-sektion h3 { font-size: 18px !important; font-weight: 700 !important; margin: 0 0 16px !important; }
.nl-dash-info-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 16px !important; }
@media (max-width: 600px) { .nl-dash-info-grid { grid-template-columns: 1fr !important; } }
.nl-dash-info-felt { background: var(--nl-bg) !important; border-radius: 8px !important; padding: 14px !important; }
.nl-dash-info-label { font-size: 12px !important; font-weight: 700 !important; text-transform: uppercase !important; letter-spacing: .06em !important; color: var(--nl-muted) !important; margin-bottom: 6px !important; }
.nl-dash-info-val { font-size: 14px !important; color: var(--nl-text) !important; line-height: 1.5 !important; }
.nl-dash-danger { border-color: #fecaca !important; background: #fff5f5 !important; }
.nl-dash-danger h3 { color: #dc2626 !important; }
.nl-btn-danger { background: #dc2626 !important; color: #fff !important; width: 100% !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; padding: 13px 24px !important; border-radius: var(--nl-radius) !important; font-size: 16px !important; font-weight: 700 !important; cursor: pointer !important; border: none !important; font-family: inherit !important; }
.nl-btn-danger:hover { background: #b91c1c !important; }
#panel-budget .vl-section { height: 520px !important; width: 100% !important; max-width: 100% !important; overflow: hidden !important; box-sizing: border-box !important; }