@import url('global.css'); /* ===== Layout ===== */ body { display: flex; min-height: 100vh; overflow-x: hidden; } /* ===== Sidebar ===== */ .sidebar { width: 260px; background-color: var(--bg-card); border-right: 1px solid var(--border-color); position: fixed; top: 0; left: 0; bottom: 0; display: flex; flex-direction: column; z-index: 100; } .sidebar-header { padding: var(--spacing-lg); border-bottom: 1px solid var(--border-color); } .sidebar-brand { display: flex; align-items: center; gap: var(--spacing-sm); text-decoration: none; color: var(--text-primary); font-weight: 700; font-size: 1.1rem; margin-bottom: var(--spacing-md); } .sidebar-brand img { width: 32px; height: 32px; border-radius: 50%; } .guild-info { display: flex; align-items: center; gap: var(--spacing-sm); padding: var(--spacing-sm); background-color: var(--bg-dark); border-radius: var(--border-radius); } .guild-info img { width: 40px; height: 40px; border-radius: 50%; } .guild-info-text { flex: 1; min-width: 0; } .guild-info-name { font-weight: 600; color: var(--text-primary); font-size: 0.9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .guild-info-id { color: var(--text-muted); font-size: 0.75rem; } /* ===== Sidebar Navigation ===== */ .sidebar-nav { flex: 1; padding: var(--spacing-md); overflow-y: auto; } .nav-section { margin-bottom: var(--spacing-lg); } .nav-section-title { font-size: 0.7rem; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; padding: var(--spacing-xs) var(--spacing-sm); margin-bottom: var(--spacing-xs); } .nav-item { display: flex; align-items: center; gap: var(--spacing-sm); padding: var(--spacing-sm) var(--spacing-md); border-radius: var(--border-radius); color: var(--text-secondary); text-decoration: none; font-size: 0.9rem; font-weight: 500; transition: all var(--transition-fast); cursor: pointer; } .nav-item:hover { background-color: var(--bg-dark); color: var(--text-primary); } .nav-item.active { background-color: var(--primary-light); color: var(--primary); } .nav-item-icon { font-size: 1.1rem; width: 24px; text-align: center; } /* ===== Sidebar Footer ===== */ .sidebar-footer { padding: var(--spacing-md); border-top: 1px solid var(--border-color); } .sidebar-footer a { display: flex; align-items: center; gap: var(--spacing-sm); padding: var(--spacing-sm) var(--spacing-md); border-radius: var(--border-radius); color: var(--text-secondary); text-decoration: none; font-size: 0.9rem; transition: all var(--transition-fast); } .sidebar-footer a:hover { background-color: var(--bg-dark); color: var(--text-primary); } /* ===== Main Content ===== */ .main-content { flex: 1; margin-left: 260px; min-height: 100vh; display: flex; flex-direction: column; } /* ===== Top Header ===== */ .top-header { background-color: var(--bg-card); border-bottom: 1px solid var(--border-color); padding: var(--spacing-md) var(--spacing-xl); display: flex; align-items: center; justify-content: space-between; position: sticky; top: 0; z-index: 50; } .breadcrumb { display: flex; align-items: center; gap: var(--spacing-sm); color: var(--text-secondary); font-size: 0.9rem; } .breadcrumb a { color: var(--text-secondary); text-decoration: none; } .breadcrumb a:hover { color: var(--text-primary); } .breadcrumb-separator { color: var(--text-muted); } .breadcrumb-current { color: var(--text-primary); font-weight: 500; } .header-user { display: flex; align-items: center; gap: var(--spacing-sm); } .header-user img { width: 32px; height: 32px; border-radius: 50%; } .header-user span { color: var(--text-primary); font-weight: 500; } /* ===== Content Area ===== */ .content-area { flex: 1; padding: var(--spacing-xl); max-width: 900px; } /* ===== Config Sections ===== */ .config-section { display: none; } .config-section.active { display: block; } /* ===== Config Card ===== */ .config-card { background-color: var(--bg-card); border: 1px solid var(--border-color); border-radius: var(--border-radius-lg); margin-bottom: var(--spacing-lg); overflow: hidden; } .config-card-header { padding: var(--spacing-lg); border-bottom: 1px solid var(--border-color); display: flex; align-items: center; justify-content: space-between; } .config-card-title { display: flex; align-items: center; gap: var(--spacing-sm); } .config-card-title h3 { font-size: 1.1rem; font-weight: 600; color: var(--text-primary); } .config-card-title .icon { font-size: 1.25rem; } .config-card-body { padding: var(--spacing-lg); } .config-card-footer { padding: var(--spacing-md) var(--spacing-lg); border-top: 1px solid var(--border-color); background-color: var(--bg-dark); display: flex; align-items: center; justify-content: space-between; } /* ===== Toggle Switch ===== */ .toggle-switch { position: relative; width: 48px; height: 24px; } .toggle-switch input { opacity: 0; width: 0; height: 0; } .toggle-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: var(--bg-dark); border: 1px solid var(--border-color); transition: var(--transition-fast); border-radius: 24px; } .toggle-slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 2px; bottom: 2px; background-color: var(--text-muted); transition: var(--transition-fast); border-radius: 50%; } .toggle-switch input:checked + .toggle-slider { background-color: var(--primary); border-color: var(--primary); } .toggle-switch input:checked + .toggle-slider:before { background-color: white; transform: translateX(24px); } /* ===== Form Styles ===== */ .form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--spacing-md); } .form-group { margin-bottom: var(--spacing-md); } .form-group:last-child { margin-bottom: 0; } .form-label { display: block; font-weight: 500; color: var(--text-primary); margin-bottom: var(--spacing-xs); font-size: 0.9rem; } .form-sublabel { display: block; color: var(--text-muted); font-size: 0.8rem; margin-top: 2px; } .form-input, .form-select, .form-textarea { width: 100%; padding: var(--spacing-sm) var(--spacing-md); background-color: var(--bg-dark); border: 1px solid var(--border-color); border-radius: var(--border-radius); color: var(--text-primary); font-size: 0.9rem; transition: border-color var(--transition-fast), box-shadow var(--transition-fast); } .form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-light); } .form-textarea { resize: vertical; min-height: 100px; } .form-select[multiple] { height: auto; min-height: 120px; } .form-hint { margin-top: var(--spacing-xs); font-size: 0.8rem; color: var(--text-muted); } .form-hint code { background-color: var(--bg-dark); padding: 2px 6px; border-radius: 4px; font-family: monospace; font-size: 0.85em; } /* ===== Inline Toggle ===== */ .inline-toggle { display: flex; align-items: center; justify-content: space-between; padding: var(--spacing-md); background-color: var(--bg-dark); border-radius: var(--border-radius); margin-bottom: var(--spacing-md); } .inline-toggle:last-child { margin-bottom: 0; } .inline-toggle-label { display: flex; flex-direction: column; } .inline-toggle-title { font-weight: 500; color: var(--text-primary); font-size: 0.9rem; } .inline-toggle-desc { color: var(--text-muted); font-size: 0.8rem; margin-top: 2px; } /* ===== Status Messages ===== */ .status-message { padding: var(--spacing-sm) var(--spacing-md); border-radius: var(--border-radius); font-size: 0.9rem; font-weight: 500; min-height: 1.5em; } .status-message:empty { display: none; } .status-message.success { background-color: rgba(35, 134, 54, 0.15); color: var(--success); border: 1px solid var(--success); } .status-message.error { background-color: rgba(248, 81, 73, 0.15); color: var(--danger); border: 1px solid var(--danger); } /* ===== Sub-sections ===== */ .sub-section { margin-top: var(--spacing-lg); padding-top: var(--spacing-lg); border-top: 1px solid var(--border-color); } .sub-section-title { font-size: 0.95rem; font-weight: 600; color: var(--text-primary); margin-bottom: var(--spacing-md); display: flex; align-items: center; gap: var(--spacing-sm); } /* ===== Variables Info Box ===== */ .variables-box { background-color: var(--bg-dark); border: 1px solid var(--border-color); border-radius: var(--border-radius); padding: var(--spacing-md); margin-top: var(--spacing-md); } .variables-box-title { font-size: 0.85rem; font-weight: 600; color: var(--text-secondary); margin-bottom: var(--spacing-sm); } .variables-list { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); } .variable-tag { display: inline-flex; align-items: center; gap: 4px; padding: 4px 8px; background-color: var(--bg-card); border-radius: 4px; font-size: 0.8rem; } .variable-tag code { color: var(--primary); font-family: monospace; } .variable-tag span { color: var(--text-muted); } /* ===== Info Box ===== */ .info-box { background: linear-gradient(135deg, rgba(88, 101, 242, 0.1), rgba(88, 101, 242, 0.05)); border: 1px solid rgba(88, 101, 242, 0.3); border-radius: var(--border-radius); padding: var(--spacing-md); margin-bottom: var(--spacing-lg); color: var(--text-secondary); font-size: 0.9rem; line-height: 1.5; } .info-box strong { color: var(--primary); display: block; margin-bottom: var(--spacing-xs); } /* ===== Mobile Sidebar Toggle ===== */ .mobile-toggle { display: none; position: fixed; bottom: var(--spacing-lg); right: var(--spacing-lg); width: 56px; height: 56px; background-color: var(--primary); border: none; border-radius: 50%; color: white; font-size: 24px; cursor: pointer; box-shadow: var(--shadow-lg); z-index: 200; } /* ===== Stats Channels List ===== */ .stats-channel-item { display: flex; align-items: center; justify-content: space-between; padding: var(--spacing-md); background: var(--bg-secondary); border-radius: var(--radius-md); margin-bottom: var(--spacing-sm); gap: var(--spacing-md); } .stats-channel-info { display: flex; flex-direction: column; gap: var(--spacing-xs); flex: 1; } .stats-channel-info strong { color: var(--text-primary); } .stats-channel-type { font-size: 0.85rem; color: var(--text-muted); } .stats-channel-format { background: var(--bg-card); padding: 2px 8px; border-radius: var(--radius-sm); font-size: 0.8rem; color: var(--text-secondary); width: fit-content; } /* ===== Responsive ===== */ @media (max-width: 900px) { .sidebar { transform: translateX(-100%); transition: transform var(--transition-normal); } .sidebar.open { transform: translateX(0); } .main-content { margin-left: 0; } .mobile-toggle { display: flex; align-items: center; justify-content: center; } .content-area { padding: var(--spacing-md); } } @media (max-width: 600px) { .form-row { grid-template-columns: 1fr; } .config-card-header { flex-direction: column; align-items: flex-start; gap: var(--spacing-md); } } /* ===== Scheduled Messages ===== */ .checkbox-group { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); } .checkbox-item { display: flex; align-items: center; gap: var(--spacing-xs); padding: var(--spacing-xs) var(--spacing-sm); background: var(--bg-secondary); border-radius: var(--radius-sm); cursor: pointer; user-select: none; } .checkbox-item:hover { background: var(--bg-card); } .checkbox-item input { cursor: pointer; } .checkbox-group-vertical { display: flex; flex-direction: column; gap: var(--spacing-sm); } .checkbox-group-vertical .checkbox-item { width: fit-content; } .times-input-container { display: flex; gap: var(--spacing-sm); align-items: center; margin-bottom: var(--spacing-sm); } .times-list { display: flex; flex-wrap: wrap; gap: var(--spacing-xs); min-height: 32px; } .time-tag { display: inline-flex; align-items: center; gap: var(--spacing-xs); padding: 4px 10px; background: var(--primary-color); color: white; border-radius: var(--radius-sm); font-size: 0.85rem; } .time-remove { background: none; border: none; color: white; cursor: pointer; font-size: 1.1rem; line-height: 1; opacity: 0.7; } .time-remove:hover { opacity: 1; } .form-actions { display: flex; gap: var(--spacing-sm); margin-top: var(--spacing-md); } .scheduled-message-item { background: var(--bg-secondary); border-radius: var(--radius-md); padding: var(--spacing-md); margin-bottom: var(--spacing-sm); } .scheduled-message-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--spacing-sm); } .scheduled-message-info strong { color: var(--text-primary); display: block; } .scheduled-message-schedule { font-size: 0.85rem; color: var(--text-muted); } .status-badge { padding: 2px 8px; border-radius: var(--radius-sm); font-size: 0.75rem; font-weight: 600; } .status-active { background: rgba(87, 242, 135, 0.2); color: #57F287; } .status-inactive { background: rgba(237, 66, 69, 0.2); color: #ED4245; } .scheduled-message-preview { background: var(--bg-card); padding: var(--spacing-sm); border-radius: var(--radius-sm); font-size: 0.9rem; color: var(--text-secondary); margin-bottom: var(--spacing-sm); word-break: break-word; } .embed-badge { display: inline-block; padding: 2px 6px; background: var(--primary-color); color: white; border-radius: var(--radius-sm); font-size: 0.75rem; margin-left: var(--spacing-xs); } .scheduled-message-options { display: flex; flex-wrap: wrap; gap: var(--spacing-xs); margin-bottom: var(--spacing-sm); } .option-tag { padding: 2px 8px; background: var(--bg-card); border-radius: var(--radius-sm); font-size: 0.75rem; color: var(--text-muted); } .scheduled-message-actions { display: flex; gap: var(--spacing-sm); flex-wrap: wrap; } .btn-warning { background: #F0B232; color: #000; } .btn-warning:hover { background: #d9a02a; } /* ===== Send Message Preview ===== */ .message-preview { background: var(--bg-dark); border-radius: var(--radius-md); padding: var(--spacing-md); min-height: 100px; } .preview-content { color: var(--text-primary); margin-bottom: var(--spacing-md); white-space: pre-wrap; word-break: break-word; } .preview-embed { background: var(--bg-card); border-left: 4px solid var(--primary-color); border-radius: var(--radius-sm); padding: var(--spacing-md); position: relative; max-width: 520px; } .preview-embed-author { display: flex; align-items: center; gap: var(--spacing-xs); font-size: 0.85rem; color: var(--text-secondary); margin-bottom: var(--spacing-xs); } .preview-author-icon { width: 24px; height: 24px; border-radius: 50%; } .preview-embed-author a { color: var(--text-secondary); text-decoration: none; } .preview-embed-author a:hover { text-decoration: underline; } .preview-embed-title { font-weight: 600; color: var(--text-primary); font-size: 1rem; margin-bottom: var(--spacing-xs); } .preview-embed-description { color: var(--text-secondary); font-size: 0.9rem; white-space: pre-wrap; word-break: break-word; } .preview-embed-thumbnail { position: absolute; top: var(--spacing-md); right: var(--spacing-md); max-width: 80px; max-height: 80px; border-radius: var(--radius-sm); } .preview-embed-fields { display: flex; flex-wrap: wrap; gap: var(--spacing-sm); margin-top: var(--spacing-md); } .preview-embed-field { flex: 1 1 100%; } .preview-embed-field.inline { flex: 1 1 calc(33% - var(--spacing-sm)); min-width: 150px; } .preview-field-name { font-weight: 600; font-size: 0.85rem; color: var(--text-primary); margin-bottom: 2px; } .preview-field-value { font-size: 0.85rem; color: var(--text-secondary); } .preview-embed-image { max-width: 100%; max-height: 300px; border-radius: var(--radius-sm); margin-top: var(--spacing-md); } .preview-embed-footer { display: flex; align-items: center; gap: var(--spacing-xs); margin-top: var(--spacing-md); font-size: 0.75rem; color: var(--text-muted); } .preview-footer-icon { width: 20px; height: 20px; border-radius: 50%; } /* ===== Field Items ===== */ .field-item { background: var(--bg-card); padding: var(--spacing-sm); border-radius: var(--radius-sm); margin-bottom: var(--spacing-sm); } .field-item .form-row { align-items: center; } /* ===== Send Message History ===== */ .history-item { background: var(--bg-card); border-radius: var(--radius-sm); padding: var(--spacing-md); margin-bottom: var(--spacing-sm); } .history-item-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--spacing-xs); } .history-channel { color: var(--primary-color); font-weight: 500; } .history-time { color: var(--text-muted); font-size: 0.8rem; } .history-content { color: var(--text-secondary); font-size: 0.9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } /* ===== Bot Appearance ===== */ .bot-preview-card { display: flex; align-items: center; gap: var(--spacing-md); background: var(--bg-dark); padding: var(--spacing-md); border-radius: var(--radius-md); max-width: 300px; } .bot-preview-card img { width: 64px; height: 64px; border-radius: 50%; } .bot-preview-info { display: flex; align-items: center; gap: var(--spacing-sm); } .bot-preview-name { font-weight: 600; color: var(--text-primary); font-size: 1.1rem; } .bot-preview-tag { background: var(--primary-color); color: white; font-size: 0.65rem; padding: 2px 5px; border-radius: 3px; font-weight: 600; } .alert { padding: var(--spacing-md); border-radius: var(--radius-sm); margin-bottom: var(--spacing-md); } .alert-warning { background: rgba(240, 178, 50, 0.15); border: 1px solid rgba(240, 178, 50, 0.3); color: #F0B232; } .alert-warning strong { color: #F0B232; } .avatar-preview-container { display: flex; align-items: center; gap: var(--spacing-md); background: var(--bg-dark); padding: var(--spacing-md); border-radius: var(--radius-md); } .avatar-preview { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; display: none; } /* ===== Logs System ===== */ .logs-types-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--spacing-md); } .log-type-card { background: var(--bg-dark); border: 2px solid var(--border-color); border-radius: var(--radius-md); padding: var(--spacing-md); transition: all 0.2s ease; cursor: pointer; } .log-type-card:hover { border-color: var(--primary-color); background: rgba(88, 101, 242, 0.05); } .log-type-card.active { border-color: var(--primary-color); background: rgba(88, 101, 242, 0.1); } .log-type-checkbox { display: flex; align-items: flex-start; gap: var(--spacing-sm); cursor: pointer; } .log-type-checkbox input[type="checkbox"] { margin-top: 4px; width: 18px; height: 18px; accent-color: var(--primary-color); } .log-type-icon { font-size: 1.5rem; line-height: 1; } .log-type-info { flex: 1; } .log-type-name { font-weight: 600; color: var(--text-primary); margin-bottom: 2px; } .log-type-desc { font-size: 0.85rem; color: var(--text-muted); } .log-type-status { font-size: 1rem; margin-left: auto; } .logs-channels-preview { background: var(--bg-dark); border-radius: var(--radius-md); padding: var(--spacing-md); } .log-channel-item { display: flex; align-items: center; gap: var(--spacing-sm); padding: var(--spacing-sm) 0; border-bottom: 1px solid var(--border-color); } .log-channel-item:last-child { border-bottom: none; } .log-channel-icon { color: var(--text-muted); font-weight: 500; } .log-channel-name { flex: 1; font-family: monospace; color: var(--text-primary); } .log-channel-status { font-size: 0.85rem; padding: 2px 8px; border-radius: var(--radius-sm); } .log-channel-status.created { background: rgba(87, 242, 135, 0.15); color: #57F287; } .log-channel-status.pending { background: rgba(240, 178, 50, 0.15); color: #F0B232; } .btn-group { display: flex; gap: var(--spacing-sm); } .btn-danger { background: var(--error-color); color: white; border: none; padding: var(--spacing-sm) var(--spacing-md); border-radius: var(--radius-sm); cursor: pointer; font-weight: 500; transition: all 0.2s ease; } .btn-danger:hover { background: #c0392b; } /* ===== Anti-Raid Styles ===== */ .antiraid-modules { display: flex; flex-direction: column; gap: var(--spacing-md); } .antiraid-module { background: var(--bg-dark); border-radius: var(--radius-md); border: 1px solid var(--border-color); overflow: hidden; transition: all 0.2s ease; } .antiraid-module:hover { border-color: var(--primary-color); } .antiraid-module-header { display: flex; align-items: center; justify-content: space-between; padding: var(--spacing-md); background: rgba(255, 255, 255, 0.02); cursor: pointer; user-select: none; } .antiraid-module-header:hover { background: rgba(255, 255, 255, 0.05); } .antiraid-module-title { display: flex; align-items: center; gap: var(--spacing-sm); font-weight: 600; color: var(--text-primary); } .antiraid-icon { font-size: 1.2rem; } .antiraid-module-body { padding: var(--spacing-md); border-top: 1px solid var(--border-color); display: block; } .antiraid-module-body .text-muted { margin-bottom: var(--spacing-md); } .form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--spacing-md); } .checkbox-group { display: flex; flex-direction: column; gap: var(--spacing-sm); } .checkbox-label { display: flex; align-items: center; gap: var(--spacing-sm); cursor: pointer; color: var(--text-secondary); transition: color 0.2s; } .checkbox-label:hover { color: var(--text-primary); } .checkbox-label input[type="checkbox"] { width: 18px; height: 18px; cursor: pointer; accent-color: var(--primary-color); } .multi-select { min-height: 80px; padding: var(--spacing-sm); } .multi-select option { padding: var(--spacing-xs) var(--spacing-sm); border-radius: var(--radius-sm); margin-bottom: 2px; } .multi-select option:checked { background: var(--primary-color); color: white; } /* Status messages */ .status-message { font-size: 0.9rem; padding: var(--spacing-xs) var(--spacing-sm); border-radius: var(--radius-sm); transition: all 0.3s ease; } .status-message.success { color: #57F287; background: rgba(87, 242, 135, 0.1); } .status-message.error { color: var(--error-color); background: rgba(237, 66, 69, 0.1); }