@import url('https://fonts.googleapis.com/css2?family=Cabinet+Grotesk:wght@400;500;700;800&family=Fira+Code:wght@400;500&display=swap');

:root {
  --pm-bg:          #0f0f13;
  --pm-surface:     #16161d;
  --pm-surface2:    #1c1c26;
  --pm-border:      #26263a;
  --pm-border2:     #32324a;
  --pm-text:        #eeeef5;
  --pm-muted:       #7070a0;
  --pm-subtle:      #4a4a70;
  --pm-accent:      #7c6af7;
  --pm-accent2:     #c084fc;
  --pm-green:       #34d399;
  --pm-green-bg:    rgba(52,211,153,0.08);
  --pm-red:         #f87171;
  --pm-yellow:      #fbbf24;
  --pm-radius:      16px;
  --pm-radius-sm:   10px;
  --pm-shadow:      0 4px 24px rgba(0,0,0,0.4);
}


body {
  background-color: var(--pm-bg) !important;
  color: var(--pm-text) !important;
  font-family: 'Cabinet Grotesk', sans-serif !important;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: '';
  position: fixed;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(124,106,247,0.07) 0%, transparent 70%);
  top: -200px; left: -100px;
  pointer-events: none;
  z-index: 0;
}

body::after {
  content: '';
  position: fixed;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(192,132,252,0.05) 0%, transparent 70%);
  bottom: -100px; right: -100px;
  pointer-events: none;
  z-index: 0;
}


h1, h2, h3, h4, h5, h6 {
  font-family: 'Cabinet Grotesk', sans-serif !important;
  font-weight: 800 !important;
  color: var(--pm-text) !important;
  letter-spacing: -0.5px;
}


.form-group label.h3 {
  font-size: 1.25rem;
  font-weight: 700 !important;
  color: var(--pm-text) !important;
  margin-bottom: 10px;
  display: block;
}


.input-group {
  border-radius: var(--pm-radius-sm);
  overflow: hidden;
}


.form-control,
.form-control-lg {
  background-color: var(--pm-surface2) !important;
  border: 1.5px solid var(--pm-border) !important;
  border-right: none !important;
  color: var(--pm-text) !important;
  font-family: 'Fira Code', monospace !important;
  font-size: 18px !important;
  font-weight: 500;
  letter-spacing: 3px;
  caret-color: var(--pm-accent);
  border-radius: var(--pm-radius-sm) 0 0 var(--pm-radius-sm) !important;
  transition: border-color 0.2s, box-shadow 0.2s;
  padding: 14px 16px !important;
}

.form-control:focus,
.form-control-lg:focus {
  background-color: var(--pm-surface) !important;
  border-color: var(--pm-accent) !important;
  box-shadow: 0 0 0 4px rgba(124,106,247,0.12) !important;
  color: var(--pm-text) !important;
  outline: none;
}

.form-control::placeholder {
  color: var(--pm-border2) !important;
  letter-spacing: 1px;
  font-weight: 400;
}

.btn.btn-outline-secondary {
  background-color: var(--pm-surface2) !important;
  border: 1.5px solid var(--pm-border) !important;
  border-left: none !important;
  color: var(--pm-muted) !important;
  font-size: 16px;
  padding: 0 16px;
  border-radius: 0 var(--pm-radius-sm) var(--pm-radius-sm) 0 !important;
  transition: background 0.2s, color 0.2s;
}

.btn.btn-outline-secondary:hover,
.btn.btn-outline-secondary:focus {
  background-color: var(--pm-border) !important;
  color: var(--pm-text) !important;
  box-shadow: none !important;
}


.form-group small.text-muted {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: 'Fira Code', monospace;
  font-size: 11px !important;
  color: var(--pm-green) !important;
  background: var(--pm-green-bg);
  border: 1px solid rgba(52,211,153,0.15);
  border-radius: 6px;
  padding: 6px 10px;
  margin-top: 10px;
}


.card {
  background-color: var(--pm-surface) !important;
  border: 1px solid var(--pm-border) !important;
  border-radius: var(--pm-radius) !important;
  box-shadow: var(--pm-shadow) !important;
  transition: border-color 0.2s;
  position: relative;
  z-index: 1;
}

