/* ============================================================
   KimaraCode — Site styles (Quiet Protocol)
   Layers on tokens.css. Token references only.
   ============================================================ */

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

.kc-container {
  width: 100%;
  max-width: 940px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 600px) { .kc-container { padding: 0 20px; } }

/* ============================================================
   Header
   ============================================================ */
.kc-header {
  position: sticky;
  top: 0;
  z-index: 40;
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  transition: box-shadow 220ms var(--ease-quiet);
}
.kc-header.is-scrolled {
  box-shadow: 0 6px 16px -10px rgba(17, 17, 17, 0.14);
}
[data-theme="dark"] .kc-header.is-scrolled {
  box-shadow: 0 6px 16px -10px rgba(0, 0, 0, 0.5);
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .kc-header.is-scrolled {
    box-shadow: 0 6px 16px -10px rgba(0, 0, 0, 0.5);
  }
}
.kc-header-row {
  max-width: 940px;
  margin: 0 auto;
  padding: 16px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
@media (max-width: 600px) { .kc-header-row { padding: 14px 20px; } }

.kc-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  color: var(--fg1);
  text-decoration: none;
}
.kc-brand:hover { text-decoration: none; }
.kc-brand-mark { width: 26px; height: 26px; display: block; }
.kc-brand-word {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: var(--tracking-tight);
}
.kc-brand-word .kimara { color: var(--fg1); }
.kc-brand-word .code { color: var(--fg3); }

.kc-nav { display: flex; align-items: center; gap: 28px; }
.kc-nav-link {
  font-size: 14px;
  color: var(--fg2);
  background: none;
  border: 0;
  padding: 4px 0;
  cursor: pointer;
  font-family: var(--font-sans);
  text-decoration: none;
  transition: color var(--dur-2) var(--ease-quiet);
}
.kc-nav-link:hover { color: var(--fg1); text-decoration: none; }
.kc-nav-link.active {
  color: var(--fg1);
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 1px;
  text-decoration-color: var(--fg1);
}

.kc-icon-btn {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--rule);
  border-radius: 0;
  cursor: pointer;
  color: var(--fg2);
  transition: border-color var(--dur-2) var(--ease-quiet), color var(--dur-2) var(--ease-quiet), opacity var(--dur-2) var(--ease-quiet);
}
.kc-icon-btn:hover { border-color: var(--fg3); color: var(--fg1); }
.kc-icon-btn:active { opacity: 0.7; }
.kc-icon-btn svg { width: 17px; height: 17px; }
.kc-icon-btn .sun { display: none; }
[data-theme="dark"] .kc-icon-btn .sun { display: block; }
[data-theme="dark"] .kc-icon-btn .moon { display: none; }

@media (max-width: 540px) {
  .kc-nav { gap: 18px; }
  .kc-nav-link { font-size: 13px; }
}

/* ============================================================
   Buttons / inline links
   ============================================================ */
.kc-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 20px;
  font: 500 14px/1 var(--font-sans);
  cursor: pointer;
  border-radius: 0;
  border: 1px solid transparent;
  text-decoration: none;
  transition: opacity var(--dur-2) var(--ease-quiet), transform var(--dur-2) var(--ease-quiet), border-color var(--dur-2) var(--ease-quiet);
}
.kc-btn:hover { text-decoration: none; }
.kc-btn-primary { background: var(--kc-kimara); color: #fff; }
.kc-btn-ghost { background: transparent; border-color: var(--fg3); color: var(--fg1); }
.kc-btn:hover { opacity: 0.82; transform: translateY(-1px); }
.kc-btn:active { opacity: 0.7; transform: translateY(0); }

.kc-mono-link {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg2);
  text-decoration: none;
  background: none;
  border: 0;
  padding: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color var(--dur-2) var(--ease-quiet), gap var(--dur-2) var(--ease-quiet);
}
.kc-mono-link:hover { color: var(--fg1); gap: 9px; text-decoration: none; }

/* ============================================================
   Hero
   ============================================================ */
.kc-hero { border-bottom: 1px solid var(--rule); }

.kc-hero-centered { padding: 104px 0 80px; text-align: center; }
.kc-hero-display {
  font-family: var(--kc-wordmark-font, var(--font-mono));
  font-weight: 500;
  font-size: clamp(3rem, 11vw, 6.875rem);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  margin: 0 0 36px;
  display: inline-flex;
  white-space: nowrap;
}
.kc-hero-display .kimara { color: var(--kc-kimara); }
.kc-hero-display .code { color: var(--kc-code); }

/* Moving caret — a real <span> element JS inserts into the wordmark.
   Absolutely positioned, so the wordmark's own width is never affected
   (no layout shift). JS sets transform: translateX(<px>) to follow the
   right edge of the just-typed character. */
