/* v.1.09 - Toolbar dettaglio, vista stampa tabella, regole @media print */

/*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 PRENOTAZIONI */

    /*region Filtro data */
    .filter-bar {
        display: flex;
        align-items: center;
        gap: 8px;
        margin-bottom: 15px;
        flex-wrap: wrap;
    }

    .filter-date-form {
        display: flex;
        align-items: center;
        gap: 4px;
    }

    .filter-date-form input[type="date"] {
        width: auto;
    }
    /*endregion Filtro data */

    /*region Riepilogo */
    .reservation-summary {
        padding: 10px 15px;
        background: var(--module-color-light);
        border-left: 4px solid var(--module-color);
        border-radius: 0 4px 4px 0;
        margin-bottom: 20px;
        font-size: 15px;
    }
    /*endregion Riepilogo */

    /*region Service card (lista sintesi) */
    .service-card {
        display: block;
        border: 1px solid var(--border-color);
        border-left: 4px solid var(--module-color);
        border-radius: 0 6px 6px 0;
        padding: 12px 15px;
        margin-bottom: 8px;
        background: var(--white);
        text-decoration: none;
        color: var(--text-color);
        transition: background-color 0.15s;
    }

    .service-card:hover {
        background-color: var(--module-color-light);
        color: var(--text-color);
        text-decoration: none;
    }

    .service-card-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        margin-bottom: 4px;
    }

    .service-card-name {
        font-size: 16px;
        font-weight: 600;
        color: var(--module-color-dark);
    }

    .service-card-pax {
        font-weight: 600;
        color: var(--module-color);
        font-size: 15px;
        white-space: nowrap;
    }

    .service-card-info {
        display: flex;
        gap: 15px;
        font-size: 14px;
        color: #666;
    }

    .service-card-time i,
    .service-card-pax i {
        font-size: 12px;
        margin-right: 3px;
    }
    /*endregion Service card (lista sintesi) */

    /*region Header dettaglio servizio */
    .detail-header {
        background: var(--module-color);
        color: var(--white);
        padding: 20px 25px;
        border-radius: 6px;
        text-align: center;
        margin: -30px -30px 20px -30px;
        border-radius: 4px 4px 0 0;
    }

    .detail-header-meta {
        font-size: 14px;
        opacity: 0.9;
        margin-bottom: 6px;
    }

    .detail-header-title {
        font-size: 26px;
        font-weight: 300;
        color: var(--white);
        border-bottom: none;
        padding-bottom: 0;
        margin-bottom: 6px;
    }

    .detail-header-count {
        font-size: 14px;
        opacity: 0.85;
    }
    /*endregion Header dettaglio servizio */

    /*region Card transazione */
    .reservation-card {
        border: 1px solid var(--border-color);
        border-radius: 6px;
        padding: 15px 20px;
        margin-bottom: 10px;
        background: var(--white);
    }

    .reservation-trans-nr {
        font-size: 12px;
        color: #999;
        margin-bottom: 4px;
    }

    .reservation-guest {
        font-size: 16px;
        font-weight: 700;
        margin-bottom: 8px;
    }

    .reservation-product-line {
        font-size: 14px;
        color: #555;
        margin-bottom: 4px;
        padding-left: 10px;
    }

    .reservation-contact-line {
        display: flex;
        gap: 20px;
        flex-wrap: wrap;
        margin-top: 10px;
        font-size: 14px;
    }

    .reservation-contact-line a {
        color: var(--module-color);
        text-decoration: none;
    }

    .reservation-contact-line a:hover {
        color: var(--module-color-dark);
    }

    .reservation-message {
        margin-top: 6px;
        padding: 6px 10px;
        background: #fff8e1;
        border-radius: 4px;
        font-size: 13px;
        color: #795548;
    }

    .reservation-message i {
        color: #ff9800;
        margin-right: 4px;
    }
    /*endregion Card transazione */

    /*region Checkout questions */
    .checkout-questions {
        margin-top: 10px;
        padding: 10px 15px;
        background: #f0f7ff;
        border-left: 3px solid var(--module-color);
        border-radius: 0 4px 4px 0;
        font-size: 13px;
    }

    .checkout-booking-section {
        margin-bottom: 8px;
        padding-bottom: 8px;
        border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    }

    .checkout-question-row {
        display: flex;
        gap: 6px;
        padding: 2px 0;
    }

    .checkout-question-label {
        color: #666;
    }

    .checkout-question-answer {
        font-weight: 600;
        color: var(--text-color);
    }

    .checkout-person-group {
        margin-top: 6px;
    }

    .checkout-person-header {
        font-weight: 600;
        color: var(--text-color);
        margin-bottom: 2px;
    }

    .checkout-question-indented {
        padding-left: 15px;
    }
    /*endregion Checkout questions */

    /*region Toolbar dettaglio */
    .detail-toolbar {
        display: flex;
        gap: 8px;
        align-items: center;
        margin-bottom: 20px;
    }
    /*endregion Toolbar dettaglio */

    /*region Vista stampa (tabella) */
    .print-table {
        font-size: 13px;
    }

    .print-table thead th {
        font-size: 12px;
        white-space: nowrap;
    }

    .print-checkout-cell {
        font-size: 12px;
        line-height: 1.6;
        max-width: 350px;
    }
    /*endregion Vista stampa (tabella) */

    /*region Vista lista prossime attivita */
    .nav-tabs .nav-link {
        color: var(--text-color);
        font-size: 15px;
    }

    .nav-tabs .nav-link.active {
        color: var(--module-color);
        font-weight: 600;
        border-bottom-color: var(--module-color);
    }

    .activity-list {
        display: flex;
        flex-direction: column;
        gap: 6px;
    }

    .activity-row {
        display: flex;
        align-items: center;
        gap: 0;
        border: 1px solid var(--border-color);
        border-radius: 6px;
        padding: 10px 15px;
        background: var(--white);
        text-decoration: none;
        color: var(--text-color);
        transition: background-color 0.15s;
    }

    .activity-row:hover {
        background-color: var(--module-color-light);
        color: var(--text-color);
        text-decoration: none;
    }

    .activity-day {
        width: 40px;
        font-size: 14px;
        color: #666;
        flex-shrink: 0;
    }

    .activity-date {
        width: 70px;
        font-size: 14px;
        font-weight: 600;
        flex-shrink: 0;
    }

    .activity-time {
        width: 100px;
        font-size: 14px;
        color: #666;
        flex-shrink: 0;
    }

    .activity-pax {
        width: 50px;
        font-size: 14px;
        font-weight: 600;
        color: var(--module-color);
        flex-shrink: 0;
        text-align: right;
        padding-right: 15px;
    }

    .activity-name {
        flex: 1;
        font-size: 14px;
        color: var(--module-color);
        font-weight: 600;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .activity-pagination {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 15px;
        margin-top: 20px;
        padding-top: 15px;
        border-top: 1px solid var(--border-color);
    }

    .activity-pagination-info {
        font-size: 13px;
        color: #666;
    }
    /*endregion Vista lista prossime attivita */

/*endregion PRENOTAZIONI */

/*region LOG VIEWER */
.log-filters {
    display: flex;
    gap: 10px;
    align-items: end;
    margin-bottom: 20px;
    flex-wrap: wrap;
}

.log-filters .form-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.log-filters label {
    font-size: 12px;
    font-weight: 600;
    color: #666;
}

.log-message-cell {
    max-width: 400px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.log-context-cell {
    font-size: 12px;
    color: #666;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
/*endregion LOG VIEWER */

/*region ADMIN FORMS */
.admin-form {
    max-width: 600px;
}

.admin-form .form-group {
    margin-bottom: 15px;
}

.admin-form label {
    font-weight: 600;
    font-size: 14px;
}

.admin-form .form-text {
    font-size: 12px;
    color: #666;
}

.readonly-info {
    font-size: 13px;
    color: #666;
    padding: 6px 0;
    line-height: 1.8;
}

.table .row-inactive {
    opacity: 0.5;
}
/*endregion ADMIN FORMS */

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

    .detail-header {
        margin: -15px -15px 15px -15px;
        padding: 15px;
    }

    .reservation-contact-line {
        flex-direction: column;
        gap: 4px;
    }

    .checkout-question-row {
        flex-direction: column;
        gap: 1px;
    }

    .checkout-question-label {
        min-width: 0;
    }

    .log-filters {
        flex-direction: column;
        align-items: stretch;
    }

    .activity-row {
        flex-wrap: wrap;
        gap: 4px;
    }

    .activity-day {
        width: 35px;
    }

    .activity-date {
        width: 65px;
    }

    .activity-time {
        width: 85px;
    }

    .activity-name {
        width: 100%;
        white-space: normal;
        padding-top: 4px;
    }
}
/*endregion RESPONSIVE */

/*region PRINT */
@media print {
    .navbar, .no-print, .env-badge {
        display: none !important;
    }

    body {
        font-size: 11px;
        background: #fff;
    }

    #wrapper {
        margin: 0;
        padding: 10px;
        border: none;
        max-width: 100%;
    }

    .detail-header {
        margin: -10px -10px 10px -10px;
        padding: 10px;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    .print-table {
        font-size: 11px;
    }

    .print-table thead th {
        font-size: 10px;
        -webkit-print-color-adjust: exact;
        print-color-adjust: exact;
    }

    .print-checkout-cell {
        font-size: 10px;
        max-width: none;
    }

    .table {
        page-break-inside: auto;
    }

    .table tr {
        page-break-inside: avoid;
    }
}
/*endregion PRINT */
