:root {
    --brand-primary: #0B2A5B;
    --brand-primary-2: #1D4ED8;
    --brand-accent: #22C55E;
    --brand-accent-dark: #16A34A;
    --brand-bg: #F8FAFC;
    --brand-surface: #FFFFFF;
    --brand-text: #0F172A;
    --brand-muted: #475569;
    --brand-border: #E2E8F0;
    --brand-soft: #EFF6FF;
}

* { box-sizing: border-box; }
body {
    margin: 0;
    font-family: Arial, Helvetica, sans-serif;
    background: var(--brand-bg);
    color: var(--brand-text);
}
a { color: var(--brand-primary-2); text-decoration: none; }
a:hover { text-decoration: underline; }
.login-page {
    display: flex; align-items: center; justify-content: center; min-height: 100vh;
    background: linear-gradient(135deg, var(--brand-primary-2) 0%, var(--brand-primary) 100%);
}
.login-card {
    width: 100%; max-width: 430px; background: #fff; padding: 32px; border-radius: 18px;
    box-shadow: 0 20px 45px rgba(0,0,0,0.16);
}
.login-card h1 { margin: 0 0 10px; }
.login-card p { margin: 0 0 20px; color: var(--brand-muted); }
.login-help {
    margin-top: 18px; padding: 12px; background: #F8FAFC; border: 1px solid var(--brand-border); border-radius: 12px; font-size: 14px;
}
label {
    display: block; margin-bottom: 6px; margin-top: 12px; font-size: 14px; font-weight: 600;
}
input, select, textarea {
    width: 100%; padding: 12px 14px; border: 1px solid var(--brand-border); border-radius: 12px; background: #fff;
}
input:focus, select:focus, textarea:focus {
    outline: none; border-color: var(--brand-primary-2); box-shadow: 0 0 0 3px rgba(13,110,253,0.12);
}
button, .btn {
    display: inline-block; background: var(--brand-primary-2); color: #fff; border: none; padding: 12px 18px; border-radius: 12px;
    cursor: pointer; text-decoration: none; font-weight: 600;
}
button:hover, .btn:hover { opacity: 0.94; text-decoration: none; }
.btn-light { background: var(--brand-border); color: var(--brand-primary); }
.btn-sm { padding: 8px 12px; border-radius: 10px; font-size: 13px; }
.btn-warning { background: #f59e0b; color: var(--brand-primary); }
.btn-danger { background: #dc2626; color: #fff; }
.alert {
    padding: 12px 14px; border-radius: 12px; margin: 14px 0;
}
.alert-danger { background: #FEE2E2; color: #991b1b; }
.alert-success { background: #DCFCE7; color: var(--brand-accent-dark); }
.alert-warning { background: #FEF3C7; color: #92400e; }
.alert-info { background: #DBEAFE; color: var(--brand-primary-2); }
.layout { display: flex; min-height: 100vh; }
.sidebar {
    width: 250px; background: var(--brand-primary); color: #fff; padding: 24px 20px;
}
.brand-block h2 { margin: 0 0 8px; }
.brand-block p { margin: 0 0 24px; color: #9ca3af; font-size: 14px; }
.sidebar nav a {
    display: block; color: var(--brand-border); text-decoration: none; padding: 12px 10px; border-radius: 10px; margin-bottom: 8px;
}
.sidebar nav a:hover, .sidebar nav a.nav-active { color: #fff; background: rgba(255,255,255,0.08); }
.content { flex: 1; padding: 28px; }
.page-header {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px;
}
.page-header h1 { margin: 0 0 6px; }
.page-header p { margin: 0; color: var(--brand-muted); }
.card {
    background: #fff; border-radius: 18px; padding: 20px; box-shadow: 0 12px 30px rgba(15,23,42,0.06); margin-bottom: 24px;
}
.section-title-row {
    display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap;
}
.section-title-row h2 { margin: 0; }
.action-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.stats-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px;
}
.stat-card h3 { margin: 0; color: var(--brand-muted); font-size: 14px; }
.stat-card strong { display: block; font-size: 30px; margin-top: 8px; }
.grid-2 {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.info-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px 24px; margin: 14px 0 20px;
}
.description-block {
    padding: 14px 16px; background: #F8FAFC; border: 1px solid var(--brand-border); border-radius: 14px;
}
.description-block p { margin: 8px 0 0; }
.grid-form {
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px 20px;
}
.col-span-2 { grid-column: span 2; }
.form-actions { display: flex; justify-content: flex-end; gap: 12px; flex-wrap: wrap; }
.filter-bar {
    display: grid; grid-template-columns: 1.1fr 1fr 1fr 1fr auto; gap: 12px; margin-bottom: 16px;
}
.metric-line {
    display: flex; gap: 14px; flex-wrap: wrap; color: var(--brand-muted); font-size: 14px; margin: 10px 0 0;
}
table { width: 100%; border-collapse: collapse; }
table th, table td {
    text-align: left; padding: 12px; border-bottom: 1px solid var(--brand-border); vertical-align: top;
}
table th { font-size: 13px; text-transform: uppercase; color: var(--brand-muted); }
.badge {
    display: inline-block; padding: 6px 10px; border-radius: 999px; font-size: 12px; font-weight: 700;
}
.badge-primary { background: #DBEAFE; color: var(--brand-primary-2); }
.badge-success { background: #DCFCE7; color: var(--brand-accent-dark); }
.badge-warning { background: #FEF3C7; color: #92400e; }
.badge-danger { background: #FEE2E2; color: #991b1b; }
.badge-secondary { background: var(--brand-border); color: #374151; }
.empty-note {
    padding: 18px; background: #F8FAFC; border: 1px dashed var(--brand-border); border-radius: 14px; color: var(--brand-muted);
}

.kanban-board {
    display: grid;
    grid-template-columns: repeat(5, minmax(240px, 1fr));
    gap: 18px;
    align-items: start;
}
.kanban-column {
    background: #eef2ff;
    border: 1px solid #DBEAFE;
    border-radius: 18px;
    padding: 14px;
    min-height: 320px;
}
.kanban-column-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    margin-bottom: 14px;
}
.kanban-column-head h3 {
    margin: 0;
    font-size: 16px;
}
.status-counter {
    min-width: 28px;
    height: 28px;
    border-radius: 999px;
    background: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    color: #334155;
}
.kanban-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.kanban-card {
    background: #fff;
    border-radius: 16px;
    padding: 14px;
    box-shadow: 0 8px 24px rgba(15,23,42,0.08);
    border: 1px solid var(--brand-border);
}
.kanban-card h4 {
    margin: 0 0 10px;
    font-size: 15px;
    line-height: 1.35;
}
.kanban-meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 13px;
    color: #64748b;
    margin-bottom: 12px;
}
.kanban-card-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.kanban-card form {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
    width: 100%;
}
.kanban-card select {
    min-width: 120px;
    padding: 9px 10px;
    border-radius: 10px;
    font-size: 13px;
}
.kanban-card .btn-sm {
    padding: 9px 10px;
}
.small-muted {
    color: #64748b;
    font-size: 13px;
}
@media (max-width: 1400px) {
    .kanban-board { grid-template-columns: repeat(3, minmax(240px, 1fr)); }
}
@media (max-width: 1100px) {
    .kanban-board { grid-template-columns: repeat(2, minmax(240px, 1fr)); }
}
@media (max-width: 980px) {
    .layout { flex-direction: column; }
    .sidebar { width: 100%; }
    .stats-grid, .grid-2, .info-grid, .grid-form, .filter-bar, .kanban-board { grid-template-columns: 1fr; }
    .col-span-2 { grid-column: span 1; }
}


.calendar-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.calendar-nav {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}
.calendar-nav-title {
    font-size: 22px;
    font-weight: 700;
    color: #0f172a;
}
.calendar-weekdays,
.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 12px;
}
.calendar-weekday {
    text-align: center;
    padding: 10px 8px;
    color: #64748b;
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
}
.calendar-day {
    min-height: 160px;
    background: #fff;
    border: 1px solid var(--brand-border);
    border-radius: 18px;
    padding: 12px;
    box-shadow: 0 8px 24px rgba(15,23,42,0.05);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.calendar-day.is-other-month {
    background: #F8FAFC;
    color: #94a3b8;
}
.calendar-day.is-today {
    border-color: #93c5fd;
    box-shadow: 0 0 0 3px rgba(13,110,253,0.12);
}
.calendar-day-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}
.calendar-day-number {
    font-size: 16px;
    font-weight: 700;
}
.calendar-event-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.calendar-event {
    display: block;
    padding: 8px 10px;
    border-radius: 12px;
    font-size: 12px;
    line-height: 1.35;
    text-decoration: none;
    border: 1px solid transparent;
}
.calendar-event:hover {
    text-decoration: none;
    opacity: 0.95;
}
.calendar-event.task {
    background: #DBEAFE;
    color: var(--brand-primary-2);
    border-color: #bfdbfe;
}
.calendar-event.milestone {
    background: #FEF3C7;
    color: #92400e;
    border-color: #fde68a;
}
.calendar-event small {
    display: block;
    margin-top: 3px;
    opacity: 0.85;
}
.calendar-more {
    font-size: 12px;
    color: #64748b;
    font-weight: 700;
}
.list-summary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
.summary-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.summary-item {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 14px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
.summary-item-main {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.summary-item-meta {
    color: #64748b;
    font-size: 13px;
}
@media (max-width: 1200px) {
    .calendar-weekdays,
    .calendar-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}
@media (max-width: 980px) {
    .calendar-weekdays,
    .calendar-grid,
    .list-summary {
        grid-template-columns: 1fr;
    }
}


.gantt-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}
.gantt-legend {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    color: #64748b;
    font-size: 13px;
    margin-top: 10px;
}
.legend-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.legend-color {
    width: 12px;
    height: 12px;
    border-radius: 999px;
}
.gantt-shell {
    overflow-x: auto;
    border: 1px solid var(--brand-border);
    border-radius: 18px;
    background: #fff;
}
.gantt-table {
    min-width: 1180px;
}
.gantt-header,
.gantt-row {
    display: grid;
    grid-template-columns: 320px minmax(760px, 1fr);
}
.gantt-header {
    position: sticky;
    top: 0;
    z-index: 5;
    background: #F8FAFC;
    border-bottom: 1px solid var(--brand-border);
}
.gantt-left-head,
.gantt-right-head {
    padding: 14px 16px;
    font-weight: 700;
    color: #475569;
}
.gantt-right-head {
    border-left: 1px solid var(--brand-border);
}
.gantt-days {
    display: grid;
    gap: 0;
    border-left: 1px solid var(--brand-border);
}
.gantt-day-head {
    text-align: center;
    padding: 10px 0;
    font-size: 12px;
    color: #64748b;
    border-left: 1px solid #eef2f7;
}
.gantt-row {
    min-height: 72px;
    border-bottom: 1px solid #eef2f7;
}
.gantt-left {
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
}
.gantt-task-title {
    font-weight: 700;
    color: #0f172a;
}
.gantt-meta {
    color: #64748b;
    font-size: 13px;
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.gantt-right {
    position: relative;
    border-left: 1px solid var(--brand-border);
}
.gantt-grid {
    position: absolute;
    inset: 0;
    display: grid;
}
.gantt-cell {
    border-left: 1px solid #eef2f7;
}
.gantt-cell.weekend {
    background: #F8FAFC;
}
.gantt-bar-track {
    position: absolute;
    left: 0;
    right: 0;
    top: 18px;
    height: 36px;
}
.gantt-bar {
    position: absolute;
    top: 0;
    height: 36px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    font-size: 12px;
    font-weight: 700;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    box-shadow: 0 6px 18px rgba(15,23,42,0.12);
}
.gantt-bar.task {
    background: linear-gradient(90deg, #2563eb, #3b82f6);
    color: #fff;
}
.gantt-bar.done {
    background: linear-gradient(90deg, var(--brand-accent-dark), var(--brand-accent));
    color: #fff;
}
.gantt-bar.review {
    background: linear-gradient(90deg, #d97706, #f59e0b);
    color: var(--brand-primary);
}
.gantt-bar.blocked {
    background: linear-gradient(90deg, #dc2626, #ef4444);
    color: #fff;
}
.gantt-bar.default {
    background: linear-gradient(90deg, #64748b, #94a3b8);
    color: #fff;
}
.gantt-milestone {
    position: absolute;
    top: 8px;
    width: 22px;
    height: 22px;
    transform: rotate(45deg);
    border-radius: 3px;
    background: #f59e0b;
    box-shadow: 0 6px 16px rgba(245, 158, 11, 0.25);
}
.gantt-milestone-label {
    position: absolute;
    top: 34px;
    font-size: 11px;
    color: #92400e;
    white-space: nowrap;
}
.gantt-empty {
    padding: 28px;
    color: #64748b;
}
@media (max-width: 980px) {
    .gantt-header,
    .gantt-row {
        grid-template-columns: 240px minmax(760px, 1fr);
    }
}


.report-hero {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 20px;
    margin-bottom: 24px;
}
.report-note {
    color: #64748b;
    line-height: 1.6;
}
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin: 20px 0 24px;
}
.kpi-card {
    background: #ffffff;
    border-radius: 18px;
    padding: 20px;
    box-shadow: 0 12px 30px rgba(15,23,42,0.06);
}
.kpi-card h3 {
    margin: 0;
    font-size: 14px;
    color: #64748b;
}
.kpi-card strong {
    display: block;
    margin-top: 8px;
    font-size: 28px;
    color: #0f172a;
}
.kpi-card small {
    display: block;
    margin-top: 6px;
    color: #64748b;
}
.report-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 20px;
}
.chart-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.bar-row {
    display: grid;
    grid-template-columns: 160px 1fr 60px;
    gap: 12px;
    align-items: center;
}
.bar-track {
    height: 14px;
    background: var(--brand-border);
    border-radius: 999px;
    overflow: hidden;
}
.bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--brand-primary-2) 0%, #2563eb 100%);
    border-radius: 999px;
}
.bar-fill.success {
    background: linear-gradient(90deg, var(--brand-accent) 0%, var(--brand-accent-dark) 100%);
}
.bar-fill.warning {
    background: linear-gradient(90deg, #f59e0b 0%, #d97706 100%);
}
.bar-fill.danger {
    background: linear-gradient(90deg, #ef4444 0%, #dc2626 100%);
}
.bar-value {
    text-align: right;
    font-weight: 700;
    color: #0f172a;
}
.mini-metrics {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 10px;
}
.mini-metric {
    padding: 10px 12px;
    border-radius: 12px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
    font-size: 13px;
    color: #475569;
}
.report-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
@media (max-width: 1200px) {
    .report-hero, .report-grid, .kpi-grid {
        grid-template-columns: 1fr;
    }
}


.nav-badge {
    display: inline-flex;
    min-width: 22px;
    height: 22px;
    padding: 0 7px;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #DBEAFE;
    color: var(--brand-primary-2);
    font-size: 12px;
    font-weight: 700;
}
.timeline-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.timeline-item {
    display: flex;
    gap: 14px;
    padding: 14px 16px;
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    background: #fff;
}
.timeline-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: #eff6ff;
    color: var(--brand-primary-2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    flex-shrink: 0;
}
.timeline-content {
    flex: 1;
}
.timeline-title-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 4px;
}
.timeline-title-row strong {
    color: #0f172a;
}
.timeline-meta {
    color: #64748b;
    font-size: 13px;
}
.timeline-message {
    color: #334155;
    margin-top: 6px;
    line-height: 1.5;
}
.timeline-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 10px;
}
.filters-inline {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr auto;
    gap: 12px;
    margin-bottom: 16px;
}
.stats-grid.stats-grid-5 {
    grid-template-columns: repeat(5, 1fr);
}
.panel-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.small-text {
    font-size: 13px;
    color: #64748b;
}
@media (max-width: 1200px) {
    .stats-grid.stats-grid-5,
    .filters-inline,
    .panel-split {
        grid-template-columns: 1fr;
    }
}


.entity-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 20px;
}
.milestone-card,
.comment-card,
.attachment-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.milestone-list,
.comment-list,
.attachment-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.comment-card strong,
.milestone-card strong,
.attachment-card strong {
    color: #0f172a;
}
.muted-line {
    margin-top: 6px;
    color: #64748b;
    font-size: 13px;
}
.attachment-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
}
.form-stack {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.inline-badges {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 8px;
}
.task-panels {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.soft-panel {
    padding: 16px;
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    background: #F8FAFC;
}
@media (max-width: 1100px) {
    .entity-grid,
    .task-panels {
        grid-template-columns: 1fr;
    }
}


.team-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 20px;
}
.team-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.member-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 8px;
    color: #64748b;
    font-size: 13px;
}
.member-row {
    display: grid;
    grid-template-columns: 1.3fr 0.8fr 0.8fr 0.8fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--brand-border);
}
.member-row:last-child {
    border-bottom: none;
}
.member-name strong {
    color: #0f172a;
}
.member-name .small-text {
    margin-top: 4px;
}
.kpi-grid.kpi-grid-5 {
    grid-template-columns: repeat(5, 1fr);
}
@media (max-width: 1200px) {
    .team-grid,
    .member-row,
    .kpi-grid.kpi-grid-5 {
        grid-template-columns: 1fr;
    }
}


.risk-grid,
.issue-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 20px;
}
.risk-card,
.issue-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.risk-meta,
.issue-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 8px;
    color: #64748b;
    font-size: 13px;
}
.notice-box {
    padding: 16px;
    border: 1px dashed #cbd5e1;
    border-radius: 16px;
    background: #F8FAFC;
    color: #475569;
    margin-bottom: 20px;
}
.table-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
@media (max-width: 1100px) {
    .risk-grid,
    .issue-grid {
        grid-template-columns: 1fr;
    }
}


.timesheet-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 20px;
}
.hours-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.hours-row {
    display: grid;
    grid-template-columns: 1.2fr 1fr 0.8fr 0.8fr 0.8fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--brand-border);
}
.hours-row:last-child {
    border-bottom: none;
}
.hours-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 20px;
}
.kpi-grid.kpi-grid-6 {
    grid-template-columns: repeat(6, 1fr);
}
@media (max-width: 1200px) {
    .timesheet-grid,
    .hours-row,
    .hours-form-grid,
    .kpi-grid.kpi-grid-6 {
        grid-template-columns: 1fr;
    }
}


.approval-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}
.week-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 14px;
}
.week-day-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px;
    background: #fff;
    min-height: 180px;
}
.week-day-card h3 {
    margin: 0 0 8px;
    font-size: 15px;
    color: #0f172a;
}
.week-day-total {
    font-size: 24px;
    font-weight: 700;
    color: var(--brand-primary-2);
    margin-bottom: 10px;
}
.week-entry-mini {
    padding: 10px;
    border-radius: 12px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
    margin-bottom: 8px;
    font-size: 13px;
}
@media (max-width: 1200px) {
    .week-grid {
        grid-template-columns: 1fr;
    }
}


