/* Shared styles for Session A implementation planning pack */
:root{
  --bg:#03070E;
  --surface:#0A1020;
  --surface2:#0E1630;
  --teal:#00E5B4;--teal2:#00B48A;--teal4:rgba(0,229,180,0.12);
  --blue:#38BDF8;--purple:#A78BFA;--amber:#FCD34D;--rose:#FB7185;--green:#34D399;
  --text1:#F0F9FF;--text2:#94A3B8;--text3:#64748B;--text4:#475569;
  --border:rgba(148,163,184,0.14);--border2:rgba(148,163,184,0.08);
  --sans:'Noto Sans Thai',-apple-system,BlinkMacSystemFont,'Inter',sans-serif;
  --mono:'Space Mono','SF Mono',Menlo,monospace;
  --bebas:'Bebas Neue','Noto Sans Thai',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{height:100%}
body{
  font-family:var(--sans);background:var(--bg);color:var(--text1);
  min-height:100vh;line-height:1.65;
  background-image:
    radial-gradient(ellipse 60% 50% at 10% -10%,rgba(0,180,138,0.10) 0%,transparent 60%),
    radial-gradient(ellipse 50% 50% at 90% 110%,rgba(56,189,248,0.06) 0%,transparent 60%);
}
.wrap{max-width:1180px;margin:0 auto;padding:40px 24px 80px}
.breadcrumb{
  font-family:var(--mono);font-size:12px;letter-spacing:.14em;
  color:var(--text3);text-transform:uppercase;margin-bottom:18px;
}
.breadcrumb a{color:var(--text2);text-decoration:none;border-bottom:1px dashed rgba(148,163,184,0.3)}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb .sep{color:var(--text4);margin:0 10px}

h1.title{
  font-family:var(--bebas);font-size:clamp(40px,6vw,64px);font-weight:400;
  letter-spacing:.06em;line-height:1.05;
  background:linear-gradient(135deg,var(--teal) 0%,var(--blue) 60%,var(--purple) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
h1 .sub-th{display:block;font-family:var(--sans);font-size:18px;font-weight:500;
  color:var(--text2);-webkit-text-fill-color:var(--text2);letter-spacing:.02em;margin-top:6px}

.status-banner{
  margin:18px 0 36px;padding:14px 18px;border-radius:10px;
  background:rgba(252,211,77,0.08);border:1px solid rgba(252,211,77,0.25);
  display:flex;gap:14px;align-items:flex-start;flex-wrap:wrap;
}
.status-banner .tag{
  display:inline-block;padding:3px 10px;border-radius:4px;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
  background:rgba(252,211,77,0.18);color:var(--amber);border:1px solid rgba(252,211,77,0.35);
}
.status-banner .text{flex:1;min-width:260px;font-size:14px;color:var(--text2)}

.section{margin:44px 0 0}
.section h2{
  font-family:var(--bebas);font-size:28px;letter-spacing:.08em;
  color:var(--text1);margin-bottom:14px;
  padding-bottom:8px;border-bottom:1px solid var(--border);
}
.section h2 .th{display:block;font-family:var(--sans);font-size:14px;font-weight:400;
  color:var(--text3);letter-spacing:.02em;margin-top:2px}
.section p{color:var(--text2);font-size:15px;margin-bottom:10px}
.section ul{color:var(--text2);font-size:15px;padding-left:22px;margin:8px 0}
.section ul li{margin:6px 0}
.section code{font-family:var(--mono);font-size:12.5px;background:rgba(0,229,180,0.07);
  padding:2px 6px;border-radius:3px;color:var(--teal);border:1px solid rgba(0,229,180,0.15)}

.pill{display:inline-block;padding:2px 10px;border-radius:100px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--border);color:var(--text2);background:rgba(148,163,184,0.04);margin:0 4px 4px 0}
.pill.teal{border-color:rgba(0,229,180,0.28);color:var(--teal);background:rgba(0,229,180,0.06)}
.pill.blue{border-color:rgba(56,189,248,0.28);color:var(--blue);background:rgba(56,189,248,0.06)}
.pill.purple{border-color:rgba(167,139,250,0.28);color:var(--purple);background:rgba(167,139,250,0.06)}
.pill.amber{border-color:rgba(252,211,77,0.28);color:var(--amber);background:rgba(252,211,77,0.06)}
.pill.rose{border-color:rgba(251,113,133,0.28);color:var(--rose);background:rgba(251,113,133,0.06)}

.contract-sources{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;
  margin:14px 0;
}
.contract-sources .src{
  padding:12px 14px;border-radius:8px;
  background:var(--surface);border:1px solid var(--border);
}
.contract-sources .src .path{font-family:var(--mono);font-size:12px;color:var(--teal);
  word-break:break-all;display:block;margin-bottom:4px}
.contract-sources .src .note{font-size:12px;color:var(--text3)}

/* Field mapping table — the hero element per page */
.fm-wrap{overflow-x:auto;margin:14px 0;border-radius:10px;border:1px solid var(--border)}
table.field-map{
  width:100%;border-collapse:collapse;font-size:13px;
  background:var(--surface);
}
table.field-map thead th{
  text-align:left;padding:12px 14px;
  background:var(--surface2);
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text2);border-bottom:1px solid var(--border);font-weight:700;
}
table.field-map td{
  padding:12px 14px;vertical-align:top;
  border-bottom:1px solid var(--border2);
  color:var(--text2);
}
table.field-map tr:last-child td{border-bottom:none}
table.field-map tr:hover td{background:rgba(0,229,180,0.025)}
table.field-map .b-field{font-family:var(--mono);font-size:12px;color:var(--blue);white-space:nowrap}
table.field-map .b-type{font-family:var(--mono);font-size:11px;color:var(--text3)}
table.field-map .a-target{color:var(--text1);font-weight:500}
table.field-map .a-owner{font-family:var(--mono);font-size:11px;color:var(--purple)}
table.field-map .a-gate{font-family:var(--mono);font-size:11px;color:var(--amber)}
table.field-map .notes{font-size:12.5px;color:var(--text3)}

.split{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}
.card{padding:18px;border-radius:10px;background:var(--surface);border:1px solid var(--border)}
.card h3{font-size:14px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text2);font-family:var(--mono);margin-bottom:10px}
.card ul{padding-left:18px}
.card ul li{font-size:13.5px;color:var(--text2);margin:5px 0}