.kc-hero-display { position: relative; }
.kc-typed-caret {
  position: absolute;
  top: 0.05em;
  left: 0;
  width: 2px;
  height: 0.9em;
  background: var(--fg2);
  animation: kc-caret-blink 900ms steps(1) infinite;
  pointer-events: none;
  transition: transform 60ms linear;
}
.kc-typed-caret.is-done { display: none; }
@keyframes kc-caret-blink { 50% { opacity: 0; } }
@media (prefers-reduced-motion: reduce) {
  .kc-typed-caret { display: none; }
}

.kc-hero-tag {
  font-size: clamp(1.4rem, 3.4vw, 1.75rem);
  color: var(--fg1);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 16px;
}
.kc-hero-sub {
  font-size: 16px;
  color: var(--fg2);
  max-width: 540px;
  margin: 0 auto;
  line-height: var(--leading-body);
}
.kc-hero-centered .kc-hero-sub { margin: 0 auto; }

.kc-hero-masthead { padding: 72px 0 56px; }
.kc-hero-masthead .kc-hero-display {
  font-size: clamp(2.6rem, 8vw, 5.25rem);
  margin: 0 0 28px;
}
.kc-hero-masthead .kc-hero-tag { margin: 0 0 14px; }
.kc-hero-masthead .kc-hero-sub { margin: 0; max-width: 560px; }
.kc-masthead-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 28px;
  margin-top: 36px;
  padding-top: 22px;
  border-top: 1px solid var(--rule);
}
.kc-masthead-meta-item { display: flex; flex-direction: column; gap: 4px; }
.kc-masthead-meta-item .k { font-family: var(--font-mono); font-size: 11px; color: var(--fg3); text-transform: uppercase; letter-spacing: var(--tracking-wide); }
.kc-masthead-meta-item .v { font-size: 14px; color: var(--fg1); }

/* Inline link inside the Practice value — subtle, underline on hover only */
.kc-meta-link {
  color: inherit;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  transition: text-decoration-color var(--dur-2) var(--ease-quiet), color var(--dur-2) var(--ease-quiet);
}
.kc-meta-link:hover { text-decoration-color: var(--underline-color); }

