:root{--primary:#00d2ff;--primary-glow:#00d2ff4d;--secondary:#3a7bd5;--bg-dark:#0f172a;--bg-card:#1e293b99;--bg-card-hover:#1e293bcc;--text-main:#f8fafc;--text-muted:#94a3b8;--accent:#f59e0b;--success:#10b981;--danger:#ef4444;--border:#ffffff1a}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-dark);color:var(--text-main);background-image:radial-gradient(at 0 0,#3a7bd526 0,#0000 50%),radial-gradient(at 100% 0,#00d2ff26 0,#0000 50%);min-height:100vh;margin:0;font-family:Outfit,Inter,system-ui,-apple-system,sans-serif;overflow-x:hidden}#root{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f172acc;flex-direction:column;padding:1.5rem;display:flex}.sidebar-header{align-items:center;gap:.75rem;margin-bottom:2.5rem;display:flex}.sidebar-header h2{color:var(--text-main);font-size:1.25rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:.5rem;display:flex}.nav-item{color:var(--text-muted);border-radius:.75rem;align-items:center;gap:.75rem;padding:.75rem 1rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex}.nav-item:hover{color:var(--text-main);background:#ffffff0d}.nav-item.active{background:var(--primary-glow);color:var(--primary);border:1px solid #00d2ff33}.sidebar-footer{border-top:1px solid var(--border);padding-top:1.5rem}.dashboard-container{width:100%;max-width:1200px;margin:0;padding:2rem}.header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding-bottom:1rem;display:flex}.view-toggle{background:#ffffff0d;border-radius:.75rem;gap:.25rem;padding:.25rem;display:flex}.toggle-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.auth-container{background:var(--bg-dark);grid-column:1/-1;justify-content:center;align-items:center;height:100vh;display:flex}.auth-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:2rem;width:100%;max-width:400px;padding:3rem;box-shadow:0 25px 50px -12px #00000080}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{margin-top:1rem;font-size:1.5rem}.auth-header p{color:var(--text-muted);font-size:.875rem}.form-group{margin-bottom:1.25rem;position:relative}.form-group svg{color:var(--text-muted);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.form-group input,.form-group select{border:1px solid var(--border);color:#fff;background:#ffffff0d;border-radius:.75rem;width:100%;padding:.875rem 1rem .875rem 3rem;font-size:1rem;transition:all .2s}.form-group input:focus{border-color:var(--primary);background:#ffffff1a;outline:none}.auth-btn{background:var(--primary);color:#000;cursor:pointer;border:none;border-radius:.75rem;width:100%;padding:.875rem;font-weight:700;transition:all .2s}.auth-btn:hover{filter:brightness(1.1);transform:scale(1.02)}.auth-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.875rem}.auth-footer a{color:var(--primary);font-weight:600;text-decoration:none}.admin-table{border-collapse:collapse;width:100%;margin-top:1rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:1rem}.admin-table th{color:var(--text-muted);text-transform:uppercase;font-size:.75rem}.approve-btn{background:var(--primary-glow);color:var(--primary);cursor:pointer;border:1px solid #00d2ff33;border-radius:.5rem;padding:.4rem .8rem;font-size:.75rem}.text-danger{color:var(--danger)}.admin-form{flex-direction:column;gap:1rem;display:flex}.admin-form input,.admin-form select{border:1px solid var(--border);color:#fff;background:#ffffff0d;border-radius:.5rem;padding:.75rem}.reg-section{background:#0000001a;border-radius:.5rem;padding:1rem}.reg-inputs{gap:.5rem;margin-top:.5rem;display:flex}.reg-inputs input{flex:1;padding:.4rem}.add-reg-btn{background:var(--primary);cursor:pointer;border:none;border-radius:.4rem;padding:.4rem .8rem}.save-btn{background:var(--primary);color:#000;cursor:pointer;border:none;border-radius:.5rem;margin-top:1rem;padding:1rem;font-weight:700}.meter-config-grid{grid-template-columns:1fr 1fr;gap:2rem;display:grid}.meter-list{flex-direction:column;gap:1rem;display:flex}.meter-item{border:1px solid var(--border);background:#ffffff08;border-radius:.75rem;justify-content:space-between;align-items:center;padding:1rem;display:flex}.reg-count{background:var(--primary-glow);color:var(--primary);border-radius:.25rem;padding:.25rem .5rem;font-size:.7rem;font-weight:600}.header h1{background:linear-gradient(to right, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;align-items:center;gap:.75rem;font-size:1.8rem;font-weight:700;display:flex}.status-badge{color:var(--success);background:#10b9811a;border:1px solid #10b98133;border-radius:9999px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:600;display:flex}.status-badge.disconnected{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:1.25rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.card:hover{background:var(--bg-card-hover);border-color:#fff3;transform:translateY(-5px);box-shadow:0 10px 25px -5px #0000004d}.card:before{content:"";background:var(--primary);width:4px;height:0;transition:height .3s;position:absolute;top:0;left:0}.card:hover:before{height:100%}.card-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:flex}.card-value{color:var(--text-main);margin-bottom:.25rem;font-size:2.25rem;font-weight:700}.card-unit{color:var(--text-muted);margin-left:.5rem;font-size:1rem;font-weight:500}.card-footer{color:var(--text-muted);align-items:center;gap:.4rem;margin-top:1rem;font-size:.75rem;display:flex}.charts-container{grid-template-columns:2fr 1fr;gap:1.5rem;display:grid}.chart-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:1.25rem;min-height:400px;padding:1.5rem}.chart-header{margin-bottom:1.5rem}.phase-values{grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-top:1rem;display:grid}.phase-item{text-align:center;background:#ffffff08;border-radius:.75rem;padding:.75rem}.phase-label{color:var(--text-muted);text-transform:uppercase;margin-bottom:.25rem;font-size:.7rem}.phase-val{color:var(--primary);font-size:1.1rem;font-weight:600}@media (width<=1024px){.charts-container{grid-template-columns:1fr}}@media (width<=640px){.dashboard-container{padding:1rem}.header h1{font-size:1.4rem}.stats-grid{grid-template-columns:1fr}}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.dot{background:currentColor;border-radius:50%;width:8px;height:8px;display:inline-block}.dot.pulse{animation:2s infinite pulse}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0f172ab3;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);background:#1e293bd9;border-radius:1.5rem;width:100%;max-width:400px;padding:2rem;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;box-shadow:0 20px 40px -15px #00000080}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-header h3{color:var(--text-main);font-size:1.25rem;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1.5rem;transition:color .2s}.modal-close:hover{color:var(--danger)}.modal-body{flex-direction:column;gap:1.25rem;display:flex}.modal-body input{border:1px solid var(--border);color:#fff;background:#ffffff0d;border-radius:.75rem;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .2s}.modal-body input:focus{border-color:var(--primary);background:#ffffff1a;outline:none}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.btn-secondary{color:var(--text-main);border:1px solid var(--border);cursor:pointer;background:#ffffff0d;border-radius:.5rem;padding:.6rem 1.2rem;font-size:.875rem;font-weight:600;transition:all .2s}.btn-secondary:hover{background:#ffffff1a}.btn-primary{background:var(--primary);color:#000;cursor:pointer;border:none;border-radius:.5rem;padding:.6rem 1.2rem;font-size:.875rem;font-weight:700;transition:all .2s}.btn-primary:hover{filter:brightness(1.1);transform:scale(1.02)}.action-icon-btn{cursor:pointer;background:0 0;border:none;border-radius:.375rem;justify-content:center;align-items:center;padding:.35rem;transition:all .2s;display:inline-flex}.action-icon-btn:hover{background:#ffffff0d}.assigned-meters-list{flex-direction:column;gap:.25rem;display:flex}.assigned-meter-badge{border:1px solid var(--border);color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;background:#ffffff0d;border-radius:.375rem;max-width:150px;padding:.2rem .5rem;font-size:.75rem;display:inline-block;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landing-container{background-color:var(--bg-dark);min-height:100vh;color:var(--text-main);background-image:radial-gradient(at 10% 20%,#3a7bd51f 0,#0000 50%),radial-gradient(at 90% 80%,#00d2ff1a 0,#0000 50%);flex-direction:column;grid-column:1/-1;font-family:Outfit,Inter,sans-serif;display:flex;overflow:hidden auto}.landing-header{z-index:10;justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex}.landing-logo{align-items:center;gap:.75rem;display:flex}.landing-logo h2,.landing-logo h3{letter-spacing:-.025em;color:var(--text-main);font-size:1.5rem;font-weight:800}.landing-logo span{background:linear-gradient(to right, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.landing-nav-actions{align-items:center;gap:1.5rem;display:flex}.btn-text{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:.95rem;font-weight:600;transition:color .2s}.btn-text:hover{color:var(--text-main)}.btn-primary-small{background:var(--primary);color:#000;cursor:pointer;border:none;border-radius:.5rem;padding:.6rem 1.25rem;font-size:.9rem;font-weight:700;transition:all .2s}.btn-primary-small:hover{filter:brightness(1.1);transform:scale(1.02)}.landing-hero{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:1000px;margin:0 auto;padding:5rem 2rem 3rem;animation:.8s ease-out fadeIn;display:flex}.hero-badge{color:var(--primary);background:#00d2ff14;border:1px solid #00d2ff33;border-radius:9999px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:flex;box-shadow:0 4px 12px #00d2ff0d}.landing-hero h1{letter-spacing:-.03em;max-width:800px;margin-bottom:1.5rem;font-size:3.5rem;font-weight:800;line-height:1.15}.landing-hero h1 span{background:linear-gradient(to right, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hero-subtitle{color:var(--text-muted);max-width:650px;margin-bottom:2.5rem;font-size:1.2rem;line-height:1.6}.hero-actions{gap:1rem;margin-bottom:4rem;display:flex}.btn-hero-primary{background:var(--primary);color:#000;cursor:pointer;border:none;border-radius:.75rem;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:1.05rem;font-weight:700;transition:all .3s;display:flex;box-shadow:0 10px 20px -5px #00d2ff4d}.btn-hero-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 12px 24px -5px #00d2ff66}.btn-hero-secondary{color:var(--text-main);border:1px solid var(--border);cursor:pointer;background:#ffffff0d;border-radius:.75rem;padding:.875rem 1.75rem;font-size:1.05rem;font-weight:700;transition:all .3s}.btn-hero-secondary:hover{background:#ffffff1a;transform:translateY(-2px)}.hero-preview-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293b66;border:1px solid #ffffff1a;border-radius:1.5rem;width:100%;max-width:900px;margin-top:1rem;padding:.5rem;animation:.8s cubic-bezier(.16,1,.3,1) .1s both slideUp;position:relative;box-shadow:0 30px 60px -15px #000c}.hero-preview-glow{filter:blur(30px);z-index:-1;pointer-events:none;background:radial-gradient(#00d2ff26 0%,#0000 70%);width:80%;height:100px;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.hero-preview-img{border:1px solid #ffffff0d;border-radius:1rem;width:100%;height:auto;display:block}.landing-stats{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);background:#1e293b4d;border-radius:1.5rem;justify-content:space-around;align-items:center;width:100%;max-width:1000px;margin:4rem auto;padding:2rem;display:flex}.stat-item{text-align:center}.stat-item h3{background:linear-gradient(to right, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.25rem;font-size:2.25rem;font-weight:800}.stat-item p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:500}.stat-divider{background:var(--border);width:1px;height:40px}.landing-features{width:100%;max-width:1200px;margin:4rem auto;padding:2rem}.section-title-wrap{text-align:center;margin-bottom:4rem}.section-tag{color:var(--primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-size:.85rem;font-weight:700;display:inline-block}.section-title-wrap h2{letter-spacing:-.02em;margin-bottom:1rem;font-size:2.5rem;font-weight:800}.section-title-wrap p{color:var(--text-muted);max-width:500px;margin:0 auto;line-height:1.6}.features-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;display:grid}.feature-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:1.5rem;padding:2.5rem 2rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.feature-card:before{content:"";background:var(--icon-color);opacity:0;width:100%;height:3px;transition:opacity .3s;position:absolute;top:0;left:0}.feature-card:hover{background:var(--bg-card-hover);border-color:#ffffff26;transform:translateY(-5px);box-shadow:0 15px 30px -10px #0006}.feature-card:hover:before{opacity:1}.feature-icon-wrap{border:1px solid var(--border);width:50px;height:50px;color:var(--icon-color);background:#ffffff08;border-radius:.75rem;justify-content:center;align-items:center;margin-bottom:1.5rem;transition:all .3s;display:flex}.feature-card:hover .feature-icon-wrap{background:#ffffff12;transform:scale(1.05)}.feature-card h3{color:var(--text-main);margin-bottom:.75rem;font-size:1.25rem;font-weight:700}.feature-card p{color:var(--text-muted);font-size:.95rem;line-height:1.5}.landing-footer{border-top:1px solid var(--border);background:#0f172ae6;width:100%;margin-top:auto;padding:4rem 2rem 2rem}.footer-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:2rem;max-width:1200px;margin:0 auto 3rem;display:flex}.footer-brand{max-width:350px}.footer-brand p{color:var(--text-muted);margin-top:1rem;font-size:.95rem;line-height:1.5}.footer-credits h4{color:var(--primary);margin-top:.25rem;font-size:1.1rem;font-weight:700}.footer-credits p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.footer-bottom{text-align:center;border-top:1px solid #ffffff0d;max-width:1200px;margin:0 auto;padding-top:1.5rem}.footer-bottom p{color:#64748b;font-size:.85rem}@media (width<=768px){.landing-hero h1{font-size:2.5rem}.landing-stats{flex-direction:column;gap:1.5rem;padding:2rem 1rem}.stat-divider{width:40px;height:1px}.footer-top{text-align:center;flex-direction:column;align-items:center}.footer-brand{flex-direction:column;align-items:center;display:flex}}.contact-card-grid{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:2rem;grid-template-columns:1.2fr 1fr;gap:3rem;width:100%;max-width:1000px;padding:3.5rem;animation:.6s cubic-bezier(.16,1,.3,1) slideUp;display:grid;box-shadow:0 30px 60px -15px #0009}.contact-info-panel{flex-direction:column;display:flex}.contact-info-panel h2{letter-spacing:-.02em;margin-top:.5rem;margin-bottom:1rem;font-size:2.25rem;font-weight:800;line-height:1.2}.contact-info-panel h2 span{background:linear-gradient(to right, var(--primary), var(--secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text}.contact-desc{color:var(--text-muted);margin-bottom:2.5rem;font-size:.975rem;line-height:1.6}.contact-details-list{flex-direction:column;gap:1.75rem;display:flex}.contact-detail-item{align-items:flex-start;gap:1rem;display:flex}.contact-icon{width:44px;height:44px;color:var(--primary);background:#00d2ff14;border:1px solid #00d2ff33;border-radius:.75rem;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 10px #00d2ff0d}.contact-detail-item h4{color:var(--text-main);margin-bottom:.25rem;font-size:.95rem;font-weight:700}.contact-detail-item p{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.4}.contact-form-panel{border:1px solid var(--border);background:#ffffff05;border-radius:1.5rem;flex-direction:column;justify-content:center;padding:2.5rem;display:flex}.contact-form{flex-direction:column;gap:1.25rem;display:flex}.form-group-wrap{flex-direction:column;gap:.5rem;display:flex}.form-group-wrap label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.form-group-wrap input,.form-group-wrap textarea{border:1px solid var(--border);color:#fff;background:#ffffff0a;border-radius:.75rem;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:.95rem;transition:all .2s}.form-group-wrap input:focus,.form-group-wrap textarea:focus{border-color:var(--primary);background:#ffffff14;outline:none}.contact-success-state{text-align:center;flex-direction:column;align-items:center;padding:1rem;animation:.4s ease-out fadeIn;display:flex}.contact-success-state h3{color:var(--text-main);margin-bottom:.5rem;font-size:1.5rem;font-weight:700}.contact-success-state p{color:var(--text-muted);max-width:320px;font-size:.95rem;line-height:1.6}@media (width<=868px){.contact-card-grid{grid-template-columns:1fr;gap:3.5rem;padding:2.5rem 2rem}.contact-info-panel h2{font-size:1.8rem}.contact-form-panel{padding:1.75rem}}.gateways-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1.5rem;margin-top:1rem;display:grid}.gateway-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:1.25rem;flex-direction:column;gap:1rem;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.gateway-card:hover{background:var(--bg-card-hover);border-color:#00d2ff4d;transform:translateY(-4px);box-shadow:0 12px 30px -10px #00d2ff26}.gateway-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding-bottom:.75rem;display:flex}.gateway-info-primary{flex-direction:column;gap:.25rem;display:flex}.gateway-title{color:var(--text-main);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:700;display:flex}.gateway-id{color:var(--text-muted);font-family:monospace;font-size:.75rem}.gateway-status-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.75rem;font-weight:700;display:inline-flex}.gateway-status-badge.online{color:#10b981;background:#10b9811f;border:1px solid #10b98140}.gateway-status-badge.offline{color:#ef4444;background:#ef44441f;border:1px solid #ef444440}.gateway-details-list{flex-direction:column;gap:.5rem;font-size:.85rem;display:flex}.gateway-detail-item{justify-content:space-between;align-items:center;display:flex}.gateway-detail-label{color:var(--text-muted)}.gateway-detail-value{color:var(--text-main);font-weight:500}.gateway-meters-summary{border:1px solid var(--border);color:var(--text-muted);background:#ffffff08;border-radius:.5rem;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.85rem;display:flex}.gateway-meters-count{background:var(--primary-glow);color:var(--primary);border-radius:.25rem;padding:.15rem .4rem;font-size:.75rem;font-weight:700}.gateway-accordion-btn{border:1px solid var(--border);width:100%;color:var(--text-main);cursor:pointer;background:#ffffff05;border-radius:.5rem;justify-content:center;align-items:center;gap:.5rem;padding:.6rem;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.gateway-accordion-btn:hover{background:#ffffff0d;border-color:#fff3}.gateway-meters-dropdown{border:1px solid var(--border);background:#0f172a66;border-radius:.75rem;flex-direction:column;gap:.5rem;margin-top:.5rem;padding:.75rem;animation:.25s cubic-bezier(.16,1,.3,1) slideDown;display:flex}.gateway-meter-row{border-bottom:1px solid #ffffff08;justify-content:space-between;align-items:center;padding:.5rem;font-size:.8rem;display:flex}.gateway-meter-row:last-child{border-bottom:none}.gateway-meter-info{flex-direction:column;gap:.15rem;display:flex}.gateway-meter-name{color:var(--text-main);font-weight:600}.gateway-meter-protocol{color:var(--text-muted);font-size:.7rem}.gateway-meter-details{text-align:right;color:var(--text-muted);font-size:.75rem}.dsm-page{animation:.3s ease-in-out fadeIn}.dsm-card{padding:20px}.tabs{gap:10px;margin-bottom:20px;display:flex}.tab-btn{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-weight:500;transition:all .2s;display:flex}.tab-btn:hover{background:#ffffff0d}.tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.blocks-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:15px;max-height:600px;margin-top:20px;padding-right:10px;display:grid;overflow-y:auto}.block-input-group{flex-direction:column;gap:5px;display:flex}.block-input-group label{color:#888;font-size:.8rem}.input-field.small{padding:8px;font-size:.9rem}.date-picker{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:10px;padding:5px 15px;display:flex}.date-picker .input-field{background:0 0;border:none;padding:5px}.date-picker .input-field:focus{border:none;outline:none}.text-warning{color:#f39c12}.text-success{color:#27ae60}
