/* =============================================================
   ds-components.css
   Requires ds-tokens.css to be loaded first.
   ============================================================= */

/* =============================================================
   TYPOGRAPHY UTILITIES
   ============================================================= */
.t-display {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: var(--t-display);
  letter-spacing: -0.025em;
  line-height: 1.05;
}
.t-display em { font-style: italic; color: var(--coral); font-weight: 500; }

.t-h1 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: var(--t-h1);
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.t-h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: var(--t-h2);
  letter-spacing: -0.015em;
  line-height: 1.2;
}
.t-h3 {
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: var(--t-h3);
  letter-spacing: -0.01em;
  line-height: 1.3;
}
.t-body  { font-family: var(--font-ui); font-size: var(--t-body); line-height: 1.65; }
.t-small { font-family: var(--font-ui); font-size: var(--t-small); line-height: 1.55; color: var(--text-2); }
.t-mono  {
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-3);
  font-weight: 700;
}
.t-serif-italic {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 19px;
  line-height: 1.55;
  color: var(--text-2);
}

/* =============================================================
   LOGO
   ============================================================= */

/* Suppress anchor underline when logo is wrapped in <a> */
a.logo-link { border-bottom: none !important; text-decoration: none !important; }
a.logo-link:hover { border-bottom: none !important; }

.logo {
  display: inline-flex;
  align-items: center;
  gap: var(--logo-gap, 14px);
}

.logo-tile {
  width: var(--tile-size, 56px);
  height: var(--tile-size, 56px);
  border-radius: var(--tile-radius, 13px);
  background: var(--bg-deep);
  position: relative;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.04);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}
