/* Portal-only layout. Paints through tokens only (same contract as
   components.css — guarded by test/design-system.test.js). */

[hidden] { display: none !important; }

.bar-end { margin-left: auto; display: flex; align-items: center; gap: var(--sp-3); position: relative; }
.bar-user { display: inline-flex; align-items: center; gap: var(--sp-2); }
.bar-user .nm { font-size: var(--app-xs); color: var(--dim); }

.scope-menu { position: absolute; top: calc(100% + 8px); right: 0; z-index: 55; }

/* ── Auth ── */
.auth { padding-top: var(--sp-8); }
.auth .mast { text-align: center; padding-bottom: var(--sp-6); }
.auth .mast h1 { font-family: var(--font-display); font-weight: var(--display-weight); font-size: var(--app-display-1); letter-spacing: var(--display-tracking); line-height: var(--leading-display); margin: 20px 0 0; }
.auth .mast h1 em { font-style: italic; color: var(--accent); }
.auth .mast .sub { color: var(--muted); font-size: var(--app-sm); margin-top: 14px; }
.auth-form { max-width: 380px; margin: 0 auto; }

/* ── Page scaffolding ── */
.page { padding: var(--sp-6) 0 var(--sp-8); }
.page-head { display: flex; align-items: baseline; gap: var(--sp-4); margin-bottom: var(--sp-5); }
.page-head h1 { font-family: var(--font-display); font-weight: var(--display-weight); font-size: var(--app-display-2); letter-spacing: var(--display-tracking); margin: 0; }
.page-head .spacer { flex: 1; }
.page-head .sg-eyebrow { margin-bottom: var(--sp-2); }
.page-note { color: var(--muted); font-size: var(--app-sm); max-width: 58ch; margin: 0 0 var(--sp-5); }

/* ── Brief (reading room) ── */
.brief-mast { position: relative; padding: var(--sp-7) 0 var(--sp-6); text-align: center; }
.brief-mast::before { content: ""; position: absolute; inset: -64px -40vw 0; background: var(--glow-masthead); pointer-events: none; }
.brief-mast > * { position: relative; }
.brief-mast h1 { font-family: var(--font-display); font-weight: var(--display-weight); font-size: var(--app-display-1); letter-spacing: var(--display-tracking); line-height: var(--leading-display); margin: 20px 0 0; text-wrap: balance; }
.brief-mast .sub { margin: 14px 0 0; color: var(--muted); font-size: var(--app-sm); }
.brief-mast .sub b { font-weight: 500; color: var(--fg); }
.brief-intro { color: var(--muted); font-size: var(--app-body); max-width: 58ch; margin: 0 auto var(--sp-5); text-align: center; }

.brief-item { display: grid; grid-template-columns: 52px 1fr; gap: 20px; padding: var(--sp-6) 0; border-top: 1px solid var(--line-2); }
.brief-item .ix { font-family: var(--font-display); font-style: italic; font-size: 19px; color: var(--dim); padding-top: 5px; }
.brief-item h2 { font-family: var(--font-display); font-weight: var(--display-weight); font-size: var(--app-headline); letter-spacing: var(--display-tracking); line-height: 1.2; margin: 0; }
.brief-item h2 a:hover { color: var(--accent); }
.brief-item .meta { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 16px; margin-top: 9px; font-size: var(--app-xs); color: var(--dim); }
.brief-item .meta .src { color: var(--muted); font-weight: 500; }
.brief-item .body { margin: 14px 0 0; color: var(--fg); font-size: var(--app-body); max-width: 58ch; }
.brief-item .why { margin: 14px 0 0; color: var(--muted); font-size: var(--app-body); max-width: 58ch; }
.brief-item .why::before { content: "Why it matters"; display: block; font-size: var(--eyebrow-size); font-weight: var(--eyebrow-weight); letter-spacing: var(--eyebrow-tracking); text-transform: uppercase; color: var(--dim); margin-bottom: 7px; }
.brief-item .caveat { margin: 10px 0 0; color: var(--dim); font-size: var(--app-sm); max-width: 58ch; }
.brief-item .caveat b { color: var(--muted); font-weight: 500; }
.brief-item .tail { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 12px; margin-top: 16px; font-size: var(--app-xs); color: var(--dim); }
.brief-item .tail .srcs a { color: var(--muted); }
.brief-item .tail .srcs a:hover { color: var(--accent); }
.brief-item .thumbs { display: inline-flex; gap: 2px; margin-left: auto; }
.brief-item .thumbs button { font: inherit; font-size: var(--app-xs); color: var(--dim); background: none; border: 1px solid transparent; border-radius: var(--r-pill); padding: 3px 10px; cursor: pointer; transition: color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease); }
.brief-item .thumbs button:hover { color: var(--fg); border-color: var(--line); }
.brief-item .thumbs button[data-sent="true"] { color: var(--accent); border-color: var(--accent); }
@media (max-width: 640px) { .brief-item { grid-template-columns: 1fr; gap: 6px; } .brief-item .ix { padding: 0; } }

.brief-also { border-top: 1px solid var(--line-2); padding: var(--sp-6) 0; }
.brief-also .sg-eyebrow { margin-bottom: var(--sp-4); }

.brief-foot { border-top: 1px solid var(--line-2); padding: var(--sp-6) 0 var(--sp-7); text-align: center; }
.brief-foot p { color: var(--muted); font-size: var(--app-sm); max-width: 46ch; margin: 0 auto; }
.brief-foot .colophon { margin-top: var(--sp-6); font-size: var(--app-xs); letter-spacing: .22em; text-transform: uppercase; color: var(--dim); }

/* ── Working views ── */
.toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-3); margin: var(--sp-4) 0 var(--sp-4); }
.toolbar .spacer { flex: 1; }

.matrix { width: 100%; border-collapse: collapse; font-size: var(--app-sm); }
.matrix th { font-size: var(--app-xs); font-weight: 500; letter-spacing: .06em; color: var(--dim); text-align: left; padding: 10px; border-bottom: 1px solid var(--line); }
.matrix th.c, .matrix td.c { text-align: center; }
.matrix td { padding: 12px 10px; border-bottom: 1px solid var(--line-2); vertical-align: baseline; }
.matrix td .nm { font-weight: 500; color: var(--fg); }
.matrix td .meta { font-size: var(--app-xs); color: var(--dim); margin-top: 2px; }
.matrix .dot-btn { width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--line); background: transparent; cursor: pointer; transition: background-color var(--dur-1) var(--ease), border-color var(--dur-1) var(--ease); }
.matrix .dot-btn[data-on="true"] { background: var(--accent); border-color: var(--accent); }
.matrix .dot-btn:hover { border-color: var(--accent); }

.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--sp-4); margin: var(--sp-5) 0; }
.stat { border-top: 1px solid var(--line); padding-top: var(--sp-3); }
.stat .v { font-family: var(--font-display); font-size: var(--app-display-2); letter-spacing: var(--display-tracking); }
.stat .k { font-size: var(--app-xs); color: var(--dim); letter-spacing: .06em; margin-top: 2px; }

.thesis-editor textarea { min-height: 220px; font-size: var(--app-sm); line-height: 1.6; }

.form-panel { border-top: 1px solid var(--line-2); padding-top: var(--sp-5); margin-top: var(--sp-5); max-width: 560px; }

.feed-note { font-size: var(--app-xs); color: var(--dim); }
