/* ============================================================
   components/_layout.css — Public-Layout-Primitives (0.1.3.1)
   ------------------------------------------------------------
   Hotfix 0.1.3.1: body.pub-standalone bekommt margin:0 — vorher
   produzierte der Browser-Default 8px margin-top eine
   ungewollte Scrollbar auf der Login-Seite und Geschwistern.
============================================================ */

/* ----------------------------------------------------------------
   Container — zentriert, breite-begrenzt
   ---------------------------------------------------------------- */
.pub-container {
    max-width: var(--pub-container-max);
    margin: 0 auto;
    padding: 24px 20px;
}

.pub-container--narrow { max-width: var(--pub-container-narrow); }
.pub-container--form   { max-width: var(--pub-container-form); }

/* ----------------------------------------------------------------
   Page-Header
   ---------------------------------------------------------------- */
.pub-page-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--pub-border);
}

.pub-page-header h1 {
    margin: 0;
    font-size: 1.7rem;
    font-weight: 600;
    color: var(--pub-text);
    line-height: 1.25;
}

.pub-page-header .pub-subtitle {
    color: var(--pub-text-muted);
    font-size: 0.95rem;
    margin-top: 4px;
}

/* ----------------------------------------------------------------
   Section
   ---------------------------------------------------------------- */
.pub-section {
    margin-bottom: 32px;
}

.pub-section h2 {
    margin: 0 0 12px 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--pub-text);
}

.pub-section p {
    color: var(--pub-text);
    line-height: 1.55;
}

/* ----------------------------------------------------------------
   Lead-Text
   ---------------------------------------------------------------- */
.pub-lead {
    font-size: 1.05rem;
    color: var(--pub-text);
    line-height: 1.6;
    margin-bottom: 24px;
}

/* ----------------------------------------------------------------
   Grid
   ---------------------------------------------------------------- */
.pub-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 16px;
}

/* ----------------------------------------------------------------
   Meta-Footer
   ---------------------------------------------------------------- */
.pub-meta {
    margin-top: 32px;
    padding-top: 16px;
    border-top: 1px dashed var(--pub-border);
    color: var(--pub-text-muted);
    font-size: 0.85rem;
    line-height: 1.5;
}

.pub-meta code {
    background: var(--pub-bg-subtle);
    padding: 1px 6px;
    border-radius: var(--pub-radius-sm);
    font-size: 0.85em;
    color: var(--pub-brand-strong);
}

/* ----------------------------------------------------------------
   Standalone-Layout — Auth-Pages (Login, Forgot, Reset, Activate,
   ChangePassword). Kein Sidebar, kein Public-Header-Frame.
   0.1.3.1: body-Default-Margin neutralisieren — vorher schob der
   8px-Default die Page nach unten und produzierte Scrollbar.
   ---------------------------------------------------------------- */
body.pub-standalone {
    margin: 0;
    padding: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--pub-bg-page);
}

/* Fallback für Pages, die nur das Klassen-Pattern, nicht body-Klasse setzen */
.pub-standalone {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: var(--pub-bg-page);
}

.pub-standalone__header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--pub-border);
    background: var(--pub-bg-surface);
}

.pub-standalone__logo {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: var(--pub-text);
    text-decoration: none;
}

.pub-standalone__logo img {
    height: 56px;
    width: auto;
}

.pub-standalone__logo span {
    font-size: 1.1rem;
    font-weight: 600;
    line-height: 1.2;
}

.pub-standalone__main {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
}

.pub-standalone__footer {
    padding: 16px 24px;
    border-top: 1px solid var(--pub-border);
    background: var(--pub-bg-surface);
    color: var(--pub-text-muted);
    font-size: 0.85rem;
    text-align: center;
}

/* ----------------------------------------------------------------
   Mobile
   ---------------------------------------------------------------- */
@media (max-width: 760px) {
    .pub-container { padding: 16px 14px; }

    .pub-page-header h1 { font-size: 1.4rem; }

    .pub-standalone__logo span { font-size: 1rem; }
    .pub-standalone__logo img  { height: 48px; }
}
