/* v.1.00 - Starter kit: layout base */

/*region VARIABILI E RESET */
:root {
    --module-color: #0072BC;
    --module-color-light: color-mix(in srgb, var(--module-color) 15%, white);
    --module-color-dark: color-mix(in srgb, var(--module-color) 85%, black);
    --text-color: #333;
    --bg-color: #f5f5f5;
    --white: #fff;
    --border-color: #ddd;
    --font-family: 'Open Sans', sans-serif;
}

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400;600;700&display=swap');

* { box-sizing: border-box; }

body {
    font-family: var(--font-family);
    font-size: 16px;
    color: var(--text-color);
    background: var(--bg-color);
    margin: 0;
    padding: 0;
}
/*endregion VARIABILI E RESET */

/*region LAYOUT GENERALE */

    /*region Navbar */
    .navbar {
        background-color: var(--module-color) !important;
    }

    .navbar .nav-link {
        color: rgba(255, 255, 255, 0.85) !important;
        font-size: 14px;
    }

    .navbar .nav-link:hover,
    .navbar .nav-link.active {
        color: var(--white) !important;
    }

    .navbar .user-info {
        color: var(--white);
        font-size: 13px;
        padding: 0.5rem 1rem;
        border: 1px solid rgba(255, 255, 255, 0.3);
        border-radius: 4px;
        margin-right: 1rem;
    }
    /*endregion Navbar */

    /*region Content area */
    #wrapper {
        max-width: 1200px;
        margin: 80px auto 30px auto;
        padding: 30px;
        background: var(--white);
        border: 1px solid var(--border-color);
        border-radius: 4px;
    }

    h1 {
        font-size: 28px;
        font-weight: 300;
        color: var(--module-color);
        border-bottom: 1px solid var(--module-color);
        padding-bottom: 10px;
        margin-bottom: 20px;
    }

    h2 {
        font-size: 22px;
        font-weight: 400;
        color: var(--module-color);
        margin-bottom: 15px;
    }

    h3 {
        font-size: 18px;
        font-weight: 600;
        color: var(--module-color-dark);
        margin-bottom: 10px;
    }

    .page-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 20px;
    }

    .page-header h1 {
        margin-bottom: 0;
        border-bottom: none;
        padding-bottom: 0;
    }
    /*endregion Content area */

    /*region Bottoni */
    .btn-module {
        background-color: var(--module-color);
        border-color: var(--module-color);
        color: var(--white);
    }

    .btn-module:hover {
        background-color: var(--module-color-dark);
        border-color: var(--module-color-dark);
        color: var(--white);
    }
    /*endregion Bottoni */

    /*region Tabelle */
    .table thead th {
        background-color: var(--module-color);
        color: var(--white);
        font-weight: 600;
        font-size: 14px;
    }
    /*endregion Tabelle */

    /*region Utilita */
    .text-module { color: var(--module-color); }
    .bg-module { background-color: var(--module-color); }
    .border-module { border-color: var(--module-color) !important; }
    .ok { color: green; }
    .ko { color: red; }
    /*endregion Utilita */

/*endregion LAYOUT GENERALE */

/*region LOGIN */
body.login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background-color: var(--bg-color);
}

body.login #wrapper {
    margin: 0;
    max-width: 400px;
    width: 100%;
    text-align: center;
}

body.login .form-signin {
    width: 100%;
    padding: 15px;
}

body.login .form-signin .form-control {
    padding: 10px;
    font-size: 16px;
    margin-bottom: 10px;
}

body.login .form-signin .btn-module {
    width: 100%;
    margin-top: 20px;
    padding: 10px;
    font-size: 16px;
}

body.login .login-error {
    color: #dc3545;
    margin-top: 10px;
    font-size: 14px;
}
/*endregion LOGIN */

/*region SETUP */
body.setup #wrapper {
    max-width: 600px;
}

body.setup #confirmation {
    text-align: center;
}

body.setup #confcontent {
    text-align: left;
    margin: 20px 0;
}
/*endregion SETUP */

/*region RESPONSIVE */
@media (max-width: 767px) {
    #wrapper {
        margin: 70px 10px 20px 10px;
        padding: 15px;
    }
}
/*endregion RESPONSIVE */