.executive-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 20px;
}
.variance-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}
.variance-chip.ok {
    background: #DCFCE7;
    color: var(--brand-accent-dark);
}
.variance-chip.warn {
    background: #FEF3C7;
    color: #92400e;
}
.variance-chip.danger {
    background: #FEE2E2;
    color: #991b1b;
}
.baseline-box {
    padding: 14px 16px;
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    background: #F8FAFC;
}
.baseline-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
@media (max-width: 1200px) {
    .executive-grid,
    .baseline-grid {
        grid-template-columns: 1fr;
    }
}


.change-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 20px;
}
.change-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.change-meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 8px;
}
.change-impact-box {
    padding: 14px 16px;
    border-radius: 16px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
.change-row {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 0.8fr 0.8fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--brand-border);
}
.change-row:last-child {
    border-bottom: none;
}
@media (max-width: 1200px) {
    .change-grid,
    .change-row {
        grid-template-columns: 1fr;
    }
}


.finance-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.finance-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.money-row {
    display: grid;
    grid-template-columns: 1.2fr 0.9fr 0.9fr 0.9fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--brand-border);
}
.money-row:last-child {
    border-bottom: none;
}
.money-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 8px;
    color: #64748b;
    font-size: 13px;
}
.kpi-grid.kpi-grid-7 {
    grid-template-columns: repeat(7, 1fr);
}
@media (max-width: 1200px) {
    .finance-grid,
    .money-row,
    .kpi-grid.kpi-grid-7 {
        grid-template-columns: 1fr;
    }
}


