:root {
    --navy: #020B45;
    --deep-navy: #00062E;
    --blue: #123A83;
    --sky: #E9F0FF;
    --pale: #F7F9FE;
    --bg: #F3F6FB;
    --card: #FFFFFF;
    --orange: #D30624;
    --crimson: #B9001E;
    --amber: #F6A609;
    --gold: #F6A609;
    --green: #18A77B;
    --red: #D30624;
    --ink: #111A35;
    --muted: #657088;
    --line: #DDE4F0;
    --shadow: 0 18px 44px rgba(2, 11, 69, .12);
    --radius: 8px;
    --font-ui: Inter, "Segoe UI", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Arial, sans-serif;
    --mobile-nav-height: 74px;
    --mobile-safe-bottom: env(safe-area-inset-bottom);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    color: var(--ink);
    background: var(--bg);
    font-family: var(--font-ui);
    font-size: 14px;
    line-height: 1.45;
    opacity: 0;
    transition: opacity .22s ease;
}
body.is-ready { opacity: 1; }
body.is-leaving { opacity: .72; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
h1, h2, h3, h4 { font-weight: 850; letter-spacing: 0; }
.icon { width: 18px; height: 18px; stroke-width: 2; }
.muted { color: var(--muted); }
.page-preloader {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: grid;
    place-items: center;
    background: rgba(2,11,69,.82);
    opacity: 0;
    pointer-events: none;
    transition: opacity .18s ease;
    backdrop-filter: blur(10px);
}
.page-preloader.show {
    opacity: 1;
    pointer-events: auto;
}
.preloader-card {
    width: 96px;
    height: 96px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    position: relative;
    background: rgba(255,255,255,.94);
    box-shadow: 0 24px 70px rgba(0,0,0,.28);
}
.preloader-card:before {
    content: "";
    position: absolute;
    inset: -7px;
    border-radius: inherit;
    border: 4px solid rgba(246,166,9,.24);
    border-top-color: #F6A609;
    border-right-color: #D30624;
    animation: preloader-spin .82s linear infinite;
}
.preloader-card img {
    width: 54px;
    height: 54px;
    object-fit: contain;
    position: relative;
    z-index: 1;
}
.preloader-card span {
    position: absolute;
    width: 132px;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(246,166,9,.85), transparent);
    transform: rotate(-24deg);
    animation: preloader-line 1.4s ease-in-out infinite;
}
.app-toast {
    position: fixed;
    top: 18px;
    left: 50%;
    z-index: 220;
    transform: translate(-50%, -16px);
    opacity: 0;
    max-width: min(92vw, 380px);
    padding: 11px 16px;
    border: 1px solid rgba(246,166,9,.34);
    border-radius: 999px;
    background: linear-gradient(135deg, #020B45, #06175F);
    color: #fff;
    box-shadow: 0 18px 46px rgba(2,11,69,.24);
    font-size: 13px;
    font-weight: 850;
    text-align: center;
    transition: opacity .2s ease, transform .2s ease;
    pointer-events: none;
}
.app-toast.show {
    opacity: 1;
    transform: translate(-50%, 0);
}
@keyframes preloader-spin { to { transform: rotate(360deg); } }
@keyframes preloader-line {
    0%, 100% { opacity: .28; transform: rotate(-24deg) translateX(-12px); }
    50% { opacity: 1; transform: rotate(-24deg) translateX(12px); }
}
.page-login {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(420px, 1fr) minmax(500px, 650px);
    background: #F7F9FE;
}
.login-hero {
    position: relative;
    overflow: hidden;
    padding: 56px;
    background:
        linear-gradient(90deg, rgba(0,6,46,.08), rgba(0,6,46,.02)),
        url("../image/login-bg.jpg") center center / cover no-repeat;
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    min-height: 100vh;
}
.login-hero:before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 18% 18%, rgba(255,255,255,.08), transparent 28%),
        linear-gradient(90deg, rgba(0,6,46,.22), transparent 54%, rgba(0,6,46,.10));
    opacity: .82;
    pointer-events: none;
}
.login-hero:after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(120deg, rgba(255,255,255,.045) 0 1px, transparent 1px) 0 0 / 34px 34px,
        radial-gradient(circle at 84% 22%, rgba(211,6,36,.10), transparent 28%);
    opacity: .44;
    pointer-events: none;
}
.login-hero > * { position: relative; z-index: 1; }
.login-cyber-lines {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}
.login-cyber-lines:before,
.login-cyber-lines:after {
    content: "";
    position: absolute;
    width: 62%;
    height: 2px;
    left: -70%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.74), rgba(246,166,9,.64), transparent);
    filter: drop-shadow(0 0 10px rgba(246,166,9,.34));
    animation: cyber-scan 7.5s linear infinite;
}
.login-cyber-lines:before {
    top: 28%;
}
.login-cyber-lines:after {
    top: 44%;
    animation-delay: 2.8s;
    opacity: .72;
}
@keyframes cyber-scan {
    0% { transform: translateX(0) skewX(-28deg); }
    100% { transform: translateX(290%) skewX(-28deg); }
}
@media (prefers-reduced-motion: reduce) {
    .login-cyber-lines:before,
    .login-cyber-lines:after,
    .sidebar:before,
    .sidebar:after,
    .page-login:before,
    .page-login:after,
    .preloader-card:before,
    .preloader-card span {
        animation: none;
    }
}
.brand-lockup { display: flex; align-items: center; gap: 12px; }
.brand-mark {
    width: 44px;
    height: 44px;
    border-radius: var(--radius);
    background: linear-gradient(135deg, var(--navy) 0 54%, var(--red) 55% 100%);
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 900;
    letter-spacing: 0;
}
.brand-lockup strong { display: block; font-size: 16px; letter-spacing: 0; }
.brand-lockup small { display: block; color: var(--muted); margin-top: 2px; }
.login-logo-lockup {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: #fff;
}
.login-logo {
    width: min(360px, 38vw);
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 18px 30px rgba(0,0,0,.22));
}
.login-logo-lockup span { display: none; }
.login-hero h1 {
    max-width: 660px;
    font-size: clamp(34px, 3.7vw, 50px);
    line-height: 1;
    letter-spacing: 0;
    margin: 0 0 18px;
}
.login-hero .crm-red { color: var(--red); }
.login-hero p { max-width: 620px; color: rgba(255,255,255,.78); font-size: 17px; margin: 0; }
.login-copy-card {
    width: min(610px, 100%);
    margin-top: 82px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(255,255,255,.15), rgba(255,255,255,.07));
    box-shadow: 0 22px 70px rgba(0,0,0,.20);
    backdrop-filter: blur(14px);
    padding: 20px;
}
.login-visual-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-top: 22px; max-width: 560px; }
.login-visual-card {
    border: 1px solid rgba(246,166,9,.34);
    background:
        radial-gradient(circle at 12% 8%, rgba(255,255,255,.22), transparent 28%),
        linear-gradient(135deg, rgba(246,166,9,.22), rgba(255,255,255,.08) 44%, rgba(211,6,36,.10));
    border-radius: var(--radius);
    padding: 14px;
    min-height: 82px;
    box-shadow: 0 16px 34px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.18);
    backdrop-filter: blur(14px);
}
.login-visual-card .icon { color: #FFD46A; filter: drop-shadow(0 5px 12px rgba(246,166,9,.24)); }
.login-visual-card b { display: block; margin-top: 9px; }
.login-visual-card span { display: block; color: rgba(255,255,255,.78); font-size: 13px; margin-top: 3px; }
.login-panel {
    position: relative;
    overflow: hidden;
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 34px;
    background:
        radial-gradient(circle at 90% 8%, rgba(211,6,36,.06), transparent 22%),
        linear-gradient(135deg, #fff 0%, #F3F6FB 100%);
}
.login-panel:before {
    display: none;
}
.login-panel > div { position: relative; z-index: 1; }
.login-language-switcher {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 10px;
}
.login-language-switcher button,
.language-switcher button {
    border: 1px solid rgba(246,166,9,.34);
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(246,166,9,.16), rgba(255,255,255,.88));
    color: var(--navy);
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 11px;
    font-weight: 900;
    cursor: pointer;
}
.login-card {
    width: min(100%, 520px);
    background: rgba(255,255,255,.92);
    border: 1px solid rgba(255,255,255,.72);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
    padding: 26px;
}
.login-card-mobile-logo,
.mobile-login-footnote {
    display: none;
}
.login-footnote {
    position: absolute;
    left: 56px;
    bottom: 28px;
    z-index: 2;
    padding: 9px 13px;
    border: 1px solid rgba(255,255,255,.28);
    border-radius: 999px;
    background: linear-gradient(135deg, #F6A609, #C77800);
    color: #fff;
    font-weight: 850;
    text-shadow: 0 1px 3px rgba(0,0,0,.25);
    box-shadow: 0 14px 32px rgba(0,0,0,.18), 0 0 0 4px rgba(246,166,9,.14), inset 0 1px 0 rgba(255,255,255,.18);
    backdrop-filter: blur(12px);
}
.mobile-brand { display: none; margin-bottom: 18px; }
.mobile-brand-logo { width: 44px; height: 44px; object-fit: contain; }
.login-card h2 { margin: 0 0 4px; color: var(--navy); font-size: 24px; letter-spacing: 0; }
.login-card p { margin: 0 0 22px; color: var(--muted); }
.field { display: grid; gap: 7px; margin-bottom: 14px; }
.field label { font-size: 13px; font-weight: 750; color: #344054; }
.auth-input-wrap {
    position: relative;
    display: block;
}
.auth-input-wrap .icon,
.auth-input-wrap svg.icon {
    position: absolute;
    left: 13px;
    top: 50%;
    width: 18px;
    height: 18px;
    color: #667085;
    transform: translateY(-50%);
    pointer-events: none;
    z-index: 2;
}
.auth-input-wrap .input {
    padding-left: 42px;
}
.input, .select, .textarea {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    color: var(--ink);
    padding: 11px 12px;
    outline: none;
}
.textarea { min-height: 96px; resize: vertical; }
.input:focus, .select:focus, .textarea:focus { border-color: var(--red); box-shadow: 0 0 0 3px rgba(211,6,36,.12); }
.btn {
    border: 0;
    border-radius: var(--radius);
    min-height: 40px;
    padding: 9px 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 800;
    cursor: pointer;
    background: #fff;
    color: var(--navy);
    border: 1px solid var(--line);
}
.btn.primary { background: linear-gradient(135deg, var(--red), var(--crimson)); border-color: var(--red); color: #fff; box-shadow: 0 10px 22px rgba(211,6,36,.18); }
.btn.navy { background: var(--navy); border-color: var(--navy); color: #fff; }
.btn.ghost { background: var(--pale); color: var(--navy); }
.btn.danger { color: var(--red); border-color: #F3C7C3; background: #FFF5F4; }
.btn.full { width: 100%; }
.demo-divider { display: flex; align-items: center; gap: 10px; margin: 18px 0 12px; color: var(--muted); font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.demo-divider:before, .demo-divider:after { content: ""; height: 1px; flex: 1; background: var(--line); }
.demo-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
.demo-grid .btn {
    justify-content: flex-start;
    min-height: 48px;
    font-size: 12px;
    padding: 7px 8px;
    text-align: left;
}
.demo-role-icon {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 34% 28%, #FFF3BE 0 18%, transparent 19%),
        linear-gradient(135deg, rgba(246,166,9,.22), rgba(255,255,255,.95));
    border: 1px solid rgba(246,166,9,.35);
    box-shadow: 0 8px 16px rgba(2,11,69,.08);
    overflow: hidden;
}
.demo-role-icon img {
    width: 24px;
    height: 24px;
    object-fit: contain;
    display: block;
}
.error { color: var(--red); font-size: 13px; margin: 8px 0 0; }
.app-shell { min-height: 100vh; display: grid; grid-template-columns: 270px 1fr; transition: grid-template-columns .2s ease; }
html[data-sidebar="collapsed"] .app-shell { grid-template-columns: 88px 1fr; }
.sidebar {
    background-color: #020B45;
    background-image: url("../image/sidebar-background.jpg");
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-right: 1px solid rgba(255,255,255,.08);
    padding: 18px 14px;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow: auto;
    transition: padding .2s ease;
    isolation: isolate;
}
.sidebar:before,
.sidebar:after {
    content: "";
    position: absolute;
    left: -72%;
    width: 145%;
    height: 2px;
    z-index: 0;
    background: linear-gradient(90deg, transparent, rgba(246,166,9,.78), rgba(255,255,255,.42), transparent);
    filter: drop-shadow(0 0 10px rgba(246,166,9,.28));
    transform: rotate(-28deg);
    animation: sidebar-cyber-line 8s linear infinite;
    pointer-events: none;
}
.sidebar:before { top: 22%; opacity: .56; animation-duration: 9s; }
.sidebar:after { top: 56%; animation-delay: 3.2s; opacity: .86; }
.sidebar > * { position: relative; z-index: 1; }
@keyframes sidebar-cyber-line {
    0% { transform: translateX(-16%) rotate(-28deg); opacity: 0; }
    12%, 78% { opacity: 1; }
    100% { transform: translateX(145%) rotate(-28deg); opacity: 0; }
}
.sidebar-top {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 2px 2px 20px;
}
.sidebar-brand {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    color: #fff;
}
.sidebar-logo-full {
    width: 188px;
    max-width: 100%;
    height: auto;
    object-fit: contain;
}
.sidebar-logo-collapsed {
    display: none;
    width: 44px;
    height: 44px;
    object-fit: contain;
}
.sidebar-toggle {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: var(--radius);
    background: rgba(255,255,255,.08);
    color: #fff;
    display: grid;
    place-items: center;
    cursor: pointer;
}
.sidebar-toggle-closed { display: none; }
html[data-sidebar="collapsed"] .sidebar {
    padding-left: 12px;
    padding-right: 12px;
}
html[data-sidebar="collapsed"] .sidebar-top {
    display: grid;
    justify-items: center;
    gap: 10px;
}
html[data-sidebar="collapsed"] .sidebar-logo-full,
html[data-sidebar="collapsed"] .nav-item span,
html[data-sidebar="collapsed"] .nav-section-label,
html[data-sidebar="collapsed"] .sidebar .mini-item {
    display: none;
}
html[data-sidebar="collapsed"] .sidebar-logo-collapsed { display: block; }
html[data-sidebar="collapsed"] .sidebar-brand { justify-content: center; }
html[data-sidebar="collapsed"] .sidebar-toggle-open { display: none; }
html[data-sidebar="collapsed"] .sidebar-toggle-closed { display: block; }
html[data-sidebar="collapsed"] .nav-item {
    justify-content: center;
    padding: 11px 0;
}
html[data-sidebar="collapsed"] .role-context-badge {
    grid-template-columns: 1fr;
    justify-items: center;
    padding: 8px;
    margin: 10px 0 0;
}
html[data-sidebar="collapsed"] .role-context-badge div {
    display: none;
}
html[data-sidebar="collapsed"] .role-icon-shell {
    width: 36px;
    height: 36px;
}
.sidebar .brand-lockup { margin: 2px 6px 20px; color: #fff; }
.sidebar .brand-lockup small { color: rgba(255,255,255,.62); }
.sidebar .brand-mark { background: linear-gradient(135deg, #fff 0 48%, var(--red) 49% 100%); color: var(--navy); }
.nav-section-label { margin: 20px 10px 8px; color: rgba(255,255,255,.50); font-size: 11px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.nav-list { display: grid; gap: 4px; }
.nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    border-radius: var(--radius);
    padding: 10px;
    color: rgba(255,255,255,.82);
    font-weight: 750;
    font-size: 14px;
    background: rgba(2,11,69,.18);
    border: 1px solid transparent;
    text-shadow: 0 1px 2px rgba(0,0,0,.18);
}
.nav-item:hover {
    background: rgba(255,255,255,.12);
    border-color: rgba(255,255,255,.12);
    color: #fff;
}
.nav-item.active {
    background: linear-gradient(135deg, rgba(246,166,9,.24), rgba(211,6,36,.16));
    border-color: rgba(246,166,9,.38);
    color: #fff;
    box-shadow: inset 3px 0 0 var(--gold), 0 10px 22px rgba(0,0,0,.16);
}
.main-wrap {
    min-width: 0;
    padding-bottom: 76px;
    background:
        linear-gradient(rgba(247,249,254,.88), rgba(247,249,254,0.6)),
        url("../image/synar-bg-desktop.jpg") top center / 1600px auto fixed;
}
.topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    height: 68px;
    background: rgba(255,255,255,.78);
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(221,228,240,.9);
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 0 24px;
}
.page-title { flex: 1; min-width: 0; }
.page-title h1 { margin: 0; font-size: 20px; letter-spacing: 0; color: var(--navy); }
.page-title small { color: var(--muted); }
.global-search { width: min(360px, 34vw); position: relative; }
.global-search .icon { position: absolute; left: 11px; top: 11px; color: var(--muted); }
.global-search input { padding-left: 38px; }
.guide-chip {
    border: 1px solid rgba(246,166,9,.34);
    border-radius: var(--radius);
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 8px 11px;
    color: var(--navy);
    background: linear-gradient(135deg, #fff, #FFF8E8);
    font-weight: 950;
    cursor: pointer;
    box-shadow: 0 10px 26px rgba(2,11,69,.06);
}
.guide-chip:hover {
    color: #fff;
    border-color: rgba(246,166,9,.65);
    background: linear-gradient(135deg, var(--navy), var(--red));
}
.guide-chip .icon { width: 18px; height: 18px; }
.environment-badge {
    min-height: 38px;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: 999px;
    background: rgba(255,255,255,.88);
    color: var(--navy);
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 7px 11px;
    font-size: 12px;
    font-weight: 950;
    white-space: nowrap;
    box-shadow: 0 10px 24px rgba(2,11,69,.06);
}
.environment-badge .icon {
    width: 16px;
    height: 16px;
}
.environment-badge.uat {
    border-color: rgba(246,166,9,.34);
    background: linear-gradient(135deg, #FFF8E8, #fff);
    color: #8A5400;
}
.environment-badge.production {
    border-color: rgba(24,167,123,.24);
    background: linear-gradient(135deg, rgba(24,167,123,.12), #fff);
    color: #08734F;
}
.user-chip, .notification-chip {
    background: rgba(255,255,255,.82);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    color: var(--navy);
    font-weight: 800;
}
button.notification-chip { cursor: pointer; }
.user-chip span { display: block; max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.notification-menu { position: relative; }
.notification-chip span {
    min-width: 20px;
    height: 20px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(211,6,36,.10);
    color: var(--red);
    font-size: 12px;
    line-height: 1;
}
.notification-dropdown {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: 360px;
    display: none;
    background: rgba(255,255,255,.94);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
    z-index: 45;
    overflow: hidden;
}
.notification-menu.open .notification-dropdown { display: block; }
.notification-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border-bottom: 1px solid var(--line);
    background: linear-gradient(135deg, rgba(2,11,69,.04), rgba(246,166,9,.08));
}
.notification-head b,
.notification-head small {
    display: block;
}
.notification-head b { color: var(--navy); }
.notification-head small { color: var(--muted); font-size: 12px; margin-top: 2px; }
.notification-head button {
    border: 1px solid rgba(246,166,9,.36);
    border-radius: 999px;
    background: linear-gradient(135deg, #F6A609, #C77800);
    color: #fff;
    padding: 7px 10px;
    font-size: 12px;
    font-weight: 900;
    cursor: pointer;
    white-space: nowrap;
}
.notification-list { max-height: 330px; overflow: auto; padding: 8px; display: grid; gap: 7px; }
.notification-item {
    display: grid;
    grid-template-columns: 10px 1fr;
    gap: 10px;
    align-items: start;
    border: 1px solid transparent;
    border-radius: var(--radius);
    padding: 10px;
    color: var(--navy);
    background: #fff;
}
.notification-item:hover { border-color: var(--line); background: var(--pale); }
.notification-item.unread {
    border-color: rgba(211,6,36,.16);
    background: linear-gradient(135deg, rgba(211,6,36,.06), rgba(255,255,255,.95));
}
.notification-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    margin-top: 6px;
    background: #C6D1E3;
}
.notification-item.unread .notification-dot { background: var(--red); box-shadow: 0 0 0 4px rgba(211,6,36,.09); }
.notification-item b,
.notification-item small {
    display: block;
}
.notification-item b { font-size: 13px; }
.notification-item small {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.4;
    margin-top: 3px;
}
.notification-empty {
    padding: 14px;
    color: var(--muted);
    font-weight: 750;
    text-align: center;
}
.notification-see-all {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 11px 12px;
    border-top: 1px solid var(--line);
    color: var(--navy);
    font-weight: 900;
    background: #fff;
}
.notification-see-all:hover { background: var(--pale); }
.role-guide-focus {
    position: fixed;
    z-index: 95;
    border: 2px solid var(--gold);
    border-radius: 18px;
    box-shadow: 0 0 0 9999px rgba(2,11,69,.68), 0 18px 40px rgba(246,166,9,.18);
    pointer-events: none;
    transition: top .2s ease, left .2s ease, width .2s ease, height .2s ease;
}
.role-guide-focus:after {
    content: "";
    position: absolute;
    inset: -7px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.42);
}
.role-guide-tooltip {
    position: fixed;
    z-index: 100;
    border: 1px solid rgba(246,166,9,.36);
    border-radius: 18px;
    background: rgba(255,255,255,.97);
    box-shadow: 0 24px 70px rgba(0,6,46,.28);
    padding: 14px;
    color: var(--navy);
}
.role-guide-panel {
    top: 86px;
    right: 18px;
    bottom: 18px;
    left: auto;
    width: min(402px, calc(100vw - 36px));
    max-height: calc(100svh - 104px);
    overflow-y: auto;
    overscroll-behavior: contain;
    background:
        radial-gradient(circle at 100% 0%, rgba(211,6,36,.10), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(255,251,241,.96));
}
.role-guide-panel::-webkit-scrollbar {
    width: 8px;
}
.role-guide-panel::-webkit-scrollbar-thumb {
    background: rgba(2,11,69,.18);
    border-radius: 999px;
}
.role-guide-tooltip small {
    color: var(--red);
    display: block;
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.role-guide-tooltip h3 {
    margin: 7px 28px 6px 0;
    font-size: 18px;
    line-height: 1.16;
    color: var(--navy);
}
.role-guide-tooltip p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
    font-weight: 750;
}
.role-guide-mission,
.role-guide-meta {
    display: grid;
    gap: 7px;
    margin-top: 11px;
}
.role-guide-current-route {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 11px;
    border: 1px solid rgba(213,182,91,.38);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,248,229,.96), rgba(255,255,255,.94));
    padding: 9px 10px;
}
.role-guide-current-route b {
    min-width: 0;
    color: var(--navy);
    font-size: 12px;
    font-weight: 950;
    line-height: 1.2;
}
.role-guide-current-route span {
    flex: 0 0 auto;
    border-radius: 999px;
    background: rgba(2,11,69,.07);
    color: var(--muted);
    padding: 5px 7px;
    font-size: 10px;
    font-weight: 950;
}
.role-guide-resume-pill {
    display: inline-flex;
    width: fit-content;
    margin-top: 8px;
    padding: 5px 8px;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(246,166,9,.18), rgba(255,255,255,.96));
    color: #8A5A00;
    font-size: 11px;
    font-weight: 950;
}
.role-guide-mission {
    border: 1px solid rgba(213,182,91,.34);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,248,229,.92), rgba(255,255,255,.92));
    padding: 9px;
}
.role-guide-mission div,
.role-guide-meta-row {
    display: grid;
    gap: 3px;
    border-radius: 11px;
    background: rgba(255,255,255,.78);
    padding: 8px;
}
.role-guide-meta-row {
    border: 1px solid rgba(221,228,240,.90);
    background: rgba(246,249,252,.84);
}
.role-guide-mission div.warning,
.role-guide-meta-row.warning {
    background: rgba(211,6,36,.06);
    border-color: rgba(211,6,36,.16);
}
.role-guide-meta-row.example {
    background: rgba(213,182,91,.12);
    border-color: rgba(213,182,91,.30);
}
.role-guide-mission b,
.role-guide-meta-row b {
    color: var(--red);
    font-size: 10px;
    font-weight: 950;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.role-guide-mission div.warning b,
.role-guide-meta-row.warning b {
    color: #A80522;
}
.role-guide-other-help {
    margin-top: 10px;
    border: 1px solid rgba(221,228,240,.90);
    border-radius: 13px;
    background: rgba(255,255,255,.70);
    padding: 8px 10px;
}
.role-guide-other-help summary {
    cursor: pointer;
    color: var(--navy);
    font-size: 12px;
    font-weight: 950;
}
.role-guide-other-help p {
    margin-top: 8px;
    font-size: 12px;
}
.role-guide-meta-row.example b {
    color: #8A5A00;
}
.role-guide-mission span,
.role-guide-meta-row span {
    color: var(--navy);
    font-size: 12px;
    line-height: 1.35;
    font-weight: 850;
}
.role-guide-home {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 12px;
}
.role-guide-home button,
.role-guide-home div,
.role-guide-scenario-card {
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 14px;
    background: rgba(255,255,255,.88);
    color: var(--navy);
    padding: 10px;
    text-align: left;
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.role-guide-home button {
    cursor: pointer;
}
.role-guide-home button:hover,
.role-guide-scenario-card:hover,
.role-guide-scenario-card.current {
    transform: translateY(-1px);
    border-color: rgba(246,166,9,.55);
    background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(255,248,229,.94));
    box-shadow: 0 12px 28px rgba(2,11,69,.08);
}
.role-guide-home b,
.role-guide-scenario-card b {
    display: block;
    color: var(--navy);
    font-size: 12px;
    font-weight: 950;
    line-height: 1.2;
}
.role-guide-home span,
.role-guide-scenario-card span {
    display: block;
    margin-top: 5px;
    color: var(--muted);
    font-size: 11px;
    line-height: 1.35;
    font-weight: 820;
}
.role-guide-scenarios {
    display: grid;
    gap: 7px;
    margin-top: 12px;
}
.role-guide-scenarios > strong {
    color: var(--red);
    font-size: 10px;
    font-weight: 950;
    letter-spacing: .05em;
    text-transform: uppercase;
}
.role-guide-scenario-card {
    width: 100%;
    cursor: pointer;
}
.role-guide-journey {
    margin-top: 12px;
    border: 1px solid rgba(213,182,91,.30);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(255,248,229,.88));
    padding: 9px;
}
.role-guide-journey-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}
.role-guide-journey-head b {
    color: var(--navy);
    font-size: 12px;
    font-weight: 950;
}
.role-guide-journey-head span {
    border-radius: 999px;
    background: rgba(2,11,69,.07);
    color: var(--navy);
    padding: 4px 7px;
    font-size: 10px;
    font-weight: 950;
}
.role-guide-journey-rail {
    display: grid;
    gap: 6px;
    max-height: 188px;
    overflow-y: auto;
}
.role-guide-journey-rail a {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    gap: 2px 8px;
    align-items: center;
    border: 1px solid rgba(221,228,240,.92);
    border-radius: 12px;
    background: rgba(255,255,255,.82);
    color: var(--navy);
    padding: 7px;
    text-decoration: none;
    transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.role-guide-journey-rail a:hover {
    transform: translateX(2px);
    border-color: rgba(211,6,36,.28);
    background: #fff;
}
.role-guide-journey-rail a span {
    grid-row: span 2;
    display: inline-grid;
    place-items: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: rgba(2,11,69,.08);
    color: var(--navy);
    font-size: 11px;
    font-weight: 950;
}
.role-guide-journey-rail a b {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 12px;
    font-weight: 950;
}
.role-guide-journey-rail a small {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: none;
}
.role-guide-journey-rail a.done span {
    background: rgba(24,167,123,.13);
    color: #08734F;
}
.role-guide-journey-rail a.current {
    border-color: rgba(211,6,36,.34);
    background: linear-gradient(135deg, rgba(211,6,36,.09), rgba(213,182,91,.16));
}
.role-guide-journey-rail a.current span {
    background: linear-gradient(135deg, var(--red), #A80522);
    color: #fff;
}
.role-guide-close {
    position: absolute;
    right: 10px;
    top: 8px;
    width: 28px;
    height: 28px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--navy);
    cursor: pointer;
    font-size: 20px;
    line-height: 1;
}
.role-guide-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 13px;
    flex-wrap: wrap;
}
.role-guide-actions .btn.small {
    min-height: 34px;
    padding: 7px 11px;
    font-size: 12px;
}
.role-guide-actions .btn[disabled] {
    opacity: .45;
    cursor: not-allowed;
}
.role-guide-hint {
    margin-top: 8px;
    border-radius: 10px;
    background: rgba(213,182,91,.14);
    color: var(--navy);
    padding: 8px 9px;
    font-size: 11px;
    font-weight: 850;
    line-height: 1.35;
}
.role-guide-prompt {
    position: fixed;
    right: 22px;
    top: 86px;
    z-index: 72;
    width: min(360px, calc(100vw - 32px));
    border: 1px solid rgba(213,182,91,.42);
    border-radius: 18px;
    background:
        radial-gradient(circle at 100% 0%, rgba(211,6,36,.12), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(255,248,229,.94));
    box-shadow: 0 22px 58px rgba(2,11,69,.18);
    padding: 15px;
    color: var(--navy);
    animation: promptFloatIn .26s ease both;
}
.role-guide-prompt small {
    display: inline-flex;
    width: fit-content;
    border-radius: 999px;
    background: rgba(213,182,91,.18);
    color: var(--navy);
    padding: 5px 8px;
    font-size: 10px;
    font-weight: 950;
    letter-spacing: .04em;
    text-transform: uppercase;
}
.role-guide-prompt h3 {
    margin: 10px 26px 6px 0;
    color: var(--navy);
    font-size: 18px;
    line-height: 1.12;
}
.role-guide-prompt p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
    font-weight: 760;
}
.role-guide-prompt-close {
    position: absolute;
    right: 10px;
    top: 9px;
    width: 28px;
    height: 28px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--navy);
    cursor: pointer;
    font-size: 20px;
    line-height: 1;
}
.role-guide-prompt-rail {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 11px;
}
.role-guide-prompt-rail span {
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 999px;
    background: #fff;
    color: var(--navy);
    padding: 6px 8px;
    font-size: 11px;
    font-weight: 900;
}
.role-guide-prompt-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 13px;
    flex-wrap: wrap;
}
@keyframes promptFloatIn {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.profile-menu { position: relative; }
.profile-trigger {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.82);
    color: var(--navy);
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 10px 6px 7px;
    cursor: pointer;
}
.profile-avatar {
    width: 32px;
    height: 32px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--navy), var(--red));
    color: #fff;
    font-size: 12px;
    font-weight: 900;
    overflow: hidden;
}
.profile-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.profile-avatar.large {
    width: 42px;
    height: 42px;
    font-size: 14px;
    flex: 0 0 auto;
}
.profile-copy { display: grid; gap: 1px; text-align: left; }
.profile-copy b {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
}
.profile-copy small {
    max-width: 150px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--muted);
    font-size: 11px;
    font-weight: 750;
}
.profile-dropdown {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: 260px;
    display: none;
    background: rgba(255,255,255,.92);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    backdrop-filter: blur(18px);
    z-index: 40;
    padding: 8px;
}
.profile-menu.open .profile-dropdown { display: block; }
.profile-dropdown-head {
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border-bottom: 1px solid var(--line);
    margin-bottom: 6px;
}
.profile-dropdown-head b,
.profile-dropdown-head small { display: block; }
.profile-dropdown-head b { color: var(--navy); }
.profile-dropdown-head small {
    color: var(--muted);
    font-size: 12px;
    max-width: 170px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.profile-dropdown a,
.profile-dropdown button {
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--navy);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 10px;
    font-weight: 800;
    cursor: pointer;
    text-align: left;
}
.profile-dropdown a:hover,
.profile-dropdown button:hover { background: var(--pale); }
.profile-self-modal .modal-panel {
    width: min(820px, calc(100vw - 28px));
}
.profile-self-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
}
.profile-self-grid > form {
    min-width: 0;
}
.profile-self-grid > form + form {
    border-left: 1px solid var(--line);
}
.profile-password-form {
    background: linear-gradient(135deg, rgba(2,11,69,.03), rgba(246,166,9,.05));
}
.profile-photo-form label {
    width: 100%;
    border: 0;
    background: transparent;
    color: var(--navy);
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 10px;
    font-weight: 800;
    cursor: pointer;
}
.profile-photo-form label:hover { background: var(--pale); }
.profile-photo-form input { display: none; }
.content { padding: 22px 24px; max-width: 1540px; margin: 0 auto; }
.training-hero {
    border: 1px solid rgba(221,228,240,.88);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 92% 8%, rgba(211,6,36,.10), transparent 24%),
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(255,248,232,.92));
    box-shadow: var(--shadow);
    padding: 22px;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    margin-bottom: 14px;
}
.training-hero h2 {
    margin: 6px 0 8px;
    color: var(--navy);
    font-size: clamp(25px, 3vw, 38px);
    max-width: 840px;
    line-height: 1.04;
}
.training-hero p {
    margin: 0;
    color: var(--muted);
    max-width: 760px;
    font-weight: 650;
}
.training-hero-actions {
    display: flex;
    gap: 9px;
    flex-wrap: wrap;
    justify-content: flex-end;
}
.training-current-role {
    border: 1px solid rgba(246,166,9,.32);
    border-radius: var(--radius);
    background:
        linear-gradient(135deg, rgba(2,11,69,.97), rgba(18,58,131,.88)),
        url("../image/sidebar-background.jpg") center / cover no-repeat;
    color: #fff;
    box-shadow: var(--shadow);
    padding: 18px;
    display: grid;
    grid-template-columns: 72px minmax(0, 1fr) minmax(260px, 340px);
    gap: 16px;
    align-items: center;
    margin-bottom: 14px;
    overflow: hidden;
    position: relative;
}
.training-current-role:after {
    content: "";
    position: absolute;
    inset: auto -20% 0 18%;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(246,166,9,.75), rgba(255,255,255,.45), transparent);
    transform: rotate(-18deg);
}
.training-current-role > * { position: relative; z-index: 1; }
.training-current-role .eyebrow { color: #FFD46A; background: rgba(255,255,255,.08); }
.training-current-role h3 {
    margin: 4px 0 5px;
    font-size: clamp(22px, 2.4vw, 32px);
    color: #fff;
}
.training-current-role p {
    margin: 0 0 10px;
    color: rgba(255,255,255,.76);
}
.training-role-icon {
    width: 64px;
    height: 64px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(246,166,9,.22), rgba(255,255,255,.96));
    border: 1px solid rgba(246,166,9,.42);
    box-shadow: 0 16px 34px rgba(0,0,0,.16);
    overflow: hidden;
}
.training-role-icon img {
    width: 50px;
    height: 50px;
    object-fit: contain;
}
.training-role-icon.small {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
}
.training-role-icon.small img {
    width: 34px;
    height: 34px;
}
.training-flow {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}
.training-flow span {
    border: 1px solid rgba(246,166,9,.30);
    border-radius: 999px;
    background: rgba(255,255,255,.10);
    color: inherit;
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 9px;
    font-size: 12px;
    font-weight: 900;
}
.training-flow.compact span {
    background: #F7F9FE;
    color: var(--navy);
    border-color: rgba(221,228,240,.96);
}
.training-action-card {
    border: 1px solid rgba(255,255,255,.22);
    border-radius: var(--radius);
    background: rgba(255,255,255,.10);
    backdrop-filter: blur(12px);
    padding: 13px;
    display: grid;
    gap: 10px;
}
.training-action-card small {
    color: #FFD46A;
    font-size: 11px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.training-action-card b {
    color: #fff;
    line-height: 1.25;
}
.training-rule-card {
    border: 1px solid rgba(246,166,9,.32);
    border-radius: var(--radius);
    background: linear-gradient(135deg, #FFF8E8, #fff);
    padding: 14px;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto;
    gap: 12px;
    align-items: center;
    margin-bottom: 14px;
}
.training-rule-card > .icon {
    width: 42px;
    height: 42px;
    padding: 10px;
    border-radius: 999px;
    color: var(--navy);
    background: rgba(246,166,9,.22);
}
.training-rule-card b,
.training-rule-card span {
    display: block;
}
.training-rule-card b { color: var(--navy); }
.training-rule-card span { color: var(--muted); font-weight: 700; }
.training-role-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 14px;
}
.training-role-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    box-shadow: 0 12px 28px rgba(2,11,69,.06);
    padding: 14px;
    display: grid;
    gap: 12px;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.training-role-card:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.42);
    box-shadow: 0 18px 42px rgba(2,11,69,.10);
}
.training-role-card.active {
    border-color: rgba(211,6,36,.24);
    background:
        radial-gradient(circle at 100% 0, rgba(246,166,9,.12), transparent 28%),
        rgba(255,255,255,.96);
}
.training-card-head {
    display: flex;
    gap: 10px;
    align-items: center;
}
.training-card-head small,
.training-card-head h4 {
    display: block;
    margin: 0;
}
.training-card-head small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 760;
}
.training-card-head h4 {
    color: var(--navy);
    font-size: 18px;
    line-height: 1.18;
}
.training-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}
.training-info-grid div {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
    min-height: 116px;
}
.training-info-grid b {
    display: block;
    color: var(--navy);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 5px;
}
.training-info-grid p {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
    font-weight: 700;
}
.training-card-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}
.training-uat-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.training-uat-strip div {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    padding: 12px;
    display: grid;
    gap: 5px;
}
.training-uat-strip span {
    width: 30px;
    height: 30px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--red), #A80522);
    color: #fff;
    font-weight: 950;
}
.training-uat-strip b {
    color: var(--navy);
}
.training-uat-strip small {
    color: var(--muted);
    font-weight: 700;
}
.training-evidence-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.training-evidence-strip div {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(255,248,232,.68));
    padding: 12px;
    display: grid;
    grid-template-columns: 34px 1fr;
    gap: 3px 10px;
    align-items: center;
}
.training-evidence-strip .icon {
    grid-row: span 2;
    width: 34px;
    height: 34px;
    padding: 8px;
    border-radius: 999px;
    color: var(--navy);
    background: rgba(246,166,9,.18);
}
.training-evidence-strip b {
    color: var(--navy);
}
.training-evidence-strip span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 720;
}
.hero-band.compact h2 { font-size: clamp(22px, 2.5vw, 30px); }
.notification-page-card { display: grid; gap: 9px; }
.notification-row {
    display: grid;
    grid-template-columns: 42px 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    color: var(--navy);
}
.notification-row.unread {
    border-color: rgba(211,6,36,.18);
    background:
        radial-gradient(circle at 3% 10%, rgba(246,166,9,.16), transparent 20%),
        #fff;
}
.notification-row-icon {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, rgba(2,11,69,.08), rgba(246,166,9,.16));
    color: var(--navy);
}
.notification-row.unread .notification-row-icon {
    background: linear-gradient(135deg, var(--red), #9A0018);
    color: #fff;
}
.notification-row-copy b,
.notification-row-copy small {
    display: block;
}
.notification-row-copy small {
    color: var(--muted);
    margin-top: 3px;
    line-height: 1.4;
}
.hero-band {
    position: relative;
    overflow: hidden;
    background: rgba(255,255,255,.94);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 14px 34px rgba(2,11,69,.07);
    backdrop-filter: blur(14px);
    padding: 20px;
    display: grid;
    grid-template-columns: minmax(320px, 1fr) auto;
    gap: 18px;
    align-items: center;
    margin-bottom: 18px;
}
.project-workspace-hero {
    grid-template-columns: 220px minmax(320px, 1fr);
}
.project-workspace-hero .quick-actions {
    max-width: 300px;
}
.project-workspace-hero .quick-actions .btn {
    flex: 1 1 100%;
    justify-content: center;
}
.workspace-hero-thumb {
    position: relative;
    overflow: hidden;
    border-radius: var(--radius);
    border: 1px solid var(--line);
    min-height: 124px;
    background: var(--navy);
}
.workspace-hero-thumb img {
    width: 100%;
    height: 124px;
    object-fit: cover;
    display: block;
}
.thumb-upload-chip {
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: 10px;
    min-height: 34px;
    border: 1px solid rgba(255,255,255,.38);
    border-radius: 999px;
    background: rgba(255,255,255,.92);
    color: var(--navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    font-size: 12px;
    font-weight: 900;
    cursor: pointer;
    box-shadow: 0 12px 26px rgba(2,11,69,.18);
    backdrop-filter: blur(12px);
}
.hero-band:before {
    display: none;
}
.hero-band > * { position: relative; z-index: 1; }
.hero-band h2 { margin: 0; font-size: clamp(22px, 3vw, 34px); letter-spacing: 0; color: var(--navy); }
.hero-band p { margin: 6px 0 0; color: var(--muted); max-width: 760px; }
.quick-actions { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.quick-actions .btn { white-space: nowrap; }
.role-action-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: -4px;
}
.role-action-card {
    min-height: 92px;
    border: 1px solid rgba(220,230,239,.96);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 12% 0, rgba(246,166,9,.16), transparent 34%),
        rgba(255,255,255,.94);
    box-shadow: 0 10px 26px rgba(2,11,69,.06);
    padding: 12px;
    display: grid;
    align-content: center;
    gap: 5px;
}
.role-action-card span {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    color: var(--red);
    background: #FFF7E3;
    border: 1px solid rgba(246,166,9,.26);
}
.role-action-card b { color: var(--navy); line-height: 1.15; }
.role-action-card small { color: var(--muted); font-weight: 750; }
.grid { display: grid; gap: 14px; }
.grid.kpi { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid.two { grid-template-columns: 1.25fr .75fr; }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.module-summary-panel {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.module-summary-panel a {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: 0 10px 26px rgba(2,11,69,.05);
    padding: 12px;
    display: grid;
    gap: 4px;
}
.module-summary-panel b { color: var(--navy); font-size: 24px; line-height: 1; }
.module-summary-panel span { color: var(--muted); font-size: 12px; font-weight: 850; }
.card {
    background: var(--card);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: 0 10px 26px rgba(2,11,69,.06);
}
.card-pad { padding: 16px; }
.card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.card-head h3 { margin: 0; font-size: 16px; color: var(--navy); letter-spacing: 0; }
.kpi-card { padding: 16px; display: grid; gap: 12px; min-height: 124px; }
.kpi-top { display: flex; justify-content: space-between; align-items: center; }
.kpi-icon { width: 38px; height: 38px; display: grid; place-items: center; border-radius: var(--radius); color: var(--red); background: #FFF0F3; }
.kpi-card b { display: block; font-size: 30px; letter-spacing: 0; color: var(--navy); }
.kpi-card span { color: var(--muted); font-size: 13px; font-weight: 750; }
.tone-orange .kpi-icon, .tone-amber .kpi-icon { color: #9A5B00; background: #FFF7E3; }
.tone-blue .kpi-icon { color: var(--blue); background: #EEF2FF; }
.tone-green .kpi-icon { color: var(--green); background: #EAFBF5; }
.tone-red .kpi-icon { color: var(--red); background: #FFF2F1; }
.table-wrap { position: relative; overflow: auto; border-radius: var(--radius); border: 1px solid var(--line); background: #fff; }
.table-wrap:after {
    content: "Scroll table";
    display: none;
    position: sticky;
    right: 8px;
    bottom: 8px;
    float: right;
    border-radius: 999px;
    background: rgba(2,11,69,.86);
    color: #fff;
    padding: 4px 8px;
    font-size: 11px;
    font-weight: 850;
}
table { border-collapse: collapse; width: 100%; background: #fff; min-width: 820px; }
th, td { padding: 11px 12px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; font-size: 13px; }
th { background: #F8FBFF; color: #344054; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
tr:last-child td { border-bottom: 0; }
.status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    border-radius: 999px;
    padding: 5px 9px;
    font-size: 12px;
    font-weight: 850;
    background: #EEF8FF;
    color: var(--blue);
    white-space: nowrap;
}
.status.approved, .status.closed, .status.completed { background: #EAFBF5; color: var(--green); }
.status.review, .status.submitted, .status.progress { background: #FFF4E8; color: #A65304; }
.status.returned, .status.overdue, .status.rejected, .status.critical { background: #FFF2F1; color: var(--red); }
.priority { font-weight: 850; color: var(--navy); }
.priority.Critical, .priority.High { color: var(--red); }
.filter-bar {
    position: sticky;
    top: 68px;
    z-index: 12;
    display: grid;
    grid-template-columns: minmax(220px, 1.35fr) repeat(auto-fit, minmax(126px, 1fr));
    gap: 8px;
    padding: 10px;
    margin-bottom: 14px;
    background: rgba(255,255,255,.78);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    backdrop-filter: blur(16px);
}
.filter-check {
    min-height: 40px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    color: var(--navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 10px;
    font-size: 13px;
    font-weight: 850;
    white-space: nowrap;
}
.filter-check input { accent-color: var(--red); }
.task-command-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(340px, .85fr);
    gap: 14px;
    align-items: stretch;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.88);
    box-shadow: 0 10px 26px rgba(2,11,69,.06);
    backdrop-filter: blur(12px);
    padding: 16px;
    margin-bottom: 14px;
}
.task-action-hub {
    position: relative;
    overflow: hidden;
}
.task-action-hub:after {
    content: "";
    position: absolute;
    right: -90px;
    bottom: -120px;
    width: 300px;
    height: 300px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(246,166,9,.16), transparent 62%);
    pointer-events: none;
}
.task-hub-focus,
.task-hub-side {
    position: relative;
    z-index: 1;
}
.task-hub-focus {
    display: grid;
    align-content: center;
    min-height: 154px;
}
.eyebrow {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    background: #FFF0F3;
    color: var(--red);
    padding: 5px 9px;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.task-command-panel h2 {
    margin: 10px 0 6px;
    color: var(--navy);
    font-size: clamp(21px, 2.6vw, 30px);
    line-height: 1.05;
}
.task-command-panel p { margin: 0; color: var(--muted); max-width: 720px; }
.task-hub-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
    margin-top: 10px;
}
.task-hub-meta span {
    border-radius: 999px;
    background: #F4F7FB;
    border: 1px solid var(--line);
    color: var(--muted);
    padding: 5px 8px;
    font-size: 11px;
    font-weight: 850;
}
.task-hub-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}
.task-hub-side {
    display: grid;
    gap: 8px;
}
.task-role-chip {
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 10px;
    align-items: center;
    border: 1px solid rgba(246,166,9,.34);
    border-radius: var(--radius);
    background: linear-gradient(135deg, #fff, #FFF8E7);
    padding: 10px;
}
.task-role-chip .icon {
    width: 42px;
    height: 42px;
    border-radius: 15px;
    padding: 10px;
    color: #8A5200;
    background: #FFE7A8;
}
.task-role-chip b,
.task-role-chip span {
    display: block;
}
.task-role-chip b {
    color: var(--navy);
    font-size: 13px;
}
.task-role-chip span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 760;
    margin-top: 2px;
}
.task-flow-mini {
    border: 1px solid rgba(221,228,240,.96);
    border-radius: var(--radius);
    background:
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,249,254,.92));
    padding: 10px;
}
.task-flow-head {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--red);
    font-size: 11px;
    font-weight: 950;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.task-flow-head .icon {
    width: 16px;
    height: 16px;
}
.task-reflection-chip,
.task-modal-reflection,
.workspace-reflection-chip {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    border: 1px solid rgba(213,182,91,.34);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,248,229,.82), rgba(255,255,255,.92));
    color: var(--navy);
    padding: 9px 10px;
    font-size: 12px;
    font-weight: 850;
    line-height: 1.35;
}
.task-reflection-chip .icon,
.task-modal-reflection .icon,
.workspace-reflection-chip .icon {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    color: #8A5A00;
}
.task-modal-reflection {
    margin-top: 10px;
}
.task-flow-steps {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: stretch;
    gap: 6px;
}
.task-flow-step {
    min-width: 0;
    display: grid;
    place-items: center;
    text-align: center;
    border: 1px solid rgba(213,182,91,.28);
    border-radius: 13px;
    background: linear-gradient(135deg, rgba(255,248,229,.86), rgba(255,255,255,.94));
    color: var(--navy);
    padding: 8px 7px;
    font-size: 11px;
    font-weight: 900;
    line-height: 1.22;
}
.task-flow-arrow {
    align-self: center;
    color: rgba(2,11,69,.34);
    width: 16px;
    height: 16px;
}
.task-command-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}
.task-command-tile {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    min-height: 82px;
    display: grid;
    align-content: center;
    gap: 5px;
    padding: 10px;
    color: var(--navy);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.task-command-tile:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.40);
    box-shadow: 0 14px 30px rgba(2,11,69,.08);
}
.task-command-tile .icon { color: var(--red); }
.task-command-tile b { font-size: 22px; line-height: 1; }
.task-command-tile span { color: var(--muted); font-size: 12px; font-weight: 850; }
.task-command-tile.danger { border-color: #F0B4BE; background: #FFF5F7; }
.task-strip {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: start;
    margin-bottom: 10px;
}
.task-strip .tabs { margin-bottom: 0; }
.task-filter-button { min-height: 40px; }
.task-filter-bar { margin-bottom: 12px; }
.tabs { display: flex; gap: 8px; overflow-x: auto; margin-bottom: 14px; padding-bottom: 2px; }
.tab { flex: 0 0 auto; border: 1px solid var(--line); border-radius: 999px; padding: 8px 12px; background: #fff; color: #344054; font-weight: 850; font-size: 13px; }
.tab.active { background: var(--navy); color: #fff; border-color: var(--navy); }
.task-list { display: grid; gap: 10px; }
.task-card { display: grid; grid-template-columns: 1fr auto; gap: 10px; padding: 14px; }
.task-card.action-card {
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.task-card.action-card:hover {
    transform: translateY(-1px);
    border-color: rgba(246,166,9,.36);
    box-shadow: 0 16px 34px rgba(2,11,69,.08);
}
.task-card-actions {
    display: grid;
    gap: 8px;
    align-content: start;
    justify-items: end;
    min-width: 164px;
}
.task-update-form {
    display: grid;
    grid-template-columns: 160px minmax(150px, 1fr) 42px;
    gap: 6px;
    align-items: center;
}
.inline-panel {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius);
}
.task-card h4 { margin: 0; color: var(--navy); }
.task-meta { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; color: var(--muted); font-size: 12px; }
.drawer-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 14px; }
.progress-line { height: 8px; background: #E9F1F8; border-radius: 999px; overflow: hidden; }
.progress-line span { display: block; height: 100%; background: linear-gradient(90deg, var(--blue), var(--red)); border-radius: inherit; }
.kanban { display: grid; grid-template-columns: repeat(4, minmax(230px, 1fr)); gap: 12px; overflow-x: auto; padding-bottom: 6px; }
.kanban-col { background: #F8FBFF; border: 1px solid var(--line); border-radius: var(--radius); padding: 10px; min-height: 180px; }
.kanban-col h4 { margin: 0 0 10px; color: var(--navy); }
.mini-item { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 10px; margin-bottom: 8px; }
.sidebar .mini-item {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.12);
    color: #fff;
}
.sidebar .mini-item .muted { color: rgba(255,255,255,.62); }
.role-context-badge {
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 11px;
    align-items: center;
    margin: 8px 6px 0;
    border: 1px solid rgba(246,166,9,.38);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 14% 12%, rgba(255,255,255,.30), transparent 26%),
        linear-gradient(135deg, #B87300, #F6A609 42%, #8A0015);
    box-shadow: 0 14px 32px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.26);
    color: #fff;
    padding: 12px;
    text-shadow: 0 1px 2px rgba(0,0,0,.22);
}
.role-context-badge b,
.role-context-badge small { display: block; }
.role-context-badge b { font-size: 13px; line-height: 1.2; }
.role-context-badge small { color: rgba(255,255,255,.76); font-size: 12px; margin-top: 4px; }
.role-icon-shell {
    width: 42px;
    height: 42px;
    margin-top: 0;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 35% 30%, #FFF4C2 0 18%, transparent 19%),
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(246,166,9,.28));
    border: 1px solid rgba(246,166,9,.45);
    box-shadow: 0 0 0 4px rgba(246,166,9,.16), 0 12px 20px rgba(211,6,36,.18);
    position: relative;
    overflow: hidden;
}
.role-icon-shell img {
    width: 32px;
    height: 32px;
    object-fit: contain;
    display: block;
    position: relative;
    z-index: 1;
}
.role-icon-shell:after {
    content: "";
    position: absolute;
    inset: 3px;
    border-radius: inherit;
    border: 1px solid rgba(255,255,255,.82);
}
.lifecycle-rail {
    display: grid;
    grid-template-columns: repeat(6, minmax(140px, 1fr));
    gap: 10px;
    overflow-x: auto;
    padding: 8px;
    margin-bottom: 14px;
    position: sticky;
    top: 128px;
    z-index: 15;
    border: 1px solid rgba(221,228,240,.82);
    border-radius: var(--radius);
    background:
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,249,254,.88));
    box-shadow: 0 14px 32px rgba(2,11,69,.07);
    backdrop-filter: blur(14px);
}
.workspace-sop-board .lifecycle-rail {
    position: relative;
    top: auto;
    z-index: 1;
    margin-bottom: 0;
}
.workspace-command-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 420px);
    gap: 12px;
    align-items: start;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.9);
    box-shadow: 0 10px 26px rgba(2,11,69,.06);
    backdrop-filter: blur(12px);
    padding: 14px;
    margin-bottom: 14px;
}
.next-action-label {
    display: inline-flex;
    width: fit-content;
    margin-top: 3px;
    padding: 5px 9px;
    border-radius: 999px;
    background: rgba(18,58,131,.08);
    color: var(--navy);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.workspace-next-action h3 { margin: 9px 0 5px; color: var(--navy); font-size: 20px; }
.workspace-next-action p { margin: 0; color: var(--muted); }
.workspace-role-focus {
    display: grid;
    grid-template-columns: 38px 1fr;
    gap: 10px;
    align-items: center;
    width: fit-content;
    max-width: 100%;
    margin: 8px 0 12px;
    border: 1px solid rgba(246,166,9,.34);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 14% 16%, rgba(255,255,255,.55), transparent 30%),
        linear-gradient(135deg, rgba(246,166,9,.18), rgba(255,255,255,.96) 48%, rgba(211,6,36,.06));
    padding: 9px 11px;
    box-shadow: 0 12px 28px rgba(2,11,69,.06);
}
.workspace-role-focus .icon {
    width: 38px;
    height: 38px;
    padding: 9px;
    border-radius: 999px;
    color: var(--navy);
    background: linear-gradient(135deg, #F6A609, #FFE7A1);
    border: 1px solid rgba(246,166,9,.40);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.52);
}
.workspace-role-focus b,
.workspace-role-focus span {
    display: block;
}
.workspace-role-focus b {
    color: var(--navy);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.workspace-role-focus span {
    color: #344054;
    font-size: 12px;
    font-weight: 750;
}
.workspace-reflection-chip {
    width: fit-content;
    max-width: 620px;
    margin: -4px 0 10px;
    background: linear-gradient(135deg, rgba(255,248,229,.88), rgba(255,255,255,.96));
}
.workspace-next-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    margin-top: 10px;
    max-width: 420px;
}
.workspace-next-card {
    border: 1px solid rgba(221,228,240,.94);
    border-radius: 14px;
    background:
        radial-gradient(circle at 8% 0%, rgba(246,166,9,.18), transparent 34%),
        #fff;
    padding: 10px 12px;
    box-shadow: 0 12px 26px rgba(2,11,69,.05);
}
.workspace-next-card small,
.workspace-next-card b,
.workspace-next-card span {
    display: block;
}
.workspace-next-card small {
    width: fit-content;
    border-radius: 999px;
    background: rgba(18,58,131,.08);
    color: var(--navy);
    padding: 4px 8px;
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
}
.workspace-next-card b {
    margin-top: 8px;
    color: var(--navy);
    font-size: 18px;
    line-height: 1.12;
}
.workspace-next-card span {
    margin-top: 4px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}
