.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-primary);padding:1rem}.login-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--color-text);font-size:1.75rem;font-weight:700;margin:0 0 .5rem;letter-spacing:-.02em}.login-header p{color:var(--color-text-tertiary);font-size:.875rem;margin:0}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:.75rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.875rem}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;background:var(--color-surface);color:var(--color-text-secondary);padding:.75rem 1.5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all .15s;box-shadow:var(--shadow-sm)}.btn-google:hover:not(:disabled){background-color:var(--color-surface-raised);border-color:var(--color-text-muted);box-shadow:var(--shadow-md)}.btn-google:active:not(:disabled){background-color:var(--color-surface-sunken)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.google-icon{flex-shrink:0}.login-info{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border);text-align:center}.login-info p{color:var(--color-text-tertiary);font-size:.75rem;margin:.25rem 0}.info-note{color:var(--color-text-muted);font-size:.6875rem}.navigation{display:flex;gap:.25rem;margin-bottom:2rem;border-bottom:1px solid var(--color-border);padding-bottom:0}.nav-link{padding:.75rem 1.25rem;color:var(--color-text-tertiary);text-decoration:none;font-weight:500;font-size:.875rem;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;position:relative;top:1px}.nav-link:hover{color:var(--color-primary)}.nav-link.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.layout{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg)}.header{background:var(--color-primary);color:#fff;box-shadow:0 1px 3px #0000001f}.header-content{max-width:1200px;margin:0 auto;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.header-title{font-size:1.375rem;font-weight:700;margin:0;letter-spacing:-.01em}.header-actions{display:flex;align-items:center;gap:1rem}.user-email{font-size:.8125rem;opacity:.85}.btn-logout{background-color:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background-color .2s}.btn-logout:hover{background-color:#ffffff40}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem 1.5rem}.footer{background-color:var(--color-text);color:var(--color-text-muted);text-align:center;padding:1.25rem;margin-top:auto}.footer p{margin:0;font-size:.8125rem}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.main-content{padding:1rem}}.dashboard{width:100%}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.dashboard-header h2{margin:0;font-size:1.75rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.user-role{display:flex;gap:.5rem}.role-badge{background-color:var(--color-primary);color:#fff;padding:.25rem .75rem;border-radius:var(--radius-pill);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.loading-container,.error-container{display:flex;align-items:center;justify-content:center;min-height:400px}.error-card{background:var(--color-surface);padding:2rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center}.error-card h2{color:var(--color-danger);margin-top:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--color-primary);padding:1.5rem;border-radius:var(--radius-md);box-shadow:0 2px 8px var(--color-primary-shadow);color:#fff}.stat-label{font-size:.8125rem;opacity:.85;margin-bottom:.5rem;font-weight:500}.stat-value{font-size:2rem;font-weight:700;line-height:1;letter-spacing:-.02em}.dashboard-section{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text)}.btn-add{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s}.btn-add:hover{background:var(--color-primary-hover)}.add-form{background-color:var(--color-surface-raised);padding:1.5rem;border-radius:var(--radius-sm);margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.form-field{display:flex;flex-direction:column}.form-field label{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.5rem}.form-field input,.form-field select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);color:var(--color-text);transition:border-color .15s,box-shadow .15s}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.btn-submit{background:var(--color-primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s}.btn-submit:hover{background:var(--color-primary-hover)}.nodes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.empty-state{text-align:center;padding:3rem;color:var(--color-text-tertiary)}.node-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1.25rem;transition:box-shadow .15s}.node-card:hover{box-shadow:var(--shadow-md)}.node-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border-light)}.node-header h4{margin:0;font-size:1.0625rem;font-weight:600;color:var(--color-text)}.status-badge{padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-pending{background-color:#fef3c7;color:#92400e}.status-active{background-color:#d1fae5;color:#065f46}.status-error{background-color:#fef2f2;color:#991b1b}.node-details p{margin:.5rem 0;font-size:.875rem;color:var(--color-text-tertiary)}.node-date{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border-light);font-size:.75rem;color:var(--color-text-muted)}@media (max-width: 768px){.dashboard-header{flex-direction:column;align-items:flex-start;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row,.nodes-grid{grid-template-columns:1fr}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}}.all-nodes{width:100%}.filters-section{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.filters-grid{display:grid;grid-template-columns:repeat(4,1fr) auto;gap:1rem;align-items:end}.filter-field{display:flex;flex-direction:column}.filter-field label{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.375rem}.filter-field input,.filter-field select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);color:var(--color-text);transition:border-color .15s,box-shadow .15s}.filter-field input:focus,.filter-field select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.btn-clear{background:var(--color-surface-sunken);color:var(--color-text-secondary);border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background-color .15s}.btn-clear:hover{background:var(--color-border)}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#991b1b;padding:1rem;border-radius:var(--radius-sm);margin-bottom:1.5rem}.loading-container{background:var(--color-surface);padding:3rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center;color:var(--color-text-tertiary)}.table-container{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow-x:auto}.nodes-table{width:100%;border-collapse:collapse}.nodes-table thead{background-color:var(--color-surface-raised)}.nodes-table th{padding:.875rem 1rem;text-align:left;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap}.nodes-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .1s}.nodes-table tbody tr:hover{background-color:var(--color-surface-raised)}.nodes-table td{padding:.75rem 1rem;font-size:.8125rem;color:var(--color-text-tertiary)}.ip-cell{display:flex;flex-direction:column;gap:.25rem}.ip-main{font-weight:500;color:var(--color-text-secondary)}.ip-network{font-size:.6875rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.address-cell{max-width:150px}.address-text{font-family:var(--font-mono);font-size:.75rem}.amount-cell{font-weight:600;color:var(--color-text-secondary)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-tertiary)}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1.25rem;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-top:1.5rem}.btn-page{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s}.btn-page:hover:not(:disabled){background:var(--color-primary-hover)}.btn-page:disabled{opacity:.4;cursor:not-allowed;background:var(--color-text-muted)}.page-info{font-size:.8125rem;color:var(--color-text-tertiary);font-weight:500}@media (max-width: 768px){.table-container{overflow-x:scroll}.nodes-table{min-width:800px}.filters-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:.5rem}}.our-nodes{width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h2{margin:0;font-size:1.75rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.page-meta{display:flex;align-items:center;gap:1rem}.total-count{font-size:.8125rem;color:var(--color-text-tertiary);font-weight:500}.btn-debug-refresh{background:var(--color-warning);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s}.btn-debug-refresh:hover:not(:disabled){background:#d97706}.btn-debug-refresh:disabled{opacity:.5;cursor:not-allowed}.summary-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.summary-card{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border-left:4px solid var(--color-primary)}.summary-card.active{border-left-color:var(--color-success)}.summary-card.inactive{border-left-color:var(--color-warning)}.summary-card.utilization{border-left-color:var(--color-primary)}.summary-label{font-size:.8125rem;color:var(--color-text-tertiary);font-weight:500;margin-bottom:.5rem}.summary-value{font-size:2rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.tier-breakdown{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:2rem}.tier-breakdown h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--color-text)}.tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.tier-card{background:var(--color-surface-raised);padding:1rem;border-radius:var(--radius-sm)}.tier-header{margin-bottom:.75rem}.tier-badge{display:inline-block;padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.tier-cumulus{background-color:var(--tier-cumulus-bg);color:var(--tier-cumulus-text)}.tier-nimbus{background-color:var(--tier-nimbus-bg);color:var(--tier-nimbus-text)}.tier-stratus{background-color:var(--tier-stratus-bg);color:var(--tier-stratus-text)}.tier-stats{display:flex;flex-direction:column;gap:.5rem}.tier-stat{display:flex;justify-content:space-between;font-size:.875rem}.tier-stat .stat-label{color:var(--color-text-tertiary)}.tier-stat .stat-value{font-weight:600;color:var(--color-text)}.tier-stat .stat-value.active{color:var(--color-success)}.tier-stat .stat-value.inactive{color:var(--color-warning)}.groups-section{margin-bottom:2rem}.groups-section>h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600;color:var(--color-text)}.group-card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1rem;overflow:hidden}.group-header{padding:1.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background-color .15s}.group-header:hover{background-color:var(--color-surface-raised)}.group-name-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.group-info h4{margin:0;font-size:1.0625rem;font-weight:600;color:var(--color-text)}.titanstart-authorized-pill{display:inline-flex;align-items:center;padding:.25rem .625rem;background:var(--color-success);color:#fff;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-pill);white-space:nowrap;cursor:help}.starting-available-pill{display:inline-flex;align-items:center;padding:.25rem .625rem;background:var(--color-primary);color:#fff;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;border-radius:var(--radius-pill);white-space:nowrap;cursor:help}.group-address{font-family:var(--font-mono);font-size:.8125rem;color:var(--color-text-tertiary)}.group-summary{display:flex;gap:2rem;align-items:center}.group-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.group-stat .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.group-stat.active .stat-value{color:var(--color-success)}.group-stat.inactive .stat-value{color:var(--color-warning)}.group-stat .stat-label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase}.expand-btn{background:none;border:none;font-size:1.25rem;color:var(--color-primary);cursor:pointer;padding:.5rem;margin-left:1rem}.group-details{padding:0 1.5rem 1.5rem;border-top:1px solid var(--color-border)}.group-tier-breakdown{margin-bottom:1.5rem}.group-tier-breakdown h5{margin:1rem 0 .75rem;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.group-tier-stats{display:flex;flex-direction:column;gap:.75rem}.group-tier-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:var(--color-surface-raised);border-radius:var(--radius-sm)}.group-tier-item .tier-count{flex:1;font-size:.875rem;color:var(--color-text-secondary)}.group-tier-item .tier-utilization{font-weight:600;font-size:.875rem}.nodes-section{margin-bottom:1.5rem}.nodes-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:1rem}.section-title-wrapper{display:flex;align-items:center;gap:.5rem}.nodes-section h5{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.collapse-btn{background:none;border:none;font-size:1rem;color:var(--color-primary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:transform .2s,color .15s}.collapse-btn:hover{color:var(--color-primary-hover);transform:scale(1.1)}.search-filter{display:flex;align-items:center;gap:.5rem;position:relative}.search-input{padding:.5rem 2rem .5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);color:var(--color-text);width:280px;transition:border-color .15s,box-shadow .15s}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.search-input::placeholder{color:var(--color-text-muted)}.clear-search{position:absolute;right:.5rem;background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1rem;padding:.25rem;display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;border-radius:50%;transition:background-color .15s,color .15s}.clear-search:hover{background-color:var(--color-border);color:var(--color-text-secondary)}.nodes-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.node-item{background:var(--color-surface-raised);padding:1rem;border-radius:var(--radius-sm);border-left:3px solid transparent}.node-item.active-node{border-left-color:var(--color-success)}.node-item.inactive-node{border-left-color:var(--color-warning)}.node-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.node-custom-name{font-weight:600;color:var(--color-text);font-size:.875rem}.status-badge{padding:.125rem .5rem;border-radius:var(--radius-pill);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge.inactive{background-color:#fef2f2;color:#991b1b}.node-details{display:flex;flex-direction:column;gap:.5rem}.node-detail{display:flex;justify-content:space-between;font-size:.8125rem}.detail-label{color:var(--color-text-tertiary);font-weight:500}.detail-value{color:var(--color-text);font-weight:600}.detail-value.txhash{font-family:var(--font-mono);font-size:.75rem}.inactive-nodes-table-container{overflow-x:auto;margin-top:.75rem}.inactive-nodes-table{width:100%;border-collapse:collapse;background:var(--color-surface)}.inactive-nodes-table thead{background-color:var(--color-surface-raised)}.inactive-nodes-table th{padding:.75rem 1rem;text-align:left;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap}.inactive-nodes-table tbody tr{border-bottom:1px solid var(--color-border-light);transition:background-color .1s}.inactive-nodes-table tbody tr:hover{background-color:var(--color-surface-raised)}.inactive-nodes-table td{padding:.75rem 1rem;font-size:.8125rem;color:var(--color-text-tertiary)}.inactive-nodes-table .amount-cell{font-weight:600;color:var(--color-text-secondary)}.inactive-nodes-table .txhash-cell{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-tertiary)}.clickable{cursor:pointer;transition:background-color .15s,color .15s;-webkit-user-select:none;user-select:none}.clickable:hover{background-color:var(--color-surface-sunken);color:var(--color-primary)}.clickable:active{background-color:var(--color-border)}@keyframes copied-pulse{0%{transform:scale(1);color:var(--color-success)}50%{transform:scale(1.05);color:#16a34a}to{transform:scale(1);color:var(--color-success)}}.clickable.copied{color:var(--color-success)!important;font-weight:600;animation:copied-pulse .4s ease-in-out;background-color:#d1fae5!important}.inactive-nodes-table .name-cell{color:var(--color-text-secondary);font-weight:500}.inactive-nodes-table .ip-cell{font-family:var(--font-mono);font-size:.875rem;color:var(--color-text-tertiary)}.inactive-nodes-table .rank-cell{font-weight:600;color:var(--color-text-secondary)}.inactive-nodes-table .location-cell{color:var(--color-text-tertiary);font-size:.875rem}.ip-mismatch{background-color:var(--tier-stratus-bg)!important;border-left:3px solid var(--color-warning)}.mismatch-icon{margin-left:.5rem;color:var(--color-warning);font-size:1rem;cursor:help}.btn-start-node{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s}.btn-start-node:hover:not(:disabled){background:var(--color-primary-hover)}.btn-start-node:disabled{opacity:.5;cursor:not-allowed}.no-start-available{font-size:.75rem;color:var(--color-text-muted);font-style:italic}.node-status-badge{display:inline-block;padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.node-status-badge.starting{background-color:var(--tier-stratus-bg);color:var(--tier-stratus-text);border:1px solid #fbbf24}.node-status-badge.dos{background-color:#fef2f2;color:#991b1b;border:1px solid #f87171}.node-status-badge.recently-started{background-color:var(--tier-cumulus-bg);color:var(--tier-cumulus-text);border:1px solid #60a5fa}.no-results{text-align:center;padding:2rem 1rem;color:var(--color-text-tertiary);font-style:italic}.sticky-notifications{position:fixed;top:80px;right:20px;z-index:1000;max-width:400px;display:flex;flex-direction:column;gap:.75rem}.notification{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:1rem 1.25rem;display:flex;align-items:center;gap:.75rem;animation:slideIn .3s ease-out;border-left:4px solid}.notification.success{border-left-color:var(--color-success)}.notification.error{border-left-color:var(--color-danger)}.notification-icon{font-size:1.5rem;flex-shrink:0}.notification.success .notification-icon{color:var(--color-success)}.notification.error .notification-icon{color:var(--color-danger)}.notification-content{flex:1}.notification-title{font-weight:600;margin-bottom:.25rem;color:var(--color-text)}.notification-message{font-size:.875rem;color:var(--color-text-tertiary)}.notification-close{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.25rem;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .15s,color .15s;flex-shrink:0}.notification-close:hover{background-color:var(--color-surface-raised);color:var(--color-text-secondary)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.success-message{background-color:#d1fae5;border:1px solid #86efac;color:#065f46;padding:1rem;border-radius:var(--radius-sm);margin-bottom:1.5rem}.empty-state{background:var(--color-surface);padding:3rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center}.empty-state p{margin:0 0 .5rem;color:var(--color-text-tertiary)}.empty-hint{font-size:.875rem;color:var(--color-text-muted)}.loading-container,.error-container{background:var(--color-surface);padding:3rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);text-align:center}.error-message{color:#991b1b;background-color:#fef2f2;border:1px solid #fecaca;padding:1rem;border-radius:var(--radius-sm)}.group-actions{display:flex;gap:.75rem;margin-bottom:1rem;padding-top:.75rem}.btn-primary{background:var(--color-primary);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--color-text-tertiary);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background-color .15s}.btn-secondary:hover{background:var(--color-text-secondary)}.btn-danger{background:var(--color-danger);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background-color .15s}.btn-danger:hover{background:#dc2626}.btn-export{background:var(--color-success);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background-color .15s}.btn-export:hover{background:#16a34a}.btn-import{background:var(--color-info);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:background-color .15s}.btn-import:hover{background:#2563eb}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:90%;max-width:500px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text)}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .15s,color .15s}.modal-close:hover{background-color:var(--color-surface-raised);color:var(--color-text-secondary)}.modal-body{padding:1.5rem;max-height:calc(90vh - 160px);overflow-y:auto}.form-group{margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-text-secondary);font-size:.875rem}.form-group input{width:100%;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);color:var(--color-text);transition:border-color .15s,box-shadow .15s}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.form-group input:disabled{background-color:var(--color-surface-raised);cursor:not-allowed;color:var(--color-text-tertiary)}.form-group small{display:block;margin-top:.375rem;font-size:.75rem;color:var(--color-text-tertiary)}.form-section-divider{margin:2rem 0 1.5rem;padding-top:1.5rem;border-top:2px solid var(--color-border)}.form-section-divider h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.form-section-description{margin:0;font-size:.875rem;color:var(--color-text-tertiary);line-height:1.5}.checkbox-label{display:flex;align-items:center;gap:.625rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:auto;height:1.125rem;cursor:pointer;margin:0}.checkbox-label span{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.email-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:.75rem;background-color:var(--color-surface-raised);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.email-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;background-color:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.email-address{font-size:.875rem;color:var(--color-text-secondary);flex:1}.btn-remove-email{background:none;border:none;color:var(--color-danger);font-size:1rem;cursor:pointer;padding:.25rem .5rem;border-radius:var(--radius-sm);transition:background-color .15s;display:flex;align-items:center;justify-content:center}.btn-remove-email:hover{background-color:#fef2f2}.email-input-group{display:flex;gap:.5rem}.email-input{flex:1;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);color:var(--color-text);transition:border-color .15s,box-shadow .15s}.email-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.btn-add-email{background:var(--color-primary);color:#fff;border:none;padding:.625rem 1.25rem;border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);font-weight:600;cursor:pointer;transition:background-color .15s;white-space:nowrap}.btn-add-email:hover:not(:disabled){background:var(--color-primary-hover)}.btn-add-email:disabled{opacity:.5;cursor:not-allowed}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid var(--color-border)}.modal-wide{max-width:700px;max-height:90vh;overflow-y:auto}.modal-description{margin:0 0 1.5rem;padding:1rem;background-color:var(--color-surface-raised);border-left:3px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.875rem;color:var(--color-text-tertiary);line-height:1.5}.existing-nodes-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--color-border)}.existing-nodes-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.existing-nodes-section .nodes-list{display:flex;flex-direction:column;gap:.75rem}.existing-nodes-section .node-item{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface-raised);padding:1rem;border-radius:var(--radius-sm);border-left:3px solid var(--color-primary);gap:1rem}.node-item-content{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem}.node-item-field{font-size:.8125rem}.node-item-field strong{color:var(--color-text-tertiary);font-weight:500;margin-right:.25rem}.node-item-actions{display:flex;gap:.5rem;flex-shrink:0}.btn-small{padding:.375rem .75rem;font-size:.75rem}.node-form-section{background-color:var(--color-surface-raised);padding:1.25rem;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.node-form-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.import-section{margin-bottom:1.5rem;padding:1.25rem;background-color:var(--color-surface-raised);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.import-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--color-text-secondary)}.file-input{display:block;width:100%;padding:.75rem;border:2px dashed var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);cursor:pointer;transition:border-color .15s,background-color .15s;font-size:.875rem;font-family:var(--font-body);color:var(--color-text)}.file-input:hover{border-color:var(--color-primary);background-color:var(--color-surface-raised)}.file-input::-webkit-file-upload-button{background:var(--color-primary);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-sm);cursor:pointer;font-weight:500;margin-right:1rem}.file-input::-webkit-file-upload-button:hover{background:var(--color-primary-hover)}.import-preview-section{margin-top:1.5rem;padding:1.25rem;background-color:#f0fdf4;border-radius:var(--radius-sm);border:1px solid #86efac}.import-preview-section h4{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#166534}.import-preview-list{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.import-preview-item{background:var(--color-surface);padding:1rem;border-radius:var(--radius-sm);border:1px solid #d1fae5}.import-preview-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.5rem}.import-preview-field{font-size:.8125rem}.import-preview-field strong{color:#065f46;font-weight:500;margin-right:.25rem}.notification-types-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-top:.5rem}.notification-types-grid .checkbox-label{padding:.875rem;background-color:var(--color-surface-raised);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:background-color .15s,border-color .15s}.notification-types-grid .checkbox-label:hover{background-color:var(--color-primary-light);border-color:var(--color-primary)}.notification-types-grid .checkbox-label input[type=checkbox]:checked+span{color:var(--color-primary)}.notification-types-grid .checkbox-label span{display:flex;flex-direction:column;gap:.25rem}@media (max-width: 768px){.summary-section,.tier-grid{grid-template-columns:1fr}.group-header{flex-direction:column;align-items:flex-start;gap:1rem}.group-summary{width:100%;justify-content:space-between;gap:1rem}.nodes-list{grid-template-columns:1fr}.nodes-section-header{flex-direction:column;align-items:flex-start}.search-input{width:100%}.modal-content{width:95%}.modal-wide{width:95%;max-width:95%}.node-item{flex-direction:column;align-items:flex-start}.node-item-content{grid-template-columns:1fr}.node-item-actions{width:100%}.node-item-actions button{flex:1}}.delegate-mode-selector{display:flex;flex-direction:column;gap:.5rem}.radio-label{display:flex;align-items:flex-start;gap:.625rem;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .15s,background-color .15s;color:var(--color-text-secondary)}.radio-label:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.radio-label input[type=radio]{margin-top:3px;accent-color:var(--color-primary)}.radio-label input[type=radio]:checked+span{color:var(--color-text);font-weight:500}.delegate-key-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem}.delegate-key-row input{flex:1;font-family:var(--font-mono);font-size:.8rem}.input-error{border-color:var(--color-danger)!important}.delegate-badge{font-size:.6875rem;font-weight:600;padding:.125rem .5rem;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.03em}.delegate-register{background:var(--color-primary-light);color:var(--color-primary);border:1px solid var(--color-primary-border)}.delegate-signing{background:#f59e0b1a;color:#b45309;border:1px solid rgba(245,158,11,.3)}.modal-narrow{max-width:500px}.monospace-input{font-family:var(--font-mono);font-size:.85rem}.history-page{width:100%}.page-subtitle{color:var(--color-text-tertiary);font-size:.875rem;margin-top:-.625rem}.filters-section{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1.5rem;display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:.375rem;min-width:180px}.filter-group label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.filter-select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);cursor:pointer;transition:border-color .15s,box-shadow .15s}.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.filter-actions{display:flex;align-items:flex-end}.btn-clear-filters{padding:.5rem 1rem;background:var(--color-surface-sunken);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.8125rem;font-family:var(--font-body);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s,border-color .15s}.btn-clear-filters:hover{background:var(--color-border);border-color:var(--color-text-muted)}.event-summary-section{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.event-summary-section h3{margin-top:0;margin-bottom:1rem;font-size:1.125rem;font-weight:600;color:var(--color-text)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.summary-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-surface-raised);border-radius:var(--radius-sm);border-left:4px solid var(--color-primary)}.summary-icon{font-size:1.75rem;flex-shrink:0}.summary-details{flex:1}.summary-label{font-size:.75rem;color:var(--color-text-tertiary);font-weight:500}.summary-count{font-size:1.5rem;font-weight:700;color:var(--color-text);line-height:1;margin-top:.125rem;letter-spacing:-.02em}.severity-badge{padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.severity-badge.critical{background:#fecaca;color:#991b1b}.severity-badge.warning{background:var(--tier-stratus-bg);color:var(--tier-stratus-text)}.severity-badge.info{background:var(--tier-cumulus-bg);color:var(--tier-cumulus-text)}.tier-badge{padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.tier-badge.tier-cumulus{background-color:var(--tier-cumulus-bg);color:var(--tier-cumulus-text)}.tier-badge.tier-nimbus{background-color:var(--tier-nimbus-bg);color:var(--tier-nimbus-text)}.tier-badge.tier-stratus{background-color:var(--tier-stratus-bg);color:var(--tier-stratus-text)}.alert-section{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.alert-section.critical{border-left:4px solid var(--color-danger);background:#fef2f2}.alert-section h3{margin-top:0;margin-bottom:1rem;font-size:1.125rem;font-weight:600;color:#991b1b}.offline-nodes-list{display:flex;flex-direction:column;gap:.625rem}.offline-node-item{display:flex;align-items:center;gap:.625rem;padding:.625rem;background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid #fecaca}.offline-node-item strong{flex:1;color:var(--color-text)}.offline-node-item .group-name{color:var(--color-text-tertiary);font-size:.8125rem}.offline-node-item .time-ago{color:#991b1b;font-size:.75rem;font-weight:600}.more-indicator{padding:.625rem;text-align:center;color:var(--color-text-tertiary);font-style:italic;font-size:.875rem}.events-section{background:var(--color-surface);padding:1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.events-section h3{margin-top:0;margin-bottom:1rem;font-size:1.125rem;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:.625rem}.event-count{font-size:.875rem;color:var(--color-text-tertiary);font-weight:400}.no-events{text-align:center;padding:3rem 1.25rem;color:var(--color-text-tertiary)}.no-events p{margin:.625rem 0}.no-events .hint{font-size:.875rem;font-style:italic}.events-timeline{display:flex;flex-direction:column;gap:.75rem}.event-item{background:var(--color-surface);border:1px solid var(--color-border);border-left-width:4px;border-radius:var(--radius-sm);padding:1rem;cursor:pointer;transition:box-shadow .15s;-webkit-user-select:none;user-select:none}.event-item:hover,.event-item.expanded{box-shadow:var(--shadow-md)}.event-item.critical{border-left-color:var(--color-danger)}.event-item.warning{border-left-color:var(--color-warning)}.event-item.info{border-left-color:var(--color-info)}.event-header{display:flex;align-items:center;gap:.75rem}.event-icon{font-size:1.5rem;flex-shrink:0}.event-main{flex:1;min-width:0}.event-title{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.event-type{font-weight:600;color:var(--color-text);font-size:.9375rem}.event-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.8125rem}.node-name{color:var(--color-text-secondary);font-weight:500}.location{color:var(--color-text-tertiary);font-size:.75rem}.group-name{color:var(--color-text-tertiary);font-size:.75rem;padding:.125rem .375rem;background:var(--color-surface-sunken);border-radius:3px}.event-time{flex-shrink:0;font-size:.75rem;color:var(--color-text-tertiary);font-weight:500}.expand-indicator{flex-shrink:0;font-size:.875rem;color:var(--color-text-muted);margin-left:.625rem;transition:transform .2s}.event-item:hover .expand-indicator{color:var(--color-text-secondary)}.event-details{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;padding-top:0;margin-top:0}to{opacity:1;max-height:500px;padding-top:1rem;margin-top:1rem}}.event-details h4{margin-top:0;margin-bottom:.625rem;font-size:.8125rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em}.details-list{display:grid;grid-template-columns:auto 1fr;gap:.5rem 1rem;font-size:.8125rem}.details-list dt{font-weight:600;color:var(--color-text-tertiary)}.details-list dd{margin:0;color:var(--color-text)}.details-list dd.mono{font-family:var(--font-mono);font-size:.75rem;word-break:break-all}.loading-container,.error-container{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2.5rem}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);padding:1.25rem;color:#991b1b;max-width:500px;text-align:center}@media (max-width: 768px){.filters-section{flex-direction:column}.filter-group,.filter-actions,.btn-clear-filters{width:100%}.summary-grid{grid-template-columns:1fr}.event-header{flex-direction:column;align-items:flex-start}.event-time{align-self:flex-start}.details-list{grid-template-columns:1fr;gap:.25rem}.details-list dt{margin-top:.5rem}}:root{--color-primary: #4f6ef7;--color-primary-hover: #3b5de7;--color-primary-light: rgba(79, 110, 247, .08);--color-primary-border: rgba(79, 110, 247, .25);--color-primary-shadow: rgba(79, 110, 247, .18);--color-bg: #f8f9fc;--color-surface: #ffffff;--color-surface-raised: #f7f8fb;--color-surface-sunken: #f1f3f9;--color-text: #1a1f36;--color-text-secondary: #3c4257;--color-text-tertiary: #697386;--color-text-muted: #a3acb9;--color-border: #e3e8ee;--color-border-light: #edf0f5;--color-success: #22c55e;--color-success-hover: #16a34a;--color-warning: #f59e0b;--color-danger: #ef4444;--color-danger-hover: #dc2626;--color-info: #3b82f6;--tier-cumulus-bg: #dbeafe;--tier-cumulus-text: #1e40af;--tier-nimbus-bg: #d1fae5;--tier-nimbus-text: #065f46;--tier-stratus-bg: #fef3c7;--tier-stratus-text: #92400e;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 100px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .12);--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace}*{box-sizing:border-box}body{margin:0;font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text);background-color:var(--color-bg)}code{font-family:var(--font-mono)}#root{min-height:100vh}