.card:hover {
  border-color: var(--pm-border2) !important;
}

.card-body {
  background: transparent !important;
  padding: 24px !important;
}


.card-title {
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--pm-text) !important;
}

#strengthText {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 12px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 99px;
  letter-spacing: 0.3px;
  vertical-align: middle;
  transition: all 0.3s;
}

.progress {
  background-color: var(--pm-surface2) !important;
  border-radius: 99px !important;
  height: 8px !important;
  overflow: hidden;
  border: none !important;
  margin-top: 12px !important;
}

.progress-bar {
    border-radius: 99px !important;
    display: block;
    height: 100%;
    background-color: var(--pm-accent);
    transition: width 0.6s cubic-bezier(0.34,1.56,0.64,1), background-color 0.4s !important;
}


#suggestions {
  font-size: 13px;
  color: var(--pm-muted);
  line-height: 1.6;
  margin-top: 10px;
}

.list-group-flush {
  border: 1px solid var(--pm-border) !important;
  border-radius: var(--pm-radius-sm) !important;
  overflow: hidden;
}

.list-group-item {
  background-color: var(--pm-surface2) !important;
  border-color: var(--pm-border) !important;
  color: var(--pm-text) !important;
  font-size: 14px;
  font-weight: 500;
  padding: 13px 16px !important;
  transition: background 0.15s;
}

.list-group-item:hover {
  background-color: var(--pm-surface) !important;
}


.list-group-item .badge {
  font-family: 'Fira Code', monospace;
  font-size: 13px;
  font-weight: 500;
  padding: 5px 10px;
  border-radius: 99px;
  min-width: 40px;
  text-align: center;
}

.badge.bg-primary {
  background-color: rgba(124,106,247,0.15) !important;
  color: var(--pm-accent2) !important;
  border: 1px solid rgba(124,106,247,0.25) !important;
}

.badge.bg-success {
  background-color: rgba(52,211,153,0.1) !important;
  color: var(--pm-green) !important;
  border: 1px solid rgba(52,211,153,0.2) !important;
}

.badge.bg-info {
  background-color: rgba(96,165,250,0.1) !important;
  color: #60a5fa !important;
  border: 1px solid rgba(96,165,250,0.2) !important;
}

.badge.bg-danger {
  background-color: rgba(248,113,113,0.1) !important;
  color: var(--pm-red) !important;
  border: 1px solid rgba(248,113,113,0.2) !important;
}

.badge.bg-secondary {
  background-color: var(--pm-surface2) !important;
  color: var(--pm-muted) !important;
  border: 1px solid var(--pm-border) !important;
}

.badge.bg-warning {
  background-color: rgba(251,191,36,0.1) !important;
  color: var(--pm-yellow) !important;
  border: 1px solid rgba(251,191,36,0.2) !important;
}


.card.border-warning {
  border-color: rgba(251,191,36,0.25) !important;
}

.card.border-warning:hover {
  border-color: rgba(251,191,36,0.5) !important;
}

.card-header.bg-warning {
  background-color: rgba(251,191,36,0.08) !important;
  border-bottom: 1px solid rgba(251,191,36,0.15) !important;
  padding: 16px 24px !important;
}

.card-header.bg-warning h5 {
  color: var(--pm-yellow) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

/* celle crack times */
.card.border-warning .fw-bold {
  font-size: 11px;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--pm-muted);
  margin-bottom: 4px;
}

.card.border-warning #crackTime1,
.card.border-warning #crackTime2,
.card.border-warning #crackTime3,
.card.border-warning #crackTime4 {
  font-family: 'Fira Code', monospace;
  font-size: 17px !important;
  font-weight: 500;
  color: var(--pm-text) !important;
  display: block;
  margin: 4px 0;
}

.card.border-warning small.text-xs {
  font-family: 'Fira Code', monospace;
  font-size: 10px;
  color: var(--pm-subtle) !important;
  letter-spacing: 0.3px;
}


.text-muted {
  color: var(--pm-muted) !important;
}


.bg-light {
  background-color: var(--pm-bg) !important;
}


::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--pm-bg); }
::-webkit-scrollbar-thumb { background: var(--pm-border2); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--pm-subtle); }


