.footer{cursor:pointer;color:var(--text-color);background-color:var(--background-color);border-top:1px solid var(--border-color);padding:.5rem}.footer p{text-align:center;font-size:.65rem}.app-container{display:flex;height:100vh;background-color:var(--background-color)}.app-container .main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.app-container .main-content .page-content{flex:1;padding:1.5rem;overflow-y:auto}@media(max-width:768px){.app-container .main-content .page-content{padding:0;margin:0}}.animated-grid-lines{position:relative;width:100%;height:100%}.animated-grid-lines .grid-canvas{position:fixed;inset:0;z-index:-1;pointer-events:none}.animated-grid-lines .content-overlay{position:relative;z-index:1;width:100%;height:100%;background-color:var(--background-color-splash)}.animated-grid-lines.light,.animated-grid-lines.dark{background-color:var(--background-color-splash)}.chart-renderer{width:100%;min-height:300px;display:flex;align-items:center;justify-content:center}.chart-renderer.no-data{background:var(--background-color);border:1px dashed var(--border-color);border-radius:12px}.chart-renderer.no-data p{color:var(--text-color);font-size:.75rem;margin:0}.chart-renderer .recharts-wrapper{background-color:var(--background-color);border-radius:12px;padding:.75rem .5rem}.chart-renderer .recharts-text{fill:var(--text-color)}.chart-renderer .recharts-default-tooltip{color:var(--primary-color)}.chart-renderer .recharts-legend-wrapper{padding:1rem .5rem}@media(max-width:768px){.chart-renderer .recharts-wrapper{border-radius:12px;padding:3rem 0rem}}.builder{padding:24px;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color)}.dashboard-header h2{margin:0;font-size:28px;color:var(--text-color);padding:1.5px 13px;border:1px solid var(--border-color);border-radius:8px;transition:background .2s;font-family:Space Mono,monospace;font-size:1.5rem}.dashboard-header .dashboard-name-input{font-family:Space Mono,monospace;font-size:1.5rem;font-weight:600;border-radius:4px;background:var(--background-color);color:var(--text-color);width:fit-content;margin:0}.dashboard-header .dashboard-name-input:focus{outline:none;border:1px solid var(--secondary-color);padding:1.5px 13px;margin:0}.header-actions{display:flex;gap:12px}.header-actions button{padding:10px 20px;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--primary-color);color:var(--text-color)}.header-actions button:hover:not(:disabled){background:var(--secondary-color)}.header-actions button:disabled{opacity:.5;cursor:not-allowed}.add-chart-section{background:var(--card-background);padding:16px;border-radius:12px;margin-bottom:24px;border:1px solid var(--border-color, #e0e0e0)}.add-chart-section label{display:block;font-weight:600;margin-bottom:12px;color:var(--text-color);font-size:1rem}.chart-type-buttons{display:flex;gap:8px;flex-wrap:wrap}.chart-type-buttons button{padding:8px 16px;border-radius:8px;background:var(--primary-color);color:var(--text-color);font-size:.85rem;cursor:pointer;transition:all .2s}.chart-type-buttons button:hover{background:var(--secondary-color);color:var(--text-color);border-color:var(--primary-color)}.dashboard-content{min-height:400px}.empty-state{text-align:center;padding:80px 24px;background:var(--card-background);border-radius:12px;border:1px dashed var(--border-color)}.empty-state h3{font-size:1.5rem;color:var(--text-color);margin:0 0 12px}.empty-state p{font-size:.85rem;color:var(--text-color-muted);margin:0}@media(max-width:768px){.builder{padding:16px}.dashboard-header{flex-direction:column;align-items:flex-start;gap:16px}.dashboard-header h2,.dashboard-header .dashboard-name-input{font-size:1.5rem}.header-actions{width:100%}.header-actions button{flex:1;padding:8px 12px;font-size:.85rem}.chart-type-buttons button{flex:1;min-width:80px}}.library{display:flex;flex-direction:column;gap:2rem;padding:1.5rem;color:var(--text-color);background:var(--background-color)}.library.loading{font-size:1.2rem;text-align:center;color:var(--text-color)}.library .library-section{background:var(--card-background);border-radius:8px;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1rem;border:1px solid var(--border-color)}.library .library-section h2{margin-bottom:.5rem;font-size:1.5rem;color:var(--secondary-color);border-bottom:1px solid var(--border-color);padding-bottom:.5rem}.library .library-section .sort-controls{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.library .library-section .sort-controls label{font-size:.9rem;color:var(--text-color)}.library .library-section .sort-controls select{padding:.25rem .5rem;font-size:.85rem;border:1px solid var(--border-color);border-radius:4px;background:var(--card-background);color:var(--text-color);cursor:pointer}.library .library-section .empty{font-size:.85rem;color:var(--text-color);opacity:.6;text-align:center;padding:1rem 0}.library .library-section .item-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.library .library-section .item-list .item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-radius:4px;border:1px solid var(--border-color);background:var(--card-background);transition:background .2s}.library .library-section .item-list .item:hover{background:var(--card-background)}.library .library-section .item-list .item .item-info{display:flex;flex-direction:column;gap:.25rem}.library .library-section .item-list .item .item-info p{font-size:.85rem;color:var(--text-color);opacity:.9;margin:0}.library .library-section .item-list .item .item-actions{display:flex;gap:.5rem}.library .library-section .item-list .item .item-actions button{padding:.35rem .8rem;font-size:.85rem;border:none;border-radius:4px;cursor:pointer;transition:background .2s,color .2s}.library .library-section .item-list .item .item-actions button:first-of-type{background:var(--secondary-color);color:var(--text-color)}.library .library-section .item-list .item .item-actions button:first-of-type:hover{filter:brightness(.9)}.library .library-section .item-list .item .item-actions button:last-of-type{background:var(--danger-color);color:var(--text-color)}.library .library-section .item-list .item .item-actions button:last-of-type:hover{filter:brightness(.9)}.spinner-container{display:flex;justify-content:center;align-items:center;height:100vh}.spinner{border:4px solid rgba(0,0,0,.1);border-left-color:#4f46e5;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--sidebar-width: 220px;--sidebar-collapsed-width: 50px;--icon-size-lg: 20px;--icon-size-sm: 18px}*{margin:0;padding:0;box-sizing:border-box;font-family:Space Mono,monospace}body{font-size:.85rem;color:var(--text-color);background-color:var(--background-color);transition:background-color .3s,color .3s}button{cursor:pointer;border:none;background:var(--primary-color);color:#fff;padding:8px 16px;border-radius:4px;transition:background-color .3s ease-in-out}button:hover{filter:brightness(1.1)}input{padding:8px 16px;border:1px solid var(--border-color);border-radius:4px;width:100%;font-size:.85rem;background:var(--card-background);color:var(--text-color)}select{color:var(--text-color)}:root{--background-color: #f5f5f5;--background-color-splash: rgba(185, 180, 180, .3);--text-color: #242424;--text-color-muted: #484848;--border-color: #dedede;--card-background: #f1f1f1;--primary-color: #c4c4c4;--secondary-color: #fec345;--accent-color: #ffb82b;--danger-color: #e0533a}[data-theme=dark]{--background-color: #242424ff;--background-color-splash: rgba(36, 36, 36, .3);--text-color: #f5f5f5;--border-color: rgb(57, 57, 57);--card-background: #2c2c2c;--primary-color: #6c6c6c;--text-color-muted: #878787;--secondary-color: #7b6aa9;--accent-color: #655987;--danger-color: #e0533a}.navbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--border-color);background:transparent}.navbar.sidebar-expanded,.navbar.sidebar-collapsed{padding-left:1.5rem;transition:padding-left .22s ease}.navbar .navbar-left{display:flex;align-items:center}.navbar .navbar-center{display:flex;flex:1;justify-content:center;align-items:center}.navbar .navbar-right{display:flex;gap:.5rem;align-items:center}.navbar .app-brand,.navbar .theme-toggle-btn,.navbar .logout-btn{color:var(--text-color);font-size:1rem;margin:0;cursor:pointer}.navbar .app-brand:hover,.navbar .theme-toggle-btn:hover,.navbar .logout-btn:hover{color:var(--secondary-color)}.navbar button{background:transparent;border:none;cursor:pointer;padding:.25rem;border-radius:6px}.navbar .upload-btn{display:flex;align-items:center;gap:.25rem;background-color:var(--primary-color);color:var(--text-color);border:none;padding:.25rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;max-width:250px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;justify-content:center;transition:background-color .2s}.navbar .upload-btn:hover:not(:disabled){background-color:var(--secondary-color)}.navbar .upload-btn:disabled{opacity:.5;cursor:not-allowed}.navbar .upload-btn svg{flex-shrink:0}@media(max-width:768px){.navbar{flex-direction:column;gap:1rem}}.sidebar{display:flex;flex-direction:column;height:100vh;padding:.5rem;background-color:var(--background-color);color:var(--text-color);border-right:1px solid var(--border-color);width:var(--sidebar-width);transition:width .22s ease,background-color .3s ease,color .3s ease;box-sizing:border-box}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar.collapsed .sidebar-header{justify-content:center}.sidebar.collapsed .sidebar-nav a{justify-content:center;padding:.35rem 0}.sidebar.collapsed .sidebar-nav span{display:none}.sidebar .sidebar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;position:relative;min-height:40px}.sidebar .sidebar-header .logo-container{display:flex;align-items:center;gap:.5rem}.sidebar .sidebar-header .logo-container h2{font-size:1.5rem;font-weight:700}.sidebar .sidebar-header .expand-container{position:relative;display:flex;align-items:center;justify-content:center}.sidebar .sidebar-header .collapse-btn,.sidebar .sidebar-header .expand-icon,.sidebar .sidebar-header .icon-button{background:transparent;border:none;cursor:pointer;border-radius:8px;color:var(--text-color);transition:color .12s ease,transform .12s ease;display:inline-flex;align-items:center;justify-content:center;padding:.125rem}.sidebar .sidebar-header .collapse-btn:hover,.sidebar .sidebar-header .icon-button:hover{color:var(--secondary-color)}.sidebar .sidebar-header .collapsed-logo.hidden{display:none}.sidebar .sidebar-header .expand-icon{display:flex;align-items:center;justify-content:center}.sidebar .sidebar-header .header-tooltip{position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%) scale(.95);background-color:var(--card-background);color:var(--text-color);border:1px solid var(--border-color);padding:4px 8px;border-radius:4px;font-size:.65rem;white-space:nowrap;pointer-events:none;opacity:0;z-index:1000;transition:opacity .15s ease,transform .15s ease}.sidebar .sidebar-header .expand-container:hover .header-tooltip,.sidebar .sidebar-header .expand-container:focus-within .header-tooltip{opacity:1;transform:translateY(-50%) scale(1)}.sidebar .sidebar-nav{display:flex;flex-direction:column;gap:.5rem}.sidebar .sidebar-nav a{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--text-color);padding:.35rem .5rem;border-radius:8px;transition:background-color .12s,color .12s;position:relative}.sidebar .sidebar-nav a:hover{background-color:var(--primary-color);color:var(--card-background)}.sidebar .sidebar-nav a.active{background-color:var(--secondary-color);color:var(--text-color)}.sidebar .sidebar-nav a svg{flex-shrink:0;color:inherit}.sidebar .sidebar-nav a span{font-size:.85rem}.sidebar .icon--brand svg,.sidebar .icon--brand svg *{width:var(--icon-size-lg);height:var(--icon-size-lg)}.sidebar .icon--toggle svg,.sidebar .icon--toggle svg *,.sidebar .icon--nav svg,.sidebar .icon--nav svg *{width:var(--icon-size-sm);height:var(--icon-size-sm)}.sidebar .sidebar-link-wrapper{position:relative}.sidebar .sidebar-tooltip{position:absolute;top:50%;left:calc(100% + 10px);background-color:var(--card-background);color:var(--text-color);border:1px solid var(--border-color);padding:4px 8px;border-radius:4px;font-size:.65rem;white-space:nowrap;z-index:1000;pointer-events:none;opacity:0;transform:translateY(-50%) scale(.95);transition:opacity .15s ease,transform .15s ease}.sidebar .sidebar-link-wrapper:hover .sidebar-tooltip{opacity:1;transform:translateY(-50%) scale(1)}@media(max-width:768px){.sidebar{width:50px!important;transition:none}.sidebar.collapsed{width:50px!important}.sidebar .expand-container,.sidebar .sidebar-nav span{display:none!important}.sidebar .sidebar-header{justify-content:center;display:none}}.auth-container{display:flex;flex-direction:row;height:100vh;width:100vw;justify-content:center;align-items:center}.auth-form{width:40vw;height:fit-content;margin:0 auto;padding:2rem;border:1px solid var(--border-color);border-radius:12px;background:var(--card-background);display:flex;flex-direction:column;gap:1rem}.auth-form h2{text-align:center;margin-bottom:1rem;font-size:1.8rem}.auth-form input{padding:.75rem 1rem;font-size:.85rem;border:1px solid var(--border-color);border-radius:8px;outline:none;transition:border-color .3s}.auth-form input:focus{border-color:var(--secondary-color)}.auth-form button{padding:.75rem 1rem;font-size:1rem;background-color:var(--secondary-color);color:var(--text-color);border:none;border-radius:8px;cursor:pointer;transition:background-color .3s}.auth-form button:hover{background-color:var(--accent-color)}.auth-form p{text-align:center;font-size:.85rem}.auth-form p a{color:var(--secondary-color);text-decoration:none}.auth-form p a:hover{text-decoration:underline}.auth-form .auth-copyright{font-size:.75rem}@media(max-width:768px){.auth-form{width:90vw;height:fit-content}}.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;width:100%;margin:0 auto;align-items:start}@media(max-width:1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-grid{grid-template-columns:1fr}}.chart-card{background:var(--card-background);border:1px solid var(--border-color);border-radius:12px;padding:16px;position:relative}.chart-card.full{grid-column:span 4}.chart-card.half{grid-column:span 2}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;cursor:grab}.chart-header:active{cursor:grabbing}.drag-handle{color:var(--text-color);-webkit-user-select:none;user-select:none}.chart-delete-btn{background:transparent;border:none;color:var(--text-color);cursor:pointer;padding:4px 8px;border-radius:8px;transition:background .2s}.chart-delete-btn:hover{background:#da402fb3}.chart-warning{display:flex;align-items:center;gap:8px;padding:12px;margin-bottom:12px;background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;color:#f57c00;font-size:.75rem;font-weight:500}.chart-warning svg{flex-shrink:0}.chart-controls{display:grid;grid-template-columns:repeat(3,minmax(100px,1fr));gap:8px;margin-bottom:16px}.chart-controls label{display:flex;flex-direction:column;font-size:.75rem;font-weight:500;color:var(--text-color);gap:4px}.chart-controls select{padding:6px 8px;border:1px solid var(--border-color);border-radius:8px;background:var(--background-color);color:var(--text-color);font-size:.85rem;cursor:pointer}.chart-controls select:focus{outline:none;border-color:var(--primary-color)}.chart-controls select.invalid{border-color:#f57c00;background:#ffc1070d}@media(max-width:1200px){.chart-card.half,.chart-card.full{grid-column:span 2}.chart-card .chart-size-selector{display:none}}@media(max-width:768px){.chart-card.half,.chart-card.full{grid-column:span 1}.chart-controls{grid-template-columns:repeat(2,minmax(100px,1fr))}.chart-size-selector{display:none}}.toaster-container{position:fixed;bottom:20px;right:20px;z-index:9999}.react-hot-toast{border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;font-family:Space Mono,monospace;font-size:.65rem;transition:background-color .3s,color .3s;background:var(--card-background)!important;color:var(--text-color)!important;border:1px solid var(--border-color)}div[role=status][aria-live=polite]>div:has(svg[viewBox="0 0 20 20"]){font-size:.65rem;background:var(--card-background)!important;color:var(--text-color)!important;border:1px solid var(--secondary-color)}div[role=status][aria-live=polite]>div:has(svg[viewBox="0 0 20 20"]) svg{color:var(--secondary-color)!important}div[role=status][aria-live=assertive]>div:has(svg[viewBox="0 0 20 20"]){font-size:.65rem;background:var(--card-background)!important;color:var(--text-color)!important;border:1px solid var(--danger-color)}div[role=status][aria-live=assertive]>div:has(svg[viewBox="0 0 20 20"]) svg{color:var(--danger-color)!important}div[role=status][aria-live=assertive]>div:has(svg[viewBox="0 0 20 20"] circle){font-size:.65rem;background:var(--card-background)!important;color:var(--text-color)!important;border:1px solid var(--primary-color)}div[role=status][aria-live=assertive]>div:has(svg[viewBox="0 0 20 20"] circle) svg{color:var(--primary-color)!important}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.react-hot-toast{animation:slideIn .3s ease-out}
