/* misterschool-clean-lite.css
   Preset sobrio/neutro ispirato a MisterSchool.
   Dipende da core.css.
*/

:root {
    --bg: #ffffff;
    --fg: #102a43;
    --muted: #52606d;
    --link: #0b4f8a;
    --border: #e6ebf1;

    --brand-primary: #0b4f8a;
    --brand-secondary: #243b53;
    --brand-accent: #f28c28;

    --surface: #ffffff;
    --surface-soft: #f7f9fb;

    --radius-sm: 6px;
    --radius-md: 10px;

    --shadow-soft: 0 2px 10px rgba(16, 42, 67, 0.05);
}

/* Base */

body {
    background: var(--bg);
    color: var(--fg);
}

/* Links */

a {
    color: var(--link);
    transition: color 0.2s ease;
}

a:hover {
    color: var(--brand-accent);
}

/* Header */

.site-header {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
}

/* Main */

.site-inner {
    background: var(--bg);
}

/* Footer */

.site-footer {
    background: var(--surface);
    border-top: 1px solid var(--border);
    color: var(--muted);
    font-size: 0.9rem;
}

/* Navigation */

.nav.nav--primary {
    color: var(--brand-primary);
}

.nav__link {
    color: var(--brand-primary);
    border-radius: var(--radius-sm);
    transition: color 0.2s ease;
}

.nav__link:hover {
    color: var(--brand-accent);
}

.nav__link.is-current {
    color: var(--brand-secondary);
    text-decoration-color: var(--brand-accent);
}

/* Breadcrumb */

.breadcrumb {
    color: var(--muted);
}

.breadcrumb a:hover {
    color: var(--brand-accent);
}

/* Document */

.doc {
    background: var(--surface);
    color: var(--fg);
}

.doc__header {
    margin-bottom: 18px;
}

.doc__title,
.doc h1,
.doc h2,
.doc h3 {
    color: var(--brand-primary);
    line-height: 1.22;
}

.doc p,
.content p {
    color: var(--brand-secondary);
}

/* Optional card-like document */

.doc--boxed {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
    padding: 24px;
}

/* Generic soft boxes */

.section,
.panel,
.card,
.box {
    background: var(--surface-soft);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-soft);
}

/* Cards */

.card {
    padding: 20px;
}

.card h2,
.card h3 {
    color: var(--brand-primary);
}

.card p {
    color: var(--muted);
}

/* Buttons */

button,
.button,
.btn,
a.button,
a.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    padding: 9px 18px;
    border: 1px solid var(--brand-primary);
    border-radius: var(--radius-sm);

    background: var(--brand-primary);
    color: #ffffff;

    font: inherit;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;

    transition:
        background-color 0.2s ease,
        color 0.2s ease,
        border-color 0.2s ease;
}

button:hover,
.button:hover,
.btn:hover,
a.button:hover,
a.btn:hover {
    background: #ffffff;
    color: var(--brand-primary);
    text-decoration: none;
}

/* Secondary button */

.button--secondary,
.btn--secondary {
    background: #ffffff;
    color: var(--brand-primary);
}

.button--secondary:hover,
.btn--secondary:hover {
    background: var(--brand-accent);
    border-color: var(--brand-accent);
    color: #ffffff;
}

/* Lists */

.list {
    color: var(--brand-secondary);
}

/* Errors */

.error {
    padding: 14px 16px;
    border-left: 4px solid #c62828;
    background: #fff5f5;
    color: #8a1f1f;
    border-radius: var(--radius-sm);
}

/* Forms */

input[type="text"],
input[type="password"],
input[type="email"],
input[type="url"],
textarea,
select {
    width: 100%;
    padding: 10px 12px;

    border: 1px solid var(--border);
    border-radius: var(--radius-sm);

    background: #ffffff;
    color: var(--fg);

    font: inherit;
}

input:focus,
textarea:focus,
select:focus {
    outline: 2px solid rgba(242, 140, 40, 0.25);
    border-color: var(--brand-accent);
}

/* Mobile */

@media (max-width: 700px) {
    :root {
        --nav-h: auto;
        --nav-px: 8px;
        --nav-gap: 6px;
        --nav-font-size: 0.95rem;
    }

    .wrap {
        padding: 0 14px;
    }

    .nav__list {
        flex-wrap: wrap;
        min-height: auto;
    }

    .nav__link {
        min-height: auto;
        padding: 8px 10px;
    }

    .doc--boxed {
        padding: 18px;
    }
}