/* ============================================================
   Stonecliffe Platform — App Shell
   Navy left sidebar + light content area, with a Harbour-blue
   accent and green/amber/red status colours.
   ============================================================ */

:root {
    --sc-ink: #16202e;
    --sc-sidebar: #0e2a47;
    --sc-sidebar-text: #9fb6d4;
    --sc-sidebar-active: #ffffff;
    --sc-content-bg: #f6f8fb;
    --sc-card: #ffffff;
    --sc-hairline: #dce3ec;
    --sc-muted: #586173;

    /* accent + semantic palette */
    --sc-accent: #1d5fa8;
    --sc-accent-2: #5b9bd5;
    --sc-accent-soft: #e7f0fa;
    --sc-good: #1e8e6a;
    --sc-good-soft: #e3f4ee;
    --sc-warn: #c9821c;
    --sc-warn-soft: #faf0db;
    --sc-risk: #c0392b;
    --sc-risk-soft: #fbeceb;
}

/* ---------- Shell ---------- */
.sc-app {
    display: flex;
    min-height: 100vh;
}

.sc-sidebar {
    width: 240px;
    flex: 0 0 240px;
    background: linear-gradient(180deg, #143a5f 0%, #0e2a47 100%);
    color: var(--sc-sidebar-text);
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
}

.sc-sidebar-brand {
    padding: 22px 20px 18px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10);
    text-align: center;
}

.sc-sidebar-brand .sc-sidebar-logo {
    display: block;
    width: 180px;
    max-width: 84%;
    height: auto;
    margin: 0 auto 8px;
    filter: invert(1);          /* black logo -> white on the dark sidebar */
}

.sc-sidebar-brand .sc-subwordmark {
    color: var(--sc-sidebar-text);
    font-size: .62rem;
    letter-spacing: .22em;
    text-transform: uppercase;
    margin-top: 2px;
}

.sc-nav {
    list-style: none;
    margin: 10px 0 0;
    padding: 0;
    flex: 1 1 auto;
    overflow-y: auto;
}

.sc-nav a {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 22px;
    color: var(--sc-sidebar-text);
    text-decoration: none;
    font-size: .92rem;
    border-left: 3px solid transparent;
    transition: background .12s ease, color .12s ease;
}

.sc-nav a:hover {
    color: #fff;
    background: rgba(91, 155, 213, 0.12);
}

.sc-nav a.active {
    color: #fff;
    background: rgba(91, 155, 213, 0.20);
    border-left-color: var(--sc-accent-2);
    font-weight: 600;
}

.sc-nav a.active .sc-ico { opacity: 1; color: var(--sc-accent-2); }

.sc-nav .sc-ico {
    width: 18px;
    text-align: center;
    opacity: .85;
    flex: 0 0 18px;
}

.sc-sidebar-user {
    border-top: 1px solid rgba(255, 255, 255, 0.10);
    padding: 14px 20px;
    font-size: .85rem;
}

.sc-sidebar-user .sc-user-name {
    color: #fff;
    font-weight: 600;
    word-break: break-word;
}

.sc-sidebar-user a {
    color: var(--sc-sidebar-text);
    text-decoration: none;
}

.sc-sidebar-user a:hover { color: #fff; text-decoration: underline; }

/* ---------- Main ---------- */
.sc-main {
    flex: 1 1 auto;
    background: var(--sc-content-bg);
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.sc-topbar {
    background: #fff;
    border-bottom: 1px solid var(--sc-hairline);
    border-top: 3px solid var(--sc-accent);
    padding: 16px 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.sc-topbar .sc-page-title {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .10em;
    font-size: 1.05rem;
    margin: 0;
    color: var(--sc-accent);
}

.sc-topbar .sc-user {
    color: var(--sc-muted);
    font-size: .9rem;
}

.sc-content {
    padding: 26px 28px;
    flex: 1 1 auto;
}

/* ---------- KPI cards ---------- */
.sc-kpi-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 22px;
}

.sc-kpi {
    background: var(--sc-card);
    border: 1px solid var(--sc-hairline);
    border-top: 3px solid var(--sc-accent);
    border-radius: 5px;
    padding: 18px 20px;
    box-shadow: 0 1px 2px rgba(20, 30, 50, 0.04);
}

.sc-kpi .sc-kpi-label {
    text-transform: uppercase;
    letter-spacing: .07em;
    font-size: .68rem;
    color: var(--sc-muted);
    margin-bottom: 6px;
}

.sc-kpi .sc-kpi-value {
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--sc-accent);
    line-height: 1.1;
}

.sc-kpi .sc-kpi-sub {
    font-size: .72rem;
    color: var(--sc-muted);
    margin-top: 4px;
}

/* accent variants for specific KPI tiles */
.sc-kpi.kpi-good { border-top-color: var(--sc-good); }
.sc-kpi.kpi-good .sc-kpi-value { color: var(--sc-good); }
.sc-kpi.kpi-warn { border-top-color: var(--sc-warn); }
.sc-kpi.kpi-warn .sc-kpi-value { color: var(--sc-warn); }
.sc-kpi.kpi-risk { border-top-color: var(--sc-risk); }
.sc-kpi.kpi-risk .sc-kpi-value { color: var(--sc-risk); }

/* ---------- Panels ---------- */
.sc-panel {
    background: var(--sc-card);
    border: 1px solid var(--sc-hairline);
    border-radius: 5px;
    padding: 18px 20px;
    box-shadow: 0 1px 2px rgba(20, 30, 50, 0.04);
}

.sc-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}

.sc-panel-head h2 {
    font-size: .8rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin: 0;
    color: var(--sc-accent);
    padding-left: 10px;
    border-left: 3px solid var(--sc-accent);
}

