/* Kaizen Shop Profit Leak Diagnostic. Scoped under .ksd so the bundle is safe
   to embed on any HubSpot page. Matches the other tools: Nunito Sans + the
   fully-dark surface treatment (Onyx canvas, #0f0f0f cards, light text, Foundry
   Tan accents, Forged Ember CTAs). Score-band + category-bar colors are applied
   inline by module.js (from the data); this file is structure + dark surfaces. */

.ksd {
  --kz-onyx: #0F0F0F;
  --kz-tan: #DDCCA5;
  --kz-ember: #D66A4A;
  --kz-graphite: #3A3838;
  --kz-font: 'Nunito Sans', 'Helvetica Neue', Arial, sans-serif;
  --s-bg: #000;
  --s-card: #0f0f0f;
  --s-panel: #161616;
  --s-line: #242424;
  --s-line-2: #2f2f2f;
  --s-text: #f1efea;
  --s-muted: #d8d3c5;
  --s-faint: #9a9384;
  --s-tan-soft: rgba(221,204,165,0.18);
}
.ksd, .ksd * { box-sizing: border-box; margin: 0; padding: 0; }
.ksd { font-family: var(--kz-font); background: var(--s-bg); color: var(--s-text); line-height: 1.5; font-weight: 300; -webkit-font-smoothing: antialiased; }
.ksd h1, .ksd h2, .ksd h3, .ksd h4 { font-family: var(--kz-font); line-height: 1.15; color: var(--s-text); }
.ksd-app { max-width: 960px; margin: 0 auto; padding: 28px 20px 64px; }

/* Header + screens */
.ksd-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--s-line); margin-bottom: 24px; }
.ksd-eyebrow { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--kz-tan); font-weight: 700; }
.ksd-tag { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--s-faint); font-weight: 700; }
.ksd-screen { display: none; }
.ksd-screen.active { display: block; animation: ksd-fade .3s ease-out; }
@keyframes ksd-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* Buttons */
.ksd-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 24px; border-radius: 8px; font-size: 15px; font-weight: 700; cursor: pointer; border: 1px solid transparent; font-family: var(--kz-font); transition: all .15s; text-decoration: none; }
.ksd-btn:focus { outline: none; box-shadow: 0 0 0 3px var(--s-tan-soft); }
.ksd-btn-primary { background: var(--kz-ember); color: #fff; border-color: var(--kz-ember); }
.ksd-btn-primary:hover:not(:disabled) { background: #c25b3d; border-color: #c25b3d; }
.ksd-btn-primary:disabled { opacity: .6; cursor: default; }
.ksd-btn-secondary { background: transparent; color: var(--s-text); border-color: var(--s-line-2); }
.ksd-btn-secondary:hover { border-color: var(--kz-tan); color: var(--kz-tan); }
.ksd-btn-lg { padding: 15px 30px; font-size: 17px; }
.ksd-btn-full { width: 100%; }

/* Cards */
.ksd-card { background: var(--s-card); border: 1px solid var(--s-line); border-radius: 14px; padding: 28px 24px; }

/* Landing hero */
.ksd-hero-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 40px; align-items: center; padding: 16px 0 8px; }
.ksd-chip { display: inline-block; background: var(--s-panel); border: 1px solid var(--s-line-2); color: var(--kz-tan); font-size: 13px; font-weight: 700; letter-spacing: 0.04em; padding: 5px 14px; border-radius: 100px; margin-bottom: 18px; }
.ksd-h1 { font-size: clamp(30px,4vw,46px); font-weight: 800; letter-spacing: 0.005em; line-height: 1.08; margin-bottom: 16px; }
.ksd-h1 .tan { color: var(--kz-tan); }
.ksd-lede { font-size: 17px; color: var(--s-muted); line-height: 1.6; margin-bottom: 24px; max-width: 56ch; }
.ksd-cta-sub { margin-top: 14px; font-size: 13px; color: var(--s-faint); }
.ksd-vps { display: grid; gap: 14px; }
.ksd-vp { display: flex; gap: 14px; padding: 16px 18px; background: var(--s-card); border: 1px solid var(--s-line); border-radius: 12px; }
.ksd-vp-icon { flex-shrink: 0; width: 38px; height: 38px; border-radius: 9px; background: var(--s-panel); border: 1px solid var(--s-line-2); display: flex; align-items: center; justify-content: center; color: var(--kz-tan); }
.ksd-vp h3 { font-size: 15px; font-weight: 700; }
.ksd-vp p { font-size: 13px; color: var(--s-faint); margin-top: 3px; font-weight: 300; }
.ksd-trust { margin-top: 32px; padding: 16px; background: var(--s-panel); border: 1px solid var(--s-line); border-radius: 10px; text-align: center; font-size: 13px; color: var(--s-muted); }
.ksd-trust strong { color: var(--kz-tan); font-weight: 700; }

/* Progress */
.ksd-progress-meta { display: flex; justify-content: space-between; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--s-faint); font-weight: 700; margin-bottom: 8px; }
.ksd-progress { height: 6px; background: var(--s-panel); border: 1px solid var(--s-line); border-radius: 3px; overflow: hidden; margin-bottom: 22px; }
.ksd-progress-fill { height: 100%; background: var(--kz-tan); border-radius: 3px; transition: width .35s ease; }

