:root{--bg-primary: #1a1a2e;--bg-secondary: #16213e;--bg-card: #0f3460;--bg-input: #1e2a4a;--text-primary: #e4e4e4;--text-secondary: #a0a0a0;--text-muted: #6a6a8a;--accent: #e94560;--border: #2a2a4e;--score-critical: #e94560;--score-degraded: #f0a500;--score-healthy: #4ecca3;--nav-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow-x:hidden}.app-layout{display:flex;flex-direction:column;height:100%}.app-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav-height) + var(--safe-bottom))}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:100}.nav-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 16px;min-width:64px;min-height:44px;background:none;border:none;color:var(--text-secondary);font-size:11px;cursor:pointer;text-decoration:none;-webkit-tap-highlight-color:transparent}.nav-tab.active{color:var(--accent)}.nav-tab svg{width:22px;height:22px}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px}.login-card{width:100%;max-width:360px;text-align:center}.login-card h1{font-size:24px;font-weight:600;margin-bottom:8px}.login-card p{color:var(--text-secondary);margin-bottom:32px;font-size:14px}.login-card input[type=email]{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:16px;outline:none;margin-bottom:12px}.login-card input[type=email]:focus{border-color:var(--accent)}.login-card input[type=email]::placeholder{color:var(--text-muted)}.btn-primary{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;min-height:44px}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.sent-state{padding:24px 0}.sent-state h2{font-size:20px;margin-bottom:8px}.sent-state p{margin-bottom:16px}.link-button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;text-decoration:underline}.page-header{padding:16px;display:flex;align-items:center;gap:12px}.page-header h1{font-size:20px;font-weight:600}.back-button{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;margin:-8px}.fleet-page{padding:0 12px}.geo-group{margin-bottom:20px}.geo-group-header{padding:8px 4px;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:8px}.geo-group-avg{font-size:12px;font-weight:400;color:var(--text-muted)}.heatmap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px}.heatmap-cell{aspect-ratio:1;min-height:44px;min-width:44px;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;padding:4px;text-decoration:none;-webkit-tap-highlight-color:transparent;transition:filter .3s ease}.heatmap-cell-hostname{font-size:9px;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.heatmap-cell-score{font-size:16px;font-weight:700;color:#fff}.host-page{padding:0 16px 24px}.host-meta{background:var(--bg-card);border-radius:10px;padding:16px;margin-bottom:16px}.host-meta h2{font-size:18px;margin-bottom:4px}.host-meta-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px;color:var(--text-secondary)}.host-meta-row span:last-child{color:var(--text-primary)}.score-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}.score-card{background:var(--bg-card);border-radius:10px;padding:16px;text-align:center}.score-card-label{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);margin-bottom:4px}.score-card-value{font-size:28px;font-weight:700}.chart-section{background:var(--bg-card);border-radius:10px;padding:16px;margin-bottom:16px}.chart-section h3{font-size:14px;margin-bottom:12px}.metric-selector{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.metric-btn{padding:6px 12px;border-radius:16px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;min-height:32px}.metric-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.regions-page{padding:0 16px}.region-card{background:var(--bg-card);border-radius:10px;padding:16px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.region-info h3{font-size:16px;margin-bottom:2px}.region-info p{font-size:12px;color:var(--text-secondary)}.region-stats{text-align:right}.region-score{font-size:24px;font-weight:700}.region-critical{font-size:11px;color:var(--score-critical)}.settings-page{padding:0 16px}.settings-section{margin-bottom:24px}.settings-section h3{font-size:13px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:12px}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-card);border-radius:10px;margin-bottom:6px;min-height:44px}.setting-row label{font-size:15px}.toggle{position:relative;width:48px;height:28px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:14px;border:none;cursor:pointer;transition:background .2s}.toggle:checked{background:var(--accent)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .2s}.toggle:checked:after{transform:translate(20px)}.session-info{padding:16px;background:var(--bg-card);border-radius:10px}.session-info p{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.session-info .email{color:var(--text-primary);font-weight:500}.btn-danger{width:100%;padding:12px;background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:8px;font-size:16px;cursor:pointer;min-height:44px;margin-top:12px}.loading-page{display:flex;align-items:center;justify-content:center;min-height:100vh;color:var(--text-secondary)}.loading-spinner{text-align:center;padding:48px;color:var(--text-secondary)}.error-banner{padding:8px 16px;background:#e9456026;color:var(--score-critical);font-size:13px;text-align:center}@media(min-width:600px){.heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.score-cards{grid-template-columns:repeat(4,1fr)}}@media(min-width:960px){.heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}}.admin-page{padding:0 16px}.admin-tabs{display:flex;gap:4px;margin-bottom:20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-tab{padding:8px 16px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;white-space:nowrap;min-height:36px}.admin-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.admin-section h3{font-size:15px;font-weight:600;margin-bottom:12px}.admin-hint{font-size:13px;color:var(--text-secondary);margin-bottom:12px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.section-header h3{margin-bottom:0}.ttl-presets{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.ttl-btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:14px;cursor:pointer;min-height:36px}.ttl-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.ttl-btn:disabled{opacity:.5}.custom-ttl{display:flex;gap:8px;margin-bottom:8px}.custom-ttl .form-input{flex:1}.success-msg{color:var(--score-healthy);font-size:13px;margin-top:4px}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;padding:8px;color:var(--text-secondary);font-weight:600;font-size:11px;text-transform:uppercase;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:10px 8px;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.rule-badge{display:inline-block;padding:2px 6px;border-radius:4px;background:var(--bg-secondary);font-size:10px;text-transform:uppercase;margin-right:6px;color:var(--text-muted)}.admin-form{background:var(--bg-card);border-radius:10px;padding:16px;margin-bottom:16px}.form-group{margin-bottom:12px}.form-group>label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:4px}.form-input{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:14px;outline:none}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}.form-radio-group{display:flex;gap:16px;padding:4px 0}.form-radio-group label{display:flex;align-items:center;gap:4px;font-size:14px;color:var(--text-primary);cursor:pointer}.form-actions{display:flex;gap:8px;margin-top:16px}.form-actions .btn-primary{flex:1}.btn-small{padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;min-height:32px;white-space:nowrap}.btn-small-danger{border-color:var(--accent);color:var(--accent)}.token-display{margin-top:16px;padding:16px;background:#4ecca31a;border:1px solid var(--score-healthy);border-radius:10px}.token-warning{font-size:12px;color:var(--score-degraded);margin-bottom:8px;font-weight:500}.token-row{display:flex;gap:8px;align-items:center}.token-value{flex:1;padding:8px;background:var(--bg-primary);border-radius:4px;font-size:12px;word-break:break-all;color:var(--score-healthy)}
