/* === MAIN.CSS ===
 * assets/css/main.css
 * НАЗНАЧЕНИЕ: Базовый layout Mindway - landing, auth, cabinet
 * СВЯЗИ: themes.css, widgets.css, responsive.css
 * РАЗМЕР: ~260 строк
 */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    min-height: 100%;
    margin: 0;
    overflow-x: clip;
}

body {
    font-family: var(--font-body);
    background:
        linear-gradient(180deg, rgba(9, 13, 21, 0.18), transparent 25%),
        var(--surface-gradient),
        var(--bg);
    color: var(--text);
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input,
select,
textarea {
    font: inherit;
}

.mindway-body {
    position: relative;
}

.mindway-body::before {
    content: "";
    position: fixed;
    inset: 0;
    background-image:
        linear-gradient(to right, rgba(255, 255, 255, 0.03) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
    background-size: 40px 40px;
    opacity: 0.25;
    pointer-events: none;
    mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.9), transparent 85%);
}

.mindway-public,
.auth-shell,
.cabinet-shell {
    position: relative;
    z-index: 1;
    min-width: 0;
}

.mindway-public,
.auth-shell {
    padding: var(--space-5);
}

.hero-shell,
.public-grid,
.auth-card {
    width: min(1200px, 100%);
    margin: 0 auto;
}

.hero-shell {
    display: grid;
    gap: var(--space-4);
    padding-top: min(8vh, 52px);
}

.public-topbar,
.auth-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}

.public-topbar .eyebrow {
    margin: 0;
}

.hero-copy h1,
.auth-card h1,
.toolbar-copy h2,
.rail-brand h1,
.section-heading h2,
.section-intro-card h3,
.person-focus-card h2 {
    margin: 0;
    font-family: var(--font-heading);
    line-height: 1.05;
}

.hero-copy h1 {
    font-size: clamp(2.1rem, 9vw, 4.6rem);
    max-width: 11ch;
}

.hero-text,
.auth-text {
    max-width: 680px;
    color: var(--text-soft);
    font-size: 1rem;
    line-height: 1.55;
    overflow-wrap: anywhere;
}

.hero-actions,
.button-row,
.source-toolbar,
.field-inline,
.dialog-actions,
.header-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.hero-panel,
.auth-card {
    padding: var(--space-5);
}

.metric-strip,
.public-grid,
.dashboard-grid,
.metric-grid,
.detail-grid,
.sources-grid,
.health-grid {
    display: grid;
    gap: var(--space-3);
}

.metric-strip,
.metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.hero-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.hero-preview {
    display: grid;
    gap: var(--space-2);
    margin-top: var(--space-4);
}

.public-grid,
.dashboard-grid,
.detail-grid,
.sources-grid {
    margin-top: var(--space-4);
}

.public-card h2,
.panel-card h3,
.dialog-header h2,
.split-head h2 {
    margin: 0 0 var(--space-2);
    font-size: 1.05rem;
    font-family: var(--font-display);
}

.eyebrow {
    margin: 0 0 var(--space-2);
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    font-size: 0.76rem;
    font-family: var(--font-display);
}

.auth-shell {
    min-height: 100vh;
    display: grid;
    place-items: center;
}

.auth-card {
    width: min(480px, 100%);
}

.auth-form {
    display: grid;
    gap: var(--space-3);
}

.auth-backlink {
    color: var(--text-soft);
    font-family: var(--font-display);
}

.auth-help {
    display: grid;
    gap: var(--space-2);
    margin-top: var(--space-4);
    padding-top: var(--space-3);
    border-top: 1px solid var(--line);
}

.auth-help h2 {
    margin: 0;
    font-size: 1rem;
    font-family: var(--font-display);
}

.auth-links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
}

.auth-fast-link {
    display: inline-flex;
    margin-top: var(--space-3);
    color: var(--accent);
}

.cabinet-shell {
    padding: var(--space-3);
    width: min(1440px, calc(100% - (var(--space-3) * 2)));
    margin: 0 auto;
    display: grid;
    gap: var(--space-3);
    min-width: 0;
}