/* Question */
.ksd-back { display: inline-flex; align-items: center; gap: 4px; background: none; border: 0; color: var(--s-faint); font-weight: 700; font-size: 14px; cursor: pointer; margin-bottom: 14px; font-family: var(--kz-font); }
.ksd-back:hover { color: var(--kz-tan); }
.ksd-q-prompt { font-size: clamp(20px,2.6vw,26px); font-weight: 800; margin-bottom: 8px; }
.ksd-help-btn { display: inline-flex; align-items: center; gap: 5px; background: none; border: 0; color: var(--s-faint); font-weight: 700; font-size: 13px; cursor: pointer; font-family: var(--kz-font); }
.ksd-help-btn:hover { color: var(--kz-tan); }
.ksd-help-text { margin-top: 8px; font-size: 13px; color: var(--s-muted); background: var(--s-panel); border: 1px solid var(--s-line-2); border-left: 3px solid var(--kz-tan); border-radius: 8px; padding: 10px 12px; }
.ksd-q-spacer { height: 20px; }
.ksd-answers { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; }
.ksd-answer { width: 100%; text-align: left; padding: 14px 16px; border: 1px solid var(--s-line-2); border-radius: 10px; background: var(--s-panel); color: var(--s-text); font-size: 15px; font-weight: 400; cursor: pointer; font-family: var(--kz-font); transition: all .15s; }
.ksd-answer:hover { border-color: var(--kz-tan); background: #1c1c1c; }
/* Selected state fills with Foundry Tan + dark text for unmistakable contrast. */
.ksd-answer.selected, .ksd-answer.selected:hover { border-color: var(--kz-tan); background: var(--kz-tan); color: var(--kz-onyx); font-weight: 700; box-shadow: none; }
.ksd-next-wrap { display: flex; justify-content: flex-end; margin-top: 18px; }

/* Centered screens (preview / lead) */
.ksd-center { max-width: 560px; margin: 0 auto; text-align: center; padding-top: 8px; }
.ksd-center h1 { font-size: 28px; font-weight: 800; margin-bottom: 6px; }
.ksd-center .sub { color: var(--s-muted); margin-bottom: 24px; }
.ksd-score-circle { width: 132px; height: 132px; border-radius: 50%; border: 4px solid var(--kz-tan); display: flex; flex-direction: column; align-items: center; justify-content: center; margin: 0 auto 18px; }
.ksd-score-num { font-size: 42px; font-weight: 800; line-height: 1; }
.ksd-score-of { font-size: 13px; color: var(--s-faint); margin-top: 2px; }
.ksd-band-label { font-size: 20px; font-weight: 800; text-align: center; margin-bottom: 10px; }
.ksd-teaser { color: var(--s-muted); margin-bottom: 22px; }
.ksd-blur-wrap { position: relative; }
.ksd-blur { filter: blur(5px); pointer-events: none; user-select: none; display: flex; flex-direction: column; gap: 12px; }
.ksd-lock { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }
.ksd-lock span { background: var(--s-panel); border: 1px solid var(--s-line-2); border-radius: 10px; padding: 10px 18px; font-size: 13px; font-weight: 700; color: var(--s-text); display: inline-flex; gap: 8px; align-items: center; }
.ksd-mini-bar { display: flex; align-items: center; gap: 10px; }
.ksd-mini-bar .track { flex: 1; height: 12px; background: var(--s-line); border-radius: 100px; overflow: hidden; }
.ksd-mini-bar .fill { height: 100%; background: var(--kz-tan); border-radius: 100px; }

/* Lead form */
.ksd-form { text-align: left; display: grid; gap: 14px; margin-top: 8px; }
.ksd-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ksd-label { display: block; font-size: 13px; font-weight: 700; color: var(--s-text); margin-bottom: 5px; }
.ksd-input { width: 100%; padding: 12px 14px; font-size: 15px; border: 1px solid var(--s-line-2); border-radius: 8px; background: var(--s-panel); color: var(--s-text); font-family: var(--kz-font); font-weight: 400; }
.ksd-input::placeholder { color: var(--s-faint); }
.ksd-input:focus { outline: none; border-color: var(--kz-tan); box-shadow: 0 0 0 3px var(--s-tan-soft); }
.ksd-error { color: var(--kz-ember); font-size: 13px; font-weight: 700; }
.ksd-fine { font-size: 12px; color: var(--s-faint); text-align: center; }

/* Dashboard */
.ksd-greeting h1 { font-size: clamp(24px,3vw,32px); font-weight: 800; }
.ksd-greeting p { color: var(--s-muted); margin-top: 4px; }
.ksd-dash-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; margin-top: 20px; }
.ksd-stack { display: flex; flex-direction: column; gap: 20px; }
.ksd-scorecard { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.ksd-scorecard .ksd-score-circle { width: 110px; height: 110px; margin: 0; }
.ksd-scorecard .ksd-score-num { font-size: 34px; }
.ksd-band-desc { color: var(--s-muted); font-size: 15px; margin-top: 6px; }
.ksd-section-h { font-size: 17px; font-weight: 800; margin-bottom: 18px; }
.ksd-scorebar { margin-bottom: 16px; }
.ksd-scorebar:last-child { margin-bottom: 0; }
.ksd-scorebar-top { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 6px; }
.ksd-scorebar-top .lbl { font-weight: 700; }
.ksd-scorebar-top .val { color: var(--s-muted); font-weight: 700; }
.ksd-scorebar-track { height: 12px; background: var(--s-line); border-radius: 100px; overflow: hidden; }
.ksd-scorebar-fill { height: 100%; border-radius: 100px; transition: width .7s ease; }
.ksd-profile .ksd-section-h { margin-bottom: 14px; }
.ksd-profile-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
.ksd-profile-chip { background: var(--s-panel); border: 1px solid var(--s-line); border-radius: 10px; padding: 10px 12px; }
.ksd-profile-chip .k { display: block; font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--s-muted); font-weight: 700; }
.ksd-profile-chip .v { display: block; font-size: 15px; font-weight: 800; margin-top: 2px; }
.ksd-rec { display: flex; gap: 14px; margin-bottom: 16px; }
.ksd-rec:last-child { margin-bottom: 0; }
.ksd-rec-num { flex-shrink: 0; width: 30px; height: 30px; border-radius: 50%; background: var(--s-panel); border: 1px solid var(--kz-tan); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 14px; color: var(--kz-tan); }
.ksd-rec h4 { font-size: 15px; font-weight: 700; }
.ksd-rec p { font-size: 14px; color: var(--s-muted); margin-top: 3px; font-weight: 300; }
.ksd-leak { display: flex; gap: 10px; padding: 12px 14px; background: rgba(214,106,74,0.10); border: 1px solid rgba(214,106,74,0.45); border-radius: 10px; margin-bottom: 10px; }
.ksd-leak:last-child { margin-bottom: 0; }
.ksd-leak-icon { color: var(--kz-ember); flex-shrink: 0; font-size: 16px; line-height: 1.3; }
.ksd-leak p.t { font-size: 14px; font-weight: 700; }
.ksd-leak p.d { font-size: 12px; color: var(--s-muted); margin-top: 3px; font-weight: 300; }
.ksd-leak-ok { display: flex; gap: 10px; padding: 12px 14px; background: rgba(134,175,199,0.12); border: 1px solid rgba(134,175,199,0.45); border-radius: 10px; font-size: 14px; font-weight: 700; }
.ksd-legend { display: flex; flex-direction: column; gap: 8px; }
.ksd-legend-row { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 700; color: var(--s-muted); }
.ksd-legend-dot { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.ksd-cta-card { background: var(--s-panel); border: 1px solid var(--s-line); border-radius: 14px; padding: 22px; }
.ksd-cta-card .icon { color: var(--kz-tan); font-size: 24px; }
.ksd-cta-card h3 { color: var(--kz-tan); font-size: 18px; font-weight: 800; margin: 10px 0 8px; }
.ksd-cta-card p { font-size: 14px; color: var(--s-muted); margin-bottom: 16px; font-weight: 300; }
.ksd-foot { margin-top: 32px; padding-top: 18px; border-top: 1px solid var(--s-line); text-align: center; }
.ksd-foot-brand { font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--s-faint); font-weight: 700; }
.ksd-foot-copy { font-size: 12px; color: var(--s-faint); margin-top: 4px; font-weight: 300; }

