/* Cruzley Stables — palette-driven, printable UI */
:root{
  --bg:#F3EFE6;           /* Cream/Bone */
  --card:#ffffff;
  --ink:#1B1B1B;          /* Deep Charcoal */
  --muted:rgba(27,27,27,.72);
  --line:rgba(27,27,27,.14);

  --forest:#13261C;       /* Forest Green */
  --forest2:#0f1f17;
  --accent:#B89A4C;       /* Muted Brass */

  --good:#0a7a4f;
  --warn:#8a5a00;
  --bad:#b00020;
}

*{box-sizing:border-box}
html,body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: #ffffff;
  color:var(--ink);
}

.wrap{max-width:1200px;margin:0 auto;padding:20px}
.grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:start;
}
@media (max-width: 980px){
  .grid{grid-template-columns:1fr}
}

.topbar{
  position:sticky; top:0; z-index:10;
  backdrop-filter: blur(8px);
  background: #ffffff;
  border-bottom:1px solid var(--line);
}

.brand{display:flex;gap:14px;align-items:center}
.logoPlain{
  display:flex;
  align-items:center;
}
.logoPlain img{
  height:84px;
  width:auto;
  display:block;
}
@media (max-width: 640px){
  .logoPlain img{ height:64px; }
}

h1{margin:0;font-size:18px;letter-spacing:.2px;color:var(--forest)}

.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px}

.card{
  background: var(--card);
  border:1px solid rgba(19,38,28,.18);
  border-radius:18px;
  padding:18px;
  box-shadow: 0 14px 30px rgba(27,27,27,.10);
}
.card h2{margin:0 0 10px;font-size:16px}
.card h3{margin:14px 0 10px;font-size:14px;color:var(--ink)}
hr{border:0;border-top:1px solid var(--line);margin:14px 0}

.field{margin:10px 0}
label{display:block;font-size:12px;color:var(--muted);margin:0 0 6px}
input,select,textarea{
  width:100%;
  border-radius:12px;
  border:1px solid var(--line);
  background: #fff;
  color:var(--ink);
  padding:10px 12px;
  outline:none;
}
input:focus,select:focus,textarea:focus{
  border-color: rgba(184,154,76,.65);
  box-shadow: 0 0 0 3px rgba(184,154,76,.14)
}
textarea{resize:vertical}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media (max-width: 640px){ .grid2,.grid3{grid-template-columns:1fr} }

.hint{margin:6px 0 0;color:var(--muted);font-size:11px;line-height:1.35}
.muted{color:var(--muted)}

.btn{
  border:1px solid rgba(184,154,76,.85);
  background: rgba(184,154,76,.22);
  color: var(--forest);
  padding:9px 12px;
  border-radius:12px;
  font-size:12px;
  cursor:pointer;
}
.btn:hover{background: rgba(184,154,76,.30)}
.btn.ghost{
  border:1px solid rgba(19,38,28,.22);
  background: rgba(19,38,28,.04);
  color: var(--forest);
}
.btn.ghost:hover{background: rgba(19,38,28,.07)}

