/* Sencargo Global Stylesheet */

/* --- Backend Logistics & Dispatch Dashboard --- */
.dispatch-grid { display: grid; grid-template-columns: 350px 1fr; gap: 20px; margin-top: 20px; }
.sc-column { background: #fff; padding: 15px; border-radius: 8px; box-shadow: 0 2px 10px rgba(0,0,0,0.05); height: 800px; overflow-y: auto; }
.sc-draggable-stop { background: #f9f9f9; border: 1px solid #ddd; padding: 10px; margin-bottom: 10px; border-radius: 5px; cursor: grab; display: flex; flex-direction: column; gap: 5px; position:relative; }
.sc-draggable-stop:active { cursor: grabbing; }
.driver-container { border: 2px dashed #ccc; padding: 10px; margin-bottom: 20px; min-height: 100px; border-radius: 5px; background: #fafafa; }
.driver-header { font-weight: bold; font-size: 16px; margin-bottom: 10px; color: #942428; display: flex; justify-content: space-between; align-items:center; }
#sc-map-canvas { width: 100%; height: 100%; border-radius: 8px; border: 1px solid #ccc; min-height: 600px; z-index: 1; }
.route-stats { font-size: 12px; color: #555; font-weight: normal; margin-top:5px; display:block; }
.stop-number { position:absolute; top:10px; right:10px; background:#333; color:#fff; width:20px; height:20px; border-radius:50%; text-align:center; line-height:20px; font-size:11px; font-weight:bold; }

/* --- Frontend Customer Dashboard (Premium Glassmorphism Navigation) --- */
.sc-nav-tabs {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    background: rgba(255, 255, 255, 0.3) !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    border: 1px solid rgba(255, 255, 255, 0.4) !important;
    border-radius: 15px !important;
    padding: 15px !important;
    gap: 15px !important;
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.05) !important;
    margin-bottom: 25px !important;
}
.sc-nav-tab {
    position: relative !important;
    flex: 0 1 auto !important;
    background: rgba(255, 255, 255, 0.6) !important;
    border: 1px solid rgba(255, 255, 255, 0.5) !important;
    border-radius: 10px !important;
    color: #2c3e50 !important;
    font-weight: 700 !important;
    padding: 12px 25px !important;
    box-shadow: 0 4px 6px rgba(0,0,0,0.02) !important;
    text-decoration: none !important;
    transition: all 0.3s ease !important;
}
.sc-nav-tab.active, .sc-nav-tab:hover {
    background: rgba(148, 36, 40, 0.9) !important;
    color: #ffffff !important;
    border-color: rgba(148, 36, 40, 0.4) !important;
    box-shadow: 0 8px 15px rgba(148,36,40,0.2) !important;
    transform: translateY(-2px) !important;
}
.sc-badge {
    background: #e74c3c !important;
    color: #ffffff !important;
    font-size: 11px !important;
    padding: 3px 7px !important;
    border-radius: 50% !important;
    position: absolute !important;
    top: -8px !important;
    right: -8px !important;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2) !important;
    border: 2px solid #fff;
}

/* --- High-Contrast Action Buttons --- */
.sc-modern-btn:not(.sc-btn-outline) {
    color: #ffffff !important;
}
.sc-modern-btn {
    display: inline-block;
    background: #942428;
    color: #ffffff;
    padding: 10px 20px;
    border: none;
    border-radius: 6px;
    font-weight: bold;
    cursor: pointer;
    transition: 0.2s;
    text-decoration: none;
    text-align: center;
}
.sc-modern-btn:not(.sc-btn-outline):hover {
    background: #7a1d21;
    color: #ffffff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 10px rgba(0,0,0,0.15);
}
.sc-modern-btn.sc-btn-outline {
    color: #942428;
}
.sc-modern-btn.sc-btn-outline:hover {
    color: #ffffff !important;
}

/* --- Newsletter Popup (Guests) --- */
.sc-nl-overlay{
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 999999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.sc-nl-card{
    width: 100%;
    max-width: 420px;
    background: rgba(255,255,255,0.92);
    border: 1px solid rgba(255,255,255,0.45);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-radius: 16px;
    padding: 22px;
    box-shadow: 0 10px 32px rgba(31,38,135,0.18);
    position: relative;
}
.sc-nl-close{
    position: absolute;
    top: 10px;
    right: 12px;
    background: none;
    border: none;
    font-size: 22px;
    cursor: pointer;
    color: #2c3e50;
}
.sc-btn-outline {
    background: transparent;
    border: 2px solid #942428;
    color: #942428;
}
.sc-btn-outline:hover {
    background: #942428;
    color: #ffffff !important;
}

/* Driver portal tabs: avoid .sc-btn-outline forcing maroon text on active burgundy background */
.sc-driver-portal-tab {
    display: inline-block;
    padding: 10px 14px;
    font-size: 13px;
    font-weight: bold;
    border-radius: 6px;
    border: 2px solid #dee2e6;
    background: #ffffff;
    color: #2c3e50;
    text-decoration: none;
    cursor: pointer;
    transition: 0.2s;
}
.sc-driver-portal-tab:hover {
    border-color: #942428;
    color: #942428;
}
.sc-driver-portal-tab.is-active {
    background: #942428;
    border-color: #942428;
    color: #ffffff;
}
.sc-driver-portal-tab.is-active:hover {
    background: #7a1d21;
    border-color: #7a1d21;
    color: #ffffff;
}

/* --- Accordion & Modal Layouts --- */
.sc-accordion-card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 8px;
    margin-bottom: 15px;
    padding: 20px;
    cursor: pointer;
    transition: 0.2s;
    position: relative;
}
.sc-accordion-card:hover {
    border-color: #942428;
    box-shadow: 0 4px 12px rgba(148,36,40,0.05);
}
.sc-accordion-content {
    display: none;
    margin-top: 15px;
    border-top: 1px dashed #eee;
    padding-top: 15px;
    cursor: default;
}

.sc-modal-overlay {
    display: none;
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0,0,0,0.6);
    z-index: 99999;
    justify-content: center;
    align-items: center;
}
.sc-modal-content {
    background: #fff;
    width: 100%;
    max-width: 800px;
    max-height: 90vh;
    overflow-y: auto;
    border-radius: 12px;
    padding: 35px;
    position: relative;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}
.sc-modal-close {
    position: absolute;
    top: 15px; right: 20px;
    font-size: 28px;
    cursor: pointer;
    background: none;
    border: none;
    color: #777;
}

/* --- Form Inputs & Cards --- */
.sc-input-modern {
    width: 100%;
    padding: 12px;
    border: 1px solid #ddd;
    border-radius: 6px;
    box-sizing: border-box;
    background: #fafafa;
}
.sc-input-modern:focus {
    border-color: #942428;
    outline: none;
    background: #fff;
}
.sc-wizard-step { display: none; }
.sc-wizard-step.active {
    display: block;
    animation: scFadeIn 0.3s ease-in;
}
@keyframes scFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}
.sc-choice-card {
    border: 2px solid #ddd;
    border-radius: 8px;
    padding: 20px;
    cursor: pointer;
    transition: 0.2s;
    margin-bottom: 15px;
    background: #fafafa;
}
.sc-choice-card.selected {
    border-color: #942428;
    background: #942428;
    color: #ffffff !important;
}
.sc-choice-card.selected h4, .sc-choice-card.selected p {
    color: #ffffff !important;
}