.App{text-align:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}html,body{height:100%;margin:0}.App-header{background:#fffffff2;padding:2.5rem;border-radius:20px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:1200px;width:calc(100% - 48px)}.App-header h1{color:#333;margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.App-header p{color:#666;margin-bottom:2rem;font-size:1.1rem}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.header-top h1{margin-bottom:0}.logout-button{background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;border:none;padding:8px 16px;font-size:.9rem;border-radius:20px;cursor:pointer;transition:all .3s ease;font-weight:600}.logout-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0003}.login-section{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem}.health-section{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(0,0,0,.1)}.dashboard-button{background:linear-gradient(135deg,#00b894,#0984e3);color:#fff;border:none;padding:10px 18px;font-size:1rem;border-radius:25px;cursor:pointer;transition:all .2s ease;font-weight:600}.dashboard-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001f}.demo-button{background:linear-gradient(135deg,#d6a317,#740a91);color:#fff;border:none;padding:10px 18px;font-size:1rem;border-radius:25px;cursor:pointer;transition:all .2s ease;font-weight:600}.demo-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001f}.health-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;font-size:1.1rem;border-radius:50px;cursor:pointer;transition:all .3s ease;font-weight:600;min-width:150px}.health-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #0003}.health-button:disabled{opacity:.7;cursor:not-allowed}.health-status{padding:1rem;border-radius:10px;font-weight:500;max-width:100%;word-wrap:break-word}.health-status:contains("✅"){background:#4caf501a;color:#2e7d32;border:1px solid rgba(76,175,80,.3)}.health-status:contains("❌"){background:#f443361a;color:#c62828;border:1px solid rgba(244,67,54,.3)}.api-key-input-group{display:flex;gap:.5rem;width:100%;max-width:400px;align-items:center}.api-key-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:25px;font-size:1rem;transition:all .3s ease;background:#fff}.api-key-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.api-key-input:disabled{background:#f5f5f5;cursor:not-allowed}.login-button{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;padding:12px 20px;font-size:1rem;border-radius:25px;cursor:pointer;transition:all .3s ease;font-weight:600;white-space:nowrap}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #0003}.login-button:disabled{opacity:.7;cursor:not-allowed}.error-message{background:#f443361a;color:#c62828;border:1px solid rgba(244,67,54,.3);padding:1rem;border-radius:10px;font-weight:500;max-width:100%;word-wrap:break-word;margin-top:1rem}@media (max-width: 600px){.App-header{padding:2rem;margin:1rem}.header-top,.api-key-input-group{flex-direction:column;gap:1rem}.login-button{width:100%}}.dashboard-header{min-height:160px;display:flex;align-items:flex-start;justify-content:flex-start;padding-top:40px}.back-arrow{background:#fff;border:1px solid rgba(0,0,0,.08);color:#333;font-size:1.2rem;padding:6px 10px;cursor:pointer;position:fixed;left:16px;top:16px;border-radius:8px;z-index:9999;box-shadow:0 6px 18px #0000001f}.back-arrow:hover{transform:translateY(-2px)}.dashboard-page{align-items:stretch;justify-content:flex-start;padding-top:0;width:100vw;margin:0 calc(-50vw + 50%)}.dashboard-page .App-header{max-width:1380px;width:calc(100% - 80px);margin:32px auto;border-radius:18px;min-height:calc(100vh - 120px);padding:2rem 3rem}.dashboard-header h1{font-size:1.8rem;margin-bottom:1rem}.dashboard-grid{display:grid;grid-template-columns:2fr 460px;grid-template-rows:auto 440px 200px;grid-template-areas:"title title" "chart side" "gantt side";gap:32px;align-items:start}.chart-card,.pie-card,.todo-card{background:linear-gradient(180deg,#fffffff5,#ffffffe6);padding:16px;border-radius:12px;box-shadow:0 8px 18px #0000000f;text-align:left}.gantt-card{margin-top:12px;background:linear-gradient(180deg,#fffffffa,#fffffff2);padding:12px;border-radius:10px;box-shadow:0 6px 14px #0000000d}.dashboard-title{grid-area:title}.chart-card{grid-area:chart;min-height:440px;display:flex;flex-direction:column;justify-content:space-between}.gantt-card{grid-area:gantt;margin-top:0}.chart-card h3,.pie-card h3,.todo-card h3{margin:0 0 30px;font-size:1.3rem;color:#222;font-weight:600}.side-column{grid-area:side;display:flex;flex-direction:column;gap:24px;height:672px}.side-column>.pie-card,.side-column>.todo-card{flex:1;display:flex;flex-direction:column;justify-content:flex-start}.pie-card{align-items:center;display:flex;gap:12px;justify-content:center}.todo-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.todo-item{display:flex;gap:12px;align-items:center;padding:8px;border-radius:8px;background:#00000005}.todo-bullet{width:10px;height:10px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:inline-block;margin-right:8px}@media (max-width: 1100px){.dashboard-grid{grid-template-columns:1fr 320px}}@media (max-width: 780px){.dashboard-grid{grid-template-columns:1fr}.App-header{max-width:920px;width:calc(100% - 40px)}}.controls{background:linear-gradient(135deg,var(--color-lightest-gray) 0%,var(--color-light-gray) 100%);padding:var(--spacing-md);border-radius:var(--border-radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.time-display{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-success);text-align:center;margin:var(--spacing-sm) 0;letter-spacing:var(--letter-spacing-tight)}.slider-container{margin:var(--spacing-md) 0}.slider-container input[type=range]{width:100%;height:var(--slider-height);border-radius:var(--slider-radius);background:var(--color-border);outline:none;appearance:none;-webkit-appearance:none}.slider-container input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:var(--thumb-size);height:var(--thumb-size);border-radius:50%;background:var(--color-success);cursor:pointer;box-shadow:var(--shadow-sm);transition:var(--transition-all)}.slider-container input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.slider-container input[type=range]::-moz-range-thumb{width:var(--thumb-size);height:var(--thumb-size);border-radius:50%;background:var(--color-success);cursor:pointer;border:none;box-shadow:var(--shadow-sm);transition:var(--transition-all)}.slider-container input[type=range]::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:var(--shadow-md)}.button-group{display:flex;justify-content:center;gap:.5em;margin:var(--spacing-md) 0}.controls button{padding:var(--spacing-sm) var(--spacing-md);cursor:pointer;border:1px solid var(--color-border);background:#fff;border-radius:8px;font-size:.9em;font-weight:500;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.controls button:hover:not(:disabled){background:var(--color-lightest-gray);border-color:var(--color-muted);transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.controls button.active{background:linear-gradient(135deg,var(--color-success) 0%,var(--color-success-dark) 100%);color:#fff;border-color:var(--color-success-dark);box-shadow:0 4px 8px #10b98133}.controls button:disabled{opacity:.4;cursor:not-allowed;transform:none}.control-row{margin-top:var(--spacing-md)}.control-row label{display:block;font-size:.85em;font-weight:600;color:var(--color-gray);margin-bottom:.4em;letter-spacing:.2px}.control-row input[type=range]{width:100%;margin:.5em 0;height:.4em;border-radius:.2em;background:var(--color-border);outline:none;appearance:none;-webkit-appearance:none}.control-row input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:1em;height:1em;border-radius:50%;background:var(--color-primary);cursor:pointer;box-shadow:0 2px 4px #3b82f64d}.control-row input[type=range]::-moz-range-thumb{width:1em;height:1em;border-radius:50%;background:var(--color-primary);cursor:pointer;border:none;box-shadow:0 2px 4px #3b82f64d}.control-row select{width:100%;padding:.6em .8em;margin-top:.4em;font-family:inherit;font-size:.9em;border:1px solid var(--color-border);border-radius:8px;background:#fff;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.control-row select:hover{border-color:var(--color-muted)}.control-row select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.speed-display{display:inline-block;margin-left:.6em;font-weight:600;color:var(--color-primary)}.time-display span{color:var(--color-success)}.checkbox-label{display:flex!important;align-items:center;gap:.6em;cursor:pointer;font-size:.9em!important;font-weight:500!important;color:var(--color-gray)!important;padding:.5em;border-radius:6px;transition:background .2s ease}.checkbox-label:hover{background:#00000005}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer;width:1.2em;height:1.2em;accent-color:var(--color-success)}.chart-container{margin-top:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);transition:var(--transition-shadow)}.chart-container:hover{box-shadow:var(--shadow-lg)}.chart-plot{margin-top:var(--spacing-sm);height:240px;border-radius:var(--border-radius-md);overflow:hidden;background:var(--color-light-gray)}.savings-analysis{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:2px solid rgba(var(--color-primary-rgb),.15)}.savings-title{font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm);color:var(--color-dark);font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--spacing-xs);letter-spacing:var(--letter-spacing-tight)}.savings-grid{display:flex;flex-direction:column;gap:var(--spacing-xs);font-size:var(--font-size-xs);line-height:var(--line-height);color:var(--color-gray)}.savings-label-bold{font-weight:var(--font-weight-semibold);color:var(--color-dark)}.savings-value{font-weight:600;font-variant-numeric:tabular-nums}.savings-value-primary{color:var(--color-primary)}.savings-value-secondary{color:var(--color-gray)}.savings-value-highlight{font-size:15px;font-weight:700}.savings-value-success{color:var(--color-success)}.savings-value-warning{color:var(--color-warning)}.savings-description{margin-top:var(--spacing-sm);padding:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-gray);font-style:italic;background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.05),rgba(var(--color-success-rgb),.05));border-radius:var(--border-radius-md);line-height:var(--line-height);border-left:3px solid var(--color-primary)}.regret-analysis{background:var(--color-white);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);transition:var(--transition-shadow)}.regret-analysis:hover{box-shadow:var(--shadow-lg)}.regret-title{margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--color-dark);letter-spacing:var(--letter-spacing-tight)}.regret-comparison{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.policy-stats{background:linear-gradient(135deg,var(--color-lightest-gray) 0%,var(--color-light-gray) 100%);border-radius:var(--border-radius-md);padding:var(--spacing-md);border:2px solid transparent;transition:var(--transition-all)}.policy-stats:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.dfl-stats{border-color:rgba(var(--color-success-rgb),.35);background:linear-gradient(135deg,rgba(var(--color-success-rgb),.04),rgba(var(--color-success-rgb),.02))}.comparison-stats{border-color:rgba(var(--color-greedy-rgb),.35);background:linear-gradient(135deg,rgba(var(--color-greedy-rgb),.04),rgba(var(--color-greedy-rgb),.02))}.policy-header{margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid rgba(100,116,139,.15)}.policy-name{font-size:14px;font-weight:700;color:var(--color-dark);letter-spacing:-.01em}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.stat-item{display:flex;flex-direction:column;gap:3px}.stat-label{font-size:11px;color:var(--color-gray);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.stat-value{font-size:16px;font-weight:700;font-variant-numeric:tabular-nums}.stat-value.dfl{color:var(--color-success)}.stat-value.comparison{color:var(--color-greedy)}.improvement-banner{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;background:linear-gradient(135deg,#10b9811f,#10b9810f);border:2px solid rgba(16,185,129,.35);border-radius:10px;margin-bottom:18px;transition:all .2s ease}.improvement-banner:hover{background:linear-gradient(135deg,#10b98126,#10b98114);border-color:#10b98173}.improvement-label{font-size:13px;font-weight:700;color:var(--color-success-dark);letter-spacing:-.01em}.improvement-value{font-size:16px;font-weight:800;color:var(--color-success);font-variant-numeric:tabular-nums}.sidebar{flex:1;min-height:0;width:100%;background:var(--color-white);padding:var(--spacing-lg);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-lg);text-align:left}.sidebar-top-row{display:flex;gap:var(--spacing-lg);align-items:flex-start}.sidebar-controls{flex:1;min-width:400px}.sidebar-chart{flex:1;min-width:300px}.sidebar h3{margin:0 0 var(--spacing-lg) 0;color:var(--color-dark);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight);text-align:left}.sidebar h4{margin:0 0 var(--spacing-md) 0;color:var(--color-gray);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);text-align:left}.sidebar hr{border:0;border-top:1px solid var(--color-border);margin:20px 0}.sidebar p{margin:8px 0;font-size:14px;color:var(--color-gray);line-height:var(--line-height)}.sidebar strong{color:var(--color-dark);font-weight:600}.chart-toggle-container{display:flex;justify-content:center;margin:0}.chart-toggle-button{padding:10px 20px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.3)}.chart-toggle-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.4);background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary-darker) 100%)}.chart-toggle-button:active{transform:translateY(0);box-shadow:0 2px 6px rgba(var(--color-primary-rgb),.3)}.map{width:100%;height:100%;z-index:0}.leaflet-control-container{z-index:1000}.cost-bar-container{background-color:var(--color-white);padding:var(--spacing-md);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);transition:var(--transition-shadow)}.cost-bar-container:hover{box-shadow:var(--shadow-lg)}.cost-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.cost-bar-header h4{margin:0;font-size:var(--font-size-md);color:var(--color-dark);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight)}.cost-value{font-weight:var(--font-weight-bold);color:var(--color-danger);font-size:var(--font-size-sm);font-variant-numeric:tabular-nums}.cost-bar-wrapper{margin:.5em 0}.cost-bar-background{width:100%;height:2em;background:linear-gradient(135deg,var(--color-light-gray) 0%,var(--color-border) 100%);border-radius:1em;overflow:hidden;box-shadow:inset 0 2px 6px #00000014;position:relative}.cost-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-success) 0%,var(--color-warning-mid) 50%,var(--color-greedy) 100%);transition:width .4s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:flex-end;padding-right:.75em;min-width:3em;box-sizing:border-box;box-shadow:0 2px 8px #00000026}.cost-bar-percentage{color:#fff;font-size:.85em;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.4);font-variant-numeric:tabular-nums}.cost-bar-legend{display:flex;justify-content:space-between;font-size:.8em;color:var(--color-gray);margin-top:.5em;font-weight:500}:root{--color-praedon: #3b82f6;--color-greedy: #ef4444;--color-anticipative: #10b981;--color-lazy: #f59e0b;--color-primary: var(--color-praedon);--color-success: var(--color-anticipative);--color-danger: var(--color-greedy);--color-warning: var(--color-lazy);--color-white: #ffffff;--color-light-gray: #f1f5f9;--color-lightest-gray: #f8fafc;--color-gray: #64748b;--color-dark: #1e293b;--color-border: #e2e8f0;--color-primary-rgb: 59,130,246;--color-success-rgb: 16,185,129;--bg-light: #f9fafb;--bg-white: var(--color-white);--bg-dark: rgba(0, 0, 0, .8);--border-color: var(--color-border);--border-radius-sm: 4px;--border-radius-md: 8px;--border-radius-lg: 12px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-size-xs: 13px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 20px;--font-weight-regular: 400;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height: 1.6;--letter-spacing-tight: -.01em;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 6px 20px rgba(0, 0, 0, .12);--sidebar-width: 400px;--map-height: 600px;--chart-height: 240px;--slider-height: .4em;--slider-radius: .2em;--thumb-size: 1.2em;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-all: all .2s ease;--transition-shadow: box-shadow .3s ease;--color-muted: #94a3b8;--color-primary-dark: #2563eb;--color-primary-darker: #1d4ed8;--color-success-dark: #059669;--color-warning-mid: #fbbf24;--color-greedy-rgb: 239,68,68}.container{display:flex;flex-direction:column;height:140vh;width:100vw;background:linear-gradient(135deg,#f5f7fa,#e8edf2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;overflow:hidden}.maps-split-container{flex:1;min-height:0;display:flex;position:relative;gap:1px;padding:12px 12px 6px}.map-half{flex:1;position:relative;display:flex;flex-direction:column;border-radius:12px;overflow:visible;box-shadow:0 4px 12px #00000014,0 2px 4px #0000000a;background:#fff;transition:box-shadow .3s ease}.map-half:hover{box-shadow:0 8px 24px #0000001f,0 4px 8px #0000000f}.map-half>.map{flex:1;border-radius:12px 12px 0 0;overflow:hidden}.cost-bar-container{position:relative;border-radius:0 0 12px 12px;background:#fff}.map-label{position:absolute;top:16px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#fffffffa,#f8fafcfa);padding:10px 20px;border-radius:24px;font-weight:600;font-size:13px;letter-spacing:.3px;z-index:1000;box-shadow:0 4px 12px #0000001a,0 2px 4px #0000000f;pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.8);color:#1e293b}.map-container{flex:1;position:relative}.loading,.error{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;text-align:center;padding:20px;color:#64748b}.loading{font-size:16px;font-weight:500}.error{color:#ef4444}.error h3{margin-bottom:12px;font-size:20px;font-weight:600}.error p{margin:6px 0;color:#64748b}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
