/* Voidmail Pro — style.css
   Aesthetic direction: broken late-90s/early-00s webmail.
   Yahoo Mail × Hotmail × ISP portal energy.
   Intentionally clunky. Deliberately dated. Still mobile-usable.
*/

@import url('https://fonts.googleapis.com/css2?family=VT323&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --silver:     #d4d0c8;
  --silver-dk:  #aca899;
  --silver-lt:  #f0ece4;
  --navy:       #000080;
  --navy-lt:    #1c3a8a;
  --blue-link:  #0000cc;
  --white:      #ffffff;
  --black:      #000000;
  --gray:       #808080;
  --red-warn:   #cc0000;
  --green-ok:   #006600;
  --yellow-sys: #ffffcc;
  --border-out: 2px outset #ffffff;
  --border-in:  2px inset  #808080;
  --border-flat: 1px solid #808080;
}

html, body {
  height: 100%;
  background: var(--silver);
  font-family: Verdana, Arial, "Helvetica Neue", sans-serif;
  font-size: 11px;
  color: var(--black);
}

/* ── UTILITY ─────────────────────────────────────────── */
.hidden { display: none !important; }
a { color: var(--blue-link); text-decoration: underline; cursor: pointer; }
a:hover { color: var(--red-warn); }
hr { border: none; border-top: 1px solid var(--gray); margin: 4px 0; }

