.app-shell{display:flex;height:100dvh;overflow:hidden}
.sidebar{width:240px;flex-shrink:0;background:var(--color-surface);border-right:1px solid var(--color-border);
    display:flex;flex-direction:column;padding:var(--space-4) 0;overflow-y:auto;transition:width var(--transition)}
.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-4) var(--space-6);
    border-bottom:1px solid var(--color-divider);margin-bottom:var(--space-4)}
.logo-mark{width:32px;height:32px;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-size:var(--text-lg);font-weight:800;
    color:var(--color-primary);letter-spacing:-0.02em}
.nav-section{padding:0 var(--space-3);margin-bottom:var(--space-6)}
.nav-label{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:0.08em;
    color:var(--color-text-faint);padding:0 var(--space-3);margin-bottom:var(--space-2)}
.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);
    border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-muted);
    cursor:pointer;width:100%;text-align:left;border:none;background:none;transition:all var(--transition)}
.nav-item:hover{background:var(--color-surface-offset);color:var(--color-text)}
.nav-item.active{background:var(--color-primary-highlight);color:var(--color-primary);font-weight:500}
.nav-item svg{flex-shrink:0}
.sidebar-bottom{margin-top:auto;padding:var(--space-4);border-top:1px solid var(--color-divider)}
.theme-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);
    border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-muted);
    width:100%;transition:all var(--transition)}
.theme-btn:hover{background:var(--color-surface-offset);color:var(--color-text)}

.main{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:10;background:var(--color-bg);
    border-bottom:1px solid var(--color-border);padding:var(--space-4) var(--space-8);
    display:flex;align-items:center;justify-content:space-between}
.page-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:800;
    letter-spacing:-0.02em}
.topbar-actions{display:flex;gap:var(--space-2)}
.content{padding:var(--space-8);max-width:1200px;width:100%}

.view{display:none}
.view.active{display:block}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:var(--space-4)}
.chart-row{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-6);margin-top:var(--space-6)}

.hamburger{display:none;padding:var(--space-2);border-radius:var(--radius-md)}
@media(max-width:768px){
    .sidebar{position:fixed;left:-240px;top:0;bottom:0;z-index:50;transition:left var(--transition)}
    .sidebar.open{left:0;box-shadow:var(--shadow-lg)}
    .hamburger{display:flex;align-items:center;gap:var(--space-2)}
    .content{padding:var(--space-4)}
    .topbar{padding:var(--space-3) var(--space-4)}
    .grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}
    .chart-row{grid-template-columns:1fr}
    .form-row,.form-row-3{grid-template-columns:1fr}
}