@import url("/styles-preview.css");

:root {
  --green: #008060;
  --green-ink: #063f2a;
  --mint: #d8f3dc;
  --lime: #c7f36b;
  --blue: #4b7bec;
  --ink: #121614;
  --muted: #5f6b63;
  --line: #d9dfd8;
  --bg: #f5f7f2;
  --surface: #ffffff;
  --wash: #eef4ed;
  --dark: #24453a;
  --dark-soft: #315b4d;
  --radius: 8px;
  font-family: Aptos, "SF Pro Text", "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
}
* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { min-width: 320px; }
body { margin: 0; min-height: 100vh; background: var(--bg); color: var(--ink); overflow-x: hidden; }
a { color: inherit; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
button:disabled { cursor: not-allowed; opacity: .48; }
button:focus-visible, a:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; }
h1, h2, h3, p { margin: 0; letter-spacing: 0; }
h1 { font-size: clamp(38px, 5vw, 68px); line-height: .95; }
h2 { font-size: 20px; line-height: 1.15; }
h3 { font-size: 16px; }
p { color: var(--muted); line-height: 1.55; }
.page-header h1 { font-size: clamp(30px, 3vw, 46px); line-height: 1; }
.eyebrow { color: var(--green); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; margin-bottom: 8px; }
.button { min-height: 40px; border: 1px solid var(--line); background: var(--surface); color: var(--ink); border-radius: var(--radius); padding: 9px 14px; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; gap: 8px; white-space: nowrap; }
.button.primary { background: var(--green); color: white; border-color: var(--green); }
.button.secondary { background: var(--surface); color: var(--ink); }
.button.danger { background: #fff7f4; color: #a2351d; border-color: #efc9bd; }
.icon { width: 16px; height: 16px; flex: 0 0 16px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.brand-icon { width: 20px; height: 20px; flex-basis: 20px; stroke-width: 2.2; }
.button .icon, .text-link .icon { width: 16px; height: 16px; }
.icon-link { display: inline-flex; align-items: center; gap: 7px; }
.text-link { color: var(--green); font-weight: 700; text-decoration: none; }
.wordmark { display: flex; align-items: center; gap: 10px; text-decoration: none; font-weight: 800; }
.wordmark .brand-mark { width: 38px; height: 38px; border-radius: 10px; color: white; display: grid; place-items: center; overflow: hidden; background: white; }
.wordmark .brand-mark img { width: 100%; height: 100%; object-fit: cover; display: block; }
.onboarding-shell { min-height: 100vh; background: var(--bg); }
.onboarding-top { min-height: 72px; display: flex; align-items: center; justify-content: space-between; padding: 20px 28px; color: var(--ink); background: var(--surface); border-bottom: 1px solid var(--line); }
.top-links a { color: var(--green); text-decoration: none; font-weight: 700; }
.onboarding-grid { max-width: 1280px; margin: 0 auto; padding: 30px 24px 54px; display: grid; grid-template-columns: minmax(300px, .72fr) minmax(0, 1.28fr); gap: 28px; align-items: start; }
.onboarding-rail { color: var(--ink); padding: 34px 8px; position: sticky; top: 18px; }
.onboarding-rail p { color: var(--muted); max-width: 48ch; margin-top: 14px; }
.onboarding-main { display: grid; gap: 16px; }
.hero-panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); min-height: 620px; padding: 28px; display: grid; align-content: space-between; gap: 28px; }
.hero-copy h2 { font-size: clamp(34px, 5vw, 68px); max-width: 11ch; line-height: .96; margin-bottom: 14px; }
.setup-cards { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.setup-cards a { min-height: 178px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--wash); padding: 18px; text-decoration: none; display: grid; align-content: space-between; }
.setup-cards strong { font-size: 18px; }
.setup-cards span { color: var(--muted); line-height: 1.45; }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 248px minmax(0, 1fr); transition: grid-template-columns 180ms ease; }
.app-shell.sidebar-collapsed { grid-template-columns: 86px minmax(0, 1fr); }
.sidebar { background: var(--dark); color: white; padding: 18px 14px; display: grid; grid-template-rows: auto 1fr auto; gap: 20px; position: sticky; top: 0; min-height: 100vh; }
.sidebar-top { display: grid; gap: 14px; }
.sidebar-bottom { display: grid; grid-template-columns: minmax(0, 1fr) 40px; gap: 8px; align-items: center; }
.onboarding-retry-card { grid-column: 1 / -1; min-height: 76px; padding: 12px; border: 1px solid rgba(255,255,255,.14); border-radius: var(--radius); color: #e7f3ed; text-decoration: none; background: rgba(255,255,255,.06); display: flex; align-items: center; gap: 12px; }
.onboarding-retry-card:hover { color: white; background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.22); }
.onboarding-retry-card strong { display: block; font-size: 14px; line-height: 1.2; }
.onboarding-retry-card small { display: block; margin-top: 3px; color: rgba(231,243,237,.72); line-height: 1.35; }
.sidebar-toggle { min-height: 40px; border: 0; border-radius: var(--radius); background: transparent; color: #e0eee8; font-weight: 800; }
.sidebar-toggle:hover { color: white; background: rgba(255,255,255,.06); }
.icon-button { width: 40px; padding: 0; display: inline-grid; place-items: center; }
.sidebar-toggle .icon { width: 18px; height: 18px; }
.expand-label { display: none; }
.side-nav { display: grid; align-content: start; gap: 6px; }
.side-nav a { color: #e0eee8; text-decoration: none; min-height: 42px; display: flex; align-items: center; gap: 12px; padding: 0 12px; border-radius: var(--radius); }
.side-nav a.active { background: var(--green); color: white; }
.nav-icon { width: 22px; height: 22px; flex: 0 0 22px; display: grid; place-items: center; color: currentColor; }
.nav-icon .icon { width: 18px; height: 18px; }
.account-link { border: 0; border-radius: var(--radius); padding: 9px 10px; min-height: 42px; color: #e0eee8; text-decoration: none; background: transparent; font-weight: 700; display: flex; align-items: center; gap: 12px; }
.account-link:hover { color: white; background: rgba(255,255,255,.06); }
.sidebar-collapsed .wordmark strong, .sidebar-collapsed .nav-label, .sidebar-collapsed .collapse-label, .sidebar-collapsed .onboarding-retry-copy { display: none; }
.sidebar-collapsed .expand-label { display: inline; }
.sidebar-collapsed .wordmark, .sidebar-collapsed .side-nav a, .sidebar-collapsed .account-link { justify-content: center; padding-left: 0; padding-right: 0; }
.sidebar-collapsed .onboarding-retry-card { min-height: 42px; padding: 0; justify-content: center; background: transparent; border-color: transparent; }
.sidebar-collapsed .onboarding-retry-card:hover { background: rgba(255,255,255,.06); border-color: transparent; }
.sidebar-collapsed .sidebar-toggle { padding: 0; }
.sidebar-collapsed .sidebar-bottom { grid-template-columns: 1fr; }
.main { padding: 26px; max-width: 1480px; width: 100%; margin: 0 auto; display: grid; gap: 18px; align-content: start; }
.page-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; padding-bottom: 18px; border-bottom: 1px solid var(--line); }
.page-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; justify-content: flex-end; }
.metrics { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; }
.metrics div { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; min-width: 0; }
.metrics span { color: var(--muted); font-size: 12px; font-weight: 700; display: block; }
.metrics strong { display: block; font-size: 32px; margin-top: 4px; }
.metrics small { color: var(--muted); }
.panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; min-width: 0; }
.panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 14px; }
.panel-action { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.driver-upload-actions { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; margin-top: 8px; }
.workspace-grid { display: grid; grid-template-columns: 330px minmax(0, 1fr); gap: 14px; }
.split { display: grid; grid-template-columns: minmax(0, .84fr) minmax(0, 1.16fr); gap: 14px; }
.draft-layout { display: grid; grid-template-columns: minmax(320px, .38fr) minmax(0, .62fr); gap: 14px; align-items: start; }
.controls, .form-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.table-controls { margin-bottom: 24px; }
.form-grid.single { grid-template-columns: 1fr; }
label { color: var(--muted); display: grid; gap: 6px; font-size: 12px; font-weight: 800; }
input, select, textarea { width: 100%; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); color: var(--ink); min-height: 40px; padding: 9px 10px; }
textarea { resize: vertical; line-height: 1.45; }
input[readonly], textarea[readonly] { background: var(--wash); color: var(--muted); }
.table-wrap { overflow-x: auto; width: 100%; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); }
table { width: 100%; min-width: 860px; border-collapse: collapse; table-layout: fixed; }
.policy-table { min-width: 980px; }
.policy-table th:nth-child(1), .policy-table td:nth-child(1) { width: 54%; }
.policy-table th:nth-child(2), .policy-table td:nth-child(2) { width: 180px; }
.policy-table th:nth-child(3), .policy-table td:nth-child(3) { width: 200px; }
.driver-table, .case-table { min-width: 1080px; }
.workbook-table { min-width: 980px; }
th, td { text-align: left; border-bottom: 1px solid var(--line); padding: 13px 12px; vertical-align: top; overflow-wrap: anywhere; }
th { color: var(--muted); font-size: 12px; font-weight: 800; background: #fbfcf8; }
td { font-size: 14px; }
.cell-input { border: 0; min-height: 32px; padding: 0; background: transparent; border-radius: 0; }
.policy-event-input { display: block; min-height: 52px; line-height: 1.35; resize: vertical; white-space: normal; overflow-wrap: anywhere; }
.cell-input.points { max-width: 80px; }
td[contenteditable="true"]:focus { outline: 2px solid var(--green); outline-offset: -2px; }
.pill { display: inline-flex; padding: 4px 8px; border-radius: 999px; background: var(--mint); color: var(--green-ink); font-size: 12px; font-weight: 800; }
.file-list { display: grid; gap: 10px; }
.file-row { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.file-row button, .file-button { width: 100%; min-height: 56px; border: 0; background: white; display: flex; justify-content: space-between; gap: 12px; align-items: center; padding: 12px 14px; text-align: left; text-decoration: none; }
.file-row strong { display: inline-flex; align-items: center; gap: 9px; min-width: 0; }
.file-row span { color: var(--muted); }
.file-preview { display: none; border-top: 1px solid var(--line); background: var(--wash); padding: 14px; gap: 10px; }
.file-preview.open { display: grid; }
pre { margin: 0; white-space: pre-wrap; font: 12px/1.5 "SF Mono", Menlo, monospace; color: var(--muted); }
.upload-zone { min-height: 170px; border: 1px dashed var(--line); border-radius: var(--radius); display: grid; place-items: center; align-content: center; text-align: center; gap: 10px; background: var(--wash); padding: 22px; }
.upload-zone span { color: var(--muted); max-width: 58ch; }
.upload-message { display: grid; gap: 8px; justify-items: center; }
.driver-upload-zone { justify-items: center; }
.upload-split { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.duration-control { display: grid; grid-template-columns: minmax(140px, 240px) auto; gap: 10px; align-items: end; }
.duration-control span { min-height: 40px; display: inline-flex; align-items: center; color: var(--muted); font-weight: 800; }
.sheet table { min-width: 940px; }
.import-preview[hidden] { display: none; }
.empty-state { margin-top: 10px; padding: 16px; border: 1px dashed var(--line); border-radius: var(--radius); background: var(--wash); color: var(--muted); text-align: center; }
.empty-state[hidden] { display: none; }
.check-list, .review-list { display: grid; gap: 10px; }
.check-list label, .review-list label { grid-template-columns: 20px 1fr; align-items: center; color: var(--ink); font-size: 14px; font-weight: 600; }
.check-list input, .review-list input { width: 18px; min-height: 18px; }
.template-edit-actions { margin-top: 14px; display: flex; gap: 10px; flex-wrap: wrap; }
.template-edit-actions[hidden], .template-empty[hidden] { display: none; }
.template-empty { margin-top: 14px; padding: 18px; border: 1px dashed var(--line); border-radius: var(--radius); background: var(--wash); color: var(--muted); font-weight: 700; }
.detail-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.detail-list div { border: 1px solid var(--line); border-radius: var(--radius); background: var(--wash); padding: 14px; }
.detail-list span { display: block; color: var(--muted); font-size: 12px; font-weight: 800; margin-bottom: 6px; }
.inline-actions { margin-top: 12px; display: flex; gap: 8px; flex-wrap: wrap; }
.generation-actions { margin-top: 28px; display: flex; gap: 10px; flex-wrap: wrap; }
.draft-preview[hidden] { display: none; }
.toast { position: fixed; left: 50%; bottom: 22px; transform: translate(-50%, 18px); opacity: 0; pointer-events: none; background: var(--dark); color: white; padding: 12px 16px; border-radius: 999px; box-shadow: 0 18px 42px rgba(0,0,0,.22); transition: opacity 160ms ease, transform 160ms ease; z-index: 10; }
.toast.show { opacity: 1; transform: translate(-50%, 0); }
@media (max-width: 1060px) {
  .app-shell { grid-template-columns: 1fr; }
  .app-shell.sidebar-collapsed { grid-template-columns: 1fr; }
  .sidebar { position: static; min-height: auto; grid-template-rows: auto; }
  .sidebar-top { grid-template-columns: 1fr auto; align-items: center; }
  .side-nav { grid-auto-flow: column; overflow-x: auto; display: grid; grid-auto-columns: max-content; }
  .workspace-grid, .split, .draft-layout, .onboarding-grid { grid-template-columns: 1fr; }
  .onboarding-rail { position: static; }
  .setup-cards, .recipe-grid, .doc-structure, .upload-split, .detail-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 680px) {
  .main, .onboarding-grid { padding: 16px; }
  .onboarding-top { padding: 16px; }
  .page-header { display: grid; }
  .page-actions { justify-content: start; }
  .metrics, .setup-cards, .recipe-grid, .doc-structure, .controls, .form-grid, .duration-control, .upload-split, .detail-list { grid-template-columns: 1fr; }
  .panel-head { display: grid; }
  .file-row button, .file-button { display: grid; justify-content: stretch; }
  .preview-page { min-height: 420px; padding: 26px; margin: 14px; }
}
