/* ============================================
   FIRMSPEC — Business Identity Layer
   Design: Light, Warm Neutral, Precise
   Fonts: Hedvig Letters Serif + Hedvig Letters Sans + Geist Mono
   ============================================ */

@font-face {
  font-family: 'Hedvig Letters Sans';
  src: url('fonts/HedvigLettersSans-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Hedvig Letters Serif';
  src: url('fonts/HedvigLettersSerif-Regular-VariableFont_opsz.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Geist Mono';
  src: url('fonts/GeistMono-Variable.ttf') format('truetype');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

:root {
  --app-nav-height: 59px;
  --color-bg: #F4F3F2;
  --color-surface: #FFFFFF;
  --color-surface-raised: #F0EFEE;
  --color-surface-hover: #E9E8E7;
  --color-border: #D6D4D2;
  --color-border-subtle: #E2E0DE;
  --color-text: #1A1917;
  --color-text-secondary: #5C5A56;
  --color-text-muted: #8F8C87;
  --color-text-faint: #B5B2AD;
  --color-accent: #2754B5;
  --color-accent-light: #3466D4;
  --color-accent-dim: rgba(39, 84, 181, 0.08);
  --color-accent-glow: rgba(39, 84, 181, 0.18);
  --color-accent-text: #FFFFFF;
  --color-success: #2F8A4F;
  --color-success-dim: rgba(47, 138, 79, 0.08);
  --color-warning: #B57B27;
  --color-warning-dim: rgba(181, 123, 39, 0.08);
  --color-error: #B53427;
  --color-error-dim: rgba(181, 52, 39, 0.08);
  --font-body: 'Hedvig Letters Sans', 'Segoe UI', sans-serif;
  --font-headline: 'Hedvig Letters Serif', Georgia, serif;
  --font-mono: 'Geist Mono', 'SFMono-Regular', Consolas, monospace;
  --font-headline-weight: 400;
  --font-headline-tracking: 0em;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 16px;
  --shadow-xs: 0 1px 2px rgba(26,25,23,0.04);
  --shadow-sm: 0 1px 4px rgba(26,25,23,0.06), 0 1px 2px rgba(26,25,23,0.04);
  --shadow-md: 0 4px 12px rgba(26,25,23,0.08), 0 1px 3px rgba(26,25,23,0.04);
  --shadow-lg: 0 8px 24px rgba(26,25,23,0.10), 0 2px 6px rgba(26,25,23,0.04);
  --transition-fast: 150ms ease;
  --transition-base: 250ms ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { font-family: var(--font-body); background: var(--color-bg); color: var(--color-text); line-height: 1.56; min-height: 100vh; letter-spacing: -0.011em; font-synthesis: none; }
a { color: var(--color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font-family: var(--font-body); cursor: pointer; border: none; background: none; color: inherit; }
button:disabled { cursor: not-allowed; }
input, select, textarea { font-family: var(--font-body); }

.app { display: flex; flex-direction: column; min-height: 100vh; }

.nav { position: sticky; top: 0; z-index: 50; display: flex; align-items: center; justify-content: space-between; padding: 14px 40px; background: rgba(255,255,255,.88); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--color-border-subtle); }
.nav__logo { display: flex; align-items: center; gap: 10px; text-decoration: none; color: var(--color-text); }
.nav__mark { width: 30px; height: 30px; background: var(--color-accent); border-radius: 6px; display: flex; align-items: center; justify-content: center; font: 700 13px/1 var(--font-body); color: #fff; }
.nav__name { font: var(--font-headline-weight) 15px/1.1 var(--font-headline); letter-spacing: var(--font-headline-tracking); }
.nav__links { display: flex; align-items: center; gap: 24px; }
.nav__link { font-size: 13.5px; color: var(--color-text-secondary); text-decoration: none; transition: color var(--transition-fast); font-weight: 450; }
.nav__link:hover { color: var(--color-accent); text-decoration: none; }
.nav__link--active { color: var(--color-accent); }
.nav__cta { padding: 8px 20px; background: var(--color-accent); color: #fff; border-radius: 8px; font-size: 13.5px; font-weight: 500; text-decoration: none; transition: all var(--transition-fast); box-shadow: 0 1px 4px rgba(39,84,181,.2); }
.nav__cta:hover { background: var(--color-accent-light); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(39,84,181,.25); text-decoration: none; }
.nav__burger { display: none; font-size: 22px; color: var(--color-text-secondary); background: none; border: none; cursor: pointer; padding: 4px 8px; }
.app__header { display: flex; align-items: center; justify-content: flex-end; padding: 1rem 0.5rem 1rem 0.5rem; position: static; }
.app__header-actions { display: flex; align-items: center; justify-content: flex-end; gap: 10px; flex-wrap: wrap; width: 100%; }
.app__main { flex: 1; display: flex; flex-direction: column; }
.footer { padding: 32px 40px 96px; border-top: 1px solid var(--color-border-subtle); background: var(--color-surface); display: flex; justify-content: space-between; align-items: center; gap: 16px; font-size: 12.5px; color: var(--color-text-muted); letter-spacing: -0.006em; }
.footer a { color: var(--color-text-muted); text-decoration: none; }
.footer a:hover { color: var(--color-accent); text-decoration: none; }
.footer__links { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

.stepper { position: sticky; top: var(--app-nav-height); z-index: 40; display: flex; align-items: center; gap: 2px; padding: 16px 32px; background: rgba(255,255,255,.94); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--color-border-subtle); overflow-x: auto; box-shadow: 0 1px 0 rgba(26,25,23,0.03); }
.stepper__step { display: flex; align-items: center; gap: 8px; padding: 7px 12px; border-radius: var(--radius-sm); border: none; background: transparent; font-size: 12.5px; font-weight: 450; color: var(--color-text-muted); white-space: nowrap; transition: all var(--transition-fast); cursor: pointer; letter-spacing: -0.006em; flex-shrink: 0; }
.stepper__step:hover { color: var(--color-text-secondary); background: var(--color-surface-raised); }
.stepper__step:focus-visible { outline: 2px solid var(--color-accent-glow); outline-offset: 2px; }
.stepper__step--active { color: var(--color-accent); background: var(--color-accent-dim); font-weight: 550; }
.stepper__step--completed { color: var(--color-text-secondary); }
.stepper__step-number { width: 22px; height: 22px; border-radius: 50%; border: 1.5px solid currentColor; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 500; font-family: var(--font-body); flex-shrink: 0; }
.stepper__step--completed .stepper__step-number { border-color: var(--color-success); background: var(--color-success); color: #fff; }
.stepper__step--completed .stepper__step-number::after { content: '✓'; font-size: 11px; }
.stepper__step--completed .stepper__step-num-text { display: none; }
.stepper__divider { width: 16px; height: 1px; background: var(--color-border); flex-shrink: 0; }

.content { flex: 1; max-width: 720px; width: 100%; margin: 0 auto; padding: 44px 32px 96px; }
.content--wide { max-width: 1060px; }

.section-header { margin-bottom: 36px; }
.section-header__label { font-size: 11.5px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-accent); font-family: var(--font-body); margin-bottom: 10px; }
.section-header__title { font-family: var(--font-headline); font-size: 26px; font-weight: var(--font-headline-weight); letter-spacing: var(--font-headline-tracking); line-height: 1.18; margin-bottom: 10px; color: var(--color-text); max-width: 20ch; }
.section-header__description { font-size: 14.5px; color: var(--color-text-secondary); max-width: 58ch; line-height: 1.6; }

.form-group { margin-bottom: 26px; }
.form-group--jump-target { scroll-margin-top: 156px; }
.form-group__label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 7px; color: var(--color-text); letter-spacing: -0.006em; }
.form-group__hint { font-size: 12px; color: var(--color-text-muted); margin-top: 6px; line-height: 1.42; max-width: 62ch; }
.form-group__hint--spaced { margin-top: 10px; }
.form-group__hint--warning { color: var(--color-warning); }
.form-group__hint--error { color: var(--color-error); }
.form-group__meta { margin-top: 4px; display: flex; justify-content: flex-end; }
.form-group__char-count { font-size: 12px; color: var(--color-text-muted); }
.form-group__label-optional { color: var(--color-text-faint); margin-left: 4px; }
.section-divider { border: none; border-top: 1px solid var(--color-border-subtle); margin: 28px 0 24px; }

.form-input { width: 100%; padding: 10px 14px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text); font-size: 14px; line-height: 1.5; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); }
.form-input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-dim); }
.form-input::placeholder { color: var(--color-text-faint); }
.form-input--mono { font-family: var(--font-mono); font-size: 13px; }
select.form-input { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238F8C87'%3E%3Cpath d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; }
textarea.form-input { min-height: 100px; resize: vertical; }
.form-row { display: grid; gap: 14px; }
.form-row--2 { grid-template-columns: 1fr 1fr; }
.form-row--3 { grid-template-columns: 1fr 1fr 1fr; }

.form-check { display: flex; align-items: center; gap: 10px; cursor: pointer; padding: 6px 0; }
.form-check input[type="checkbox"] { width: 17px; height: 17px; accent-color: var(--color-accent); cursor: pointer; }
.form-check__label { font-size: 14px; }

.industry-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 12px; margin-top: 32px; }
.industry-grid--compact { margin-top: 10px; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
.industry-grid--compact .industry-card {
  width: 100%;
  min-height: 76px;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  padding: 14px 14px;
  text-align: left;
}
.industry-grid--compact .industry-card__icon {
  font-size: 22px;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.industry-grid--compact .industry-card__label {
  font-size: 13px;
  line-height: 1.28;
  max-width: none;
  margin: 0;
  overflow-wrap: anywhere;
  hyphens: auto;
}
.industry-card { width: 100%; padding: 28px 20px; background: var(--color-surface); border: 1.5px solid var(--color-border); border-radius: var(--radius-lg); cursor: pointer; transition: all var(--transition-fast); text-align: center; box-shadow: var(--shadow-xs); appearance: none; }
.industry-card:hover { border-color: var(--color-accent); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.industry-card:focus-visible { outline: 2px solid var(--color-accent-glow); outline-offset: 2px; }
.industry-card--selected { border-color: var(--color-accent); background: var(--color-accent-dim); box-shadow: 0 0 0 3px var(--color-accent-glow); }
.industry-card__icon { font-size: 34px; margin-bottom: 14px; display: block; }
.industry-card__label { font-family: var(--font-body); font-size: 14px; font-weight: 500; line-height: 1.28; color: var(--color-text); max-width: 18ch; margin: 0 auto; letter-spacing: -0.006em; }

.service-list { display: flex; flex-direction: column; gap: 8px; }
.service-item { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); transition: border-color var(--transition-fast); box-shadow: var(--shadow-xs); }
.service-item:hover { border-color: var(--color-accent); }
.service-item__check { margin-top: 2px; flex-shrink: 0; }
.service-item__check input { width: 17px; height: 17px; accent-color: var(--color-accent); cursor: pointer; }
.service-item__content { flex: 1; min-width: 0; }
.service-item__name { font-size: 14px; margin-bottom: 2px; }
.service-item__desc { font-size: 13px; color: var(--color-text-secondary); }
.service-item__url { margin-top: 8px; }
.service-item__url input { font-size: 12px; padding: 6px 10px; background: var(--color-surface-raised); }
.topic-suggestions { display: flex; flex-wrap: wrap; gap: 8px; }
.topic-suggestion--active { color: var(--color-accent); border-color: var(--color-accent); background: var(--color-accent-dim); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 22px; font-size: 13.5px; font-weight: 500; letter-spacing: -0.006em; border-radius: var(--radius-md); transition: all var(--transition-fast); white-space: nowrap; }
.btn--primary { background: var(--color-accent); color: var(--color-accent-text); box-shadow: var(--shadow-sm); }
.btn--primary:hover { background: var(--color-accent-light); box-shadow: var(--shadow-md); transform: translateY(-1px); }
.btn--secondary { background: var(--color-surface); border: 1px solid var(--color-border); color: var(--color-text); box-shadow: var(--shadow-xs); }
.btn--secondary:hover { background: var(--color-surface-raised); border-color: var(--color-text-muted); }
.btn--ghost { color: var(--color-text-secondary); padding: 8px 14px; font-size: 12.5px; font-weight: 450; line-height: 1.2; border-radius: 8px; }
.btn--ghost:hover { color: var(--color-text); background: var(--color-surface-raised); }
.btn--sm { padding: 7px 14px; font-size: 12px; }
.btn--danger { color: var(--color-error); }
.btn:disabled,
.btn--disabled { opacity: 0.3; }

.nav-bar { position: fixed; bottom: 0; left: 0; right: 0; padding: 14px 32px; background: rgba(255,255,255,0.88); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-top: 1px solid var(--color-border-subtle); display: flex; justify-content: space-between; align-items: center; z-index: 100; box-shadow: 0 -2px 12px rgba(26,25,23,0.04); }
.nav-bar__left, .nav-bar__right { display: flex; gap: 12px; }

.output-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; margin-top: 32px; }
.output-grid--primary { grid-template-columns: minmax(0, 1fr); margin-top: 20px; }
.output-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); box-shadow: var(--shadow-sm); }
.output-card:hover { border-color: var(--color-accent); box-shadow: var(--shadow-md); }
.output-card__header { padding: 18px 20px 14px; display: flex; justify-content: space-between; align-items: flex-start; }
.output-card__title-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.output-card__title { font-family: var(--font-headline); font-size: 15px; font-weight: var(--font-headline-weight); letter-spacing: var(--font-headline-tracking); }
.output-card__label { font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 999px; line-height: 1.3; letter-spacing: 0.2px; }
.output-card__label--recommended { background: var(--color-accent-dim); color: var(--color-accent); }
.output-card__label--inactive { background: var(--color-surface-raised); color: var(--color-text-muted); }
.output-card__label--internal { background: rgba(26, 25, 23, 0.06); color: var(--color-text-secondary); }
.output-card__label--template { background: var(--color-warning-dim); color: var(--color-warning); }
.output-card__subtitle { font-size: 12px; color: var(--color-text-muted); margin-top: 2px; }
.output-card__badge { font-size: 10px; font-weight: 500; padding: 3px 8px; border-radius: 100px; font-family: var(--font-body); letter-spacing: 0.3px; }
.output-card__badge--json { background: var(--color-accent-dim); color: var(--color-accent); }
.output-card__badge--txt { background: var(--color-warning-dim); color: var(--color-warning); }
.output-card__badge--html { background: var(--color-error-dim); color: var(--color-error); }
.output-card__helper-note { padding: 0 20px 10px; font-size: 12px; line-height: 1.5; color: var(--color-text-muted); white-space: pre-line; }
.output-card__readiness { padding: 0 20px 10px; }
.output-card__readiness-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 10px; }
.output-card__readiness-summary { font-size: 12px; line-height: 1.45; color: var(--color-text-secondary); flex: 1; min-width: 220px; }
.output-card__readiness-meta { margin-top: 6px; font-size: 11.5px; line-height: 1.45; color: var(--color-text-muted); }
.output-card__status,
.output-card__autoclean {
  padding: 0 20px 8px;
  font-size: 12px;
  line-height: 1.45;
  text-align: left;
}
.output-card__status--valid { color: var(--color-success); }
.output-card__status--warning { color: var(--color-warning); }
.output-card__status--invalid { color: var(--color-error); }
.output-card__status--valid_non_schema { color: var(--color-warning); }
.output-card__autoclean { color: var(--color-text-muted); }
.output-card__preview { padding: 0 20px; max-height: 200px; overflow: hidden; position: relative; }
.output-card__preview::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 60px; background: linear-gradient(transparent, var(--color-surface)); pointer-events: none; }
.output-card__preview pre { font-family: var(--font-mono); font-size: 11px; line-height: 1.65; color: var(--color-text-secondary); white-space: pre-wrap; word-break: break-all; background: var(--color-surface-raised); padding: 14px; border-radius: var(--radius-sm); border: 1px solid var(--color-border-subtle); }
.output-card__actions { padding: 12px 20px; display: flex; gap: 8px; border-top: 1px solid var(--color-border-subtle); }
.output-card--disabled { border-style: dashed; }
.output-card--internal { background: var(--color-surface-raised); border-color: var(--color-border-subtle); }
.output-card--internal:hover { border-color: var(--color-border); box-shadow: var(--shadow-sm); }
.output-card--disabled:hover { border-color: var(--color-border); box-shadow: var(--shadow-sm); }
.output-card--disabled .output-card__preview pre { color: var(--color-text-muted); }
.advanced-export {
  margin-top: 14px;
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.advanced-export__summary {
  cursor: pointer;
  padding: 11px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-secondary);
}
.advanced-export__body {
  padding: 0 14px 14px;
}
.advanced-export__cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 12px;
}
.advanced-export__hint {
  margin: 0;
  font-size: 12px;
  line-height: 1.45;
  color: var(--color-text-muted);
  max-width: 75ch;
}
.advanced-export__status {
  padding: 0 20px 8px;
  font-size: 12px;
  color: var(--color-text-muted);
}
.advanced-export__status--ok { color: var(--color-success); }
.advanced-export__status--empty { color: var(--color-text-muted); }
.advanced-export__control {
  padding: 0 20px 10px;
}
.advanced-export__control .form-group__label {
  display: block;
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-bottom: 6px;
}
.advanced-export__actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}
.advanced-export__feedback {
  font-size: 12px;
  color: var(--color-success);
}

