body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  background-color: #f5f6fa;
  color: #2c3e50; }

a {
  color: #2ab5b2;
  text-decoration: none; }
  a:hover {
    color: #3dd4d0; }

h1, h2, h3 {
  color: #1a2332;
  font-weight: 600; }

.navbar-brand {
  font-weight: 700;
  font-size: 1.3rem;
  color: #ffffff !important;
  letter-spacing: -0.5px; }

.navbar-dark .nav-link {
  color: rgba(255, 255, 255, 0.85) !important; }
  .navbar-dark .nav-link:hover {
    color: #3dd4d0 !important; }

.bg-primary-dark {
  background-color: #1a2332 !important; }

.footer {
  background-color: #ffffff;
  padding: 1rem 0;
  font-size: 0.875rem;
  color: #7f8c8d; }

.hero {
  padding: 3rem 0;
  text-align: center; }
  .hero h1 {
    font-size: 2.5rem;
    margin-bottom: 0.5rem; }
  .hero .lead {
    color: #7f8c8d;
    font-size: 1.2rem;
    margin-bottom: 2rem; }

.btn-accent {
  background-color: #2ab5b2;
  border-color: #2ab5b2;
  color: #ffffff; }
  .btn-accent:hover {
    background-color: #3dd4d0;
    border-color: #3dd4d0;
    color: #ffffff; }

.auth-card-wrapper {
  display: flex;
  justify-content: center;
  padding: 3rem 0; }

.auth-card {
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  padding: 3rem;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); }
  .auth-card h2 {
    margin-bottom: 0.25rem;
    color: #2c3e50; }
  .auth-card .text-muted {
    margin-bottom: 2rem; }
  .auth-card .form-label {
    font-weight: 500;
    color: #2c3e50; }
  .auth-card .form-control {
    border-color: #e1e4e8; }
    .auth-card .form-control:focus {
      border-color: #2ab5b2;
      box-shadow: 0 0 0 0.2rem rgba(42, 181, 178, 0.15); }
  .auth-card .alert-danger {
    font-size: 0.875rem; }

.auth-footer {
  text-align: center;
  margin-top: 2rem;
  margin-bottom: 0;
  font-size: 0.9rem;
  color: #7f8c8d; }
  .auth-footer a {
    color: #2ab5b2;
    font-weight: 500; }
    .auth-footer a:hover {
      color: #3dd4d0; }

.nav-user-email {
  color: #3dd4d0 !important;
  font-weight: 500; }

.nav-logout-btn {
  color: rgba(255, 255, 255, 0.85) !important;
  text-decoration: none;
  padding: 0.5rem 1rem;
  border: none;
  background: none; }
  .nav-logout-btn:hover {
    color: #3dd4d0 !important; }

.accounts-page {
  max-width: 700px;
  margin: 3rem auto; }

.accounts-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem; }
  .accounts-header h2 {
    margin: 0;
    color: #2c3e50; }

.accounts-empty {
  text-align: center;
  padding: 3rem;
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px; }
  .accounts-empty p {
    color: #7f8c8d;
    margin-bottom: 2rem; }

.accounts-list {
  display: flex;
  flex-direction: column;
  gap: 1rem; }

.account-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  padding: 1rem 2rem;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); }

.account-name {
  margin: 0 0 0.25rem;
  color: #2c3e50; }

.account-details {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  font-size: 0.875rem;
  flex-wrap: wrap; }

.account-status {
  font-size: 0.8rem;
  margin-top: 0.25rem; }

.badge-provider {
  background: #2ab5b2;
  color: #ffffff;
  font-size: 0.75rem;
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 500; }

.accounts-form-card {
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  padding: 3rem;
  max-width: 540px;
  margin: 0 auto;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); }
  .accounts-form-card h2 {
    margin-bottom: 0.25rem;
    color: #2c3e50; }
  .accounts-form-card .text-muted {
    margin-bottom: 2rem; }
  .accounts-form-card .form-label {
    font-weight: 500;
    color: #2c3e50; }
  .accounts-form-card .form-control,
  .accounts-form-card .form-select {
    border-color: #e1e4e8; }
    .accounts-form-card .form-control:focus,
    .accounts-form-card .form-select:focus {
      border-color: #2ab5b2;
      box-shadow: 0 0 0 0.2rem rgba(42, 181, 178, 0.15); }

.btn-outline-accent {
  color: #2ab5b2;
  border-color: #2ab5b2;
  background: transparent; }
  .btn-outline-accent:hover {
    background: #2ab5b2;
    color: #ffffff; }

.dashboard-page {
  max-width: 900px;
  margin: 2rem auto; }

.dashboard-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  flex-wrap: wrap;
  gap: 0.5rem; }
  .dashboard-header h2 {
    margin: 0;
    color: #2c3e50; }

.dashboard-tabs {
  display: flex;
  gap: 2px;
  background: #e1e4e8;
  border-radius: 8px;
  padding: 3px; }
  .dashboard-tabs .tab {
    padding: 0.5rem 2rem;
    border-radius: 6px;
    text-decoration: none;
    color: #7f8c8d;
    font-weight: 600;
    font-size: 0.95rem;
    transition: all 0.2s; }
    .dashboard-tabs .tab:hover {
      color: #2c3e50;
      background: rgba(255, 255, 255, 0.7); }
    .dashboard-tabs .tab.active {
      background: #2ab5b2;
      color: #ffffff;
      box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15); }
    .dashboard-tabs .tab .badge {
      background: rgba(0, 0, 0, 0.12);
      border-radius: 10px;
      padding: 2px 8px;
      font-size: 0.8rem;
      margin-left: 4px;
      font-weight: 700; }
    .dashboard-tabs .tab.active .badge {
      background: rgba(255, 255, 255, 0.3); }

.dashboard-filters {
  margin-bottom: 1rem;
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  padding: 0.5rem 1rem; }

.filter-form .filter-row {
  display: flex;
  gap: 0.5rem;
  align-items: flex-end;
  flex-wrap: wrap; }
.filter-form .filter-group {
  display: flex;
  flex-direction: column;
  gap: 2px; }
  .filter-form .filter-group label {
    font-size: 0.75rem;
    color: #7f8c8d;
    font-weight: 500; }
  .filter-form .filter-group .form-select-sm,
  .filter-form .filter-group .form-control-sm {
    min-width: 120px; }
.filter-form .filter-check {
  padding-bottom: 4px; }
  .filter-form .filter-check label {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.85rem;
    cursor: pointer; }

.dashboard-empty {
  text-align: center;
  padding: 3rem;
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  color: #7f8c8d; }
  .dashboard-empty a {
    color: #2ab5b2; }

.bulk-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 0.5rem;
  padding: 0.25rem 0; }
  .bulk-actions .select-all-label {
    font-size: 0.85rem;
    color: #7f8c8d;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px; }

.email-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: #e1e4e8;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  overflow: hidden; }

.email-card {
  display: flex;
  align-items: flex-start;
  background: #ffffff;
  padding: 0.5rem 1rem;
  gap: 0.5rem;
  transition: background 0.15s; }
  .email-card:hover {
    background: #f5f6fa; }
  .email-card.checked-off {
    opacity: 0.5; }
  .email-card.marked-spam {
    opacity: 0.6; }

.email-select {
  padding-top: 4px;
  flex-shrink: 0; }

.email-importance {
  flex-shrink: 0;
  padding-top: 4px;
  width: 44px;
  text-align: center; }

.importance-indicator {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase; }

.importance-dots {
  font-size: 0.85rem;
  color: #2ab5b2;
  letter-spacing: 2px; }
  .importance-dots.level2 {
    color: #6ba8a6; }
  .importance-dots.level3 {
    color: #b0b8bf;
    font-size: 0.8rem; }
  .importance-dots.spam {
    color: #dc3545;
    font-size: 1rem;
    font-weight: bold; }

.importance-label {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  white-space: nowrap; }
  .importance-label.important {
    background: rgba(42, 181, 178, 0.15);
    color: #2ab5b2; }
  .importance-label.likely {
    background: rgba(107, 168, 166, 0.12);
    color: #5a9290; }
  .importance-label.noise-label {
    background: rgba(0, 0, 0, 0.06);
    color: #7f8c8d; }
  .importance-label.spam {
    background: rgba(220, 53, 69, 0.1);
    color: #dc3545; }

.level-1 {
  border-left: 3px solid #2ab5b2; }

.level-2 {
  border-left: 3px solid #6ba8a6; }

.level-3.noise {
  border-left: 3px solid #b0b8bf; }

.level-4.noise {
  border-left: 3px solid #dc3545; }

.email-content {
  flex: 1;
  min-width: 0;
  overflow: hidden; }

.email-sender {
  font-weight: 600;
  font-size: 0.9rem;
  color: #2c3e50;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis; }

.email-address {
  font-weight: 400;
  color: #7f8c8d;
  font-size: 0.8rem; }

.email-subject {
  font-size: 0.9rem;
  color: #2c3e50;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis; }

.email-snippet {
  font-size: 0.8rem;
  color: #7f8c8d;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px; }

.email-meta {
  display: flex;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #7f8c8d;
  margin-top: 4px; }

.email-account {
  background: rgba(42, 181, 178, 0.1);
  color: #2ab5b2;
  padding: 0 6px;
  border-radius: 3px;
  font-weight: 500; }

.email-actions {
  flex-shrink: 0;
  display: flex;
  gap: 4px;
  align-items: flex-start;
  padding-top: 4px; }

.done-label {
  font-size: 0.8rem;
  color: #2ab5b2;
  font-weight: 500;
  padding: 4px 8px; }

.spam-label {
  font-size: 0.8rem;
  color: #dc3545;
  font-weight: 500;
  padding: 4px 8px; }

.btn-outline-danger {
  color: #dc3545;
  border-color: #dc3545; }
  .btn-outline-danger:hover {
    background: #dc3545;
    color: #ffffff; }

.rules-page {
  max-width: 800px;
  margin: 3rem auto; }
  .rules-page h2 {
    color: #2c3e50;
    margin-bottom: 0.25rem; }

.rules-add-form {
  background: #ffffff;
  border: 1px solid #e1e4e8;
  border-radius: 8px;
  padding: 1rem;
  margin-bottom: 1rem; }

.add-rule-row {
  display: flex;
  gap: 0.5rem;
  align-items: center; }
  .add-rule-row .rule-type-select {
    width: 160px;
    flex-shrink: 0; }
  .add-rule-row .form-control-sm {
    flex: 1; }

.rules-preview {
  background: #fef9e7;
  border: 1px solid #f0e5b8;
  border-radius: 6px;
  padding: 0.5rem 1rem;
  margin-bottom: 1rem;
  font-size: 0.85rem;
  color: #2c3e50; }

.rules-columns {
  display: flex;
  gap: 2rem; }
  @media (max-width: 600px) {
    .rules-columns {
      flex-direction: column; } }

.rules-column {
  flex: 1; }
  .rules-column h4 {
    color: #2c3e50;
    margin-bottom: 0.25rem; }
    .rules-column h4 .badge {
      font-size: 0.7rem;
      vertical-align: middle; }

.rule-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: #e1e4e8;
  border: 1px solid #e1e4e8;
  border-radius: 6px;
  overflow: hidden; }

.rule-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #ffffff;
  padding: 0.25rem 0.5rem; }
  .rule-item.good {
    border-left: 3px solid #28a745; }
  .rule-item.bad {
    border-left: 3px solid #dc3545; }

.rule-pattern {
  font-family: monospace;
  font-size: 0.9rem; }

.rule-delete {
  font-size: 1.2rem;
  line-height: 1;
  padding: 0 4px;
  text-decoration: none; }

/*# sourceMappingURL=stylesheet.css.map */
