@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--font-primary:"Inter", sans-serif;--bg-app:#f4f5f7;--bg-surface:#fff;--bg-sidebar:#1e1e24;--bg-hover:#f1f5f9;--text-primary:#0f172a;--text-secondary:#64748b;--text-inverse:#fff;--text-inverse-muted:#94a3b8;--glass-bg:#ffffffb3;--glass-border:#ffffff80;--accent-blue:#2563eb;--accent-blue-hover:#1d4ed8;--accent-green:#10b981;--accent-red:#ef4444;--accent-orange:#f59e0b;--accent-purple:#8b5cf6;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--transition:all .2s cubic-bezier(.4, 0, .2, 1)}@media (prefers-color-scheme:dark){:root{--bg-app:#0f172a;--bg-surface:#1e293b;--bg-sidebar:#0b0f19;--bg-hover:#334155;--text-primary:#f8fafc;--text-secondary:#94a3b8;--border-color:#334155;--glass-bg:#1e293bb3;--glass-border:#ffffff1a;--accent-blue:#3b82f6;--accent-blue-hover:#60a5fa}}html{font-size:14px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-primary);background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.5}.app-container{height:100vh;display:flex;overflow:hidden}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.page-content{flex:1;padding:32px 40px;overflow-y:auto}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);padding:24px;transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s ease-out;position:relative;overflow:hidden}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--accent-blue);background:var(--bg-surface);transform:translateY(-4px)}.page-title{color:var(--text-primary);letter-spacing:-.02em;margin-bottom:24px;font-size:1.75rem;font-weight:700}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);font-size:.875rem;font-weight:500;font-family:var(--font-primary);border:none;align-items:center;gap:8px;padding:10px 16px;display:inline-flex}.btn-primary{background-color:var(--accent-blue);color:#fff}.btn-primary:hover{background-color:var(--accent-blue-hover)}.btn-outline{border:1px solid var(--border-color);color:var(--text-primary);background-color:#0000}.btn-outline:hover{background-color:var(--bg-hover)}.table-container{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;color:var(--text-secondary);border-bottom:1px solid var(--border-color);padding:16px;font-size:.875rem;font-weight:500}td{border-bottom:1px solid var(--border-color);color:var(--text-primary);padding:16px;font-size:.875rem}tr:last-child td{border-bottom:none}tr:hover td{background-color:var(--bg-hover)}.badge{white-space:nowrap;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:600}.badge-green{color:var(--accent-green);background:#10b9811a;border:1px solid #10b98133}.badge-blue{color:var(--accent-blue);background:#3b82f61a;border:1px solid #3b82f633}.badge-orange{color:var(--accent-orange);background:#f59e0b1a;border:1px solid #f59e0b33}.badge-red{color:var(--accent-red);background:#ef44441a;border:1px solid #ef444433}.badge-purple{color:var(--accent-purple);background:#8b5cf61a;border:1px solid #8b5cf633}.sidebar{background-color:var(--bg-sidebar);border-right:1px solid var(--border-color);width:260px;color:var(--text-inverse);flex-direction:column;padding:24px 0;transition:width .2s;display:flex}.sidebar-collapsed{width:72px}.sidebar-collapsed .sidebar-logo{justify-content:center;padding:0 12px}.sidebar-collapsed .sidebar-nav{padding:0 8px}.sidebar-collapsed .nav-item{justify-content:center;padding:12px}.sidebar-collapsed .sidebar-footer{padding:0 8px}.sidebar-logo{align-items:center;gap:12px;margin-bottom:40px;padding:0 24px;display:flex}.logo-icon{background:linear-gradient(135deg, var(--accent-blue), var(--accent-purple));color:#fff;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.125rem;font-weight:700;display:flex}.logo-text{letter-spacing:-.5px;font-size:1.25rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:8px;padding:0 16px;display:flex}.nav-item{border-radius:var(--radius-md);color:var(--text-inverse-muted);font-family:var(--font-primary);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:12px;padding:12px 16px;font-size:.95rem;font-weight:500;display:flex}.nav-item:hover{color:var(--text-inverse);background:#ffffff0d}.nav-item.active{color:var(--text-inverse);background:#ffffff1a;font-weight:600}.nav-icon{opacity:.8}.nav-item.active .nav-icon{opacity:1;color:var(--accent-blue)}.sidebar-footer{margin-top:auto;padding:0 24px}.user-profile{border-radius:var(--radius-md);background:#ffffff0d;border:1px solid #ffffff1a;align-items:center;gap:12px;padding:12px;display:flex}.avatar{background:var(--accent-orange);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;font-weight:600;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-inverse);font-size:.875rem;font-weight:600}.user-role{color:var(--text-inverse-muted);font-size:.75rem}.header{background-color:var(--bg-surface);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;height:72px;padding:0 32px;display:flex}.header-title{color:var(--text-primary);font-size:1.25rem;font-weight:600}.header-right{align-items:center;gap:24px;display:flex}.search-bar{background:var(--bg-hover);border-radius:var(--radius-xl);transition:var(--transition);border:1px solid #0000;align-items:center;gap:8px;padding:8px 16px;display:flex}.search-bar:focus-within{background:var(--bg-surface);border-color:var(--accent-blue);box-shadow:0 0 0 2px #2563eb1a}.search-icon{color:var(--text-secondary)}.search-bar input{font-family:var(--font-primary);color:var(--text-primary);background:0 0;border:none;outline:none;width:200px;font-size:.875rem}.icon-btn{background:var(--bg-hover);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.icon-btn:hover{background:var(--border-color);color:var(--text-primary)}.notification-dot{background:var(--accent-red);border:2px solid var(--bg-surface);border-radius:50%;width:8px;height:8px;position:absolute;top:10px;right:12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;background:#0f172a99;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.2s ease-out fadeIn;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-surface);border-radius:var(--radius-lg);width:100%;max-width:650px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{color:var(--text-primary);font-size:1.125rem;font-weight:600}.modal-body{padding:24px;overflow-y:auto}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:8px;font-size:.875rem;font-weight:500;display:block}.form-control{border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-app);width:100%;color:var(--text-primary);font-family:var(--font-primary);transition:var(--transition);padding:10px 12px;font-size:.875rem}.form-control:focus{border-color:var(--accent-blue);outline:none;box-shadow:0 0 0 2px #2563eb1a}.form-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.alert-strip{border-radius:var(--radius-lg);transition:var(--transition);justify-content:flex-start;align-items:center;gap:24px;margin-bottom:24px;padding:12px 20px;display:flex}.alert-strip--active{background:#ef44440f;border:1px solid #ef444433}.alert-strip--clear{background:#10b9810f;border:1px solid #10b98133}.alert-strip__header{flex-shrink:0}.alert-strip__title{color:var(--text-primary);white-space:nowrap;font-size:.8125rem;font-weight:600}.alert-strip__items{flex-wrap:wrap;gap:16px;display:flex}.alert-item{cursor:pointer;transition:var(--transition);font-size:.8125rem;font-weight:500;font-family:var(--font-primary);background:0 0;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:6px 14px;display:inline-flex}.alert-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.alert-item--danger{color:var(--accent-red);background:#ef44441a;border-color:#ef444440}.alert-item--danger:hover{background:#ef44442e}.alert-item--warning{color:var(--accent-orange);background:#f59e0b1a;border-color:#f59e0b40}.alert-item--warning:hover{background:#f59e0b2e}.alert-item--ok{color:var(--accent-green);background:#10b98114;border-color:#10b98133}.alert-item__count{font-variant-numeric:tabular-nums;font-size:.9375rem;font-weight:700}.alert-item__label{font-weight:500}.pnl-card{padding:24px}.pnl-card:hover{border-color:var(--border-color);transform:none}.pnl-card__title{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:20px;font-size:1.0625rem;font-weight:700}.pnl-table{flex-direction:column;gap:0;display:flex}.pnl-row{border-bottom:1px solid var(--border-color);grid-template-columns:130px 1fr 1fr 110px;align-items:center;gap:6px;padding:8px 0;display:grid}.pnl-row--header{border-bottom:2px solid var(--border-color);padding-bottom:8px}.pnl-row--header .pnl-cell{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.pnl-row--data:last-of-type{border-bottom:1px solid var(--border-color)}.pnl-row--margin{border-radius:var(--radius-md);background:#10b9810d;border-bottom:none;margin:8px -12px 0;padding:12px}.pnl-row--margin .pnl-cell--label{color:var(--accent-green);font-weight:700}.pnl-cell{font-size:.875rem}.pnl-cell--label{color:var(--text-primary);font-size:.8125rem;font-weight:600}.pnl-cell--value{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.pnl-cell--clickable{cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);margin:-4px -8px;padding:4px 8px}.pnl-cell--clickable:hover{background:var(--bg-hover)}.pnl-cell--delta{font-variant-numeric:tabular-nums;align-items:center;gap:4px;font-size:.8125rem;font-weight:600;display:flex}.pnl-value__usd{font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:700}.pnl-value__pct{color:var(--text-secondary);background:var(--bg-hover);border-radius:4px;padding:1px 6px;font-size:.6875rem;font-weight:500}.pnl-value__pct--margin{color:var(--accent-green);background:#10b9811a;font-weight:600}.pnl-value__vnd{color:var(--accent-purple);cursor:help;text-transform:uppercase;letter-spacing:.02em;background:#8b5cf614;border-radius:4px;padding:1px 5px;font-size:.625rem;font-weight:600}.pnl-value__vnd:hover{background:#8b5cf633}@media (width<=768px){.pnl-row{grid-template-columns:100px 1fr 1fr 90px;gap:4px}.pnl-cell--label{font-size:.75rem}.pnl-value__usd{font-size:.8125rem}}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-item{border-radius:var(--radius-md);background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);min-width:160px;transition:var(--transition);flex-direction:column;flex:1;justify-content:flex-start;gap:10px;padding:16px;display:flex;position:relative}.kpi-item--clickable{cursor:pointer}.kpi-item--clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.kpi-item--blue{border-left:3px solid var(--accent-blue)}.kpi-item--green{border-left:3px solid var(--accent-green)}.kpi-item--orange{border-left:3px solid var(--accent-orange)}.kpi-item--purple{border-left:3px solid var(--accent-purple)}.kpi-item--red{border-left:3px solid var(--accent-red)}.kpi-item__header{justify-content:space-between;align-items:center;width:100%;display:flex}.kpi-item__icon-wrapper{align-items:center;gap:8px;display:flex}.kpi-item__icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.kpi-item--blue .kpi-item__icon{color:var(--accent-blue);background:#3b82f61a}.kpi-item--green .kpi-item__icon{color:var(--accent-green);background:#10b9811a}.kpi-item--orange .kpi-item__icon{color:var(--accent-orange);background:#f59e0b1a}.kpi-item--purple .kpi-item__icon{color:var(--accent-purple);background:#8b5cf61a}.kpi-item--red .kpi-item__icon{color:var(--accent-red);background:#ef44441a}.kpi-item__label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:600}.kpi-item__subtext{color:var(--text-secondary);white-space:nowrap;font-size:.6875rem;font-weight:500}.kpi-item__body{justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.kpi-item__value{color:var(--text-primary);font-variant-numeric:tabular-nums;align-items:baseline;gap:6px;font-size:1.5rem;font-weight:700;line-height:1.2;display:flex}.kpi-item__value-detail{color:var(--text-secondary);font-size:.875rem;font-weight:500}.kpi-item__progress-container{background:var(--bg-hover);border-radius:3px;flex:1;max-width:80px;height:6px;overflow:hidden}.kpi-item__progress-bar{border-radius:3px;height:100%;transition:width .6s ease-in-out}.kpi-item__footer{color:var(--text-secondary);border-top:1px dashed var(--border-color);margin-top:auto;padding-top:10px;font-size:.75rem;line-height:1.4}@media (width<=768px){.kpi-row{grid-template-columns:1fr 1fr;gap:12px}}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:24px;display:grid}.metric-card{flex-direction:column;justify-content:space-between;min-height:140px;padding:20px 24px;display:flex}.clickable-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent-blue)!important}.metric-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.metric-label{color:var(--text-secondary);margin-bottom:8px;font-size:.875rem;font-weight:500}.metric-value{color:var(--text-primary);font-size:1.75rem;font-weight:700;line-height:1.2}.metric-icon-bg{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.bg-blue{background:#3b82f61a}.text-blue{color:var(--accent-blue)}.bg-orange{background:#f59e0b1a}.text-orange{color:var(--accent-orange)}.bg-green{background:#10b9811a}.text-green{color:var(--accent-green)}.bg-purple{background:#8b5cf61a}.text-purple{color:var(--accent-purple)}.bg-red{background:#ef44441a}.text-red{color:var(--accent-red)}.metric-footer{color:var(--text-secondary);font-size:.875rem}.dashboard-content-grid{grid-template-columns:1.4fr 1fr;align-items:stretch;gap:24px;margin-bottom:32px;display:grid}.pnl-section{flex-direction:column;display:flex}.chart-section{flex-direction:column;padding:0;display:flex}.pnl-section>.card,.chart-section.card{flex-direction:column;height:100%;padding:24px;display:flex}.chart-section .recharts-responsive-container{margin-top:auto;margin-bottom:auto}.chart-footer{opacity:.8;font-style:italic}.operational-drivers{flex-direction:column;gap:0;display:flex}.section-title{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:16px;font-size:1.125rem;font-weight:700;display:flex}.section-badge{border-radius:10px;padding:3px 10px;font-size:.6875rem;font-weight:500}.section-badge--info{color:var(--accent-blue);background:#3b82f61a}.section-badge--urgent{background:var(--accent-red);color:#fff}.section-badge--forecast{background:var(--accent-purple);color:#fff}.dashboard-kpi-stack{flex-direction:column;gap:16px;display:flex}.charts-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}.charts-grid-single{grid-template-columns:1fr;gap:24px;max-width:480px;margin-bottom:24px;display:grid}.chart-card{flex-direction:column;display:flex}.chart-card:hover{border-color:var(--border-color);transform:none}.chart-title{margin-bottom:16px;font-size:1rem;font-weight:600}.chart-placeholder{background:var(--bg-hover);border-radius:var(--radius-md);color:var(--text-secondary);border:1px dashed var(--border-color);flex:1;justify-content:center;align-items:center;display:flex}.detail-pill{color:var(--accent-blue);opacity:0;font-size:.6875rem;font-weight:500;transition:opacity .2s;position:absolute;top:8px;right:12px}.clickable-card:hover .detail-pill{opacity:1}@media (width<=1024px){.dashboard-main-grid{grid-template-columns:1fr}}@media (width<=768px){.metrics-grid,.charts-grid{grid-template-columns:1fr}}