.score-display { text-align: center; padding: 32px 20px 40px; margin-bottom: 32px; }
.score-ring { position: relative; width: 160px; height: 160px; margin: 0 auto 28px; }
.score-ring svg { transform: rotate(-90deg); }
.score-ring__value { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.score-ring__number { font-size: 42px; font-family: var(--font-headline); font-weight: var(--font-headline-weight); line-height: 1; color: var(--color-accent); letter-spacing: var(--font-headline-tracking); }
.score-ring__label { font-size: 12px; color: var(--color-text-muted); margin-top: 4px; font-family: var(--font-body); }
.score-breakdown { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 10px; max-width: 680px; margin: 0 auto; }
.score-category { padding: 14px 16px; background: var(--color-surface); border-radius: var(--radius-md); border: 1px solid var(--color-border-subtle); box-shadow: var(--shadow-xs); }
.score-category__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.score-category__name { font-size: 12.5px; font-weight: 500; letter-spacing: -0.006em; }
.score-category__points { font-size: 12px; font-family: var(--font-body); color: var(--color-accent); }
.score-category__bar { height: 4px; background: var(--color-surface-raised); border-radius: 2px; overflow: hidden; }
.score-category__bar-fill { height: 100%; background: var(--color-accent); border-radius: 2px; transition: width 600ms ease; }
.score-ring__progress { transition: stroke-dashoffset 1s ease; }

.toast { position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%) translateY(16px); padding: 10px 20px; background: var(--color-surface); border: 1px solid var(--color-accent); border-radius: var(--radius-md); font-size: 13px; font-weight: 500; color: var(--color-accent); box-shadow: var(--shadow-lg); opacity: 0; pointer-events: none; transition: opacity 250ms ease, transform 250ms ease; z-index: 200; }
.toast--visible { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: auto; }

