:root{--color-primary: #04315A;--color-secondary: #4991C6;--color-tertiary: #e6f7ff;--color-accent: white;--color-background: whitesmoke;--color-text-primary: darkslategray;--color-text-secondary: grey;--color-shadow: rgba(0, 0, 0, .2);--color-overlay: rgba(0, 0, 0, .5);--color-highlight: #646cff;--color-border: #ccc}[data-theme=dark]{--color-primary: #78BBE2;--color-secondary: #4991C6;--color-tertiary: #1a2a3a;--color-accent: #1e1e2e;--color-background: #141420;--color-text-primary: #e0e0e0;--color-text-secondary: #a0a0a0;--color-shadow: rgba(0, 0, 0, .5);--color-overlay: rgba(0, 0, 0, .7);--color-highlight: #646cff;--color-border: #3a3a4a}:root{--text-heading: var(--color-primary);--text-body: var(--color-text-primary);--text-muted: var(--color-text-secondary);--page-background: var(--color-background);--navbar-bg: var(--color-accent);--navbar-shadow: var(--color-shadow);--navbar-title: var(--color-primary);--navbar-subtitle: var(--color-secondary);--navbar-link: var(--color-primary);--navbar-link-hover: var(--color-secondary);--navbar-link-secondary: var(--color-text-secondary);--button-bg: var(--color-primary);--button-text: var(--color-accent);--button-hover-bg: var(--color-secondary);--card-bg: var(--color-accent);--card-shadow: var(--color-shadow);--modal-bg: var(--color-accent);--modal-overlay: var(--color-overlay);--modal-text: var(--color-primary);--modal-close: var(--color-text-primary);--input-bg: var(--color-accent);--input-border: var(--color-text-secondary);--input-text: var(--color-text-secondary);--form-heading: var(--color-primary);--table-header-bg: var(--color-primary);--table-header-text: var(--color-accent);--table-border: var(--color-text-secondary);--table-row-alt: var(--color-tertiary);--table-text: var(--color-text-primary);--profile-bg: var(--color-accent);--profile-shadow: var(--color-shadow);--profile-text: var(--color-text-primary);--profile-border: var(--color-secondary);--logo-hover-glow: var(--color-highlight);--chart-line-color: var(--color-secondary);--chart-color-1: #4991C6;--chart-color-2: #E6733C;--chart-color-3: #5BAA6A;--chart-color-4: #C75B8E;--chart-color-5: #8B6FC0;--chart-color-6: #D4A843;--change-up: #2e9e5a;--change-down: #d43d3d;--edit-overlay-bg: rgba(0, 0, 0, .35);--edit-overlay-text-bg: rgba(0, 0, 0, .45);--edit-overlay-text: #fff;--footer-text: var(--color-text-secondary);--border-radius: 8px}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;color:var(--text-body);background-color:var(--page-background)}body{margin:0;overflow:hidden}h1{font-size:3.2em;color:var(--text-heading)}button{width:100%;padding:.75rem 1rem;background-color:var(--button-bg);color:var(--button-text);border:none;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;box-sizing:border-box}button:hover{background-color:var(--button-hover-bg)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.dropdown-label{display:block;margin-bottom:.35rem}select{background-color:var(--input-bg);color:var(--text-body);border:1px solid var(--input-border);border-radius:var(--border-radius)}select option{background-color:var(--input-bg);color:var(--text-body)}.navbar{box-sizing:border-box;position:fixed;top:0;left:0;z-index:1000;width:100%;background-color:var(--navbar-bg);box-shadow:0 2px 6px var(--navbar-shadow);padding:.75rem 1.5rem;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1rem}.panel-link{display:flex;align-items:center;gap:.75rem;text-decoration:none}.panel-logo{height:34px}.navbar-datafunn-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}.navbar-datafunn-title{color:var(--navbar-title);font-size:1.5rem}.navbar-datafunn-subtitle{color:var(--navbar-subtitle);font-size:.65rem}.navbar-center{display:flex;gap:1.75rem;justify-content:center;align-items:center;justify-self:center;min-width:0;overflow:visible}.navbar-center .navbar-link{color:var(--navbar-link);font-size:1rem;text-decoration:none}.navbar-center .navbar-link:hover{color:var(--navbar-link-hover)}.navbar-right{display:flex;gap:.75rem;align-items:center;justify-self:end;min-width:0}.navbar-right .navbar-link{color:var(--navbar-link-secondary);font-size:1rem;text-decoration:none}.navbar-right .navbar-link:hover{color:var(--navbar-link-hover)}.navbar-right .panel-link{color:var(--navbar-link-secondary);font-size:1rem;text-decoration:none}.navbar-right .panel-link:hover{color:var(--navbar-link-hover)}.navbar-edit-btn{width:auto;padding:.4rem 1rem;font-size:.85rem;border-radius:var(--border-radius);background-color:var(--button-bg);color:var(--button-text);border:none;cursor:pointer}.navbar-edit-btn:hover{background-color:var(--button-hover-bg)}.profile-photo{border-radius:50%;height:32px;width:auto;flex-shrink:0;border:1px solid var(--navbar-link-secondary)}@media(max-width:600px){.navbar{padding:.5rem 1rem}.navbar-center{gap:1rem}.navbar-datafunn-title{font-size:1.2rem}}#root{margin:0;height:100%}.panel-page{padding:.75rem 1.5rem;max-width:100%;flex:1;min-height:0;box-sizing:border-box;overflow:hidden;display:flex;flex-direction:column}.panel-grid{width:100%;flex:1;min-height:0}@media(max-width:768px){.panel-page{padding:0 1rem}}.panel-tile{width:100%;border-radius:12px;box-shadow:0 2px 8px var(--card-shadow);background-color:var(--card-bg);color:var(--text-heading);position:relative;overflow:hidden;padding:.75rem;box-sizing:border-box}.panel-tile.tile-big,.panel-tile.tile-small,.panel-tile.tile-wide{height:100%}.panel-tile .chart-container{width:100%;height:100%}.panel-tile .data-table-container{width:100%;height:100%;overflow-y:auto}.panel-tile .data-table-container h2{font-size:.9rem;margin:0 0 .5rem}.panel-tile.editable{cursor:pointer}.panel-tile.editable:hover{box-shadow:0 4px 16px var(--card-shadow)}.panel-tile-edit-overlay{position:absolute;inset:0;background-color:var(--edit-overlay-bg);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:1}.panel-tile-edit-overlay span{color:var(--edit-overlay-text);font-size:.95rem;font-weight:600;padding:.4rem 1rem;background-color:var(--edit-overlay-text-bg);border-radius:var(--border-radius)}.panel-tile.tile-infobox .panel-tile-edit-overlay span{font-size:.6rem;padding:.2rem .4rem}.panel-tile-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.95rem}.series-entry{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;border:1px solid var(--input-border);border-radius:var(--border-radius);background-color:var(--page-background)}.series-header{display:flex;justify-content:space-between;align-items:center}.series-label{font-size:.85rem;font-weight:600;color:var(--text-heading)}.series-remove{width:auto;padding:0;background:none;border:none;font-size:1.3rem;color:var(--text-muted);cursor:pointer;line-height:1}.series-remove:hover{color:var(--text-body);background:none}.series-add{background:none;border:1px dashed var(--input-border);color:var(--text-muted);font-size:.85rem;padding:.5rem;cursor:pointer}.series-add:hover{border-color:var(--button-bg);color:var(--button-bg);background:none}.date-range-picker{display:flex;gap:1rem}.date-range-picker label{flex:1;display:flex;flex-direction:column;gap:.25rem;font-size:.9rem;color:var(--text-body)}.date-range-picker input[type=date]{padding:.5rem;border:1px solid var(--input-border);border-radius:var(--border-radius);font-size:.9rem;background-color:var(--input-bg);color:var(--input-text)}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--modal-overlay);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:var(--modal-bg);color:var(--modal-text);padding:2rem 2.5rem;border-radius:var(--border-radius);min-width:360px;max-width:480px;width:100%;position:relative;box-shadow:0 8px 30px var(--card-shadow);display:flex;flex-direction:column;gap:1rem}.modal-content h2{margin:0 0 .5rem;font-size:1.2rem;color:var(--text-heading);padding-right:2rem}.modal-close{position:absolute;top:.75rem;right:.75rem;width:2rem;height:2rem;padding:0;background:none;border:none;font-size:1.5rem;line-height:1;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-close:hover{background-color:var(--page-background);color:var(--text-body)}@media(max-width:480px){.modal-content{min-width:unset;width:95%;margin:1rem}}.data-table-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.data-table-container h2{margin:0 0 .5rem;font-size:.9rem;color:var(--text-heading);flex-shrink:0}.data-table-scroll{flex:1;overflow-y:auto;min-height:0}.data-table{width:100%;border-collapse:collapse;font-size:.8rem}.data-table thead{position:sticky;top:0;z-index:1}.data-table th,.data-table td{padding:.4rem .6rem;border:1px solid var(--table-border);text-align:left;color:var(--table-text)}.data-table th{background-color:var(--table-header-bg);color:var(--table-header-text);font-weight:600;-webkit-user-select:none;user-select:none;white-space:nowrap;position:relative}.th-content{cursor:pointer}.filter-icon{float:right;cursor:pointer;font-size:.7rem;opacity:.5;margin-left:.4rem}.filter-icon:hover,.filter-icon.active{opacity:1}.filter-popup{position:absolute;top:100%;right:0;background-color:var(--card-bg);border:1px solid var(--table-border);border-radius:var(--border-radius);padding:.4rem;box-shadow:0 2px 8px var(--card-shadow);z-index:10;min-width:140px}.filter-popup input{width:100%;padding:.3rem .4rem;border:1px solid var(--input-border);border-radius:var(--border-radius);font-size:.75rem;background-color:var(--input-bg);color:var(--input-text);box-sizing:border-box}.data-table tr:nth-child(2n){background-color:var(--table-row-alt)}.panel-tile.tile-infobox{padding:.5rem;display:flex;align-items:center;justify-content:center;container-type:size}.infobox-content{display:flex;flex-direction:column;align-items:center;gap:.05rem;width:100%;text-align:center}.infobox-label{font-size:5cqi;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;line-height:1.2}.infobox-value{font-size:12cqi;font-weight:700;color:var(--text-heading);line-height:1.2}.infobox-date{font-size:5cqi;color:var(--text-muted);margin-bottom:.15rem}.infobox-changes{display:flex;flex-direction:column;gap:0;width:100%}.infobox-change-row{display:flex;justify-content:space-between;align-items:center;font-size:5cqi;padding:.05rem .15rem}.change-period{color:var(--text-muted);font-weight:500}.infobox-change{font-weight:600}.change-up{color:var(--change-up)}.change-down{color:var(--change-down)}.change-neutral{color:var(--text-muted)}.layout-picker{display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.layout-option{width:auto;padding:.5rem 1rem;font-size:.85rem;background-color:var(--card-bg);color:var(--text-body);border:2px solid transparent;border-radius:var(--border-radius);cursor:pointer}.layout-option.active{border-color:var(--button-bg);color:var(--button-bg)}.layout-option:hover{background-color:var(--button-hover-bg);color:var(--button-text)}.form-container{width:320px;flex-shrink:0;padding:2rem;color:var(--form-heading);background-color:var(--card-bg);box-shadow:0 2px 6px var(--card-shadow);border-radius:var(--border-radius);display:flex;flex-direction:column;align-items:center;gap:1rem}.form-container h2{width:100%}.form-container form{width:100%;display:flex;flex-direction:column;gap:1rem}.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--input-border);border-radius:var(--border-radius);font-size:1rem;background-color:var(--input-bg);color:var(--input-text);box-sizing:border-box}input.form-input:-webkit-autofill{background-color:var(--input-bg);-webkit-box-shadow:0 0 0 1000px var(--input-bg) inset!important;-webkit-text-fill-color:var(--input-text)!important}.form-button{width:100%;padding:.75rem 1rem;background-color:var(--button-bg);color:var(--button-text);border:none;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;box-sizing:border-box}.google-signin-button{display:flex;gap:.75rem;align-items:center;width:100%;padding:.75rem 1rem;border:none;border-radius:var(--border-radius);font-size:1rem;cursor:pointer;box-sizing:border-box}.google-logo{height:24px}.form-page{display:flex;flex-direction:row;align-items:flex-start;box-sizing:border-box;padding:2rem;gap:2rem}.intro-section{flex:1;text-align:center}@media(max-width:768px){.form-page{flex-direction:column;padding:1rem}.form-container{width:100%}}.profile-page{display:flex;justify-content:center;align-items:flex-start;padding:3rem 2rem;gap:2rem;flex-wrap:wrap;max-width:900px;margin:0 auto}.profile-card{padding:2.5rem 2rem;color:var(--profile-text);background-color:var(--profile-bg);box-shadow:0 4px 20px var(--profile-shadow);border-radius:var(--border-radius);border:1px solid var(--profile-border)}.user-card{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:280px;flex:1;max-width:360px}.user-avatar-wrapper{display:flex;justify-content:center;width:100%;margin-bottom:1.25rem}.user-avatar-wrapper img{width:130px;height:130px;border-radius:50%;object-fit:cover;border:3px solid var(--profile-border);box-shadow:0 4px 12px var(--profile-shadow)}.user-name{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--text-heading);letter-spacing:-.01em}.user-email{margin:0 0 1rem;font-size:.95rem;color:var(--text-muted)}.user-roles{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap;justify-content:center}.role-badge{display:inline-flex;align-items:center;padding:.3rem .85rem;border-radius:20px;font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.role-superuser{background-color:var(--color-primary);color:var(--color-accent)}.role-staff{background-color:var(--color-secondary);color:var(--color-accent)}.logout{width:100%;padding:.75rem 1rem;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;background-color:var(--button-bg);color:var(--button-text);transition:background-color .2s ease;margin-top:.5rem}.settings-card{min-width:280px;flex:1;max-width:420px}.settings-card h2{margin-top:0;margin-bottom:1.5rem;font-size:1.3rem;font-weight:700;color:var(--text-heading)}.setting-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.6rem 0;border-bottom:1px solid var(--color-border)}.setting-row:last-child{border-bottom:none;margin-bottom:0}.setting-row label{font-weight:500;font-size:.95rem}.setting-row select{padding:.45rem .75rem;border-radius:var(--border-radius);border:1px solid var(--profile-border);background-color:var(--input-bg);color:var(--text-body);font-size:.95rem;cursor:pointer}@media(max-width:640px){.profile-page{flex-direction:column;align-items:stretch;padding:1.5rem 1rem}.user-card,.settings-card{max-width:100%}}.news-page{padding:2rem;max-width:900px;margin:0 auto}.news-page h1{margin:0 0 1.5rem}.news-empty{color:var(--text-muted)}.news-grid{display:flex;flex-direction:column;gap:1.5rem}.news-card{display:flex;background-color:var(--card-bg);border-radius:var(--border-radius);box-shadow:0 2px 8px var(--card-shadow);overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .2s}.news-card:hover{box-shadow:0 4px 16px var(--card-shadow)}.news-card-image{width:200px;object-fit:cover;flex-shrink:0}.news-card-body{padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.news-card-body h2{margin:0;font-size:1.2rem;color:var(--text-heading)}.news-card-meta{font-size:.8rem;color:var(--text-muted);margin:0}.news-card-excerpt{font-size:.95rem;color:var(--text-body);margin:0;line-height:1.5}.news-back-link{display:inline-block;margin-bottom:1.5rem;color:var(--button-bg);text-decoration:none;font-size:.9rem}.news-back-link:hover{color:var(--button-hover-bg)}.news-article h1{margin:0 0 .5rem}.news-article-meta{font-size:.85rem;color:var(--text-muted);margin:0 0 1.5rem}.news-article-image{width:100%;border-radius:var(--border-radius);margin-bottom:1.5rem}.news-article-content{line-height:1.8;color:var(--text-body);font-size:1rem}.news-article-content p{margin:0 0 1rem}@media(max-width:600px){.news-card{flex-direction:column}.news-card-image{width:100%;height:180px}}.contact-page{display:flex;flex-direction:row;align-items:flex-start;box-sizing:border-box;padding:2rem;gap:2rem}.contact-page .intro-section{flex:1;text-align:center}.contact-info{width:320px;flex-shrink:0;background-color:var(--card-bg);border-radius:var(--border-radius);box-shadow:0 2px 8px var(--card-shadow);padding:2rem;text-align:center}.contact-info h2{margin:0 0 .5rem;color:var(--text-heading)}.contact-info>p{color:var(--text-body);margin:0 0 1.5rem}.contact-details{display:flex;flex-direction:column;gap:1rem}.contact-item{display:flex;flex-direction:column;gap:.25rem}.contact-item strong{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.contact-item a{color:var(--button-bg);text-decoration:none;font-size:1rem}.contact-item a:hover{color:var(--button-hover-bg)}@media(max-width:768px){.contact-page{flex-direction:column;padding:1rem}.contact-info{width:100%}}.terms-page{max-width:720px;margin:0 auto;padding:2rem;color:var(--text-body)}.terms-page h1{font-size:1.8rem;color:var(--text-heading);margin:0 0 .25rem}.terms-updated{font-size:.85rem;color:var(--text-muted);margin:0 0 2rem}.terms-page section{margin-bottom:1.5rem}.terms-page h2{font-size:1.1rem;color:var(--text-heading);margin:0 0 .5rem}.terms-page p{line-height:1.6;margin:0}.footer{width:100%;padding:.5rem 0;color:var(--footer-text);text-align:center;font-size:.8rem;flex-shrink:0}.footer a{color:var(--footer-text);text-decoration:none}.footer a:hover{text-decoration:underline}