/* ── WINDOW CHROME ────────────────────────────────────── */
.vm-titlebar {
  background: linear-gradient(90deg, var(--navy) 0%, var(--navy-lt) 100%);
  color: var(--white);
  font-family: 'VT323', 'Courier New', monospace;
  font-size: 18px;
  letter-spacing: 1px;
  padding: 3px 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  user-select: none;
}
.vm-titlebar .logo-text { font-size: 20px; }
.vm-titlebar .user-info { font-family: Verdana, Arial, sans-serif; font-size: 10px; text-align: right; }
.vm-titlebar .user-info a { color: #aaccff; }

/* ── AD ZONES ─────────────────────────────────────────── */
.vm-ad-zone {
  background: var(--silver-lt);
  border: var(--border-in);
  text-align: center;
  padding: 2px;
  color: var(--gray);
  font-size: 10px;
  overflow: hidden;
}
.vm-ad-zone .ad-label {
  font-size: 9px;
  color: var(--gray);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 2px;
}
.vm-ad-banner {
  width: 100%;
  height: 62px;
}
.vm-ad-sidebar {
  width: 100%;
  min-height: 120px;
}

/* ── LAYOUT ───────────────────────────────────────────── */
.vm-shell {
  display: flex;
  flex-direction: column;
  height: 100vh;
  max-width: 1024px;
  margin: 0 auto;
  border-left: 1px solid var(--gray);
  border-right: 1px solid var(--gray);
}
.vm-body {
  display: flex;
  flex: 1;
  overflow: hidden;
}
.vm-sidebar {
  width: 140px;
  min-width: 140px;
  background: var(--silver);
  border-right: var(--border-flat);
  padding: 4px 2px;
  overflow-y: auto;
  flex-shrink: 0;
}
.vm-main {
  flex: 1;
  background: var(--white);
  border: var(--border-in);
  overflow-y: auto;
  padding: 0;
}

/* ── SIDEBAR FOLDERS ──────────────────────────────────── */
.vm-folder-header {
  background: var(--navy);
  color: var(--white);
  font-size: 10px;
  font-weight: bold;
  padding: 2px 4px;
  margin-bottom: 2px;
}
.vm-folder-list { list-style: none; margin-bottom: 8px; }
.vm-folder-list li { padding: 0; }
.vm-folder-list a,
.vm-folder-list span {
  display: block;
  padding: 2px 4px;
  font-size: 11px;
  text-decoration: none;
  color: var(--black);
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.vm-folder-list a:hover { background: var(--navy); color: var(--white); }
.vm-folder-list .folder-disabled {
  color: var(--gray);
  cursor: default;
}
.vm-folder-list .folder-disabled:hover { background: none; color: var(--gray); }
.vm-folder-list .folder-active { background: var(--navy); color: var(--white); }
.vm-folder-badge {
  float: right;
  background: var(--red-warn);
  color: var(--white);
  border-radius: 2px;
  font-size: 9px;
  padding: 0 3px;
  font-weight: bold;
}
.vm-folder-coming-soon {
  font-size: 9px;
  color: var(--gray);
  display: block;
}

/* ── TOOLBAR ──────────────────────────────────────────── */
.vm-toolbar {
  background: var(--silver);
  border-bottom: var(--border-flat);
  padding: 3px 4px;
  display: flex;
  gap: 3px;
  align-items: center;
  flex-wrap: wrap;
}
.vm-toolbar-sep {
  width: 1px;
  height: 20px;
  background: var(--gray);
  margin: 0 2px;
}

/* ── BUTTONS ──────────────────────────────────────────── */
.vm-btn {
  background: var(--silver);
  border: var(--border-out);
  font-family: Verdana, Arial, sans-serif;
  font-size: 11px;
  padding: 2px 10px;
  cursor: pointer;
  color: var(--black);
  white-space: nowrap;
}
.vm-btn:hover { background: var(--silver-lt); }
.vm-btn:active { border-style: inset; }
.vm-btn:disabled { color: var(--gray); cursor: default; }
.vm-btn-primary {
  background: var(--navy);
  color: var(--white);
  border: var(--border-out);
}
.vm-btn-primary:hover { background: var(--navy-lt); }
.vm-btn-danger { background: #cc0000; color: var(--white); }
.vm-btn-danger:hover { background: #990000; }
.vm-btn-big {
  font-size: 13px;
  padding: 6px 18px;
  font-weight: bold;
}

/* ── SYSTEM NOTICES ───────────────────────────────────── */
.vm-notice {
  background: var(--yellow-sys);
  border: 1px solid #999900;
  padding: 4px 8px;
  font-size: 11px;
  margin: 4px;
}
.vm-notice-err {
  background: #ffeeee;
  border-color: var(--red-warn);
  color: var(--red-warn);
}
.vm-notice-ok {
  background: #eeffee;
  border-color: var(--green-ok);
  color: var(--green-ok);
}

/* ── STATUS BAR ───────────────────────────────────────── */
.vm-statusbar {
  background: var(--silver);
  border-top: var(--border-flat);
  padding: 2px 6px;
  font-size: 10px;
  color: var(--gray);
  display: flex;
  justify-content: space-between;
  min-height: 18px;
}

/* ── INBOX LIST ───────────────────────────────────────── */
.vm-inbox-header {
  background: var(--silver);
  border-bottom: var(--border-flat);
  padding: 4px 8px;
  font-weight: bold;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.vm-msg-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
}
.vm-msg-table th {
  background: var(--silver);
  border: var(--border-flat);
  padding: 2px 6px;
  text-align: left;
  font-size: 10px;
}
.vm-msg-table td {
  padding: 3px 6px;
  border-bottom: 1px solid #e0dcd4;
  vertical-align: top;
  cursor: pointer;
}
.vm-msg-table tr:hover td { background: #dde8ff; }
.vm-msg-table .unread td { font-weight: bold; }
.vm-msg-table .vm-subject { max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vm-msg-table .vm-preview { color: var(--gray); font-weight: normal !important; max-width: 300px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vm-msg-table .vm-age { color: var(--gray); white-space: nowrap; }
.vm-msg-table .vm-replies { color: var(--gray); text-align: center; }

.vm-empty-inbox {
  padding: 20px;
  text-align: center;
  color: var(--gray);
}
.vm-empty-inbox .vm-void-art {
  font-family: 'VT323', monospace;
  font-size: 36px;
  color: var(--silver-dk);
  margin-bottom: 8px;
}

/* ── THREAD VIEW ──────────────────────────────────────── */
.vm-thread-header {
  background: var(--silver);
  border-bottom: var(--border-flat);
  padding: 4px 8px;
}
.vm-thread-subject {
  font-weight: bold;
  font-size: 13px;
  margin-bottom: 2px;
}
.vm-thread-meta { font-size: 10px; color: var(--gray); }
.vm-thread-body { padding: 8px; }

.vm-entry {
  border: var(--border-in);
  background: var(--white);
  padding: 6px 8px;
  margin-bottom: 6px;
  font-size: 12px;
  line-height: 1.6;
}
.vm-entry-time {
  font-size: 10px;
  color: var(--gray);
  margin-bottom: 4px;
  font-style: italic;
}
.vm-entry-body { white-space: pre-wrap; word-break: break-word; }

.vm-reply-area {
  border-top: var(--border-flat);
  background: var(--silver-lt);
  padding: 8px;
}
.vm-reply-area label { display: block; font-size: 11px; font-weight: bold; margin-bottom: 4px; }
.vm-reply-textarea {
  width: 100%;
  border: var(--border-in);
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  padding: 4px;
  resize: vertical;
  min-height: 80px;
  background: var(--white);
}
.vm-char-count { font-size: 10px; color: var(--gray); text-align: right; margin-top: 2px; }
.vm-reply-actions { display: flex; gap: 4px; margin-top: 6px; flex-wrap: wrap; }

/* ── COMPOSE ──────────────────────────────────────────── */
.vm-compose {
  padding: 8px;
}
.vm-compose-fields { margin-bottom: 8px; }
.vm-compose-row {
  display: flex;
  align-items: center;
  margin-bottom: 3px;
  gap: 4px;
}
.vm-compose-row label { width: 60px; font-weight: bold; font-size: 11px; flex-shrink: 0; }
.vm-compose-row .vm-fake-field {
  flex: 1;
  border: var(--border-in);
  background: var(--silver);
  padding: 2px 4px;
  font-size: 11px;
  color: var(--gray);
  font-style: italic;
}
.vm-subject-input, .vm-body-textarea {
  width: 100%;
  border: var(--border-in);
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  padding: 4px;
  background: var(--white);
}
.vm-body-textarea {
  min-height: 200px;
  resize: vertical;
}
.vm-compose-actions { display: flex; gap: 4px; flex-wrap: wrap; }

/* ── AUTH / LANDING ───────────────────────────────────── */
.vm-landing {
  min-height: 100vh;
  background: var(--silver);
  display: flex;
  flex-direction: column;
}
.vm-landing-header {
  background: linear-gradient(90deg, var(--navy) 60%, #1c3a8a 100%);
  padding: 6px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.vm-landing-logo {
  font-family: 'VT323', 'Courier New', monospace;
  font-size: 28px;
  color: var(--white);
  letter-spacing: 2px;
}
.vm-landing-logo span { color: #aaccff; }
.vm-landing-tagline {
  font-size: 10px;
  color: #8aaabb;
  font-style: italic;
}

.vm-landing-body {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 16px;
  gap: 16px;
  flex-wrap: wrap;
}

.vm-landing-card {
  background: var(--white);
  border: var(--border-in);
  width: 100%;
  max-width: 460px;
}
.vm-landing-card-title {
  background: var(--navy);
  color: var(--white);
  font-family: 'VT323', monospace;
  font-size: 16px;
  padding: 2px 8px;
  letter-spacing: 1px;
}
.vm-landing-card-body { padding: 12px; }

.vm-hero-headline {
  font-family: 'VT323', 'Courier New', monospace;
  font-size: 28px;
  line-height: 1.1;
  color: var(--navy);
  margin-bottom: 8px;
}
.vm-hero-sub {
  font-size: 12px;
  line-height: 1.7;
  color: #333;
  margin-bottom: 12px;
}
.vm-cta-row { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }

.vm-system-notice {
  background: var(--yellow-sys);
  border: 1px solid #aaa800;
  padding: 6px 8px;
  font-size: 11px;
  line-height: 1.5;
  margin-bottom: 8px;
}
.vm-system-notice strong { display: block; margin-bottom: 2px; }

.vm-counter {
  font-family: 'VT323', monospace;
  font-size: 18px;
  text-align: center;
  background: var(--black);
  color: #00ff00;
  padding: 4px 8px;
  letter-spacing: 3px;
  margin-bottom: 8px;
}
.vm-counter .counter-label { font-size: 11px; color: #aaa; letter-spacing: 0; font-family: Verdana, sans-serif; }

.vm-blink { animation: blink 1.2s step-end infinite; }
@keyframes blink { 50% { opacity: 0; } }

.vm-new-badge {
  background: var(--red-warn);
  color: var(--white);
  font-size: 10px;
  font-weight: bold;
  padding: 1px 4px;
  margin-left: 4px;
}

/* ── AUTH FORM ────────────────────────────────────────── */
.vm-auth-form { padding: 12px; }
.vm-auth-form h3 {
  background: var(--navy);
  color: var(--white);
  margin: -12px -12px 10px -12px;
  padding: 4px 8px;
  font-size: 12px;
}
.vm-form-row { margin-bottom: 8px; }
.vm-form-row label { display: block; font-size: 11px; font-weight: bold; margin-bottom: 3px; }
.vm-input {
  width: 100%;
  border: var(--border-in);
  padding: 3px 5px;
  font-family: Verdana, Arial, sans-serif;
  font-size: 12px;
  background: var(--white);
}
.vm-auth-note { font-size: 10px; color: var(--gray); margin-top: 4px; }

/* ── LOADING ──────────────────────────────────────────── */
.vm-loading {
  text-align: center;
  padding: 20px;
  color: var(--gray);
  font-style: italic;
}
.vm-spinner {
  display: inline-block;
  font-family: 'VT323', monospace;
  font-size: 20px;
  animation: spin-chars 0.8s steps(4) infinite;
}
@keyframes spin-chars {
  0%  { content: '|'; }
  25% { content: '/'; }
  50% { content: '-'; }
  75% { content: '\\'; }
}

/* ── MOBILE ───────────────────────────────────────────── */
@media (max-width: 600px) {
  .vm-sidebar { width: 110px; min-width: 110px; }
  .vm-landing-body { padding: 8px; }
  .vm-hero-headline { font-size: 22px; }
  .vm-titlebar .logo-text { font-size: 16px; }
  .vm-msg-table .vm-preview { display: none; }
  .vm-ad-banner { height: 50px; }
}