.risk-row{display:grid;grid-template-columns:1fr 80px 2fr;gap:14px;
  padding:10px 0;border-bottom:1px solid var(--border2);align-items:start}
.risk-row:last-child{border-bottom:none}
.risk-row .label{font-size:13px;color:var(--text1);font-weight:500}
.risk-row .lvl{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;text-align:center;padding:3px 6px;border-radius:4px}
.risk-row .lvl.low{background:rgba(52,211,153,0.1);color:var(--green);border:1px solid rgba(52,211,153,0.3)}
.risk-row .lvl.med{background:rgba(252,211,77,0.1);color:var(--amber);border:1px solid rgba(252,211,77,0.3)}
.risk-row .lvl.high{background:rgba(251,113,133,0.1);color:var(--rose);border:1px solid rgba(251,113,133,0.3)}
.risk-row .mit{font-size:13px;color:var(--text2)}

.dod-list{counter-reset:dod}
.dod-list li{list-style:none;padding:10px 0 10px 40px;position:relative;
  border-bottom:1px solid var(--border2);color:var(--text1);font-size:14px}
.dod-list li::before{counter-increment:dod;content:counter(dod);
  position:absolute;left:0;top:10px;width:26px;height:26px;
  background:rgba(0,229,180,0.12);border:1px solid rgba(0,229,180,0.35);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11px;color:var(--teal);font-weight:700}

.deferred-list{color:var(--text3);font-size:13.5px}
.deferred-list li{margin:5px 0;padding-left:16px;position:relative}
.deferred-list li::before{content:'–';position:absolute;left:0;color:var(--text4)}