.faq-item { padding: 16px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: 10px; box-shadow: var(--shadow-xs); }
.faq-item__header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.faq-item__number { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-muted); }
.faq-item__remove { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; padding: 0; border: 1px solid var(--color-border); border-radius: 0.5rem; color: var(--color-text-muted); background: transparent; transition: color var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast); }
.faq-item__remove:hover { color: #b42318; border-color: rgba(180, 35, 24, 0.28); background: rgba(180, 35, 24, 0.08); transform: translateY(-1px); }
.faq-item__remove:focus-visible { outline: 2px solid rgba(180, 35, 24, 0.22); outline-offset: 2px; }
.faq-item__remove svg { width: 14px; height: 14px; fill: currentColor; }
.faq-item__question { margin-bottom: 10px; }
.faq-item__answer textarea { min-height: 70px; }
.faq-item__question-input { font-weight: 600; }

.add-item-btn { width: 100%; padding: 13px; border: 1.5px dashed var(--color-border); border-radius: var(--radius-md); color: var(--color-text-muted); font-size: 12.5px; font-weight: 500; text-align: center; transition: all var(--transition-fast); margin-top: 10px; }
.add-item-btn:hover { border-color: var(--color-accent); color: var(--color-accent); background: var(--color-accent-dim); }

.hours-row { display: grid; grid-template-columns: 100px 1fr 1fr auto; gap: 10px; align-items: center; padding: 7px 0; }
.hours-row__day { font-size: 14px; }
.hours-row input[type="time"] { padding: 8px 10px; font-size: 13px; font-family: var(--font-body); }
.hours-row__toggle { padding: 0; }
.hours-row--header { color: var(--color-text-muted); font-size: 12px; font-weight: 600; }

.service-item__name-input,
.service-item__desc-input {
  border: none;
  padding: 0;
  background: transparent;
}

.service-item__name-input {
  font-weight: 600;
  font-size: 14px;
}

.service-item__desc-input {
  margin-top: 2px;
  font-size: 13px;
  color: var(--color-text-secondary);
}

.section-header--center { text-align: center; }

.section-header--center .section-header__label,
.section-header--center .section-header__title,
.section-header--center .section-header__description {
  margin-left: auto;
  margin-right: auto;
}

.section-header__description--dashboard { max-width: 540px; margin-top: 8px; text-align: center; }

.dashboard-actions { margin-bottom: 32px; display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }
.dashboard-hint { max-width: 720px; margin: -8px auto 28px; text-align: center; font-size: 13px; color: var(--color-text-muted); }
.dashboard-hint__review--primary { margin-top: 10px; }
.dashboard-hint__review--secondary { margin-top: 4px; }
.dashboard-tabs { display: flex; flex-wrap: nowrap; gap: 10px; margin: 0 auto 24px; padding-bottom: 4px; overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; scrollbar-width: none; -ms-overflow-style: none; }
.dashboard-tabs::-webkit-scrollbar { display: none; }
.export-section { margin-top: 24px; }
.export-section + .export-section { margin-top: 34px; padding-top: 18px; border-top: 1px solid var(--color-border-subtle); }
.export-section--expert { margin-top: 18px; }
.advanced-export.export-section--expert { background: var(--color-surface-raised); border-style: dashed; }
.dashboard-tab { flex: 0 0 auto; padding: 11px 16px; border: 1px solid var(--color-border); border-radius: var(--radius-md); background: var(--color-surface); color: var(--color-text-secondary); font-size: 13px; font-weight: 600; letter-spacing: -0.01em; cursor: pointer; transition: all var(--transition-fast); }
.dashboard-tab:hover { border-color: var(--color-accent); color: var(--color-accent); background: var(--color-accent-dim); }
.dashboard-tab:focus-visible { outline: 2px solid var(--color-accent-glow); outline-offset: 2px; }
.dashboard-tab--active { border-color: var(--color-accent); background: var(--color-accent); color: #fff; box-shadow: 0 8px 20px rgba(8, 110, 89, 0.18); }
.dashboard-tabpanel { display: none; min-height: 320px; }
.dashboard-tabpanel--active { display: block; }
.dashboard-exports { margin-top: 8px; }
.dashboard-exports__header { margin-bottom: -8px; }
.dashboard-exports__description { max-width: 620px; margin-top: 8px; text-align: center; }
.dashboard-tool { margin: 0; }
.tool-title { max-width: 26ch; }
.tool-panel { padding: 22px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); }
.tool-actions { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 4px; }
.tool-metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)); gap: 12px; margin-top: 18px; }
.tool-metric { padding: 14px 16px; border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md); background: var(--color-surface-raised); display: flex; flex-direction: column; gap: 4px; }
.tool-metric span { font-size: 28px; font-weight: 620; line-height: 1; letter-spacing: -0.03em; color: var(--color-text); }
.tool-metric small { font-size: 12px; color: var(--color-text-muted); line-height: 1.4; }
.tool-metric--ok span { color: var(--color-success); }
.tool-metric--warning span { color: var(--color-warning); }
.tool-metric--error span { color: var(--color-error); }
.tool-meta { display: flex; flex-wrap: wrap; gap: 8px 14px; margin-top: 16px; font-size: 12px; color: var(--color-text-muted); }
.tool-empty { margin-top: 16px; padding: 18px 20px; border: 1px dashed var(--color-border); border-radius: var(--radius-md); background: var(--color-surface-raised); color: var(--color-text-muted); font-size: 13px; line-height: 1.58; }
.tool-empty--tight { margin-top: 10px; padding: 14px 16px; }
.structure-checklist { display: flex; flex-direction: column; gap: 2px; }
.structure-check { padding: 8px 0; border-bottom: 1px solid var(--color-border-subtle); }
.structure-check:last-child { border-bottom: none; }
.person-list { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.person-item { padding: 16px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); box-shadow: var(--shadow-xs); }
.person-item__header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.tool-chip-group { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.audit-list { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }
.audit-item { padding: 14px 16px; border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md); background: var(--color-surface-raised); }
.audit-item--ok { border-color: rgba(47, 138, 79, 0.22); background: var(--color-success-dim); }
.audit-item--warning { border-color: rgba(181, 123, 39, 0.24); background: var(--color-warning-dim); }
.audit-item--error { border-color: rgba(181, 52, 39, 0.24); background: var(--color-error-dim); }
.audit-item__title { font-size: 13px; font-weight: 600; color: var(--color-text); }
.audit-item__detail { margin-top: 6px; font-size: 12px; line-height: 1.55; color: var(--color-text-secondary); }
.status-pill { display: inline-flex; align-items: center; justify-content: center; padding: 4px 9px; border-radius: 999px; font-size: 11px; font-weight: 600; letter-spacing: -0.01em; white-space: nowrap; }
.status-pill--ok { background: rgba(47, 138, 79, 0.12); color: var(--color-success); }
.status-pill--warning { background: rgba(181, 123, 39, 0.12); color: var(--color-warning); }
.status-pill--muted { background: var(--color-surface-raised); color: var(--color-text-muted); }
.plan-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin-top: 18px; }
.plan-card { padding: 18px; border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md); background: var(--color-surface); box-shadow: var(--shadow-xs); }
.plan-card__title-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.plan-card__title { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; color: var(--color-text); }
.plan-card__detail { font-size: 13px; line-height: 1.58; color: var(--color-text-secondary); }
.plan-card__note { margin-top: 10px; font-size: 12px; line-height: 1.5; color: var(--color-text-muted); }
.plan-list { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.plan-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 12px; border: 1px solid var(--color-border-subtle); border-radius: var(--radius-sm); background: var(--color-surface-raised); }
.plan-row__title { font-size: 13px; font-weight: 600; color: var(--color-text); }
.plan-row__detail { margin-top: 4px; font-size: 12px; line-height: 1.5; color: var(--color-text-muted); word-break: break-word; }
.rollout-list { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.rollout-item { padding: 14px; border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md); background: var(--color-surface-raised); }
.rollout-item__header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.rollout-item__title { font-size: 13px; font-weight: 600; color: var(--color-text); }
.diff-list { display: flex; flex-direction: column; gap: 10px; margin-top: 18px; }
.diff-item { padding: 14px 16px; border: 1px solid var(--color-border-subtle); border-radius: var(--radius-md); background: var(--color-surface-raised); }
.diff-item__scope { margin-bottom: 10px; font-size: 12px; font-weight: 600; color: var(--color-text-secondary); letter-spacing: -0.01em; }
.diff-item__values { display: grid; grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr); gap: 10px; align-items: stretch; }
.diff-item__value { min-height: 56px; padding: 10px 12px; border: 1px solid var(--color-border); border-radius: var(--radius-sm); background: var(--color-surface); font-size: 12px; line-height: 1.52; color: var(--color-text-secondary); }
.diff-item__value span { display: block; margin-bottom: 4px; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-faint); }
.diff-item__arrow { display: flex; align-items: center; justify-content: center; color: var(--color-text-muted); font-size: 12px; }

