/* DG Group Data Flow — Light Executive Theme v2 */
:root{--bg-primary:#f8f9fc;--bg-secondary:#fff;--bg-subtle:#f1f3f9;--bg-glass:rgba(255,255,255,.88);--accent-purple:#059669;--accent-pink:#ec4899;--accent-teal:#10b981;--accent-amber:#f59e0b;--accent-blue:#3b82f6;--accent-red:#ef4444;--accent-orange:#f97316;--accent-violet:#047857;--text-primary:#1e293b;--text-secondary:#475569;--text-muted:#94a3b8;--border-subtle:#e2e8f0;--border-hover:#cbd5e1;--shadow-sm:0 1px 3px rgba(0,0,0,.05);--shadow-md:0 4px 14px rgba(0,0,0,.06);--shadow-lg:0 10px 36px rgba(0,0,0,.08);--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--fast:150ms cubic-bezier(.4,0,.2,1);--smooth:300ms cubic-bezier(.4,0,.2,1)}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:15px;scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}
.bg-particles{display:none}

/* ── Header ── */
.main-header{position:sticky;top:0;z-index:100;background:var(--bg-glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border-subtle);padding:12px 28px}
.header-content{max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.logo-section{display:flex;align-items:center;gap:12px}
.logo-icon{width:40px;height:40px;border-radius:var(--radius-md);background:linear-gradient(135deg,#ecfdf5,#d1fae5);display:flex;align-items:center;justify-content:center;border:1px solid #a7f3d0}
.logo-section h1{font-size:1.1rem;font-weight:700;color:var(--accent-purple);letter-spacing:-.02em}
.subtitle{font-size:.68rem;color:var(--text-muted);font-weight:400;margin-top:1px}
.header-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.search-box{display:flex;align-items:center;gap:7px;background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:6px 12px;transition:var(--smooth);min-width:180px}
.search-box:focus-within{border-color:var(--accent-purple);box-shadow:0 0 0 3px rgba(5,150,105,.08);background:#fff}
.search-box svg{color:var(--text-muted);flex-shrink:0}
.search-box input{background:none;border:none;outline:none;color:var(--text-primary);font-size:.76rem;font-family:inherit;width:100%}
.search-box input::placeholder{color:var(--text-muted)}
.view-toggles{display:flex;background:var(--bg-subtle);border-radius:var(--radius-md);padding:2px;border:1px solid var(--border-subtle)}
.view-btn{display:flex;align-items:center;gap:5px;padding:5px 11px;border:none;background:none;color:var(--text-muted);font-size:.7rem;font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:var(--fast);font-family:inherit}
.view-btn.active{background:var(--accent-purple);color:#fff;box-shadow:0 1px 4px rgba(5,150,105,.25)}
.view-btn:not(.active):hover{color:var(--text-primary);background:rgba(0,0,0,.03)}
.stats-pills{display:flex;gap:5px}
.pill{padding:3px 9px;border-radius:var(--radius-lg);font-size:.63rem;font-weight:600;white-space:nowrap}
.pill-purple{background:#ecfdf5;color:var(--accent-purple);border:1px solid #a7f3d0}
.pill-teal{background:#ecfdf5;color:var(--accent-teal);border:1px solid #a7f3d0}
.pill-amber{background:#fffbeb;color:#b45309;border:1px solid #fde68a}
.pill-red{background:#fef2f2;color:var(--accent-red);border:1px solid #fecaca}

/* ── Main Content ── */
.main-content{position:relative;z-index:1;padding:24px 28px 80px;max-width:1600px;margin:0 auto}
.view-container{display:none}
.view-container.active{display:block;animation:fadeIn .35s ease-out}
@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
@keyframes cardSlideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ── Executive Summary ── */
.exec-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:10px;margin:16px 0;padding:14px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.exec-stat{text-align:center;padding:8px 6px}
.exec-stat-value{font-size:1.5rem;font-weight:800;letter-spacing:-.03em}
.exec-stat-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-top:2px}

/* ── Pillar Cards ── */
.pillar-section{margin:20px 0}
.pillar-section-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.pillar-section-title::after{content:'';flex:1;height:1px;background:var(--border-subtle)}
.pillar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:8px}
.pillar-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:18px;cursor:pointer;transition:all var(--smooth);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.pillar-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.pillar-card.proposed{border-style:dashed}
.pillar-card-accent{position:absolute;top:0;left:0;right:0;height:3px}
.pillar-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.pillar-card-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pillar-card-title{font-weight:700;font-size:.85rem;color:var(--text-primary)}
.pillar-card-tag{font-size:.55rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:2px 6px;border-radius:20px;margin-left:6px}
.pillar-card-desc{font-size:.72rem;color:var(--text-secondary);line-height:1.5;margin-bottom:10px}
.pillar-card-badge{display:inline-flex;align-items:center;gap:4px;font-size:.58rem;font-weight:600;padding:3px 8px;border-radius:20px}
.badge-live{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}
.badge-proposed{background:#fef2f2;color:#dc2626;border:1px dashed #fca5a5}
.pillar-feeds{margin-top:10px;display:flex;flex-wrap:wrap;gap:4px}
.pillar-feed-chip{font-size:.6rem;padding:2px 7px;border-radius:20px;background:var(--bg-subtle);color:var(--text-secondary);border:1px solid var(--border-subtle)}

/* Board card (top) */
.board-card{background:var(--bg-secondary);border:2px dashed var(--accent-purple);border-radius:var(--radius-xl);padding:20px 28px;text-align:center;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.board-title{font-size:1.2rem;font-weight:800;color:var(--accent-purple);letter-spacing:-.02em}
.board-sub{font-size:.72rem;color:var(--text-secondary);margin-top:3px}

/* Connector */
.v-connector{width:2px;height:24px;background:linear-gradient(to bottom,var(--accent-purple),rgba(5,150,105,.15));margin:0 auto}
.v-connector-down{width:2px;height:20px;background:linear-gradient(to bottom,rgba(5,150,105,.15),var(--border-subtle));margin:0 auto}

/* Arrow label */
.arrow-label{text-align:center;font-size:.58rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin:4px 0;display:flex;align-items:center;justify-content:center;gap:6px}
.arrow-label svg{opacity:.5}

/* ── L1 Dept Chips ── */
.l1-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:6px}
.l1-chip{padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--smooth);text-align:center;box-shadow:var(--shadow-sm);min-width:110px;display:flex;flex-direction:column;align-items:center;gap:4px}
.l1-chip:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.l1-chip.active{border-color:var(--accent-purple);background:#f0fdf4;box-shadow:0 0 0 3px rgba(5,150,105,.08),var(--shadow-md)}
.l1-chip-icon{display:flex;align-items:center;justify-content:center}
.l1-chip-name{font-size:.72rem;font-weight:600;color:var(--text-primary)}
.l1-chip-count{font-size:.57rem;color:var(--text-muted)}
.l1-chip-pillar{font-size:.52rem;font-weight:600;padding:1px 5px;border-radius:20px;margin-top:2px}

/* ── L2 Detail ── */
.l2-detail-area{margin-top:18px;animation:fadeIn .3s ease-out}
.dept-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:14px;margin-top:18px;width:100%}
.dept-card{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--smooth);animation:cardSlideUp .35s ease-out both;box-shadow:var(--shadow-sm)}
.dept-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}
.dept-card.highlight{border-color:var(--accent-amber);box-shadow:0 0 0 3px rgba(245,158,11,.08)}
.dept-card-header{padding:12px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background var(--fast)}
.dept-card-header:hover{background:var(--bg-subtle)}
.dept-card-icon{width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dept-card-info{flex:1;min-width:0}
.dept-card-name{font-weight:600;font-size:.82rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dept-card-meta{font-size:.64rem;color:var(--text-muted);margin-top:1px}
.dept-card-toggle{width:24px;height:24px;border-radius:50%;background:var(--bg-subtle);border:1px solid var(--border-subtle);color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--fast)}
.dept-card-toggle:hover{background:#ecfdf5;color:var(--accent-purple)}
.dept-card-body{max-height:0;overflow:hidden;transition:max-height .4s ease-in-out}
.dept-card-body.open{max-height:4000px}
.dept-card-body-inner{padding:12px 16px}

/* ── Dashboard Links ── */
.dashboard-link{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:var(--radius-md);margin-bottom:7px;cursor:pointer;transition:var(--fast)}
.dashboard-link.live{background:#fffbeb;border:1px solid #fde68a}
.dashboard-link.proposed{background:#fef2f2;border:1px dashed #fca5a5}
.dashboard-link:hover{transform:translateX(3px)}
.dashboard-link.live:hover{background:#fef3c7}
.dashboard-link.proposed:hover{background:#fee2e2}
.dashboard-link-icon{width:30px;height:30px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dashboard-link.live .dashboard-link-icon{background:rgba(245,158,11,.1)}
.dashboard-link.proposed .dashboard-link-icon{background:rgba(239,68,68,.06)}
.dashboard-link-name{font-size:.75rem;font-weight:600}
.dashboard-link.live .dashboard-link-name{color:#92400e}
.dashboard-link.proposed .dashboard-link-name{color:#b91c1c}
.dashboard-link-desc{font-size:.6rem;color:var(--text-muted);margin-top:1px}
.dashboard-status-badge{font-size:.52rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:2px 6px;border-radius:20px;margin-left:auto;flex-shrink:0}

/* Proposed data block */
.proposed-data{margin-top:5px;padding:8px 10px;background:#fafafe;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);font-size:.62rem;color:var(--text-secondary)}
.proposed-data-title{font-weight:700;font-size:.58rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-violet);margin-bottom:4px}
.proposed-data-list{display:flex;flex-wrap:wrap;gap:3px}
.proposed-data-item{padding:2px 6px;background:#dcfce7;color:#15803d;border-radius:20px;font-size:.58rem;font-weight:500}

/* ── KPI List ── */
.section-block{margin-bottom:12px}
.section-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;display:flex;align-items:center;gap:7px}
.section-label::after{content:'';flex:1;height:1px;background:var(--border-subtle)}
.category-header{display:flex;align-items:center;justify-content:space-between;padding:5px 9px;background:var(--bg-subtle);border-radius:var(--radius-sm);margin-bottom:4px}
.category-name{font-size:.68rem;font-weight:600;color:var(--text-primary)}
.category-count{font-size:.55rem;color:var(--text-muted);padding:2px 6px;background:#fff;border-radius:20px;border:1px solid var(--border-subtle)}
.kpi-list{display:flex;flex-direction:column;gap:1px}
.kpi-item{display:flex;align-items:center;gap:7px;padding:5px 9px;border-radius:var(--radius-sm);transition:var(--fast);cursor:default}
.kpi-item:hover{background:#f1f5f9}
.kpi-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.kpi-dot.on-track{background:var(--accent-teal);box-shadow:0 0 4px rgba(16,185,129,.3)}
.kpi-dot.off-track{background:var(--accent-red);box-shadow:0 0 4px rgba(239,68,68,.3)}
.kpi-dot.mixed{background:var(--accent-amber);box-shadow:0 0 4px rgba(245,158,11,.3)}
.kpi-name{font-size:.7rem;color:var(--text-secondary);flex:1;min-width:0}
.kpi-target{font-size:.58rem;color:var(--text-muted);flex-shrink:0}
.kpi-source{font-size:.52rem;color:var(--accent-blue);flex-shrink:0;font-weight:500}

/* ── Scorecard Pills ── */
.scorecard-entities{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.sc-entity-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:20px;font-size:.62rem;font-weight:500;cursor:pointer;transition:var(--fast);border:1px solid var(--border-subtle);background:var(--bg-secondary)}
.sc-entity-pill:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.sc-entity-pill .sc-count{color:var(--text-muted);font-size:.55rem}

/* ── Data Dictionary ── */
.dict-header{margin-bottom:20px}
.dict-header h2{font-size:1.1rem;font-weight:700;color:var(--text-primary)}
.dict-header p{font-size:.78rem;color:var(--text-secondary);margin-top:4px}
.dict-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.dict-filter-btn{padding:5px 12px;border-radius:20px;border:1px solid var(--border-subtle);background:var(--bg-secondary);font-size:.68rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:var(--fast);font-family:inherit}
.dict-filter-btn:hover{border-color:var(--border-hover);background:var(--bg-subtle)}
.dict-filter-btn.active{background:var(--accent-purple);color:#fff;border-color:var(--accent-purple)}
.dict-table{width:100%;border-collapse:separate;border-spacing:0;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
.dict-table thead th{padding:10px 14px;text-align:left;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-subtle);border-bottom:1px solid var(--border-subtle);position:sticky;top:0}
.dict-table tbody tr{transition:background var(--fast)}
.dict-table tbody tr:hover{background:#f8fafc}
.dict-table tbody td{padding:8px 14px;font-size:.72rem;color:var(--text-secondary);border-bottom:1px solid #f1f5f9;vertical-align:middle}
.dict-table tbody tr:last-child td{border-bottom:none}
.dict-dept-badge{padding:2px 7px;border-radius:20px;font-size:.58rem;font-weight:600;white-space:nowrap}
.dict-status-dot{display:inline-flex;align-items:center;gap:4px}

/* ── Sidebar ── */
.detail-sidebar{position:fixed;right:-440px;top:0;width:440px;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);z-index:200;transition:right var(--smooth);overflow-y:auto;box-shadow:var(--shadow-lg)}
.detail-sidebar.open{right:0}
.sidebar-close{position:absolute;top:12px;right:12px;width:30px;height:30px;border-radius:50%;background:var(--bg-subtle);border:1px solid var(--border-subtle);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--fast);z-index:5}
.sidebar-close:hover{background:#fee2e2;color:var(--accent-red)}
.sidebar-content{padding:20px;padding-top:50px}
.sidebar-type{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;display:inline-block;padding:3px 9px;border-radius:20px}
.sidebar-title{font-size:1rem;font-weight:700;margin-bottom:4px}
.sidebar-section{margin-bottom:16px}
.sidebar-section-title{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:7px;padding-bottom:4px;border-bottom:1px solid var(--border-subtle)}
.sidebar-kpi-item{display:flex;align-items:center;gap:7px;padding:7px;border-radius:var(--radius-sm);margin-bottom:2px;background:var(--bg-subtle)}
.sidebar-kpi-name{font-size:.73rem;color:var(--text-primary);font-weight:500}
.sidebar-kpi-meta{font-size:.6rem;color:var(--text-muted);margin-top:1px}
.sidebar-kpi-goal{font-size:.58rem;color:var(--text-muted)}

/* ── Flow Canvas ── */
#flowCanvas{width:100%;height:78vh;display:block;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}

/* ── Legend ── */
.legend-bar{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:14px;padding:7px 18px;background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);z-index:50;box-shadow:var(--shadow-md)}
.legend-item{display:flex;align-items:center;gap:5px;font-size:.62rem;color:var(--text-muted);white-space:nowrap;font-weight:500}
.legend-dot{width:8px;height:8px;border-radius:50%}
.dot-on{background:var(--accent-teal);box-shadow:0 0 5px rgba(16,185,129,.35)}
.dot-mixed{background:var(--accent-amber);box-shadow:0 0 5px rgba(245,158,11,.35)}
.dot-off{background:var(--accent-red);box-shadow:0 0 5px rgba(239,68,68,.35)}
.dot-live{background:var(--accent-amber)}
.dot-proposed{background:#fff;border:1.5px dashed var(--accent-red)}
.legend-sep{width:1px;height:14px;background:var(--border-subtle)}

/* ── Responsive ── */
@media(max-width:900px){.pillar-grid{grid-template-columns:1fr}}
@media(max-width:768px){.main-header{padding:10px 14px}.header-content{flex-direction:column;align-items:flex-start}.main-content{padding:12px}.dept-grid{grid-template-columns:1fr}.legend-bar{flex-wrap:wrap;justify-content:center;bottom:4px;padding:5px 10px;gap:7px}.detail-sidebar{width:100%;right:-100%}.stats-pills{flex-wrap:wrap}.l1-row{gap:5px}.l1-chip{min-width:90px;padding:8px 10px}.exec-summary{grid-template-columns:repeat(4,1fr)}.dict-table{font-size:.65rem}}

/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}