/* ═══ Binding status pills (v0.2) ═══ */
.bst{display:inline-block;padding:2px 7px;border-radius:3px;
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;white-space:nowrap}
.bst.live{background:rgba(52,211,153,0.12);color:var(--green);border:1px solid rgba(52,211,153,0.35)}
.bst.mock{background:rgba(252,211,77,0.10);color:var(--amber);border:1px solid rgba(252,211,77,0.30)}
.bst.mapped{background:rgba(56,189,248,0.10);color:var(--blue);border:1px solid rgba(56,189,248,0.30)}
.bst.placeholder{background:rgba(148,163,184,0.08);color:var(--text3);border:1px solid rgba(148,163,184,0.22)}
.bst.derived{background:rgba(167,139,250,0.10);color:var(--purple);border:1px solid rgba(167,139,250,0.30)}

/* Binding legend */
.bst-legend{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 16px;
  padding:10px 14px;border-radius:8px;background:var(--surface);border:1px dashed var(--border)}
.bst-legend span{font-size:12px;color:var(--text2)}

/* ═══ Diagrams (v0.2) ═══ */
.diagram{background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:20px;margin:14px 0;overflow-x:auto}
.diagram svg{display:block;max-width:100%;height:auto}
.diagram .title{font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--text3);margin-bottom:10px}