.logo-tile .glyphs {
  font-family: var(--font-ui);
  font-weight: 700;
  letter-spacing: -0.06em;
  line-height: 1;
  font-size: calc(var(--tile-size, 56px) * 0.42);
  transform: translateY(calc(var(--tile-size, 56px) * -0.06));
  display: flex;
  align-items: baseline;
}
.logo-tile .g-d { color: var(--coral); }
.logo-tile .g-i { color: #FFFFFF; }
.logo-tile .g-f { color: var(--text-3); }

.logo-tile.with-bar::after {
  content: '';
  position: absolute;
  left: 18%; right: 18%;
  bottom: calc(var(--tile-size, 56px) * 0.20);
  height: calc(var(--tile-size, 56px) * 0.045);
  min-height: 2px;
  border-radius: 2px;
  background: var(--coral);
}

.logo-word {
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: var(--word-size, 28px);
  letter-spacing: -0.03em;
  line-height: 1;
  white-space: nowrap;
}
.logo-word .drop   { color: var(--coral); }
.logo-word .in     { color: var(--text); }
.logo-word .in.on-dark { color: #FFFFFF; }
.logo-word .finops { color: var(--text-3); }

/* Pill lockup */
.logo-pill {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 8px 22px 8px 8px;
  background: var(--bg-deep);
  border-radius: var(--r-pill);
  box-shadow: var(--shadow-2);
}
.logo-pill .logo-tile { width: 36px; height: 36px; border-radius: 9px; box-shadow: none; }
.logo-pill .logo-tile.with-bar::after { left: 16%; right: 16%; bottom: 18%; height: 2px; }
.logo-pill .logo-word { font-size: 18px; }
.logo-pill .logo-word .in { color: #FFFFFF; }

/* Plain wordmark */
.logo-plain { display: inline-flex; }
.logo-plain .logo-word { font-size: 36px; }

/* Banner (decorative hero usage) */
.logo-banner {
  background: var(--bg-deep);
  color: white;
  border-radius: var(--r-2xl);
  padding: 36px 40px;
  display: flex;
  align-items: center;
  gap: 22px;
  box-shadow: var(--shadow-3);
  margin: 0 0 40px;
}
.logo-banner .logo-tile { width: 88px; height: 88px; border-radius: 22px; }
.logo-banner .logo-word { font-size: 40px; }
.logo-banner .logo-word .in { color: #FFFFFF; }

/* =============================================================
   BUTTONS
   ============================================================= */
.btn {
  font-family: var(--font-ui);
  font-weight: 700;
  padding: 11px 20px;
  border-radius: var(--r-md);
  font-size: 14px;
  letter-spacing: 0.005em;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.1s, box-shadow 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
}
.btn:active { transform: scale(0.98); }

.btn-primary   { background: var(--text); color: #fff; }
.btn-primary:hover { background: var(--bg-deep); }

.btn-coral     { background: var(--coral); color: var(--bg-deep); }
.btn-coral:hover { background: #D6694C; }

.btn-secondary { background: transparent; color: var(--coral); border-color: var(--coral); }
.btn-secondary:hover { background: var(--coral-soft); }

.btn-ghost     { background: transparent; color: var(--text-2); border-color: var(--border); }
.btn-ghost:hover { color: var(--text); border-color: var(--text); }

.btn-link {
  background: transparent;
  color: var(--coral);
  padding: 6px 0;
  border-radius: 0;
  border-bottom: 1.5px solid transparent;
  border-left: 0; border-right: 0; border-top: 0;
}
.btn-link:hover { border-bottom-color: var(--coral); }

.btn-sm { padding: 8px 14px; font-size: 13px; }
.btn-lg { padding: 14px 26px; font-size: 16px; }

/* =============================================================
   BADGES
   ============================================================= */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

/* Status */
.badge-coral  { background: var(--coral-soft);  color: var(--coral); border-color: var(--coral-strong); }
.badge-teal   { background: var(--teal-soft);   color: var(--teal);  border-color: rgba(61,90,128,0.30); }
.badge-green  { background: var(--green-soft);  color: var(--green); border-color: rgba(39,174,96,0.30); }
.badge-red    { background: var(--red-soft);    color: var(--red);   border-color: rgba(231,76,60,0.30); }
.badge-grey   { background: rgba(140,142,151,0.10); color: var(--text-2); border-color: rgba(140,142,151,0.30); }

/* Cloud provider — fixed brand colors, never theme-driven */
.badge-aws   { background: #FF9900; color: #232F3E; border-color: transparent; }
.badge-gcp   { background: #4285F4; color: #FFFFFF; border-color: transparent; }
.badge-azure { background: #0078D4; color: #FFFFFF; border-color: transparent; }

/* Severity — locked mapping */
.badge-sev-high { background: var(--coral-soft); color: var(--coral); border-color: var(--coral-strong); }
.badge-sev-med  { background: var(--teal-soft);  color: var(--teal);  border-color: rgba(61,90,128,0.30); }
.badge-sev-low  { background: rgba(140,142,151,0.10); color: var(--text-2); border-color: rgba(140,142,151,0.30); }

/* =============================================================
   INPUTS
   ============================================================= */
.field { display: flex; flex-direction: column; gap: 6px; }
.field-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-3);
  font-weight: 700;
}
.input {
  font-family: var(--font-ui);
  font-size: 15px;
  padding: 11px 14px;
  border-radius: var(--r-md);
  border: 1.5px solid var(--border);
  background: var(--paper);
  color: var(--text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  width: 100%;
}
.input::placeholder { color: var(--text-3); }
.input:focus { border-color: var(--coral); box-shadow: var(--shadow-glow-coral); }
.input-search {
  padding-left: 38px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='none'%3E%3Ccircle cx='6.5' cy='6.5' r='5' stroke='%238C8E97' stroke-width='1.5'/%3E%3Cpath d='M10.5 10.5L14 14' stroke='%238C8E97' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 14px center;
}

/* =============================================================
   CODE
   ============================================================= */
code.inline {
  font-family: var(--font-mono);
  font-size: 0.88em;
  background: rgba(45,49,66,0.06);
  padding: 2px 6px;
  border-radius: 4px;
  color: var(--text);
}
pre.code-block {
  background: var(--bg-deep);
  color: #EDE8E0;
  border-radius: var(--r-lg);
  padding: 22px 26px;
  font-family: var(--font-mono);
  font-size: 13.5px;
  line-height: 1.7;
  overflow-x: auto;
  margin: 0;
  box-shadow: var(--shadow-2);
}
pre.code-block .c-prompt  { color: var(--coral); user-select: none; }
pre.code-block .c-keyword { color: #C0A8E0; }
pre.code-block .c-string  { color: #A8D49C; }
pre.code-block .c-comment { color: rgba(255,255,255,0.4); font-style: italic; }
pre.code-block .c-fn      { color: #F2A98F; }

/* =============================================================
   ANOMALY CARD
   ============================================================= */
.anomaly {
  border: 1.5px solid var(--anom-color, var(--coral));
  border-radius: var(--r-lg);
  background: var(--anom-bg, rgba(224,122,95,0.06));
  padding: 22px 26px;
  margin: 16px 0;
}
.anomaly[data-sev="medium"] {
  --anom-color: var(--teal);
  --anom-bg: rgba(61,90,128,0.06);
}
.anomaly[data-sev="low"] {
  --anom-color: var(--text-3);
  --anom-bg: rgba(140,142,151,0.08);
}

.anom-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.anom-id {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 4px;
}
.anom-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.015em;
  color: var(--text);
  margin: 0 0 8px;
  line-height: 1.2;
}
.anom-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.anom-impact { text-align: right; flex-shrink: 0; }
.anom-cost {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 28px;
  color: var(--anom-color, var(--coral));
  line-height: 1;
}
.anom-cost-label {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  margin-top: 4px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.anom-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 18px;
}
@media (max-width: 700px) { .anom-grid { grid-template-columns: 1fr; } }

.anom-section-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 6px;
  font-weight: 700;
}
.anom-section-body { font-size: 13.5px; line-height: 1.55; color: var(--text); }
.anom-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(45,49,66,0.08);
}
@media (max-width: 700px) { .anom-meta-grid { grid-template-columns: repeat(2, 1fr); } }

.anom-meta-row .k {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-3);
  margin-bottom: 2px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-weight: 700;
}
.anom-meta-row .v { font-size: 13px; font-weight: 600; color: var(--text); }
.anom-cols { margin-top: 14px; }
.anom-cols .pillrow { display: flex; gap: 6px; flex-wrap: wrap; }
.anom-col-pill {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px 8px;
  background: rgba(45,49,66,0.06);
  border-radius: 4px;
  color: var(--text);
}

/* =============================================================
   TOPBAR (product chrome — charcoal)
   ============================================================= */
.topbar {
  height: 52px;
  background: var(--text);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 14px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.10);
}
.topbar .logo .logo-tile { box-shadow: none; }
.topbar .logo .logo-word { color: #fff; font-size: 15px; }
.topbar .logo .logo-word .drop   { color: var(--coral); }
.topbar .logo .logo-word .in     { color: #fff; }
.topbar .logo .logo-word .finops { color: var(--text-3); }

.topbar-divider { width: 1px; height: 22px; background: rgba(255,255,255,0.15); }
.topbar-section {
  font-family: var(--font-mono);
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  letter-spacing: 0.06em;
}
.topbar-spacer { flex: 1; }
.topbar-right { display: flex; gap: 12px; align-items: center; }
.topbar-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 3px 10px;
  border-radius: var(--r-pill);
  background: var(--coral-mid);
  color: var(--coral);
  border: 1px solid var(--coral-strong);
  letter-spacing: 0.04em;
}
.topbar-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: var(--coral);
  color: var(--bg-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-ui);
  font-weight: 700;
  font-size: 12px;
  box-shadow: 0 0 0 2px rgba(224,122,95,0.22);
  cursor: pointer;
}

/* =============================================================
   APP FRAME (product surface wrapper)
   ============================================================= */
.app-frame {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-2);
}
.app-frame .topbar { border-radius: var(--r-md) var(--r-md) 0 0; }
.app-frame .body {
  padding: 28px 32px;
  min-height: 240px;
  background: var(--bg);
}
.app-frame .body h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.app-frame .body p {
  font-family: var(--font-serif);
  color: var(--text-2);
  line-height: 1.6;
  margin: 0 0 12px;
  max-width: 60ch;
}

/* =============================================================
   FOOTER (marketing — cream/coral)
   ============================================================= */
.ds-footer {
  background: var(--coral-soft);
  border-top: 1px solid var(--coral-mid);
  padding: 36px 40px;
}
.ds-footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 32px;
  margin-bottom: 22px;
}
@media (max-width: 720px) { .ds-footer-grid { grid-template-columns: 1fr 1fr; } }

.ds-footer h5 {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--coral);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0 0 10px;
  font-weight: 700;
}
.ds-footer-links { display: flex; flex-direction: column; gap: 6px; font-size: 13.5px; }
.ds-footer-links a { color: var(--text-2); border: none; }
.ds-footer-links a:hover { color: var(--coral); }
.ds-footer-bottom {
  padding-top: 22px;
  border-top: 1px solid var(--coral-mid);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-2);
  letter-spacing: 0.06em;
  text-align: center;
}

/* =============================================================
   CHARTS
   ============================================================= */
.chart-card {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px;
}
.chart-card h4 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 18px;
  margin: 0 0 4px;
  letter-spacing: -0.01em;
}
.chart-card .sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.chart-legend {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-2);
}
.chart-legend .key { display: inline-flex; align-items: center; gap: 6px; }
.chart-legend .dot { width: 10px; height: 10px; border-radius: 2px; }

/* =============================================================
   CONSERVATIVE DIRECTION — component overrides
   ============================================================= */
body.conservative .t-display { letter-spacing: -0.015em; }
body.conservative .t-display em { color: var(--text); font-style: normal; font-weight: 600; }

body.conservative .anom-title,
body.conservative .chart-card h4,
body.conservative .app-frame .body h3 {
  font-family: var(--font-ui);
  font-weight: 700;
  letter-spacing: -0.01em;
}
body.conservative .app-frame .body p { font-family: var(--font-ui); }
body.conservative .anom-cost { font-family: var(--font-ui); font-weight: 700; }
body.conservative .logo-banner .logo-word { font-weight: 700; }
