@import"https://fonts.googleapis.com/css2?family=DM+Mono:ital,wght@0,300;0,400;0,500;1,400&family=Syne:wght@400;500;600;700;800&family=Instrument+Sans:ital,wght@0,400;0,500;0,600;1,400&display=swap";:root{--sidebar-bg: #10251c;--sidebar-hover: #1a3829;--sidebar-active: #196a44;--sidebar-text: #a8c4b0;--sidebar-text-bright: #e8f2ea;--accent: #196a44;--accent-light: #22a05a;--accent-dim: #0f4a2e;--bg: #f4f6f4;--surface: #ffffff;--surface-2: #f9fbf9;--border: #e2e8e2;--border-light: #eef2ee;--text: #111c13;--text-2: #4a5e4d;--text-3: #7a917d;--font-display: "Syne", sans-serif;--font-body: "Instrument Sans", sans-serif;--font-mono: "DM Mono", monospace;--radius: 10px;--radius-sm: 6px;--shadow: 0 1px 3px rgba(16,37,28,.08), 0 4px 16px rgba(16,37,28,.04);--shadow-md: 0 4px 12px rgba(16,37,28,.12), 0 1px 3px rgba(16,37,28,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.login-panel{width:min(100%,380px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:28px}.login-mark{width:40px;height:40px;border-radius:8px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:18px}.login-panel h1{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--text);line-height:1.1}.login-panel p{color:var(--text-3);font-size:13px;margin:6px 0 20px}.login-panel .form-field{margin-bottom:14px}.login-submit{width:100%;justify-content:center;margin-top:4px}.layout{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{background:var(--sidebar-bg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;padding:0 0 24px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:12px}.sidebar-brand-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-brand-text{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--sidebar-text-bright);letter-spacing:-.01em;line-height:1.2}.sidebar-brand-sub{font-size:10px;color:var(--sidebar-text);font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase}.sidebar-section{padding:0 10px;flex:1}.sidebar-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#a8c4b073;padding:12px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--sidebar-text);font-family:var(--font-body);font-size:13.5px;font-weight:500;cursor:pointer;text-align:left;transition:background .15s,color .15s;margin-bottom:2px}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-bright)}.nav-item.active{background:var(--accent);color:#fff}.nav-item svg{flex-shrink:0;opacity:.85}.nav-item.active svg{opacity:1}.sidebar-footer{padding:16px 20px 0;border-top:1px solid rgba(255,255,255,.06);margin-top:auto}.sidebar-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--sidebar-text);font-family:var(--font-mono)}.status-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;box-shadow:0 0 0 2px #4ade8040;animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 0 2px #4ade8040}50%{box-shadow:0 0 0 4px #4ade801a}}.main{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 32px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.topbar-title{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em}.topbar-actions{display:flex;align-items:center;gap:10px}.btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-light)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-sm{padding:5px 10px;font-size:12px}.btn-danger{background:transparent;color:#c0392b;border:1px solid #f5c6c2}.btn-danger:hover{background:#fef2f2}.page-content{padding:28px 32px;flex:1;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-header{margin-bottom:24px}.page-header h1{font-family:var(--font-display);font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--text)}.page-header p{color:var(--text-3);font-size:13px;margin-top:3px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent);opacity:0;transition:opacity .2s}.stat-card:hover:before{opacity:1}.stat-icon{width:36px;height:36px;border-radius:8px;background:#edf7f1;display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:14px}.stat-label{font-size:11.5px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-mono);margin-bottom:6px}.stat-value{font-family:var(--font-display);font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1}.stat-value.success{color:#16a34a}.stat-value.danger{color:#dc2626}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.overview-grid.full{grid-template-columns:1fr}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.panel-header{padding:16px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.panel-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.02em}.panel-body{padding:0}.vendor-chart{padding:16px 20px}.vendor-row{display:grid;grid-template-columns:80px 1fr 48px;align-items:center;gap:12px;margin-bottom:12px}.vendor-row:last-child{margin-bottom:0}.vendor-name{font-family:var(--font-mono);font-size:12px;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}.vendor-bar-track{height:8px;background:var(--border-light);border-radius:99px;overflow:hidden}.vendor-bar-fill{height:100%;border-radius:99px;background:var(--accent);transition:width .6s cubic-bezier(.16,1,.3,1)}.vendor-bar-fill.fcm{background:#196a44}.vendor-bar-fill.hms{background:#0ea5e9}.vendor-bar-fill.honor{background:#8b5cf6}.vendor-bar-fill.webpush{background:#f59e0b}.vendor-bar-fill.apns{background:#6b7280}.vendor-pct{font-family:var(--font-mono);font-size:12px;color:var(--text-3);text-align:right}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{padding:10px 16px;text-align:left;font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap}tbody tr{border-bottom:1px solid var(--border-light);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface-2)}tbody td{padding:11px 16px;color:var(--text);vertical-align:middle}.td-mono{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}.td-truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-size:11.5px;font-weight:600;font-family:var(--font-mono);letter-spacing:.02em;white-space:nowrap}.badge-dot{width:5px;height:5px;border-radius:50%}.badge-online{background:#dcfce7;color:#15803d}.badge-online .badge-dot{background:#16a34a}.badge-offline{background:#f3f4f6;color:#6b7280}.badge-offline .badge-dot{background:#9ca3af}.badge-sent{background:#dcfce7;color:#15803d}.badge-sent .badge-dot{background:#16a34a}.badge-queued{background:#fef9c3;color:#a16207}.badge-queued .badge-dot{background:#ca8a04}.badge-failed{background:#fee2e2;color:#b91c1c}.badge-failed .badge-dot{background:#dc2626}.badge-partial{background:#ffedd5;color:#c2410c}.badge-partial .badge-dot{background:#ea580c}.badge-active{background:#dcfce7;color:#15803d}.badge-inactive{background:#f3f4f6;color:#6b7280}.chip{display:inline-block;padding:2px 8px;border-radius:4px;font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.chip-fcm{background:#d1fae5;color:#065f46}.chip-hms{background:#e0f2fe;color:#0369a1}.chip-honor{background:#ede9fe;color:#5b21b6}.chip-webpush{background:#fef3c7;color:#92400e}.chip-apns{background:#f3f4f6;color:#374151}.chip-android{background:#d1fae5;color:#065f46}.chip-ios{background:#e0f2fe;color:#0369a1}.chip-web{background:#fef3c7;color:#92400e}.platform-cell{display:flex;align-items:center;gap:8px}.platform-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.platform-icon.android{background:#d1fae5;color:#065f46}.platform-icon.ios{background:#e0f2fe;color:#0369a1}.platform-icon.web{background:#fef3c7;color:#92400e}.copy-wrap{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-family:var(--font-mono);font-size:12px;color:var(--text-2);cursor:pointer;transition:all .15s;max-width:200px}.copy-wrap:hover{border-color:var(--accent);color:var(--accent)}.copy-wrap.copied{border-color:#16a34a;color:#16a34a;background:#f0fdf4}.copy-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filters{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border-light);background:var(--surface-2);flex-wrap:wrap}.search-input{flex:1;min-width:200px;padding:7px 12px 7px 34px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;position:relative}.search-input:focus{border-color:var(--accent)}.search-wrap{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none}.filter-select{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;background:var(--surface);color:var(--text);outline:none;cursor:pointer}.filter-select:focus{border-color:var(--accent)}.filter-count{font-family:var(--font-mono);font-size:12px;color:var(--text-3);margin-left:auto;white-space:nowrap}.skeleton{background:linear-gradient(90deg,#e8ede8 25%,#f2f6f2,#e8ede8 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:4px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-light)}.skeleton-row:last-child{border-bottom:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--text-3)}.empty-icon{width:48px;height:48px;border-radius:12px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;margin-bottom:14px;color:var(--text-3)}.empty-state h3{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-2);margin-bottom:6px}.empty-state p{font-size:13px;max-width:280px}.inline-form{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.inline-form h3{font-family:var(--font-display);font-size:14px;font-weight:700;margin-bottom:14px;color:var(--text)}.form-row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.form-field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:140px}.form-field label{font-size:11.5px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono)}.form-input{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:13px;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}.secret-reveal{background:#0f1f16;border:1px solid #1e3d2a;border-radius:var(--radius-sm);padding:12px 16px;font-family:var(--font-mono);font-size:12px;color:#4ade80;word-break:break-all;margin-top:8px;position:relative}.secret-reveal-label{font-size:10px;color:#6b7280;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.topic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;padding:20px}.topic-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:box-shadow .15s,border-color .15s}.topic-card:hover{box-shadow:var(--shadow-md);border-color:#c8dcc8}.topic-card-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.02em}.topic-card-desc{font-size:12.5px;color:var(--text-3);margin-bottom:14px;line-height:1.5}.topic-card-footer{display:flex;align-items:center;justify-content:space-between}.topic-subscribers{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:12px;color:var(--text-2)}.topic-subscribers strong{font-size:18px;font-family:var(--font-display);font-weight:800;color:var(--accent)}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);padding:10px 14px;color:#b91c1c;font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.refresh-badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:11px;color:var(--text-3);padding:4px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:99px}.refresh-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mobile-header{display:none;background:var(--sidebar-bg);padding:14px 20px;align-items:center;justify-content:space-between}.mobile-brand{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--sidebar-text-bright)}.hamburger{background:transparent;border:none;color:var(--sidebar-text-bright);cursor:pointer;padding:4px}@media(max-width:900px){.layout{grid-template-columns:1fr}.sidebar{position:fixed;left:-232px;top:0;z-index:100;transition:left .25s ease;height:100vh}.sidebar.open{left:0}.mobile-header{display:flex}.stat-grid{grid-template-columns:repeat(2,1fr)}.overview-grid{grid-template-columns:1fr}.page-content{padding:20px 16px}.topbar{padding:0 16px}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:24px}}
