@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--primary: #00a19a;--primary-light: #00c4bc;--primary-dark: #00847e;--primary-glow: rgba(0, 161, 154, .3);--bg-primary: #0a0e17;--bg-secondary: #111827;--bg-card: rgba(17, 24, 39, .8);--bg-card-hover: rgba(17, 24, 39, .95);--bg-input: rgba(17, 24, 39, .6);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border: rgba(148, 163, 184, .1);--border-focus: rgba(0, 161, 154, .5);--danger: #ef4444;--danger-dark: #dc2626;--success: #22c55e;--warning: #f59e0b;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -4px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 8px 10px -6px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--primary-glow), 0 0 40px rgba(0, 161, 154, .1);--transition: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;background:radial-gradient(ellipse at 30% 20%,rgba(0,161,154,.08) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(0,161,154,.05) 0%,transparent 50%),var(--bg-primary)}.login-bg-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(0,161,154,.06) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(0,161,154,.04) 0%,transparent 50%);animation:bgPulse 8s ease-in-out infinite alternate}@keyframes bgPulse{0%{opacity:.5}to{opacity:1}}.login-card{width:100%;max-width:420px;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:3rem 2.5rem;box-shadow:var(--shadow-xl);position:relative;z-index:1;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-logo{text-align:center;margin-bottom:2rem}.login-logo img{height:48px;width:auto}.login-title{text-align:center;font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.login-subtitle{text-align:center;color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.label-hint{font-weight:400;color:var(--text-muted);font-size:.8rem}.input-icon-wrapper{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted);transition:color var(--transition);pointer-events:none}.input-icon-wrapper input{padding-left:42px!important}.input-icon-wrapper:focus-within .input-icon{color:var(--primary)}input[type=text],input[type=password],input[type=email],input[type=search],.search-bar input{width:100%;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--transition);outline:none}input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-glow);background:#111827cc}input.input-error{border-color:var(--danger)}input::placeholder{color:var(--text-muted)}.field-meta{display:flex;justify-content:flex-end;margin-top:.25rem}.char-count{font-size:.75rem;font-family:JetBrains Mono,monospace;color:var(--text-muted);transition:color var(--transition)}.char-count.valid{color:var(--success)}.error-text{font-size:.8rem;color:var(--danger);display:flex;align-items:center;gap:.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all var(--transition);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:var(--shadow-sm),0 0 15px #00a19a33}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--primary-light),var(--primary));box-shadow:var(--shadow-md),0 0 25px #00a19a4d;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-input);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary);border-color:#94a3b833}.btn-danger{background:linear-gradient(135deg,var(--danger),var(--danger-dark));color:#fff}.btn-danger:hover:not(:disabled){box-shadow:var(--shadow-md),0 0 20px #ef44444d;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary);padding:.5rem 1rem;border:1px solid transparent}.btn-ghost:hover{background:#94a3b81a;color:var(--text-primary);border-color:var(--border)}.btn-block{display:flex;width:100%}.btn-loading{display:flex;align-items:center;gap:.5rem}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.btn-icon:hover{background:#94a3b81a;color:var(--primary)}.btn-icon-danger:hover{background:#ef44441a;color:var(--danger)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:.875rem 1rem;border-radius:var(--radius-md);font-size:.9rem;display:flex;align-items:center;justify-content:space-between}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#fca5a5}.alert-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.2rem;padding:0 .25rem;opacity:.7}.alert-close:hover{opacity:1}.app-layout{min-height:100vh;display:flex;flex-direction:column}.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:64px;background:#111827f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.navbar-brand{display:flex;align-items:center}.navbar-logo{height:32px;width:auto}.navbar-actions{display:flex;align-items:center;gap:1rem}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.4rem .85rem;background:#00a19a1a;border:1px solid rgba(0,161,154,.2);border-radius:var(--radius-lg);color:var(--primary-light);font-size:.875rem;font-weight:500}.main-content{flex:1;padding:2rem;max-width:1280px;margin:0 auto;width:100%}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem}.page-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.025em}.page-subtitle{color:var(--text-secondary);font-size:.95rem;margin-top:.25rem}.search-bar{position:relative;margin-bottom:2rem}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted);pointer-events:none}.search-bar input{padding-left:42px!important;background:var(--bg-card);border:1px solid var(--border)}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1.25rem}.device-card{background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-slow);animation:fadeInUp .4s ease-out both}.device-card:hover{border-color:#00a19a4d;box-shadow:var(--shadow-lg),0 0 30px #00a19a0d;transform:translateY(-2px)}.device-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.device-name{display:flex;align-items:center;gap:.75rem}.device-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:#00a19a1a;color:var(--primary);flex-shrink:0}.device-name h3{font-size:1.05rem;font-weight:600;color:var(--text-primary)}.device-actions{display:flex;gap:.25rem}.device-details{display:flex;flex-direction:column;gap:.75rem}.detail-row{display:flex;align-items:center;justify-content:space-between;padding:.625rem .875rem;background:#0003;border-radius:var(--radius-sm);gap:1rem}.detail-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.detail-value{font-family:JetBrains Mono,Fira Code,monospace;font-size:.8rem;color:var(--primary-light);background:transparent;word-break:break-all;text-align:right}.detail-value.appkey{font-size:.72rem}.device-card-footer{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.device-meta{font-size:.8rem;color:var(--text-muted)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-muted)}.empty-state svg{margin-bottom:1.5rem;opacity:.4}.empty-state h3{font-size:1.25rem;color:var(--text-secondary);margin-bottom:.5rem}.empty-state p{margin-bottom:1.5rem}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:2rem;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{width:100%;max-width:520px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2rem;box-shadow:var(--shadow-xl);animation:modalSlide .3s ease-out;max-height:90vh;overflow-y:auto}.modal-sm{max-width:400px}@keyframes modalSlide{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.modal-header h2{font-size:1.25rem;font-weight:700}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-muted);font-size:1.5rem;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition)}.modal-close:hover{background:#94a3b81a;color:var(--text-primary)}.device-form{display:flex;flex-direction:column;gap:1.25rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:.5rem}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh}.loader{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.main-content{padding:1.5rem 1rem}.page-header{flex-direction:column}.page-header .btn-primary{width:100%}.devices-grid{grid-template-columns:1fr}.navbar{padding:0 1rem}.login-card{padding:2rem 1.5rem}.modal-content{margin:1rem;padding:1.5rem}.user-badge span{display:none}}@media(max-width:480px){.detail-row{flex-direction:column;align-items:flex-start;gap:.25rem}.detail-value{text-align:left}}.btn-icon-downlink:hover{background:#00a19a1a;color:var(--primary)}.btn-icon-logs:hover{background:#f59e0b1a;color:var(--warning)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:9999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.badge-success{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.25)}.badge-danger{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.25)}.badge-warning{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.25)}.modal-subtitle{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.payload-header{display:flex;align-items:center;justify-content:space-between}.format-toggle{display:flex;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.toggle-btn{padding:.4rem .85rem;font-size:.75rem;font-weight:600;font-family:JetBrains Mono,monospace;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all var(--transition)}.toggle-btn.active{background:var(--primary);color:#fff}.toggle-btn:hover:not(.active){color:var(--text-primary);background:#94a3b81a}.mono-input{font-family:JetBrains Mono,monospace!important;letter-spacing:.05em}.payload-preview{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem;background:#0003;border-radius:var(--radius-sm);font-size:.8rem}.preview-label{color:var(--text-muted);font-size:.75rem;font-weight:600;text-transform:uppercase;flex-shrink:0}.payload-preview code{font-family:JetBrains Mono,monospace;color:var(--primary-light);font-size:.8rem;word-break:break-all}.field-error{font-size:.8rem;color:var(--danger)}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}input[type=number]{width:100%;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--transition);outline:none}input[type=number]:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-glow);background:#111827cc}.modal-lg{max-width:680px}.table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-md)}.logs-table{width:100%;border-collapse:collapse;font-size:.85rem}.logs-table th{text-align:left;padding:.75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#00000040;border-bottom:1px solid var(--border);white-space:nowrap}.logs-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);color:var(--text-secondary)}.logs-table tbody tr:last-child td{border-bottom:none}.logs-table tbody tr:hover{background:#00a19a0a}.logs-table .mono{font-family:JetBrains Mono,monospace;font-size:.8rem;color:var(--primary-light)}.logs-table .nowrap{white-space:nowrap;font-size:.8rem}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}.pagination-info{font-size:.85rem;color:var(--text-muted)}.btn-sm{padding:.4rem .85rem;font-size:.8rem;border-radius:var(--radius-sm)}select{width:100%;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all var(--transition);outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;cursor:pointer}select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-glow);background-color:#111827cc}select option{background:var(--bg-secondary);color:var(--text-primary)}.device-type-subtitle{font-size:.75rem;color:var(--text-muted);padding:0 .25rem;margin-top:-.25rem;margin-bottom:.25rem}.input-disabled{opacity:.5;cursor:not-allowed;background:#00000026!important}@media(max-width:768px){.logs-table{font-size:.75rem}.logs-table th,.logs-table td{padding:.5rem}.modal-lg{max-width:100%}}.navbar-nav{display:flex;gap:.25rem}.nav-link{padding:.5rem 1rem;border-radius:var(--radius-md);color:var(--text-muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:all var(--transition)}.nav-link:hover{color:var(--text-primary);background:#ffffff0d}.nav-link.active{color:var(--primary);background:#00a19a1a}.schedule-modal{max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.schedule-form{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group-sm{flex:0 0 100px!important}.form-group-lg{flex:1!important}.target-mode-toggle{display:flex;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.toggle-btn{flex:1;padding:.6rem 1rem;border:none;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.toggle-btn.active{background:#00a19a26;color:var(--primary)}.toggle-btn:hover:not(.active){background:#ffffff08}.device-picker{max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input)}.device-pick-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;cursor:pointer;transition:background var(--transition);border-bottom:1px solid rgba(255,255,255,.03)}.device-pick-item:last-child{border-bottom:none}.device-pick-item:hover{background:#ffffff08}.device-pick-item input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}.device-pick-name{font-weight:500;color:var(--text-primary);flex:1}.device-pick-eui{font-family:JetBrains Mono,monospace;font-size:.75rem;color:var(--text-muted)}.weekday-picker{display:flex;gap:.4rem;flex-wrap:wrap}.weekday-item{display:flex;align-items:center;justify-content:center;width:48px;height:40px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-input);color:var(--text-muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--transition);-webkit-user-select:none;user-select:none}.weekday-item input[type=checkbox]{display:none}.weekday-item:hover{border-color:var(--primary)}.weekday-item.active{background:#00a19a33;border-color:var(--primary);color:var(--primary)}.payload-format-toggle{display:inline-flex;gap:.25rem;margin-left:.5rem}.fmt-btn{padding:.15rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:.7rem;font-weight:600;cursor:pointer;transition:all var(--transition)}.fmt-btn.active{background:#00a19a26;border-color:var(--primary);color:var(--primary)}.schedules-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary)}.schedules-table{width:100%;border-collapse:collapse}.schedules-table thead{background:#0003}.schedules-table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.schedules-table td{padding:.75rem 1rem;font-size:.875rem;color:var(--text-secondary);border-top:1px solid rgba(255,255,255,.03);white-space:nowrap}.schedules-table tr:hover{background:#ffffff05}.schedules-table .row-disabled{opacity:.5}.td-name{font-weight:600;color:var(--text-primary)!important}.td-days{font-size:.8rem!important}.td-time{font-family:JetBrains Mono,monospace}.td-tz{font-size:.8rem!important;color:var(--text-muted)!important}.td-payload{font-size:.8rem;padding:.2rem .5rem;background:#00a19a14;border-radius:var(--radius-sm);color:var(--primary-light)}.td-lastrun{font-size:.8rem!important;color:var(--text-muted)!important}.td-actions{display:flex;gap:.4rem}.toggle-switch{position:relative;width:40px;height:22px;border-radius:11px;border:none;cursor:pointer;transition:background var(--transition);padding:0}.toggle-switch.on{background:var(--primary)}.toggle-switch.off{background:#ffffff26}.toggle-knob{position:absolute;top:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left var(--transition)}.toggle-switch.on .toggle-knob{left:21px}.toggle-switch.off .toggle-knob{left:3px}.page-container{max-width:1200px;margin:0 auto;padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.page-subtitle{color:var(--text-muted);font-size:.875rem;margin-top:.25rem}.error-banner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);color:#f87171;margin-bottom:1rem;font-size:.875rem}.error-banner button{background:none;border:none;color:#f87171;font-size:1.2rem;cursor:pointer}.modal-sm{max-width:400px;padding:1.5rem}@media(max-width:768px){.form-row{flex-direction:column}.weekday-picker{justify-content:center}.schedules-table th:nth-child(5),.schedules-table td:nth-child(5),.schedules-table th:nth-child(8),.schedules-table td:nth-child(8){display:none}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}}
