:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;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;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}}.navigation{display:flex;align-items:center;padding:1rem 2rem;background:#0084ca;color:#fff;box-shadow:0 2px 4px #0000001a}.nav-brand{display:flex;align-items:center;gap:15px;margin-right:60px}.nav-logo{height:40px;width:auto;object-fit:contain}.nav-brand h2{margin:0;font-size:1.5rem}.user-info{color:#ecf0f1;font-size:4px}.nav-links{flex:1;display:flex;gap:3rem;margin-left:4rem}.nav-links a{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background .2s}.nav-links a:hover{background:#16326033}.nav-links a.active{background:#16326066}.nav-user{display:flex;align-items:center;gap:1rem;margin-left:4rem}.nav-user button{padding:.5rem 1rem;background:#1f4789;color:#fff;border:none;border-radius:4px;cursor:pointer}.nav-user button:hover{background:#163260}.nav-title{font-size:28px;font-weight:700;color:#fff;margin:0}.nav-user span{font-size:13px;color:#ecf0f1}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.login-box h1{margin-bottom:1.5rem;text-align:center}.login-box form div{margin-bottom:1rem}.login-box label{display:block;margin-bottom:.5rem;font-weight:500}.login-box input{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.login-box button{width:100%;padding:.75rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.login-box button:hover{background-color:#0056b3}.login-box .error{color:red;margin-top:.5rem;text-align:center}.login-logo{width:380px;height:auto;margin-bottom:40px;display:block;margin-left:auto;margin-right:auto}table{border-collapse:collapse;margin-top:1rem}.error{color:red}.filters{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.filters label{display:flex;align-items:center;gap:.5rem}.pagination{display:flex;gap:1rem;align-items:center;margin-top:1rem}.pagination button:disabled{opacity:.5;cursor:not-allowed}.table-container{overflow-x:auto}.chart-container{margin:1rem 0}.view-toggle{display:flex;gap:0}.view-toggle button{padding:.5rem 1rem;border:1px solid #ccc;background:#fff;cursor:pointer}.view-toggle button.active{background:#09639f;color:#fff;border-color:#09639f}.view-toggle button:first-child{border-radius:4px 0 0 4px}.view-toggle button:last-child{border-radius:0 4px 4px 0}.table-container{overflow-x:auto;max-height:500px;overflow-y:auto}.table-container table{border-collapse:collapse;width:100%}.table-container th,.table-container td{border:1px solid #ccc;padding:.5rem 1rem;text-align:left}.table-container th{position:sticky;top:0;background-color:#f0f0f0;box-shadow:0 1px #ccc;z-index:1;cursor:pointer;-webkit-user-select:none;user-select:none}.table-container th:hover{background-color:#e0e0e0}.column-toggle{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;align-items:center}.column-toggle label{display:flex;align-items:center;gap:.25rem;font-size:.85rem}.export-button{padding:.5rem 1rem;background-color:#338458;color:#fff;border:none;border-radius:4px;cursor:pointer}.export-button:hover{background-color:#00652e}.btn-download{padding:10px 20px;background-color:#3498db;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-download:hover:not(:disabled){background-color:#2980b9}.btn-download:disabled{background-color:#bdc3c7;cursor:not-allowed}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chart-header h2{margin:0}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;width:100%;max-width:100%}.ydoc-dashboard{max-width:1400px;margin:0 auto;padding:20px}.ydoc-dashboard h1{color:#2c3e50;margin-bottom:30px}.error-message{background-color:#fee;border:1px solid #fcc;color:#c33;padding:12px 16px;border-radius:4px;margin-bottom:20px}.export-controls{background:#fff;border:1px solid #ddd;border-radius:8px;padding:30px;box-shadow:0 2px 4px #0000001a}.control-group{margin-bottom:25px}.control-group label{display:block;font-weight:600;color:#34495e;margin-bottom:8px}.control-group select,.control-group input[type=date]{padding:10px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;width:100%;max-width:400px}.control-group select:focus,.control-group input[type=date]:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.date-range{display:flex;align-items:center;gap:10px}.date-range input[type=date]{flex:0 0 180px}.date-range span{color:#7f8c8d;font-weight:500}.channel-controls{display:flex;align-items:center;gap:10px;margin-bottom:15px}.channel-count{color:#7f8c8d;font-size:14px;margin-left:auto}.channel-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px;max-height:300px;overflow-y:auto;padding:15px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px}.channel-checkbox{display:flex;align-items:center;cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.channel-checkbox:hover{background-color:#e9ecef}.channel-checkbox input[type=checkbox]{margin-right:8px;cursor:pointer}.channel-name{font-size:14px;color:#2c3e50}.channel-unit{color:#7f8c8d;font-size:13px}.btn-primary,.btn-secondary{padding:10px 20px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:#338458;color:#fff}.btn-primary:hover:not(:disabled){background-color:#00652e}.btn-primary:disabled{background-color:#bdc3c7;cursor:not-allowed}.btn-secondary{background-color:#ecf0f1;color:#34495e}.btn-secondary:hover:not(:disabled){background-color:#d5dbdb}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-download{min-width:200px;padding:12px 24px;font-size:16px}.export-info{margin-top:30px;padding:20px;background:#f8f9fa;border-left:4px solid #00652E;border-radius:4px}.export-info h3{margin-top:0;color:btn-download;font-size:18px}.export-info p{margin:8px 0;color:#34495e}.export-info strong{color:#2c3e50;margin-right:8px}@media(max-width:768px){.date-range{flex-direction:column;align-items:stretch}.date-range input[type=date]{flex:1;max-width:100%}.channel-list{grid-template-columns:1fr}.channel-controls{flex-wrap:wrap}.channel-count{margin-left:0;width:100%}}.device-detail-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem}.back-button{padding:.5rem 1rem;background:#ecf0f1;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.back-button:hover{background:#bdc3c7}.controls-panel{background:#fff;padding:1.5rem;border-radius:8px;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a}.date-range-selector{margin-bottom:1.5rem}.date-range-selector label{display:block;font-weight:600;margin-bottom:.5rem}.range-buttons{display:flex;gap:.5rem}.range-buttons button{padding:.5rem 1rem;border:2px solid #3498db;background:#fff;color:#3498db;border-radius:4px;cursor:pointer;transition:all .2s}.range-buttons button:hover{background:#ebf5fb}.range-buttons button.active{background:#3498db;color:#fff}.channel-selector label{display:block;font-weight:600;margin-bottom:.5rem}.channel-checkboxes{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.channel-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem}.channel-checkbox input{cursor:pointer}.chart-area{background:#fff;padding:2rem;border-radius:8px;margin-bottom:2rem;min-height:400px;box-shadow:0 2px 4px #0000001a}.export-section{display:flex;justify-content:flex-end}.yexport-button{padding:.75rem 1.5rem;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.yexport-button:hover{background:#229954}.schematics-page{padding:20px;max-width:1400px;margin:0 auto}.schematics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.schematics-header h1{margin:0;color:#15325f}.upload-button{padding:12px 24px;background-color:#0084ca;color:#fff;border-radius:6px;cursor:pointer;display:inline-block;font-weight:500;transition:background-color .2s}.upload-button:hover{background-color:#006ba6}.upload-button.uploading{background-color:#ccc;cursor:not-allowed}.loading{text-align:center;padding:60px 20px;color:#666;font-size:18px}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state p{margin:10px 0;font-size:16px}.schematics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.schematic-card{border:1px solid #ddd;border-radius:8px;overflow:hidden;background:#fff;transition:box-shadow .2s;display:flex;flex-direction:column;min-height:380px}.schematic-card:hover{box-shadow:0 4px 12px #00000026}.schematic-thumbnail{position:relative;width:100%;height:200px;overflow:hidden;cursor:pointer;background-color:#f5f5f5;flex-shrink:0}.schematic-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.schematic-thumbnail:hover img{transform:scale(1.05)}.thumbnail-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;color:#fff;font-weight:500}.schematic-thumbnail:hover .thumbnail-overlay{opacity:1}.schematic-info{padding:15px;display:flex;flex-direction:column;flex:1}.schematic-title{font-weight:600;margin-bottom:8px;color:#333;word-wrap:break-word;font-size:14px}.schematic-meta{display:flex;justify-content:space-between;font-size:12px;color:#666;margin-bottom:5px}.schematic-date{font-size:11px;color:#999;margin-bottom:auto}.delete-button{width:auto;padding:8px 16px;background-color:transparent;color:#999;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s;opacity:0;margin-top:8px;align-self:center}.schematic-card:hover .delete-button{opacity:1;display:flex;flex-direction:column}.delete-button:hover{background-color:#1f4789;color:#fff;border-color:#1f4789}.error-message{text-align:center;padding:60px 20px;color:#dc3545}.error-message h2{margin-bottom:15px}.error-message p{margin-bottom:20px;font-family:monospace;background:#f8f9fa;padding:15px;border-radius:4px;display:inline-block;text-align:left}.retry-button{padding:10px 20px;background-color:#0084ca;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px}.retry-button:hover{background-color:#006ba6}.thumbnail-loading{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;color:#666;font-size:14px}.thumbnail-error{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f8f9fa;color:#666}.file-icon{font-size:24px;font-weight:700;color:#999;padding:10px 15px;background-color:#e9ecef;border-radius:4px}.pdf-thumbnail{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0b04f,#8b1e1e 60%)}.pdf-icon{font-size:64px;margin-bottom:10px}.pdf-label{font-size:18px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:2px}
