*{box-sizing:border-box;padding:0;margin:0}:root{--bg-primary:#0a0a0a;--bg-secondary:#161616;--bg-tertiary:#1e1e1e;--text-primary:#f5f5f5;--text-secondary:#a3a3a3;--text-muted:#666;--border-color:#2a2a2a;--border-subtle:#222;--shadow:rgba(0,0,0,.4);--shadow-lg:rgba(0,0,0,.6);--accent:#3a9f0d;--accent-hover:#49b51a;--card-radius:16px;--card-radius-sm:12px;--card-radius-xs:8px;color-scheme:dark}[data-theme=light]{--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-tertiary:#f0f0f0;--text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#999;--border-color:#e5e5e5;--border-subtle:#eee;--shadow:rgba(0,0,0,.06);--shadow-lg:rgba(0,0,0,.12);--accent:#3a9f0d;--accent-hover:#2f8a0a;color-scheme:light}@media (prefers-color-scheme:light){:root:not([data-theme]){--bg-primary:#f8f9fa;--bg-secondary:#fff;--bg-tertiary:#f0f0f0;--text-primary:#1a1a1a;--text-secondary:#666;--text-muted:#999;--border-color:#e5e5e5;--border-subtle:#eee;--shadow:rgba(0,0,0,.06);--shadow-lg:rgba(0,0,0,.12);--accent:#3a9f0d;--accent-hover:#2f8a0a;color-scheme:light}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color .3s,color .3s}.container{max-width:1200px;margin:0 auto;padding:2rem}.header{justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.header,.header-left{display:flex;align-items:center}.header-left{gap:1rem}.header h1{font-size:1.75rem;color:var(--text-primary)}.header-actions{gap:.75rem}.header-actions,.theme-toggle{display:flex;align-items:center}.theme-toggle{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:.5rem;cursor:pointer;justify-content:center;transition:all .2s;color:var(--text-primary)}.theme-toggle:hover{border-color:var(--accent)}.theme-toggle svg{width:20px;height:20px}.feedback-grid{display:grid;grid-gap:1rem;gap:1rem}.feedback-card{background:var(--bg-secondary);border-radius:var(--card-radius-sm);border:1px solid var(--border-subtle);padding:1.5rem;box-shadow:0 2px 8px var(--shadow);transition:border-color .2s,box-shadow .2s}.feedback-card:hover{border-color:var(--border-color);box-shadow:0 4px 12px var(--shadow-lg)}.feedback-card .type{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;margin-bottom:.75rem}.feedback-card .type.like{background-color:#166534;color:#dcfce7}.feedback-card .type.issue{background-color:#991b1b;color:#fee2e2}.feedback-card .type.what_you_would_like_to_see{background-color:#1e40af;color:#dbeafe}[data-theme=light] .feedback-card .type.like{background-color:#dcfce7;color:#166534}[data-theme=light] .feedback-card .type.issue{background-color:#fee2e2;color:#991b1b}[data-theme=light] .feedback-card .type.what_you_would_like_to_see{background-color:#dbeafe;color:#1e40af}@media (prefers-color-scheme:light){:root:not([data-theme]) .feedback-card .type.like{background-color:#dcfce7;color:#166534}:root:not([data-theme]) .feedback-card .type.issue{background-color:#fee2e2;color:#991b1b}:root:not([data-theme]) .feedback-card .type.what_you_would_like_to_see{background-color:#dbeafe;color:#1e40af}}.feedback-card .content{color:var(--text-primary);margin-bottom:.75rem;line-height:1.5}.feedback-card .meta{font-size:.875rem;color:var(--text-secondary)}.feedback-card .timestamp{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;opacity:.8}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem;background-color:var(--bg-primary)}.auth-container h1{font-size:1.5rem;color:var(--text-primary)}.auth-container p{color:var(--text-secondary)}.sign-in-btn{background-color:var(--accent);color:#fff;padding:.75rem 1.5rem;border-radius:8px;border:none;font-size:1rem;cursor:pointer;transition:background-color .2s}.sign-in-btn:hover{background-color:var(--accent-hover)}.error-message{background-color:#991b1b;color:#fee2e2;padding:1rem;border-radius:8px;text-align:center}[data-theme=light] .error-message{background-color:#fee2e2;color:#991b1b}@media (prefers-color-scheme:light){:root:not([data-theme]) .error-message{background-color:#fee2e2;color:#991b1b}}.loading{text-align:center;padding:2rem;color:var(--text-secondary)}.filter-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-tab{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-size:.875rem;transition:all .2s}.filter-tab.active,.filter-tab:hover{border-color:var(--accent)}.filter-tab.active{background-color:var(--accent);color:#fff}.section-toggle{display:flex;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.section-btn{padding:.75rem 1.5rem;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s}.section-btn.active,.section-btn:hover{border-color:var(--accent)}.section-btn.active{background-color:var(--accent);color:#fff}.filter-dropdowns{display:flex;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.filter-dropdown{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.875rem;cursor:pointer;min-width:180px;transition:all .2s}.filter-dropdown:focus,.filter-dropdown:hover{border-color:var(--accent)}.filter-dropdown:focus{outline:none;box-shadow:0 0 0 2px rgba(58,159,13,.25)}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:1rem;gap:1rem}.user-card{background:var(--bg-secondary);border-radius:var(--card-radius-sm);border:1px solid var(--border-subtle);padding:1.25rem;box-shadow:0 2px 8px var(--shadow);transition:border-color .2s,box-shadow .2s}.user-card:hover{border-color:var(--border-color);box-shadow:0 4px 12px var(--shadow-lg)}.user-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.user-info{display:flex;flex-direction:column;gap:.35rem}.user-info p{font-size:.875rem;color:var(--text-secondary)}.user-info .label{font-weight:500;color:var(--text-primary)}.user-count{margin-top:1rem;text-align:center;font-size:.875rem;color:var(--text-secondary)}.chart-container{background:var(--bg-secondary);border-radius:var(--card-radius-sm);border:1px solid var(--border-subtle);padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px var(--shadow)}.chart-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1.25rem}.bar-chart{flex-direction:column}.bar-chart,.bar-row{display:flex;gap:.75rem}.bar-row{align-items:center}.bar-label{flex:0 0 120px;font-size:.875rem;color:var(--text-primary);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1 1;height:24px;background:var(--bg-primary);border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:4px;transition:width .3s ease;min-width:2px}.bar-value{flex:0 0 40px;font-size:.875rem;font-weight:600;color:var(--text-primary);text-align:right}.landing-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.spinner-large{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.landing-page{min-height:100vh;display:flex;flex-direction:column}.landing-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.landing-brand{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.landing-nav-actions{display:flex;gap:1rem;align-items:center}.landing-sign-in{color:var(--text-primary);text-decoration:none;padding:.5rem 1rem;border-radius:8px;transition:background .2s}.landing-sign-in:hover{background:var(--bg-primary)}.landing-sign-up{background:var(--accent);color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:8px;transition:background .2s}.landing-sign-up:hover{background:var(--accent-hover)}.landing-hero{flex:1 1;display:flex;align-items:center;justify-content:center;gap:4rem;padding:4rem 2rem;max-width:1200px;margin:0 auto}.hero-content{max-width:500px}.hero-content h1{font-size:3rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem;color:var(--text-primary)}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}.hero-description{font-size:1rem;color:var(--text-tertiary);line-height:1.7}.hero-card-text{font-size:1.25rem;font-weight:600;color:var(--text-secondary);margin-top:.5rem}.hero-actions{display:flex;gap:1rem}.hero-cta{background:var(--accent);color:#fff;text-decoration:none;padding:1rem 2rem;border-radius:8px;font-weight:600;font-size:1.1rem;transition:background .2s}.hero-cta:hover{background:var(--accent-hover)}.hero-secondary{color:var(--text-primary);text-decoration:none;padding:1rem 2rem;border-radius:8px;font-weight:600;font-size:1.1rem;border:2px solid var(--border-color);transition:border-color .2s}.hero-secondary:hover{border-color:var(--accent)}.hero-visual{flex-shrink:0}.hero-card{background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:2.5rem 2rem;box-shadow:0 8px 32px var(--shadow-lg);text-align:center}.hero-bulb{margin-bottom:1rem}.hero-stats{text-align:center}.stat{display:flex;align-items:baseline;justify-content:center;gap:.5rem}.stat-value{font-size:2.5rem;font-weight:700;color:var(--text-primary)}.stat-unit{font-size:1rem}.stat-label,.stat-unit{color:var(--text-secondary)}.stat-label{font-size:.875rem;margin-top:.25rem}.landing-features{background:var(--bg-primary);padding:5rem 2rem}.landing-features h2{text-align:center;font-size:2rem;margin-bottom:3rem;color:var(--text-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2rem;gap:2rem;max-width:1000px;margin:0 auto}.feature-card{text-align:center;padding:2rem;background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);transition:border-color .2s,box-shadow .2s}.feature-card:hover{border-color:var(--border-color);box-shadow:0 4px 16px var(--shadow)}.feature-icon{width:56px;height:56px;background:var(--bg-tertiary);border-radius:var(--card-radius-sm);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;color:var(--accent)}.feature-card h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--text-primary)}.feature-card p{color:var(--text-secondary);line-height:1.6}.landing-footer{text-align:center;padding:2rem;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem}.footer-links{display:flex;justify-content:center;gap:2rem;margin-bottom:1rem}.footer-links a{color:var(--text-secondary);text-decoration:none;font-size:.875rem;transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-links a:focus{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.auth-page{align-items:center;justify-content:center;padding:2rem}.auth-page,.dashboard-layout{min-height:100vh;display:flex;background:var(--bg-primary)}.dashboard-layout{flex-direction:column}.dashboard-nav{display:flex;justify-content:space-between;align-items:center;padding:.875rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);position:-webkit-sticky;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px var(--shadow)}.nav-brand{font-weight:700;font-size:1.1rem}.nav-brand a{text-decoration:none}.brand-text,.nav-brand a{color:var(--text-primary)}.nav-links{display:flex;gap:.5rem}.nav-item{color:var(--text-secondary);text-decoration:none;padding:.5rem 1.125rem;border-radius:var(--card-radius-xs);font-size:.875rem;font-weight:500;transition:all .2s}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent);color:#fff}.nav-item.admin-link{color:var(--accent)}.nav-item.admin-link:hover{background:rgba(58,159,13,.12)}.nav-item.admin-link.active{background:var(--accent);color:#fff}.nav-actions{display:flex;align-items:center;gap:.75rem}.sign-out-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.875rem;transition:all .2s}.sign-out-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.dashboard-main{flex:1 1;padding:2.5rem 2rem;max-width:1200px;margin:0 auto;width:100%}.home-container{max-width:900px;margin:0 auto;padding:0 1rem}.coming-soon-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.coming-soon-page h1{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.coming-soon-page p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.home-header{text-align:center;margin-bottom:2.5rem;padding-top:.5rem}.home-header h1{font-size:1.75rem;font-weight:600;margin-bottom:.75rem;letter-spacing:-.02em}.grid-region{display:inline-block;background:var(--bg-tertiary);padding:.375rem 1rem;border-radius:var(--card-radius-xs);font-size:.8rem;font-weight:500;color:var(--text-secondary);border:1px solid var(--border-subtle);letter-spacing:.02em;text-transform:uppercase}.visualizations-placeholder{display:grid;grid-gap:2rem;gap:2rem;margin-bottom:2rem}.graph-placeholder,.lightbulb-placeholder{background:var(--bg-secondary);border-radius:12px;padding:3rem 2rem;text-align:center;border:2px dashed var(--border-color)}.placeholder-icon{margin-bottom:1rem;color:var(--text-secondary);opacity:.5}.placeholder-text{font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem}.placeholder-subtext{font-size:.875rem;color:var(--text-secondary)}.setup-prompt{text-align:center;padding:4rem 2rem;background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);box-shadow:0 2px 8px var(--shadow)}.setup-prompt h2{margin-bottom:1rem;font-weight:600}.setup-prompt p{color:var(--text-secondary);margin-bottom:2rem;max-width:400px;margin-left:auto;margin-right:auto;line-height:1.6}.cta-button{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;padding:.875rem 1.75rem;border-radius:var(--card-radius-xs);font-weight:600;font-size:.95rem;transition:background .2s,transform .15s}.cta-button:hover{background:var(--accent-hover);transform:translateY(-1px)}.location-switcher{text-align:center;padding:1.25rem 1.5rem;background:var(--bg-secondary);border-radius:var(--card-radius-sm);border:1px solid var(--border-subtle);margin-top:1.5rem;box-shadow:0 2px 8px var(--shadow)}.location-switcher p{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem}.manage-link{color:var(--accent);text-decoration:none;font-weight:500;font-size:.9rem}.manage-link:hover{text-decoration:underline}.visualizations{display:grid;grid-template-columns:minmax(280px,1fr) minmax(400px,2fr);grid-gap:1.5rem;gap:1.5rem;margin-bottom:1.5rem}@media (max-width:900px){.visualizations{grid-template-columns:1fr;gap:1.25rem}}.lightbulb-container{display:flex;justify-content:center;align-items:center;background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:2rem 1.5rem;min-height:340px;box-shadow:0 2px 8px var(--shadow);transition:border-color .2s,box-shadow .2s}.lightbulb-container:hover{border-color:var(--border-color);box-shadow:0 4px 16px var(--shadow-lg)}.lightbulb-container.compact{padding-top:1rem}.lightbulb-container svg{max-width:100%;height:auto}.graph-loading,.lightbulb-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:3rem 2rem;text-align:center;min-height:300px;box-shadow:0 2px 8px var(--shadow)}.graph-loading p,.lightbulb-loading p{margin-top:1.25rem;color:var(--text-secondary);font-size:.9rem}.loading-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.graph-forecast-container{background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:1.75rem 1.5rem 1.5rem;min-height:300px;box-shadow:0 2px 8px var(--shadow);transition:border-color .2s,box-shadow .2s}.graph-forecast-container:hover{border-color:var(--border-color);box-shadow:0 4px 16px var(--shadow-lg)}.graph-forecast-container svg{width:100%;height:auto}.grad-forecast-container{background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:1.25rem 1.75rem 1.5rem;box-shadow:0 2px 8px var(--shadow);transition:border-color .2s,box-shadow .2s}.grad-forecast-container:hover{border-color:var(--border-color);box-shadow:0 4px 16px var(--shadow-lg)}.grad-forecast-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;text-align:center}.grad-forecast-container svg{width:100%;height:auto;display:block}.grad-forecast-loading{background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:2rem;display:flex;align-items:center;justify-content:center;min-height:100px;box-shadow:0 2px 8px var(--shadow)}.places-container{max-width:1400px;margin:0 auto;padding:0 2rem}.places-header{margin-bottom:1rem;text-align:center;padding-top:0}.places-header h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem;letter-spacing:-.02em;background:linear-gradient(135deg,var(--text-primary) 0,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.places-subtitle{color:var(--text-secondary);font-size:.875rem}.search-section{margin-bottom:1rem}.search-placeholder{position:relative}.search-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--card-radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;transition:border-color .2s,box-shadow .2s;box-shadow:0 2px 8px var(--shadow)}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(58,159,13,.15)}.search-input:disabled{opacity:.6;cursor:not-allowed}.search-hint{position:absolute;right:1.25rem;top:50%;transform:translateY(-50%);font-size:.75rem;color:var(--text-muted);background:var(--bg-tertiary);padding:.375rem .75rem;border-radius:var(--card-radius-xs)}.empty-state{text-align:center;padding:4rem 2rem;background:var(--bg-secondary);border-radius:var(--card-radius);border:2px dashed var(--border-color);box-shadow:0 2px 8px var(--shadow)}.empty-icon{margin-bottom:1.5rem;color:var(--accent);opacity:.6}.empty-icon svg{width:80px;height:80px}.empty-state h2{margin-bottom:.75rem;font-size:1.5rem}.empty-state p{color:var(--text-secondary);max-width:400px;margin:0 auto;line-height:1.6}.location-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));grid-gap:1rem;gap:1rem}.location-card{display:flex;align-items:center;gap:1.5rem;background:var(--bg-secondary);border-radius:var(--card-radius);padding:1.5rem 1.75rem;transition:transform .2s,box-shadow .2s,border-color .2s;border:1px solid var(--border-subtle);box-shadow:0 2px 8px var(--shadow)}.location-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow-lg);border-color:var(--border-color)}.location-info{gap:1.25rem;min-width:200px}.location-info,.location-rank{display:flex;align-items:center}.location-rank{width:40px;height:40px;background:linear-gradient(135deg,var(--accent) 0,var(--accent-hover) 100%);border-radius:12px;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff;flex-shrink:0}.location-details{flex:1 1}.location-name{font-weight:700;font-size:1.15rem;margin-bottom:.35rem;color:var(--text-primary)}.location-grid{font-size:.85rem;color:var(--text-secondary);background:var(--bg-primary);padding:.25rem .6rem;border-radius:6px;display:inline-block;font-family:monospace}.location-graph-placeholder{width:120px;text-align:center}.mini-graph-placeholder{opacity:.5}.graph-hint{font-size:.625rem;color:var(--text-secondary)}.location-graph{flex:1 1;min-width:300px;max-width:450px;background:var(--bg-tertiary);border-radius:var(--card-radius-sm);border:1px solid var(--border-subtle);padding:.875rem 1.125rem}.graph-label{display:block;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.625rem;text-align:center}.small-graph-container{width:100%;height:auto}.small-graph-container.with-header{display:flex;flex-direction:column}.small-graph-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;padding:0 .25rem}.small-graph-title{display:flex;flex-direction:column;gap:.25rem}.small-graph-city{font-weight:700;font-size:.95rem;color:var(--text-primary)}.small-graph-grid{font-size:.7rem;color:var(--text-secondary);background:var(--bg-primary);padding:.15rem .4rem;border-radius:4px;font-family:monospace;display:inline-block;width:-moz-fit-content;width:fit-content}.small-graph-current-value{font-weight:700;font-size:1.2rem;font-family:monospace;margin-right:1.75rem}.small-graph-container svg{width:100%;height:auto;display:block}.location-card-graph{position:relative;background:var(--bg-tertiary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:.875rem 1rem;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 2px 8px var(--shadow)}.location-card-graph:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--shadow-lg);border-color:var(--border-color)}.location-card-graph.dragging{opacity:.5;transform:scale(.98)}.location-card-graph.drag-over{border-color:var(--accent);border-style:dashed;background:rgba(58,159,13,.12)}[data-theme=light] .location-card-graph.drag-over{background:rgba(58,159,13,.05)}@media (prefers-color-scheme:light){:root:not([data-theme]) .location-card-graph.drag-over{background:rgba(58,159,13,.05)}}.graph-drag-handle{position:absolute;top:50%;left:-.25rem;transform:translateY(-50%);cursor:-webkit-grab;cursor:grab;color:var(--text-muted);opacity:0;transition:opacity .2s;padding:.5rem .25rem;z-index:2}.location-card-graph:hover .graph-drag-handle{opacity:.5}.graph-drag-handle:hover{opacity:1!important}.graph-drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.graph-delete-btn{position:absolute;top:.5rem;right:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);padding:.4rem;cursor:pointer;border-radius:6px;transition:all .2s;opacity:0;z-index:2}.location-card-graph:hover .graph-delete-btn{opacity:1}.graph-delete-btn:hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.4);color:#f87171}[data-theme=light] .graph-delete-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}@media (prefers-color-scheme:light){:root:not([data-theme]) .graph-delete-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}}.graph-delete-btn:disabled{opacity:.3!important;cursor:not-allowed}.graph-delete-btn svg{display:block}.spinner-small{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;display:block}.small-graph-loading{width:100%;min-height:120px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.75rem;padding:.875rem 1rem}.small-graph-loading .small-graph-header{width:100%}.loading-spinner-small{width:28px;height:28px;border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.delete-btn{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);padding:.75rem;cursor:pointer;border-radius:12px;transition:all .2s;flex-shrink:0}.delete-btn:hover{background:rgba(239,68,68,.2);border-color:rgba(239,68,68,.4);color:#fca5a5}[data-theme=light] .delete-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#991b1b}@media (prefers-color-scheme:light){:root:not([data-theme]) .delete-btn:hover{background:#fee2e2;border-color:#fca5a5;color:#991b1b}}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn svg{display:block}.spinner{width:18px;height:18px;border:2px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;display:inline-block}.places-settings{margin-top:2rem;padding:.75rem 1.25rem;background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);box-shadow:0 2px 8px var(--shadow)}.places-settings-top{margin-top:0;margin-bottom:1rem}.toggle-label{display:flex;align-items:center;gap:1rem;font-weight:500}.toggle-hint{font-size:.8rem;color:var(--text-secondary);margin-left:auto;background:var(--bg-primary);padding:.25rem .75rem;border-radius:6px}.scale-toggle-section{position:relative;display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}.scale-toggle-header{display:flex;align-items:center;gap:.375rem}.scale-toggle-label{font-weight:500;font-size:.875rem;color:var(--text-primary)}.info-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:color .2s,background-color .2s}.info-btn:hover{color:var(--accent);background-color:rgba(58,159,13,.12)}.info-btn svg{width:16px;height:16px}.scale-toggle-control{display:flex;align-items:center;gap:.75rem}.scale-option{font-size:.85rem;color:var(--text-secondary);transition:color .2s,font-weight .2s}.scale-option.active{color:var(--accent);font-weight:600}.toggle-switch{position:relative;width:52px;height:28px;background:var(--border-color);border:none;border-radius:14px;cursor:pointer;transition:background-color .2s;padding:0}.toggle-switch:hover{background:var(--text-secondary)}.toggle-switch.active{background:var(--accent)}.toggle-switch.loading{opacity:.6;cursor:wait}.toggle-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 2px 4px rgba(0,0,0,.2)}.toggle-switch.active .toggle-thumb{transform:translateX(24px)}.scale-info-tooltip{position:absolute;top:calc(100% + .75rem);left:50%;transform:translateX(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius-sm);padding:1.25rem;width:min(400px,calc(100vw - 2rem));box-shadow:0 8px 32px var(--shadow-lg);z-index:100}.scale-info-tooltip:before{top:-8px;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:8px solid var(--border-color)}.scale-info-tooltip:after,.scale-info-tooltip:before{content:"";position:absolute;left:50%;transform:translateX(-50%)}.scale-info-tooltip:after{top:-6px;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid var(--bg-primary)}.tooltip-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .2s,background-color .2s}.tooltip-close:hover{color:var(--text-primary);background-color:var(--bg-secondary)}.scale-info-tooltip h4{margin:0 0 1rem;font-size:1rem;color:var(--text-primary)}.tooltip-content{display:flex;flex-direction:column;gap:1rem}.tooltip-option strong{display:block;color:var(--accent);font-size:.9rem;margin-bottom:.25rem}.tooltip-option p{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.drag-handle{cursor:-webkit-grab;cursor:grab;padding:.5rem;color:var(--text-secondary);opacity:.5;transition:opacity .2s,color .2s;flex-shrink:0}.drag-handle:hover{opacity:1;color:var(--accent)}.drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing}.location-card[draggable=true]{cursor:default}.location-card.dragging{opacity:.5;transform:scale(.98);box-shadow:0 4px 12px var(--shadow)}.location-card.drag-over{border-color:var(--accent);border-style:dashed;background:rgba(58,159,13,.12)}[data-theme=light] .location-card.drag-over{background:rgba(58,159,13,.05)}@media (prefers-color-scheme:light){:root:not([data-theme]) .location-card.drag-over{background:rgba(58,159,13,.05)}}.settings-container{max-width:700px;margin:0 auto;padding:0 1rem}.settings-header{margin-bottom:2rem;padding-top:.5rem}.settings-header h1{font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.settings-tabs{display:flex;gap:.375rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-subtle);padding-bottom:1rem;flex-wrap:wrap}.settings-tab{padding:.5rem 1rem;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;border-radius:var(--card-radius-xs);transition:all .2s}.settings-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.settings-tab.active{background:var(--accent);color:#fff}.settings-content{background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-subtle);padding:2rem;box-shadow:0 2px 8px var(--shadow)}.settings-section h2{font-size:1.25rem;margin-bottom:.5rem}.section-description{color:var(--text-secondary);margin-bottom:1.5rem}.unit-selectors{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.unit-group{flex:1 1;min-width:200px}.unit-group label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.unit-options{display:flex;gap:.5rem;flex-wrap:wrap}.unit-btn{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:8px;cursor:pointer;font-size:.875rem;transition:all .2s}.unit-btn.active,.unit-btn:hover{border-color:var(--accent)}.unit-btn.active{background:var(--accent);color:#fff}.unit-divider{font-size:2rem;color:var(--text-secondary);padding:0 .5rem}.unit-preview{padding:1rem;background:var(--bg-primary);border-radius:8px;text-align:center}.unit-preview strong{font-size:1.25rem}.toggle-option{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid var(--border-color)}.toggle-info{display:flex;flex-direction:column;gap:.25rem}.toggle-title{font-weight:600}.toggle-description{font-size:.875rem;color:var(--text-secondary)}.switch{position:relative;display:inline-block;width:50px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color);border-radius:28px}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;border-radius:50%}input:checked+.slider{background-color:var(--accent)}input:checked+.slider:before{transform:translateX(22px)}.color-preview{margin-top:1.5rem;display:flex;align-items:center;gap:1rem}.color-swatches{display:flex;gap:.5rem}.swatch{padding:.5rem 1rem;border-radius:8px;color:#fff;font-size:.875rem;font-weight:500}.account-info{margin-bottom:1.5rem}.info-row{display:flex;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.info-label{color:var(--text-secondary)}.info-value{font-weight:500}.input-group{margin-bottom:1.5rem}.input-group label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.input-with-button{display:flex;gap:.5rem}.input-with-button input{flex:1 1;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem}.input-with-button input:focus{outline:none;border-color:var(--accent)}.save-btn{padding:.75rem 1.5rem;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:background .2s}.save-btn:hover:not(:disabled){background:var(--accent-hover)}.save-btn:disabled{opacity:.5;cursor:not-allowed}.danger-zone{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.danger-zone h3{font-size:1rem;margin-bottom:1rem;color:var(--text-secondary)}.feedback-type-selector{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.feedback-type{padding:.75rem 1rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:8px;cursor:pointer;font-size:.875rem;transition:all .2s}.feedback-type:hover{border-color:var(--accent)}.feedback-type.active{border-width:2px}.feedback-type.active.like{border-color:#166534;background:#dcfce7;color:#166534}.feedback-type.active.issue{border-color:#991b1b;background:#fee2e2;color:#991b1b}.feedback-type.active.suggestion{border-color:#1e40af;background:#dbeafe;color:#1e40af}.feedback-input{width:100%;padding:1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:1rem}.feedback-input:focus{outline:none;border-color:var(--accent)}.submit-feedback-btn{width:100%;padding:1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:1rem;transition:background .2s}.submit-feedback-btn:hover:not(:disabled){background:var(--accent-hover)}.submit-feedback-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-success{margin-top:1rem;padding:1rem;background:#dcfce7;color:#166534;border-radius:8px;text-align:center}.about-content{line-height:1.6}.about-content p{margin-bottom:1.5rem;color:var(--text-secondary)}.about-links{display:flex;gap:1rem;margin-bottom:2rem}.about-links a{color:var(--accent);text-decoration:none}.about-links a:hover{text-decoration:underline}.version-info{padding-top:1rem;border-top:1px solid var(--border-color);font-size:.875rem;color:var(--text-secondary)}.nav-link{color:var(--accent);text-decoration:none;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;transition:background .2s}.nav-link:hover{background:rgba(58,159,13,.12)}@media (max-width:768px){.landing-hero{flex-direction:column;gap:2rem;text-align:center}.hero-content h1{font-size:1.75rem}.hero-actions{justify-content:center;flex-wrap:wrap}.footer-links{gap:1.5rem}.dashboard-nav{flex-wrap:wrap;gap:.75rem;padding:.875rem 1rem}.nav-links{order:3;width:100%;justify-content:center}.dashboard-main{padding:1.5rem 1rem}.home-container,.places-container,.settings-container{padding:0 .5rem}.settings-tabs{justify-content:center}.unit-selectors{flex-direction:column;align-items:stretch}.unit-divider{text-align:center}.places-header h1{font-size:1.5rem}.places-subtitle{font-size:.9rem}.home-header h1{font-size:1.5rem}.location-card{flex-direction:column;align-items:stretch;padding:1.25rem;gap:1rem}.location-info{min-width:unset}.location-graph-placeholder{width:100%;margin-top:.5rem}.location-graph{width:100%;min-width:unset;max-width:100%;margin:0}.small-graph-loading{width:100%}.small-graph-city{font-size:.9rem}.small-graph-current-value{font-size:1.1rem;margin-right:1.5rem}.location-list{grid-template-columns:1fr}.delete-btn{align-self:flex-end}.drag-handle{position:absolute;top:.75rem;left:.75rem}.location-card{position:relative;padding-left:2.5rem}.location-card-graph{padding:.75rem}.graph-drag-handle{opacity:.4}.graph-delete-btn{opacity:1}.visualizations{gap:1rem}.graph-forecast-container,.lightbulb-container{min-height:260px}.grad-forecast-container{padding:1rem 1.25rem 1.25rem}}.support-page{min-height:100vh;background:var(--bg-primary);padding:2rem}.support-container{max-width:800px;margin:0 auto}.support-nav{margin-bottom:1.5rem}.back-to-home{display:inline-flex;align-items:center;color:var(--accent);text-decoration:none;font-size:.95rem;font-weight:500;transition:color .2s}.back-to-home:hover{color:var(--accent-hover);text-decoration:underline}.support-header{text-align:center;margin-bottom:3rem}.support-header h1{font-size:2.5rem;color:var(--text-primary);margin-bottom:.5rem}.support-header p{font-size:1.1rem;color:var(--text-secondary)}.support-section{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--card-radius);padding:2rem;margin-bottom:1.5rem;box-shadow:0 2px 8px var(--shadow)}.support-section h2{font-size:1.5rem;color:var(--text-primary);margin-bottom:1rem}.support-section p{color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}.support-section a{color:var(--accent);text-decoration:none}.support-section a:hover{text-decoration:underline}.support-section ul{color:var(--text-secondary);padding-left:1.5rem;line-height:1.8}.faq-item{border:1px solid var(--border-subtle);border-radius:var(--card-radius-sm);padding:1rem;margin-bottom:.75rem;background:var(--bg-tertiary);transition:border-color .2s}.faq-item:hover{border-color:var(--border-color)}.faq-item summary{font-weight:600;color:var(--text-primary);cursor:pointer;padding:.5rem;list-style:none;display:flex;justify-content:space-between;align-items:center}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary:after{content:"+";font-size:1.25rem;font-weight:400;color:var(--text-secondary);transition:transform .2s}.faq-item[open] summary:after{content:"-"}.faq-item p{padding:1rem .5rem .5rem;margin-bottom:0}@media (max-width:768px){.support-page{padding:1rem}.support-header h1{font-size:2rem}.support-section{padding:1.5rem}}