@keyframes pm-fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.card {
  animation: pm-fadeUp 0.45s ease both;
}


header.row {
  position: relative;
  z-index: 1;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--pm-border);
  margin-bottom: 32px !important;
}

h1.display-5 {
  font-family: 'Cabinet Grotesk', sans-serif !important;
  font-weight: 800 !important;
  font-size: clamp(32px, 5vw, 48px) !important;
  letter-spacing: -1.5px;
  color: var(--pm-text) !important;
  margin-bottom: 8px;
}

header .h4.text-muted {
  font-family: 'Cabinet Grotesk', sans-serif !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  color: var(--pm-muted) !important;
  line-height: 1.6;
  display: block;
}


.accordion-item {
  background-color: var(--pm-surface2) !important;
  border: 1px solid var(--pm-border) !important;
  border-radius: var(--pm-radius-sm) !important;
  margin-bottom: 6px;
  overflow: hidden;
}

.accordion-item:last-child {
  margin-bottom: 0;
}

.accordion-header {
  margin: 0;
}

.accordion-button {
  background-color: var(--pm-surface2) !important;
  color: var(--pm-text) !important;
  font-family: 'Cabinet Grotesk', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  padding: 16px 20px !important;
  border: none !important;
  box-shadow: none !important;
  transition: background 0.2s, color 0.2s;
}

.accordion-button:not(.collapsed) {
  background-color: var(--pm-surface) !important;
  color: var(--pm-accent2) !important;
  box-shadow: none !important;
}

.accordion-button:hover {
  background-color: var(--pm-surface) !important;
}

.accordion-button::after {
  filter: invert(60%) sepia(20%) saturate(500%) hue-rotate(200deg);
}

.accordion-button:not(.collapsed)::after {
  filter: invert(70%) sepia(40%) saturate(600%) hue-rotate(240deg);
}

.accordion-collapse {
  border-top: 1px solid var(--pm-border);
}

.password-frequency-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.password-frequency-stat {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.375rem;
}

.password-frequency-stat-label {
  font-family: 'Fira Code', monospace;
  font-size: 0.6875rem;
  letter-spacing: 0.025rem;
  text-transform: uppercase;
  color: var(--pm-muted);
}

.password-frequency-chart {
  display: grid;
  gap: 0.75rem;
}

.password-frequency-row {
  display: grid;
  grid-template-columns: minmax(3.5rem, 4.5rem) minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: center;
}

.password-frequency-label {
  font-family: 'Fira Code', monospace;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--pm-text);
  white-space: nowrap;
}

.password-frequency-track {
  overflow: hidden;
  height: 0.875rem;
  background: linear-gradient(90deg, rgba(124,106,247,0.12), rgba(192,132,252,0.08));
  border: 0.0625rem solid rgba(124,106,247,0.12);
  border-radius: 999rem;
}

.password-frequency-bar {
  height: 100%;
  min-width: 0.375rem;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--pm-accent), var(--pm-accent2));
}

.password-frequency-value {
  min-width: 4.5rem;
  text-align: right;
  font-family: 'Fira Code', monospace;
  font-size: 0.8125rem;
  color: var(--pm-muted);
  font-variant-numeric: tabular-nums;
}

@media (max-width: 48rem) {
  .password-frequency-header {
    flex-direction: column;
  }

  .password-frequency-stat {
    align-items: flex-start;
  }

  .password-frequency-row {
    grid-template-columns: minmax(3rem, 4rem) minmax(0, 1fr);
  }

  .password-frequency-value {
    grid-column: 2;
    min-width: 0;
  }
}

.accordion-body {
  background-color: var(--pm-surface) !important;
  color: var(--pm-muted) !important;
  font-size: 13px !important;
  line-height: 1.7;
  padding: 16px 20px !important;
}

.accordion-body strong {
  color: var(--pm-text);
  font-weight: 600;
}

.accordion-body a {
  color: var(--pm-accent2);
  text-decoration: none;
}

.accordion-body a:hover {
  text-decoration: underline;
}

.title-omatic {
  background: linear-gradient(135deg, var(--pm-accent), var(--pm-accent2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-style: italic;
}