.workspace-next-card.is-clear {
    background:
        radial-gradient(circle at 8% 0%, rgba(24,167,123,.14), transparent 34%),
        #fff;
}
.workspace-next-actions .btn {
    min-height: 48px;
    justify-content: center;
    width: 100%;
}
.workspace-command-side {
    display: grid;
    gap: 10px;
    align-self: center;
    justify-content: stretch;
}
.workspace-command-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}
.workspace-command-metrics a {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 12% 14%, rgba(246,166,9,.12), transparent 32%),
        #fff;
    padding: 11px;
    display: grid;
    grid-template-columns: 34px 1fr;
    align-items: center;
    gap: 4px;
    min-height: 72px;
    box-shadow: 0 10px 24px rgba(2,11,69,.05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.workspace-command-metrics a:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.46);
    box-shadow: 0 16px 32px rgba(2,11,69,.09);
    background:
        radial-gradient(circle at 12% 14%, rgba(246,166,9,.22), transparent 34%),
        linear-gradient(135deg, #fff, rgba(247,249,254,.96));
}
.workspace-command-metrics .icon {
    width: 34px;
    height: 34px;
    padding: 8px;
    border-radius: 12px;
    color: var(--red);
    background: rgba(211,6,36,.08);
}
.workspace-command-metrics span {
    display: grid;
    gap: 2px;
    min-width: 0;
}
.workspace-command-metrics b { color: var(--navy); font-size: 24px; line-height: 1; }
.workspace-command-metrics small { color: var(--muted); font-size: 11px; font-weight: 900; line-height: 1.1; }
.phase-modal-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}
.phase-modal-flow span {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: 14px;
    background:
        radial-gradient(circle at 10% 10%, rgba(246,166,9,.12), transparent 34%),
        #fff;
    min-height: 76px;
    padding: 10px;
    display: grid;
    align-content: center;
    gap: 3px;
    box-shadow: 0 10px 24px rgba(2,11,69,.05);
}
.phase-modal-flow .icon {
    width: 28px;
    height: 28px;
    padding: 6px;
    border-radius: 10px;
    color: var(--red);
    background: rgba(211,6,36,.08);
}
.phase-modal-flow b {
    color: var(--navy);
    font-size: 20px;
    line-height: 1;
}
.phase-modal-flow small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
}
.phase-claim-path {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 12px;
    padding: 8px;
    border: 1px solid rgba(221,228,240,.90);
    border-radius: 16px;
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.15), transparent 28%),
        rgba(247,249,254,.82);
}
.phase-claim-path span {
    display: grid;
    gap: 4px;
    min-height: 82px;
    padding: 10px;
    border: 1px solid rgba(221,228,240,.90);
    border-radius: 14px;
    background: #fff;
}
.phase-claim-path .icon {
    width: 30px;
    height: 30px;
    padding: 7px;
    border-radius: 10px;
    color: var(--red);
    background: rgba(211,6,36,.08);
}
.phase-claim-path b {
    color: var(--navy);
    font-size: 12px;
}
.phase-claim-path small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.2;
}
.phase-modal-focus {
    border: 1px solid rgba(211,6,36,.16);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 4% 0%, rgba(211,6,36,.08), transparent 38%),
        rgba(255,255,255,.96);
    padding: 10px;
    box-shadow: 0 12px 28px rgba(2,11,69,.06);
}
.phase-modal-section-title,
.phase-modal-group > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.phase-modal-section-title {
    margin-bottom: 9px;
}
.phase-modal-section-title span,
.phase-modal-group > summary span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--navy);
    font-weight: 950;
}
.phase-modal-section-title .icon,
.phase-modal-group > summary .icon {
    width: 30px;
    height: 30px;
    padding: 7px;
    border-radius: 10px;
    color: var(--red);
    background: rgba(211,6,36,.08);
}
.phase-modal-section-title small,
.phase-modal-group > summary small {
    flex: 0 0 auto;
    border-radius: 999px;
    background: rgba(18,58,131,.08);
    color: var(--muted);
    padding: 5px 9px;
    font-size: 11px;
    font-weight: 950;
}
.phase-modal-group {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.phase-modal-group:hover {
    transform: translateY(-1px);
    border-color: rgba(246,166,9,.44);
    box-shadow: 0 16px 32px rgba(2,11,69,.08);
}
.phase-modal-group > summary {
    list-style: none;
    min-height: 54px;
    padding: 10px 12px;
    cursor: pointer;
    transition: background .18s ease, color .18s ease;
}
.phase-modal-group > summary::-webkit-details-marker {
    display: none;
}
.phase-modal-group > summary:after {
    content: "Open";
    border-radius: 999px;
    background: rgba(246,166,9,.14);
    color: var(--navy);
    padding: 5px 9px;
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
}
.phase-modal-group[open] > summary {
    border-bottom: 1px solid var(--line);
    background: linear-gradient(135deg, rgba(246,166,9,.10), rgba(255,255,255,.98));
}
.phase-modal-group[open] > summary:after {
    content: "Close";
}
.phase-modal-group > .phase-task-list {
    padding: 10px;
}
.phase-empty-state {
    border: 1px dashed rgba(18,58,131,.16);
    border-radius: 14px;
    background: rgba(248,251,255,.8);
    color: var(--muted);
    padding: 12px;
    font-size: 13px;
    font-weight: 800;
}
.grid.kpi.workspace-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.workspace-kpi-grid .kpi-card {
    align-content: start;
    min-height: 98px;
    padding: 12px;
    gap: 7px;
}
.workspace-kpi-grid .kpi-card b {
    font-size: 24px;
    line-height: 1.05;
}
.workspace-kpi-grid .kpi-card span {
    font-size: 12px;
    line-height: 1.25;
}
.workspace-kpi-grid .kpi-icon {
    width: 32px;
    height: 32px;
}
.project-action-strip {
    position: sticky;
    top: 70px;
    z-index: 16;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(118px, 1fr);
    gap: 8px;
    overflow-x: auto;
    margin: -2px 0 14px;
    padding: 8px;
    border: 1px solid rgba(221,228,240,.90);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.08);
    backdrop-filter: blur(14px);
}
.project-action-strip a,
.project-action-strip button {
    min-height: 42px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    color: var(--navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 10px;
    font-weight: 950;
    font-size: 12px;
    cursor: pointer;
    transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease, color .16s ease;
}
.project-action-strip a:hover,
.project-action-strip button:hover {
    transform: translateY(-1px);
    border-color: rgba(246,166,9,.48);
    background: linear-gradient(135deg, #fff, rgba(255,248,229,.94));
    box-shadow: 0 12px 26px rgba(2,11,69,.09);
}
.project-action-strip .project-action-primary-mobile {
    display: none;
}
.project-action-strip .project-action-primary-mobile {
    border-color: rgba(211,6,36,.22);
    background: linear-gradient(135deg, var(--red), #A80522);
    color: #fff;
}
.workspace-sop-board,
.advanced-exception-panel {
    border: 1px solid rgba(221,228,240,.90);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.07);
    padding: 14px;
    margin-bottom: 14px;
}
.advanced-exception-panel {
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,249,254,.90));
}
.advanced-exception-panel > summary {
    list-style: none;
    cursor: pointer;
    color: var(--navy);
    font-weight: 950;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    border-radius: 12px;
    padding: 8px 10px;
    transition: background .18s ease, color .18s ease, transform .18s ease;
}
.advanced-exception-panel > summary:after {
    content: "Open";
    margin-left: 6px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(18,58,131,.08);
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
}
.advanced-exception-panel[open] > summary:after { content: "Close"; }
.advanced-exception-panel > summary:hover {
    transform: translateY(-1px);
    background: rgba(246,166,9,.12);
    color: var(--red);
}
.advanced-exception-panel > summary::-webkit-details-marker { display: none; }
.module-advanced-panel {
    margin-bottom: 14px;
}
.module-advanced-panel .muted {
    margin: 6px 0 0;
}
.module-quickstart-panel {
    margin-top: 12px;
    padding: 12px;
    border: 1px solid rgba(221,228,240,.90);
    border-radius: 12px;
    background: rgba(255,255,255,.78);
}
.module-advanced-panel .open-modal-btn {
    margin-top: 12px;
}
.project-next-action {
    border: 1px solid rgba(18,58,131,.12);
    border-radius: 12px;
    background: rgba(248,250,255,.86);
    padding: 9px;
    display: grid;
    gap: 3px;
}
.project-next-action span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
}
.project-next-action b {
    color: var(--navy);
    font-size: 12px;
    line-height: 1.25;
}
.project-open-workspace {
    width: 100%;
    justify-content: center;
}
.workspace-support-details {
    border: 1px solid rgba(221,228,240,.90);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.07);
    padding: 12px;
    margin-bottom: 14px;
}
.workspace-support-details > summary {
    list-style: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--navy);
    font-weight: 950;
    border-radius: 12px;
    padding: 8px 10px;
    transition: background .18s ease, color .18s ease, transform .18s ease;
}
.workspace-support-details > summary:after {
    content: "Open";
    margin-left: 6px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(18,58,131,.08);
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
}
.workspace-support-details[open] > summary:after { content: "Close"; }
.workspace-support-details > summary:hover {
    transform: translateY(-1px);
    background: rgba(246,166,9,.12);
    color: var(--red);
}
.workspace-support-details > summary::-webkit-details-marker { display: none; }
.advanced-exception-panel,
.workspace-support-details {
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease, background .18s ease;
}
.advanced-exception-panel:hover,
.workspace-support-details:hover {
    border-color: rgba(246,166,9,.42);
    box-shadow: 0 18px 38px rgba(2,11,69,.10);
}
.module-detail-list {
    margin-top: 14px;
    margin-bottom: 0;
    box-shadow: none;
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,249,254,.92));
}
.module-detail-list > summary {
    width: fit-content;
}
.module-detail-list .table-wrap {
    margin-top: 12px;
}
.module-detail-list .pagination {
    margin-top: 12px;
}
.module-empty-state .quick-actions {
    justify-content: center;
    margin-top: 10px;
}
.module-empty-state .btn {
    min-height: 38px;
}
.lifecycle-step {
    min-width: 148px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    display: grid;
    gap: 9px;
    color: var(--navy);
    text-align: left;
    font: inherit;
    cursor: pointer;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.lifecycle-step:hover {
    transform: translateY(-3px);
    border-color: rgba(246,166,9,.55);
    background:
        radial-gradient(circle at 12% 10%, rgba(246,166,9,.16), transparent 34%),
        #fff;
    box-shadow: 0 18px 34px rgba(2,11,69,.10);
}
.lifecycle-step b { color: var(--navy); }
.lifecycle-step small { color: var(--muted); font-weight: 800; }
.phase-owner,
.phase-risk {
    width: fit-content;
    border-radius: 999px;
    padding: 5px 8px;
    font-size: 11px;
    font-weight: 900;
}
.phase-owner {
    background: rgba(18,58,131,.07);
    color: var(--navy);
}
.phase-risk.ok {
    background: rgba(24,167,123,.10);
    color: var(--green);
}
.phase-risk.danger {
    background: #FFF0F3;
    color: var(--red);
}
.phase-task-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.phase-task-row:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.44);
    box-shadow: 0 16px 30px rgba(2,11,69,.08);
}
.phase-task-row b,
.phase-task-row small {
    display: block;
}
.phase-task-row b { color: var(--navy); }
.phase-task-row small {
    color: var(--muted);
    margin-top: 3px;
    line-height: 1.35;
}
.phase-task-actions {
    display: grid;
    justify-items: end;
    gap: 8px;
}
.phase-task-list-large {
    gap: 10px;
}
.workspace-section-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.workspace-section { scroll-margin-top: 86px; }
.workspace-section .task-list,
#overview .task-list,
#documents .task-list {
    max-height: 330px;
    overflow: auto;
    padding-right: 2px;
}
.project-media-panel {
    margin-bottom: 14px;
    scroll-margin-top: 88px;
}
.project-media-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
    max-height: 382px;
    overflow: auto;
    padding-right: 2px;
}
.project-media-card {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    box-shadow: 0 10px 22px rgba(2,11,69,.06);
}
.project-media-thumb {
    position: relative;
    width: 100%;
    border: 0;
    padding: 0;
    background: var(--navy);
    cursor: pointer;
}
.project-media-thumb img {
    width: 100%;
    height: 132px;
    object-fit: cover;
    display: block;
}
.project-media-thumb span {
    position: absolute;
    left: 8px;
    top: 8px;
    border-radius: 999px;
    background: linear-gradient(135deg, #F6A609, #B06B00);
    color: #fff;
    padding: 4px 8px;
    font-size: 11px;
    font-weight: 950;
    box-shadow: 0 8px 18px rgba(0,0,0,.18);
}
.project-media-copy {
    padding: 10px;
    display: grid;
    gap: 3px;
}
.project-media-copy b {
    color: var(--navy);
    font-size: 13px;
    line-height: 1.25;
}
.project-media-copy small {
    color: var(--muted);
    font-weight: 750;
}
.media-delete-btn {
    position: absolute;
    right: 8px;
    top: 8px;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.52);
    background: rgba(255,255,255,.94);
    color: var(--red);
    display: grid;
    place-items: center;
    cursor: pointer;
    box-shadow: 0 10px 22px rgba(2,11,69,.15);
}
.media-preview-modal {
    width: min(980px, 100%);
}
.media-preview-image {
    width: 100%;
    max-height: 70vh;
    object-fit: contain;
    border-radius: var(--radius);
    background: var(--navy);
}
.workspace-task-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: start;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 10px;
    background: #fff;
}
.workspace-task-row b { color: var(--navy); }
.workspace-performance-panel {
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    box-shadow: 0 16px 36px rgba(2,11,69,.08);
    padding: 14px;
    margin-bottom: 14px;
}
.workspace-performance-panel .card-head {
    margin-bottom: 12px;
}
.workspace-performance-grid {
    display: grid;
    grid-template-columns: minmax(380px, 1fr) minmax(340px, .9fr);
    gap: 12px;
    margin-top: 12px;
}
.workspace-performance-signals {
    margin-top: 10px;
}
.workspace-compact-details {
    margin-top: 12px;
    border: 1px solid rgba(18,58,131,.13);
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,251,255,.92));
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.workspace-compact-details:hover {
    border-color: rgba(246,166,9,.42);
    box-shadow: 0 16px 34px rgba(2,11,69,.08);
}
.workspace-compact-details > summary {
    min-height: 54px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    list-style: none;
    cursor: pointer;
    color: var(--navy);
    font-weight: 950;
    transition: background .18s ease, color .18s ease;
}
.workspace-compact-details > summary:after {
    content: "Open";
    flex: 0 0 auto;
    padding: 5px 9px;
    border-radius: 999px;
    background: rgba(18,58,131,.08);
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.workspace-compact-details[open] > summary:after { content: "Close"; }
.workspace-compact-details > summary:hover {
    background: linear-gradient(135deg, rgba(246,166,9,.12), rgba(255,255,255,.96));
    color: var(--red);
}
.workspace-compact-details > summary::-webkit-details-marker {
    display: none;
}
.workspace-compact-details > summary span,
.workspace-compact-details > summary small {
    display: flex;
    align-items: center;
    gap: 8px;
}
.workspace-compact-details > summary small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}
.workspace-compact-details > summary .icon {
    color: var(--red);
}
.workspace-compact-details[open] > summary {
    border-bottom: 1px solid var(--line);
    background: linear-gradient(135deg, rgba(246,166,9,.10), rgba(255,255,255,.96));
}
.workspace-compact-details > .workspace-performance-grid,
.workspace-compact-details > .performance-update-disclosure,
.workspace-compact-details > .performance-history-grid {
    margin-left: 12px;
    margin-right: 12px;
}
.workspace-compact-details > .performance-history-grid {
    margin-bottom: 12px;
}
.cpm-timeline.compact {
    max-height: 258px;
    overflow: auto;
    padding-right: 2px;
}
.empty-analytics-state.compact {
    min-height: 206px;
}
.performance-update-disclosure {
    margin-top: 12px;
    border: 1px solid rgba(246,166,9,.32);
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(246,166,9,.10), rgba(255,255,255,.96));
    overflow: hidden;
}
.performance-update-disclosure summary {
    list-style: none;
    cursor: pointer;
    min-height: 48px;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    color: var(--navy);
    font-weight: 950;
}
.performance-update-disclosure summary::-webkit-details-marker {
    display: none;
}
.performance-update-disclosure summary .icon {
    color: var(--red);
}
.performance-update-disclosure .performance-entry-panel {
    margin-top: 0;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    border-radius: 0;
    box-shadow: none;
}
.performance-history-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 12px;
}
.performance-history-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
}
.performance-history-list {
    display: grid;
    gap: 8px;
}
.performance-history-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: linear-gradient(135deg, #fff, #F8FAFF);
    padding: 10px;
}
.performance-history-row b,
.performance-history-row span {
    display: block;
}
.performance-history-row b {
    color: var(--navy);
    line-height: 1.2;
}
.performance-history-row span {
    color: var(--muted);
    font-size: 12px;
    margin-top: 3px;
}
.btn.compact {
    min-height: 34px;
    padding: 6px 9px;
    font-size: 12px;
}
.drawer-headline {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: start;
    border-bottom: 1px solid var(--line);
    padding-bottom: 12px;
    margin-bottom: 12px;
}
.drawer-headline h3 { margin: 0; color: var(--navy); }
.drawer-headline p { margin: 5px 0 0; color: var(--muted); }
.drawer-section {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    margin-top: 12px;
}
.modal-command-section {
    background:
        radial-gradient(circle at 3% 0, rgba(246,166,9,.12), transparent 24%),
        #fff;
}
.modal-command-section .delete-row {
    margin-top: 10px;
    align-items: center;
}
.drawer-section h4 {
    margin: 0 0 10px;
    color: var(--navy);
    display: flex;
    align-items: center;
    gap: 8px;
}
.drawer-section h4 .icon { color: var(--red); }
.timeline-list,
.document-list {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
}
.timeline-list.compact,
.document-list.compact {
    max-height: 220px;
    overflow: auto;
    padding-right: 2px;
}
.timeline-item,
.document-row {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #F9FBFE;
    padding: 10px;
}
.timeline-item b,
.timeline-item span,
.document-row b,
.document-row span {
    display: block;
}
.timeline-item b,
.document-row b { color: var(--navy); font-size: 13px; }
.timeline-item span,
.document-row span { color: var(--muted); font-size: 12px; margin-top: 2px; }
.timeline-item p { margin: 7px 0 0; color: #344054; font-size: 13px; }
.document-row {
    display: grid;
    grid-template-columns: 28px 1fr;
    align-items: start;
    gap: 8px;
}
.document-row .icon { color: var(--red); margin-top: 2px; }
.delete-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px dashed var(--line);
}
.sop-quickstart { background: linear-gradient(135deg, #fff, #F7F9FE); }
.quickstart-form {
    display: grid;
    grid-template-columns: minmax(220px, 1.4fr) minmax(150px, .8fr) minmax(170px, 1fr) auto;
    gap: 8px;
    align-items: start;
}
.sop-template-strip {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-top: 10px;
}
.sop-template-chip {
    flex: 0 0 220px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
}
.sop-template-chip b,
.sop-template-chip span { display: block; }
.sop-template-chip b { color: var(--navy); font-size: 13px; }
.sop-template-chip span { color: var(--muted); font-size: 12px; margin-top: 4px; }
.sop-template-chip.critical-template { border-color: #F0B4BE; background: #FFF5F7; }
.sop-detail-box {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #F8FBFF;
    padding: 12px;
    margin: 12px 0;
}
.sop-mini-meta,
.sop-doc-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 10px;
}
.sop-mini-meta span,
.sop-doc-list span {
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--muted);
    padding: 5px 8px;
    font-size: 12px;
    font-weight: 800;
}
.sop-checklist { display: grid; gap: 7px; margin-bottom: 10px; }
.sop-check {
    display: grid;
    grid-template-columns: 20px 1fr;
    gap: 8px;
    align-items: center;
    color: var(--ink);
    font-size: 13px;
}
.sop-check .icon { color: var(--blue); width: 16px; height: 16px; }
.sop-mini-progress { margin-top: 8px; display: grid; gap: 5px; }
.sop-mini-progress span { color: var(--muted); font-size: 12px; font-weight: 850; }
.dashboard-section { margin-bottom: 14px; }
.role-flow-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.9);
    box-shadow: 0 10px 26px rgba(2,11,69,.06);
    backdrop-filter: blur(12px);
    padding: 14px;
}
.role-flow-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}
.role-flow-head h3 { margin: 0; color: var(--navy); font-size: 16px; }
.role-flow-head p { margin: 3px 0 0; color: var(--muted); }
.role-flow-strip {
    display: grid;
    grid-template-columns: repeat(5, minmax(120px, 1fr));
    gap: 24px;
    overflow-x: auto;
    padding: 4px 2px 8px;
}
.role-flow-step {
    position: relative;
    min-height: 92px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 9px;
}
.role-flow-step:not(:last-child):after {
    content: "";
    position: absolute;
    left: calc(100% + 6px);
    top: 50%;
    width: 12px;
    height: 12px;
    border-top: 2px solid #A7B0C7;
    border-right: 2px solid #A7B0C7;
    transform: translateY(-50%) rotate(45deg);
}
.role-flow-step span {
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    border-radius: 999px;
    background: var(--navy);
    color: #fff;
    box-shadow: 0 8px 18px rgba(2,11,69,.18);
}
.role-flow-step:nth-child(3) span { background: var(--red); }
.role-flow-step:nth-child(5) span { background: var(--green); }
.role-flow-step b { color: var(--navy); font-size: 13px; text-align: center; }
.section-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin: 4px 0 12px;
}
.section-heading h3 { margin: 0; color: var(--navy); font-size: 18px; letter-spacing: 0; }
.section-heading p { margin: 3px 0 0; color: var(--muted); max-width: 760px; }
.metric-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.metric-tile {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    min-height: 82px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.metric-tile b { display: block; color: var(--navy); font-size: 24px; line-height: 1; letter-spacing: 0; }
.metric-tile small { display: block; color: var(--muted); font-weight: 800; margin-top: 4px; }
.pm-visual-grid {
    display: grid;
    grid-template-columns: minmax(320px, .95fr) minmax(360px, 1.05fr);
    gap: 14px;
    margin-bottom: 14px;
}
.project-stack { display: grid; gap: 10px; }
.project-health-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 12px;
    background: linear-gradient(135deg, #fff, #F8FBFF);
}
.project-health-row small { display: block; color: var(--muted); margin: 4px 0 9px; }
.project-health-row strong { color: var(--navy); font-size: 22px; }
.project-row-title { display: flex; align-items: center; gap: 8px; justify-content: space-between; }
.risk-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 4px 8px;
    font-size: 11px;
    font-weight: 900;
    background: #EEF8FF;
    color: var(--blue);
}
.risk-pill.success { background: #EAFBF5; color: var(--green); }
.risk-pill.danger { background: #FFF2F1; color: var(--red); }
.risk-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 12px;
}
.risk-row.stacked { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.risk-row > div {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #F8FBFF;
    padding: 11px;
}
.risk-row b { display: block; color: var(--navy); font-size: 24px; line-height: 1; }
.risk-row span { color: var(--muted); font-size: 12px; font-weight: 800; }
.site-pulse-list { display: grid; gap: 9px; }
.site-pulse-item {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 10px;
}
.site-pulse-item small { display: block; color: var(--muted); margin-top: 3px; }
.demo-flow-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
.flow-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: linear-gradient(135deg, #fff, #F8FBFF);
    padding: 12px;
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 10px;
}
.flow-card b { display: block; color: var(--navy); }
.flow-card small { display: block; color: var(--muted); font-weight: 850; margin-top: 2px; }
.flow-card p { margin: 8px 0 0; color: var(--muted); font-size: 12px; }
.template-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}
.template-link {
    min-height: 42px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 10px;
    color: var(--navy);
    font-weight: 850;
}
.security-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}
.security-check {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #F8FBFF;
    padding: 10px;
}
.security-check b,
.security-check span,
.security-check small { display: block; }
.security-check b { color: var(--navy); }
.security-check span { color: var(--ink); font-weight: 850; margin-top: 4px; }
.security-check small { color: var(--muted); margin-top: 2px; }
.production-gate {
    border-top: 3px solid var(--gold);
}
.production-gate.is-ready {
    border-top-color: var(--green);
}
.production-gate.is-blocked {
    border-top-color: var(--red);
}
.gate-score {
    min-width: 92px;
    border: 1px solid rgba(246,166,9,.45);
    border-radius: var(--radius);
    background: linear-gradient(135deg, var(--gold), #C77805);
    color: #fff;
    text-align: center;
    padding: 10px 12px;
    box-shadow: 0 12px 28px rgba(198,120,5,.18);
}
.gate-score b { display: block; font-size: 26px; line-height: 1; }
.gate-score span { display: block; margin-top: 4px; font-size: 12px; font-weight: 850; }
.gate-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
}
.gate-check {
    display: grid;
    grid-template-columns: 34px 1fr auto;
    gap: 10px;
    align-items: start;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 11px;
}
.gate-check.pass {
    border-color: rgba(24,167,123,.28);
    background: rgba(24,167,123,.06);
}
.gate-check.blocked {
    border-color: rgba(211,6,36,.22);
    background: rgba(211,6,36,.045);
}
.gate-icon {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(2,11,69,.06);
    color: var(--navy);
}
.gate-check.pass .gate-icon { color: var(--green); background: rgba(24,167,123,.12); }
.gate-check.blocked .gate-icon { color: var(--red); background: rgba(211,6,36,.1); }
.gate-check b,
.gate-check small,
.gate-check p { display: block; }
.gate-check b { color: var(--navy); }
.gate-check small { margin-top: 2px; color: var(--muted); font-weight: 850; }
.gate-check p { margin: 6px 0 0; color: var(--muted); font-size: 12px; line-height: 1.35; }
.gate-check strong {
    color: var(--red);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.gate-check.pass strong { color: var(--green); }
.final-walkthrough-pack {
    background:
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,251,255,.94)),
        #fff;
}
.walkthrough-role-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.walkthrough-role-card {
    min-height: 172px;
    display: grid;
    align-content: space-between;
    gap: 10px;
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 16px;
    background:
        radial-gradient(circle at 0 0, rgba(213,182,91,.18), transparent 34%),
        rgba(255,255,255,.96);
    padding: 12px;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.walkthrough-role-card:hover {
    transform: translateY(-2px);
    border-color: rgba(213,182,91,.52);
    box-shadow: 0 16px 34px rgba(2,11,69,.08);
}
.walkthrough-role-card h4 {
    margin: 3px 0 0;
    color: var(--navy);
    font-size: 15px;
    line-height: 1.15;
}
.walkthrough-role-card p {
    margin: 0;
    color: var(--muted);
    font-size: 12.5px;
    font-weight: 750;
    line-height: 1.42;
}
.walkthrough-role-meta {
    display: grid;
    gap: 6px;
}
.walkthrough-role-meta span,
.walkthrough-role-meta small {
    display: block;
    border-radius: 12px;
    padding: 8px 9px;
    font-size: 11.5px;
    font-weight: 850;
    line-height: 1.3;
}
.walkthrough-role-meta span {
    background: rgba(211,6,36,.08);
    color: var(--red);
}
.walkthrough-role-meta small {
    background: rgba(2,11,69,.05);
    color: var(--muted);
}
.walkthrough-evidence-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-top: 10px;
}
.walkthrough-evidence-strip > div {
    border: 1px solid rgba(213,182,91,.34);
    border-radius: 14px;
    background:
        linear-gradient(135deg, rgba(213,182,91,.16), rgba(255,255,255,.96)),
        #fff;
    padding: 10px;
}
.walkthrough-evidence-strip b,
.walkthrough-evidence-strip span {
    display: block;
}
.walkthrough-evidence-strip b {
    color: var(--navy);
    font-size: 22px;
    line-height: 1;
}
.walkthrough-evidence-strip span {
    margin-top: 4px;
    color: var(--muted);
    font-size: 11.5px;
    font-weight: 850;
    line-height: 1.25;
}
.walkthrough-freeze-sequence {
    margin-top: 12px;
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 16px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.96), rgba(247,249,254,.9)),
        #fff;
    padding: 12px;
}
.freeze-sequence-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}
.freeze-sequence-head h4 {
    margin: 2px 0 0;
    color: var(--navy);
    font-size: 16px;
    line-height: 1.2;
}
.freeze-sequence-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}
.freeze-sequence-card {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 9px;
    align-items: start;
    border: 1px solid rgba(221,228,240,.92);
    border-radius: 14px;
    background: rgba(255,255,255,.94);
    padding: 10px;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.freeze-sequence-card:hover {
    transform: translateY(-2px);
    border-color: rgba(213,182,91,.5);
    box-shadow: 0 14px 28px rgba(2,11,69,.08);
}
.freeze-sequence-card > span {
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--gold), var(--orange));
    color: #fff;
    font-size: 13px;
    font-weight: 950;
    box-shadow: 0 8px 20px rgba(213,182,91,.22);
}
.freeze-sequence-card b,
.freeze-sequence-card small,
.freeze-sequence-card p {
    display: block;
}
.freeze-sequence-card b {
    color: var(--navy);
    font-size: 13px;
    line-height: 1.25;
}
.freeze-sequence-card small {
    margin-top: 2px;
    color: var(--red);
    font-size: 10.5px;
    font-weight: 900;
    text-transform: uppercase;
}
.freeze-sequence-card p {
    margin: 5px 0 0;
    color: var(--muted);
    font-size: 11.5px;
    font-weight: 760;
    line-height: 1.35;
}
.walkthrough-freeze-sequence code {
    display: block;
    margin-top: 10px;
    overflow-x: auto;
    border: 1px solid rgba(213,182,91,.34);
    border-radius: 12px;
    background: rgba(2,11,69,.04);
    color: var(--navy);
    padding: 9px 10px;
    font-size: 12px;
    font-weight: 850;
}
.completion-roadmap {
    background:
        radial-gradient(circle at 8% 0%, rgba(213,182,91,.16), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,251,255,.94)),
        #fff;
}
.completion-roadmap-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.completion-roadmap-card {
    min-height: 210px;
    display: grid;
    align-content: start;
    gap: 8px;
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 16px;
    background: rgba(255,255,255,.96);
    padding: 12px;
    box-shadow: 0 12px 28px rgba(2,11,69,.05);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.completion-roadmap-card:hover {
    transform: translateY(-2px);
    border-color: rgba(213,182,91,.52);
    box-shadow: 0 18px 36px rgba(2,11,69,.09);
}
.completion-roadmap-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.completion-roadmap-top span,
.completion-roadmap-card small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    line-height: 1.25;
}
.completion-roadmap-top strong {
    border-radius: 999px;
    background: rgba(213,182,91,.18);
    color: var(--navy);
    padding: 5px 8px;
    font-size: 12px;
    font-weight: 950;
}
.completion-roadmap-card h4 {
    margin: 0;
    color: var(--navy);
    font-size: 15px;
    line-height: 1.18;
}
.completion-roadmap-card p,
.completion-roadmap-card em {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    font-style: normal;
    font-weight: 760;
    line-height: 1.38;
}
.completion-roadmap-card em {
    border-radius: 12px;
    background: rgba(211,6,36,.06);
    color: #8F1026;
    padding: 8px;
}
.completion-meter {
    height: 7px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(18,58,131,.10);
}
.completion-meter i {
    display: block;
    width: var(--value);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--blue), var(--red), var(--gold));
}
.next-actions-100 {
    border-color: rgba(213,182,91,.42);
    background:
        radial-gradient(circle at 92% 0%, rgba(211,6,36,.08), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(255,249,235,.88)),
        #fff;
}
.next-actions-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.next-action-card {
    display: grid;
    align-content: start;
    gap: 8px;
    min-height: 210px;
    padding: 14px;
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 16px;
    background: rgba(255,255,255,.96);
    box-shadow: 0 12px 28px rgba(2,11,69,.06);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.next-action-card:hover {
    transform: translateY(-2px);
    border-color: rgba(211,6,36,.32);
    box-shadow: 0 18px 36px rgba(2,11,69,.10);
}
.next-action-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.next-action-top span {
    display: inline-grid;
    place-items: center;
    width: 30px;
    height: 30px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--gold), var(--red));
    color: #fff;
    font-weight: 950;
    box-shadow: 0 10px 18px rgba(211,6,36,.18);
}
.next-action-top strong {
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(2,11,69,.06);
    color: var(--navy);
    font-size: 11px;
    line-height: 1.1;
}
.next-action-card h4 {
    margin: 0;
    color: var(--navy);
    font-size: 16px;
    line-height: 1.18;
}
.next-action-card small {
    color: var(--muted);
    font-weight: 850;
}
.next-action-card p,
.next-action-card em,
.next-action-card code {
    margin: 0;
    color: var(--muted);
    font-size: 12px;
    line-height: 1.45;
}
.next-action-card em {
    color: var(--ink);
    font-style: normal;
    font-weight: 760;
}
.next-action-card code {
    display: block;
    padding: 8px;
    border-radius: 10px;
    background: rgba(2,11,69,.05);
    color: #334155;
    white-space: normal;
    word-break: break-word;
}
.readiness-detail-stack {
    display: grid;
    gap: 10px;
    margin-bottom: 14px;
}
.readiness-accordion {
    border: 1px solid rgba(221,228,240,.96);
    border-radius: 16px;
    background:
        linear-gradient(135deg, rgba(255,255,255,.97), rgba(247,249,254,.92)),
        #fff;
    box-shadow: 0 12px 30px rgba(2,11,69,.05);
    overflow: hidden;
    transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.readiness-accordion:hover {
    transform: translateY(-1px);
    border-color: rgba(213,182,91,.45);
    box-shadow: 0 18px 38px rgba(2,11,69,.08);
}
.readiness-accordion > summary {
    position: relative;
    min-height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 14px 16px;
    cursor: pointer;
    list-style: none;
}
.readiness-accordion > summary::-webkit-details-marker {
    display: none;
}
.readiness-accordion > summary:after {
    content: "";
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--navy);
    border-bottom: 2px solid var(--navy);
    transform: rotate(45deg);
    transition: transform .18s ease;
    flex: 0 0 auto;
}
.readiness-accordion[open] > summary:after {
    transform: rotate(225deg);
}
.readiness-accordion > summary span,
.readiness-accordion > summary small {
    display: flex;
    align-items: center;
}
.readiness-accordion > summary span {
    gap: 9px;
    color: var(--navy);
    font-size: 15px;
    font-weight: 950;
}
.readiness-accordion > summary .icon {
    color: var(--red);
}
.readiness-accordion > summary small {
    max-width: 520px;
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    line-height: 1.35;
    text-align: right;
}
.readiness-accordion[open] {
    padding-bottom: 10px;
}
.readiness-accordion[open] > summary {
    border-bottom: 1px solid rgba(221,228,240,.72);
    margin-bottom: 10px;
}
.readiness-accordion > .grid,
.readiness-accordion > .card {
    margin-left: 12px;
    margin-right: 12px;
}
.role-flow-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.role-flow-grid .role-flow-card {
    min-height: 100%;
    display: grid;
    gap: 8px;
}
.role-flow-grid .role-flow-card h4 {
    margin: 2px 0 0;
    color: var(--navy);
    font-size: 15px;
}
.role-flow-grid .role-flow-card p {
    margin: 0;
    color: var(--muted);
    font-size: 12.5px;
    line-height: 1.4;
}
.role-flow-grid .role-flow-card p b { color: var(--ink); }
.role-flow-grid .role-flow-card small {
    display: block;
    margin-top: 2px;
    border-top: 1px solid var(--line);
    padding-top: 8px;
    color: var(--red);
    font-weight: 850;
    line-height: 1.35;
}
.action-inventory-card {
    overflow: hidden;
}
.action-inventory-summary {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 12px;
}
.action-inventory-summary > div {
    border: 1px solid rgba(213, 182, 91, .32);
    border-radius: 14px;
    background:
        linear-gradient(135deg, rgba(213, 182, 91, .16), rgba(255,255,255,.94) 54%),
        #fff;
    padding: 12px;
}
.action-inventory-summary b,
.action-inventory-summary span {
    display: block;
}
.action-inventory-summary b {
    color: var(--navy);
    font-size: 24px;
    line-height: 1;
}
.action-inventory-summary span {
    margin-top: 4px;
    color: var(--muted);
    font-weight: 800;
    font-size: 12px;
}
.action-inventory-grid {
    display: grid;
    gap: 8px;
    max-height: 620px;
    overflow: auto;
    padding-right: 2px;
}
.action-inventory-row {
    display: grid;
    grid-template-columns: minmax(150px, .7fr) minmax(240px, 1.25fr) minmax(220px, 1fr);
    gap: 12px;
    align-items: start;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,.96);
    padding: 12px;
}
.action-inventory-row b,
.action-inventory-row small,
.action-inventory-row p {
    display: block;
}
.action-inventory-row b {
    color: var(--navy);
    font-size: 14px;
}
.action-inventory-row p {
    margin: 5px 0 8px;
    color: var(--muted);
    font-size: 12.5px;
    line-height: 1.4;
}
.action-inventory-row code {
    display: block;
    width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    border-radius: 10px;
    background: rgba(2,11,69,.05);
    color: var(--navy);
    padding: 7px 9px;
    font-size: 11px;
}
.action-inventory-role {
    display: grid;
    gap: 7px;
}
.action-inventory-role small,
.action-inventory-row small {
    color: var(--muted);
    line-height: 1.35;
    font-size: 12px;
}
.action-inventory-chip,
.action-inventory-status {
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-items: center;
    border-radius: 999px;
    border: 1px solid rgba(213, 182, 91, .46);
    background: linear-gradient(135deg, #ffd96b, #b47412);
    color: #fff;
    padding: 6px 9px;
    font-size: 11px;
    font-weight: 900;
    line-height: 1.1;
    box-shadow: 0 10px 24px rgba(180,116,18,.18);
}
.action-inventory-status {
    margin-bottom: 7px;
    background: rgba(2,11,69,.06);
    border-color: rgba(2,11,69,.12);
    color: var(--navy);
    box-shadow: none;
}
.qa-check-list { display: grid; gap: 9px; }
.qa-check {
    display: grid;
    grid-template-columns: 28px 1fr;
    gap: 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
}
.qa-check .icon { color: var(--blue); margin-top: 2px; }
.qa-check b,
.qa-check span,
.qa-check small { display: block; }
.qa-check b { color: var(--navy); }
.qa-check span { color: var(--muted); margin-top: 3px; }
.qa-check small { color: var(--green); font-weight: 800; margin-top: 5px; }
.sop-coverage-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}
.critical-template-list { display: grid; gap: 8px; }
.critical-template-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
}
.critical-template-row b,
.critical-template-row span,
.critical-template-row small { display: block; }
.critical-template-row b { color: var(--navy); }
.critical-template-row span { color: var(--muted); font-size: 12px; margin-top: 3px; }
.critical-template-row small {
    color: var(--red);
    background: #FFF0F3;
    border-radius: 999px;
    padding: 5px 8px;
    font-weight: 900;
    white-space: nowrap;
}
.chart-box {
    min-height: 282px;
    display: flex;
    flex-direction: column;
}
.chart-box > canvas {
    width: 100% !important;
    height: 220px !important;
    max-height: 220px;
}
.chart-frame {
    position: relative;
    width: 100%;
    height: 220px;
    min-height: 220px;
}
.chart-frame.large { height: 268px; min-height: 268px; }
.chart-frame canvas,
.s-curve-box canvas {
    width: 100% !important;
    height: 100% !important;
}
.s-curve-box { position: relative; height: 300px; }
.cpm-list { display: grid; gap: 9px; }
.cpm-list.compact { max-height: 250px; overflow: auto; padding-right: 2px; }
.cpm-item { display: grid; grid-template-columns: 70px 1fr 60px; gap: 10px; align-items: center; padding: 10px; border: 1px solid var(--line); border-radius: var(--radius); }
.critical { color: var(--red); font-weight: 900; }
.project-phase-panel {
    width: min(1180px, calc(100vw - 24px));
    max-height: 90vh;
}
.project-phase-body {
    display: grid;
    gap: 12px;
    max-height: calc(90vh - 96px);
    overflow: auto;
}
.phase-explainer {
    display: grid;
    grid-template-columns: 40px 1fr;
    gap: 10px;
    align-items: center;
    border: 1px solid rgba(213,182,91,.38);
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(213,182,91,.16), rgba(255,255,255,.96));
    padding: 12px;
}
.phase-explainer .icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    padding: 9px;
    color: #fff;
    background: linear-gradient(135deg, #D5A332, #9A610E);
}
.phase-explainer b,
.phase-explainer span {
    display: block;
}
.phase-explainer b { color: var(--navy); }
.phase-explainer span { color: var(--muted); margin-top: 3px; line-height: 1.4; }
.phase-project-card {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: rgba(255,255,255,.96);
    overflow: hidden;
}
.phase-project-card summary {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 14px;
    cursor: pointer;
    list-style: none;
}
.phase-project-card summary::-webkit-details-marker { display: none; }
.phase-project-card summary b,
.phase-project-card summary small {
    display: block;
}
.phase-project-card summary b { color: var(--navy); }
.phase-project-card summary small { color: var(--muted); margin-top: 3px; }
.phase-project-card summary strong {
    border-radius: 999px;
    background: rgba(24,167,123,.1);
    color: var(--green);
    border: 1px solid rgba(24,167,123,.24);
    padding: 7px 10px;
    font-size: 12px;
}
.project-phase-layout {
    display: grid;
    grid-template-columns: 290px 1fr;
    gap: 12px;
    border-top: 1px solid var(--line);
    padding: 14px;
}
.project-phase-list,
.project-phase-detail {
    display: grid;
    gap: 10px;
}
.phase-card {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,255,.94));
    padding: 10px;
    display: grid;
    gap: 8px;
    color: var(--navy);
}
.phase-card > div {
    display: flex;
    align-items: center;
    gap: 8px;
}
.phase-card .icon {
    width: 28px;
    height: 28px;
    border-radius: 10px;
    padding: 6px;
    color: var(--red);
    background: rgba(211,6,36,.08);
}
.phase-card b { justify-self: end; font-size: 12px; color: var(--green); }
.phase-card span { font-weight: 900; font-size: 12px; }
.phase-card small { color: var(--muted); font-weight: 800; }
.phase-detail-section {
    border: 1px solid var(--line);
    border-radius: 14px;
    background: #fff;
    padding: 10px;
}
.phase-detail-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: start;
    margin-bottom: 10px;
}
.phase-detail-head b,
.phase-detail-head small,
.phase-detail-head span {
    display: block;
}
.phase-detail-head b { color: var(--navy); }
.phase-detail-head small {
    margin-top: 4px;
    color: var(--muted);
    line-height: 1.35;
}
.phase-detail-head > span {
    border-radius: 999px;
    background: rgba(2,11,69,.05);
    color: var(--navy);
    padding: 6px 9px;
    font-size: 11px;
    font-weight: 900;
}
.phase-task-list {
    display: grid;
    gap: 8px;
}
.phase-task-list a {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 9px;
    color: var(--navy);
    background: rgba(248,250,255,.72);
}
.phase-task-list b,
.phase-task-list small {
    display: block;
}
.phase-task-list b { font-size: 13px; }
.phase-task-list small { margin-top: 3px; color: var(--muted); }
.mobile-bottom-nav {
    display: none;
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 30;
    background:
        linear-gradient(180deg, rgba(255,255,255,.96), #fff),
        radial-gradient(circle at 50% -30%, rgba(246,166,9,.20), transparent 42%);
    border-top: 1px solid rgba(221,228,240,.95);
    box-shadow: 0 -18px 38px rgba(2,11,69,.14);
    backdrop-filter: blur(18px);
    grid-template-columns: repeat(5, 1fr);
    min-height: var(--mobile-nav-height);
    padding: 6px 8px calc(6px + env(safe-area-inset-bottom));
}
.mobile-bottom-nav a,
.mobile-bottom-nav button {
    min-height: 52px;
    border: 1px solid transparent;
    border-radius: 16px;
    background: transparent;
    display: grid;
    place-items: center;
    gap: 2px;
    color: #344054;
    font-size: 10px;
    font-weight: 900;
    cursor: pointer;
    transition: transform .16s ease, background .16s ease, color .16s ease, border-color .16s ease;
}
.mobile-bottom-nav a.active,
.mobile-bottom-nav button.active {
    color: var(--navy);
    background: linear-gradient(135deg, rgba(246,166,9,.16), rgba(255,255,255,.96));
    border-color: rgba(246,166,9,.34);
    box-shadow: inset 0 -2px 0 rgba(211,6,36,.55);
}
.mobile-bottom-nav .mobile-center-action {
    position: relative;
    min-height: 56px;
    height: 56px;
    max-width: 58px;
    width: 58px;
    justify-self: center;
    align-self: start;
    margin-top: -18px;
    color: var(--navy);
    background:
        radial-gradient(circle at 30% 18%, rgba(246,166,9,.18), transparent 30%),
        #fff;
    border: 2px solid rgba(246,166,9,.72);
    border-radius: 999px;
    box-shadow:
        0 12px 24px rgba(2,11,69,.14),
        0 0 0 4px rgba(255,255,255,.86),
        0 0 0 6px rgba(246,166,9,.18);
    text-shadow: none;
    overflow: visible;
}
.mobile-bottom-nav .mobile-center-action:before {
    content: "";
    position: absolute;
    inset: -3px;
    border-radius: 999px;
    border: 1px solid rgba(246,166,9,.38);
    background: rgba(255,255,255,.10);
    z-index: -1;
    display: none;
}
.mobile-bottom-nav .mobile-center-action.active,
.mobile-bottom-nav .mobile-center-action:hover {
    transform: translateY(-1px);
    color: #fff;
    background:
        radial-gradient(circle at 30% 18%, rgba(255,255,255,.26), transparent 30%),
        linear-gradient(145deg, #D30624 0%, #B30521 62%, #7A0319 100%);
    border-color: #fff;
    box-shadow:
        0 13px 26px rgba(211,6,36,.24),
        0 0 0 3px rgba(246,166,9,.34),
        0 0 0 7px rgba(255,255,255,.72),
        inset 0 -4px 9px rgba(2,11,69,.18);
}
.mobile-center-action .center-action-icon {
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: transparent;
    border: 0;
}
.mobile-center-action .icon { width: 22px; height: 22px; color: var(--navy); stroke-width: 2.45; }
.mobile-center-action.active .icon,
.mobile-center-action:hover .icon { color: #fff; }
.mobile-bottom-nav .mobile-center-action > span:not(.center-action-icon) {
    display: none;
}
.mobile-menu-fab {
    display: none;
    position: fixed;
    right: 14px;
    bottom: calc(84px + env(safe-area-inset-bottom));
    z-index: 32;
    width: 46px;
    height: 46px;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: 999px;
    background: rgba(255,255,255,.96);
    color: var(--navy);
    box-shadow: 0 16px 32px rgba(2,11,69,.18), 0 0 0 4px rgba(255,255,255,.62);
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 0;
    font-size: 11px;
    font-weight: 950;
    cursor: pointer;
    text-shadow: none;
}
.mobile-menu-fab .icon {
    width: 20px;
    height: 20px;
    color: var(--navy);
    transition: color .16s ease, transform .16s ease;
}
.mobile-menu-fab:hover,
.mobile-menu-fab:focus-visible,
.mobile-menu-fab.open {
    border-color: rgba(246,166,9,.48);
    background:
        radial-gradient(circle at 30% 20%, rgba(255,255,255,.24), transparent 28%),
        linear-gradient(135deg, var(--navy), #08165A 58%, var(--red));
    color: #fff;
    box-shadow: 0 18px 36px rgba(2,11,69,.28), 0 0 0 5px rgba(246,166,9,.16);
    outline: none;
}
.mobile-menu-fab:hover .icon,
.mobile-menu-fab:focus-visible .icon,
.mobile-menu-fab.open .icon {
    color: #FFD46A;
    transform: rotate(-8deg);
}
.mobile-menu-sheet {
    position: fixed;
    inset: 0;
    z-index: 61;
    display: none;
    align-items: flex-end;
    background: rgba(2,11,69,.44);
    backdrop-filter: blur(5px);
}
.mobile-menu-sheet.open { display: flex; }
.mobile-menu-card {
    width: 100%;
    max-height: 76vh;
    overflow: auto;
    border-radius: 18px 18px 0 0;
    background:
        linear-gradient(rgba(255,255,255,.96), rgba(255,255,255,.96)),
        url("../image/sidebar-background.jpg") center / cover no-repeat;
    border: 1px solid var(--line);
    box-shadow: 0 -24px 60px rgba(2,11,69,.26);
    padding: 12px 12px calc(18px + env(safe-area-inset-bottom));
}
.mobile-menu-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 6px 2px 12px;
}
.mobile-menu-head b,
.mobile-menu-head small {
    display: block;
}
.mobile-menu-head b {
    color: var(--navy);
    font-size: 16px;
}
.mobile-menu-head small {
    color: var(--muted);
    font-size: 12px;
    margin-top: 2px;
}
.mobile-menu-head button {
    width: 38px;
    height: 38px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: #fff;
    color: var(--navy);
    display: grid;
    place-items: center;
}
.mobile-menu-quick-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 10px;
}
.mobile-menu-quick-actions a {
    min-height: 76px;
    border: 1px solid rgba(246,166,9,.30);
    border-radius: 16px;
    background:
        radial-gradient(circle at 28% 18%, rgba(255,255,255,.26), transparent 28%),
        linear-gradient(135deg, var(--navy), #08165A 62%, var(--red));
    color: #fff;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 6px;
    padding: 10px 7px;
    text-align: center;
    font-size: 11px;
    font-weight: 950;
    box-shadow: 0 14px 28px rgba(2,11,69,.16);
}
.mobile-menu-quick-actions a .icon {
    width: 24px;
    height: 24px;
    color: #FFD46A;
    filter: drop-shadow(0 5px 10px rgba(0,0,0,.18));
}
.mobile-menu-links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}
.mobile-menu-links a {
    min-height: 54px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: rgba(255,255,255,.94);
    color: var(--navy);
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 10px;
    font-weight: 900;
    box-shadow: 0 10px 24px rgba(2,11,69,.07);
}
.mobile-menu-links a .icon {
    color: var(--red);
    flex: 0 0 auto;
}
.mobile-menu-links a.active {
    border-color: rgba(246,166,9,.45);
    background: linear-gradient(135deg, rgba(246,166,9,.16), rgba(255,255,255,.96));
    box-shadow: inset 0 -2px 0 rgba(211,6,36,.55), 0 12px 26px rgba(2,11,69,.09);
}
.mobile-profile-sheet {
    position: fixed;
    inset: 0;
    z-index: 60;
    display: none;
    align-items: flex-end;
    background: rgba(2,11,69,.42);
    backdrop-filter: blur(5px);
}
.mobile-profile-sheet.open { display: flex; }
.mobile-profile-card {
    width: 100%;
    border-radius: 18px 18px 0 0;
    background: #fff;
    border: 1px solid var(--line);
    box-shadow: 0 -20px 50px rgba(2,11,69,.20);
    padding: 10px 12px calc(16px + env(safe-area-inset-bottom));
}
.mobile-profile-actions {
    display: grid;
    gap: 7px;
}
.mobile-profile-actions a,
.mobile-profile-actions button,
.mobile-sheet-close {
    width: 100%;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    color: var(--navy);
    min-height: 42px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 900;
}
.mobile-sheet-close {
    margin-top: 8px;
    background: var(--pale);
}
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.form-grid .span-2 { grid-column: span 2; }
.site-diary-form { overflow: visible; }
.quick-phrase-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
}
.quick-phrase-row > span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.quick-phrase-row > div {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.quick-phrase-row button {
    border: 1px solid rgba(212, 164, 65, .36);
    border-radius: 999px;
    background: rgba(255, 248, 229, .86);
    color: var(--navy);
    cursor: pointer;
    font-size: 11px;
    font-weight: 850;
    padding: 6px 9px;
    transition: .18s ease;
}
.quick-phrase-row button:hover {
    background: var(--gold);
    border-color: var(--gold);
    box-shadow: 0 10px 24px rgba(212, 164, 65, .22);
    transform: translateY(-1px);
}
.quick-phrase-row .quick-phrase-save {
    background: #fff;
    border-color: var(--line);
    color: var(--muted);
}
.mobile-sticky-submit { display: none; }
.site-diary-flow {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 14px;
}
.site-diary-flow div {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px;
    color: var(--navy);
}
.site-diary-flow .icon { color: var(--red); flex: 0 0 auto; }
.site-diary-flow b { font-size: 13px; }
.photo-upload-field {
    border: 1px dashed #C9D4E5;
    border-radius: var(--radius);
    padding: 12px;
    background: #F9FBFF;
}
.photo-upload-field small { color: var(--muted); font-size: 12px; margin-top: 6px; display: block; }
.site-diary-step-cards div {
    min-height: 64px;
    background: linear-gradient(135deg, #fff, #F8FBFF);
}
.worker-stepper input {
    min-height: 52px;
    font-size: 22px;
    font-weight: 900;
    text-align: center;
    color: var(--navy);
}
.progress-slider-field {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
}
.progress-slider-field label {
    display: flex;
    justify-content: space-between;
}
.progress-slider-field label span {
    color: var(--red);
    font-weight: 950;
}
.progress-slider {
    padding: 0;
    accent-color: var(--red);
}
.interruption-card {
    border: 1px solid #F3C7C3;
    border-radius: var(--radius);
    background: #FFF8F7;
    padding: 10px;
}
.interruption-card label {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--red);
}
.site-supervisor-diary-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr) minmax(240px, .55fr);
    gap: 12px;
    align-items: stretch;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(213,182,91,.14), transparent 32%),
        rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.07);
    backdrop-filter: blur(14px);
    padding: 12px;
    margin-bottom: 14px;
}
.site-supervisor-copy {
    display: grid;
    align-content: center;
    gap: 5px;
    min-width: 0;
}
.site-supervisor-copy h3 {
    margin: 0;
    color: var(--navy);
    font-size: 22px;
    line-height: 1.08;
}
.site-supervisor-copy p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    font-weight: 760;
    line-height: 1.35;
}
.site-supervisor-steps,
.site-supervisor-status {
    display: grid;
    gap: 8px;
}
.site-supervisor-steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.site-supervisor-steps div,
.site-supervisor-status a {
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 15px;
    background: #fff;
    padding: 10px;
    color: var(--navy);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.site-supervisor-steps div:hover,
.site-supervisor-status a:hover {
    transform: translateY(-1px);
    border-color: rgba(246,166,9,.48);
    box-shadow: 0 14px 28px rgba(2,11,69,.08);
}
.site-supervisor-steps .icon {
    color: var(--red);
    width: 20px;
    height: 20px;
    margin-bottom: 8px;
}
.site-supervisor-steps b,
.site-supervisor-steps span,
.site-supervisor-status b,
.site-supervisor-status span {
    display: block;
}
.site-supervisor-steps b {
    font-size: 12px;
    font-weight: 950;
    line-height: 1.12;
}
.site-supervisor-steps span {
    margin-top: 4px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 820;
    line-height: 1.2;
}
.site-supervisor-status {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.site-supervisor-status a {
    display: grid;
    place-items: center;
    text-align: center;
}
.site-supervisor-status b {
    font-size: 23px;
    line-height: 1;
}
.site-supervisor-status span {
    margin-top: 5px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
}
.flash { border: 1px solid #BFEAD9; background: #ECFBF5; color: #076A4C; border-radius: var(--radius); padding: 10px 12px; margin-bottom: 14px; font-weight: 750; }
.pagination,
.pagination-wrap {
    margin-top: 14px;
}
.synar-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    box-shadow: 0 10px 24px rgba(2,11,69,.06);
}
.pagination-summary {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
}
.pagination-summary b {
    color: var(--navy);
}
.pagination-controls {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 6px;
}
.pagination-btn {
    min-width: 36px;
    min-height: 36px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: #fff;
    color: var(--navy);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    font-size: 12px;
    font-weight: 950;
}
.pagination-btn.active {
    border-color: rgba(211,6,36,.28);
    background: linear-gradient(135deg, var(--red), #A80522);
    color: #fff;
    box-shadow: 0 10px 22px rgba(211,6,36,.18);
}
.pagination-btn.disabled {
    opacity: .46;
    cursor: not-allowed;
}
.role-command-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(260px, .42fr);
    gap: 12px;
    align-items: stretch;
    margin-bottom: 14px;
    padding: 12px;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.14), transparent 32%),
        rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.08);
    backdrop-filter: blur(14px);
}
.finance-ownership-strip {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 28px minmax(0, 1fr) 28px minmax(0, 1fr) 28px minmax(0, 1fr);
    gap: 8px;
    align-items: center;
    margin-bottom: 14px;
    padding: 10px;
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 5% 0%, rgba(246,166,9,.16), transparent 34%),
        rgba(255,255,255,.94);
    box-shadow: 0 14px 30px rgba(2,11,69,.06);
}
.finance-ownership-strip div {
    min-height: 82px;
    display: grid;
    align-content: center;
    gap: 4px;
    padding: 10px;
    border: 1px solid rgba(221,228,240,.88);
    border-radius: 12px;
    background: #fff;
}
.finance-ownership-strip span {
    width: 32px;
    height: 32px;
    display: grid;
    place-items: center;
    border-radius: 11px;
    background: rgba(211,6,36,.08);
    color: var(--red);
}
.finance-ownership-strip b {
    color: var(--navy);
    font-size: 13px;
    line-height: 1.1;
}
.finance-ownership-strip small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.25;
}
.finance-ownership-strip .flow-arrow {
    color: rgba(18,58,131,.42);
    justify-self: center;
}