.hidden { display: none !important; }
.mt-4 { margin-top: 4px; }
.mt-8 { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-32 { margin-top: 32px; }
.mb-24 { margin-bottom: 24px; }
.text-muted { color: var(--color-text-muted); }
.text-secondary { color: var(--color-text-secondary); }
.text-accent { color: var(--color-accent); }
.text-sm { font-size: 13px; }
.text-mono { font-family: var(--font-mono); }
.form-row .btn { width: 100%; }

@media (max-width: 768px) {
  :root { --app-nav-height: 55px; }
  .nav { padding: 12px 20px; }
  .nav__burger { display: block; }
  .nav__links { display: none; position: absolute; top: 100%; left: 0; right: 0; flex-direction: column; background: var(--color-surface); border-bottom: 1px solid var(--color-border-subtle); padding: 16px 20px; gap: 12px; box-shadow: 0 4px 12px rgba(0,0,0,.06); z-index: 49; }
  .nav__links--open { display: flex; }
  .nav__link { display: block; font-size: 15px; padding: 8px 0; }
  .nav__cta { text-align: center; }
  .dashboard-tabpanel { min-height: 0; }
  .footer { padding: 24px 20px 92px; flex-direction: column; text-align: center; }
  .footer__links { justify-content: center; gap: 12px; }
}

/* ── Score diagnostic hints (1.1) ── */
.score-category__hints { margin-top: 8px; text-align: left; }
.score-hint { font-size: 12px; color: var(--color-warning); line-height: 1.55; padding: 2px 0; text-align: left; }

/* ── Stepper completeness (1.2) ── */
.stepper__comp { font-size: 10px; color: var(--color-text-faint); margin-left: 2px; font-family: var(--font-body); }
.stepper__step--active .stepper__comp { color: var(--color-accent); }
.stepper__step--completed .stepper__comp { color: var(--color-success); }

/* ── Output card additions (2.1 + 2.2 + 8.1 + 8.2) ── */
.output-card__warnings { padding: 0 20px 10px; }
.output-card__warning { font-size: 12px; color: var(--color-warning); line-height: 1.6; }
.output-card__preview--expanded::after { display: none !important; }

/* ── JSON syntax highlighting (8.1) ── */
.hl-key { color: var(--color-accent); }
.hl-str { color: var(--color-success); }
.hl-num { color: var(--color-warning); }
.hl-kw { color: var(--color-error); }

/* ── Service drag-and-drop (4.2) ── */
.service-item { display: flex; align-items: flex-start; gap: 10px; padding: 14px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-md); margin-bottom: 8px; box-shadow: var(--shadow-xs); transition: opacity 150ms, border-color 150ms; }
.service-item__drag { cursor: grab; color: var(--color-text-faint); font-size: 16px; user-select: none; padding: 2px 2px 0 0; line-height: 1; }
.service-item__drag:active { cursor: grabbing; }
.service-item__check { padding-top: 2px; }
.service-item__content { flex: 1; min-width: 0; }
.service-item--dragging { opacity: 0.3; }
.service-item--dragover { border-color: var(--color-accent); background: var(--color-accent-dim); }

