:root{--bg-page: radial-gradient(circle at 0 0, #2168ad38, transparent 34%), radial-gradient(circle at 100% 0, #35b8de38, transparent 28%), radial-gradient(circle at 100% 100%, #bfdbfe85, transparent 34%), linear-gradient(180deg, #f5fbff, #e8f3fb 44%, #dceffd);--bg-card: rgba(255, 255, 255, .9);--bg-sidebar: linear-gradient(180deg, #103560, #184d86 54%, #2168ad);--bg-sidebar-hover: rgba(255, 255, 255, .1);--bg-sidebar-active: rgba(255, 255, 255, .16);--text-primary: #163557;--text-secondary: #23476f;--text-muted: #5b7aa4;--text-on-dark: #e8edf5;--text-on-dark-muted: rgba(219, 234, 254, .75);--border-color: rgba(93, 132, 187, .38);--accent: #2168ad;--accent-light: #dceffd;--accent-dark: #184d86;--danger: #dc2626;--danger-light: #fef2f2;--warning: #d97706;--warning-light: #fffbeb;--info: #2563eb;--info-light: #eff6ff;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow-card: 0 18px 40px -34px rgba(16, 53, 96, .38)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-page);color:var(--text-primary);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:14px}a{color:var(--accent);text-decoration:none}.mono{font-family:JetBrains Mono,monospace}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--bg-sidebar);box-shadow:18px 0 45px -35px #103560d9;color:var(--text-on-dark);display:flex;flex-direction:column;padding:20px 14px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:0 8px 24px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:20px}.sidebar-brand-icon{width:34px;height:34px;border-radius:8px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;color:#fff;flex-shrink:0}.brand-logo{width:46px;height:46px;border-radius:8px;object-fit:contain;background:#fff;border:1px solid rgba(17,32,58,.12);flex-shrink:0}.brand-logo-sidebar{width:38px;height:38px}.sidebar-brand-text{font-size:14px;font-weight:600;color:#fff;line-height:1.3}.sidebar-brand-sub{font-size:11px;color:var(--text-on-dark-muted)}.sidebar-nav{display:flex;flex-direction:column;gap:2px;flex:1}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;color:var(--text-on-dark-muted);font-size:13.5px;font-weight:500;cursor:pointer;border:none;background:transparent;width:100%;text-align:left}.sidebar-link:hover{background:var(--bg-sidebar-hover);color:#fff;transform:translateY(-1px)}.sidebar-link.active{background:var(--bg-sidebar-active);border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px #ffffff29;color:#fff}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding-top:14px;margin-top:10px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:6px 8px 12px}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-light);color:var(--accent-dark);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12.5px;flex-shrink:0}.sidebar-user-name{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--text-on-dark-muted)}.main-content{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:16px 28px;display:flex;align-items:center;justify-content:space-between}.topbar-title{font-size:18px;font-weight:600}.topbar-subtitle{font-size:12.5px;color:var(--text-secondary);margin-top:2px}.page-body{padding:24px 28px;flex:1}.monitor-kpi-grid{margin-bottom:18px}.stat-card-ok .stat-value,.status-ok{color:#15803d}.stat-card-warning .stat-value,.status-warning{color:#b45309}.stat-card-danger .stat-value,.status-danger{color:#b91c1c}.stat-card-info .stat-value{color:var(--accent)}.monitor-filters{display:grid;grid-template-columns:repeat(2,minmax(260px,1fr));align-items:center;gap:10px 14px;margin-bottom:12px;padding:14px}.monitor-search{min-width:0}.monitor-filters .field-input,.monitor-filters .field-select{width:100%;min-height:42px;padding:8px 12px}.monitor-filter-actions{align-items:center;display:flex;gap:10px;min-height:42px;flex-wrap:wrap}.monitor-filter-actions .btn{min-height:42px;padding:8px 15px}.check-line{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-weight:600;white-space:nowrap}@media (max-width: 900px){.monitor-filters{grid-template-columns:1fr}}.table-meta{color:var(--text-muted);font-size:12px;font-weight:600;margin:10px 0}.status-pill{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:3px 9px;background:#2168ad14;border:1px solid rgba(33,104,173,.16);font-size:12px;font-weight:800;white-space:nowrap}.row-warning{background:#d9770614}.monitor-payments-card{display:block;overflow-x:scroll!important;overflow-y:hidden!important;max-width:100%;scrollbar-gutter:stable;padding-bottom:6px;border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg);scrollbar-width:auto;scrollbar-color:#2168ad rgba(33,104,173,.14)}.monitor-payments-card::-webkit-scrollbar{height:14px}.monitor-payments-card::-webkit-scrollbar-track{background:#2168ad24;border-radius:999px}.monitor-payments-card::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#2168ad,#35b8de);border-radius:999px;border:3px solid rgba(255,255,255,.82)}.monitor-payments-table{width:1675px;min-width:1675px;table-layout:fixed}.monitor-payments-table th,.monitor-payments-table td{overflow:hidden}.monitor-payments-table td{line-height:1.55}.monitor-payments-table .pay-col-date{width:140px}.monitor-payments-table .pay-col-client{width:168px}.monitor-payments-table .pay-col-type{width:150px}.monitor-payments-table .pay-col-product{width:190px}.monitor-payments-table .pay-col-amount{width:130px}.monitor-payments-table .pay-col-provider{width:205px}.monitor-payments-table .pay-col-status{width:132px}.monitor-payments-table .pay-col-follow{width:140px}.monitor-payments-table .pay-col-ref,.monitor-payments-table .pay-col-provider-ref{width:210px}.location-card{overflow-x:auto}.location-table{min-width:1040px;table-layout:fixed}.location-table th,.location-table td{overflow:hidden}.location-table .loc-col-child{width:130px}.location-table .loc-col-parent{width:150px}.location-table .loc-col-country{width:130px}.location-table .loc-col-address{width:205px}.location-table .loc-col-coordinate{width:128px}.location-table .loc-col-battery{width:118px}.location-table .loc-col-date{width:170px}.location-table .loc-col-action{width:86px}.location-map-button{width:64px;justify-content:center}.truncate-cell{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mono-cell{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pagination-row{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:14px}.modal-wide{width:min(680px,calc(100vw - 32px))}.detail-grid{display:grid;gap:8px}.detail-row{display:grid;grid-template-columns:170px 1fr;gap:14px;padding:9px 0;border-top:1px solid var(--border-color);word-break:break-word}.detail-row span{color:var(--text-muted);font-size:12px;font-weight:700}.progress-line{margin:0 0 16px}.progress-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:7px;color:var(--text-secondary);font-weight:800}.progress-track{height:12px;background:#2168ad1a;border-radius:999px;overflow:hidden;border:1px solid rgba(33,104,173,.14)}.progress-fill{height:100%;border-radius:999px;background:var(--accent)}.progress-ok{background:#16a34a}.progress-warning{background:#d97706}.progress-info{background:#35b8de}.card{backdrop-filter:blur(16px);background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.card-padded{padding:20px 22px}.btn{display:inline-flex;align-items:center;gap:6px;border-radius:12px;border:1px solid var(--border-color);background:#ffffffe6;padding:9px 16px;font-size:13.5px;font-weight:500;color:var(--text-primary);transition:background .15s,border-color .15s,box-shadow .15s,transform .15s}.btn:hover{background:#fffffff7;border-color:#7a91b0a6;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#184d86,#2168ad 56%,#35b8de);border-color:transparent;box-shadow:0 16px 34px -20px #184d86b3;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#103560,#2168ad 56%,#35b8de);border-color:transparent;box-shadow:0 26px 70px -42px #10356099}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:#791f1f;border-color:#791f1f}.btn-danger-soft{background:#b3261e14;border-color:#b3261e38;color:var(--danger)}.btn-danger-soft:hover{background:#b3261e24;border-color:#b3261e61}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover{background:#f0f1f3}.btn-sm{padding:6px 11px;font-size:12.5px}.field-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.field-label{font-size:12.5px;font-weight:500;color:var(--text-secondary)}.field-input,.field-select,.field-textarea{border:2px solid rgba(93,132,187,.34);border-radius:12px;padding:10px 13px;font-size:13.5px;color:var(--text-primary);background:#fffffff0;box-shadow:inset 0 1px #ffffffb8,0 10px 24px -24px #103560a6;width:100%;outline:none}.field-input:focus,.field-select:focus,.field-textarea:focus{border-color:#35b8de;box-shadow:0 0 0 3px #06b6d42e}.field-error{font-size:12px;color:var(--danger)}.alert{border-radius:var(--radius-md);padding:11px 14px;font-size:13px;display:flex;align-items:flex-start;gap:8px}.alert-danger{background:var(--danger-light);color:var(--danger)}.alert-info{background:var(--info-light);color:var(--info)}.alert-warning{background:var(--warning-light);color:var(--warning)}.badge{display:inline-flex;align-items:center;gap:4px;border-radius:100px;padding:3px 10px;font-size:11.5px;font-weight:600}.badge-success{background:var(--accent-light);color:var(--accent-dark)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-neutral{background:#eef0f3;color:var(--text-secondary)}table.data-table{width:100%;border-collapse:collapse;font-size:13px}table.data-table th{text-align:left;font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);padding:10px 14px;border-bottom:1px solid var(--border-color);background:#fafbfc;white-space:nowrap}table.data-table td{padding:11px 14px;border-bottom:1px solid var(--border-color);vertical-align:middle}table.data-table tbody tr:hover{background:#fafbfc}table.data-table tbody tr:last-child td{border-bottom:none}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}.stat-card{backdrop-filter:blur(16px);background:var(--bg-card);border:2px solid rgba(215,229,245,.9);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:16px 18px;position:relative;overflow:hidden}.stat-card:before{background:linear-gradient(90deg,#184d86,#2e89ca 58%,#38bdf8);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-label{font-size:12px;color:var(--text-secondary);font-weight:500;margin-bottom:6px}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.stat-sub{font-size:12px;color:var(--text-muted);margin-top:4px}.dashboard-page{display:grid;gap:18px}.dashboard-header{margin-bottom:0}.dashboard-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}@media (max-width: 900px){.dashboard-kpi-grid{grid-template-columns:1fr}}.dashboard-grid{display:grid;gap:18px}.dashboard-grid-main{grid-template-columns:minmax(0,1.35fr) minmax(320px,.9fr)}.dashboard-grid-three{grid-template-columns:repeat(3,minmax(0,1fr))}.trend-bars,.category-list,.alert-list,.region-list,.activity-list,.goal-list{display:grid;gap:12px}.trend-row{display:grid;grid-template-columns:120px minmax(0,1fr) 120px;gap:12px;align-items:center}.trend-label,.trend-value{font-size:12.5px;color:var(--text-secondary)}.trend-value{text-align:right;font-weight:700;color:var(--text-primary)}.trend-track,.category-bar,.goal-track{height:10px;border-radius:999px;background:#dceffdd9;overflow:hidden}.trend-track span,.category-bar span,.goal-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#184d86,#35b8de)}.category-row{display:grid;grid-template-columns:minmax(0,1fr) 48px;gap:8px;align-items:center}.category-row strong,.region-head strong,.goal-row strong{display:block;color:var(--text-primary)}.category-row span,.activity-row small,.goal-row span{display:block;color:var(--text-muted);font-size:12px}.category-percent{text-align:right;font-weight:700;color:var(--accent-dark)}.category-bar{grid-column:1 / -1}.mini-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.mini-stat-grid>div{border:1px solid rgba(93,132,187,.28);border-radius:12px;padding:12px;background:#ffffff8f}.mini-stat-grid span{display:block;color:var(--text-muted);font-size:12px;margin-bottom:4px}.mini-stat-grid strong{font-size:20px;color:var(--text-primary)}.mini-alert{border-radius:12px;padding:10px 12px;font-size:13px;border:1px solid rgba(93,132,187,.28);background:#eff6ffe6;color:var(--text-primary)}.mini-alert-danger{background:var(--danger-light);color:var(--danger);border-color:#dc262638}.mini-alert-warning{background:var(--warning-light);color:var(--warning);border-color:#d977063d}.region-row{border-bottom:1px solid rgba(93,132,187,.2);padding-bottom:10px}.region-row:last-child{border-bottom:none}.region-head,.region-child,.goal-row>div:first-child{display:flex;justify-content:space-between;gap:12px}.region-head span{font-weight:700;color:var(--accent-dark)}.region-child{padding:5px 0 0 14px;color:var(--text-secondary);font-size:12.5px}.activity-row{display:grid;grid-template-columns:52px 1fr;gap:12px;align-items:start}.activity-row>span{color:var(--accent-dark);font-weight:700;font-size:12px}.activity-row strong{display:block;color:var(--text-primary)}.goal-row{display:grid;gap:7px}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.toolbar-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.search-input{width:min(320px,70vw)}.muted-text{color:var(--text-secondary);font-size:13px}.inline-form{display:grid;grid-template-columns:minmax(180px,240px) minmax(220px,1fr) auto;gap:10px;align-items:center}.inline-field{display:grid;grid-template-columns:1fr auto;gap:8px}.scanner-layer{z-index:150}.scanner-video{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius-md);background:#0b1320}.modal-overlay{position:fixed;inset:0;background:#0f141e80;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal-box{backdrop-filter:blur(20px);background:linear-gradient(180deg,#fffffff5,#ffffffe6);border:2px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 30px 80px -42px #10356073;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;padding:24px}.modal-wide{max-width:680px}.field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.stats-layout{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(260px,.8fr);gap:18px}.modal-title{font-size:16px;font-weight:600;margin-bottom:4px}.modal-subtitle{font-size:12.5px;color:var(--text-secondary);margin-bottom:18px}.empty-state{text-align:center;padding:50px 20px;color:var(--text-muted)}.empty-state-icon{font-size:32px;margin-bottom:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-page);padding:20px}.login-card{backdrop-filter:blur(18px);background:linear-gradient(180deg,#fffffff5,#ffffffe6);border:2px solid var(--border-color);border-radius:24px;box-shadow:0 30px 80px -42px #10356073;padding:36px 32px;width:100%;max-width:380px}.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:28px}@media (max-width: 760px){.field-grid,.stats-layout,.dashboard-grid-main,.dashboard-grid-three,.inline-form{grid-template-columns:1fr}.trend-row{grid-template-columns:1fr;gap:6px}.trend-value{text-align:left}.mini-stat-grid{grid-template-columns:1fr}.sidebar{width:210px}}.tag-pill{display:inline-flex;align-items:center;font-size:12px;font-weight:500;padding:3px 10px;border-radius:100px;background:#eef0f3;color:var(--text-secondary)}