/* Mobile */
@media (max-width: 720px) {
  .ksd-hero-grid { grid-template-columns: 1fr; gap: 28px; }
  .ksd-dash-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .ksd-app { padding: 18px 14px 56px; }
  .ksd-card { padding: 22px 18px; }
  .ksd-form-grid { grid-template-columns: 1fr; }
}

/* Print (results dashboard → PDF) */
@media print {
  .ksd { background: #fff !important; color: #111 !important; font-weight: 400; }
  .ksd-app { padding: 0; max-width: 100%; }
  .ksd h1, .ksd h2, .ksd h3, .ksd h4, .ksd-greeting h1, .ksd-section-h { color: #111 !important; }
  .ksd-card, .ksd-cta-card { background: #fff !important; border: 1px solid #ddd !important; }
  .ksd-header, .ksd-back, .ksd-btn, .ksd-cta-card, .ksd-foot { display: none !important; }
  .ksd-band-desc, .ksd-rec p, .ksd-leak p.d, .ksd-scorebar-top .val { color: #444 !important; }
  .ksd-scorebar-track { background: #e6e6e6 !important; }
  .ksd-leak { background: #fdf2ee !important; border-color: #e0a48f !important; }
  .ksd-rec p, .ksd-rec h4 { color: #111 !important; }
}

