html,body,#root{width:100%;height:100%;min-height:100%;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:18px;line-height:1.45}#root{box-sizing:border-box;flex-direction:column;display:flex}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#dc2626;--primary-dark:#b91c1c;--bg-dark:#1a1a2e;--bg-card:#16213e;--bg-card-hover:#1e3a5f;--text-light:#fff;--text-muted:#94a3b8;--border-color:#334155}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:#1a1a2e;background:var(--bg-dark);color:var(--text-light);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.loading-container{flex-direction:column;justify-content:center;align-items:center;height:100vh;display:flex}.loading-container>*+*{margin-top:1rem}.loading-spinner{border:4px solid #334155;border:4px solid var(--border-color);border-top-color:#dc2626;border-top-color:var(--primary-color);border-radius:50%;width:48px;height:48px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-container{background:linear-gradient(135deg,#1a1a2e 0%,#0f0f1a 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{background:#16213e;background:var(--bg-card);text-align:center;border:1px solid #334155;border:1px solid var(--border-color);border-radius:1rem;width:100%;max-width:400px;padding:3rem}.login-logo{margin-bottom:1.5rem}.logo-circle{background:#dc2626;background:var(--primary-color);color:#fff;border-radius:.75rem;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;font-weight:700;display:inline-flex}.login-card h1{margin-bottom:.5rem;font-size:1.75rem}.login-card .subtitle{color:var(--text-muted);margin-bottom:2rem}.login-card form{text-align:left}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-muted);margin-bottom:.5rem;font-size:.875rem;display:block}.form-group input{background:#1a1a2e;background:var(--bg-dark);border:1px solid #334155;border:1px solid var(--border-color);color:var(--text-light);width:100%;border-radius:.5rem;padding:.875rem 1rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{border-color:#dc2626;border-color:var(--primary-color);outline:none}.form-group input::placeholder{color:var(--text-muted)}.error-message{border:1px solid #dc2626;border:1px solid var(--primary-color);color:#fca5a5;background:rgba(220,38,38,.1);border-radius:.5rem;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.submit-btn{background:#dc2626;background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:.5rem;width:100%;padding:1rem;font-size:1rem;font-weight:600;transition:background .2s}.submit-btn:hover{background:#b91c1c;background:var(--primary-dark)}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.display-container{background:#1a1a2e;background:var(--bg-dark);flex-direction:column;height:100vh;display:flex}.display-header{background:#16213e;background:var(--bg-card);border-bottom:1px solid #334155;border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.header-logo{align-items:center;display:flex}.header-logo>*+*{margin-left:1rem}.logo-small{background:#dc2626;background:var(--primary-color);border-radius:.5rem;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;font-weight:700;display:flex}.logo-image{-o-object-fit:contain;object-fit:contain;width:auto;height:48px}.station-name{font-size:1.5rem;font-weight:600}.header-info{align-items:center;display:flex}.header-info>*+*{margin-left:2rem}.current-time{-webkit-font-feature-settings:"tnum";font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:2rem;font-weight:300}.last-refresh{color:var(--text-muted);font-size:.875rem}.display-error{border-bottom:1px solid #dc2626;border-bottom:1px solid var(--primary-color);color:#fca5a5;text-align:center;background:rgba(220,38,38,.1);padding:.75rem 2rem}.display-main{flex:1;padding:1rem;display:flex;overflow:hidden}.display-main>*+*{margin-left:1rem}.display-column{background:#16213e;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border-color);border-radius:1rem;flex-direction:column;flex:1;display:flex;overflow:hidden}.display-column h2{background:#1e3a5f;background:var(--bg-card-hover);border-bottom:1px solid #334155;border-bottom:1px solid var(--border-color);flex-shrink:0;padding:1.25rem 1.5rem;font-size:1.25rem;font-weight:600}.column-content{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;flex:1;padding:1rem;overflow-y:auto}.column-content::-webkit-scrollbar{width:4px}.column-content::-webkit-scrollbar-track{background:0 0}.column-content::-webkit-scrollbar-thumb{background:#334155;background:var(--border-color);border-radius:2px}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:1.125rem}.news-card{background:#1a1a2e;background:var(--bg-dark);border:1px solid #334155;border:1px solid var(--border-color);-webkit-transition:-webkit-transform .2s,border-color .2s;border-radius:.75rem;flex-direction:row;margin-bottom:1rem;transition:transform .2s,border-color .2s;display:flex;overflow:hidden}.news-image{background-color:#1a1a2e;background-color:var(--bg-dark);flex-shrink:0;width:180px;min-width:180px;margin-left:8px;overflow:hidden}.news-image img{-o-object-fit:contain;object-fit:contain;width:100%;height:100%;display:block}.news-content{flex:1;min-width:0;padding:1.25rem}.news-card h3{margin-bottom:.5rem;font-size:1.125rem;font-weight:600;line-height:1.4}.news-excerpt{color:var(--text-muted);margin-bottom:.75rem;font-size:.9375rem;line-height:1.6}.news-text{color:var(--text-muted);white-space:pre-wrap;word-wrap:break-word;margin-bottom:.75rem;font-size:.9375rem;line-height:1.6}.news-text p{margin-bottom:.5rem}.news-text ul,.news-text ol{margin-bottom:.5rem;margin-left:1.5rem}.news-card time{color:var(--text-muted);font-size:.8125rem}.news-meta{flex-wrap:wrap;align-items:center;display:flex}.news-meta>*+*{margin-left:.5rem}.news-author{color:var(--text-muted);font-size:.8125rem;font-style:italic}.event-card{background:#1a1a2e;background:var(--bg-dark);border:1px solid #334155;border:1px solid var(--border-color);border-radius:.75rem;flex-direction:row;margin-bottom:1rem;display:flex;position:relative;overflow:hidden}.event-image{background-color:#1a1a2e;background-color:var(--bg-dark);flex-shrink:0;width:180px;min-width:180px;margin-left:8px;overflow:hidden}.event-image img{-o-object-fit:contain;object-fit:contain;width:100%;height:100%;display:block}.event-content{flex:1;min-width:0;padding:1.25rem}.event-date-badge{background:#dc2626;background:var(--primary-color);color:#fff;border-radius:1rem;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.8125rem;font-weight:600;display:inline-block}.event-card h3{margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.event-details{flex-direction:column;margin-bottom:.5rem;display:flex}.event-details>*+*{margin-top:.25rem}.event-details time{color:var(--text-muted);font-size:.9375rem}.event-location{color:var(--text-muted);font-size:.875rem}.event-location:before{content:"📍 "}.event-description{color:var(--text-muted);white-space:pre-wrap;word-wrap:break-word;margin-top:.5rem;font-size:.875rem;line-height:1.5}.event-registration-status{border-radius:1rem;margin-top:.5rem;padding:.25rem .75rem;font-size:.8125rem;font-weight:500;display:inline-block}.event-registration-status.open{color:#22c55e;background:rgba(34,197,94,.2)}.event-registration-status.closed{color:#f87171;background:rgba(239,68,68,.2)}.linked-document-mention{color:#60a5fa;background:rgba(59,130,246,.15);border-radius:.5rem;margin-top:.5rem;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.8125rem;font-weight:500;display:inline-block}.display-footer{background:#16213e;background:var(--bg-card);border-top:1px solid #334155;border-top:1px solid var(--border-color);color:var(--text-muted);flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 2rem;font-size:.875rem;display:flex}.display-footer .last-refresh{color:var(--text-muted);font-size:.875rem}.tab-indicators{align-items:center;gap:.5rem;display:flex}.tab-dot{border:2px solid #334155;border:2px solid var(--border-color);cursor:pointer;background:0 0;border-radius:50%;width:12px;height:12px;padding:0;transition:all .3s}.tab-dot:hover{border-color:#94a3b8;border-color:var(--text-muted)}.tab-dot.active{background:#dc2626;background:var(--primary-color);border-color:#dc2626;border-color:var(--primary-color)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.current-date{color:var(--text-muted);text-transform:capitalize;font-size:1.25rem;font-weight:400}.info-button{border:1px solid #334155;border:1px solid var(--border-color);background:#1a1a2e;background:var(--bg-dark);color:var(--text-muted);width:32px;height:32px;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.info-button:hover{background:#1e3a5f;background:var(--bg-card-hover);border-color:#dc2626;border-color:var(--primary-color);color:var(--text-light)}.modal-overlay{z-index:1000;background:rgba(0,0,0,.7);justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal-content{background:#16213e;background:var(--bg-card);border:1px solid #334155;border:1px solid var(--border-color);text-align:center;border-radius:1rem;min-width:320px;max-width:90%;padding:2rem}.modal-content h3{margin-bottom:1.5rem;font-size:1.25rem}.modal-buttons{flex-direction:column;margin-bottom:1.5rem;display:flex}.modal-buttons>*+*{margin-top:.75rem}.modal-btn{cursor:pointer;border:none;border-radius:.5rem;padding:1rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.modal-btn.refresh-btn{background:#1e3a5f;background:var(--bg-card-hover);color:var(--text-light);border:1px solid #334155;border:1px solid var(--border-color)}.modal-btn.refresh-btn:hover{background:#dc2626;background:var(--primary-color);border-color:#dc2626;border-color:var(--primary-color)}.modal-btn.logout-btn{background:#dc2626;background:var(--primary-color);color:#fff}.modal-btn.logout-btn:hover{background:#b91c1c;background:var(--primary-dark)}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:.875rem}.modal-close:hover{color:var(--text-light)}.secondary-tab .weather-column,.secondary-tab .birthdays-column{flex:1}.display-main{animation:.5s ease-in-out fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.weather-content{flex-direction:column;align-items:center;padding:1rem;display:flex}.weather-location{color:var(--text-muted);margin-bottom:1rem;font-size:1.25rem}.weather-today{text-align:center;width:100%;margin-bottom:1.5rem;padding-bottom:1.5rem}.weather-today-header{color:var(--primary-color);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:1rem;font-weight:600}.weather-current{justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.weather-current>*+*{margin-left:.75rem}.weather-icon-large{font-size:3rem}.weather-temp-large{font-size:3rem;font-weight:300}.weather-description{color:var(--text-muted);text-transform:capitalize;margin-bottom:.5rem;font-size:1.125rem}.weather-today-details{color:var(--text-muted);flex-wrap:wrap;justify-content:center;font-size:.9375rem;display:flex}.weather-today-details>*+*{margin-left:1rem}.weather-forecast{flex-wrap:wrap;justify-content:center;width:100%;display:flex}.forecast-day{background:#1a1a2e;background:var(--bg-dark);border:1px solid #334155;border:1px solid var(--border-color);border-radius:.75rem;flex-direction:column;align-items:center;min-width:100px;margin:.375rem;padding:1rem;display:flex}.forecast-day-name{color:var(--text-light);margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.forecast-icon{margin-bottom:.5rem;font-size:2.25rem}.forecast-temps{flex-direction:column;align-items:center;margin-bottom:.375rem;font-size:1.125rem;display:flex}.forecast-temp-max{color:var(--text-light);font-weight:600}.forecast-temp-min{color:var(--text-muted)}.forecast-precip{color:var(--text-muted);font-size:1rem}.birthdays-list{flex-direction:column;display:flex}.birthdays-list>*+*{margin-top:1rem}.birthday-card{background:#1a1a2e;background:var(--bg-dark);border:1px solid #334155;border:1px solid var(--border-color);border-radius:.75rem;align-items:center;padding:1.25rem;display:flex}.birthday-card>*+*{margin-left:1rem}.birthday-card.today{border-color:#dc2626;border-color:var(--primary-color);background:rgba(220,38,38,.1)}.birthday-icon{flex-shrink:0;justify-content:center;align-items:center;width:4rem;height:4rem;font-size:2.5rem;display:flex}.birthday-photo{object-fit:cover;border:2px solid var(--primary-color);border-radius:50%;width:4rem;height:4rem}.birthday-info{flex:1}.birthday-name{margin-bottom:.25rem;font-size:1.25rem;font-weight:600}.birthday-details{color:var(--text-muted);font-size:1rem}.birthday-card.today .birthday-details{color:var(--primary-color);font-weight:500}@media (max-width:768px){.display-main{flex-direction:column}.display-main>*+*{margin-top:1rem;margin-left:0}.display-header{text-align:center;flex-direction:column}.display-header>*+*{margin-top:1rem}.header-info{flex-direction:column}.header-info>*+*{margin-top:.5rem;margin-left:0}.weather-detail{width:100%;margin:.375rem 0}}.board-tab .board-column.full-width{width:100%;max-width:none}.board-tab .column-content{justify-content:center;align-items:flex-start;display:flex}.board-members-grid{flex-wrap:wrap;justify-content:center;gap:2rem;padding:1rem;display:flex}.board-member-card{background:#1a1a2e;background:var(--bg-dark);border:1px solid #334155;border:1px solid var(--border-color);text-align:center;border-radius:1rem;min-width:200px;max-width:280px;padding:1.5rem;transition:transform .2s,box-shadow .2s}.board-member-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.3)}.board-member-photo{background:#334155;background:var(--border-color);border:3px solid #dc2626;border:3px solid var(--primary-color);border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;margin:0 auto 1rem;display:flex;overflow:hidden}.board-member-photo img{object-fit:cover;width:100%;height:100%}.board-member-placeholder{color:var(--text-muted);text-transform:uppercase;font-size:2.5rem;font-weight:700}.board-member-info{margin-top:.5rem}.board-member-name{color:var(--text-light);margin-bottom:.375rem;font-size:1.25rem;font-weight:600}.board-member-function{color:var(--primary-color);font-size:1rem;font-weight:500}@media (max-width:600px){.board-member-card{min-width:150px;padding:1rem}.board-member-photo{width:80px;height:80px}.board-member-placeholder{font-size:1.5rem}.board-member-name{font-size:1rem}.board-member-function{font-size:.875rem}}.weather-column{--zs:var(--zoom-scale,1)}.weather-column .weather-location{font-size:calc(1.25rem * var(--zs))}.weather-column .weather-icon-large,.weather-column .weather-temp-large{font-size:calc(3rem * var(--zs))}.weather-column .weather-today-header{font-size:calc(1rem * var(--zs))}.weather-column .weather-description{font-size:calc(1.125rem * var(--zs))}.weather-column .weather-today-details{font-size:calc(.9375rem * var(--zs))}.weather-column .forecast-day{min-width:calc(100px * var(--zs));padding:calc(1rem * var(--zs))}.weather-column .forecast-day-name{font-size:calc(1.125rem * var(--zs))}.weather-column .forecast-icon{font-size:calc(2.25rem * var(--zs))}.weather-column .forecast-temps{font-size:calc(1.125rem * var(--zs))}.weather-column .forecast-precip{font-size:calc(1rem * var(--zs))}.birthdays-column{--zs:var(--zoom-scale,1)}.birthdays-column .birthday-icon{width:calc(4rem * var(--zs));height:calc(4rem * var(--zs));font-size:calc(2.5rem * var(--zs))}.birthdays-column .birthday-photo{width:calc(4rem * var(--zs));height:calc(4rem * var(--zs))}.birthdays-column .birthday-name{font-size:calc(1.25rem * var(--zs))}.birthdays-column .birthday-details{font-size:calc(1rem * var(--zs))}.birthdays-column .birthday-card{padding:calc(1.25rem * var(--zs))}.birthdays-column .birthday-card>*+*{margin-left:calc(1rem * var(--zs))}.board-column{--zs:var(--zoom-scale,1)}.board-column .board-members-grid{gap:calc(2rem * var(--zs))}.board-column .board-member-card{min-width:calc(200px * var(--zs));padding:calc(1.5rem * var(--zs))}.board-column .board-member-photo{width:calc(120px * var(--zs));height:calc(120px * var(--zs))}.board-column .board-member-placeholder{font-size:calc(2.5rem * var(--zs))}.board-column .board-member-name{font-size:calc(1.25rem * var(--zs))}.board-column .board-member-function{font-size:calc(1rem * var(--zs))}