/* Whole-row link (Posture → /about/) */
a.kc-masthead-meta-item {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
a.kc-masthead-meta-item .v {
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  transition: text-decoration-color var(--dur-2) var(--ease-quiet);
}
a.kc-masthead-meta-item:hover .v { text-decoration-color: var(--underline-color); }

@media (prefers-reduced-motion: no-preference) {
  .is-mounted .kc-fade-up { animation: kc-fade-up var(--dur-3) var(--ease-enter) both; }
  .is-mounted .kc-fade-up.d1 { animation-delay: 80ms; }
  .is-mounted .kc-fade-up.d2 { animation-delay: 160ms; }
  .is-mounted .kc-fade-up.d3 { animation-delay: 240ms; }
}
@keyframes kc-fade-up { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* Layout-stable typed reveal — wordmark renders at full width from frame 0;
   each character is wrapped in <span class="kc-typed-ch"> and revealed via
   opacity, so the container never reflows. No wiggle. */
.kc-typed-ch { display: inline-block; opacity: 1; transition: opacity 60ms ease-out; }
.kc-hero-display.kc-typed-pending .kc-typed-ch { opacity: 0; }
.kc-hero-display.kc-typed-pending .kc-typed-ch.is-on { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  .kc-typed-ch { opacity: 1 !important; transition: none; }
}

/* ============================================================
   Section scaffold
   ============================================================ */
.kc-section { padding: 72px 0; border-bottom: 1px solid var(--rule); }
.kc-section:last-of-type { border-bottom: 0; }
.kc-section-head { margin-bottom: 36px; }
.kc-section-head h2 { margin: 6px 0 0; }
.kc-section-head .kc-section-aside { font-size: 14px; color: var(--fg2); max-width: 460px; margin: 12px 0 0; line-height: var(--leading-body); }

/* ============================================================
   Work index — ledger layout
   ============================================================ */
.kc-ledger { border-top: 1px solid var(--rule); }
.kc-ledger-row {
  display: grid;
  grid-template-columns: 44px 1.4fr 1fr auto;
  align-items: baseline;
  gap: 20px;
  width: 100%;
  text-align: left;
  background: none;
  border: 0;
  border-bottom: 1px solid var(--rule);
  padding: 22px 8px 22px 4px;
  cursor: pointer;
  color: var(--fg1);
  font-family: var(--font-sans);
  text-decoration: none;
  transition: background-color var(--dur-2) var(--ease-quiet), padding-left var(--dur-2) var(--ease-quiet);
}
.kc-ledger-row:hover { background: var(--bg-elev); padding-left: 12px; text-decoration: none; }
.kc-ledger-row[data-disabled="true"] { cursor: default; }
.kc-ledger-row[data-disabled="true"]:hover { background: none; padding-left: 4px; }
.kc-ledger-num { font-family: var(--font-mono); font-size: 13px; color: var(--fg3); }
.kc-ledger-main .name { font-size: 19px; font-weight: 600; letter-spacing: var(--tracking-flat); margin: 0 0 4px; color: var(--fg1); }
.kc-ledger-main .desc { font-size: 13px; color: var(--fg2); margin: 0; line-height: 1.5; }
.kc-ledger-cat { font-family: var(--font-mono); font-size: 12px; color: var(--fg2); }
.kc-ledger-cat .year { color: var(--fg3); }
.kc-ledger-status { display: flex; align-items: center; gap: 8px; justify-content: flex-end; white-space: nowrap; }

.kc-status-dot { width: 6px; height: 6px; border-radius: var(--r-pill); background: var(--fg3); }
.kc-status-dot.live { background: var(--intent-positive); }
.kc-status-dot.dev { background: var(--intent-warning); }
.kc-status-dot.planned { background: var(--kc-code); }
.kc-status-pill {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg2);
}

@media (max-width: 680px) {
  .kc-ledger-row { grid-template-columns: 30px 1fr; gap: 4px 14px; padding: 18px 4px; }
  .kc-ledger-cat, .kc-ledger-status { grid-column: 2; justify-content: flex-start; margin-top: 6px; }
  .kc-ledger-status { justify-content: flex-start; }
}

/* ============================================================
   Detail page
   ============================================================ */
.kc-detail { padding: 48px 0 80px; }
.kc-back { margin-bottom: 40px; }
.kc-detail-head { max-width: 640px; }
.kc-detail-head .eyebrow { display: block; margin-bottom: 16px; }
.kc-detail-head h1 { font-size: var(--t-3xl); margin: 0 0 18px; }
.kc-detail-head .lead { font-size: var(--t-md); color: var(--fg2); margin: 0; }

.kc-detail-section { margin: 0 0 40px; }
.kc-detail-section h3 { margin: 0 0 14px; }
.kc-detail-section p { font-size: 15px; color: var(--fg1); line-height: var(--leading-body); margin: 0 0 14px; max-width: 580px; }

/* ============================================================
   About
   ============================================================ */
.kc-about { padding: 56px 0 80px; }
.kc-about-content { max-width: 680px; margin: 0 auto; }
.kc-about .eyebrow { display: block; margin-bottom: 18px; }
.kc-about h1 { font-size: var(--t-2xl); margin: 0 0 28px; max-width: 600px; }
.kc-about p { font-size: 16px; color: var(--fg1); line-height: var(--leading-body); margin: 0 0 20px; }
.kc-about p.muted { color: var(--fg2); }
.kc-about-domains {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  margin: 36px 0;
  overflow: hidden;
}
.kc-about-domain { background: var(--bg); padding: 22px 20px; }
.kc-about-domain .k { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--fg3); margin: 0 0 8px; }
.kc-about-domain .v { font-size: 14px; color: var(--fg1); line-height: 1.45; }
@media (max-width: 600px) { .kc-about-domains { grid-template-columns: 1fr; } }

.kc-imprint { margin-top: 40px; padding-top: 28px; border-top: 1px solid var(--rule); }

/* ============================================================
   Footer
   ============================================================ */
.kc-footer { margin-top: auto; padding: 56px 0 44px; border-top: 1px solid var(--rule); }
.kc-footer-row {
  max-width: 940px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
@media (max-width: 600px) { .kc-footer-row { padding: 0 20px; } }
.kc-footer-brand { display: flex; align-items: center; gap: 10px; }
.kc-footer-brand .kc-brand-mark { width: 22px; height: 22px; }
.kc-footer-brand .label { font-family: var(--font-mono); font-size: 13px; color: var(--fg2); transition: color var(--dur-2) var(--ease-quiet); }
a.kc-footer-brand { text-decoration: none; color: inherit; transition: opacity var(--dur-2) var(--ease-quiet); }
a.kc-footer-brand:hover { text-decoration: none; }
a.kc-footer-brand:hover .label { color: var(--fg1); }
.kc-footer-links { display: flex; gap: 22px; }
.kc-footer-links a {
  font-size: 13px; color: var(--fg3); text-decoration: none; padding: 0;
  font-family: var(--font-sans);
  transition: color var(--dur-2) var(--ease-quiet);
}
.kc-footer-links a:hover { color: var(--fg1); }
.kc-footer-meta { font-family: var(--font-mono); font-size: 12px; color: var(--fg3); }
