/* Bastion — CMMC L2 / NIST 800-171 self-assessment. Plain CSS, no build. */
:root {
  --bg: #0b1018;
  --bg2: #0f1623;
  --surface: #141d2b;
  --surface2: #1b2738;
  --border: #25344a;
  --text: #e8eef6;
  --muted: #94a6bd;
  --brand: #f0a830;      /* amber/gold */
  --brand2: #ffc15e;
  --steel: #4f8cff;      /* steel blue */
  --good: #34d399;
  --warn: #ffce5c;
  --bad: #f06a6a;
  --na: #7c8aa0;
  --maxw: 1280px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--bg); color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  line-height: 1.6; -webkit-font-smoothing: antialiased; }
a { color: var(--brand2); text-decoration: none; }
a:hover { text-decoration: underline; }
h1,h2,h3 { line-height: 1.2; }
strong { color: #fff; }
code { background: var(--surface2); padding: .1rem .35rem; border-radius: 4px; font-size: .9em; }

/* ---- Nav ---- */
.nav { position: sticky; top: 0; z-index: 30; background: rgba(11,16,24,.92); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border); }
.nav-inner { max-width: var(--maxw); margin: 0 auto; padding: .7rem 1.2rem; display: flex; align-items: center; gap: .3rem 1.1rem; flex-wrap: wrap; }
.brand { display: flex; align-items: center; gap: .55rem; font-weight: 800; font-size: 1.15rem; color: var(--text); margin-right: auto; }
.brand .mark { width: 26px; height: 26px; flex: none; }
.nav a { color: var(--muted); font-size: .92rem; }
.nav a:hover { color: var(--text); text-decoration: none; }
.nav .btn { padding: .4rem .9rem; }

/* ---- Buttons ---- */
.btn { display: inline-block; cursor: pointer; font: inherit; font-weight: 600; border-radius: 9px;
  background: var(--surface2); color: var(--text); border: 1px solid var(--border); padding: .55rem 1.05rem; transition: .12s; }