.contract-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.contract-card, .revenue-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.commercial-box {
    padding: 14px 16px;
    border-radius: 16px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
.commercial-row {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 0.8fr 0.8fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--brand-border);
}
.commercial-row:last-child {
    border-bottom: none;
}
@media (max-width: 1200px) {
    .contract-grid,
    .commercial-row {
        grid-template-columns: 1fr;
    }
}


.crm-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.crm-card, .proposal-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.pipeline-badge {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    background: #eff6ff;
    color: var(--brand-primary-2);
    font-size: 12px;
    font-weight: 700;
}
.crm-box {
    padding: 14px 16px;
    border-radius: 16px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
.crm-row {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr 0.8fr 0.8fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px solid var(--brand-border);
}
.crm-row:last-child {
    border-bottom: none;
}
@media (max-width: 1200px) {
    .crm-grid,
    .crm-row {
        grid-template-columns: 1fr;
    }
}


.portal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.portal-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.portal-box {
    padding: 14px 16px;
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    background: #F8FAFC;
}
.client-portal-wrapper {
    max-width: 1200px;
    margin: 0 auto;
    padding: 24px;
}
.client-portal-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    margin-bottom: 20px;
}
.client-portal-section {
    background: #fff;
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 18px;
    margin-bottom: 18px;
}
@media (max-width: 1200px) {
    .portal-grid {
        grid-template-columns: 1fr;
    }
    .client-portal-header {
        flex-direction: column;
        align-items: flex-start;
    }
}


.docs-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.doc-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.doc-meta {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 8px;
}
.doc-link {
    word-break: break-all;
}
@media (max-width: 1200px) {
    .docs-grid {
        grid-template-columns: 1fr;
    }
}


.workflow-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.workflow-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.version-note {
    padding: 12px 14px;
    border-radius: 14px;
    background: #F8FAFC;
    border: 1px dashed #cbd5e1;
}
@media (max-width: 1200px) {
    .workflow-grid {
        grid-template-columns: 1fr;
    }
}


.document-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.document-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.comment-box {
    border: 1px solid var(--brand-border);
    border-radius: 12px;
    padding: 12px 14px;
    background: #fff;
    margin-bottom: 10px;
}
.compliance-box {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #F8FAFC;
}
@media (max-width: 1200px) {
    .document-grid {
        grid-template-columns: 1fr;
    }
}


.audit-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.audit-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.sla-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}
.sla-chip.ok {
    background: #DCFCE7;
    color: var(--brand-accent-dark);
}
.sla-chip.warn {
    background: #FEF3C7;
    color: #92400e;
}
.sla-chip.danger {
    background: #FEE2E2;
    color: #991b1b;
}
@media (max-width: 1200px) {
    .audit-grid {
        grid-template-columns: 1fr;
    }
}



.meeting-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.meeting-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.meeting-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 8px;
    color: #64748b;
    font-size: 13px;
}
.agenda-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    background: #eff6ff;
    color: var(--brand-primary-2);
    font-size: 12px;
    font-weight: 700;
}
@media (max-width: 1200px) {
    .meeting-grid {
        grid-template-columns: 1fr;
    }
}


.resource-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.resource-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.load-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}
.load-chip.ok {
    background: #DCFCE7;
    color: var(--brand-accent-dark);
}
.load-chip.warn {
    background: #FEF3C7;
    color: #92400e;
}
.load-chip.danger {
    background: #FEE2E2;
    color: #991b1b;
}
@media (max-width: 1200px) {
    .resource-grid {
        grid-template-columns: 1fr;
    }
}


.budget-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.budget-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.metric-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
}
.metric-chip.ok {
    background: #DCFCE7;
    color: var(--brand-accent-dark);
}
.metric-chip.warn {
    background: #FEF3C7;
    color: #92400e;
}
.metric-chip.danger {
    background: #FEE2E2;
    color: #991b1b;
}
@media (max-width: 1200px) {
    .budget-grid {
        grid-template-columns: 1fr;
    }
}


.heatmap-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(70px, 1fr));
    gap: 8px;
}
.heatmap-cell {
    border-radius: 14px;
    padding: 12px;
    text-align: center;
    font-weight: 700;
    border: 1px solid var(--brand-border);
}
.heat-low { background:#DCFCE7; color:var(--brand-accent-dark); }
.heat-medium { background:#FEF3C7; color:#92400e; }
.heat-high { background:#DBEAFE; color:var(--brand-primary-2); }
.heat-critical { background:#FEE2E2; color:#991b1b; }
.risk-grid {
    display:grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap:20px;
}
@media (max-width: 1200px) {
    .risk-grid { grid-template-columns: 1fr; }
}


.issue-heatmap {
    display: grid;
    grid-template-columns: 100px repeat(5, minmax(90px, 1fr));
    gap: 8px;
    align-items: stretch;
}
.issue-heat-label,
.issue-heat-cell {
    border-radius: 14px;
    padding: 12px;
    border: 1px solid var(--brand-border);
    background: #fff;
    text-align: center;
}
.issue-heat-label {
    font-weight: 700;
    background: #F8FAFC;
}
.issue-heat-cell strong {
    display: block;
    font-size: 20px;
    margin-bottom: 6px;
}
.heat-low {
    background: #ecfdf5;
    border-color: #a7f3d0;
}
.heat-medium {
    background: #fffbeb;
    border-color: #fde68a;
}
.heat-high {
    background: #fff7ed;
    border-color: #fdba74;
}
.heat-critical {
    background: #fef2f2;
    border-color: #fca5a5;
}
.issue-metric-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(180px, 1fr));
    gap: 16px;
}
@media (max-width: 1200px) {
    .issue-heatmap {
        grid-template-columns: repeat(2, 1fr);
    }
    .issue-metric-grid {
        grid-template-columns: 1fr 1fr;
    }
}
@media (max-width: 700px) {
    .issue-heatmap,
    .issue-metric-grid {
        grid-template-columns: 1fr;
    }
}


.planning-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 20px;
}
.planning-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.critical-pill {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    background: #FEE2E2;
    color: #991b1b;
}
.gantt-bar.critical {
    background: #dc2626;
    box-shadow: 0 0 0 1px rgba(153, 27, 27, 0.25);
}
@media (max-width: 1200px) {
    .planning-grid {
        grid-template-columns: 1fr;
    }
}


.change-board-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 20px;
}
.change-board-card {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 16px;
    background: #fff;
}
.impact-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
@media (max-width: 1100px) {
    .change-board-grid {
        grid-template-columns: 1fr;
    }
}