.finance-role-guard,
.finance-owner-card {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.12), transparent 34%),
        rgba(255,255,255,.96);
    padding: 12px;
    margin-bottom: 14px;
    box-shadow: 0 14px 30px rgba(2,11,69,.06);
}

.finance-role-guard {
    display: grid;
    grid-template-columns: minmax(220px, .68fr) minmax(0, 1.32fr);
    gap: 12px;
    align-items: stretch;
}

.finance-role-guard-copy {
    display: grid;
    align-content: center;
    gap: 4px;
}

.finance-role-guard-copy h3 {
    margin: 0;
    color: var(--navy);
    font-size: 17px;
    line-height: 1.18;
}

.finance-role-guard-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.finance-role-guard-grid > div,
.director-finance-boundary > div:not(.director-finance-boundary-copy) {
    display: grid;
    align-content: start;
    gap: 5px;
    min-height: 92px;
    border: 1px solid rgba(221,228,240,.88);
    border-radius: 13px;
    background: #fff;
    padding: 10px;
}

.finance-role-guard-grid span,
.director-finance-boundary span {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: rgba(211,6,36,.08);
    color: var(--red);
}

.finance-role-guard-grid b,
.director-finance-boundary b {
    color: var(--navy);
    font-size: 13px;
    line-height: 1.15;
}

