/* ============================================================================
   Keyroost Learn site — layout chrome. Builds on assets/keyroost-theme.css;
   reads only var(--kr-*) tokens so it tracks any palette/theme change.
   ========================================================================== */

.kr-wrap { max-width: 820px; margin: 0 auto; padding: 0 22px; }

/* ---------- top bar ---------- */
.kr-topbar {
  position: sticky; top: 0; z-index: 20;
  background: var(--kr-bar);
  border-bottom: 1px solid var(--kr-line);
}
.kr-topbar-inner {
  display: flex; align-items: center; gap: 16px;
  min-height: 56px; padding-top: 8px; padding-bottom: 8px;
  flex-wrap: wrap;
}
.kr-wordmark {
  display: inline-flex; align-items: center; gap: 9px;
  font-weight: 700; font-size: 1.05rem; color: var(--kr-txt);
  letter-spacing: -0.3px;
}
.kr-wordmark:hover { text-decoration: none; }
.kr-mark {
  display: inline-grid; place-items: center;
  width: 26px; height: 26px; border-radius: 28%;
  background: var(--kr-brand); color: #fff;
  font-weight: 700; font-size: 0.95rem; line-height: 1;
}
.kr-nav {
  display: flex; align-items: center; gap: 4px;
  margin-left: auto; flex-wrap: wrap;
}
.kr-nav a {
  color: var(--kr-txt-2); font-size: 0.875rem; font-weight: 500;
  padding: 6px 10px; border-radius: var(--kr-r-ctrl);
}
.kr-nav a:hover { color: var(--kr-txt); background: var(--kr-raised); text-decoration: none; }
.kr-nav a.active { color: var(--kr-accent); background: var(--kr-accent-soft); }

.kr-theme-toggle {
  display: inline-grid; place-items: center;
  width: 34px; height: 34px; flex: none;
  background: var(--kr-raised); color: var(--kr-txt-2);
  border: 1px solid var(--kr-line); border-radius: var(--kr-r-ctrl);
  font-size: 1rem; cursor: pointer;
}
.kr-theme-toggle:hover { color: var(--kr-txt); border-color: var(--kr-accent-line); }

/* ---------- hero ---------- */
.kr-hero { padding: 56px 0 30px; border-bottom: 1px solid var(--kr-line); }
.kr-hero .kr-label { margin-bottom: 12px; }
.kr-hero h1 { margin: 0 0 14px; }
.kr-hero .q { color: var(--kr-txt-2); font-weight: 400; }
.kr-lede { color: var(--kr-txt-2); font-size: 1.08rem; margin: 0; max-width: 62ch; }
.kr-hero .kr-meta { margin: 26px 0 0; color: var(--kr-txt-3); font-size: 0.95rem; }
.kr-hero .kr-meta a { color: var(--kr-txt-2); }

/* ---------- sections ---------- */
main.kr-wrap { padding-top: 8px; padding-bottom: 8px; }
.kr-section { padding: 36px 0; border-bottom: 1px solid var(--kr-line-soft); }
.kr-section:last-of-type { border-bottom: 0; }
.kr-section > h2 { margin: 0 0 16px; }
.kr-section > h2 .num { font-family: var(--kr-mono); color: var(--kr-txt-3);
  font-size: 0.95rem; font-weight: 600; margin-right: 0.55em; }
p { margin: 0 0 14px; }
.kr-muted { color: var(--kr-txt-2); }
ul, ol { margin: 0 0 14px; padding-left: 1.25em; }
li { margin: 7px 0; }
h3 { margin: 22px 0 8px; }

/* card grid */
.kr-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 14px; }
.kr-card h3 { margin: 0 0 6px; font-size: 1.02rem; }
.kr-card .kr-label { display: block; margin-bottom: 9px; }
.kr-card p { margin: 0; color: var(--kr-txt-2); font-size: 0.95rem; }
a.kr-card { color: inherit; display: block; }
a.kr-card:hover { border-color: var(--kr-accent-line); text-decoration: none; }
a.kr-card .kr-more { color: var(--kr-accent); font-size: 0.85rem; font-weight: 600; }

/* callout variants by edge color */
.kr-callout { margin: 18px 0; }
.kr-callout.tip   { border-left: 3px solid var(--kr-ok);   }
.kr-callout.note  { border-left: 3px solid var(--kr-warn); }
.kr-callout.danger{ border-left: 3px solid var(--kr-err);  }
.kr-callout .kr-callout-title.tip    { color: var(--kr-ok); }
.kr-callout .kr-callout-title.note   { color: var(--kr-warn); }
.kr-callout .kr-callout-title.danger { color: var(--kr-err); }
.kr-callout p:last-child { margin-bottom: 0; }

/* FAQ accordion */
.kr-faq details {
  background: var(--kr-panel); border: 1px solid var(--kr-line);
  border-radius: var(--kr-r-card); margin: 10px 0; padding: 0 18px;
}
.kr-faq details[open] { background: var(--kr-surface); border-color: var(--kr-accent-line); }
.kr-faq summary {
  cursor: pointer; padding: 15px 0; font-weight: 600; list-style: none;
  display: flex; align-items: center; gap: 0.6em;
}
.kr-faq summary::-webkit-details-marker { display: none; }
.kr-faq summary::before {
  content: "+"; font-family: var(--kr-mono); color: var(--kr-accent);
  font-weight: 700; width: 1em; display: inline-block;
}
.kr-faq details[open] summary::before { content: "\2013"; }
.kr-faq .kr-answer { padding: 0 0 16px; color: var(--kr-txt-2); }
.kr-faq .kr-answer p:last-child { margin-bottom: 0; }

/* glossary */
.kr-glossary dl { margin: 0; }
.kr-glossary dt { font-family: var(--kr-mono); color: var(--kr-txt);
  font-size: 0.92rem; font-weight: 600; margin-top: 16px; }
.kr-glossary dd { margin: 4px 0 0; color: var(--kr-txt-2); }

/* resource links */
.kr-res { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 10px; }
.kr-res a {
  background: var(--kr-panel); border: 1px solid var(--kr-line);
  border-radius: var(--kr-r-ctrl); padding: 12px 14px; display: block; color: var(--kr-txt);
}
.kr-res a:hover { border-color: var(--kr-accent-line); text-decoration: none; }
.kr-res .who { display: block; font-family: var(--kr-mono); font-size: 0.78rem; color: var(--kr-txt-3); margin-bottom: 2px; }

/* "what keyroost does here" strip */
.kr-tool {
  display: flex; gap: 12px; align-items: flex-start;
  background: var(--kr-side); border: 1px solid var(--kr-line);
  border-radius: var(--kr-r-card); padding: 15px 17px; margin: 18px 0;
}
.kr-tool .kr-mark { flex: none; margin-top: 2px; }
.kr-tool p { margin: 0; color: var(--kr-txt-2); font-size: 0.95rem; }
.kr-tool strong { color: var(--kr-txt); }

/* prev/next related nav */
.kr-related { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }

/* footer */
.kr-footer { padding: 34px 0 60px; color: var(--kr-txt-3); font-size: 0.9rem;
  border-top: 1px solid var(--kr-line); margin-top: 10px; }
.kr-footer a { color: var(--kr-txt-2); }
.kr-footer p { margin: 0 0 10px; }

@media (max-width: 620px) {
  .kr-nav { width: 100%; margin-left: 0; order: 3; }
  .kr-theme-toggle { margin-left: auto; }
  .kr-hero { padding-top: 38px; }
  h1 { font-size: 1.7rem; }
}