.stakeholder-matrix {
    display: grid;
    grid-template-columns: repeat(2, minmax(220px, 1fr));
    gap: 16px;
}
.stakeholder-quadrant {
    border: 1px solid var(--brand-border);
    border-radius: 18px;
    background: #fff;
    padding: 16px;
    min-height: 180px;
}
.stakeholder-quadrant h3 {
    margin: 0 0 10px 0;
    font-size: 20px;
}
.stakeholder-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    background: #eef2ff;
    color: #3730a3;
}
.comm-board {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 20px;
}
.comm-card {
    border: 1px solid var(--brand-border);
    border-radius: 18px;
    background: #fff;
    padding: 16px;
}
@media (max-width: 1100px) {
    .stakeholder-matrix, .comm-board {
        grid-template-columns: 1fr;
    }
}


.health-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(260px, 1fr));
    gap: 20px;
}
.health-card {
    border: 1px solid var(--brand-border);
    border-radius: 18px;
    padding: 16px;
    background: #fff;
}
.health-card h3 {
    margin: 0 0 10px 0;
}
.qa-check-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(180px, 1fr));
    gap: 16px;
}
.module-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px dashed var(--brand-border);
}
.module-row:last-child {
    border-bottom: none;
}
@media (max-width: 1100px) {
    .health-grid, .qa-check-grid {
        grid-template-columns: 1fr;
    }
}


.platform-grid {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 20px;
}
.platform-card {
    border: 1px solid var(--brand-border);
    border-radius: 18px;
    background: #fff;
    padding: 16px;
}
.context-chip {
    display: inline-flex;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    background: #eff6ff;
    color: var(--brand-primary-2);
}
@media (max-width: 1100px) {
    .platform-grid {
        grid-template-columns: 1fr;
    }
}

.footer-note { margin-top: 18px; color: var(--brand-muted); font-size: 12px; }