@media (max-width: 640px) {
  .app__header { padding: 12px 20px 6px; }
  .stepper { padding: 12px 16px; }
  .content { padding: 32px 16px 96px; }
  .form-group--jump-target { scroll-margin-top: 132px; }
  .nav-bar { padding: 12px 16px; }
  .section-header__title { font-size: 24px; padding-left: auto; padding-right: auto;}
  .form-row--2, .form-row--3 { grid-template-columns: 1fr; }
  .industry-grid { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
  .industry-grid--compact { grid-template-columns: 1fr; gap: 8px; }
  .industry-grid--compact .industry-card {
    width: 100%;
    min-height: 0;
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    text-align: left;
  }
  .industry-grid--compact .industry-card__icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }
  .industry-grid--compact .industry-card__label {
    font-size: 14px;
    line-height: 1.35;
  }
  .output-grid { grid-template-columns: 1fr; }
  .advanced-export__cards { grid-template-columns: 1fr; }
  .score-breakdown { grid-template-columns: 1fr; }
  .hours-row { grid-template-columns: 70px 1fr 1fr auto; }
  .tool-panel { padding: 18px; }
  .tool-actions { flex-direction: column; align-items: stretch; }
  .tool-actions .btn { width: 100%; }
  .tool-metrics { grid-template-columns: 1fr 1fr; }
  .plan-grid { grid-template-columns: 1fr; }
  .diff-item__values { grid-template-columns: 1fr; }
  .diff-item__arrow { min-height: 14px; }
}