.btn:hover { border-color: var(--brand); text-decoration: none; }
.btn.primary { background: var(--brand); color: #1a1206; border-color: var(--brand); }
.btn.primary:hover { filter: brightness(1.07); }
.btn.ghost { background: transparent; }
.btn.sm { padding: .35rem .7rem; font-size: .85rem; }
.btn.danger { border-color: var(--bad); color: #ff9b9b; }
.btn:disabled { opacity: .45; cursor: not-allowed; }

/* ---- Layout ---- */
.wrap { max-width: 1080px; margin: 0 auto; padding: 2rem 1.2rem 5rem; }
.wrap-app { max-width: var(--maxw); margin: 0 auto; padding: 1.4rem 1.2rem 5rem; }
.muted { color: var(--muted); }
.row { display: flex; gap: .7rem; flex-wrap: wrap; align-items: center; }
.spread { justify-content: space-between; }

/* ---- Marketing ---- */
.hero { text-align: center; padding: 4rem 1.2rem 2rem; background: radial-gradient(1100px 420px at 50% -10%, rgba(240,168,48,.10), transparent); }
.kicker { display: inline-block; font-size: .8rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--brand); border: 1px solid var(--border); border-radius: 999px; padding: .25rem .8rem; margin-bottom: 1rem; }
.hero h1 { font-size: 2.7rem; margin: .3rem auto .7rem; max-width: 16ch; }
.hero .sub { font-size: 1.2rem; color: var(--muted); max-width: 60ch; margin: 0 auto 1.6rem; }
.section { max-width: var(--maxw); margin: 0 auto; padding: 2.5rem 1.2rem; }
.section h2 { font-size: 1.7rem; text-align: center; margin-bottom: .4rem; }
.section .lead { text-align: center; color: var(--muted); max-width: 60ch; margin: 0 auto 1.8rem; }
.grid { display: grid; gap: 1.1rem; grid-template-columns: 1fr; }
@media (min-width:680px){ .grid.c2{grid-template-columns:1fr 1fr} .grid.c3{grid-template-columns:1fr 1fr 1fr} }
@media (min-width:980px){ .grid.c4{grid-template-columns:1fr 1fr 1fr 1fr} .grid.c3{grid-template-columns:1fr 1fr 1fr} }
.feat { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 1.2rem 1.3rem; }
.feat h3 { margin: .2rem 0 .4rem; font-size: 1.08rem; }
.feat p { margin: 0; color: var(--muted); font-size: .95rem; }
.feat .ico { font-size: 1.5rem; color: var(--brand); line-height: 1; }
.integr { display:flex; gap:1rem; align-items:flex-start; background: var(--surface); border:1px solid var(--border); border-left:4px solid var(--steel); border-radius:12px; padding:1.1rem 1.2rem; }
.steps { counter-reset: s; display: grid; gap: 1rem; }
.step { counter-increment: s; position: relative; padding-left: 3rem; }
.step::before { content: counter(s); position: absolute; left: 0; top: -.1rem; width: 2rem; height: 2rem; border-radius: 50%; background: var(--brand); color: #1a1206; font-weight: 800; display: grid; place-items: center; }
.faq dt { font-weight: 700; margin-top: 1rem; }
.faq dd { margin: .25rem 0 0; color: var(--muted); }
.cta { text-align: center; background: linear-gradient(180deg, var(--surface), var(--bg2)); border: 1px solid var(--border); border-radius: 18px; padding: 2.6rem 1.5rem; margin: 2rem auto; max-width: var(--maxw); }
.cta h2 { font-size: 1.8rem; }
footer.site { border-top: 1px solid var(--border); color: var(--muted); font-size: .85rem; text-align: center; padding: 2rem 1.2rem; }
.disclaim { font-size: .8rem; color: var(--muted); max-width: 70ch; margin: 1rem auto 0; }

/* ---- App tabs ---- */
.tabs { display: flex; gap: .3rem; flex-wrap: wrap; border-bottom: 1px solid var(--border); margin-bottom: 1.4rem; }
.tabs button { font: inherit; cursor: pointer; background: transparent; border: 0; border-bottom: 2px solid transparent; color: var(--muted); padding: .6rem .9rem; font-weight: 600; }
.tabs button:hover { color: var(--text); }
.tabs button.on { color: var(--text); border-bottom-color: var(--brand); }

/* ---- Score / stats ---- */
.stats { display: grid; gap: 1rem; grid-template-columns: repeat(2,1fr); margin: 0 0 1.4rem; }
@media (min-width:820px){ .stats { grid-template-columns: repeat(4,1fr); } }
.stat { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 1.1rem 1.2rem; }
.stat .num { font-size: 2rem; font-weight: 800; line-height: 1; }
.stat .lbl { font-size: .82rem; color: var(--muted); margin-top: .35rem; }
.score-hero { background: linear-gradient(135deg, var(--surface), var(--surface2)); border: 1px solid var(--border); border-radius: 16px; padding: 1.4rem 1.5rem; display: flex; align-items: center; gap: 1.4rem; flex-wrap: wrap; }
.score-big { font-size: 3.4rem; font-weight: 800; line-height: 1; }
.score-big small { font-size: 1.1rem; color: var(--muted); font-weight: 600; }
.score-good { color: var(--good); } .score-mid { color: var(--warn); } .score-bad { color: var(--bad); }

.bar { background: var(--surface2); border-radius: 999px; height: 12px; overflow: hidden; }
.bar > span { display: block; height: 100%; background: var(--brand); border-radius: 999px; transition: width .4s; }
.bar.good>span{background:var(--good)} .bar.warn>span{background:var(--warn)} .bar.bad>span{background:var(--bad)}
.fam-row { margin: .8rem 0; }
.fam-row .top { display: flex; justify-content: space-between; font-size: .92rem; margin-bottom: .25rem; }

/* ---- Controls / assessment ---- */
.toolbar { display: flex; gap: .6rem; flex-wrap: wrap; align-items: center; margin-bottom: 1rem; }
select, input[type=text], input[type=date], textarea { font: inherit; color: var(--text); background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; padding: .5rem .7rem; }
textarea { width: 100%; min-height: 64px; resize: vertical; }
label.fld { display: flex; flex-direction: column; gap: .25rem; font-size: .82rem; color: var(--muted); }
.ctrl { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 1rem 1.1rem; margin: .7rem 0; }
.ctrl.met { border-left: 4px solid var(--good); }
.ctrl.partial { border-left: 4px solid var(--warn); }
.ctrl.notmet { border-left: 4px solid var(--bad); }
.ctrl.na { border-left: 4px solid var(--na); }
.ctrl.unset { border-left: 4px solid var(--border); }
.ctrl .hd { display: flex; gap: .6rem; align-items: baseline; flex-wrap: wrap; }
.ctrl .cid { font-weight: 800; color: var(--brand2); font-variant-numeric: tabular-nums; }
.ctrl .ctitle { font-weight: 700; }
.ctrl .req { color: var(--muted); font-size: .95rem; margin: .4rem 0 .2rem; }
.badge { font-size: .68rem; font-weight: 700; padding: .1rem .5rem; border-radius: 999px; border: 1px solid var(--border); color: var(--muted); }
.badge.l1 { color: var(--brand); border-color: var(--brand); }
.badge.w5 { color: var(--bad); border-color: var(--bad); }
.badge.w3 { color: var(--warn); border-color: var(--warn); }
.badge.w1 { color: var(--muted); }
.badge.sl { color: var(--steel); border-color: var(--steel); }
.badge.cn { color: #b78bff; border-color: #b78bff; }
.statusbtns { display: flex; gap: .35rem; flex-wrap: wrap; margin: .6rem 0; }
.statusbtns button { font: inherit; cursor: pointer; font-size: .82rem; font-weight: 600; padding: .3rem .7rem; border-radius: 8px; border: 1px solid var(--border); background: var(--surface2); color: var(--muted); }
.statusbtns button.on[data-s=met]{background:rgba(52,211,153,.16);color:var(--good);border-color:var(--good)}
.statusbtns button.on[data-s=partial]{background:rgba(255,206,92,.16);color:var(--warn);border-color:var(--warn)}
.statusbtns button.on[data-s=notmet]{background:rgba(240,106,106,.16);color:var(--bad);border-color:var(--bad)}
.statusbtns button.on[data-s=na]{background:rgba(124,138,160,.16);color:var(--na);border-color:var(--na)}
.poam-fields { display: grid; gap: .6rem; grid-template-columns: 1fr; margin-top: .6rem; }
@media (min-width:720px){ .poam-fields { grid-template-columns: 2fr 1fr 1fr; } }
details.guide { margin: .4rem 0; } details.guide summary { cursor: pointer; color: var(--brand2); font-size: .9rem; }

/* ---- Tables ---- */
.table-scroll { overflow-x: auto; }
table { border-collapse: collapse; width: 100%; font-size: .92rem; }
th,td { text-align: left; padding: .55rem .7rem; border-bottom: 1px solid var(--border); vertical-align: top; }
th { color: var(--brand2); }
.callout { background: var(--surface2); border-left: 4px solid var(--brand); border-radius: 0 8px 8px 0; padding: .8rem 1rem; margin: 1.2rem 0; }
.callout.warn { border-left-color: var(--warn); }
.callout.good { border-left-color: var(--good); }
.toast { position: fixed; bottom: 1.2rem; left: 50%; transform: translateX(-50%); background: var(--surface2); border: 1px solid var(--brand); padding: .6rem 1rem; border-radius: 10px; z-index: 60; opacity: 0; transition: .2s; }
.toast.show { opacity: 1; }
.pill { display:inline-block; font-size:.72rem; font-weight:700; padding:.1rem .55rem; border-radius:999px; }
.pill.free{background:rgba(52,211,153,.18);color:var(--good)} .pill.steel{background:rgba(79,140,255,.18);color:var(--steel)}
@media print { .nav,.tabs,.toolbar,.noprint{display:none!important} body{background:#fff;color:#000} .ctrl,table{break-inside:avoid} }
