:root{--text:#1f2937;--text-muted:#6b7280;--text-h:#111827;--bg:#f9fafb;--surface:#fff;--border:#e5e7eb;--primary:#6366f1;--error:#dc2626;--error-bg:#fef2f2;--bg-hover:#f3f4f6;--sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font:16px/1.5 var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;-webkit-font-smoothing:antialiased}@media (prefers-color-scheme:dark){:root{--text:#e5e7eb;--text-muted:#9ca3af;--text-h:#f9fafb;--bg:#111827;--surface:#1f2937;--border:#374151;--primary:#818cf8;--error:#f87171;--error-bg:#450a0a;--bg-hover:#374151}}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}h1,h2{color:var(--text-h);font-weight:600}.loading-screen{min-height:40vh;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.layout{flex-direction:column;min-height:100vh;display:flex}.layout-header{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.logo{color:var(--primary);font-size:1.25rem;font-weight:700;text-decoration:none}.nav{align-items:center;gap:1.25rem;display:flex}.nav a{color:var(--text);font-size:.9rem;text-decoration:none}.nav a:hover{color:var(--primary)}.user{color:var(--text-muted);margin-left:.5rem;font-size:.85rem}.btn-logout{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.4rem .75rem;font-size:.85rem}.btn-logout:hover{background:var(--bg-hover)}.layout-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;padding:2rem;box-shadow:0 4px 20px #00000014}.login-card h1{color:var(--text);margin:0 0 .25rem;font-size:1.75rem}.subtitle{color:var(--text-muted);margin:0 0 1.5rem;font-size:.9rem}.login-error{background:var(--error-bg);color:var(--error);border-radius:8px;margin-bottom:1rem;padding:.75rem;font-size:.9rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-form label{color:var(--text);flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}.login-form input,.login-form select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:8px;padding:.6rem .75rem;font-size:1rem}.login-form input:focus,.login-form select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #6366f133}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.75rem 1rem;font-size:1rem;font-weight:600}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.form-footer,.form-hint{color:var(--text-muted);margin:.5rem 0 0;font-size:.9rem}.form-footer a{color:var(--primary);text-decoration:none}.form-footer a:hover{text-decoration:underline}.dashboard h1{color:var(--text);margin:0 0 .25rem;font-size:1.75rem}.dashboard-sub{color:var(--text-muted);margin:0 0 1.5rem;font-size:.95rem}.dashboard-actions{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.card-link{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:12px;padding:1.25rem;text-decoration:none;transition:border-color .2s,box-shadow .2s;display:block}.card-link:hover{border-color:var(--primary);box-shadow:0 4px 12px #6366f126}.card-title{margin-bottom:.35rem;font-size:1.1rem;font-weight:600;display:block}.card-desc{color:var(--text-muted);font-size:.9rem}.servicios-list h1{color:var(--text);margin:0 0 1rem;font-size:1.5rem}.filters{flex-wrap:wrap;gap:1rem;margin-bottom:1rem;display:flex}.filters label{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.85rem;display:flex}.filters select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;min-width:140px;padding:.5rem .75rem}.list-error{background:var(--error-bg);color:var(--error);border-radius:8px;margin-bottom:1rem;padding:.75rem}.loading,.empty{color:var(--text-muted);margin:1rem 0}.servicios-table{border:1px solid var(--border);border-radius:10px;margin:0;padding:0;list-style:none;overflow:hidden}.servicios-table .row{grid-template-columns:50px 90px 100px 1fr 1fr 90px 60px;align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.9rem;display:grid}.servicios-table .row.header{background:var(--surface);color:var(--text-muted);font-weight:600}.servicios-table .row:not(.header):nth-child(2n){background:var(--surface)}.coord{text-overflow:ellipsis;font-family:ui-monospace,monospace;font-size:.8rem;overflow:hidden}.link{color:var(--primary);text-decoration:none}.link:hover{text-decoration:underline}.pagination-info{color:var(--text-muted);margin-top:.75rem;font-size:.85rem}@media (width<=768px){.servicios-table .row{grid-template-columns:1fr 1fr auto}.servicios-table .row span:nth-child(n+4):nth-child(-n+5){display:none}}.servicio-detail .detail-header{margin-bottom:1rem}.servicio-detail .back{color:var(--primary);margin-bottom:.5rem;font-size:.9rem;text-decoration:none;display:inline-block}.servicio-detail .back:hover{text-decoration:underline}.servicio-detail h1{color:var(--text);margin:0;font-size:1.5rem}.detail-error{background:var(--error-bg);color:var(--error);border-radius:8px;margin-bottom:1rem;padding:.75rem}.detail-error a{color:var(--primary);margin-left:.5rem}.detail-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:1.5rem;padding:1rem}.detail-section h2{color:var(--text);margin:0 0 .75rem;font-size:1.1rem}.detail-section dl{grid-template-columns:auto 1fr;gap:.35rem 1.5rem;margin:0;font-size:.9rem;display:grid}.detail-section dt{color:var(--text-muted)}.detail-section dd{color:var(--text);margin:0}.form-inline{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.form-inline select,.form-inline input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;padding:.5rem .75rem}.form-inline input[type=text]{min-width:160px}.form-inline button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.9rem}.form-inline button:disabled{opacity:.7;cursor:not-allowed}.create-servicio .create-header{margin-bottom:1rem}.create-servicio .back{color:var(--primary);margin-bottom:.5rem;font-size:.9rem;text-decoration:none;display:inline-block}.create-servicio .back:hover{text-decoration:underline}.create-servicio h1{color:var(--text);margin:0;font-size:1.5rem}.create-error{background:var(--error-bg);color:var(--error);border-radius:8px;margin-bottom:1rem;padding:.75rem}.create-form .muted,.create-form .form-warn{margin-top:.25rem;font-size:.9rem;display:block}.create-form .muted{color:var(--text-muted)}.create-form .form-warn{color:var(--error)}.create-form{flex-direction:column;gap:1rem;max-width:420px;display:flex}.create-form label{color:var(--text);flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}.create-form fieldset{border:1px solid var(--border);border-radius:8px;margin:0;padding:1rem}.create-form fieldset legend{color:var(--text-muted);padding:0 .5rem;font-size:.9rem}.create-form input,.create-form select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;padding:.6rem .75rem}.checkboxes{flex-wrap:wrap;gap:1rem;display:flex}.checkbox{align-items:center;flex-direction:row!important}.checkbox input{width:auto;margin-right:.5rem}.create-form .btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:.5rem;padding:.75rem 1rem;font-size:1rem;font-weight:600}.create-form .btn-primary:disabled{opacity:.7;cursor:not-allowed}.profile-page h1{color:var(--text);margin:0 0 1rem;font-size:1.5rem}.profile-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:1.5rem;padding:1rem}.profile-section h2{color:var(--text);margin:0 0 .75rem;font-size:1.1rem}.profile-section dl{grid-template-columns:auto 1fr;gap:.35rem 1.5rem;margin:0;font-size:.9rem;display:grid}.profile-section dt{color:var(--text-muted)}.profile-section dd{color:var(--text);margin:0}.muted{color:var(--text-muted);margin:.5rem 0;font-size:.9rem}.profile-error{color:var(--error);margin:0 0 .5rem;font-size:.9rem}.devices-list{margin:0;padding:0;list-style:none}.device-item{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:.5rem 1rem;padding:.75rem 0;display:flex}.device-item:last-child{border-bottom:none}.device-meta{color:var(--text-muted);flex:1;min-width:200px;font-size:.85rem}.btn-revoke{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.35rem .75rem;font-size:.85rem}.btn-revoke:hover:not(:disabled){background:var(--error-bg);color:var(--error);border-color:var(--error)}.btn-revoke:disabled{opacity:.7;cursor:not-allowed}.profile-form{flex-direction:column;gap:.75rem;max-width:400px;display:flex}.profile-form label{color:var(--text);flex-direction:column;gap:.25rem;font-size:.9rem;display:flex}.profile-form input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;padding:.5rem .75rem}.form-actions{gap:.5rem;margin-top:.5rem;display:flex}.btn-secondary{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.5rem 1rem;font-size:.9rem}.btn-secondary:hover{background:var(--bg-hover)}
