body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(1400px 820px at 10% -4%,rgba(42,128,255,.42),transparent 58%),radial-gradient(980px 640px at 92% 8%,rgba(45,223,255,.28),transparent 62%),linear-gradient(145deg,#082a66,#0e3f8f 40%,#1461b7 75%,#1f7cd5);background-attachment:fixed;color:#e8f2ff}.container{width:100%;max-width:none;margin:0;padding:14px 18px 10px;box-sizing:border-box;min-height:100vh;display:flex;flex-direction:column}.header{text-align:center;margin-bottom:30px;padding:20px;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);color:#f1f6ff;border-radius:10px;box-shadow:0 12px 28px #040b1e6b,inset 0 1px #bbd9ff2e}.header h1{margin:0;font-size:2.5rem}.controls{display:flex;gap:15px;margin-bottom:30px;flex-wrap:wrap;align-items:center;padding:20px;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:10px;box-shadow:0 12px 28px #040b1e6b,inset 0 1px #bbd9ff2e}.control-group{display:flex;flex-direction:column;gap:5px}.control-group label{font-weight:700;color:#e8f2ff}.control-group input,.control-group select{padding:10px;border:1px solid rgba(82,150,243,.52);background:#2c344b;color:#ecf5ff;border-radius:5px;font-size:14px}.daily-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-bottom:30px}.date-card{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:10px;overflow:hidden;box-shadow:0 12px 28px #040b1e6b,inset 0 1px #bbd9ff2e;transition:transform .2s ease;cursor:pointer}.date-card:hover{transform:translateY(-5px)}.date-card img{width:100%;height:200px;object-fit:cover}.date-info{padding:15px}.date-info h3{margin:0 0 10px;color:#e8f2ff}.date-info p{margin:0;color:#9ab4db;font-size:14px}.detail-view{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:10px;padding:20px;box-shadow:0 12px 28px #040b1e6b,inset 0 1px #bbd9ff2e;margin-top:20px}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:20px}.frame-item{background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:8px;padding:15px;text-align:center}.frame-item img{max-width:100%;height:200px;object-fit:cover;border-radius:5px;margin-bottom:10px}.env-data{background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:8px;padding:15px;margin:10px 0}.env-data h4{margin-top:0;color:#2c3e50}.log-item{background:#312608b3;border:1px solid rgba(255,214,128,.35);color:#ffe8b8;border-radius:8px;padding:15px;margin:10px 0}.loading{text-align:center;padding:40px;font-size:18px;color:#9ab4db}.error{background:#8c163659;border:1px solid rgba(255,145,176,.36);color:#ffc5d2;padding:15px;border-radius:5px;margin:20px 0;text-align:center}.btn{padding:10px 20px;background:linear-gradient(145deg,#84bef5a3,#6cacec7a 48%,#a0d5ff8a);color:#000;border:1px solid rgba(152,202,247,.82);color:#f1f6ff;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:background .2s ease}.btn:hover{background:linear-gradient(145deg,#8ec7fca3,#78b8f47a 48%,#a9dcff8a)}.btn:disabled{background:#ccc;cursor:not-allowed}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48)}.login-box{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;text-align:center}.login-box h1{margin:0 0 10px;color:#e8f2ff;font-size:1.8rem}.login-box p{color:#9ab4db;margin-bottom:30px}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#e8f2ff}.form-group input{width:100%;padding:12px;border:1px solid rgba(82,150,243,.52);background:#2c344b;color:#ecf5ff;border-radius:8px;font-size:14px;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-full{width:100%;padding:14px;font-size:16px;font-weight:500;margin-top:10px}.btn-small{padding:6px 12px;font-size:12px;background:linear-gradient(145deg,#84bef5a3,#6cacec7a 48%,#a0d5ff8a);color:#000;border:1px solid rgba(152,202,247,.82);color:#f1f6ff}.btn-small:hover{background:linear-gradient(145deg,#8ec7fca3,#78b8f47a 48%,#a9dcff8a)}.user-info{display:flex;align-items:center;gap:15px;margin-top:15px;justify-content:center}.breadcrumb-right{margin-top:0;justify-content:flex-end;flex-wrap:wrap;gap:8px}.user-info span{color:#ffffffe6}.login-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px}.fixed-value{padding:10px;background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:5px;color:#9ab4db;font-weight:500}.breadcrumb{padding:12px 16px;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:8px;margin-bottom:14px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.breadcrumb-topline{width:100%;color:#ecf4ff;font-weight:600;font-size:28px;line-height:1.25;text-align:center;letter-spacing:1px}.breadcrumb-path{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.breadcrumb span{color:#9ab4db}.breadcrumb span.clickable{color:#667eea;cursor:pointer}.breadcrumb span.clickable:hover{text-decoration:underline}.device-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}@media (max-width: 1280px){.device-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 992px){.device-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){.device-grid{grid-template-columns:1fr}}.device-card{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000001a;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;background-size:cover;background-position:center;min-height:180px}.device-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#07173757,#05122dd1 56%,#030c21f0)}.device-card:hover{transform:translateY(-3px);box-shadow:0 8px 15px #00000026}.device-icon{font-size:40px;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);width:70px;height:70px;border-radius:12px;display:flex;align-items:center;justify-content:center}.device-info{position:relative;z-index:1;flex:1}.device-info h3{margin:0 0 8px;color:#e8f2ff;font-size:1.1rem}.device-info .device-id{color:#7fa3d7;font-size:12px;margin:0 0 5px}.device-info p{margin:0 0 5px;color:#9ab4db;font-size:14px}.device-stats{background:#091b48d9;border:1px solid rgba(80,137,216,.4);padding:5px 10px;border-radius:15px;display:inline-block;font-size:12px!important;color:#666!important;margin-top:8px!important}.latest-date{color:#667eea!important;font-weight:500}.latest-env{margin-top:10px!important;padding:7px 10px;border-radius:10px;background:#0616349e;border:1px solid rgba(126,170,235,.42);color:#dcecff!important;font-size:12px!important}.auto-refresh-text{margin:8px 0 14px;color:#9db6db;font-size:13px}.auto-refresh-inline{margin:0;color:#d1e6ff;font-size:12px;white-space:nowrap}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{margin:0}.empty-state{text-align:center;padding:60px 20px;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:12px;box-shadow:0 4px 6px #0000001a}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{color:#e8f2ff;margin-bottom:10px}.empty-state p{color:#9ab4db;margin-bottom:20px}.page-company-footer{margin-top:auto;margin-bottom:6px;padding-top:18px;text-align:center;color:#b8cdea;font-size:14px;letter-spacing:1px;white-space:nowrap}.device-table-container{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow:hidden}.device-table{width:100%;border-collapse:collapse}.device-table th,.device-table td{padding:12px 15px;text-align:left;border-bottom:1px solid rgba(104,144,203,.32)}.device-table th{background:#091b48d9;border:1px solid rgba(80,137,216,.4);font-weight:600;color:#e8f2ff}.device-table tr:hover{background:#1e396c61}.device-table code{background:#243558c7;border:1px solid rgba(102,151,228,.36);color:#d8e8ff;padding:2px 6px;border-radius:4px;font-size:12px}.device-type{padding:4px 8px;border-radius:12px;font-size:12px}.device-type.camera{background:#1f6fc733;color:#8ec6ff}.rtsp-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:#9ab4db}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.active{background:#32b17e3d;color:#9ef5cd}.status-badge.inactive{background:#8c163659;border:1px solid rgba(255,145,176,.36);color:#ffc5d2}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#020818b8;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(104,144,203,.32)}.modal-header h3{margin:0}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#7fa3d7}.modal-close:hover{color:#e8f2ff}.modal-body{padding:20px}.modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:20px;border-top:1px solid #eee}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.btn-secondary{background:linear-gradient(145deg,#b1c3d89e,#97acc680 48%,#cfddee8f);color:#000;border:1px solid rgba(186,204,226,.82);color:#e8f2ff}.btn-secondary:hover{background:linear-gradient(145deg,#bccee39e,#a2b7d180 48%,#dae8f98f)}.btn-danger{background:linear-gradient(145deg,#f48b9a9e,#e86d8180 48%,#ffb5c18f);color:#000;border:1px solid rgba(243,153,171,.8);color:#f1f6ff}.btn-danger:hover{background:linear-gradient(145deg,#fa96a59e,#ee788c80 48%,#ffc0cc8f)}.form-group select{width:100%;padding:12px;border:1px solid rgba(82,150,243,.52);background:#2c344b;color:#ecf5ff;border-radius:8px;font-size:14px;box-sizing:border-box;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48)}.header-actions{display:flex;align-items:center;gap:15px}.mode-switch{display:flex;background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:8px;padding:4px}.mode-btn{padding:8px 16px;border:none;background:transparent;cursor:pointer;border-radius:6px;font-size:14px;color:#9ab4db;transition:all .2s}.mode-btn.active{background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);color:#667eea;box-shadow:0 2px 4px #0000001a}.mode-btn:hover:not(.active){color:#e8f2ff}.frame-list-compact{padding:10px 0}.list-summary{color:#9ab4db;margin:0 0 15px;font-size:14px}.frame-grid-compact{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.frame-card-compact{background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s}.frame-card-compact:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.frame-card-compact img{width:100%;height:150px;object-fit:cover}.frame-meta-compact{padding:8px 10px;display:flex;justify-content:space-between;align-items:center;font-size:11px;background:#00000008}.frame-meta-compact .time{color:#667eea;font-weight:500}.frame-meta-compact .env{color:#888}.album-view{padding:10px 0}.album-main{position:relative;background:#020c23;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:400px;max-height:70vh}.album-main img{max-width:100%;max-height:70vh;object-fit:contain}.nav-btn{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border:none;background:#082452e0;color:#eaf3ff;border:1px solid rgba(132,190,245,.7);border-radius:50%;font-size:20px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0003}.nav-btn:hover:not(:disabled){background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);transform:translateY(-50%) scale(1.1)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.nav-btn.prev{left:15px}.nav-btn.next{right:15px}.album-info{display:flex;justify-content:center;gap:25px;padding:15px;background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:8px;margin-top:15px;font-size:14px;color:#555}.album-info span{display:flex;align-items:center;gap:5px}.album-controls{display:flex;align-items:center;justify-content:center;gap:15px;padding:15px;margin-top:10px}.play-btn{padding:10px 25px;background:linear-gradient(145deg,#84bef5a3,#6cacec7a 48%,#a0d5ff8a);color:#000;border:1px solid rgba(152,202,247,.82);color:#f1f6ff;border:none;border-radius:25px;font-size:14px;cursor:pointer;transition:background .2s}.play-btn:hover{background:linear-gradient(145deg,#8ec7fca3,#78b8f47a 48%,#a9dcff8a)}.interval-select{padding:8px 12px;border:1px solid rgba(82,150,243,.52);background:#2c344b;color:#ecf5ff;border-radius:6px;font-size:14px;background:linear-gradient(90deg,#061844e6,#061844e6 4%,#030e2cf5);border:1px solid rgba(84,154,255,.48);cursor:pointer}.progress-label{color:#9ab4db;font-size:14px;min-width:80px;text-align:center}.album-progress{padding:0 20px 15px}.progress-slider{width:100%;height:8px;-webkit-appearance:none;background:linear-gradient(145deg,#b1c3d89e,#97acc680 48%,#cfddee8f);color:#000;border:1px solid rgba(186,204,226,.82);border-radius:4px;outline:none;cursor:pointer}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:linear-gradient(145deg,#84bef5a3,#6cacec7a 48%,#a0d5ff8a);color:#000;border:1px solid rgba(152,202,247,.82);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0003}.progress-slider::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(145deg,#84bef5a3,#6cacec7a 48%,#a0d5ff8a);color:#000;border:1px solid rgba(152,202,247,.82);border-radius:50%;cursor:pointer;border:none}.album-thumbs{display:flex;gap:8px;padding:10px 20px;overflow-x:auto;background:#091b48d9;border:1px solid rgba(80,137,216,.4);border-radius:8px}.album-thumbs .thumb{width:60px;height:45px;object-fit:cover;border-radius:4px;cursor:pointer;opacity:.6;transition:all .2s;flex-shrink:0;border:2px solid transparent}.album-thumbs .thumb:hover{opacity:.9}.album-thumbs .thumb.active{opacity:1;border-color:#667eea;box-shadow:0 0 0 2px #667eea4d}.album-controls .interval-select,.album-controls select{background:#2c344b!important;color:#ecf5ff!important;border:1px solid rgba(82,150,243,.52)!important}.album-controls .interval-select option,.album-controls select option{background:#2c344b!important;color:#ecf5ff!important}.video-panel{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 4px 6px #0000001a}.video-generate-section h3{margin:0 0 15px;color:#333;font-size:16px}.date-range-picker{display:flex;align-items:flex-end;gap:15px;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;gap:5px}.date-input-group label{font-size:12px;color:#666}.date-input-group input[type=date]{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;min-width:150px}.date-input-group input[type=date]:focus{outline:none;border-color:#667eea}.date-separator{color:#999;padding-bottom:10px}.generate-btn{padding:10px 20px;font-size:14px}.video-list-section{margin-top:20px;padding-top:20px;border-top:1px solid #eee}.video-list-section h4{margin:0 0 15px;color:#555;font-size:14px}.video-list{display:flex;flex-direction:column;gap:10px}.video-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:#f8f9fa;border-radius:8px;transition:background .2s}.video-item:hover{background:#f0f0f0}.video-info{display:flex;align-items:center;gap:20px;flex:1}.video-name{font-weight:500;color:#333}.video-date{color:#667eea;font-size:13px}.video-size{color:#999;font-size:12px}.video-actions{display:flex;gap:8px}.video-actions a{text-decoration:none}@media (max-width: 768px){.container{padding:12px}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.header-actions{width:100%;flex-wrap:wrap;gap:8px}.header-actions .btn,.header-actions .mode-btn{flex:1 1 140px}.video-panel{padding:14px}.date-range-picker{flex-direction:column;align-items:stretch;gap:10px}.date-separator{display:none}.date-input-group{width:100%}.date-input-group input[type=date]{width:100%;min-width:0;box-sizing:border-box}.generate-btn{width:100%}.video-item{flex-direction:column;align-items:stretch;gap:10px}.video-info{flex-direction:column;align-items:flex-start;gap:6px;min-width:0}.video-name{width:100%;overflow-wrap:anywhere}.video-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.video-actions .btn,.video-actions a{width:100%;box-sizing:border-box;text-align:center}}@media (max-width: 480px){.video-actions{grid-template-columns:1fr}}.env-curve-panel{background:#fff;border-radius:12px;padding:20px;margin-bottom:20px;box-shadow:0 4px 6px #0000001a}.env-curve-header h3{margin:0 0 8px;color:#333;font-size:16px}.env-curve-header p{margin:0 0 14px;font-size:13px;color:#666}.env-chart-list{margin-top:14px;display:grid;gap:12px}.env-combined-chart{border:1px solid #e7eaf0;border-radius:10px;padding:12px;background:#fbfcff}.env-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.env-scale-note{margin:2px 0 8px;color:#6b7892;font-size:12px}.env-legend-item{display:inline-flex;align-items:center;gap:6px;border:1px solid #d7deec;background:#fff;color:#33415a;border-radius:999px;padding:4px 10px;font-size:12px;cursor:pointer}.env-legend-item.inactive{opacity:.45}.env-legend-item.active{border-color:#aebedd;box-shadow:0 0 0 1px #e6ecfa inset}.env-legend-color{width:10px;height:10px;border-radius:50%;display:inline-block}.env-chart-card{border:1px solid #e7eaf0;border-radius:10px;padding:10px 12px 12px;background:#fbfcff}.env-chart-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;color:#263047;font-weight:600;font-size:13px}.env-chart-latest{font-size:12px;color:#66748d;font-weight:500}.env-chart-svg{width:100%;height:220px;display:block}.env-chart-svg-tall{height:420px}.env-axis-line{stroke:#b7c2d4;stroke-width:1}.env-grid-line{stroke:#e8edf6;stroke-width:1;stroke-dasharray:3 3}.env-axis-text{fill:#6f7f99;font-size:12px}.env-hover-line{stroke:#98a6bf;stroke-width:1;stroke-dasharray:4 4}.env-tooltip-bg{fill:#1c2230ed;stroke:#92a3bf8c;stroke-width:1}.env-tooltip-time{fill:#f2f7ff;font-size:12px;font-weight:600}.env-tooltip-text{fill:#d9e7ff;font-size:12px}.env-empty{margin-top:10px;border-radius:8px;padding:12px;text-align:center;background:#f6f8fc;color:#77839a;font-size:13px}@media (max-width: 768px){.env-curve-panel{padding:14px}.env-chart-svg{height:180px}.env-chart-svg-tall{height:340px}.env-chart-title{flex-direction:column;align-items:flex-start}}
