:root {
    --gv-primary: #6558f5;
    --gv-primary-dark: #5145db;
    --gv-primary-soft: #efedff;
    --gv-sidebar: #141a2c;
    --gv-sidebar-muted: #8d96ae;
    --gv-bg: #f4f6fa;
    --gv-soft: #f4f6fa;
    --gv-card: #ffffff;
    --gv-text: #20263a;
    --gv-muted: #697189;
    --gv-border: #e6e9f0;
    --gv-success: #16a779;
    --gv-warning: #e99a24;
    --gv-danger: #e05260;
    --sidebar-width: 272px;
    --topbar-height: 72px;
}

[data-bs-theme="dark"] {
    --gv-bg: #111522;
    --gv-soft: #111522;
    --gv-card: #191f30;
    --gv-text: #edf0f8;
    --gv-muted: #9ca5bd;
    --gv-border: #2b3347;
    --bs-body-color: var(--gv-text);
    --bs-body-bg: var(--gv-bg);
}

* { box-sizing: border-box; }
body { margin: 0; color: var(--gv-text); background: var(--gv-bg); font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif; font-size: .9rem; }
a { text-decoration: none; }
.app-shell { min-height: 100vh; }
.sidebar { position: fixed; inset: 0 auto 0 0; z-index: 1040; width: var(--sidebar-width); background: var(--gv-sidebar); color: #fff; display: flex; flex-direction: column; padding: 18px 14px; overflow-y: auto; transition: transform .25s ease; scrollbar-width: thin; }
.brand { display: flex; align-items: center; gap: 11px; color: #fff; padding: 2px 8px 17px; }
.brand:hover { color: #fff; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 13px; background: linear-gradient(135deg, #8b7cff, var(--gv-primary)); font-size: 1.35rem; box-shadow: 0 7px 18px rgba(101, 88, 245, .35); }
.brand-mark img { width: 100%; height: 100%; object-fit: contain; border-radius: inherit; background: #fff; padding: 3px; }
.upload-current { display: flex; align-items: center; gap: 8px; min-height: 38px; padding: 7px 10px; border: 1px solid var(--gv-border); border-radius: 9px; background: var(--gv-bg); font-size: .75rem; }
.upload-current img { width: 48px; height: 38px; object-fit: contain; border-radius: 6px; background: #fff; }
.brand-copy, .company-pill > span:not(.avatar), .user-copy { display: flex; flex-direction: column; min-width: 0; }
.brand-copy strong { font-size: 1.04rem; letter-spacing: -.02em; }
.brand-copy small, .company-pill small { color: var(--gv-sidebar-muted); font-size: .7rem; }
.company-pill { display: flex; align-items: center; gap: 9px; border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.045); border-radius: 12px; padding: 10px; margin: 0 2px 16px; color: #fff; }
.company-pill:hover { color: #fff; background: rgba(255,255,255,.075); }
.company-pill strong { font-size: .79rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.company-pill > i { color: var(--gv-sidebar-muted); }
.sidebar-nav { flex: 1; }
.nav-section { margin-bottom: 3px; }
.nav-section-toggle { width: 100%; border: 0; background: transparent; color: #d7dbea; display: flex; align-items: center; justify-content: space-between; border-radius: 9px; padding: 9px 10px; font-size: .78rem; font-weight: 650; text-align: left; }
.nav-section-toggle > span { display: flex; align-items: center; gap: 10px; }
.nav-section-toggle > span i { width: 18px; font-size: .95rem; color: #aeb6cc; }
.nav-section-toggle .arrow { font-size: .65rem; transition: transform .2s; }
.nav-section-toggle:not(.collapsed) .arrow { transform: rotate(180deg); }
.nav-section-toggle:hover { background: rgba(255,255,255,.05); }
.sidebar .nav-link { color: var(--gv-sidebar-muted); display: flex; align-items: center; gap: 10px; padding: 8px 10px 8px 20px; border-radius: 9px; font-size: .76rem; margin: 2px 0; }
.sidebar .nav-link i { width: 17px; text-align: center; }
.sidebar .nav-link:hover { color: #fff; background: rgba(255,255,255,.05); }
.sidebar .nav-link.active { color: #fff; background: linear-gradient(100deg, rgba(101,88,245,.95), rgba(101,88,245,.65)); box-shadow: 0 5px 15px rgba(0,0,0,.14); }
.sidebar-help { display: flex; gap: 10px; padding: 12px; margin: 14px 2px 0; border-radius: 11px; background: rgba(101,88,245,.13); color: #d9d5ff; }
.sidebar-help > i { font-size: 1.15rem; }
.sidebar-help div { display: flex; flex-direction: column; }
.sidebar-help strong { font-size: .73rem; }
.sidebar-help small { font-size: .65rem; color: var(--gv-sidebar-muted); }
.app-main { margin-left: var(--sidebar-width); min-height: 100vh; display: flex; flex-direction: column; }
.topbar { position: sticky; top: 0; z-index: 1025; height: var(--topbar-height); display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 0 28px; background: color-mix(in srgb, var(--gv-card) 94%, transparent); border-bottom: 1px solid var(--gv-border); backdrop-filter: blur(14px); }
.quick-search { display: flex; align-items: center; width: min(430px, 42vw); height: 40px; padding: 0 12px; gap: 9px; border: 1px solid var(--gv-border); border-radius: 10px; background: var(--gv-bg); color: var(--gv-muted); }
.quick-search input { flex: 1; min-width: 0; border: 0; outline: 0; background: transparent; color: var(--gv-text); font-size: .81rem; }
.quick-search kbd { color: var(--gv-muted); border: 1px solid var(--gv-border); background: var(--gv-card); font-size: .63rem; box-shadow: none; }
.topbar-actions { display: flex; align-items: center; gap: 8px; }
.tenant-pill { align-items: center; gap: 7px; min-height: 39px; max-width: 280px; padding: 0 12px; border-radius: 999px; border: 1px solid color-mix(in srgb, var(--gv-primary) 28%, var(--gv-border)); background: var(--gv-primary-soft); color: var(--gv-primary); font-size: .72rem; font-weight: 700; white-space: nowrap; }
.tenant-pill span { overflow: hidden; text-overflow: ellipsis; }
.tenant-pill:hover { color: var(--gv-primary-dark); border-color: var(--gv-primary); }
.icon-btn { display: grid; place-items: center; border: 1px solid var(--gv-border); background: var(--gv-card); color: var(--gv-text); border-radius: 10px; width: 39px; height: 39px; font-size: 1rem; }
.icon-btn:hover { color: var(--gv-primary); border-color: color-mix(in srgb, var(--gv-primary) 35%, var(--gv-border)); }
.notification-dot { position: absolute; top: 8px; right: 8px; width: 7px; height: 7px; border-radius: 99px; background: var(--gv-danger); border: 1px solid #fff; }
.user-menu { display: flex; align-items: center; gap: 9px; border: 0; background: transparent; color: var(--gv-text); padding: 3px 2px 3px 7px; }
.avatar { display: grid; place-items: center; flex: 0 0 auto; width: 38px; height: 38px; border-radius: 11px; background: linear-gradient(135deg, #8074ff, var(--gv-primary)); color: #fff; font-size: .72rem; font-weight: 750; }
.avatar-sm { width: 32px; height: 32px; border-radius: 9px; font-size: .64rem; }
.user-copy { text-align: left; line-height: 1.25; }
.user-copy strong { font-size: .76rem; }
.user-copy small { color: var(--gv-muted); font-size: .66rem; }
.notification-menu { width: min(350px, 92vw); }
.notification-item { display: flex; align-items: center; gap: 11px; color: var(--gv-text); padding: 12px 15px; border-bottom: 1px solid var(--gv-border); }
.notification-item:hover { background: var(--gv-bg); }
.notification-item > span:last-child { display: flex; flex-direction: column; }
.notification-item strong { font-size: .76rem; }
.notification-item small { color: var(--gv-muted); font-size: .68rem; }
.soft-icon { display: grid; place-items: center; width: 35px; height: 35px; border-radius: 10px; }
.soft-icon.primary { background: #efedff; color: var(--gv-primary); }
.soft-icon.success { background: #e8f8f2; color: var(--gv-success); }
.soft-icon.warning { background: #fff4df; color: var(--gv-warning); }
.soft-icon.danger { background: #fff0f2; color: var(--gv-danger); }
.content-wrap { flex: 1; padding: 25px 28px 36px; max-width: 1800px; width: 100%; margin-inline: auto; }
.page-heading { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; margin-bottom: 22px; }
.page-heading h1 { font-size: 1.55rem; font-weight: 750; letter-spacing: -.035em; margin: 0; }
.page-heading p { color: var(--gv-muted); margin: 6px 0 0; font-size: .8rem; }
.breadcrumb { --bs-breadcrumb-divider: '›'; font-size: .69rem; color: var(--gv-muted); }
.breadcrumb-item.active { color: var(--gv-primary); }
.btn { border-radius: 9px; font-size: .78rem; font-weight: 600; padding: .57rem .9rem; display: inline-flex; align-items: center; justify-content: center; gap: 7px; }
.btn-primary { --bs-btn-bg: var(--gv-primary); --bs-btn-border-color: var(--gv-primary); --bs-btn-hover-bg: var(--gv-primary-dark); --bs-btn-hover-border-color: var(--gv-primary-dark); }
.card { --bs-card-bg: var(--gv-card); --bs-card-border-color: var(--gv-border); border-radius: 13px; box-shadow: 0 3px 14px rgba(35, 42, 66, .035); }
.card-header { background: transparent; border-color: var(--gv-border); padding: 17px 19px; }
.card-body { padding: 19px; }
.card-title-sm { font-size: .87rem; font-weight: 700; margin: 0; }
.stat-card { padding: 17px; height: 100%; position: relative; overflow: hidden; }
.stat-card::after { content: ''; position: absolute; right: -20px; top: -28px; width: 88px; height: 88px; border-radius: 50%; background: color-mix(in srgb, var(--stat-color, var(--gv-primary)) 8%, transparent); }
.stat-top { display: flex; align-items: center; justify-content: space-between; }
.stat-icon { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 11px; color: var(--stat-color, var(--gv-primary)); background: color-mix(in srgb, var(--stat-color, var(--gv-primary)) 12%, transparent); font-size: 1.05rem; }
.stat-trend { font-size: .65rem; font-weight: 700; color: var(--gv-success); }
.stat-card h3 { font-size: 1.35rem; margin: 14px 0 2px; font-weight: 750; letter-spacing: -.03em; }
.stat-card p { color: var(--gv-muted); margin: 0; font-size: .72rem; }
.table-card .card-body { padding: 0; }
.table { --bs-table-bg: transparent; --bs-table-color: var(--gv-text); --bs-table-border-color: var(--gv-border); margin: 0; vertical-align: middle; font-size: .76rem; }
.table > :not(caption) > * > * { padding: .82rem .85rem; }
.table thead th { color: var(--gv-muted); background: color-mix(in srgb, var(--gv-bg) 70%, transparent); text-transform: uppercase; letter-spacing: .04em; font-size: .63rem; font-weight: 700; white-space: nowrap; }
.table tbody tr:hover { background: color-mix(in srgb, var(--gv-primary) 2.5%, transparent); }
.budget-component-disabled { opacity: .45; text-decoration: line-through; }
.badge { font-size: .63rem; padding: .42em .68em; border-radius: 99px; font-weight: 650; }
.badge-soft-success { color: #0d875f; background: #e8f8f2; }
.badge-soft-danger { color: #c93e4e; background: #fff0f2; }
.badge-soft-warning { color: #a86b0f; background: #fff4df; }
.badge-soft-primary { color: #5548df; background: #efedff; }
.badge-soft-secondary { color: #657087; background: #edf0f5; }
.table-actions { display: flex; justify-content: flex-end; gap: 4px; }
.table-actions form { margin: 0; }
.action-btn { display: grid; place-items: center; width: 30px; height: 30px; border: 1px solid var(--gv-border); background: var(--gv-card); border-radius: 8px; color: var(--gv-muted); }
.action-btn:hover { color: var(--gv-primary); border-color: var(--gv-primary); }
.filter-card { margin-bottom: 18px; }
.filter-card .card-body { padding: 15px 17px; }
.form-label { font-size: .7rem; color: var(--gv-muted); font-weight: 650; margin-bottom: 5px; }
.form-control, .form-select { background-color: var(--gv-card); border-color: var(--gv-border); color: var(--gv-text); border-radius: 9px; font-size: .77rem; min-height: 39px; }
.form-control:focus, .form-select:focus { border-color: var(--gv-primary); box-shadow: 0 0 0 .18rem rgba(101,88,245,.12); }
.input-group-text { background: var(--gv-bg); border-color: var(--gv-border); color: var(--gv-muted); }
.section-title { display: flex; align-items: center; justify-content: space-between; margin-bottom: 13px; }
.section-title h2 { font-size: .92rem; font-weight: 700; margin: 0; }
.section-title a { font-size: .7rem; color: var(--gv-primary); }
.chart-wrap { position: relative; min-height: 260px; }
.quick-action { display: flex; align-items: center; gap: 11px; color: var(--gv-text); border: 1px solid var(--gv-border); border-radius: 11px; padding: 12px; height: 100%; transition: .18s; }
.quick-action:hover { border-color: color-mix(in srgb, var(--gv-primary) 45%, var(--gv-border)); transform: translateY(-2px); box-shadow: 0 7px 20px rgba(35,42,66,.07); }
.quick-action span:last-child { display: flex; flex-direction: column; }
.quick-action strong { font-size: .76rem; }
.quick-action small { color: var(--gv-muted); font-size: .65rem; }
.plan-card { border: 1px solid var(--gv-border); border-radius: 12px; padding: 15px; background: color-mix(in srgb, var(--gv-card) 92%, var(--gv-bg)); }
.plan-card:hover { border-color: color-mix(in srgb, var(--gv-primary) 34%, var(--gv-border)); box-shadow: 0 8px 24px rgba(35,42,66,.05); }
.progress { height: 6px; background: var(--gv-bg); }
.app-footer { display: flex; justify-content: space-between; padding: 15px 28px; color: var(--gv-muted); border-top: 1px solid var(--gv-border); font-size: .66rem; }
.empty-state { padding: 50px 20px; text-align: center; color: var(--gv-muted); }
.empty-state i { display: block; font-size: 2.2rem; margin-bottom: 10px; color: color-mix(in srgb, var(--gv-muted) 60%, transparent); }
.empty-state h5 { color: var(--gv-text); font-size: .9rem; }
.modal-danger-icon { display: inline-grid; place-items: center; width: 58px; height: 58px; border-radius: 50%; color: var(--gv-danger); background: #fff0f2; font-size: 1.4rem; }
.kanban-board { display: grid; grid-template-columns: repeat(6, minmax(240px, 1fr)); gap: 13px; overflow-x: auto; padding-bottom: 12px; }
.kanban-column { background: color-mix(in srgb, var(--gv-bg) 82%, var(--gv-card)); border: 1px solid var(--gv-border); border-radius: 13px; padding: 11px; min-height: 480px; }
.kanban-column-over { border-color: var(--gv-primary); background: color-mix(in srgb, var(--gv-primary) 7%, var(--gv-card)); }
.kanban-head { display: flex; justify-content: space-between; align-items: center; padding: 3px 3px 11px; font-size: .75rem; font-weight: 700; }
.kanban-head span:last-child { display: grid; place-items: center; min-width: 24px; height: 24px; border-radius: 99px; background: var(--gv-card); color: var(--gv-muted); font-size: .65rem; }
.kanban-card { background: var(--gv-card); border: 1px solid var(--gv-border); border-radius: 11px; padding: 12px; margin-bottom: 9px; cursor: grab; box-shadow: 0 2px 7px rgba(35,42,66,.03); }
.kanban-card:hover { border-color: color-mix(in srgb, var(--gv-primary) 40%, var(--gv-border)); }
.kanban-card h6 { font-size: .77rem; margin: 7px 0 4px; }
.kanban-card p { font-size: .68rem; color: var(--gv-muted); margin-bottom: 10px; }
.kanban-meta { display: flex; justify-content: space-between; color: var(--gv-muted); font-size: .64rem; }
.pipeline-dot { display: inline-block; width: 7px; height: 7px; border-radius: 99px; margin-right: 5px; background: var(--column-color); }
.production-board { display: grid; grid-template-columns: repeat(7, minmax(230px, 1fr)); gap: 13px; overflow-x: auto; padding-bottom: 12px; }
.timeline { position: relative; padding-left: 24px; }
.timeline::before { content: ''; position: absolute; left: 7px; top: 5px; bottom: 5px; width: 2px; background: var(--gv-border); }
.timeline-item { position: relative; padding: 0 0 20px 15px; }
.timeline-item::before { content: ''; position: absolute; left: -21px; top: 4px; width: 12px; height: 12px; border-radius: 50%; background: var(--gv-primary); border: 3px solid var(--gv-card); box-shadow: 0 0 0 2px var(--gv-primary-soft); }
.timeline-item h6 { font-size: .77rem; margin: 0 0 3px; }
.timeline-item p { color: var(--gv-muted); font-size: .68rem; margin: 0; }
.chat-shell { display: grid; grid-template-columns: 290px 1fr 280px; height: calc(100vh - 155px); min-height: 600px; background: var(--gv-card); border: 1px solid var(--gv-border); border-radius: 14px; overflow: hidden; }
.chat-list, .chat-details { border-right: 1px solid var(--gv-border); overflow-y: auto; }
.chat-details { border-right: 0; border-left: 1px solid var(--gv-border); }
.chat-pane { display: flex; flex-direction: column; background: color-mix(in srgb, var(--gv-bg) 60%, var(--gv-card)); min-width: 0; }
.chat-header, .chat-panel-head { min-height: 65px; padding: 12px 15px; display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--gv-border); background: var(--gv-card); }
.conversation { display: flex; gap: 10px; padding: 12px 14px; border-bottom: 1px solid var(--gv-border); color: var(--gv-text); }
.conversation:hover, .conversation.active { background: var(--gv-primary-soft); }
.conversation-copy { min-width: 0; flex: 1; }
.conversation-copy div { display: flex; justify-content: space-between; }
.conversation-copy strong { font-size: .73rem; }
.conversation-copy small, .conversation-copy p { color: var(--gv-muted); font-size: .64rem; }
.conversation-copy p { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin: 3px 0 0; }
.chat-messages { flex: 1; overflow-y: auto; padding: 22px; }
.message-row { display: flex; margin-bottom: 11px; }
.message-row.out { justify-content: flex-end; }
.message { max-width: 70%; border-radius: 5px 13px 13px 13px; background: var(--gv-card); padding: 10px 12px 6px; box-shadow: 0 2px 8px rgba(35,42,66,.06); font-size: .76rem; }
.message-row.out .message { background: #dedaff; border-radius: 13px 5px 13px 13px; }
.message time { display: block; text-align: right; color: var(--gv-muted); font-size: .57rem; margin-top: 4px; }
.chat-compose { display: flex; align-items: center; gap: 8px; padding: 11px; border-top: 1px solid var(--gv-border); background: var(--gv-card); }
.chat-compose input { flex: 1; }
.detail-section { padding: 16px; border-bottom: 1px solid var(--gv-border); }
.detail-section h6 { font-size: .7rem; color: var(--gv-muted); text-transform: uppercase; letter-spacing: .05em; }
.permission-table th:first-child, .permission-table td:first-child { position: sticky; left: 0; z-index: 2; background: var(--gv-card); }
.file-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.file-card { border: 1px solid var(--gv-border); border-radius: 11px; padding: 14px; color: var(--gv-text); }
.file-card:hover { border-color: var(--gv-primary); }
.file-card > i { font-size: 2rem; color: var(--gv-primary); }
.file-card strong, .file-card small { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.file-card strong { font-size: .73rem; margin-top: 9px; }
.file-card small { color: var(--gv-muted); font-size: .62rem; }
.report-card { color: var(--gv-text); transition: .18s; }
.report-card:hover { transform: translateY(-3px); border-color: color-mix(in srgb, var(--gv-primary) 35%, var(--gv-border)); box-shadow: 0 10px 25px rgba(35,42,66,.07); }
.report-card .card-body { display: flex; align-items: flex-start; gap: 13px; }
.auth-body { min-height: 100vh; background: #11172a; }
.auth-shell { min-height: 100vh; display: grid; grid-template-columns: minmax(420px, .9fr) 1.2fr; }
.auth-form-side { background: var(--gv-card); display: flex; align-items: center; justify-content: center; padding: 40px; }
.auth-form { width: min(410px, 100%); }
.auth-form .brand-mark { display: inline-grid; margin-bottom: 28px; }
.auth-form h1 { font-size: 1.7rem; font-weight: 750; letter-spacing: -.04em; }
.auth-visual { position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; padding: 60px; color: #fff; background: radial-gradient(circle at 75% 20%, rgba(101,88,245,.5), transparent 32%), radial-gradient(circle at 20% 80%, rgba(32,183,183,.22), transparent 28%), #141a2c; }
.auth-visual::before { content: ''; position: absolute; inset: 0; opacity: .12; background-image: linear-gradient(rgba(255,255,255,.4) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.4) 1px, transparent 1px); background-size: 48px 48px; }
.auth-showcase { position: relative; z-index: 1; max-width: 620px; }
.auth-showcase h2 { font-size: clamp(2rem, 4vw, 3.6rem); font-weight: 750; letter-spacing: -.055em; line-height: 1.05; }
.auth-showcase p { color: #aab2c8; max-width: 520px; font-size: 1rem; }
.auth-metric { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.09); border-radius: 14px; padding: 16px; backdrop-filter: blur(12px); }
.auth-metric strong { display: block; font-size: 1.3rem; }
.auth-metric small { color: #aab2c8; }
.error-page { min-height: 100vh; display: grid; place-items: center; text-align: center; padding: 30px; background: var(--gv-bg); }
.error-code { font-size: clamp(5rem, 14vw, 9rem); line-height: 1; font-weight: 800; letter-spacing: -.08em; color: var(--gv-primary); opacity: .16; }
.sidebar-backdrop { display: none; }

/* PCP */
.pcp-grid{min-width:1180px;table-layout:fixed}.pcp-grid th{background:var(--gv-soft);font-size:.72rem;text-align:center}.pcp-grid .pcp-resource-column{width:205px;text-align:left}.pcp-resource-cell{position:sticky;left:0;z-index:3;background:var(--gv-card)!important}.pcp-resource-cell strong,.pcp-resource-cell small{display:block}.pcp-resource-cell small{color:var(--gv-muted);font-size:.66rem}.pcp-resource-color{display:inline-block;width:9px;height:9px;margin-right:6px;border-radius:50%;background:var(--resource-color)}.pcp-drop-zone{position:relative;height:142px;padding:6px!important;vertical-align:top!important;background:color-mix(in srgb,var(--gv-card) 96%,var(--gv-soft))}.pcp-drop-zone.pcp-today,.pcp-grid th.pcp-today{background:color-mix(in srgb,var(--gv-primary) 7%,var(--gv-card))}.pcp-drop-zone.is-over{box-shadow:inset 0 0 0 2px var(--gv-primary);background:var(--gv-primary-soft)}.pcp-plan-card{position:relative;margin-bottom:5px;padding:8px 9px;border:1px solid color-mix(in srgb,var(--resource-color) 35%,var(--gv-border));border-left:3px solid var(--resource-color);border-radius:8px;background:var(--gv-card);cursor:grab;box-shadow:0 3px 10px rgba(26,28,45,.05)}.pcp-plan-card:hover{transform:translateY(-1px);box-shadow:0 7px 16px rgba(26,28,45,.1)}.pcp-plan-card.is-dragging{opacity:.45}.pcp-plan-card.is-late{border-color:#e05260}.pcp-plan-card strong{font-size:.7rem}.pcp-plan-card>small{display:block;overflow:hidden;color:var(--gv-muted);font-size:.59rem;text-overflow:ellipsis;white-space:nowrap}.pcp-plan-card .badge{font-size:.5rem}.pcp-late-icon{position:absolute;right:7px;bottom:7px;color:#e05260}.pcp-cell-add{position:absolute;right:5px;bottom:5px;width:25px;height:25px;border:1px dashed var(--gv-border);border-radius:7px;background:transparent;color:var(--gv-muted);opacity:0}.pcp-drop-zone:hover .pcp-cell-add{opacity:1}.pcp-capacity-list{display:grid;gap:18px}.pcp-capacity-list>div>small{font-size:.62rem}.pcp-resource-chips{display:flex;flex-wrap:wrap;gap:7px}.pcp-resource-chips button{display:flex;align-items:center;gap:6px}.pcp-resource-chips button span{width:9px;height:9px;border-radius:50%}

@media (max-width: 1199.98px) {
    .chat-shell { grid-template-columns: 250px 1fr; }
    .chat-details { display: none; }
}

@media (max-width: 991.98px) {
    .sidebar { transform: translateX(-100%); box-shadow: 15px 0 40px rgba(0,0,0,.25); }
    body.sidebar-open .sidebar { transform: translateX(0); }
    .sidebar-backdrop { position: fixed; inset: 0; z-index: 1035; background: rgba(5,8,18,.55); backdrop-filter: blur(2px); }
    body.sidebar-open .sidebar-backdrop { display: block; }
    .app-main { margin-left: 0; }
    .topbar { padding-inline: 18px; }
    .content-wrap { padding: 20px 18px 30px; }
    .auth-shell { grid-template-columns: 1fr; }
    .auth-visual { display: none; }
}

@media (max-width: 767.98px) {
    .quick-search { width: auto; flex: 1; }
    .quick-search kbd { display: none; }
    .page-heading { align-items: flex-start; flex-direction: column; }
    .page-heading .btn { width: 100%; }
    .content-wrap { padding-inline: 13px; }
    .topbar { padding-inline: 13px; gap: 9px; }
    .app-footer { padding-inline: 15px; }
    .app-footer span:last-child { display: none; }
    .chat-shell { grid-template-columns: 1fr; height: calc(100vh - 140px); }
    .chat-list { display: none; }
    .message { max-width: 88%; }
    .auth-form-side { padding: 26px 20px; }
}

