:root{color-scheme:dark;font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#e2e8f0;background-color:#020617}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}button,input,textarea{font:inherit}.shell{min-height:100vh;display:flex;flex-direction:column}.shell-topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;height:3rem;padding:0 .5rem 0 .35rem;background:#020617;border-bottom:1px solid #1e293b}.shell-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;margin:0;padding:0;border:none;border-radius:10px;background:transparent;color:#e2e8f0;cursor:pointer}.shell-menu-btn:hover{background:#0f172a}.shell-menu-btn:focus-visible{outline:2px solid #38bdf8;outline-offset:2px}.shell-menu-icon{display:flex;flex-direction:column;gap:5px;width:1.35rem}.shell-menu-icon span{display:block;height:2px;border-radius:1px;background:currentColor}.shell-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;margin:0;padding:0;border:none;background:#0206178c;cursor:pointer}.shell-drawer{position:fixed;top:0;left:0;z-index:70;width:min(16rem,86vw);height:100%;padding:4.25rem 1rem 1rem;background:#0f172a;border-right:1px solid #1e293b;box-shadow:8px 0 24px #00000059;transform:translate(-100%);transition:transform .2s ease;pointer-events:none}.shell-drawer--open{transform:translate(0);pointer-events:auto}.shell-drawer-title{margin:0 0 .75rem;font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#64748b}.shell-drawer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.shell-drawer-link{display:block;padding:.6rem .75rem;border-radius:8px;color:#e2e8f0;text-decoration:none;font-size:.95rem}.shell-drawer-link:hover{background:#1e293b}.shell-drawer-link.active{background:#1e3a5f;color:#7dd3fc}.shell-drawer-group{display:flex;flex-direction:column;gap:.15rem}.shell-drawer-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;margin:0;padding:.6rem .75rem;border:none;border-radius:8px;background:transparent;color:#e2e8f0;font-size:.95rem;text-align:left;cursor:pointer}.shell-drawer-group-toggle:hover{background:#1e293b}.shell-drawer-group-toggle:focus-visible{outline:2px solid #38bdf8;outline-offset:2px}.shell-drawer-group-toggle--active{background:#1e293b;color:#7dd3fc}.shell-drawer-group-chevron{display:inline-block;margin-left:.35rem;font-size:.65rem;opacity:.75;transition:transform .15s ease}.shell-drawer-group-toggle[aria-expanded=true] .shell-drawer-group-chevron{transform:rotate(90deg)}.shell-drawer-group-chevron:before{content:"›"}.shell-drawer-sublist{list-style:none;margin:0;padding:0 0 .15rem .5rem;display:flex;flex-direction:column;gap:.15rem;border-left:2px solid #334155;margin-left:.65rem}.shell-drawer-sublink{display:block;padding:.45rem .65rem;border-radius:6px;color:#cbd5e1;text-decoration:none;font-size:.9rem}.shell-drawer-sublink:hover{background:#1e293b;color:#e2e8f0}.shell-drawer-sublink.active{background:#1e3a5f;color:#7dd3fc}.shell-drawer-action{display:block;width:100%;margin:.5rem 0 0;padding:.6rem .75rem;border:1px solid #334155;border-radius:8px;background:transparent;color:#fca5a5;font-size:.95rem;text-align:left;cursor:pointer}.shell-drawer-action:hover{background:#450a0a;border-color:#7f1d1d}.shell-main{flex:1}.app{max-width:720px;margin:0 auto;padding:1.25rem 1rem 3rem}.status-bar{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;padding:.65rem .85rem;border-radius:10px;background:#0f172a;border:1px solid #1e293b;margin-bottom:1.25rem}.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .55rem;border-radius:999px;font-size:.8rem;border:1px solid transparent}.pill-online{background:#022c22;border-color:#14532d;color:#86efac}.pill-offline{background:#422006;border-color:#7c2d12;color:#fdba74}.pill-sync-pending{background:#422006;border-color:#a16207;color:#fde68a}.pill-sync-synced{background:#022c22;border-color:#166534;color:#bbf7d0}.pill-sync-error{background:#450a0a;border-color:#991b1b;color:#fecaca}.messages{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1.25rem;font-size:.9rem;color:#94a3b8}.card{background:#0f172a;border:1px solid #1e293b;border-radius:12px;padding:1rem 1.1rem;margin-bottom:1rem}.card h2{margin:0 0 .75rem;font-size:1.05rem;font-weight:600;color:#f8fafc}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.field label{font-size:.8rem;color:#94a3b8}.field input,.field textarea{border-radius:8px;border:1px solid #334155;background:#020617;color:#f1f5f9;padding:.5rem .65rem}.field textarea{min-height:96px;resize:vertical}.row-actions{display:flex;flex-wrap:wrap;gap:.5rem}.btn{border-radius:8px;border:1px solid #334155;background:#1e293b;color:#e2e8f0;padding:.45rem .85rem;cursor:pointer}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:#0369a1;border-color:#0ea5e9}.btn-ghost{background:transparent}.list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.list-item{display:flex;justify-content:space-between;gap:.75rem;align-items:flex-start;padding:.65rem .75rem;border-radius:8px;border:1px solid #1e293b;background:#020617}.list-item small{color:#64748b;display:block;margin-top:.25rem}.muted{color:#64748b;font-size:.85rem}.error-text{color:#fecaca;font-size:.85rem}.informes-campo-page{padding:1rem 1rem 2rem;max-width:36rem}.informes-campo-page__title{margin:0 0 .5rem;font-size:1.35rem;font-weight:600;color:#f1f5f9}.informes-campo-page__muted{margin:0 0 1rem;font-size:.95rem;color:#94a3b8}.informes-campo-page__list{margin:0;padding-left:1.15rem;color:#cbd5e1}.informes-campo-page__link{color:#7dd3fc;text-decoration:none}.informes-campo-page__link:hover{text-decoration:underline}.informes-campo-page__link--current{color:#e2e8f0;font-weight:600;pointer-events:none;text-decoration:none}.informes-campo-page__back{display:inline-block;margin-top:.5rem;color:#7dd3fc;text-decoration:none;font-size:.95rem}.informes-campo-page__back:hover{text-decoration:underline}.data-grid{border:1px solid #1e293b;border-radius:12px;background:#020617;overflow:hidden}.data-grid-scroll{overflow-x:auto}.data-grid-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-grid-table th,.data-grid-table td{padding:.55rem .75rem;text-align:left;border-bottom:1px solid #1e293b;vertical-align:top}.data-grid-table th{background:#0f172a;color:#94a3b8;font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}.data-grid-table tbody tr:hover{background:#0f172aa6}.data-grid-muted{color:#64748b;text-align:center;padding:1.25rem!important}.data-grid-footer{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;justify-content:space-between;padding:.65rem .75rem;background:#0f172a;border-top:1px solid #1e293b;font-size:.85rem;color:#94a3b8}.data-grid-controls{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.data-grid-page-size{display:inline-flex;align-items:center;gap:.4rem}.data-grid-page-size-label{color:#64748b}.data-grid-page-size select{border-radius:8px;border:1px solid #334155;background:#020617;color:#e2e8f0;padding:.25rem .4rem}.data-grid-pager{display:inline-flex;align-items:center;gap:.5rem}.data-grid-pager-btn{border-radius:8px;border:1px solid #334155;background:#1e293b;color:#e2e8f0;padding:.35rem .65rem;cursor:pointer;font-size:.85rem}.data-grid-pager-btn:disabled{opacity:.45;cursor:not-allowed}.data-grid-pager-status{color:#cbd5e1;min-width:7.5rem;text-align:center}.data-grid-actions{display:inline-flex;flex-wrap:wrap;gap:.35rem}.data-grid-actions button{border-radius:8px;border:1px solid #334155;background:transparent;color:#7dd3fc;padding:.25rem .5rem;font-size:.8rem;cursor:pointer}.data-grid-actions button:hover{background:#1e293b}.data-grid-actions .danger{color:#fca5a5;border-color:#7f1d1d}.data-grid-actions .danger:hover{background:#450a0a}.client-dialog-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;display:flex;align-items:flex-start;justify-content:center;padding:10vh 1rem 2rem}.client-dialog-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;margin:0;border:none;background:#020617a6;cursor:pointer}.client-dialog-panel{position:relative;z-index:1;width:min(28rem,100%);padding:1.1rem 1.15rem 1.15rem;border-radius:12px;border:1px solid #1e293b;background:#0f172a;box-shadow:0 18px 50px #00000073}.client-dialog-title{margin:0 0 1rem;font-size:1.05rem;font-weight:600;color:#f8fafc}.client-dialog-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}.client-dialog-field label{font-size:.8rem;color:#94a3b8}.client-dialog-field input{border-radius:8px;border:1px solid #334155;background:#020617;color:#f1f5f9;padding:.5rem .65rem;font:inherit}.client-dialog-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.client-dialog-actions .btn{border-radius:8px;border:1px solid #334155;padding:.45rem .85rem;font:inherit;cursor:pointer}.client-dialog-actions .btn-ghost{background:transparent;color:#e2e8f0}.client-dialog-actions .btn-primary{background:#0369a1;border-color:#0ea5e9;color:#f0f9ff}.clients-section.card{margin-top:1.25rem}.clients-section-header{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-start;justify-content:space-between;margin-bottom:1rem}.clients-section-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600;color:#f8fafc}.clients-section-hint{margin:0;font-size:.85rem;max-width:40rem}.clients-error{color:#fecaca;font-size:.9rem;margin:0 0 .75rem}.clients-badge{font-size:.78rem;font-weight:500}.clients-badge--pending{color:#fde68a}.clients-badge--danger{color:#fca5a5}.clients-col-address{min-width:8rem}.clients-col-actions{white-space:nowrap}.clients-section .btn{border-radius:8px;border:1px solid #334155;background:#1e293b;color:#e2e8f0;padding:.45rem .85rem;cursor:pointer;font:inherit}.clients-section .btn-primary{background:#0369a1;border-color:#0ea5e9}.page{max-width:720px;margin:0 auto;padding:1rem 1rem 3rem}.page-title{margin:0 0 .5rem;font-size:1.35rem;font-weight:600;color:#f8fafc}.page-lead{margin:0;font-size:.95rem;line-height:1.5}.page .muted{color:#94a3b8}
