:root {
  --primary: #0f3d5c;
  --accent: #c89b3c;
  --ink: #1f2937;
  --muted: #6b7280;
  --line: #e5e7eb;
  --bg: #f6f7f9;
}
* { box-sizing: border-box; }
body {
  margin: 0; background: var(--bg); color: var(--ink);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; line-height: 1.6;
}
.topbar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 24px; background: var(--primary); color: #fff;
}
.brand { font-weight: 800; letter-spacing: .3px; font-size: 1.15rem; }
.topbar-right { display: flex; align-items: center; gap: 14px; }
#ui-lang { background: rgba(255,255,255,.12); color: #fff; border: 1px solid rgba(255,255,255,.3); border-radius: 8px; padding: 5px 8px; font: inherit; font-size: .85rem; cursor: pointer; }
#ui-lang option { color: #1f2937; }
.mode { font-size: .75rem; opacity: .85; }
main { max-width: 820px; margin: 0 auto; padding: 28px 20px 80px; }
.panel { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 28px; margin-bottom: 22px; }
.hidden { display: none; }
.center { text-align: center; }
h1 { font-size: 1.9rem; line-height: 1.2; margin: 0 0 12px; color: var(--primary); }
h2 { color: var(--primary); }
.lead { font-size: 1.05rem; color: #374151; }
.fineprint { color: var(--muted); font-size: .85rem; margin-top: 14px; }

.btn { border: 0; border-radius: 10px; padding: 13px 24px; font-size: 1rem; font-weight: 700; cursor: pointer; }
.btn.primary { background: var(--accent); color: #1a1300; }
.btn.primary:hover { filter: brightness(.96); }
.btn.ghost { background: #fff; border: 1px solid var(--line); color: var(--primary); }

.progress { height: 6px; background: var(--line); border-radius: 999px; margin-bottom: 22px; overflow: hidden; }
.progress-bar { height: 100%; width: 0; background: var(--accent); transition: width .2s; }

.q { margin-bottom: 20px; }
.q label.qlabel { display: block; font-weight: 600; margin-bottom: 6px; }
.q .help { color: var(--muted); font-size: .85rem; margin: 0 0 8px; }
.q input[type=text], .q textarea, .q select {
  width: 100%; padding: 11px 13px; border: 1px solid var(--line); border-radius: 10px; font: inherit; background: #fff;
}
.q textarea { min-height: 84px; resize: vertical; }
.req { color: #b91c1c; }
.branch-note { background: #f0f7ff; border: 1px solid #cfe3ff; border-radius: 10px; padding: 8px 12px; font-size: .85rem; color: #1e40af; margin-bottom: 14px; }

.tone-options { display: flex; gap: 10px; flex-wrap: wrap; }
.tone-opt { flex: 1 1 140px; border: 2px solid var(--line); border-radius: 12px; padding: 14px; cursor: pointer; text-align: center; }
.tone-opt.active { border-color: var(--accent); background: #fff8ec; }

.uploads { border: 1px dashed var(--line); border-radius: 12px; padding: 16px; margin: 10px 0 20px; }
.uploads legend { font-weight: 600; padding: 0 6px; }
.filelabel { display: block; cursor: pointer; }
.filelist { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; }
.filelist .thumb { width: 64px; height: 64px; object-fit: cover; border-radius: 8px; border: 1px solid var(--line); }
.filelist .doc { font-size: .75rem; padding: 6px 10px; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; }

.actions { display: flex; gap: 12px; }

.spinner { width: 44px; height: 44px; border: 4px solid var(--line); border-top-color: var(--accent); border-radius: 50%; margin: 0 auto 16px; animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Results */
.result-block { border: 1px solid var(--line); border-radius: 14px; padding: 20px; margin-bottom: 18px; }
.result-block h3 { margin-top: 0; color: var(--primary); }
.badge-row { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
.tag { background: var(--primary); color: #fff; padding: 4px 12px; border-radius: 999px; font-size: .8rem; }
.tag.alt { background: var(--accent); color: #1a1300; }
.market { border-left: 4px solid var(--accent); padding: 8px 14px; margin: 12px 0; background: #fafafa; border-radius: 0 10px 10px 0; }
.market .country { font-weight: 700; color: var(--primary); }
.signal { font-size: .8rem; color: var(--muted); }
.checklist h4 { margin: 14px 0 4px; }
.checklist ul { margin: 4px 0 12px; padding-left: 20px; }
.gap { color: #92400e; }
table.cal { width: 100%; border-collapse: collapse; font-size: .9rem; }
table.cal th, table.cal td { border: 1px solid var(--line); padding: 8px 10px; text-align: left; vertical-align: top; }
table.cal th { background: var(--bg); }
.bios dt { font-weight: 700; margin-top: 10px; }
.bios dd { margin: 2px 0 0; color: #374151; }
.handles { display: flex; gap: 8px; flex-wrap: wrap; margin: 6px 0 14px; }
.handles .h { background: #f0f7ff; border: 1px solid #cfe3ff; border-radius: 999px; padding: 4px 12px; font-size: .85rem; }
.site-cta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
iframe.preview { width: 100%; height: 520px; border: 1px solid var(--line); border-radius: 12px; margin-top: 12px; background: #fff; }
.err { color: #b91c1c; }

.download-bar { display: flex; gap: 12px; flex-wrap: wrap; margin: 0 0 18px; }

/* Optional Google Business pre-fill */
.gimport { border: 1px dashed var(--accent); border-radius: 12px; padding: 14px 16px; margin: 0 0 20px; background: #fff8ec; }
.gimport legend { font-weight: 700; color: var(--primary); padding: 0 6px; }
.gimport .help { margin: 0 0 10px; }
.gimport-row { display: flex; gap: 8px; flex-wrap: wrap; }
.gimport-row input { flex: 1; min-width: 220px; padding: 11px 13px; border: 1px solid var(--line); border-radius: 10px; font: inherit; }
.gimport-msg { font-size: .9rem; margin-top: 8px; }
.gimport-msg.ok { color: #166534; }
.gimport-msg.err { color: #b91c1c; }

.host-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 14px; }
.host-card { border: 1px solid var(--line); border-radius: 12px; padding: 16px; }
.host-card.managed { border: 2px solid var(--accent); background: #fff8ec; }
.host-card h4 { margin: 8px 0 6px; color: var(--primary); }
.host-card p { font-size: .9rem; color: #374151; margin: 0 0 12px; }
.host-tag { display: inline-block; font-size: .75rem; font-weight: 700; padding: 3px 10px; border-radius: 999px; background: var(--primary); color: #fff; }
.host-card.managed .host-tag { background: var(--accent); color: #1a1300; }
.host-url { font-size: .8rem; color: var(--muted); margin-top: 8px; word-break: break-all; }
@media (max-width: 640px) { .host-options { grid-template-columns: 1fr; } }

/* Print / Save as PDF — show only the strategy content */
@media print {
  .topbar, .no-print, #intro, #questionnaire, #loading { display: none !important; }
  body { background: #fff; }
  main { max-width: none; padding: 0; }
  .panel { border: 0; padding: 0; margin: 0; }
  .result-block { border: 1px solid #ddd; break-inside: avoid; page-break-inside: avoid; }
  h3 { break-after: avoid; }
}
