*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}:root{--primary:#4f46e5;--bg-gray:#f3f4f6;--border:#e5e7eb}*{box-sizing:border-box}body{background:var(--bg-gray);color:#1f2937;margin:0;font-family:-apple-system,system-ui,sans-serif}.app-wrapper{flex-direction:column;height:100vh;display:flex}.navbar{border-bottom:1px solid var(--border);background:#fff;padding:1rem 1.5rem}.navbar-content{justify-content:space-between;align-items:center;display:flex}.navbar-left{align-items:center;gap:10px;display:flex}.navbar-title{margin:0;font-size:1.25rem}.dashboard-content{flex:1;gap:20px;width:100%;max-width:1400px;margin:0 auto;padding:20px;display:flex;overflow:hidden}.users-sidebar{border:1px solid var(--border);background:#fff;border-radius:8px;flex-direction:column;flex-shrink:0;width:300px;display:flex}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:15px;display:flex}.sidebar-header h2{margin:0;font-size:1rem}.sidebar-actions{border-bottom:1px solid var(--border);background:#f9fafb;justify-content:space-between;align-items:center;padding:10px 15px;display:flex}.btn-select-all{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-weight:600;display:flex}.users-list{flex:1;padding:10px;overflow-y:auto}.user-card{border-bottom:1px solid var(--border);cursor:pointer;border-radius:6px;align-items:center;gap:10px;padding:10px;transition:all .2s;display:flex}.user-card:hover{background:#f3f4f6}.user-card.selected{border-left:3px solid var(--primary);background:#eef2ff}.user-avatar-small{width:32px;height:32px;color:var(--primary);background:#e0e7ff;border-radius:50%;justify-content:center;align-items:center;font-weight:700;display:flex}.user-info{flex:1;overflow:hidden}.user-email-text{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.user-meta{color:#6b7280;flex-wrap:wrap;align-items:center;gap:4px;font-size:.75rem;display:flex}.circle-empty{border:2px solid #d1d5db;border-radius:50%;width:16px;height:16px}.main-panel{flex-direction:column;flex:1;gap:20px;display:flex;overflow-y:auto}.section-card{border:1px solid var(--border);background:#fff;border-radius:8px;padding:20px}.section-header{align-items:center;gap:10px;margin-bottom:20px;display:flex}.notification-form{flex-direction:column;gap:15px;display:flex}.form-input{border:1px solid #d1d5db;border-radius:6px;width:100%;margin-top:5px;padding:10px}.form-textarea{resize:vertical;min-height:100px}.btn-send{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:12px;font-weight:600}.btn-send:disabled{opacity:.7;cursor:not-allowed}.status-alert{border-radius:6px;margin-top:10px;padding:10px}.status-alert.success{color:#065f46;background:#d1fae5}.status-alert.error{color:#991b1b;background:#fee2e2}.history-item{border-bottom:1px solid var(--border);padding:10px 0}.history-header{justify-content:space-between;margin-bottom:5px;display:flex}.history-stats{color:#6b7280;margin-top:5px;font-size:.8rem}.login-container{justify-content:center;align-items:center;height:100vh;display:flex}.login-card{text-align:center;background:#fff;border-radius:12px;width:100%;max-width:400px;padding:40px;box-shadow:0 4px 6px -1px #0000001a}.btn-login{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;margin-top:20px;padding:12px}.navbar-right{align-items:center;gap:15px;display:flex}.btn-settings{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.btn-settings:hover{background:#f3f4f6}.customization-panel{border-bottom:1px solid var(--border);background:#fff;max-height:500px;animation:.3s ease-out slideDown;overflow-y:auto}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.customization-header{border-bottom:1px solid var(--border);background:#f9fafb;justify-content:space-between;align-items:center;padding:20px;display:flex}.customization-header h2{align-items:center;gap:10px;margin:0;font-size:1.1rem;display:flex}.btn-close{cursor:pointer;color:#6b7280;background:0 0;border:none;width:30px;height:30px;padding:0;font-size:1.5rem}.btn-close:hover{color:#1f2937}.customization-content{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;padding:20px;display:grid}.customization-section{border:1px solid var(--border);background:#f9fafb;border-radius:8px;padding:15px}.customization-section h3{color:#374151;align-items:center;gap:8px;margin:0 0 15px;font-size:.95rem;display:flex}.setting-group{margin-bottom:15px}.setting-group:last-child{margin-bottom:0}.setting-group label{color:#374151;margin-bottom:6px;font-size:.9rem;font-weight:500;display:block}.setting-select,.setting-input{color:#1f2937;background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:8px 12px;font-size:.9rem}.setting-select:focus,.setting-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #4f46e51a}.setting-select:disabled,.setting-input:disabled{cursor:not-allowed;opacity:.6;background:#f3f4f6}.setting-group small{color:#6b7280;margin-top:4px;font-size:.8rem;display:block}.checkbox-label{cursor:pointer;align-items:center;gap:8px;font-weight:400;display:flex}.checkbox-label input{cursor:pointer;width:16px;height:16px}.color-picker-wrapper{align-items:center;gap:10px;display:flex}.color-input{cursor:pointer;border:1px solid #d1d5db;border-radius:6px;width:50px;height:40px}.color-value{color:#6b7280;flex:1;font-family:monospace;font-size:.9rem}.customization-actions{border-top:1px solid var(--border);grid-column:1/-1;justify-content:flex-end;gap:10px;padding-top:15px;display:flex}.btn-reset,.btn-done{cursor:pointer;border:none;border-radius:6px;padding:10px 20px;font-weight:600;transition:all .2s}.btn-reset{color:#374151;border:1px solid var(--border);background:#f3f4f6}.btn-reset:hover{background:#e5e7eb}.btn-done{background:var(--primary);color:#fff}.btn-done:hover{opacity:.9}.notification-type-selector{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:10px;display:grid}.type-button{border:2px solid var(--border);cursor:pointer;text-align:center;background:#fff;border-radius:8px;flex-direction:column;align-items:center;gap:8px;padding:16px;transition:all .3s;display:flex}.type-button:hover{border-color:var(--primary);background:#f9fafb;transform:translateY(-2px)}.type-button.active{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 4px 12px #4f46e54d}.type-icon{font-size:28px}.type-label{font-size:14px;font-weight:600}.type-desc{opacity:.7;font-size:12px}.type-button.active .type-desc{opacity:.9}.notification-preview-section{border:1px solid var(--border);background:#f9fafb;border-radius:8px;margin-top:20px;padding:20px}.notification-preview-section h3{color:#1f2937;margin:0 0 15px;font-size:1rem}.preview-container{grid-template-columns:1fr 1fr;gap:20px;display:grid}.preview-device{border:1px solid var(--border);background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.preview-header{color:#6b7280;border-bottom:1px solid var(--border);background:#f3f4f6;padding:10px;font-size:.9rem;font-weight:600}.preview-notification{align-items:flex-start;gap:12px;padding:15px;display:flex}.preview-notification.ios{background:#f0f0f0;flex-direction:column;padding:20px}.preview-icon{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;font-weight:700;display:flex}.preview-title{color:#1f2937;word-break:break-word;margin-bottom:4px;font-size:.95rem;font-weight:600}.preview-body{color:#6b7280;word-break:break-word;font-size:.85rem;line-height:1.4}.preview-name{color:#9ca3af;margin-top:6px;font-size:.75rem;font-style:italic}.preview-notification.ios .preview-title{margin-bottom:8px;font-size:1rem}.preview-notification.ios .preview-body{color:#333;font-size:.9rem}.platform-filter{border-bottom:1px solid var(--border);background:#fafafa;padding:12px}.platform-filter label{color:#666;margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.filter-buttons{gap:6px;display:flex}.filter-btn{border:1px solid var(--border);cursor:pointer;color:#666;background:#fff;border-radius:4px;flex:1;padding:6px 10px;font-size:.85rem;transition:all .2s}.filter-btn:hover{border-color:var(--primary);color:var(--primary)}.filter-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.platform-badge{white-space:nowrap;border-radius:12px;margin-left:8px;padding:3px 8px;font-size:.75rem;font-weight:600;display:inline-block}.platform-badge.platform-android{color:#fff;background:#3ddc84}.platform-badge.platform-ios{color:#fff;background:#555}@media (max-width:768px){.preview-container{grid-template-columns:1fr}}.fcm-options{flex-direction:column;gap:20px;display:flex}.fcm-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;padding:20px}.fcm-section h3{color:#333;align-items:center;gap:8px;margin:0 0 15px;font-size:16px;display:flex}.templates-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;display:grid}.template-btn{cursor:pointer;text-align:center;color:#333;background:#fff;border:1px solid #ddd;border-radius:6px;padding:10px;font-size:12px;font-weight:500;transition:all .3s}.template-btn:hover{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.fcm-option{flex-direction:column;gap:6px;margin-bottom:15px;display:flex}.fcm-option:last-child{margin-bottom:0}.fcm-option label{color:#333;font-size:13px;font-weight:600}.fcm-select,.fcm-input,.fcm-textarea{border:1px solid #ddd;border-radius:6px;padding:10px;font-family:inherit;font-size:13px;transition:all .3s}.fcm-select:focus,.fcm-input:focus,.fcm-textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.fcm-textarea{resize:vertical;min-height:100px;font-family:Courier New,monospace;font-size:12px}.fcm-option small{color:#999;font-size:11px;font-style:italic}.color-picker-group{align-items:center;gap:10px;display:flex}.color-picker{cursor:pointer;border:1px solid #ddd;border-radius:6px;width:50px;height:40px}.color-value{color:#666;font-family:Courier New,monospace;font-size:12px;font-weight:500}.advanced-toggle{cursor:pointer;color:#667eea;text-align:left;background:#fff;border:1px solid #ddd;border-radius:6px;width:100%;padding:10px;font-size:13px;font-weight:600;transition:all .3s}.advanced-toggle:hover{background:#f0f0f0;border-color:#667eea}.advanced-options{border-top:1px solid #e9ecef;flex-direction:column;gap:15px;margin-top:15px;padding-top:15px;animation:.3s ease-out slideDown;display:flex}.preview-section{background:#fff;border:2px solid #667eea}.notification-preview{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:15px}.preview-header{gap:12px;margin-bottom:12px;display:flex}.preview-icon{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;font-size:24px;display:flex}.preview-content{flex:1}.preview-title{color:#333;margin-bottom:4px;font-size:14px;font-weight:600}.preview-body{color:#666;font-size:13px;line-height:1.4}.preview-meta{border-top:1px solid #e9ecef;flex-wrap:wrap;gap:8px;padding-top:12px;display:flex}.meta-badge{color:#666;background:#fff;border:1px solid #ddd;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:500}@media (max-width:768px){.templates-grid{grid-template-columns:repeat(2,1fr)}.fcm-section{padding:15px}}
