.login-page{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fffffff2;border-radius:20px;padding:40px;box-shadow:0 20px 40px #0000001a;text-align:center;max-width:400px;width:100%}.login-logo{height:60px;width:auto;margin-bottom:20px}.login-header h1{color:#333;margin-bottom:10px;font-size:2rem}.login-header p{color:#666;margin-bottom:30px;font-size:1.1rem}.login-form{display:flex;flex-direction:column;gap:20px}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#333;border:2px solid #ddd;border-radius:12px;padding:16px 24px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #0000001a}.google-login-btn:hover{background:#f8f9fa;border-color:#4285f4;transform:translateY(-2px);box-shadow:0 4px 20px #00000026}.google-login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.google-icon{width:20px;height:20px}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:8px;border:1px solid #ffcdd2;font-size:14px}.login-info{background:#fff3cd;color:#856404;padding:12px;border-radius:8px;border:1px solid #ffeaa7;font-size:14px}.login-info p{margin:0}@media (max-width: 768px){.login-page{padding:10px}.login-container{padding:30px 20px;margin:0;border-radius:15px}.login-logo{height:50px}.login-header h1{font-size:1.5rem}.login-header p{font-size:1rem}.google-login-btn{padding:14px 20px;font-size:15px}}@media (max-width: 480px){.login-page{padding:15px}.login-container{padding:25px 15px;max-width:none;width:100%}.login-logo{height:45px}.login-header h1{font-size:1.3rem}.google-login-btn{padding:12px 16px;font-size:14px}.google-icon{width:18px;height:18px}}.access-denied-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ff6b6b,#ee5a24);padding:20px}.access-denied-container{background:#fffffff2;border-radius:20px;padding:40px;box-shadow:0 20px 40px #0000001a;text-align:center;max-width:500px;width:100%}.access-denied-icon{font-size:4rem;margin-bottom:20px}.access-denied-container h1{color:#333;margin-bottom:15px;font-size:2rem}.access-denied-container p{color:#666;margin-bottom:25px;font-size:1.1rem;line-height:1.5}.user-info{background:#f8f9fa;padding:15px;border-radius:10px;margin:20px 0}.user-info p{margin:0 0 5px;color:#666;font-size:.9rem}.user-info strong{color:#333;font-size:1rem}.access-requirements{background:#fff3cd;padding:20px;border-radius:10px;margin:20px 0;text-align:left}.access-requirements h3{margin:0 0 10px;color:#856404;text-align:center}.access-requirements ul{list-style:none;padding:0;margin:0}.access-requirements li{padding:5px 0;color:#856404}.sign-out-btn{background:#dc3545;color:#fff;border:none;border-radius:12px;padding:16px 24px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;margin:20px 0}.sign-out-btn:hover{background:#c82333;transform:translateY(-2px);box-shadow:0 4px 15px #dc35454d}.contact-info{margin-top:20px;padding-top:20px;border-top:1px solid #eee}.contact-info p{color:#888;font-size:.9rem;margin:0}@media (max-width: 768px){.access-denied-page{padding:10px}.access-denied-container{padding:30px 20px;margin:0;border-radius:15px}.access-denied-icon{font-size:3rem}.access-denied-container h1{font-size:1.5rem}.access-denied-container p{font-size:1rem}.sign-out-btn{padding:14px 20px;font-size:15px}}@media (max-width: 480px){.access-denied-container{padding:25px 15px}.access-denied-icon{font-size:2.5rem}.access-denied-container h1{font-size:1.3rem}.sign-out-btn{padding:12px 16px;font-size:14px;width:100%}}.led-banner-container{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:15px;width:100%}.canvas-wrapper{width:100%;max-width:min(1056px,100vw - 40px);border:8px solid #333;border-radius:8px;background:#000;overflow:hidden;box-shadow:0 4px 20px #0000004d}.led-canvas{width:100%;height:auto;display:block;background:#000}.animation-toggle-btn{background:#efb8fa;color:#000;border:none;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;transition:background-color .2s;min-width:100px;font-weight:500}.animation-toggle-btn:hover{background:#ff00ec}@media (min-width: 1600px){.canvas-wrapper{max-width:min(1400px,100vw - 120px);border:10px solid #333}}@media (min-width: 1200px) and (max-width: 1599px){.canvas-wrapper{max-width:min(1200px,100vw - 80px)}}@media (max-width: 768px){.canvas-wrapper{border:6px solid #333;border-radius:6px;max-width:100%}.animation-toggle-btn{width:100%;padding:12px;font-size:16px}}@media (max-width: 480px){.led-banner-container{gap:10px}.canvas-wrapper{border:4px solid #333;border-radius:4px}.animation-toggle-btn{padding:14px;font-size:16px}}.zone-editor{background:#1a1a1a;border-radius:8px;padding:1rem;margin-bottom:1rem;border:1px solid #333}.zone-editor h3{margin:0 0 1rem;color:#fff!important}.zone-editor h4{margin:1rem 0 .5rem;color:#ccc;font-size:1rem;padding-bottom:.3rem;border-bottom:1px solid #444}.line-mode-group{display:flex;gap:1rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#ccc}.radio-label input[type=radio]{margin:0}.line-section,.background-section,.infographics-section{background:#2a2a2a;border-radius:6px;padding:1rem;margin:1rem 0;border:1px solid #444}.infographics-description,.infographics-note{color:#ccc;font-size:14px;line-height:1.4;margin-bottom:.8rem}.infographics-list{color:#ccc;margin:.8rem 0;padding-left:1.5rem}.infographics-list li{margin-bottom:.4rem;font-size:14px}.infographics-note{color:#ff9800;font-style:italic}.infographics-note strong{color:#ff9800}.background-type-select,.background-mode-select,.url-input,.font-select{width:100%;padding:.5rem;border:1px solid #444;border-radius:4px;background:#333;color:#fff;font-size:14px}.background-type-select:focus,.background-mode-select:focus,.url-input:focus,.font-select:focus{outline:none;border-color:#ff00ec}.mode-description{display:block;margin-top:.3rem;color:#999;font-size:12px;line-height:1.3;font-style:italic}.form-group{margin-bottom:.8rem}.form-group label{display:block;margin-bottom:.3rem;font-weight:500;color:#ccc}.text-input-group{display:flex;gap:.5rem;align-items:center}.text-input{flex:1;padding:.5rem;border:1px solid #444;border-radius:4px;background:#333;color:#fff;font-size:14px}.text-input:focus{outline:none;border-color:#ff00ec}.color-input-group{display:flex;gap:.5rem;align-items:center}.color-picker{width:40px;height:32px;border:1px solid #444;border-radius:4px;background:transparent;cursor:pointer}.color-text{flex:1;padding:.5rem;border:1px solid #444;border-radius:4px;background:#333;color:#fff;font-size:14px}.color-text:focus{outline:none;border-color:#ff00ec}.speed-input-group{display:flex;gap:.5rem;align-items:center}.speed-slider{flex:1;height:6px;background:#444;border-radius:3px;outline:none;-webkit-appearance:none}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#ff00ec;border-radius:50%;cursor:pointer}.speed-slider::-moz-range-thumb{width:20px;height:20px;background:#ff00ec;border-radius:50%;cursor:pointer;border:none}.speed-number{width:60px;padding:.3rem;border:1px solid #444;border-radius:4px;background:#333;color:#fff;font-size:14px;text-align:center}.speed-number:focus{outline:none;border-color:#ff00ec}@media (max-width: 768px){.zone-editor{padding:15px;margin-bottom:15px}.zone-editor h3{font-size:1.1rem}.form-group{margin-bottom:15px}.text-input,.color-text,.speed-number{padding:10px;font-size:16px}.color-picker{width:50px;height:40px}.speed-slider{height:8px}.speed-slider::-webkit-slider-thumb{width:24px;height:24px}.speed-slider::-moz-range-thumb{width:24px;height:24px}}@media (max-width: 480px){.zone-editor{padding:12px}.zone-editor h3{font-size:1rem;margin-bottom:12px}.form-group{margin-bottom:12px}.form-group label{font-size:14px;margin-bottom:6px}.color-input-group,.speed-input-group{gap:8px}.speed-number{width:70px}}.dashboard{min-height:100vh;width:100%;background:#f5f5f5}.dashboard-header{background:#fff;padding:20px 40px;width:100%;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.header-logo-title{display:flex;align-items:center;gap:15px}.header-logo{height:50px;width:auto}.dashboard-header h1{margin:0;color:#333;font-size:1.8rem}.user-info{display:flex;align-items:center;gap:15px}.user-info span{color:#666;font-size:.9rem}.sign-out-btn{background:#dc3545;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;transition:background-color .2s}.sign-out-btn:hover{background:#c82333}.dashboard-main{padding:40px;width:100%;margin:0 auto}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:#666}.loading-section .loading-spinner{width:30px;height:30px;border:3px solid #e0e0e0;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.dashboard-content{display:flex;flex-direction:column;gap:30px}.profiles-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 20px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.section-header h2{margin:0;color:#333;font-size:1.5rem}.section-header p{margin:0;color:#666;font-size:.9rem}.create-btn{background:#28a745;color:#fff;border:none;border-radius:8px;padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.create-btn:hover{background:#218838}.profiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.profile-card{border:2px solid #e0e0e0;border-radius:10px;padding:20px;background:#fafafa;transition:all .2s}.profile-card.active{border-color:#28a745;background:#f8fff8}.profile-card:hover{box-shadow:0 4px 15px #0000001a}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.profile-header h3{margin:0;color:#333;font-size:1.2rem}.active-badge{background:#28a745;color:#fff;padding:4px 8px;border-radius:4px;font-size:.7rem;font-weight:600}.profile-info{margin-bottom:15px}.profile-info p{margin:5px 0;color:#666;font-size:.8rem}.profile-actions{display:flex;gap:8px;flex-wrap:wrap}.edit-btn,.copy-btn,.activate-btn,.delete-btn{padding:6px 12px;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background-color .2s}.edit-btn{background:#007bff;color:#fff}.edit-btn:hover{background:#0056b3}.copy-btn{background:#6c757d;color:#fff}.copy-btn:hover:not(:disabled){background:#5a6268}.copy-btn:disabled{background:#ccc;cursor:not-allowed}.activate-btn{background:#ffc107;color:#333}.activate-btn:hover:not(:disabled){background:#e0a800}.activate-btn:disabled{background:#06402b;color:#fff;cursor:not-allowed}.delete-btn{background:#dc3545;color:#fff}.delete-btn:hover{background:#c82333}.no-profiles{text-align:center;padding:40px;color:#666;grid-column:1 / -1}.editor-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 20px #0000001a}.editor-actions{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.profile-name-input{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;min-width:200px}.profile-name-input:focus{outline:none;border-color:#007bff}.save-btn,.cancel-btn{padding:8px 16px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s}.save-btn{background:#28a745;color:#fff}.save-btn:hover:not(:disabled){background:#218838}.save-btn:disabled{background:#6c757d;cursor:not-allowed}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#545b62}.editor-content{display:grid;grid-template-columns:1fr 400px;gap:30px;margin-top:25px;height:70vh;min-height:600px}.config-section{display:flex;flex-direction:column;gap:25px}.night-mode-indicator{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:12px 16px;color:#856404;font-size:.9rem;font-weight:500;text-align:center}.night-mode-config{background:#3d3d3d;border-radius:8px;padding:20px;border:1px solid #e9ecef}.night-mode-config h3{margin:0 0 15px;color:#fff;font-size:1.1rem}.night-mode-controls{display:flex;flex-direction:column;gap:15px}.save-night-mode-btn{background:#17a2b8;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:14px;cursor:pointer;transition:background-color .2s;margin-top:10px}.save-night-mode-btn:hover:not(:disabled){background:#138496}.save-night-mode-btn:disabled{background:#6c757d;cursor:not-allowed}.night-mode-actions{display:flex;flex-direction:column;gap:10px}.night-mode-config input[type=time]{padding:6px 10px;border:1px solid #ced4da;border-radius:4px;font-size:.9rem;background:#fff;color:#333;min-width:120px}.night-mode-config input[type=time]:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.night-mode-config input[type=checkbox]{margin:0}.zones-section{display:flex;flex-direction:column;min-height:0;overflow:hidden}.zones-section h3{margin:0 0 20px;color:#333;font-size:1.2rem;flex-shrink:0}.zones-scroll-container{flex:1;overflow-y:auto;padding-right:10px;display:flex;flex-direction:column;gap:15px}.zones-scroll-container::-webkit-scrollbar{width:8px}.zones-scroll-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.zones-scroll-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.zones-scroll-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.preview-section{display:flex;flex-direction:column}.preview-section h3{margin:0 0 20px;color:#333;font-size:1.2rem;flex-shrink:0}.active-display-section,.no-active-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 4px 20px #0000001a}.active-display{text-align:center}.active-display h3{margin:0 0 20px;color:#333;font-size:1.3rem}.obs-info{margin-top:20px;padding:15px;background:#f8f9fa;border-radius:8px;text-align:left}.obs-info p{margin:0;color:#333;font-size:.9rem}.obs-info code{background:#e9ecef;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;color:#495057}@media (min-width: 1600px){.dashboard-main{padding:60px 80px}.profiles-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:25px}.editor-content{grid-template-columns:1fr 450px;gap:40px}}@media (min-width: 1200px) and (max-width: 1599px){.dashboard-main{padding:50px 60px}.profiles-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.editor-content{grid-template-columns:1fr 400px;gap:35px}}@media (max-width: 1200px){.dashboard-main{padding:30px}.editor-content{grid-template-columns:1fr 350px;gap:25px}}@media (max-width: 992px){.dashboard-main{padding:25px}.editor-content{grid-template-columns:1fr;gap:20px}.profiles-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width: 768px){.dashboard-header{padding:15px 20px;flex-direction:column;gap:15px;text-align:center;width:100%}.header-logo-title{flex-direction:column;gap:10px}.header-logo{height:40px}.dashboard-header h1{font-size:1.5rem}.user-info{flex-direction:column;gap:10px}.dashboard-main{padding:20px 15px;width:100%}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.section-header h2{font-size:1.3rem}.profiles-grid{grid-template-columns:1fr;gap:15px}.profile-card{padding:15px}.profile-actions{justify-content:space-between}.edit-btn,.copy-btn,.activate-btn,.delete-btn{flex:1;text-align:center}.editor-actions{flex-direction:column;align-items:stretch;gap:10px}.profile-name-input{min-width:unset;width:100%}.save-btn,.cancel-btn{width:100%;padding:12px}.obs-info{text-align:center}.obs-info code{word-break:break-all;display:block;margin-top:5px}}@media (max-width: 480px){.dashboard-header{padding:10px 15px;width:100%}.dashboard-header h1{font-size:1.3rem}.dashboard-main{padding:15px 10px;width:100%}.profiles-section,.editor-section,.active-display-section,.no-active-section{padding:20px 15px;border-radius:8px}.section-header h2{font-size:1.2rem}.create-btn{width:100%;padding:12px}.profile-header h3{font-size:1rem}.profile-actions{flex-direction:column;gap:8px}.edit-btn,.copy-btn,.activate-btn,.delete-btn{width:100%;padding:10px}.editor-content{gap:15px}.preview-section h3,.zones-section h3{font-size:1.1rem}}.message-fade.animating-in{opacity:0;animation:fadeIn .5s ease-in-out forwards}.message-fade.displaying{opacity:1}.message-fade.animating-out{opacity:1;animation:fadeOut .5s ease-in-out forwards}.message-slide.animating-in{opacity:1;transform:translate(100%);animation:slideIn .5s ease-out forwards}.message-slide.displaying{opacity:1;transform:translate(0)}.message-slide.animating-out{opacity:1;transform:translate(0);animation:slideOut .5s ease-in forwards}.message-drop.animating-in{opacity:0;transform:translateY(0) scaleY(0);transform-origin:top;animation:dropIn .5s ease-out forwards}.message-drop.displaying{opacity:1;transform:translateY(0) scaleY(1);transform-origin:top}.message-drop.animating-out{opacity:1;transform:translateY(0) scaleY(1);transform-origin:bottom;animation:dropOut .5s ease-in forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOut{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes dropIn{0%{transform:translateY(0) scaleY(0);transform-origin:top;opacity:0}to{transform:translateY(0) scaleY(1);transform-origin:top;opacity:1}}@keyframes dropOut{0%{transform:translateY(0) scaleY(1);transform-origin:bottom;opacity:1}to{transform:translateY(0) scaleY(0);transform-origin:bottom;opacity:0}}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-screen p{font-size:1.2rem;margin:0}.app{max-width:1400px;margin:0 auto;padding:2rem;text-align:center}.main-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem;margin-top:2rem}.preview-section{display:flex;flex-direction:column;align-items:center}.preview-section h2{margin-bottom:1rem}.editor-section{text-align:left}.editor-section h2{margin-bottom:1rem;text-align:center}.preview-buttons{display:flex;gap:1rem;margin-top:1rem;justify-content:center}.export-btn,.preview-btn{background-color:#4caf50;color:#fff;border:none;padding:12px 24px;font-size:16px;cursor:pointer;border-radius:4px;transition:background-color .3s}.export-btn:hover,.preview-btn:hover{background-color:#45a049}.preview-btn{background-color:#2196f3}.preview-btn:hover{background-color:#1976d2}@media (max-width: 768px){.main-content{grid-template-columns:1fr}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:#ffffffde;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