.cabinet-rail,
.cabinet-stage,
.cabinet-content,
.dashboard-layout,
.dashboard-column,
.people-workspace,
.people-focus,
.people-action-rail,
.recommendations-layout,
.settings-layout,
.sources-hero__stats,
.page-section,
.section-heading,
.section-heading > div,
.toolbar-copy,
.toolbar-actions,
.rail-context,
.rail-nav,
.sidebar-content {
    min-width: 0;
}

.cabinet-rail {
    display: grid;
    gap: var(--space-4);
    align-content: start;
    padding: var(--space-4);
}

.rail-brand {
    display: grid;
    gap: var(--space-3);
}

.rail-brand h1 {
    font-size: clamp(1.3rem, 2vw, 1.8rem);
    max-width: 10ch;
}

.rail-copy,
.toolbar-description {
    margin: 0;
    color: var(--text-soft);
    line-height: 1.55;
}

.rail-nav {
    display: grid;
    gap: 8px;
}

.rail-context {
    display: grid;
    gap: var(--space-3);
}

.sidebar-head {
    display: grid;
    gap: 4px;
}

.sidebar-head span {
    font-family: var(--font-heading);
    font-size: 1rem;
}

.sidebar-head small {
    color: var(--text-muted);
}

.cabinet-stage {
    display: grid;
    gap: var(--space-3);
}

.cabinet-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--space-3);
    padding: var(--space-4);
    position: sticky;
    top: var(--space-2);
    z-index: 10;
}

.toolbar-copy {
    display: grid;
    gap: 8px;
}

.toolbar-copy h2 {
    font-size: clamp(1.55rem, 3.2vw, 2.2rem);
}

.toolbar-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    gap: var(--space-2);
}

.toolbar-status {
    max-width: 300px;
    margin: 0;
    color: var(--text-muted);
    font-size: 0.92rem;
    line-height: 1.45;
    text-align: right;
}

.cabinet-content {
    min-width: 0;
}

.app-shell {
    min-height: 70vh;
}

.page-section {
    display: grid;
    gap: var(--space-3);
}

.section-intro-card,
.dashboard-hero,
.people-roster,
.person-focus-card {
    display: grid;
    gap: var(--space-3);
}

.section-intro-card__copy {
    display: grid;
    gap: 6px;
}

.dashboard-layout,
.recommendations-layout,
.settings-layout {
    display: grid;
    gap: var(--space-3);
}

.dashboard-column,
.people-focus,
.people-action-rail {
    display: grid;
    gap: var(--space-3);
}

.dashboard-status-list,
.sources-hero__stats {
    display: grid;
    gap: var(--space-2);
}

.people-workspace {
    display: grid;
    gap: var(--space-3);
}

.people-roster__head,
.person-focus-card__head {
    display: grid;
    gap: var(--space-2);
}

.people-roster__head h2 {
    margin: 0;
    font-family: var(--font-heading);
    font-size: 1.2rem;
}

.people-roster__head p {
    margin: 0;
    color: var(--text-muted);
    line-height: 1.45;
}

.person-focus-card__copy {
    display: grid;
    gap: 8px;
}

.person-focus-card__meta {
    display: grid;
    gap: var(--space-2);
}

.focus-meta-card {
    display: grid;
    gap: 4px;
    padding: var(--space-3);
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: color-mix(in oklch, var(--panel-strong) 84%, white 16%);
}

.focus-meta-card span {
    color: var(--text-muted);
    font-size: 0.8rem;
    font-family: var(--font-display);
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.focus-meta-card strong {
    font-family: var(--font-heading);
    font-size: 1rem;
}

.section-heading p,
.muted-text,
.metric-hint,
.person-card__meta,
.source-card__type {
    margin: 0;
    color: var(--text-muted);
}

.split-search,
.welcome-card {
    margin-bottom: var(--space-2);
}

.loading-screen,
.empty-state {
    display: grid;
    place-items: center;
    min-height: 36vh;
    text-align: center;
}

.loading-badge {
    padding: 14px 18px;
    border-radius: var(--radius-md);
    border: 1px solid var(--line);
    background: var(--panel-strong);
    font-family: var(--font-display);
}

.summary-text {
    overflow-wrap: anywhere;
}

.empty-state-compact {
    min-height: 180px;
    padding: var(--space-3);
}