/* ER diagram node classes */
.er-box{fill:#0E1630;stroke:rgba(0,229,180,0.35);stroke-width:1.2}
.er-box-label{fill:var(--teal);font-family:var(--mono);font-size:11px;font-weight:700}
.er-field{fill:var(--text2);font-family:var(--mono);font-size:10.5px}
.er-field-key{fill:var(--amber);font-weight:700}
.er-edge{stroke:rgba(167,139,250,0.5);stroke-width:1.3;fill:none;stroke-dasharray:3,3}
.er-edge-label{fill:var(--purple);font-family:var(--mono);font-size:9.5px}

/* Sequence flow classes */
.seq-lane{fill:var(--surface2);stroke:var(--border);stroke-width:1}
.seq-lane-label{fill:var(--text2);font-family:var(--mono);font-size:11px;font-weight:700}
.seq-arrow{stroke:var(--teal);stroke-width:1.5;fill:none;marker-end:url(#seq-arrowhead)}
.seq-arrow-reply{stroke:var(--blue);stroke-width:1.2;stroke-dasharray:4,3;fill:none;marker-end:url(#seq-arrowhead-blue)}
.seq-msg{fill:var(--text1);font-family:var(--mono);font-size:10.5px}
.seq-step-n{fill:var(--amber);font-family:var(--mono);font-size:10px;font-weight:700}

/* API sketch */
.api-block{background:var(--surface2);border:1px solid var(--border);
  border-radius:8px;padding:14px 16px;margin:10px 0;font-family:var(--mono);font-size:12.5px;overflow-x:auto}
.api-method{display:inline-block;padding:2px 8px;border-radius:3px;
  font-weight:700;font-size:10.5px;letter-spacing:.08em;margin-right:8px}
.api-method.get{background:rgba(56,189,248,0.14);color:var(--blue);border:1px solid rgba(56,189,248,0.35)}
.api-method.post{background:rgba(52,211,153,0.14);color:var(--green);border:1px solid rgba(52,211,153,0.35)}
.api-method.put{background:rgba(167,139,250,0.14);color:var(--purple);border:1px solid rgba(167,139,250,0.35)}
.api-method.patch{background:rgba(252,211,77,0.14);color:var(--amber);border:1px solid rgba(252,211,77,0.35)}
.api-method.delete{background:rgba(251,113,133,0.14);color:var(--rose);border:1px solid rgba(251,113,133,0.35)}
.api-path{color:var(--text1);font-weight:600}
.api-desc{color:var(--text3);font-size:11.5px;margin-top:4px;font-family:var(--sans)}
.api-sample{background:#050912;padding:10px 12px;border-radius:6px;
  margin-top:8px;font-size:11.5px;color:var(--text2);
  white-space:pre;overflow-x:auto;border-left:2px solid var(--teal4)}
.api-sample .k{color:var(--blue)}
.api-sample .s{color:var(--green)}
.api-sample .c{color:var(--text4)}
.api-sample .n{color:var(--amber)}

/* A-owned runtime boundary block */
.boundary{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:14px 0}
@media (max-width:640px){.boundary{grid-template-columns:1fr}}
.boundary .side{padding:16px;border-radius:8px}
.boundary .side.b-owns{background:rgba(167,139,250,0.05);border:1px solid rgba(167,139,250,0.22)}
.boundary .side.a-owns{background:rgba(0,229,180,0.05);border:1px solid rgba(0,229,180,0.22)}
.boundary .side h4{font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:8px}
.boundary .side.b-owns h4{color:var(--purple)}
.boundary .side.a-owns h4{color:var(--teal)}
.boundary .side ul{font-size:13px;color:var(--text2);padding-left:18px;margin:0}
.boundary .side ul li{margin:4px 0}

.foot{margin-top:60px;padding-top:20px;border-top:1px solid var(--border);
  font-family:var(--mono);font-size:11px;color:var(--text4);letter-spacing:.12em;text-transform:uppercase;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.foot a{color:var(--text3);text-decoration:none}
.foot a:hover{color:var(--teal)}

/* Hub page specifics */
.hub-header{text-align:center;margin-bottom:48px}
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.hub-card{
  display:flex;flex-direction:column;gap:10px;padding:22px;border-radius:12px;
  background:var(--surface);border:1px solid var(--border);text-decoration:none;color:inherit;
  transition:all .2s;
}
.hub-card:hover{border-color:rgba(0,229,180,0.4);transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(0,229,180,0.08)}
.hub-card h3{font-family:var(--bebas);font-size:24px;letter-spacing:.06em;color:var(--text1)}
.hub-card h3 .th{display:block;font-family:var(--sans);font-size:13px;font-weight:500;color:var(--text2);letter-spacing:.02em}
.hub-card .meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text3)}
.hub-card .desc{font-size:13px;color:var(--text2);line-height:1.6}
.hub-card .stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.hub-card .stats span{font-family:var(--mono);font-size:10.5px;color:var(--text3)}
.hub-card .stats strong{color:var(--teal);font-weight:700}

/* =========================================================================
 * Console Typography Upgrade (Batch 5 · 2026-04-19)
 * Rule: 11px → 14px · 12px and 12.5px → 16px · 14px → 18px.
 * Only sizes that matched the rule in this file are lifted. Sizes outside
 * the rule (9px/10px/10.5px/11.5px/13px/13.5px/15px/17px/18px/...) are left.
 * Appended as overrides so the file history stays readable. If you read
 * an earlier rule with a smaller size, this block is the authoritative one.
 * ========================================================================= */

/* Breadcrumb + banners */
.breadcrumb          { font-size: 16px; }
.status-banner .text { font-size: 18px; }
.section h2 .th      { font-size: 18px; }
.section code        { font-size: 16px; }

/* Contract sources cards */
.contract-sources .src .path { font-size: 16px; }
.contract-sources .src .note { font-size: 16px; }

/* Field-map table labels */
table.field-map thead th { font-size: 14px; }
table.field-map .b-field { font-size: 16px; }
table.field-map .b-type  { font-size: 14px; }
table.field-map .a-owner { font-size: 14px; }
table.field-map .a-gate  { font-size: 14px; }
table.field-map .notes   { font-size: 16px; }

/* Cards */
.card h3 { font-size: 18px; }

/* Risk/DoD lists */
.dod-list li          { font-size: 18px; }
.dod-list li::before  { font-size: 14px; }

/* Binding legend + diagrams */
.bst-legend span      { font-size: 16px; }
.diagram .title       { font-size: 14px; }
.er-box-label         { font-size: 14px; }
.seq-lane-label       { font-size: 14px; }

/* API blocks */
.api-block            { font-size: 16px; }

/* Boundary block */
.boundary .side h4    { font-size: 14px; }

/* Footer */
.foot                 { font-size: 14px; }