.sc-panel-head a { font-size: .78rem; color: var(--sc-accent); text-decoration: none; font-weight: 600; }
.sc-panel-head a:hover { color: var(--sc-accent-2); text-decoration: underline; }

/* ---------- Chart cards ---------- */
.sc-chart-card {
    background: var(--sc-card);
    border: 1px solid var(--sc-hairline);
    border-radius: 5px;
    padding: 16px 18px;
    box-shadow: 0 1px 2px rgba(20, 30, 50, 0.04);
    height: 100%;
}
.sc-chart-card h3 {
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--sc-ink);
    margin: 0 0 12px;
}
.sc-chart-wrap { position: relative; height: 260px; }

/* ---------- Stage columns ---------- */
.sc-stage-col {
    background: var(--sc-card);
    border: 1px solid var(--sc-hairline);
    border-radius: 5px;
    overflow: hidden;
    height: 100%;
}

.sc-stage-col .sc-stage-head {
    padding: 12px 14px;
    border-bottom: 1px solid var(--sc-hairline);
    border-top: 3px solid var(--sc-accent);
}

.sc-stage-head .sc-stage-no {
    color: var(--sc-accent);
    font-weight: 700;
    margin-right: 6px;
}

.sc-stage-head .sc-stage-name {
    text-transform: uppercase;
    letter-spacing: .05em;
    font-size: .72rem;
    font-weight: 700;
}

.sc-proj-card {
    padding: 11px 14px;
    border-bottom: 1px solid #f0f0ee;
}

.sc-proj-card:last-child { border-bottom: 0; }
.sc-proj-card .sc-proj-name { font-weight: 600; font-size: .9rem; color: var(--sc-accent); text-decoration: none; }
.sc-proj-card .sc-proj-name:hover { text-decoration: underline; }
.sc-proj-card .sc-proj-addr { color: var(--sc-muted); font-size: .76rem; }

/* status dot badges */
.sc-status { font-size: .72rem; display: inline-flex; align-items: center; gap: 5px; }
.sc-status .dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.sc-status.on-track .dot { background: var(--sc-good); }
.sc-status.on-track { color: var(--sc-good); }
.sc-status.at-risk .dot { background: var(--sc-risk); }
.sc-status.at-risk { color: var(--sc-risk); font-weight: 600; }

/* shared status pill (works on any page) */
.sc-pill { display: inline-block; font-size: .7rem; font-weight: 600; padding: 2px 9px; border-radius: 999px; }
.sc-pill.good { background: var(--sc-good-soft); color: var(--sc-good); }
.sc-pill.warn { background: var(--sc-warn-soft); color: var(--sc-warn); }
.sc-pill.risk { background: var(--sc-risk-soft); color: var(--sc-risk); }
.sc-pill.accent { background: var(--sc-accent-soft); color: var(--sc-accent); }

/* ---------- list rows (deadlines / activity) ---------- */
.sc-list-row {
    display: flex;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid #f0f0ee;
    align-items: flex-start;
}
.sc-list-row:last-child { border-bottom: 0; }

.sc-date-chip {
    flex: 0 0 46px;
    text-align: center;
    border: 1px solid var(--sc-hairline);
    border-radius: 4px;
    padding: 4px 0;
    line-height: 1.1;
    background: var(--sc-accent-soft);
}
.sc-date-chip .m { font-size: .6rem; text-transform: uppercase; color: var(--sc-accent); letter-spacing: .05em; }
.sc-date-chip .d { font-size: 1.05rem; font-weight: 700; color: var(--sc-accent); }

.sc-list-row .sc-row-main { flex: 1 1 auto; min-width: 0; }
.sc-list-row .sc-row-title { font-weight: 600; font-size: .86rem; color: var(--sc-ink); }
.sc-list-row .sc-row-sub { font-size: .76rem; color: var(--sc-muted); }
.sc-list-row .sc-row-meta { font-size: .72rem; color: var(--sc-muted); white-space: nowrap; }
.sc-list-row .sc-row-meta.overdue { color: var(--sc-risk); font-weight: 700; }

/* ---------- bootstrap accents (carry colour to other pages) ---------- */
.sc-content .btn-primary { background-color: var(--sc-accent); border-color: var(--sc-accent); }
.sc-content .btn-primary:hover { background-color: #16487f; border-color: #16487f; }
.sc-content .btn-outline-primary { color: var(--sc-accent); border-color: var(--sc-accent); }
.sc-content .btn-outline-primary:hover { background-color: var(--sc-accent); border-color: var(--sc-accent); }
.sc-content .table > thead th { color: var(--sc-accent); border-bottom: 2px solid var(--sc-accent-soft); }
.sc-content a:not(.btn):not(.badge):not(.nav-link) { color: var(--sc-accent); }
.sc-content .badge.bg-dark { background-color: var(--sc-accent) !important; }

/* ---------- map ---------- */
#sc-map, #sc-map-full { width: 100%; border-radius: 4px; border: 1px solid var(--sc-hairline); }
#sc-map { height: 260px; }
#sc-map-full { height: 70vh; }
.leaflet-container { font-family: Arial, sans-serif; }

/* ---------- responsive ---------- */
@media (max-width: 900px) {
    .sc-app { flex-direction: column; }
    .sc-sidebar { width: 100%; flex-basis: auto; height: auto; position: static; flex-direction: column; }
    .sc-nav { display: flex; flex-wrap: wrap; }
    .sc-nav a { border-left: 0; border-bottom: 3px solid transparent; padding: 10px 14px; }
    .sc-nav a.active { border-left: 0; border-bottom-color: var(--sc-accent-2); }
}