.finance-role-guard-grid small,
.director-finance-boundary small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.35;
}

.workflow-boundary-guard {
    display: grid;
    grid-template-columns: minmax(230px, .72fr) minmax(0, 1.28fr);
    gap: 12px;
    align-items: stretch;
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.13), transparent 34%),
        rgba(255,255,255,.96);
    padding: 12px;
    margin-bottom: 14px;
    box-shadow: 0 14px 30px rgba(2,11,69,.06);
}

.workflow-boundary-copy {
    display: grid;
    align-content: center;
    gap: 4px;
}

.workflow-boundary-copy h3 {
    margin: 0;
    color: var(--navy);
    font-size: 17px;
    line-height: 1.18;
}

.workflow-boundary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
}

.workflow-boundary-grid.four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.workflow-boundary-grid > div {
    display: grid;
    align-content: start;
    gap: 5px;
    min-height: 94px;
    border: 1px solid rgba(221,228,240,.88);
    border-radius: 13px;
    background: #fff;
    padding: 10px;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}

.workflow-boundary-grid > div:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.55);
    box-shadow: 0 14px 28px rgba(2,11,69,.08);
}

.workflow-boundary-grid span {
    width: 30px;
    height: 30px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: rgba(211,6,36,.08);
    color: var(--red);
}