.range{padding:0;height:34px}
.rangeRow{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.rangeVal{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:44px;height:26px;
  border-radius:10px;border:1px solid var(--line);
  background: rgba(243,239,230,.06);
  font-size:12px;
}

.diagramWrap{display:grid;grid-template-columns: 1.2fr .8fr;gap:12px;align-items:start}
@media (max-width: 980px){ .diagramWrap{grid-template-columns:1fr} }
.diagram{
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  background:#fff;
}
.svgFrame{fill:#fff;stroke:rgba(27,27,27,.12);stroke-width:2}
.horseBody{stroke:rgba(184,154,76,.55);stroke-width:2}
.horseLeg{fill:none;stroke:rgba(27,27,27,.65);stroke-width:6;stroke-linecap:round}
.horseTail{fill:none;stroke:rgba(27,27,27,.55);stroke-width:5;stroke-linecap:round}
.svgLabel{fill:rgba(19,38,28,.80);font-size:14px}

.region{fill:rgba(243,239,230,.05);stroke:rgba(184,154,76,.35);stroke-width:2;cursor:pointer}
.region:hover{fill:rgba(184,154,76,.10)}
.region.active{fill:rgba(184,154,76,.14);stroke:rgba(184,154,76,.70)}

.subjective{
  margin-top:8px;padding:12px;
  border:1px dashed rgba(243,239,230,.22);
  border-radius:16px;
  background:rgba(243,239,230,.03)
}

.results{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:12px;
}
@media (max-width: 640px){ .results{grid-template-columns:1fr} }

.kpi{
  padding:12px;border-radius:16px;border:1px solid var(--line);
  background: rgba(243,239,230,.04);
}
.kpiLabel{color:var(--muted);font-size:11px}
.kpiValue{font-size:26px;margin-top:4px;letter-spacing:.2px}
.kpiSmall{font-size:13px;color:var(--muted);margin-left:4px}
.kpiHint{margin-top:4px;color:var(--muted);font-size:11px}

.priceCompare{
  margin-top:12px;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:12px;
}
@media (max-width: 640px){ .priceCompare{grid-template-columns:1fr} }

.priceCard{
  border:1px solid var(--line);
  background: rgba(243,239,230,.04);
  border-radius:16px;
  padding:12px;
}
.priceLabel{color:var(--muted);font-size:11px}
.priceValue{font-size:22px;margin-top:6px}
.priceMeta{color:var(--muted);font-size:11px;margin-top:6px;line-height:1.35}

.callout{
  margin-top:12px;
  border-radius:16px;
  padding:12px;
  border:1px solid rgba(19,38,28,.18);
  background: linear-gradient(135deg, rgba(184,154,76,.14), rgba(19,38,28,.06));
}
.calloutTitle{font-size:12px;color:var(--ink);letter-spacing:.2px}
.calloutBody{margin-top:6px;color:rgba(243,239,230,.92);font-size:13px;line-height:1.45}
.good{color:var(--good)}
.warn{color:var(--warn)}
.bad{color:var(--bad)}

.details{
  margin-top:10px;
  border:1px solid var(--line);
  border-radius:16px;
  padding:10px 12px;
  background: rgba(243,239,230,.03);
}
.details summary{cursor:pointer;color:var(--muted);font-size:12px}
.detailsBody{margin-top:8px;color:rgba(243,239,230,.92);font-size:12px;line-height:1.5}
.detailsBody code{
  background: rgba(19,38,28,.04);
  padding:2px 6px;
  border-radius:8px;
  border:1px solid rgba(19,38,28,.18);
}

.footer{margin-top:10px;color:var(--muted);font-size:11px}

/* Print / Save to PDF */
@media print{
  body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: #ffffff;
  color:var(--ink);
}
  .topbar{position:static;background:#fff !important;border-bottom:1px solid #ddd}
  .top-actions{display:none !important;}
  .modalBackdrop{display:none !important;}
  .card{box-shadow:none !important;border:1px solid #ddd !important;background:#fff !important;}
  input, select, textarea{background:#fff !important;color:#111 !important;border:1px solid #ccc !important;}
  .diagram{background:#fff !important;}
  .kpi, .priceCard, .details, .subjective, .callout{
  margin-top:12px;
  border-radius:16px;
  padding:12px;
  border:1px solid rgba(19,38,28,.18);
  background: linear-gradient(135deg, rgba(184,154,76,.14), rgba(19,38,28,.06));
}
  .wrap{max-width:none;padding:10px}
  .grid{grid-template-columns:1fr}
}


.printNotes{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
}
.printBlock{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  background:#fff;
}
.printTitle{
  font-size:12px;
  color:var(--muted);
  margin-bottom:8px;
}
.printBody{
  white-space: pre-wrap;
  word-break: break-word;
  line-height:1.4;
  font-size:13px;
}

.modalBackdrop{
  position:fixed;
  inset:0;
  background: rgba(27,27,27,.35);
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
  z-index:50;
}
.modalBackdrop.open{ display:flex; }
.modal{
  width:min(980px, 100%);
  max-height: calc(100vh - 36px);
  overflow:auto;
  background:#fff;
  border:1px solid rgba(27,27,27,.18);
  border-radius:18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.18);
  padding:16px;
}
.modalHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.adminGrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  margin-top:10px;
}
@media (max-width: 900px){
  .adminGrid{ grid-template-columns:1fr; }
}
.adminCard{
  border:1px solid var(--line);
  border-radius:16px;
  padding:12px;
  background:#fff;
}

/* Readability fixes */
.card h2, .card h3{ color: var(--forest); }
.kpiLabel, .priceLabel, label, .hint, .kpiHint, .priceMeta, .footer, .details summary, .printTitle{
  color: var(--muted);
}
.detailsBody{ color: rgba(27,27,27,.86); }
.calloutBody{ color: rgba(27,27,27,.90); }
.calloutTitle{ color: var(--forest); }
.rangeVal{ color: rgba(27,27,27,.82); }
input::placeholder, textarea::placeholder{ color: rgba(27,27,27,.45); }
code{ color: rgba(27,27,27,.88); }


.adminHelp{
  border:1px dashed rgba(19,38,28,.22);
  border-radius:16px;
  padding:12px;
  background: rgba(19,38,28,.03);
  margin-top:10px;
}
.adminHelp ul{ margin:8px 0 0 18px; padding:0; color: rgba(27,27,27,.88); font-size:13px; line-height:1.45; }
.adminHelp li{ margin:6px 0; }
.helpMono{
  margin-top:6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:12px;
  background: rgba(184,154,76,.12);
  border:1px solid rgba(184,154,76,.28);
  color: rgba(19,38,28,.92);
  padding:6px 8px;
  border-radius:12px;
}