.dashboard-hero {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    padding: 24px;
    background: linear-gradient(135deg, #eef4ff 0%, #f8fbff 100%);
    border: 1px solid #DBEAFE;
}
.dashboard-hero h2 { margin: 4px 0 10px; font-size: 30px; }
.dashboard-hero p { margin: 0; color: #4b5563; max-width: 720px; }
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    background: #DBEAFE;
    color: var(--brand-primary-2);
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; }
.hero-context-row { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 16px; }
.context-pill {
    display: inline-flex;
    padding: 8px 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #DBEAFE;
    color: var(--brand-text);
    font-size: 13px;
    font-weight: 600;
}
.context-pill-info { background: #DBEAFE; color: var(--brand-primary-2); }
.context-pill-warning { background: #FEF3C7; color: #92400e; border-color: #fde68a; }
.dashboard-top-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.dashboard-kpi-card {
    margin-bottom: 0;
    padding: 20px;
    border: 1px solid #eef2f7;
}
.dashboard-kpi-card strong {
    display: block;
    margin: 10px 0 8px;
    font-size: 32px;
    line-height: 1;
}
.kpi-label { color: var(--brand-muted); font-size: 14px; font-weight: 700; }
.kpi-meta { color: #64748b; font-size: 13px; }
.dashboard-main-grid { align-items: start; }
.priority-stack, .list-stack, .project-focus-list, .activity-mini-list { display: flex; flex-direction: column; gap: 12px; }
.priority-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 16px;
    border-radius: 14px;
    border: 1px solid var(--brand-border);
    background: #fff;
}
.priority-warning { background: #fffaf0; border-color: #fde68a; }
.priority-danger { background: #fef2f2; border-color: #fecaca; }
.priority-info { background: #eff6ff; border-color: #bfdbfe; }
.priority-value { font-size: 24px; font-weight: 800; white-space: nowrap; }
.quick-links-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.quick-link-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 16px;
    border-radius: 14px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
    text-decoration: none;
    color: var(--brand-primary);
}
.quick-link-card:hover { text-decoration: none; background: #eff6ff; border-color: #bfdbfe; }
.quick-link-card span { color: #64748b; font-size: 13px; }
.list-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 14px 0;
    border-bottom: 1px solid #eef2f7;
    color: inherit;
    text-decoration: none;
}
.list-row:last-child { border-bottom: none; }
.list-row:hover { text-decoration: none; }
.list-row-meta {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-end;
    color: #64748b;
    font-size: 13px;
    min-width: 120px;
}
.project-focus-item {
    padding: 16px;
    border-radius: 16px;
    border: 1px solid var(--brand-border);
    background: #fff;
}
.project-focus-head, .project-focus-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
.project-focus-head { margin-bottom: 14px; }
.project-focus-foot { margin-top: 12px; color: #64748b; font-size: 13px; }
.progress-track {
    height: 10px;
    border-radius: 999px;
    background: var(--brand-border);
    overflow: hidden;
}
.progress-track span {
    display: block;
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--brand-primary-2) 0%, var(--brand-primary-2) 100%);
}
.health-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.health-card {
    padding: 16px;
    border-radius: 14px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
.health-card span { display: block; color: #64748b; font-size: 13px; margin-bottom: 8px; }
.health-card strong { font-size: 24px; }
.activity-mini-list { margin-top: 16px; }
.activity-mini-item {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid #eef2f7;
    font-size: 14px;
}
.activity-mini-item:last-child { border-bottom: none; }
@media (max-width: 1180px) {
    .dashboard-top-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .dashboard-hero { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 980px) {
    .dashboard-top-grid, .quick-links-grid, .health-grid { grid-template-columns: 1fr; }
    .list-row, .project-focus-head, .project-focus-foot, .priority-item { flex-direction: column; align-items: flex-start; }
    .list-row-meta { align-items: flex-start; min-width: 0; }
}


.nav-badge {
    min-width: 22px;
    padding: 4px 7px;
    border-radius: 999px;
    background: rgba(13,110,253,0.16);
    color: #8ec5ff;
    font-size: 12px;
    font-weight: 700;
    text-align: center;
}
.app-shell { background: #eff4fb; }
.app-sidebar {
    width: 290px;
    background: linear-gradient(180deg, #0f172a 0%, var(--brand-primary) 100%);
    padding: 22px 18px;
    border-right: 1px solid rgba(255,255,255,0.06);
    position: sticky;
    top: 0;
    align-self: flex-start;
    min-height: 100vh;
}
.app-brand {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
}
.brand-mark {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #2563eb 0%, #38bdf8 100%);
    color: #fff;
    font-weight: 800;
    letter-spacing: 0.5px;
    box-shadow: 0 12px 28px rgba(37,99,235,0.28);
}
.sidebar-context-card {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 18px;
    padding: 14px;
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    color: #DBEAFE;
}
.context-kicker, .topbar-kicker, .nav-group-title {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 11px;
    font-weight: 700;
}
.context-kicker { color: #93c5fd; }
.context-role {
    display: inline-flex;
    width: fit-content;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(59,130,246,0.18);
    color: #bfdbfe;
    font-size: 12px;
    font-weight: 700;
}
.sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.nav-group { display: flex; flex-direction: column; gap: 8px; }
.nav-group-title { color: #64748b; padding: 0 10px; }
.nav-group-links { display: flex; flex-direction: column; gap: 6px; }
.nav-item {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    color: var(--brand-border) !important;
    text-decoration: none;
    padding: 11px 12px !important;
    border-radius: 12px !important;
    margin-bottom: 0 !important;
    transition: background .18s ease, transform .18s ease, color .18s ease;
}
.nav-item:hover {
    background: rgba(255,255,255,0.08);
    color: #fff !important;
    text-decoration: none !important;
    transform: translateX(2px);
}
.nav-item.nav-active {
    background: linear-gradient(135deg, rgba(37,99,235,0.34) 0%, rgba(56,189,248,0.2) 100%);
    color: #fff !important;
    border: 1px solid rgba(96,165,250,0.28);
}
.nav-item-label { font-weight: 600; }
.sidebar-footer-actions {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.app-content { padding: 26px 30px 34px; }
.app-topbar {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    padding: 0 0 10px;
}
.topbar-kicker { color: #2563eb; margin-bottom: 6px; }
.app-topbar h1 { font-size: 32px; margin: 0 0 8px; }
.topbar-meta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.meta-pill {
    min-width: 150px;
    padding: 12px 14px;
    border-radius: 16px;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 10px 30px rgba(15,23,42,0.04);
}
.meta-pill span {
    display: block;
    color: #64748b;
    font-size: 12px;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.meta-pill strong { font-size: 14px; color: #0f172a; }
.footer-note {
    color: #64748b;
    font-size: 13px;
    margin: 6px 0 20px;
}
@media (max-width: 980px) {
    .app-sidebar {
        width: 100%;
        min-height: auto;
        position: static;
    }
    .app-topbar {
        flex-direction: column;
        align-items: flex-start;
    }
    .topbar-meta {
        width: 100%;
        justify-content: flex-start;
    }
}

.topbar-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.sidebar-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.profile-grid {
    align-items: start;
}
.profile-summary-stack {
    display: flex;
    gap: 16px;
    align-items: center;
    margin-bottom: 18px;
}
.profile-avatar {
    width: 64px;
    height: 64px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #2563eb 0%, var(--brand-primary-2) 100%);
    color: #fff;
    font-size: 24px;
    font-weight: 700;
}
.profile-name {
    display: block;
    font-size: 20px;
    margin-bottom: 4px;
}
.password-hint-box {
    background: #eff6ff;
    border: 1px solid #bfdbfe;
    color: var(--brand-primary-2);
    border-radius: 14px;
    padding: 12px 14px;
    font-size: 14px;
}


.register-card { max-width: 560px; }
.register-card p { margin-bottom: 18px; }
.login-help a { color: inherit; font-weight: 600; }


/* Landing page */
.landing-page {
    background: #F8FAFC;
    color: #0f172a;
}
.landing-header {
    position: sticky;
    top: 0;
    z-index: 30;
    background: rgba(255,255,255,0.92);
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--brand-border);
}
.landing-container {
    width: min(1180px, calc(100% - 32px));
    margin: 0 auto;
}
.landing-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 18px;
    padding: 18px 0;
}
.landing-brand {
    font-size: 22px;
    font-weight: 800;
    color: #0f172a;
}
.landing-brand:hover { text-decoration: none; }
.landing-nav-actions {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
}
.hero-section {
    padding: 56px 0 28px;
    background: radial-gradient(circle at top left, rgba(13,110,253,0.12), transparent 40%),
                radial-gradient(circle at right center, rgba(30,58,138,0.10), transparent 35%);
}
.hero-grid {
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 28px;
    align-items: center;
}
.hero-kicker,
.section-kicker {
    display: inline-block;
    margin-bottom: 14px;
    padding: 8px 12px;
    border-radius: 999px;
    background: #DBEAFE;
    color: var(--brand-primary-2);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.hero-section h1 {
    margin: 0;
    font-size: 52px;
    line-height: 1.05;
}
.hero-copy {
    font-size: 18px;
    line-height: 1.7;
    color: #475569;
    margin: 20px 0 0;
    max-width: 700px;
}
.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px;
}
.btn-lg {
    padding: 14px 22px;
    border-radius: 14px;
    font-size: 15px;
}
.hero-trust-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 26px;
}
.hero-trust-row span {
    padding: 9px 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--brand-border);
    color: #475569;
    font-size: 13px;
    font-weight: 600;
}
.hero-showcase {
    padding: 24px;
}
.showcase-top {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 14px;
}
.hero-showcase h2 {
    margin: 0 0 18px;
    font-size: 24px;
}
.showcase-metrics {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}
.showcase-metric {
    padding: 16px;
    border-radius: 16px;
    background: #F8FAFC;
    border: 1px solid var(--brand-border);
}
.showcase-metric strong {
    display: block;
    font-size: 28px;
    margin-bottom: 6px;
}
.showcase-metric span {
    color: #64748b;
    font-size: 14px;
}
.showcase-list {
    margin-top: 16px;
    display: grid;
    gap: 12px;
}
.showcase-item {
    border: 1px solid var(--brand-border);
    border-radius: 16px;
    padding: 14px 16px;
    background: #fff;
}
.showcase-item strong {
    display: block;
    margin-bottom: 6px;
}
.showcase-item span {
    color: #64748b;
    font-size: 14px;
}
.feature-section {
    padding: 32px 0;
}
.alt-surface {
    background: #eef4ff;
}
.center-copy {
    text-align: center;
    max-width: 780px;
    margin: 0 auto 22px;
}
.section-copy h2 {
    margin: 0 0 12px;
    font-size: 34px;
}
.section-copy p {
    margin: 0;
    color: #64748b;
    font-size: 17px;
    line-height: 1.7;
}
.landing-feature-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.landing-feature-card {
    min-height: 190px;
}
.landing-feature-card h3 {
    margin-top: 0;
    margin-bottom: 10px;
}
.landing-feature-card p {
    margin: 0;
    color: #64748b;
    line-height: 1.7;
}
.steps-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 24px;
    align-items: start;
}
.steps-list {
    display: grid;
    gap: 14px;
}
.step-card {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 18px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #DBEAFE;
    box-shadow: 0 10px 24px rgba(15,23,42,0.06);
}
.step-number {
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: var(--brand-primary-2);
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    flex-shrink: 0;
}
.step-card h3 {
    margin: 0 0 8px;
}
.step-card p {
    margin: 0;
    color: #64748b;
    line-height: 1.6;
}
.cta-section {
    padding: 24px 0 56px;
}
.cta-card {
    background: linear-gradient(135deg, var(--brand-primary-2), var(--brand-primary));
    color: #fff;
    border-radius: 26px;
    padding: 30px;
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: center;
    flex-wrap: wrap;
    box-shadow: 0 20px 40px rgba(13,110,253,0.22);
}
.cta-card .section-kicker {
    background: rgba(255,255,255,0.16);
    color: #fff;
}
.cta-card h2 {
    margin: 0 0 10px;
    font-size: 32px;
}
.cta-card p {
    margin: 0;
    color: rgba(255,255,255,0.86);
    max-width: 720px;
    line-height: 1.7;
}
.cta-card .btn-light {
    background: rgba(255,255,255,0.14);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.24);
}
.register-card {
    max-width: 520px;
}

@media (max-width: 980px) {
    .hero-grid,
    .landing-feature-grid,
    .steps-grid {
        grid-template-columns: 1fr;
    }
    .hero-section h1 {
        font-size: 40px;
    }
    .showcase-metrics {
        grid-template-columns: 1fr 1fr;
    }
    .cta-card {
        padding: 24px;
    }
}
@media (max-width: 640px) {
    .landing-container {
        width: min(100% - 24px, 1180px);
    }
    .landing-nav {
        align-items: flex-start;
        flex-direction: column;
    }
    .hero-section {
        padding-top: 38px;
    }
    .hero-section h1 {
        font-size: 34px;
    }
    .hero-copy,
    .section-copy p,
    .cta-card p {
        font-size: 16px;
    }
    .showcase-metrics {
        grid-template-columns: 1fr;
    }
    .btn,
    .btn-lg {
        width: 100%;
        text-align: center;
    }
    .hero-actions,
    .landing-nav-actions {
        width: 100%;
    }
}

.projects-hero {
    display: grid;
    grid-template-columns: 1.25fr auto;
    gap: 18px;
    align-items: center;
}
.hero-kicker,
.project-code {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 12px;
    font-weight: 700;
    color: #2563eb;
}
.projects-hero h2 {
    margin: 8px 0 10px;
    font-size: 30px;
    line-height: 1.15;
    color: #0f172a;
}
.projects-hero p {
    margin: 0;
    color: #475569;
    max-width: 720px;
    line-height: 1.6;
}
.stats-grid.stats-grid-4 {
    grid-template-columns: repeat(4, 1fr);
}
.projects-filters {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr auto;
    gap: 14px;
    align-items: end;
}
.projects-filter-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
.empty-state-large {
    padding: 28px;
    border-radius: 18px;
    border: 1px dashed #cbd5e1;
    background: linear-gradient(180deg, #F8FAFC 0%, #ffffff 100%);
    color: #475569;
}
.empty-state-large strong {
    display: block;
    color: #0f172a;
    font-size: 18px;
    margin-bottom: 8px;
}
.empty-state-large p {
    margin: 0 0 16px;
    max-width: 620px;
}
.project-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.project-card-v2 {
    border: 1px solid var(--brand-border);
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #F8FAFC 100%);
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.05);
}
.project-card-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
}
.project-card-head h3 {
    margin: 6px 0 0;
    font-size: 20px;
    color: #0f172a;
}
.project-card-meta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    color: #64748b;
    font-size: 13px;
}
.project-progress-block {
    padding: 14px 16px;
    border-radius: 16px;
    background: #fff;
    border: 1px solid var(--brand-border);
}
.progress-label-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    font-size: 14px;
    margin-bottom: 10px;
    color: #475569;
}
.progress-bar-shell {
    width: 100%;
    height: 12px;
    background: var(--brand-border);
    border-radius: 999px;
    overflow: hidden;
}
.progress-bar-fill {
    height: 100%;
    border-radius: 999px;
    background: linear-gradient(90deg, #2563eb 0%, #38bdf8 100%);
}
.project-card-insights {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.insight-chip {
    border-radius: 16px;
    padding: 14px 12px;
    background: #fff;
    border: 1px solid var(--brand-border);
}
.insight-chip strong {
    display: block;
    font-size: 22px;
    color: #0f172a;
}
.insight-chip span {
    display: block;
    margin-top: 4px;
    font-size: 13px;
    color: #64748b;
}
.insight-chip-alert {
    border-color: #fecaca;
    background: #fef2f2;
}
.project-card-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}
@media (max-width: 1200px) {
    .projects-hero,
    .projects-filters,
    .project-card-grid,
    .stats-grid.stats-grid-4 {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .project-card-head,
    .project-card-insights {
        grid-template-columns: 1fr;
        display: grid;
    }
}

.task-hero {
    border: 1px solid #DBEAFE;
    background: linear-gradient(135deg, #f8fbff 0%, #eef6ff 56%, #ffffff 100%);
}
.tasks-filters-grid {
    grid-template-columns: 1.4fr 1fr 1fr 1fr auto;
}
.task-card-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.task-card-v2 {
    border: 1px solid var(--brand-border);
    border-radius: 20px;
    background: linear-gradient(180deg, #ffffff 0%, #F8FAFC 100%);
    padding: 18px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    box-shadow: 0 14px 30px rgba(15, 23, 42, 0.05);
}
.task-card-head {
    display: flex;
    justify-content: space-between;
    gap: 14px;
    align-items: flex-start;
}
.task-card-head h3 {
    margin: 6px 0 0;
    font-size: 20px;
    color: #0f172a;
}
.task-project-line {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    font-size: 14px;
    color: #475569;
}
.task-project-line a {
    color: #2563eb;
    font-weight: 600;
    text-decoration: none;
}
.task-project-line a:hover {
    text-decoration: underline;
}
.task-card-meta {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    color: #64748b;
    font-size: 13px;
}
.task-card-insights {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.task-card-actions {
    margin-top: auto;
}
@media (max-width: 1200px) {
    .tasks-filters-grid,
    .task-card-grid {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .task-card-head,
    .task-card-insights {
        grid-template-columns: 1fr;
        display: grid;
    }
}

.kanban-hero {
    border: 1px solid #DBEAFE;
    background: linear-gradient(135deg, #eff6ff 0%, #f8fbff 52%, #ffffff 100%);
}
.kanban-stats-grid {
    margin-top: 18px;
}
.kanban-filters-grid {
    display: grid;
    grid-template-columns: 1.2fr 1.1fr auto 1.5fr;
    gap: 16px;
    align-items: end;
}
.filter-action-row {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}
.kanban-helper-copy {
    align-self: stretch;
    border-radius: 18px;
    background: #F8FAFC;
    border: 1px solid #e2e8f0;
    padding: 14px 16px;
    color: #475569;
    font-size: 14px;
}
.kanban-board-v2 {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 18px;
    align-items: start;
    margin-top: 18px;
}
.kanban-column-v2 {
    border: 1px solid #dbe4f0;
    background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
    border-radius: 24px;
    padding: 16px;
    min-height: 360px;
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.06);
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.kanban-column-v2.drag-over {
    border-color: #2563eb;
    box-shadow: 0 20px 38px rgba(37, 99, 235, 0.14);
    transform: translateY(-2px);
}
.kanban-column-head-v2 {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}
.kanban-column-kicker {
    display: inline-block;
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #64748b;
    margin-bottom: 6px;
}
.kanban-column-head-v2 h3 {
    margin: 0;
    color: #0f172a;
    font-size: 20px;
}
.kanban-list-v2 {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.kanban-card-v2 {
    border: 1px solid var(--brand-border);
    border-radius: 20px;
    background: #ffffff;
    padding: 16px;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
    display: flex;
    flex-direction: column;
    gap: 12px;
    cursor: grab;
}
.kanban-card-v2.is-dragging {
    opacity: .65;
    transform: rotate(1deg);
}
.kanban-card-v2.is-overdue {
    border-color: #fecaca;
    background: linear-gradient(180deg, #fffefe 0%, #fff7f7 100%);
}
.kanban-card-topline {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: flex-start;
}
.kanban-card-v2 h4 {
    margin: 0;
    font-size: 18px;
    color: #0f172a;
}
.kanban-card-copy {
    margin: 0;
    color: #475569;
    font-size: 14px;
    line-height: 1.5;
}
.kanban-card-meta-v2 {
    display: flex;
    flex-direction: column;
    gap: 6px;
    color: #64748b;
    font-size: 13px;
}
.compact-progress {
    height: 9px;
    background: #e2e8f0;
}
.progress-copy-row {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    font-size: 13px;
    color: #64748b;
    flex-wrap: wrap;
}
.kanban-alert-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.mini-alert {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid transparent;
}
.mini-alert-danger {
    background: #fef2f2;
    color: #b91c1c;
    border-color: #fecaca;
}
.mini-alert-warning {
    background: #fff7ed;
    color: #c2410c;
    border-color: #fed7aa;
}
.mini-alert-neutral {
    background: #F8FAFC;
    color: #475569;
    border-color: #e2e8f0;
}
.kanban-card-actions-v2 {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: auto;
}
.kanban-move-form {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}
.kanban-move-form select {
    min-width: 150px;
}
.kanban-secondary-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.hidden-kanban-form {
    display: none;
}
.empty-state-card {
    text-align: center;
    padding: 30px;
}
@media (max-width: 1200px) {
    .kanban-filters-grid {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .kanban-card-topline,
    .progress-copy-row {
        flex-direction: column;
        align-items: flex-start;
    }
    .kanban-board-v2 {
        grid-template-columns: 1fr;
    }
    .kanban-move-form {
        flex-direction: column;
        align-items: stretch;
    }
    .kanban-move-form select,
    .kanban-move-form button,
    .kanban-secondary-actions a {
        width: 100%;
    }
}


/* Project detail redesign */
.project-detail-hero{padding:28px;border-radius:22px;box-shadow:0 18px 50px rgba(15,23,42,.06)}
.project-hero-top{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;flex-wrap:wrap}
.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:700;color:#64748b;margin-bottom:8px}
.project-detail-hero h1{margin:0 0 10px;font-size:34px;line-height:1.1}
.project-hero-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.soft-badge{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;background:#eff6ff;color:var(--brand-primary);font-size:13px;font-weight:600}
.badge-success{background:#ecfdf5;color:#047857}.badge-warning{background:#fffbeb;color:#b45309}.badge-danger{background:#fef2f2;color:#b91c1c}
.project-hero-copy{max-width:800px;color:#475569;font-size:15px;line-height:1.65;margin:0}
.project-hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.project-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:24px}
.project-kpi-grid .kpi-card{padding:18px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}
.project-kpi-grid .kpi-card span{display:block;font-size:13px;color:#64748b;margin-bottom:6px}
.project-kpi-grid .kpi-card strong{display:block;font-size:30px;line-height:1.1;margin-bottom:6px;color:#0f172a}
.project-kpi-grid .kpi-card small{color:#64748b}
.project-kpi-grid .kpi-card--accent{background:linear-gradient(135deg,#0f172a,var(--brand-primary-2));border:none}.project-kpi-grid .kpi-card--accent span,.project-kpi-grid .kpi-card--accent strong,.project-kpi-grid .kpi-card--accent small{color:#fff}
.project-summary-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;margin-top:20px}
.project-summary-card{padding:20px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}
.project-summary-card h3{margin:0 0 14px;font-size:18px}
.info-grid.compact{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.info-grid.compact div{display:flex;flex-direction:column;gap:4px;padding:12px;border-radius:14px;background:#F8FAFC}
.info-grid.compact strong{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#64748b}
.info-grid.compact span{font-weight:600;color:#0f172a}
.focus-list{margin:0 0 14px;padding-left:18px;color:#334155;display:grid;gap:8px}
.quick-links{display:flex;flex-wrap:wrap;gap:10px}.quick-links a{display:inline-flex;padding:8px 12px;border-radius:999px;background:#f1f5f9;color:#0f172a;text-decoration:none;font-weight:600}
.text-success{color:#047857}.text-warning{color:#b45309}.text-danger{color:#b91c1c}
@media (max-width: 1100px){.project-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-summary-grid{grid-template-columns:1fr}.info-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 720px){.project-detail-hero h1{font-size:28px}.project-kpi-grid{grid-template-columns:1fr}.info-grid.compact{grid-template-columns:1fr}}


/* Task form redesign */
.task-form-hero{padding:28px;border-radius:22px;box-shadow:0 18px 50px rgba(15,23,42,.06);margin-bottom:18px}.task-form-hero-top{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;flex-wrap:wrap}.task-form-hero h1{margin:0 0 10px;font-size:34px;line-height:1.1}.task-form-hero p{margin:0;color:#475569;max-width:760px;line-height:1.65}.task-form-kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:24px}.task-form-kpi{padding:18px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}.task-form-kpi span{display:block;font-size:13px;color:#64748b;margin-bottom:6px}.task-form-kpi strong{display:block;font-size:28px;line-height:1.1;margin-bottom:6px;color:#0f172a}.task-form-kpi small{color:#64748b}.task-form-kpi--accent{background:linear-gradient(135deg,#0f172a,var(--brand-primary-2));border:none}.task-form-kpi--accent span,.task-form-kpi--accent strong,.task-form-kpi--accent small{color:#fff}.task-form-shell{display:grid;grid-template-columns:minmax(0,1.55fr) 340px;gap:18px;margin-top:18px}.task-form-main{display:flex;flex-direction:column;gap:18px}.task-form-card{padding:22px}.task-form-grid{display:flex;flex-direction:column;gap:18px}.task-form-section{padding:18px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}.task-form-grid-inner{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.task-form-grid-inner .col-span-2{grid-column:span 2}.task-form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.task-form-aside{display:flex;flex-direction:column;gap:18px}.task-form-side-card{padding:20px}.task-form-list-space{margin-top:16px}.task-panels--redesign{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.task-form-shell .focus-list{margin-bottom:0}.task-form-section label{display:block;font-weight:600;margin-bottom:8px;color:#0f172a}.task-form-section input,.task-form-section select,.task-form-section textarea{width:100%}.task-form-section textarea{min-height:120px}.task-form-section .small-text{margin-top:6px}.task-form-shell .info-grid.compact{grid-template-columns:1fr}.task-form-shell .info-grid.compact div{background:#F8FAFC}.task-form-shell .badge-secondary{background:#f1f5f9;color:#334155}.task-form-shell .card,.task-form-hero.card{border:1px solid #e2e8f0}.task-form-shell .soft-panel{border-radius:16px}.task-form-shell .comment-card,.task-form-shell .attachment-card{border-radius:16px}.task-form-shell .mini-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.task-form-shell .mini-metric{padding:14px;border-radius:14px;background:#F8FAFC;border:1px solid #e2e8f0}.task-form-shell .timeline-item{border-radius:16px}@media (max-width: 1200px){.task-form-shell{grid-template-columns:1fr}.task-form-aside{order:-1}.task-panels--redesign{grid-template-columns:1fr}.task-form-kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.task-form-hero h1{font-size:28px}.task-form-kpi-row,.task-form-grid-inner,.task-form-shell .mini-metrics{grid-template-columns:1fr}.task-form-grid-inner .col-span-2{grid-column:span 1}.task-form-actions{justify-content:stretch}.task-form-actions .btn,.task-form-actions button,.project-hero-actions .btn{width:100%}}

.project-form-hero{padding:28px;border-radius:22px;box-shadow:0 18px 50px rgba(15,23,42,.06);margin-bottom:18px}.project-form-kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:24px}.project-form-kpi{padding:18px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}.project-form-kpi span{display:block;font-size:13px;color:#64748b;margin-bottom:6px}.project-form-kpi strong{display:block;font-size:28px;line-height:1.1;margin-bottom:6px;color:#0f172a}.project-form-kpi small{color:#64748b}.project-form-kpi--accent{background:linear-gradient(135deg,#0f172a,var(--brand-primary-2));border:none}.project-form-kpi--accent span,.project-form-kpi--accent strong,.project-form-kpi--accent small{color:#fff}.project-form-shell{display:grid;grid-template-columns:minmax(0,1.55fr) 340px;gap:18px;margin-top:18px}.project-form-main{display:flex;flex-direction:column;gap:18px}.project-form-card{padding:22px}.project-form-grid{display:flex;flex-direction:column;gap:18px}.project-form-section{padding:18px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}.project-form-grid-inner{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.project-form-grid-inner .col-span-2{grid-column:span 2}.project-form-section label{display:block;font-weight:600;margin-bottom:8px;color:#0f172a}.project-form-section input,.project-form-section select,.project-form-section textarea{width:100%}.project-form-section textarea{min-height:120px}.project-form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.project-form-aside{display:flex;flex-direction:column;gap:18px}.project-form-side-card{padding:20px}.project-form-shell .info-grid.compact{grid-template-columns:1fr}.project-form-shell .info-grid.compact div{background:#F8FAFC}.project-form-shell .card,.project-form-hero.card{border:1px solid #e2e8f0}@media (max-width: 1200px){.project-form-shell{grid-template-columns:1fr}.project-form-aside{order:-1}.project-form-kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.project-form-kpi-row,.project-form-grid-inner{grid-template-columns:1fr}.project-form-grid-inner .col-span-2{grid-column:span 1}.project-form-actions{justify-content:stretch}.project-form-actions .btn,.project-form-actions button{width:100%}}

/* Proposals redesign */
.eyebrow { display:inline-block; margin-bottom:8px; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#2563eb; }
.proposal-hero-top { display:flex; justify-content:space-between; gap:20px; align-items:flex-start; }
.proposal-hero-top h2 { margin:0 0 8px; font-size:30px; }
.proposal-hero-top p { margin:0; max-width:700px; color:var(--brand-muted); }
.proposal-kpi-grid { margin-top:22px; }
.proposal-stage-strip { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:12px; margin-top:18px; }
.stage-pill { background:#F8FAFC; border:1px solid var(--brand-border); border-radius:16px; padding:14px; }
.stage-pill strong { display:block; margin-bottom:4px; }
.stage-pill span { color:var(--brand-muted); font-size:13px; }
.stage-pill.success { background:#ecfdf5; border-color:#bbf7d0; }
.proposal-filter-grid { display:grid; grid-template-columns:2fr 1.2fr 1fr auto; gap:14px; align-items:end; }
.proposal-filter-actions { display:flex; gap:10px; }
.proposal-board { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:18px; margin-top:18px; }
.proposal-card { background:#fff; border:1px solid var(--brand-border); border-radius:18px; padding:18px; box-shadow:0 8px 25px rgba(15,23,42,.05); }
.proposal-card-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.proposal-card h3 { margin:4px 0 0; font-size:20px; }
.proposal-meta-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:16px 0; }
.proposal-meta-grid div, .proposal-context-grid div { background:#F8FAFC; border-radius:14px; padding:12px; }
.proposal-meta-grid strong, .proposal-context-grid strong { display:block; margin-bottom:6px; font-size:13px; color:#374151; }
.proposal-meta-grid span, .proposal-context-grid span { color:var(--brand-primary); font-size:14px; }
.proposal-value-row { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; margin:16px 0; }
.proposal-value-row > div { background:#F8FAFC; border-radius:14px; padding:12px; }
.proposal-alert-row { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:16px; }
.mini-alert { display:inline-block; padding:7px 10px; border-radius:999px; font-size:12px; font-weight:700; }
.mini-alert.danger { background:#FEE2E2; color:#991b1b; }
.mini-alert.warning { background:#FEF3C7; color:#92400e; }
.mini-alert.info { background:#DBEAFE; color:var(--brand-primary-2); }
.proposal-card-actions { justify-content:flex-start; }
.proposal-form-shell { display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:20px; }
.proposal-form-main { display:flex; flex-direction:column; gap:18px; }
.proposal-form-hero h2 { margin:0 0 8px; font-size:28px; }
.proposal-form-hero p { margin:0; color:var(--brand-muted); }
.proposal-form-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:16px; }
.proposal-form-grid.compact { gap:14px; }
.proposal-form-section { background:#F8FAFC; border:1px solid var(--brand-border); border-radius:18px; padding:18px; }
.proposal-form-section h3 { margin:0 0 14px; }
.proposal-summary-chips { display:flex; gap:10px; flex-wrap:wrap; margin-top:14px; }
.summary-chip { background:#eff6ff; color:var(--brand-primary-2); border-radius:999px; padding:8px 12px; font-size:13px; font-weight:700; }
.proposal-context-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:14px; }
.proposal-doc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:14px; }
.proposal-doc-card { border:1px solid var(--brand-border); border-radius:16px; padding:14px; display:flex; flex-direction:column; gap:12px; background:#fff; }
.sticky-card { position:sticky; top:24px; }
.plain-list { margin:0; padding-left:18px; }
.plain-list li { margin:0 0 10px; color:#4b5563; }
.empty-state-card { text-align:center; padding:28px; }
@media (max-width: 1100px) {
  .proposal-form-shell { grid-template-columns:1fr; }
  .proposal-context-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width: 800px) {
  .proposal-hero-top, .proposal-alert-row { flex-direction:column; align-items:flex-start; }
  .proposal-stage-strip, .proposal-filter-grid, .proposal-form-grid, .proposal-value-row, .proposal-context-grid, .proposal-meta-grid { grid-template-columns:1fr; }
  .proposal-filter-actions { width:100%; }
}


.finance-hero { background: linear-gradient(135deg, #eff6ff 0%, #ffffff 60%); }
.finance-kpis { margin-top: 18px; }
.finance-income strong, .finance-item-income strong { color: var(--brand-accent-dark); }
.finance-cost strong, .finance-item-cost strong { color: #991b1b; }
.finance-filter-bar { grid-template-columns: 1fr 1fr 1.2fr auto; }
.finance-stream { display: grid; gap: 14px; }
.finance-item {
    display: flex; justify-content: space-between; gap: 18px; align-items: center;
    padding: 16px 18px; border: 1px solid var(--brand-border); border-radius: 18px; background: #fff;
}
.finance-item-main h3 { margin: 6px 0 0; font-size: 17px; }
.finance-item-type { font-size: 12px; font-weight: 700; text-transform: uppercase; color: #64748b; letter-spacing: .04em; }
.finance-item-side { text-align: right; display: flex; flex-direction: column; gap: 10px; align-items: flex-end; }
.finance-item-income { border-left: 4px solid var(--brand-accent); }
.finance-item-cost { border-left: 4px solid #ef4444; }
@media (max-width: 980px) {
  .finance-item { flex-direction: column; align-items: flex-start; }
  .finance-item-side { align-items: flex-start; text-align: left; }
}


/* Pricing */
.pricing-hero {
    padding-bottom: 20px;
}
.pricing-hero-copy {
    max-width: 900px;
}
.pricing-strip {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 22px;
}
.pricing-strip-item {
    padding: 18px 20px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid var(--brand-border);
    box-shadow: 0 12px 28px rgba(15,23,42,0.05);
}
.pricing-strip-item strong {
    display: block;
    margin-bottom: 6px;
}
.pricing-strip-item span {
    color: #64748b;
    font-size: 14px;
}
.pricing-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
}
.pricing-card {
    border-radius: 24px;
    background: #fff;
    border: 1px solid var(--brand-border);
    box-shadow: 0 20px 40px rgba(15,23,42,0.06);
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.pricing-card-featured {
    border-color: #93c5fd;
    box-shadow: 0 24px 50px rgba(13,110,253,0.18);
    transform: translateY(-6px);
}
.pricing-card-top h2 {
    margin: 10px 0 10px;
    font-size: 28px;
}
.pricing-card-top p {
    margin: 0;
    color: #64748b;
    line-height: 1.7;
}
.pricing-value {
    display: flex;
    align-items: flex-end;
    gap: 10px;
}
.pricing-value strong {
    font-size: 40px;
    line-height: 1;
}
.pricing-value span {
    color: #64748b;
    font-weight: 600;
    margin-bottom: 4px;
}
.pricing-features {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}
.pricing-features li {
    position: relative;
    padding-left: 22px;
    color: #334155;
}
.pricing-features li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 0;
    color: var(--brand-accent-dark);
    font-weight: 800;
}
.btn-block {
    width: 100%;
    text-align: center;
}
.pricing-compare {
    overflow: hidden;
    padding: 0;
}
.pricing-compare-head,
.pricing-compare-row {
    display: grid;
    grid-template-columns: 1.25fr 0.9fr 0.9fr 0.9fr;
}
.pricing-compare-head > div {
    background: #0f172a;
    color: #fff;
    padding: 16px;
    font-weight: 700;
}
.pricing-compare-row > div {
    padding: 16px;
    border-top: 1px solid var(--brand-border);
}
.pricing-compare-row > div:not(:first-child),
.pricing-compare-head > div:not(:first-child) {
    text-align: center;
}
@media (max-width: 980px) {
    .pricing-strip,
    .pricing-grid {
        grid-template-columns: 1fr;
    }
    .pricing-card-featured {
        transform: none;
    }
}
@media (max-width: 720px) {
    .pricing-compare {
        overflow-x: auto;
    }
    .pricing-compare-head,
    .pricing-compare-row {
        min-width: 680px;
    }
}


body { background: linear-gradient(180deg, #F8FAFC 0%, #EEF4FF 100%); color: var(--brand-text); }
.btn { background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-2) 100%); box-shadow: 0 12px 24px rgba(11,42,91,0.18); }
.btn:hover { transform: translateY(-1px); }
.btn-light { background: #ffffff; color: var(--brand-primary); border: 1px solid var(--brand-border); box-shadow: none; }
input:focus, select:focus, textarea:focus { border-color: var(--brand-primary-2); box-shadow: 0 0 0 4px rgba(29,78,216,0.12); }
.brand-mark { display:none; }
.brand-logo-wrap { display:flex; align-items:center; }
.brand-logo { height: 44px; width:auto; display:block; }
.app-brand h2 { letter-spacing: -0.02em; }
.app-brand p { color: rgba(255,255,255,0.72); }
.sidebar { background: linear-gradient(180deg, var(--brand-primary) 0%, #081C3E 100%); }
.nav-group-title { color: rgba(255,255,255,0.55); text-transform: uppercase; letter-spacing: .08em; font-size: 11px; margin: 18px 0 10px; }
.nav-item.nav-active, .sidebar nav a:hover { background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.08); }
.sidebar-context-card { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 14px; margin-bottom: 18px; display:flex; flex-direction:column; gap:6px; }
.context-kicker, .context-role { color: rgba(255,255,255,0.72); font-size:12px; }
.page-header { padding: 4px 0 18px; border-bottom: 1px solid var(--brand-border); }
.topbar-kicker { color: var(--brand-accent-dark); text-transform: uppercase; letter-spacing: .08em; font-size: 12px; font-weight: 700; margin-bottom: 6px; }
.meta-pill { background: #fff; border: 1px solid var(--brand-border); border-radius: 999px; padding: 10px 14px; min-width: 130px; }
.meta-pill span { display:block; font-size:11px; color: var(--brand-muted); text-transform: uppercase; letter-spacing: .06em; }
.meta-pill strong { display:block; margin-top: 4px; color: var(--brand-primary); }
.card { border: 1px solid rgba(11,42,91,0.06); }
.login-page { background: radial-gradient(circle at top left, #1D4ED8 0%, #0B2A5B 52%, #081C3E 100%); }
.auth-brand { text-align:center; margin-bottom: 18px; }
.auth-brand img { height: 58px; width:auto; }
.login-card { border: 1px solid rgba(255,255,255,0.24); }
.login-card h1 { text-align:center; color: var(--brand-primary); }
.login-card p { text-align:center; }
.landing-brand img { height: 44px; width:auto; display:block; }
.hero-kicker, .section-kicker { color: var(--brand-accent-dark); font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.hero-section { background: linear-gradient(180deg, #F8FAFC 0%, #EAF2FF 100%); }
.hero-showcase { border-top: 4px solid var(--brand-accent); }
.pricing-card-featured { border: 2px solid var(--brand-accent); box-shadow: 0 20px 40px rgba(34,197,94,0.12); }
.footer-note { color: var(--brand-muted); font-size: 12px; margin-top: 18px; }