.workflow-boundary-grid b {
    color: var(--navy);
    font-size: 13px;
    line-height: 1.15;
}

.workflow-boundary-grid small {
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.35;
}

.handover-boundary-guard {
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.16), transparent 34%),
        linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,251,255,.94));
}

.handover-path-grid span {
    background: rgba(246,166,9,.15);
    color: #8A5200;
}
.role-command-main {
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 10px;
    align-items: center;
}
.role-command-main h3 {
    margin: 2px 0;
    color: var(--navy);
    font-size: 18px;
}
.role-command-main p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.35;
}
.role-command-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-content: center;
    gap: 8px;
}
.role-command-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
}
.role-command-stats a {
    border: 1px solid var(--line);
    border-radius: 12px;
    background: #fff;
    padding: 10px;
    display: grid;
    gap: 3px;
}
.role-command-stats b {
    color: var(--navy);
    font-size: 21px;
    line-height: 1;
}
.role-command-stats span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 850;
}
.phase-focus-board {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, .74fr);
    gap: 12px;
    align-items: stretch;
    margin-bottom: 14px;
    padding: 12px;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.16), transparent 32%),
        rgba(255,255,255,.95);
    box-shadow: 0 14px 32px rgba(2,11,69,.07);
    backdrop-filter: blur(14px);
}
.phase-focus-main {
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 10px;
    align-items: center;
    min-width: 0;
}
.phase-focus-main h3 {
    margin: 2px 0 4px;
    color: var(--navy);
    font-size: 19px;
    line-height: 1.12;
}
.phase-focus-main p {
    margin: 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.35;
}
.phase-focus-metrics {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}
.phase-focus-metrics a {
    display: grid;
    gap: 4px;
    align-content: center;
    min-height: 72px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 13px;
    background: #fff;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.phase-focus-metrics a:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.54);
    box-shadow: 0 14px 28px rgba(2,11,69,.08);
}
.phase-focus-metrics b {
    color: var(--navy);
    font-size: 22px;
    line-height: 1;
}
.phase-focus-metrics span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    line-height: 1.16;
}
.tender-pipeline-details {
    margin-bottom: 14px;
}
.role-lane-board {
    margin-bottom: 14px;
    padding: 12px;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 100% 0, rgba(246,166,9,.12), transparent 30%),
        rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.06);
    backdrop-filter: blur(14px);
}
.role-lane-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}
.role-lane-head h3 {
    margin: 2px 0 0;
    color: var(--navy);
    font-size: 18px;
}
.role-lane-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}
.handover-lane-board .role-lane-grid,
.procurement-lane-board .role-lane-grid,
.site-lane-board .role-lane-grid,
.admin-lane-board .role-lane-grid,
.finance-lane-board .role-lane-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}
.role-lane-card {
    position: relative;
    min-height: 128px;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: linear-gradient(145deg, #fff, #F8FBFF);
    padding: 12px;
    display: grid;
    grid-template-columns: 38px 1fr auto;
    gap: 8px;
    align-items: start;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.role-lane-card:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.5);
    box-shadow: 0 16px 34px rgba(2,11,69,.09);
}
.role-lane-card:after {
    content: "";
    position: absolute;
    right: -28px;
    top: -34px;
    width: 94px;
    height: 94px;
    border-radius: 999px;
    background: rgba(211,6,36,.06);
}
.role-lane-card span {
    width: 36px;
    height: 36px;
    border-radius: 13px;
    display: grid;
    place-items: center;
    background: rgba(211,6,36,.08);
    color: var(--red);
}
.role-lane-card b {
    color: var(--navy);
    font-size: 14px;
    line-height: 1.1;
}
.role-lane-card strong {
    color: var(--navy);
    font-size: 24px;
    line-height: 1;
    position: relative;
    z-index: 1;
}
.role-lane-card small {
    grid-column: 1 / -1;
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
    line-height: 1.35;
}
.handover-owner-details {
    margin-bottom: 14px;
}
.compact-strip {
    margin: 10px 0 0;
    box-shadow: none;
}
.technical-command-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.technical-command-card {
    min-height: 112px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.94);
    padding: 12px;
    display: grid;
    align-content: start;
    gap: 8px;
    box-shadow: 0 10px 24px rgba(2,11,69,.06);
}
.technical-command-card b {
    color: var(--navy);
    line-height: 1.15;
}
.technical-command-card small {
    color: var(--muted);
    font-weight: 800;
}
.modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 70;
    display: none;
    background: rgba(2,11,69,.48);
    backdrop-filter: blur(6px);
}
.modal-backdrop.open { display: grid; place-items: center; padding: 18px; }
.modal-panel {
    width: min(920px, 100%);
    max-height: min(86vh, 820px);
    overflow: auto;
    border-radius: 14px;
    background: rgba(255,255,255,.96);
    border: 1px solid rgba(221,228,240,.95);
    box-shadow: 0 28px 80px rgba(2,11,69,.25);
}
.modal-head {
    position: sticky;
    top: 0;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--line);
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(14px);
}
.modal-head h3 { margin: 0; color: var(--navy); font-size: 18px; }
.modal-close {
    width: 36px;
    height: 36px;
    border: 1px solid var(--line);
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: #fff;
    color: var(--navy);
    cursor: pointer;
}
.modal-body { padding: 16px; }
.open-modal-btn { white-space: nowrap; }
.quick-create-modal .modal-panel {
    border-color: rgba(246,166,9,.34);
    box-shadow: 0 32px 88px rgba(2,11,69,.28), 0 0 0 1px rgba(246,166,9,.12);
}
.quick-preset-callout {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 14px;
    padding: 12px;
    border: 1px solid rgba(246,166,9,.35);
    border-radius: 14px;
    background:
        radial-gradient(circle at 12% 0%, rgba(246,166,9,.22), transparent 32%),
        linear-gradient(135deg, rgba(255,250,237,.98), rgba(255,255,255,.94));
    color: var(--navy);
}
.quick-preset-callout > span {
    flex: 0 0 auto;
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #F6A609, #B06B00);
    color: #fff;
    box-shadow: 0 10px 22px rgba(176,107,0,.25);
}
.quick-preset-callout b,
.quick-preset-callout p {
    display: block;
    margin: 0;
}
.quick-preset-callout p {
    margin-top: 2px;
    color: var(--muted);
    line-height: 1.45;
}
.project-create-modal {
    width: min(1024px, 100%);
}
.project-create-flow {
    display: grid;
    gap: 12px;
}
.project-create-section {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: 16px;
    background:
        linear-gradient(rgba(255,255,255,.95), rgba(255,255,255,.95)),
        url("../image/synar-bg-desktop.jpg") top center / 1200px auto fixed;
    padding: 14px;
    box-shadow: 0 12px 28px rgba(2,11,69,.06);
}
.section-kicker {
    display: flex;
    align-items: center;
    gap: 9px;
    margin-bottom: 12px;
}
.section-kicker span {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #F6A609, #B06B00);
    color: #fff;
    font-weight: 950;
    box-shadow: 0 8px 18px rgba(176,107,0,.22);
}
.section-kicker b {
    color: var(--navy);
    font-size: 14px;
}
.section-kicker small {
    color: var(--muted);
    font-size: 12px;
    margin-left: auto;
}
.inline-create-input {
    margin-top: 8px;
    background: rgba(246,250,255,.88);
}
.inline-create-field[hidden] {
    display: none;
}
.upload-drop {
    min-height: 118px;
    border: 1px dashed rgba(18,58,131,.22);
    border-radius: 14px;
    background: rgba(247,249,254,.82);
    display: grid;
    place-items: center;
    align-content: center;
    gap: 6px;
    text-align: center;
    cursor: pointer;
    color: var(--muted);
    transition: border-color .16s ease, background .16s ease, transform .16s ease;
}
.upload-drop:hover {
    border-color: rgba(246,166,9,.55);
    background: rgba(255,250,237,.92);
    transform: translateY(-1px);
}
.upload-drop .icon {
    width: 30px;
    height: 30px;
    color: var(--navy);
}
.upload-drop span {
    color: var(--navy);
    font-weight: 850;
}
.upload-drop small {
    font-size: 12px;
}
.upload-drop input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.compact-upload {
    min-height: 96px;
}
.sop-auto-preview {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    margin-top: 12px;
}
.sop-auto-preview span {
    border: 1px solid rgba(246,166,9,.34);
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(246,166,9,.14), rgba(255,255,255,.92));
    color: var(--navy);
    padding: 8px 10px;
    font-size: 12px;
    font-weight: 900;
    text-align: center;
}
.project-create-note {
    margin: 12px 0 0;
}
.workspace-sop-starter {
    margin-bottom: 14px;
    border-color: rgba(211, 6, 36, .12);
}
.quickstart-form.compact {
    grid-template-columns: minmax(220px, 1.2fr) minmax(180px, .8fr) auto;
}
.finance-payment-mini {
    border: 1px solid rgba(246,166,9,.26);
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(246,166,9,.12), rgba(255,255,255,.96));
    padding: 10px 12px;
}
.finance-payment-mini b {
    display: block;
    color: var(--navy);
}
.finance-payment-mini span {
    display: block;
    color: var(--muted);
    font-size: 12px;
    margin-top: 2px;
}
.directory-guide {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.directory-guide-item {
    border: 1px solid rgba(18,58,131,.12);
    border-radius: 12px;
    background: rgba(255,255,255,.86);
    padding: 12px;
}
.directory-guide-item b,
.directory-card b {
    color: var(--navy);
}
.directory-guide-item span,
.directory-card small,
.directory-meta,
.directory-stats {
    color: var(--muted);
    font-size: 12px;
}
.directory-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 12px;
    margin-top: 14px;
}
.directory-card {
    padding: 14px;
}
.directory-contact-list {
    display: grid;
    gap: 5px;
    margin-top: 10px;
    border-top: 1px solid var(--line);
    padding-top: 10px;
    color: var(--muted);
    font-size: 12px;
}
.directory-contact-list b {
    color: var(--navy);
}
.directory-card-head {
    display: flex;
    align-items: center;
    gap: 10px;
}
.directory-meta,
.directory-stats {
    display: grid;
    gap: 4px;
    margin-top: 12px;
}
.directory-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.directory-stats span {
    border-radius: 999px;
    background: rgba(246,166,9,.12);
    color: var(--navy);
    padding: 6px 8px;
    font-weight: 800;
    text-align: center;
}
.modal-action-bar {
    position: sticky;
    bottom: -16px;
    z-index: 2;
    margin: 14px -16px -16px;
    padding: 12px 16px;
    border-top: 1px solid rgba(221,228,240,.92);
    background: rgba(255,255,255,.94);
    backdrop-filter: blur(14px);
    display: flex;
    justify-content: flex-end;
}
.mobile-filter-trigger { display: none; }
.workflow-card-grid {
    display: none;
    gap: 10px;
    margin-top: 12px;
}
.workflow-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    box-shadow: 0 10px 22px rgba(2,11,69,.06);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.workflow-card:hover {
    transform: translateY(-1px);
    border-color: rgba(18,58,131,.22);
    box-shadow: 0 14px 30px rgba(2,11,69,.09);
}
.workflow-card h4 { margin: 0; color: var(--navy); font-size: 15px; }
.workflow-card .btn { width: 100%; margin-top: 10px; }
.project-thumb-card {
    overflow: hidden;
    padding: 0;
}
.project-thumb {
    position: relative;
    min-height: 132px;
    background: var(--navy);
}
.sample-data-badge {
    position: absolute;
    right: 10px;
    top: 10px;
    z-index: 3;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    border: 1px solid rgba(255,255,255,.45);
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(246,166,9,.96), rgba(190,104,0,.96));
    color: #fff;
    padding: 6px 9px;
    font-size: 11px;
    font-weight: 950;
    box-shadow: 0 10px 24px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.24);
}
.sample-data-badge .icon {
    width: 13px;
    height: 13px;
}
.sample-data-badge.inline {
    position: static;
    flex: 0 0 auto;
}
.workspace-title-row {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.workspace-title-row h2 {
    margin: 0;
}
.project-thumb img {
    width: 100%;
    height: 150px;
    object-fit: cover;
    display: block;
}
.project-thumb:after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent, rgba(2,11,69,.72));
}
.project-thumb-label {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 10px;
    z-index: 1;
    color: #fff;
    display: flex;
    justify-content: space-between;
    gap: 8px;
    align-items: end;
}
.project-thumb-label b,
.project-thumb-label small { display: block; }
.project-thumb-label small { color: rgba(255,255,255,.78); font-weight: 800; margin-top: 2px; }
.project-thumb-body { padding: 12px; display: grid; gap: 9px; }
.project-thumb-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.project-thumb-meta span {
    border-radius: 999px;
    background: var(--pale);
    color: var(--muted);
    padding: 4px 7px;
    font-size: 11px;
    font-weight: 850;
}
.project-sop-progress {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 5px 8px;
    align-items: center;
    border-top: 1px solid var(--line);
    padding-top: 8px;
}
.project-sop-progress span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 850;
}
.project-sop-progress strong {
    color: var(--navy);
    font-size: 12px;
}
.project-sop-progress .progress-line {
    grid-column: 1 / -1;
}
.visual-tile-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}
.visual-tile {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: rgba(255,255,255,.95);
    padding: 12px;
    min-height: 96px;
    display: grid;
    gap: 7px;
    box-shadow: 0 10px 22px rgba(2,11,69,.06);
}
.visual-tile .kpi-icon { width: 34px; height: 34px; }
.visual-tile b { color: var(--navy); font-size: 22px; line-height: 1; }
.visual-tile span { color: var(--muted); font-weight: 800; font-size: 12px; }
.visual-tile.tone-red { border-color: rgba(211,6,36,.18); background: linear-gradient(135deg, #fff, #FFF6F6); }
.visual-tile.tone-amber,
.visual-tile.tone-orange { border-color: rgba(246,166,9,.24); background: linear-gradient(135deg, #fff, #FFF9EA); }
.visual-tile.tone-green { border-color: rgba(24,167,123,.18); background: linear-gradient(135deg, #fff, #F0FBF7); }
.visual-tile.tone-blue { border-color: rgba(18,58,131,.18); background: linear-gradient(135deg, #fff, #F4F8FF); }
.role-workbench {
    display: grid;
    grid-template-columns: minmax(260px, .56fr) minmax(420px, 1fr);
    gap: 12px;
    align-items: stretch;
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.13), transparent 22%),
        rgba(255,255,255,.94);
    box-shadow: 0 14px 34px rgba(2,11,69,.07);
    padding: 14px;
}
.role-workbench-copy {
    border-radius: var(--radius);
    background: linear-gradient(135deg, rgba(2,11,69,.96), rgba(18,58,131,.92));
    color: #fff;
    padding: 14px;
    display: grid;
    align-content: center;
    min-height: 126px;
    position: relative;
    overflow: hidden;
}
.role-workbench-copy:after {
    content: "";
    position: absolute;
    right: -24%;
    bottom: -38%;
    width: 70%;
    height: 70%;
    border-radius: 999px;
    border: 1px solid rgba(246,166,9,.32);
}
.role-workbench-copy .eyebrow {
    color: #F6D77F;
    background: rgba(246,166,9,.14);
    width: fit-content;
}
.role-workbench-copy h3 {
    margin: 9px 0 5px;
    font-size: 20px;
}
.role-workbench-copy p {
    margin: 0;
    color: rgba(255,255,255,.78);
    line-height: 1.45;
}
.role-workbench-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}
.first-login-workbench {
    grid-template-columns: minmax(260px, .48fr) minmax(360px, .92fr);
}
.first-login-workbench .role-workbench-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}
.first-login-workbench .workbench-card {
    min-height: 112px;
}
.first-login-workbench .workbench-card b {
    font-size: 17px;
    line-height: 1.15;
}
.workbench-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    display: grid;
    align-content: space-between;
    gap: 13px;
    min-height: 126px;
    box-shadow: 0 10px 22px rgba(2,11,69,.05);
    transition: transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.workbench-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 32px rgba(2,11,69,.09);
}
.workbench-card b,
.workbench-card small {
    display: block;
}
.workbench-card b {
    color: var(--navy);
    font-size: 24px;
    line-height: 1;
}
.workbench-card small {
    color: var(--muted);
    margin-top: 5px;
    font-weight: 850;
}
.workbench-card.tone-red { border-color: rgba(211,6,36,.20); background: linear-gradient(135deg, #fff, #FFF4F6); }
.workbench-card.tone-amber,
.workbench-card.tone-orange { border-color: rgba(246,166,9,.28); background: linear-gradient(135deg, #fff, #FFF8E8); }
.workbench-card.tone-green { border-color: rgba(24,167,123,.20); background: linear-gradient(135deg, #fff, #F0FBF7); }
.workbench-card.tone-blue { border-color: rgba(18,58,131,.20); background: linear-gradient(135deg, #fff, #F4F8FF); }
.director-command-center {
    border: 1px solid rgba(221,228,240,.95);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.14), transparent 26%),
        rgba(255,255,255,.96);
    box-shadow: 0 18px 42px rgba(2,11,69,.09);
    padding: 14px;
}
.director-command-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 12px;
}
.director-command-head h3 {
    margin: 8px 0 5px;
    color: var(--navy);
    font-size: 22px;
}
.director-command-head p {
    margin: 0;
    color: var(--muted);
}
.director-command-head p span {
    display: block;
    margin-top: 3px;
    color: #344054;
    font-weight: 800;
}
.director-risk-pill {
    min-width: 132px;
    border-radius: 999px;
    padding: 10px 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    color: #fff;
    font-weight: 950;
    box-shadow: 0 12px 24px rgba(2,11,69,.14);
}
.director-risk-pill.tone-red { background: linear-gradient(135deg, #D30624, #8A0015); }
.director-risk-pill.tone-amber { background: linear-gradient(135deg, #F6A609, #B87300); }
.director-risk-pill.tone-green { background: linear-gradient(135deg, #18A77B, #087459); }
.director-signal-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 9px;
    margin-bottom: 12px;
}
.director-signal {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    padding: 12px;
    background: #fff;
    display: grid;
    gap: 6px;
}
.director-signal span,
.director-signal b,
.director-signal small {
    display: block;
}
.director-signal span {
    color: var(--muted);
    font-weight: 900;
    font-size: 12px;
}
.director-signal b {
    color: var(--navy);
    font-size: 25px;
    line-height: 1;
}
.director-signal small {
    color: #344054;
    font-weight: 750;
}
.director-signal.tone-red { border-color: rgba(211,6,36,.20); background: linear-gradient(135deg, #fff, #FFF4F6); }
.director-signal.tone-amber { border-color: rgba(246,166,9,.28); background: linear-gradient(135deg, #fff, #FFF8E8); }
.director-signal.tone-green { border-color: rgba(24,167,123,.20); background: linear-gradient(135deg, #fff, #F0FBF7); }
.director-analytics-grid,
.report-analytics-grid {
    display: grid;
    grid-template-columns: minmax(420px, 1.12fr) minmax(360px, .88fr);
    gap: 12px;
}
.director-chart-card .chart-frame.large {
    height: 306px;
    min-height: 306px;
}
.empty-analytics-state {
    min-height: 260px;
    border: 1px dashed rgba(148, 163, 184, .7);
    border-radius: 14px;
    background: rgba(248, 250, 252, .86);
    color: var(--muted);
    display: grid;
    place-items: center;
    align-content: center;
    gap: 8px;
    text-align: center;
    padding: 24px;
}
.empty-analytics-state .icon {
    width: 32px;
    height: 32px;
    color: var(--corporate-blue);
}
.empty-analytics-state b {
    color: var(--navy);
    font-size: 16px;
}
.empty-analytics-state span {
    max-width: 420px;
}
.cpm-timeline {
    display: grid;
    gap: 8px;
}
.cpm-timeline-row {
    display: grid;
    grid-template-columns: 82px 1fr 52px;
    gap: 10px;
    align-items: center;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
}
.cpm-timeline-row.is-critical {
    border-color: rgba(211,6,36,.20);
    background: linear-gradient(135deg, #fff, #FFF7F8);
}
.cpm-timeline-row strong {
    color: var(--navy);
    font-size: 13px;
}
.cpm-code b,
.cpm-code span {
    display: block;
}
.cpm-code b {
    color: var(--navy);
    font-weight: 950;
}
.cpm-code span {
    width: fit-content;
    margin-top: 4px;
    border-radius: 999px;
    background: #FFF0F3;
    color: var(--red);
    padding: 4px 7px;
    font-size: 10px;
    font-weight: 950;
}
.cpm-timeline-row > b {
    color: var(--navy);
    justify-self: end;
}
.report-performance-panel {
    margin-bottom: 14px;
    scroll-margin-top: 88px;
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.12), transparent 24%),
        rgba(255,255,255,.95);
}
.director-report-pack {
    display: grid;
    grid-template-columns: minmax(240px, .7fr) minmax(420px, 1.2fr) minmax(260px, .72fr);
    gap: 10px;
    align-items: stretch;
    margin-bottom: 14px;
    border: 1px solid rgba(246,166,9,.28);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.14), transparent 28%),
        rgba(255,255,255,.95);
    padding: 12px;
    box-shadow: 0 16px 36px rgba(2,11,69,.07);
}
.director-report-copy {
    display: grid;
    align-content: center;
    gap: 6px;
    padding: 10px;
}
.director-report-copy h3 {
    margin: 0;
    color: var(--navy);
    font-size: 20px;
}
.director-report-copy p {
    margin: 0;
    color: var(--muted);
    font-weight: 750;
    line-height: 1.45;
}
.director-report-signals {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(128px, 1fr));
    gap: 8px;
}
.director-report-signals .report-signal {
    min-height: 126px;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.director-report-signals .report-signal:hover {
    transform: translateY(-2px);
    border-color: rgba(211,6,36,.28);
    box-shadow: 0 16px 34px rgba(2,11,69,.10);
}
.director-report-steps {
    display: grid;
    gap: 8px;
}
.director-report-steps div {
    display: grid;
    grid-template-columns: 34px 1fr;
    gap: 4px 9px;
    align-items: center;
    min-height: 70px;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 9px;
}
.director-report-steps div.is-hot {
    border-color: rgba(211,6,36,.20);
    background: linear-gradient(135deg, #fff, #FFF5F7);
}
.director-report-steps span {
    grid-row: span 2;
    width: 32px;
    height: 32px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--gold), #C87900);
    color: #fff;
    font-weight: 950;
}
.director-report-steps b {
    color: var(--navy);
    line-height: 1.1;
}
.director-report-steps small {
    color: var(--muted);
    font-weight: 750;
    line-height: 1.35;
}
.report-department-pulse {
    margin-bottom: 14px;
    border: 1px solid rgba(221,228,240,.92);
    border-radius: var(--radius-lg);
    background:
        radial-gradient(circle at 4% 0, rgba(211,6,36,.07), transparent 28%),
        rgba(255,255,255,.95);
    padding: 12px;
    box-shadow: 0 16px 36px rgba(2,11,69,.06);
}
.report-department-pulse .card-head {
    margin-bottom: 10px;
}
.report-department-pulse h3 {
    margin: 4px 0 0;
    color: var(--navy);
    font-size: 20px;
}
.department-pulse-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 9px;
}
.department-pulse-card {
    min-height: 132px;
    display: grid;
    grid-template-columns: 38px 1fr;
    gap: 8px;
    align-content: start;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    color: var(--navy);
    padding: 10px;
    text-decoration: none;
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.department-pulse-card:hover {
    transform: translateY(-2px);
    border-color: rgba(246,166,9,.45);
    box-shadow: 0 16px 32px rgba(2,11,69,.09);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.10), transparent 32%),
        #fff;
}
.department-pulse-card .pulse-icon {
    width: 38px;
    height: 38px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    background: rgba(211,6,36,.08);
    color: var(--red);
}
.department-pulse-card .pulse-icon .icon {
    width: 19px;
    height: 19px;
}
.department-pulse-card b {
    display: block;
    font-size: 26px;
    line-height: 1;
    color: var(--navy);
}
.department-pulse-card small {
    display: block;
    margin-top: 2px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
}
.department-pulse-card strong {
    grid-column: 1 / -1;
    font-size: 13px;
    line-height: 1.15;
}
.department-pulse-card p {
    grid-column: 1 / -1;
    margin: 0;
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    line-height: 1.28;
}
.department-pulse-card.tone-red .pulse-icon { background: rgba(211,6,36,.10); color: var(--red); }
.department-pulse-card.tone-amber .pulse-icon { background: rgba(246,166,9,.16); color: #A15C00; }
.department-pulse-card.tone-green .pulse-icon { background: rgba(24,167,123,.12); color: var(--green); }
.department-pulse-card.tone-blue .pulse-icon { background: rgba(29,116,184,.12); color: var(--blue); }
.report-performance-grid,
.report-card-grid {
    display: grid;
    gap: 10px;
}
.performance-selector {
    display: grid;
    grid-template-columns: auto minmax(150px, .8fr) minmax(150px, .8fr) minmax(260px, 1.35fr) auto;
    align-items: center;
    gap: 8px;
    margin: 12px 0;
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 10px;
}
.performance-selector label {
    color: var(--navy);
    font-weight: 950;
}
.project-chip-row {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-bottom: 12px;
}
.director-quick-read {
    display: grid;
    grid-template-columns: minmax(260px, .9fr) minmax(360px, 1.05fr) minmax(240px, .75fr);
    gap: 10px;
    align-items: stretch;
    border: 1px solid rgba(246,166,9,.30);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.14), transparent 30%),
        rgba(255,255,255,.98);
    padding: 10px;
    margin: 10px 0 12px;
    box-shadow: 0 14px 30px rgba(2,11,69,.06);
}
.quick-read-project,
.quick-read-action,
.read-card {
    border: 1px solid rgba(221,228,240,.92);
    border-radius: 14px;
    background: #fff;
}
.quick-read-project,
.quick-read-action {
    display: grid;
    align-content: center;
    gap: 5px;
    padding: 12px;
}
.quick-read-project h3 {
    margin: 0;
    color: var(--navy);
    font-size: 17px;
    line-height: 1.18;
}
.quick-read-project p,
.quick-read-action small {
    margin: 0;
    color: var(--muted);
    font-weight: 800;
    line-height: 1.35;
}
.quick-read-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
}
.read-card {
    display: grid;
    align-content: center;
    gap: 6px;
    padding: 12px;
    min-height: 86px;
}
.read-card span,
.quick-read-action span {
    color: var(--muted);
    font-size: 10px;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: .02em;
}
.read-card b,
.quick-read-action b {
    color: var(--navy);
    font-size: 23px;
    line-height: 1;
}
.quick-read-action {
    border-color: rgba(24,167,123,.22);
    background: linear-gradient(135deg, #fff, #F0FBF7);
}
.quick-read-action.tone-red {
    border-color: rgba(211,6,36,.20);
    background: linear-gradient(135deg, #fff, #FFF5F7);
}

.director-finance-boundary {
    display: grid;
    grid-template-columns: minmax(230px, .75fr) repeat(3, minmax(0, 1fr));
    gap: 10px;
    align-items: stretch;
    border: 1px solid rgba(246,166,9,.28);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 0 0, rgba(246,166,9,.12), transparent 34%),
        rgba(255,255,255,.96);
    padding: 10px;
    margin: 0 0 12px;
    box-shadow: 0 14px 30px rgba(2,11,69,.055);
}

.director-finance-boundary-copy {
    display: grid;
    align-content: center;
    gap: 5px;
    padding: 10px;
}

.director-finance-boundary-copy h3 {
    margin: 0;
    color: var(--navy);
    font-size: 16px;
    line-height: 1.18;
}

.report-detail-disclosure,
.report-export-library {
    margin-top: 14px;
    margin-bottom: 14px;
    background: rgba(255,255,255,.94);
}
.report-detail-disclosure > summary,
.report-export-library > summary {
    min-height: 58px;
}
.report-detail-disclosure > summary:hover,
.report-export-library > summary:hover {
    border-color: rgba(246,166,9,.45);
    box-shadow: 0 12px 26px rgba(2,11,69,.07);
}
.report-detail-disclosure .grid.two,
.report-export-library .report-card-grid {
    margin-top: 10px;
}
.report-performance-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 12px;
}
.report-card-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.report-signal,
.report-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    display: grid;
    gap: 8px;
    box-shadow: 0 10px 22px rgba(2,11,69,.05);
}
.report-signal .icon {
    color: var(--red);
}
.report-signal b,
.report-signal span,
.report-card b,
.report-card small {
    display: block;
}
.report-signal b,
.report-card b {
    color: var(--navy);
    font-size: 26px;
    line-height: 1;
}
.report-signal span,
.report-card small {
    color: var(--muted);
    font-weight: 800;
    line-height: 1.4;
}
.report-card .btn {
    margin-top: auto;
    width: 100%;
}
.report-signal.tone-red { border-color: rgba(211,6,36,.18); background: linear-gradient(135deg, #fff, #FFF4F6); }
.report-signal.tone-amber { border-color: rgba(246,166,9,.28); background: linear-gradient(135deg, #fff, #FFF8E8); }
.report-signal.tone-green { border-color: rgba(24,167,123,.20); background: linear-gradient(135deg, #fff, #F0FBF7); }
.report-signal.tone-blue { border-color: rgba(18,58,131,.20); background: linear-gradient(135deg, #fff, #F4F8FF); }
.performance-entry-panel {
    margin-top: 14px;
    border: 1px solid rgba(246,166,9,.30);
    border-radius: var(--radius);
    background:
        radial-gradient(circle at 6% 0%, rgba(246,166,9,.14), transparent 30%),
        rgba(255,255,255,.94);
    padding: 12px;
}
.performance-entry-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 10px;
}
.performance-entry-card {
    border: 1px solid var(--line);
    border-radius: var(--radius);
    background: #fff;
    padding: 12px;
    box-shadow: 0 12px 30px rgba(2,11,69,.07);
}
.entry-card-head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
}
.entry-card-head .icon {
    width: 38px;
    height: 38px;
    padding: 9px;
    border-radius: 999px;
    color: var(--red);
    background: linear-gradient(135deg, rgba(246,166,9,.18), rgba(255,255,255,.95));
    border: 1px solid rgba(246,166,9,.30);
}
.entry-card-head b,
.entry-card-head small {
    display: block;
}
.entry-card-head b {
    color: var(--navy);
}
.entry-card-head small {
    color: var(--muted);
    font-size: 12px;
}
.form-grid.compact {
    gap: 9px;
}
.form-grid.compact .field {
    margin-bottom: 0;
}

.staff-panel {
    margin-top: 16px;
}

.staff-access-summary {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 10px;
}

.staff-access-summary > div {
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr);
    align-items: center;
    gap: 10px;
    border: 1px solid var(--border);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255, 255, 255, .96), rgba(255, 248, 230, .72));
    padding: 10px;
    min-height: 68px;
}

.staff-access-summary span {
    width: 38px;
    height: 38px;
    border-radius: 13px;
    display: grid;
    place-items: center;
    color: var(--red);
    background: rgba(255, 241, 204, .92);
    border: 1px solid rgba(226, 166, 52, .38);
}

.staff-access-summary b,
.staff-access-summary small {
    display: block;
}

.staff-access-summary b {
    color: var(--navy);
    font-size: 22px;
    line-height: 1;
}

.staff-access-summary small {
    color: var(--muted);
    font-size: 12px;
    font-weight: 750;
}

.staff-activation-guard {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    border: 1px solid rgba(226, 166, 52, .32);
    border-radius: 14px;
    background: rgba(255, 248, 230, .62);
    padding: 10px;
    margin-bottom: 12px;
}

.staff-activation-guard > div {
    display: grid;
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 8px;
    align-items: start;
}

.staff-activation-guard span {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: var(--gold);
    color: #fff;
    font-size: 12px;
    font-weight: 900;
}

.staff-activation-guard b,
.staff-activation-guard small {
    display: block;
}

.staff-activation-guard b {
    color: var(--navy);
    font-size: 12px;
}

.staff-activation-guard small {
    color: var(--muted);
    font-size: 11px;
    line-height: 1.35;
}

.staff-list-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 10px;
    margin: 2px 0 8px;
}

.staff-list-head b {
    color: var(--navy);
}

.staff-list-head span {
    color: var(--muted);
    font-size: 12px;
}

.staff-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 10px;
    max-height: 460px;
    overflow: auto;
    padding-right: 2px;
}

.staff-card {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 10px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: rgba(255, 255, 255, .94);
    padding: 10px;
}

.staff-avatar {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    color: #fff;
    font-weight: 850;
    background: linear-gradient(135deg, var(--navy), var(--red));
    box-shadow: 0 10px 22px rgba(2, 11, 69, .14);
}

.staff-card b,
.staff-card span,
.staff-card small {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.staff-card b {
    color: var(--navy);
    font-size: 13px;
}

.staff-card span,
.staff-card small {
    color: var(--muted);
    font-size: 12px;
}

.staff-panel-callout {
    border: 1px solid rgba(226, 166, 52, .35);
    border-radius: 14px;
    background: rgba(255, 248, 230, .68);
    padding: 11px 12px;
}

.staff-panel-callout b,
.staff-panel-callout span {
    display: block;
}

.staff-panel-callout b {
    color: var(--navy);
    font-size: 13px;
}

.staff-panel-callout span {
    color: var(--muted);
    font-size: 12px;
    line-height: 1.4;
}

@media (max-width: 1100px) {
    body:not(:has(.page-login)) {
        padding-bottom: calc(var(--mobile-nav-height) + var(--mobile-safe-bottom));
    }
    .app-shell { grid-template-columns: 1fr; }
    .sidebar { display: none; }
    .content {
        padding-bottom: calc(26px + var(--mobile-nav-height) + var(--mobile-safe-bottom));
    }
    .grid.kpi { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .module-summary-panel { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .role-action-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .grid.two, .drawer-grid, .pm-visual-grid, .workspace-section-grid, .workspace-command-panel, .workspace-performance-grid, .performance-history-grid { grid-template-columns: 1fr; }
    .task-command-panel { grid-template-columns: 1fr; }
    .role-workbench { grid-template-columns: 1fr; }
    .role-workbench-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .first-login-workbench .role-workbench-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .role-command-panel {
        grid-template-columns: 1fr;
    }
    .role-command-actions {
        justify-content: flex-start;
    }
    .technical-command-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .report-performance-grid,
    .report-card-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .department-pulse-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .director-report-pack { grid-template-columns: 1fr; }
    .director-report-signals { grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)); }
    .director-report-steps { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .director-quick-read { grid-template-columns: 1fr; }
    .quick-read-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .performance-selector { grid-template-columns: 1fr 1fr; }
    .performance-selector label { grid-column: 1 / -1; }
    .performance-selector button { grid-column: 1 / -1; }
    .finance-role-guard {
        grid-template-columns: 1fr;
    }
    .workflow-boundary-guard {
        grid-template-columns: 1fr;
    }
    .workflow-boundary-grid,
    .workflow-boundary-grid.four {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .director-finance-boundary {
        grid-template-columns: 1fr;
    }
    .performance-entry-grid { grid-template-columns: 1fr; }
    .director-analytics-grid,
    .report-analytics-grid { grid-template-columns: 1fr; }
    .director-signal-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .metric-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .lifecycle-rail { grid-template-columns: repeat(6, minmax(148px, 1fr)); }
    .demo-flow-grid { grid-template-columns: 1fr; }
    .walkthrough-role-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .topbar { padding: 0 14px; }
    .global-search { display: none; }
    .guide-chip {
        width: 42px;
        min-width: 42px;
        padding: 8px;
        justify-content: center;
        border-radius: 14px;
    }
    .guide-chip span { display: none; }
    .profile-copy { display: none; }
    .profile-dropdown { right: -6px; width: min(260px, calc(100vw - 24px)); }
    .notification-dropdown {
        position: fixed;
        right: 12px;
        top: 62px;
        width: min(340px, calc(100vw - 24px));
    }
    .mobile-bottom-nav { display: grid; }
    .mobile-menu-fab { display: inline-flex; }
}

@media (max-width: 640px) {
    .staff-access-summary,
    .staff-activation-guard {
        grid-template-columns: 1fr;
    }

    .staff-list-head {
        display: block;
    }

    .staff-grid {
        grid-template-columns: 1fr;
        max-height: 380px;
    }

    .staff-card {
        grid-template-columns: 38px minmax(0, 1fr) auto;
    }

    .staff-card .btn {
        grid-column: 1 / -1;
        justify-content: center;
    }
}

@media (max-width: 1460px) {
    .hero-band {
        grid-template-columns: 1fr;
        align-items: start;
    }
    .project-workspace-hero {
        grid-template-columns: 180px minmax(0, 1fr);
        align-items: center;
        padding: 14px;
        gap: 12px;
    }
    .project-workspace-hero h2 {
        font-size: 24px;
        line-height: 1.1;
    }
    .project-workspace-hero p {
        font-size: 13px;
        line-height: 1.45;
    }
    .project-workspace-hero .workspace-hero-thumb,
    .project-workspace-hero .workspace-hero-thumb img {
        min-height: 108px;
        height: 108px;
    }
    .quick-actions {
        justify-content: flex-start;
    }
}

@media (min-width: 721px) and (max-width: 1100px) {
    .workspace-command-panel {
        grid-template-columns: minmax(0, 1fr) minmax(260px, .48fr);
        align-items: stretch;
    }
    .workspace-command-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .grid.kpi.workspace-kpi-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .workspace-kpi-grid .kpi-card {
        min-height: 122px;
    }
}

@media (max-width: 720px) {
    html,
    body {
        max-width: 100%;
        overflow-x: hidden;
    }
    html:has(.page-login),
    body:has(.page-login) {
        background: #020B45;
        overflow-x: hidden;
        overflow-y: auto;
        width: 100%;
        min-height: 100%;
    }
    .page-login {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        place-items: center;
        min-height: 100dvh;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        position: relative;
        overflow-x: hidden;
        overflow-y: visible;
        box-sizing: border-box;
        padding: 18px 0 24px;
        background-color: #020B45;
        background:
            linear-gradient(180deg, rgba(0,6,46,.22), rgba(0,6,46,.34)),
            url("../image/login-bg.jpg") center center / cover no-repeat;
    }
    .page-login:before,
    .page-login:after {
        content: "";
        position: fixed;
        left: 0;
        width: 100%;
        height: 2px;
        z-index: 0;
        background: linear-gradient(90deg, transparent, rgba(246,166,9,.8), transparent);
        transform: translateX(-110%) rotate(-24deg);
        animation: cyber-scan 7s linear infinite;
        pointer-events: none;
    }
    .page-login:before { top: 22%; }
    .page-login:after { top: 66%; animation-delay: 2.6s; opacity: .66; }
    .login-hero { display: none; }
    .login-hero:before,
    .login-hero:after,
    .login-cyber-lines,
    .login-copy-card,
    .login-footnote {
        display: none;
    }
    .login-logo {
        width: min(260px, 72vw);
        filter: drop-shadow(0 12px 22px rgba(0,0,0,.26));
    }
    .login-panel {
        min-height: auto;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
        padding: 8px 16px 18px;
        align-items: center;
        justify-items: center;
        background: transparent;
        overflow-x: hidden;
    }
    .login-panel:before { display: none; }
    .login-panel > div {
        width: 100% !important;
        max-width: 430px;
        box-sizing: border-box;
    }
    .mobile-brand { display: none; }
    .login-language-switcher {
        display: none;
    }
    .login-card-mobile-logo {
        display: grid;
        place-items: center;
        width: min(286px, 78%);
        margin: 0 auto 16px;
        padding: 0;
        background: transparent;
        border: 0;
    }
    .login-card-mobile-logo img {
        width: 100%;
        height: auto;
        object-fit: contain;
        filter: drop-shadow(0 12px 20px rgba(0,0,0,.24));
    }
    .login-card {
        width: 100%;
        max-width: 100%;
        box-shadow: 0 16px 38px rgba(0,0,0,.20);
        padding: 23px 18px 19px;
        background: rgba(255,255,255,.93);
        backdrop-filter: blur(16px);
        overflow: hidden;
        box-sizing: border-box;
    }
    .login-card .field {
        margin-bottom: 12px;
    }
    .login-card .auth-input-wrap .input {
        min-height: 46px;
    }
    .login-card .auth-input-wrap > .icon,
    .login-card .auth-input-wrap > svg.icon {
        left: 14px;
        top: 50%;
        transform: translateY(-50%);
    }
    .login-card .auth-input-wrap > .input {
        padding-left: 42px;
    }
    .login-card .btn.primary.full {
        margin-top: 10px !important;
    }
    .login-card > h2 {
        font-size: 22px;
        margin-bottom: 5px;
    }
    .login-card > h2,
    .login-card > p {
        text-align: center;
    }
    .login-card > p {
        margin-left: auto;
        margin-right: auto;
        max-width: 32ch;
        margin-bottom: 15px;
        font-size: 13px;
        line-height: 1.35;
    }
    .mobile-login-footnote {
        display: flex;
        width: fit-content;
        max-width: calc(100% - 8px);
        align-items: center;
        justify-content: center;
        margin: 16px auto 8px;
        padding: 8px 11px;
        border-radius: 999px;
        background: linear-gradient(135deg, #F6A609, #C77800);
        color: #fff;
        font-size: 11px;
        font-weight: 900;
        text-align: center;
        text-shadow: 0 1px 2px rgba(0,0,0,.22);
        box-shadow: 0 12px 26px rgba(0,0,0,.20), 0 0 0 4px rgba(246,166,9,.16);
    }
    .demo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
        margin-top: 2px;
    }
    .demo-grid .btn {
        min-height: 43px;
        min-width: 0;
        padding: 7px 6px;
        gap: 6px;
        font-size: 10.5px;
        line-height: 1.12;
        overflow: hidden;
    }
    .demo-grid .btn span:last-child {
        min-width: 0;
        overflow-wrap: anywhere;
    }
    .demo-grid .demo-role-icon {
        width: 28px;
        height: 28px;
        flex-basis: 28px;
    }
    .demo-grid .demo-role-icon img {
        width: 22px;
        height: 22px;
    }
    .profile-self-grid {
        grid-template-columns: 1fr;
    }
    .profile-self-grid > form + form {
        border-left: 0;
        border-top: 1px solid var(--line);
    }
    .content { padding: 14px; }
    .topbar { height: 58px; }
    .page-title h1 { font-size: 16px; }
    body { font-size: 13px; }
    .role-guide-panel.role-guide-tooltip {
        inset: auto 10px calc(84px + env(safe-area-inset-bottom)) 10px;
        width: auto !important;
        max-height: min(72svh, calc(100svh - 108px));
        overflow: auto;
        padding: 12px;
        border-radius: 18px 18px 16px 16px;
    }
    .role-guide-tooltip h3 { font-size: 16px; }
    .role-guide-home {
        grid-template-columns: 1fr;
    }
    .role-guide-current-route {
        display: grid;
        gap: 6px;
    }
    .role-guide-current-route span {
        width: fit-content;
    }
    .role-guide-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .role-guide-actions .btn.small {
        width: 100%;
        justify-content: center;
    }
    .role-guide-actions a.btn.small {
        grid-column: 1 / -1;
    }
    .role-guide-journey-rail {
        max-height: 132px;
    }
    .role-guide-prompt {
        inset: auto 12px calc(86px + env(safe-area-inset-bottom)) 12px;
        width: auto;
        padding: 13px;
    }
    .role-guide-prompt-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }
    .role-guide-prompt-actions .btn.small {
        width: 100%;
        justify-content: center;
    }
    .language-switcher { display: none; }
    .user-chip span { display: none; }
    .hero-band, .project-workspace-hero { grid-template-columns: 1fr; padding: 14px; }
    .workspace-hero-thumb { min-height: 108px; }
    .workspace-hero-thumb img { height: 108px; }
    .thumb-upload-chip {
        left: 8px;
        right: auto;
        width: fit-content;
        padding: 0 10px;
    }
    .hero-band h2 { font-size: 21px; }
    .quick-actions { justify-content: flex-start; }
    .task-reflection-chip,
    .task-modal-reflection,
    .workspace-reflection-chip {
        padding: 8px;
        font-size: 11px;
        line-height: 1.3;
    }
    .quick-actions .btn { flex: 1 1 calc(50% - 8px); min-width: 0; }
    .role-action-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; }
    .role-action-card { min-height: 78px; padding: 10px; }
    .role-action-card span { width: 32px; height: 32px; }
    .role-action-card small { display: none; }
    .grid.kpi { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
    .grid.kpi.workspace-kpi-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .grid.three.project-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }
    .project-card-grid .project-thumb {
        min-height: 96px;
    }
    .project-card-grid .project-thumb img {
        height: 108px;
    }
    .project-card-grid .project-thumb-label {
        left: 9px;
        right: 9px;
        bottom: 8px;
        align-items: flex-end;
    }
    .project-card-grid .project-thumb-label b {
        font-size: 12px;
        line-height: 1.1;
    }
    .project-card-grid .project-thumb-label small,
    .project-card-grid .project-thumb-label .status-badge {
        font-size: 10px;
    }
    .project-card-grid .sample-data-badge {
        padding: 4px 7px;
        font-size: 10px;
    }
    .project-card-grid .project-thumb-body {
        padding: 9px;
        gap: 7px;
    }
    .project-card-grid .project-thumb-body > b {
        font-size: 13px;
        line-height: 1.18;
        min-height: 31px;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .project-card-grid .project-thumb-meta span:nth-child(n+3),
    .project-card-grid .project-sop-progress,
    .project-card-grid .project-next-action span {
        display: none;
    }
    .project-card-grid .project-thumb-meta {
        gap: 4px;
    }
    .project-card-grid .project-thumb-meta span {
        font-size: 10px;
        padding: 3px 6px;
    }
    .project-card-grid .project-next-action {
        padding: 8px;
        min-height: 42px;
    }
    .project-card-grid .project-next-action b {
        font-size: 11px;
        line-height: 1.18;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .project-card-grid .project-open-workspace {
        min-height: 38px;
        padding: 8px;
        font-size: 11px;
    }
    .module-summary-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .kpi-card { min-height: 104px; padding: 12px; }
    .kpi-card b { font-size: 24px; }
    .section-heading { align-items: flex-start; flex-direction: column; }
    .section-heading h3 { font-size: 17px; }
    .role-flow-card { padding: 12px; }
    .role-flow-head { align-items: flex-start; }
    .role-flow-head .btn { display: none; }
    .role-flow-strip { grid-template-columns: repeat(5, minmax(92px, 1fr)); gap: 16px; }
    .role-flow-step { min-height: 82px; }
    .role-flow-step span { width: 34px; height: 34px; }
    .role-flow-step b { font-size: 12px; }
    .metric-strip { gap: 8px; }
    .task-command-panel {
        padding: 12px;
        gap: 10px;
    }
    .task-hub-focus {
        min-height: auto;
    }
    .task-hub-focus h2 {
        font-size: 20px;
        line-height: 1.12;
    }
    .task-hub-actions .btn {
        flex: 1 1 100%;
        min-height: 42px;
    }
    .task-role-chip {
        grid-template-columns: 36px 1fr;
        padding: 9px;
    }
    .task-role-chip .icon {
        width: 36px;
        height: 36px;
        padding: 8px;
    }
    .task-role-chip span {
        font-size: 11px;
        line-height: 1.25;
    }
    .task-flow-mini {
        padding: 9px;
    }
    .task-flow-head {
        margin-bottom: 7px;
        font-size: 10px;
    }
    .task-flow-steps {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 6px;
    }
    .task-flow-arrow {
        display: none;
    }
    .task-flow-step {
        min-height: 46px;
        padding: 7px 5px;
        font-size: 10px;
        line-height: 1.18;
    }
    .task-command-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .task-command-tile {
        min-height: 68px;
        border-radius: 14px;
        padding: 9px 7px;
    }
    .task-command-tile .icon { width: 18px; height: 18px; }
    .task-command-tile b {
        font-size: 19px;
    }
    .task-command-tile span {
        font-size: 10px;
        line-height: 1.1;
    }
    .task-strip {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .task-strip .tabs {
        margin: 0 -2px;
    }
    .task-filter-button {
        width: 100%;
        justify-content: center;
    }
    .role-workbench {
        padding: 10px;
        gap: 9px;
    }
    .role-workbench-copy {
        min-height: auto;
        padding: 12px;
    }
    .role-workbench-copy h3 { font-size: 17px; }
    .role-workbench-copy p { font-size: 12px; }
    .role-workbench-grid { gap: 8px; }
    .first-login-workbench .role-workbench-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .workbench-card {
        min-height: 82px;
        padding: 10px;
        gap: 8px;
    }
    .workbench-card .kpi-icon {
        width: 32px;
        height: 32px;
    }
    .workbench-card b { font-size: 17px; line-height: 1.12; }
    .workbench-card small { font-size: 11px; }
    .report-performance-grid,
    .report-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .performance-selector {
        grid-template-columns: 1fr;
        padding: 9px;
        gap: 7px;
    }
    .performance-selector label,
    .performance-selector button {
        grid-column: auto;
    }
    .director-quick-read {
        grid-template-columns: 1fr;
        padding: 9px;
        gap: 8px;
    }
    .quick-read-project,
    .quick-read-action,
    .read-card {
        padding: 10px;
    }
    .quick-read-project h3 {
        font-size: 15px;
    }
    .quick-read-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .finance-role-guard-grid,
    .workflow-boundary-grid,
    .workflow-boundary-grid.four,
    .director-finance-boundary {
        display: grid;
        grid-template-columns: repeat(3, minmax(172px, 1fr));
        overflow-x: auto;
        padding-bottom: 4px;
    }
    .workflow-boundary-copy {
        position: sticky;
        left: 0;
        background: rgba(255,255,255,.96);
        border-radius: 12px;
        z-index: 1;
        padding: 8px;
    }
    .director-finance-boundary-copy {
        grid-column: 1 / -1;
        position: sticky;
        left: 0;
        background: rgba(255,255,255,.96);
        border-radius: 12px;
        z-index: 1;
    }
    .read-card {
        min-height: 72px;
    }
    .read-card b,
    .quick-read-action b {
        font-size: 20px;
    }
    .report-department-pulse {
        padding: 10px;
    }
    .report-department-pulse h3 {
        font-size: 17px;
    }
    .department-pulse-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .department-pulse-card {
        min-height: 112px;
        padding: 9px;
        grid-template-columns: 32px 1fr;
    }
    .department-pulse-card .pulse-icon {
        width: 32px;
        height: 32px;
        border-radius: 12px;
    }
    .department-pulse-card b {
        font-size: 22px;
    }
    .department-pulse-card p {
        display: none;
    }
    .director-report-pack {
        padding: 10px;
        gap: 9px;
    }
    .director-report-copy {
        padding: 4px;
    }
    .director-report-copy h3 {
        font-size: 17px;
    }
    .director-report-copy p {
        font-size: 12px;
    }
    .director-report-signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .director-report-signals .report-signal {
        min-height: 108px;
    }
    .director-report-steps {
        grid-template-columns: 1fr;
    }
    .director-report-steps div {
        min-height: 60px;
    }
    .role-command-panel {
        padding: 10px;
        gap: 9px;
    }
    .role-command-main {
        grid-template-columns: 36px 1fr;
    }
    .role-command-main h3 {
        font-size: 16px;
    }
    .role-command-main p {
        font-size: 12px;
    }
    .role-command-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .role-command-actions .btn {
        width: 100%;
        min-height: 42px;
        padding: 8px;
    }
    .role-command-actions .btn:first-child:last-child {
        grid-column: 1 / -1;
    }
    .role-command-stats {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .phase-focus-board {
        grid-template-columns: 1fr;
        padding: 10px;
        gap: 10px;
    }
    .phase-focus-main {
        grid-template-columns: 36px 1fr;
    }
    .phase-focus-main h3 {
        font-size: 16px;
    }
    .phase-focus-main p {
        font-size: 12px;
    }
    .phase-focus-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .phase-focus-metrics a {
        min-height: 62px;
        padding: 9px;
    }
    .phase-focus-metrics b {
        font-size: 20px;
    }
    .role-lane-grid,
    .handover-lane-board .role-lane-grid,
    .procurement-lane-board .role-lane-grid,
    .site-lane-board .role-lane-grid,
    .admin-lane-board .role-lane-grid,
    .finance-lane-board .role-lane-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .role-lane-card {
        min-height: 112px;
        padding: 10px;
        grid-template-columns: 34px 1fr auto;
    }
    .role-lane-card span {
        width: 32px;
        height: 32px;
    }
    .role-lane-card strong {
        font-size: 20px;
    }
    .role-lane-card small {
        font-size: 11px;
    }
    .finance-ownership-strip {
        grid-template-columns: repeat(4, minmax(118px, 1fr));
        overflow-x: auto;
        gap: 7px;
        padding: 8px;
    }
    .finance-ownership-strip .flow-arrow {
        display: none;
    }
    .finance-ownership-strip div {
        min-height: 74px;
        padding: 9px;
    }
    .finance-ownership-strip small {
        font-size: 10px;
    }
    .project-phase-panel {
        width: calc(100vw - 18px);
        max-height: 88vh;
        border-radius: 18px;
    }
    .project-phase-body {
        max-height: calc(88vh - 88px);
    }
    .project-phase-layout {
        grid-template-columns: 1fr;
        padding: 10px;
    }
    .project-phase-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .phase-card {
        min-height: 96px;
    }
    .phase-card b {
        justify-self: start;
    }
    .phase-task-list a,
    .phase-detail-head,
    .phase-project-card summary {
        grid-template-columns: 1fr;
    }
    .technical-command-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .technical-command-card {
        min-height: 94px;
        padding: 10px;
    }
    .synar-pagination {
        display: grid;
        gap: 8px;
    }
    .pagination-controls {
        justify-content: center;
    }
    .pagination-summary {
        text-align: center;
    }
    .director-command-center {
        padding: 10px;
    }
    .director-command-head {
        display: grid;
        gap: 9px;
    }
    .director-command-head h3 {
        font-size: 18px;
    }
    .director-risk-pill {
        width: fit-content;
        min-width: 0;
        padding: 8px 10px;
    }
    .director-signal-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .director-signal {
        padding: 10px;
    }
    .director-signal b {
        font-size: 21px;
    }
    .director-chart-card .chart-frame.large {
        height: 220px;
        min-height: 220px;
    }
    .performance-selector {
        grid-template-columns: 1fr;
    }
    .cpm-timeline-row {
        grid-template-columns: 58px 1fr 42px;
        gap: 8px;
        padding: 9px;
    }
    .cpm-timeline-row strong {
        font-size: 12px;
    }
    .report-signal,
    .report-card {
        padding: 10px;
    }
    .report-signal b,
    .report-card b {
        font-size: 21px;
    }
    .task-command-tile { min-height: 68px; }
    .workspace-command-metrics {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 7px;
    }
    .workspace-command-side {
        gap: 8px;
        align-self: stretch;
    }
    .workspace-command-metrics a {
        grid-template-columns: 1fr;
        justify-items: start;
        min-height: 74px;
        padding: 9px;
    }
    .workspace-command-metrics .icon {
        width: 28px;
        height: 28px;
        padding: 7px;
        border-radius: 10px;
    }
    .workspace-command-metrics b {
        font-size: 20px;
    }
    .workspace-command-metrics small {
        font-size: 10px;
    }
    .workspace-next-actions {
        display: none;
    }
    .phase-modal-flow {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
    }
    .phase-claim-path {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 7px;
        padding: 7px;
    }
    .phase-claim-path span {
        min-height: 72px;
        padding: 8px;
    }
    .phase-claim-path b {
        font-size: 11px;
    }
    .phase-claim-path small {
        font-size: 10px;
    }
    .phase-modal-flow span {
        min-height: 66px;
        padding: 9px;
    }
    .phase-modal-section-title,
    .phase-modal-group > summary {
        align-items: flex-start;
        gap: 7px;
    }
    .phase-modal-section-title span,
    .phase-modal-group > summary span {
        min-width: 0;
        font-size: 12px;
        line-height: 1.25;
    }
    .phase-modal-section-title small,
    .phase-modal-group > summary small,
    .phase-modal-group > summary:after {
        padding: 4px 7px;
        font-size: 10px;
    }
    .project-action-strip {
        position: sticky;
        top: 58px;
        z-index: 18;
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: minmax(72px, 1fr);
        gap: 7px;
        overflow-x: auto;
        margin: -2px 0 10px;
        padding: 8px;
        border: 1px solid rgba(221,228,240,.82);
        border-radius: 16px;
        background: rgba(255,255,255,.94);
        box-shadow: 0 14px 30px rgba(2,11,69,.10);
        backdrop-filter: blur(14px);
    }
    .project-action-strip a,
    .project-action-strip button {
        min-height: 58px;
        border: 1px solid rgba(18,58,131,.12);
        border-radius: 13px;
        background: #fff;
        color: var(--navy);
        display: grid;
        place-items: center;
        gap: 3px;
        padding: 7px 8px;
        font-size: 11px;
        font-weight: 950;
        cursor: pointer;
        box-shadow: 0 8px 18px rgba(2,11,69,.06);
    }
    .project-action-strip .project-action-primary-mobile {
        background: linear-gradient(135deg, var(--red), #A80522);
        color: #fff;
        border-color: rgba(211,6,36,.20);
        box-shadow: 0 12px 24px rgba(211,6,36,.22);
    }
    .project-action-strip .project-action-primary-mobile {
        display: grid;
    }
    .project-action-strip .icon {
        width: 18px;
        height: 18px;
    }
    .workspace-sop-board {
        padding: 10px;
    }
    .lifecycle-rail {
        grid-template-columns: repeat(6, minmax(122px, 1fr));
        gap: 7px;
        padding: 7px;
    }
    .lifecycle-step {
        min-width: 122px;
        padding: 9px;
        gap: 6px;
    }
    .phase-task-row,
    .phase-task-actions {
        grid-template-columns: 1fr;
        justify-items: stretch;
    }
    .lifecycle-step small {
        font-size: 10px;
    }
    .workspace-role-focus {
        width: 100%;
        grid-template-columns: 34px 1fr;
        margin-bottom: 10px;
        padding: 8px;
    }
    .workspace-role-focus .icon {
        width: 34px;
        height: 34px;
        padding: 8px;
    }
    .workspace-performance-panel {
        padding: 10px;
    }
    .workspace-performance-panel > .card-head {
        display: grid;
        gap: 9px;
        align-items: start;
    }
    .workspace-performance-signals {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .workspace-compact-details > summary {
        display: grid;
        gap: 4px;
        align-items: start;
        padding: 10px;
    }
    .workspace-compact-details > summary small {
        font-size: 11px;
        line-height: 1.25;
    }
    .workspace-compact-details > .workspace-performance-grid,
    .workspace-compact-details > .performance-update-disclosure,
    .workspace-compact-details > .performance-history-grid {
        margin-left: 8px;
        margin-right: 8px;
    }
    .workspace-section .task-list,
    #overview .task-list,
    #documents .task-list {
        max-height: 248px;
    }
    .project-media-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        max-height: 278px;
    }
    .project-media-thumb img {
        height: 106px;
    }
    .project-media-copy {
        padding: 8px;
    }
    .project-media-copy b {
        font-size: 12px;
    }
    .performance-update-disclosure summary {
        min-height: 44px;
        justify-content: center;
    }
    .performance-history-card {
        padding: 10px;
    }
    .performance-history-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .performance-history-row .btn {
        width: 100%;
    }
    .mobile-menu-quick-actions {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .mobile-menu-quick-actions a {
        min-height: 70px;
        font-size: 10px;
    }
    .metric-tile { min-height: 74px; padding: 10px; gap: 9px; }
    .metric-tile b, .risk-row b { font-size: 20px; }
    .project-health-row { grid-template-columns: 1fr; }
    .project-row-title { align-items: flex-start; }
    .risk-row, .risk-row.stacked { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .template-grid, .security-grid, .sop-coverage-grid, .gate-grid, .role-flow-grid, .walkthrough-role-grid, .walkthrough-evidence-strip, .freeze-sequence-grid, .completion-roadmap-grid, .next-actions-grid, .action-inventory-summary { grid-template-columns: 1fr; }
    .freeze-sequence-head { display: grid; align-items: start; }
    .readiness-accordion > summary {
        display: grid;
        align-items: start;
        min-height: 58px;
        padding: 12px;
    }
    .readiness-accordion > summary:after {
        position: absolute;
        right: 16px;
        margin-top: 4px;
    }
    .readiness-accordion > summary small {
        max-width: none;
        padding-right: 28px;
        text-align: left;
    }
    .readiness-accordion > .grid,
    .readiness-accordion > .card {
        margin-left: 8px;
        margin-right: 8px;
    }
    .action-inventory-grid { max-height: none; overflow: visible; }
    .action-inventory-row { grid-template-columns: 1fr; gap: 8px; }
    .gate-check { grid-template-columns: 32px 1fr; }
    .gate-check strong { grid-column: 2; justify-self: start; }
    .gate-score { justify-self: start; }
    .flow-card { grid-template-columns: 36px 1fr; }
    .chart-box { min-height: 246px; }
    .chart-box > canvas { height: 190px !important; max-height: 190px; }
    .chart-frame, .chart-frame.large { height: 206px; min-height: 206px; }
    .s-curve-box { height: 220px; }
    .notification-row {
        grid-template-columns: 36px 1fr;
        align-items: start;
    }
    .notification-row .status {
        grid-column: 2;
        justify-self: start;
    }
    .cpm-item { grid-template-columns: 56px 1fr 44px; gap: 8px; }
    .filter-bar { top: 58px; grid-template-columns: 1fr 44px; }
    .filter-bar .select, .filter-bar .filter-check, .filter-bar .btn:not(.filter-submit) { display: none; }
    .mobile-filter-trigger { display: inline-flex; }
    .filter-bar.mobile-sheet-open {
        position: fixed;
        left: 10px;
        right: 10px;
        bottom: calc(var(--mobile-nav-height) + 10px + var(--mobile-safe-bottom));
        top: auto;
        z-index: 56;
        display: grid;
        grid-template-columns: 1fr;
        max-height: 74vh;
        overflow: auto;
        padding: 12px;
        border-radius: 16px;
        background: rgba(255,255,255,.97);
        box-shadow: 0 20px 60px rgba(2,11,69,.22);
    }
    .filter-bar.mobile-sheet-open .select,
    .filter-bar.mobile-sheet-open .filter-check,
    .filter-bar.mobile-sheet-open .btn {
        display: flex;
    }
    .workflow-card-grid { display: grid; }
    .table-wrap.workflow-table-primary { display: none; }
    .workflow-card {
        padding: 11px;
        gap: 7px;
    }
    .workflow-card h4 {
        font-size: 14px;
        line-height: 1.25;
    }
    .workflow-card .task-meta {
        gap: 6px;
        margin-top: 6px;
    }
    .task-card { grid-template-columns: 1fr; }
    .task-card-actions {
        display: flex;
        align-items: center;
        justify-content: space-between;
        min-width: 0;
        width: 100%;
    }
    .task-update-form { grid-template-columns: 1fr 42px; }
    .task-update-form .input { grid-column: 1 / -1; width: 100% !important; }
    .task-update-form .select { width: 100% !important; }
    .modal-backdrop.open { align-items: end; padding: 10px; }
    .modal-panel {
        width: 100%;
        max-height: 84vh;
        border-radius: 18px 18px 10px 10px;
    }
    .modal-body {
        padding: 12px;
    }
    .drawer-section {
        padding: 10px;
    }
    .project-create-section {
        padding: 10px;
        border-radius: 14px;
    }
    .section-kicker {
        align-items: flex-start;
    }
    .section-kicker small {
        display: none;
    }
    .sop-auto-preview {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 6px;
    }
    .sop-auto-preview span {
        padding: 7px 8px;
        font-size: 11px;
    }
    .modal-action-bar {
        margin: 12px -12px -12px;
        padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
    }
    .modal-action-bar .btn {
        width: 100%;
    }
    .table-wrap:after { display: inline-flex; }
    .workflow-filter-trigger { display: none; }
    .quickstart-form { grid-template-columns: 1fr; }
    .directory-guide { grid-template-columns: 1fr; }
    .sop-template-chip { flex-basis: 190px; }
    .form-grid { grid-template-columns: 1fr; }
    .form-grid .span-2 { grid-column: auto; }
    .site-supervisor-diary-panel {
        grid-template-columns: 1fr;
        gap: 9px;
        padding: 10px;
    }
    .site-supervisor-copy h3 {
        font-size: 19px;
    }
    .site-supervisor-copy p {
        font-size: 12px;
    }
    .site-supervisor-steps {
        grid-template-columns: repeat(4, minmax(72px, 1fr));
        overflow-x: auto;
        padding-bottom: 1px;
    }
    .site-supervisor-steps div {
        min-height: 76px;
        padding: 8px;
    }
    .site-supervisor-steps .icon {
        margin-bottom: 5px;
    }
    .site-supervisor-status {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
    .site-supervisor-status a {
        padding: 8px 6px;
    }
    .site-diary-form.card-pad { padding: 10px; }
    .site-diary-hero { margin-bottom: 10px !important; }
    .site-diary-hero p { display: none; }
    .site-diary-hero .btn { display: none; }
    .workspace-next-actions { display: none; }
    .site-diary-flow {
        grid-template-columns: repeat(4, minmax(76px, 1fr));
        gap: 7px;
        overflow-x: auto;
        margin-bottom: 10px;
    }
    .site-diary-flow div {
        min-height: 58px;
        padding: 8px 6px;
        flex-direction: column;
        justify-content: center;
        text-align: center;
        gap: 5px;
    }
    .site-diary-flow b { font-size: 11px; }
    .site-diary-form .form-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }
    .site-diary-form .field.span-2,
    .site-diary-form .interruption-card,
    .site-diary-form .mobile-sticky-submit {
        grid-column: 1 / -1;
    }
    .site-diary-form .textarea { min-height: 88px; }
    .worker-stepper input {
        min-height: 46px;
        font-size: 20px;
    }
    .mobile-sticky-submit {
        display: block;
        position: sticky;
        bottom: calc(var(--mobile-nav-height) + 14px + var(--mobile-safe-bottom));
        z-index: 18;
        margin: 4px -4px -4px;
    }
    table { min-width: 760px; }
    .environment-badge {
        display: none;
    }
    .training-hero,
    .training-current-role,
    .training-rule-card {
        grid-template-columns: 1fr;
        padding: 12px;
        gap: 10px;
    }
    .training-hero h2 {
        font-size: 22px;
    }
    .training-hero-actions,
    .training-card-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
    }
    .training-current-role {
        align-items: start;
    }
    .training-action-card {
        width: 100%;
    }
    .training-role-grid,
    .training-info-grid,
    .training-uat-strip,
    .training-evidence-strip {
        grid-template-columns: 1fr;
        gap: 8px;
    }
    .training-info-grid div {
        min-height: auto;
    }
    .training-flow {
        gap: 6px;
    }
    .training-flow span {
        min-height: 30px;
        padding: 6px 8px;
        font-size: 11px;
    }
}

@media (max-width: 359px) {
    .grid.three.project-card-grid {
        grid-template-columns: 1fr;
    }
    .project-card-grid .project-thumb img {
        height: 128px;
    }
    .project-card-grid .project-sop-progress {
        display: grid;
    }
}
