/* ═══════════════════════════════════════════════════════════════════
   Monopeak Mail — Classical Rouge / Rouge Impérial
   Palette: Rouge · Or · Parchemin · Ivoire
   ═══════════════════════════════════════════════════════════════════ */

:root {
  --bg-parchment:  #F5F0E8;
  --bg-cream:      #FDFAF4;
  --bg-white:      #FFFFFF;
  --bg-sidebar:    #3D1F1F;
  --bg-sidebar-hi: #4A2828;
  --bg-overlay:    rgba(30,12,12,0.72);

  --rouge:         #8B1A2B;
  --rouge-dark:    #6E1522;
  --rouge-light:   #A8203A;
  --rouge-dim:     rgba(139,26,43,0.12);
  --rouge-soft:    rgba(139,26,43,0.05);
  --rouge-glow:    0 0 28px rgba(139,26,43,0.25);

  --gold:          #B8860B;
  --gold-dark:     #936B08;
  --gold-light:    #D4A853;
  --gold-dim:      rgba(184,134,11,0.15);
  --gold-soft:     rgba(184,134,11,0.06);
  --gold-glow:     0 0 18px rgba(184,134,11,0.2);

  --text:          #2C1810;
  --text-2:        #4A3028;
  --text-3:        #6B5048;
  --text-4:        #8C7368;
  --text-inv:      #F5F0E8;

  --bd:            #E0D6C8;
  --bd-hi:         #C4B8A8;
  --bd-gold:       rgba(184,134,11,0.25);

  --green:  #4A8C4A;
  --red:    #A8203A;
  --orange: #B87A20;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }

html, body { height:100%; overflow:hidden; }

body {
  background: var(--bg-parchment);
  color: var(--text);
  font-family: 'Georgia','Times New Roman',serif;
  font-size: 15px;
  line-height: 1.6;
}

::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bd); }
::-webkit-scrollbar-thumb { background:var(--bd-hi); border-radius:3px; }

/* ═══════════════ AUTH ═══════════════════════════════════════════ */
.auth-wrap {
  min-height:100vh; min-height:100dvh;
  display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(139,26,43,0.10) 0%, transparent 70%),
    radial-gradient(ellipse 40% 30% at 50% 100%, rgba(184,134,11,0.06) 0%, transparent 70%),
    var(--bg-parchment);
  padding:20px;
}

.auth-card {
  background: var(--bg-white);
  border: 1px solid var(--bd-hi);
  border-radius: 4px;
  width:100%; max-width:400px;
  padding: 44px 36px 36px;
  position:relative;
  box-shadow:
    0 0 0 1px rgba(184,134,11,0.08),
    0 16px 48px rgba(44,24,16,0.12),
    0 2px 6px rgba(44,24,16,0.06);
}

.auth-card::before,
.auth-card::after {
  content:'\25C6'; position:absolute; color:var(--gold); opacity:0.35; font-size:9px; top:12px;
}
.auth-card::before { left:16px; }
.auth-card::after  { right:16px; }

.auth-top-bar {
  position:absolute; top:0; left:40px; right:40px; height:3px;
  background:linear-gradient(90deg, transparent, var(--rouge), var(--gold), var(--rouge), transparent);
}

.auth-emblem { text-align:center; margin-bottom:6px; }
.auth-emblem-icon {
  display:inline-flex; align-items:center; justify-content:center;
  width:56px; height:56px;
  border:1px solid var(--gold-dim); border-radius:4px;
  font-size:26px; color:var(--rouge);
  background: var(--bg-cream);
  box-shadow: var(--rouge-glow);
  position:relative;
}
.auth-emblem-icon::before {
  content:''; position:absolute; inset:3px;
  border:1px solid rgba(184,134,11,0.15); border-radius:2px; pointer-events:none;
}

.auth-title {
  text-align:center; font-size:22px; font-weight:normal;
  color:var(--text); letter-spacing:2px; margin-bottom:2px; margin-top:16px;
}
.auth-subtitle {
  text-align:center; font-size:11px; color:var(--text-3);
  letter-spacing:3px; text-transform:uppercase; margin-bottom:28px;
}

.auth-steps {
  display:flex; align-items:center; justify-content:center; gap:8px; margin-bottom:24px;
}
.auth-step {
  width:28px; height:2px; background:var(--bd); border-radius:1px; transition:background .4s;
}
.auth-step.active { background:var(--rouge); }
.auth-step.done   { background:var(--gold); }

.auth-field { margin-bottom:14px; position:relative; }
.auth-field-label {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text-3); margin-bottom:6px; display:block;
}

.auth-input-wrap {
  display:flex; align-items:center;
  background:var(--bg-cream); border:1px solid var(--bd);
  border-radius:4px; transition:border-color .25s,box-shadow .25s;
}
.auth-input-wrap:focus-within {
  border-color:var(--rouge); box-shadow:0 0 0 3px var(--rouge-dim);
}

.auth-input-icon { padding:0 12px; color:var(--text-4); font-size:15px; flex-shrink:0; }
.auth-input {
  flex:1; background:transparent; border:none; outline:none;
  color:var(--text); font-family:'Georgia',serif; font-size:15px;
  padding:13px 12px 13px 0; width:100%; user-select:text; -webkit-user-select:text;
}
.auth-input-ltr { direction:ltr; text-align:left; unicode-bidi:plaintext; }
.auth-input-wrap .auth-input-ltr { padding:13px 0 13px 12px; }
.auth-input::placeholder { color:var(--text-4); }
.auth-input:disabled { opacity:0.5; }

.auth-domain {
  padding:0 12px; color:var(--text-3); font-size:13px; flex-shrink:0; white-space:nowrap;
}

.pin-eye {
  background:none; border:none; cursor:pointer; padding:0 12px;
  color:var(--text-4); font-size:14px; transition:color .2s;
}
.pin-eye:hover { color:var(--rouge); }

.auth-note { font-size:11px; color:var(--text-4); margin-top:4px; letter-spacing:.5px; }
.auth-forgot { font-size:12px; color:var(--rouge); }

.auth-recovery-banner {
  font-size:12px; color:var(--text-2); background:var(--rouge-soft);
  border:1px solid var(--rouge-dim); padding:10px 12px; margin-bottom:12px; line-height:1.5;
}

.settings-block {
  padding:18px 22px; border-bottom:1px solid var(--bd);
  background:var(--bg-white);
}
.settings-title {
  font-size:13px; color:var(--rouge); letter-spacing:1px; margin-bottom:12px;
}
.settings-row {
  display:flex; justify-content:space-between; gap:12px;
  font-size:12px; color:var(--text-2); margin-bottom:8px;
}
.settings-q {
  font-size:14px; color:var(--text); padding:12px;
  background:var(--bg-cream); border:1px solid var(--bd); margin:8px 0; line-height:1.6;
}

.auth-status {
  min-height:20px; font-size:12px; letter-spacing:.5px;
  margin-bottom:14px; text-align:center; transition:all .25s; border-radius:4px;
}
.auth-status.info    { color:var(--text-2); }
.auth-status.success { color:var(--gold-dark); }
.auth-status.error   {
  color:var(--rouge); background:var(--rouge-soft);
  padding:8px; border:1px solid var(--rouge-dim);
}

/* ══════════ BUTTONS ═══════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:12px 20px; border:none; border-radius:4px; cursor:pointer;
  font-family:'Georgia',serif; font-size:13px; letter-spacing:1.5px;
  text-transform:uppercase; transition:all .25s; white-space:nowrap;
}
.btn:disabled { opacity:0.4; cursor:not-allowed; }

.btn-primary {
  background:linear-gradient(135deg, var(--rouge) 0%, var(--rouge-dark) 100%);
  color:#fff; border:1px solid var(--rouge-light); width:100%;
  box-shadow:0 4px 16px rgba(139,26,43,0.25);
}
.btn-primary:hover:not(:disabled) {
  background:linear-gradient(135deg, var(--rouge-light) 0%, var(--rouge) 100%);
  box-shadow:var(--rouge-glow); transform:translateY(-1px);
}
.btn-primary:active:not(:disabled) { transform:translateY(0); }

.btn-link {
  background:none; color:var(--rouge); border:1px solid transparent; font-size:12px;
}
.btn-link:hover { color:var(--rouge-light); border-color:var(--rouge-dim); }

.btn-ghost {
  background:var(--bg-cream); border:1px solid var(--bd);
  color:var(--text-2); font-size:12px; padding:8px 14px;
}
.btn-ghost:hover:not(:disabled) { border-color:var(--rouge); color:var(--rouge); }

.btn-icon {
  background:none; border:1px solid transparent; color:var(--text-3);
  cursor:pointer; padding:7px; border-radius:4px;
  display:inline-flex; align-items:center; justify-content:center;
  transition:all .2s; font-size:14px;
}
.btn-icon:hover { color:var(--rouge); border-color:var(--bd); }
.btn-icon.active { color:var(--rouge); }
.btn-icon.danger:hover { color:var(--rouge-light); border-color:var(--rouge-dim); }

/* ═══════════════ SHELL ═════════════════════════════════════════ */
#app { height:100vh; height:100dvh; display:flex; flex-direction:column; overflow:hidden; }

.shell {
  display:flex; height:100%; overflow:hidden;
  background:var(--bg-parchment);
}

.sb-overlay {
  display:none; position:fixed; inset:0; background:var(--bg-overlay);
  z-index:40; backdrop-filter:blur(2px);
}
.sb-overlay.on { display:block; }

/* ── Sidebar ── */
.sidebar {
  width:240px; flex-shrink:0;
  background:linear-gradient(180deg, var(--bg-sidebar) 0%, #2F1515 100%);
  border-right:1px solid rgba(184,134,11,0.15);
  display:flex; flex-direction:column; overflow:hidden; position:relative;
}
.sidebar::after {
  content:''; position:absolute; top:0; right:0; bottom:0; width:1px;
  background:linear-gradient(180deg, transparent, var(--gold), var(--rouge-light), var(--gold), transparent);
  opacity:0.3;
}

.sb-account { padding:18px 16px 14px; border-bottom:1px solid rgba(184,134,11,0.12); }
.sb-acct-row { display:flex; align-items:center; gap:10px; }
.sb-avatar {
  width:36px; height:36px; border-radius:4px;
  background:linear-gradient(135deg, var(--rouge) 0%, var(--rouge-dark) 100%);
  border:1px solid var(--rouge-light);
  display:flex; align-items:center; justify-content:center;
  font-size:15px; font-weight:bold; color:#fff; flex-shrink:0;
  box-shadow:var(--rouge-glow);
}
.sb-uname { font-size:13px; color:#E8D5C0; font-weight:bold; letter-spacing:.5px; }
.sb-addr  { font-size:10px; color:#A89080; letter-spacing:.3px; margin-top:1px; }
.sb-logout {
  background:none; border:none; cursor:pointer; color:#A89080;
  font-size:15px; margin-right:-4px; transition:color .2s;
}
.sb-logout:hover { color:#D4956B; }

.sb-compose {
  display:flex; align-items:center; gap:9px;
  margin:14px 12px 8px; padding:10px 14px;
  background:var(--rouge-soft); border:1px solid var(--rouge-dim);
  border-radius:4px; color:#E8D5C0;
  font-family:'Georgia',serif; font-size:12px; letter-spacing:1.5px;
  text-transform:uppercase; cursor:pointer; transition:all .25s;
}
.sb-compose:hover {
  background:var(--rouge-dim); border-color:var(--rouge);
  box-shadow:var(--rouge-glow); color:#fff;
}

.sb-section {
  font-size:9px; letter-spacing:3px; text-transform:uppercase;
  color:#8C7060; padding:12px 16px 6px;
}

.folder-row {
  display:flex; align-items:center; gap:10px; padding:9px 16px;
  cursor:pointer; font-size:13px; color:#C8B0A0;
  transition:all .2s; border-right:2px solid transparent; letter-spacing:.3px; position:relative;
}
.folder-row:hover { background:rgba(255,255,255,0.04); color:#E8D5C0; }
.folder-row.on {
  background:var(--rouge-soft); color:#fff; border-right-color:var(--rouge);
}
.folder-row.hot .fc { background:var(--rouge); }
.fi { font-size:14px; width:20px; text-align:center; }
.fl { flex:1; }
.fc {
  background:rgba(255,255,255,0.12); color:#E8D5C0;
  font-size:10px; padding:1px 6px; border-radius:10px; min-width:20px; text-align:center;
}
.folder-add {
  display:flex; align-items:center; gap:10px; padding:8px 16px;
  cursor:pointer; font-size:11px; color:#8C7060; letter-spacing:.5px; transition:color .2s; margin-top:4px;
}
.folder-add:hover { color:var(--gold-light); }

.sb-bunker {
  display:block; width:100%; margin-top:auto; padding:14px 16px;
  border:none; border-top:1px solid rgba(184,134,11,0.15);
  background:transparent; cursor:pointer; text-align:inherit; font:inherit; color:inherit;
  transition:background .2s;
}
.sb-bunker:hover, .sb-bunker.on { background:rgba(184,134,11,0.08); }
.sb-bunker .sb-storage-lbl { margin-bottom:6px; }
.sb-bunker .sb-storage-lbl span:first-child { color:#C8B0A0; font-size:10px; letter-spacing:.5px; }
.sb-bunker .sb-storage-lbl span:last-child { color:var(--gold-light); font-size:10px; }
.sb-storage-lbl { display:flex; justify-content:space-between; }
.sb-track {
  height:3px; background:rgba(255,255,255,0.08); border-radius:2px; overflow:hidden;
}
.sb-fill {
  height:100%; width:12%;
  background:linear-gradient(90deg, var(--rouge), var(--gold));
  border-radius:2px;
}

/* ── Sidebar calendar widget ─── */
.sb-cal {
  margin:6px 10px 8px; border:1px solid rgba(184,134,11,0.15);
  border-radius:4px; overflow:hidden; flex-shrink:0;
}
.cal-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:6px 8px; background:rgba(255,255,255,0.03);
}
.cal-nav {
  background:none; border:none; color:#A89080; cursor:pointer;
  font-size:16px; padding:2px 6px; border-radius:3px; line-height:1;
  transition:color .2s; font-family:serif;
}
.cal-nav:hover { color:var(--gold-light); }
.cal-month {
  font-size:10px; color:#C8B0A0; letter-spacing:1px; text-transform:uppercase;
}
.cal-grid { padding:2px 4px 6px; }
.cal-row { display:flex; gap:0; }
.cal-row-head { margin-bottom:2px; }
.cal-cell {
  width:calc(100%/7); aspect-ratio:1; display:flex;
  align-items:center; justify-content:center;
  font-size:9px; color:#8C7060; position:relative;
  border-radius:2px; transition:background .15s; cursor:default;
}
.cal-cell:hover:not(:empty) { background:rgba(255,255,255,0.06); }
.cal-hd {
  font-size:8px; color:#6A5040; font-weight:bold; cursor:default;
}
.cal-today {
  background:var(--rouge-dim); color:var(--gold-light); font-weight:bold;
  border:1px solid var(--rouge);
}
.cal-ev { color:#E8D5C0; font-weight:bold; cursor:pointer; }
.cal-dot {
  position:absolute; bottom:2px; left:50%; transform:translateX(-50%);
  width:4px; height:4px; border-radius:50%; background:var(--gold);
  display:block; font-style:normal;
}

/* ── Right Panel (calendar + contacts) ─── */
.right-panel {
  width:200px; flex-shrink:0; border-left:1px solid var(--bd);
  background:var(--bg-white); display:flex; flex-direction:column;
  overflow:hidden; transition:width .3s,opacity .3s;
}
.right-panel.rp-collapsed { width:0; overflow:hidden; opacity:0; border:none; }

.shell-right { display:flex; height:100%; overflow:hidden; background:var(--bg-parchment); }

.rp-section {
  padding:0; border-bottom:1px solid var(--bd); flex-shrink:0;
}
.rp-section-grow {
  flex:1; display:flex; flex-direction:column; overflow:hidden;
}
.rp-section-title {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--rouge); padding:10px 10px 6px;
  display:flex; align-items:center; justify-content:space-between;
}

.rp-contact-list { flex:1; overflow-y:auto; padding:0 6px 8px; }
.rp-contact {
  display:flex; align-items:center; gap:8px; padding:8px 6px;
  border-radius:4px; cursor:pointer; transition:background .15s;
  border-bottom:1px solid var(--bd);
}
.rp-contact:hover { background:var(--rouge-soft); }
.rp-contact-avatar {
  width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg, var(--rouge), var(--rouge-dark));
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:bold; flex-shrink:0;
}
.rp-contact-info { flex:1; min-width:0; }
.rp-contact-name {
  font-size:11px; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  display:flex; align-items:center; gap:4px;
}
.rp-contact-dots { color:var(--gold); font-size:8px; letter-spacing:1px; flex-shrink:0; }
.rp-contact-email { font-size:9px; color:var(--text-4); direction:ltr; text-align:left; }
.rp-empty {
  padding:20px 10px; font-size:10px; color:var(--text-3); text-align:center; line-height:1.5;
}
.rp-add-contact { font-size:14px !important; padding:2px 4px !important; }

/* Schedule badge in compose */
.c-sched-badge {
  font-size:10px; color:var(--gold-dark); letter-spacing:.5px;
  background:var(--gold-soft); padding:2px 8px; border-radius:3px;
  margin-left:8px; vertical-align:middle;
}

/* Calendar popup */
.cal-popup-box { max-width:380px !important; }
.cal-popup-form { margin-top:12px; padding-top:12px; border-top:1px solid var(--bd); }
.cal-ev-list { margin-bottom:10px; max-height:120px; overflow-y:auto; }
.cal-ev-item {
  display:flex; align-items:center; gap:6px; padding:6px 0;
  border-bottom:1px solid var(--bd); font-size:12px;
}
.cal-ev-item-title { flex:1; color:var(--text); font-weight:bold; }
.cal-ev-item-time { color:var(--gold-dark); font-size:11px; flex-shrink:0; }
.cal-ev-item-note { color:var(--text-3); font-size:10px; margin-left:6px; }
.cal-ev-del { font-size:10px; padding:2px; flex-shrink:0; }

/* ── Main Area ── */
.main {
  flex:1; display:flex; flex-direction:column; overflow:hidden; min-width:0;
  background:var(--bg-parchment);
}

.topbar {
  display:flex; align-items:center; gap:10px; padding:0 16px; height:52px;
  border-bottom:2px solid var(--bd); background:var(--bg-white); flex-shrink:0; position:relative;
}
.topbar::after {
  content:''; position:absolute; bottom:-2px; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--rouge-dim), transparent);
}
.topbar-menu {
  display:none; background:none; border:none; cursor:pointer;
  color:var(--text-3); padding:6px; border-radius:4px; transition:color .2s;
}
.topbar-menu:hover { color:var(--rouge); }
.topbar-title {
  flex:1; font-size:14px; letter-spacing:2px; text-transform:uppercase; color:var(--text-2);
}
.topbar-actions { display:flex; align-items:center; gap:4px; }

.search-bar {
  padding:10px 16px; border-bottom:1px solid var(--bd); flex-shrink:0;
  background:var(--bg-white);
}
.search-inner {
  display:flex; align-items:center; gap:10px;
  background:var(--bg-cream); border:1px solid var(--bd);
  border-radius:4px; padding:8px 12px; transition:border-color .25s;
}
.search-inner:focus-within { border-color:var(--rouge); }
.search-inner svg { color:var(--text-4); flex-shrink:0; }
.search-inner input {
  flex:1; background:none; border:none; outline:none;
  color:var(--text); font-family:'Georgia',serif; font-size:13px; width:100%;
}
.search-inner input::placeholder { color:var(--text-4); }

.msg-list { flex:1; overflow-y:auto; background:var(--bg-parchment); }

.msg-item {
  display:flex; flex-direction:column; gap:4px; padding:14px 18px;
  border-bottom:1px solid var(--bd); cursor:pointer; transition:background .2s;
  position:relative; background:var(--bg-white);
}
.msg-item:hover { background:var(--bg-cream); }
.msg-item.unread {
  background:var(--rouge-soft); border-right:3px solid var(--rouge);
}
.msg-item.unread:hover { background:var(--rouge-dim); }

.msg-row { display:flex; justify-content:space-between; align-items:center; }
.msg-from { font-size:13px; font-weight:bold; color:var(--text); letter-spacing:.3px; }
.msg-time  { font-size:10px; color:var(--text-3); letter-spacing:.3px; flex-shrink:0; }
.msg-subj  { font-size:13px; color:var(--text-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msg-prev  { font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msg-star  { color:var(--gold); margin-right:4px; }
.msg-acts {
  display:flex; gap:4px; margin-top:4px; opacity:0; transition:opacity .2s;
}
.msg-item:hover .msg-acts { opacity:1; }

/* ── Bulk selection ── */
.msg-item-main {
  display:flex; align-items:flex-start; gap:6px;
}
.msg-check-label {
  display:flex; align-items:flex-start; padding-top:2px; flex-shrink:0;
  cursor:pointer; user-select:none;
}
.msg-check {
  width:15px; height:15px; cursor:pointer; accent-color:var(--rouge);
  margin:0; border:1px solid var(--bd); border-radius:3px;
}
.msg-item-body { flex:1; min-width:0; cursor:pointer; }

.bulk-bar {
  display:flex; align-items:center; gap:10px; padding:10px 18px;
  border-top:2px solid var(--rouge); background:var(--bg-white); flex-shrink:0;
  box-shadow:0 -4px 20px rgba(44,24,16,0.12);
}
.bulk-count {
  flex:1; font-size:12px; color:var(--text-2); letter-spacing:.5px;
}
.bulk-del-btn {
  width:auto !important; padding:8px 16px !important;
  font-size:12px !important; letter-spacing:.5px !important;
}

.empty {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:12px; height:200px; color:var(--text-3);
}
.empty-icon { font-size:32px; opacity:0.4; }
.empty-text { font-size:13px; letter-spacing:1px; }

.loading {
  display:flex; justify-content:center; align-items:center; height:120px;
}
.spinner {
  width:28px; height:28px;
  border:2px solid var(--bd); border-top-color:var(--rouge);
  border-radius:50%; animation:spin .8s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ═══════════════ COMPOSE ═══════════════════════════════════════ */
.compose-overlay {
  position:fixed; inset:0; background:var(--bg-overlay);
  backdrop-filter:blur(3px); z-index:100;
  display:flex; align-items:flex-end; justify-content:center; padding:0;
}

.compose-box {
  background:var(--bg-white); border:1px solid var(--bd-hi); border-bottom:none;
  border-radius:6px 6px 0 0; width:100%; max-width:620px;
  display:flex; flex-direction:column; max-height:80vh; overflow:hidden;
  box-shadow:0 -8px 48px rgba(44,24,16,0.18), var(--rouge-glow);
  position:relative;
}
.compose-box::before {
  content:''; position:absolute; top:0; left:40px; right:40px; height:3px;
  background:linear-gradient(90deg, transparent, var(--rouge), var(--gold), var(--rouge), transparent);
}

.compose-header {
  display:flex; align-items:center; gap:12px; padding:12px 14px;
  border-bottom:1px solid var(--bd); flex-shrink:0;
  position:relative; z-index:30; background:var(--bg-white);
}
.compose-header-title {
  flex:1; font-size:11px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--text-3); text-align:center; min-width:0;
}
.compose-header-tools { display:flex; gap:4px; flex-shrink:0; }
.c-send-top {
  flex-shrink:0; padding:9px 22px !important; font-size:13px; letter-spacing:.5px;
  position:relative; z-index:31; pointer-events:auto;
  box-shadow:0 3px 12px rgba(139,26,43,0.35);
}
.c-status {
  display:none; padding:8px 18px; font-size:11px;
  color:var(--rouge); text-align:center; line-height:1.5;
  border-bottom:1px solid var(--rouge-dim);
  background:var(--rouge-soft); flex-shrink:0;
}

.c-field {
  display:flex; align-items:center; gap:10px;
  border-bottom:1px solid var(--bd); padding:0 18px; background:var(--bg-white);
}
.c-label {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text-3); width:28px; flex-shrink:0;
}
.c-field input {
  flex:1; background:none; border:none; outline:none;
  color:var(--text); font-family:'Georgia',serif; font-size:14px; padding:11px 0; width:100%;
}
.c-field input::placeholder { color:var(--text-4); }

.c-body { flex:1; padding:14px 18px; overflow-y:auto; min-height:150px; background:var(--bg-white); }
.c-body textarea {
  width:100%; height:100%; min-height:150px;
  background:none; border:none; outline:none;
  color:var(--text-2); font-family:'Georgia',serif; font-size:14px;
  resize:none; line-height:1.7;
}
.c-body textarea::placeholder { color:var(--text-4); }

.c-footer {
  display:flex; align-items:center; gap:8px; padding:12px 18px;
  border-top:1px solid var(--bd); flex-shrink:0; flex-wrap:wrap;
  position:relative; z-index:5; background:var(--bg-white);
}
.a-chip-rm {
  background:none; border:none; cursor:pointer; color:var(--text-4);
  font-size:12px; padding:0; line-height:1;
}
.a-chip-rm:hover { color:var(--rouge); }

.attach-chips {
  display:flex; flex-wrap:wrap; gap:6px; padding:8px 18px;
  border-top:1px solid var(--bd); flex-shrink:0; max-height:96px; overflow-y:auto;
  background:var(--bg-cream);
}
.a-chip {
  display:flex; align-items:center; gap:6px;
  background:var(--bg-white); border:1px solid var(--bd);
  border-radius:4px; padding:4px 8px; font-size:11px; color:var(--text-2);
}
.a-chip button {
  background:none; border:none; cursor:pointer; color:var(--text-4);
  font-size:12px; padding:0; line-height:1; transition:color .2s;
}
.a-chip button:hover { color:var(--rouge); }
.a-chip-bunker { border-color:var(--gold-dim); color:var(--gold-dark); background:var(--gold-soft); }

/* ── Bunker Picker Modal ── */
.bp-modal {
  max-width:520px; max-height:80vh;
  display:flex; flex-direction:column; overflow:hidden;
}
.bp-grid {
  flex:1; overflow-y:auto; display:grid;
  grid-template-columns:repeat(auto-fill, minmax(100px,1fr));
  gap:8px; padding:4px 0 12px;
}
.bp-item {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:8px; border:1px solid var(--bd);
  border-radius:4px; cursor:pointer; text-align:center;
  transition:border-color .2s, background .2s; position:relative;
}
.bp-item:hover { border-color:var(--gold); background:var(--gold-soft); }
.bp-item-sel {
  border-color:var(--rouge); background:var(--rouge-soft);
  box-shadow:0 0 0 1px var(--rouge);
}
.bp-check { position:absolute; top:4px; right:4px; margin:0; accent-color:var(--rouge); }
.bp-preview {
  width:72px; height:72px; display:flex; align-items:center; justify-content:center;
  background:var(--bg-cream); border-radius:4px; overflow:hidden; margin-top:8px;
  font-size:32px; color:var(--text-4);
}
.bp-img { max-width:100%; max-height:100%; object-fit:contain; }
.bp-file-icon { font-size:32px; }
.bp-name {
  font-size:10px; color:var(--text-2); word-break:break-word;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
  max-width:100%; line-height:1.2;
}
.bp-size { font-size:9px; color:var(--text-4); }
.bp-actions {
  display:flex; gap:8px; margin-top:4px; padding-top:12px;
  border-top:1px solid var(--bd); flex-shrink:0;
}

.vault-scroll { flex:1; overflow-y:auto; padding:0; background:var(--bg-parchment); }
.vault-row {
  display:flex; align-items:center; gap:10px; padding:14px 18px;
  border-bottom:1px solid var(--bd); background:var(--bg-white);
}
.vault-row-main { flex:1; min-width:0; cursor:pointer; }
.vault-row-title { font-size:14px; color:var(--text); margin-bottom:3px; }
.vault-row-sub { font-size:11px; color:var(--text-3); }
.vault-form {
  padding:18px; border-bottom:1px solid var(--bd); background:var(--bg-white);
}
.vault-form-title {
  font-size:12px; letter-spacing:2px; text-transform:uppercase;
  color:var(--rouge); margin-bottom:12px;
}

.modal-text { font-size:13px; color:var(--text-2); text-align:center; margin-bottom:10px; line-height:1.6; }
.modal-addr {
  text-align:center; font-size:13px; color:var(--text); margin-bottom:16px;
  padding:10px; background:var(--bg-cream); border:1px solid var(--bd);
}

/* ═══════════════ DETAIL ════════════════════════════════════════ */
.detail-wrap { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.detail-scroll { flex:1; overflow-y:auto; padding:0; }

.d-top {
  padding:22px 22px 18px; border-bottom:1px solid var(--bd); background:var(--bg-white);
}
.d-subj {
  font-size:20px; font-weight:normal; color:var(--text); margin-bottom:14px;
  line-height:1.4; letter-spacing:.3px;
}
.d-meta { display:flex; flex-direction:column; gap:5px; }
.d-row { display:flex; gap:14px; font-size:12px; }
.d-lbl { color:var(--text-4); flex-shrink:0; width:36px; text-align:right; letter-spacing:.5px; }
.d-val { color:var(--text-2); direction:ltr; text-align:left; }
.d-val.name { color:var(--text); font-weight:bold; direction:rtl; text-align:right; }

.d-actions {
  display:flex; gap:8px; padding:12px 22px;
  border-bottom:1px solid var(--bd); flex-shrink:0; flex-wrap:wrap;
  background:var(--bg-white);
}

.d-verify-banner {
  margin:0 22px 16px; padding:16px 18px;
  background:linear-gradient(135deg, var(--rouge-soft), var(--gold-soft));
  border:1px solid var(--gold-dim); border-radius:4px;
}
.d-verify-title { font-size:15px; color:var(--rouge); letter-spacing:.5px; margin-bottom:6px; }
.d-verify-hint { font-size:12px; color:var(--text-2); line-height:1.55; margin-bottom:10px; }
.d-verify-code { font-size:13px; color:var(--text); margin-bottom:12px; }
.d-verify-btn { width:100%; text-decoration:none; font-size:14px; letter-spacing:.5px; }

.d-atts {
  padding:14px 22px; border-bottom:1px solid var(--bd);
  background:var(--gold-soft);
}
.d-atts-title { font-size:12px; color:var(--rouge); margin-bottom:6px; letter-spacing:.5px; }
.trash-bar {
  padding:10px 16px; border-bottom:1px solid var(--bd); background:var(--rouge-soft);
}
.trash-bar .btn { width:100%; font-size:12px; }
.d-atts-note { font-size:11px; color:var(--text-3); margin-bottom:12px; line-height:1.5; }
.d-att-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(140px,1fr)); gap:12px;
}
.d-att-card {
  background:var(--bg-white); border:1px solid var(--bd);
  border-radius:8px; padding:10px; text-align:center;
}
.d-att-preview {
  min-height:100px; display:flex; align-items:center; justify-content:center;
  background:var(--bg-cream); border-radius:6px; margin-bottom:8px;
  font-size:28px; overflow:hidden; width:100%; border:none; padding:0;
  cursor:pointer; color:inherit;
}
.d-att-preview:hover { background:var(--rouge-soft); }
.d-att-img { max-width:100%; max-height:160px; object-fit:contain; display:block; }
.d-att-name { font-size:11px; color:var(--text-2); word-break:break-word; margin-bottom:4px; }
.d-att-size { font-size:10px; color:var(--text-3); margin-bottom:6px; }

.bunker-note { padding:12px 18px 0; font-size:11px; color:var(--text-3); line-height:1.5; }
.bunker-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(150px,1fr));
  gap:14px; padding:14px 18px 24px;
}
.bunker-card {
  background:var(--bg-white); border:1px solid var(--bd);
  border-radius:8px; padding:10px; text-align:center;
}
.bunker-preview {
  width:100%; min-height:110px; display:flex; align-items:center; justify-content:center;
  background:var(--bg-cream); border:none; border-radius:6px;
  margin-bottom:8px; font-size:28px; overflow:hidden;
  cursor:pointer; padding:0; color:inherit;
}
.bunker-preview:hover { background:var(--rouge-soft); }
.bunker-preview-icon {
  display:flex; align-items:center; justify-content:center;
  width:100%; min-height:110px;
}
.bunker-img { max-width:100%; max-height:180px; object-fit:contain; display:block; }
.bunker-card-name { font-size:11px; color:var(--text-2); word-break:break-word; margin-bottom:4px; }
.bunker-card-sub { font-size:10px; color:var(--text-3); margin-bottom:6px; }
.bunker-card-actions { display:flex; gap:6px; justify-content:center; }
.bunker-card-actions .btn { flex:1; font-size:10px; padding:5px 6px; }

.bunker-viewer {
  position:fixed; inset:0; z-index:9000;
  background:rgba(30,12,12,0.92); display:flex; flex-direction:column;
}
.bunker-viewer-head {
  display:flex; align-items:center; gap:12px; padding:12px 16px;
  border-bottom:1px solid rgba(184,134,11,0.2);
  background:var(--bg-sidebar); flex-shrink:0;
}
.bunker-viewer-title {
  flex:1; font-size:13px; color:#E8D5C0;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.bunker-viewer-body {
  flex:1; overflow:auto; display:flex; align-items:center; justify-content:center;
  padding:16px; min-height:0; background:rgba(0,0,0,0.5);
}
.bunker-viewer-foot {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:10px 16px; border-top:1px solid rgba(184,134,11,0.2);
  background:var(--bg-sidebar); flex-shrink:0;
}
.bunker-viewer-meta { font-size:11px; color:#A89080; }
.bunker-viewer-img { max-width:100%; max-height:100%; object-fit:contain; }
.bunker-viewer-frame {
  width:100%; height:100%; min-height:60vh; border:none; background:#fff; border-radius:4px;
}
.bunker-viewer-text {
  width:100%; max-height:70vh; overflow:auto; text-align:start; direction:ltr;
  font-size:12px; line-height:1.5; color:#E0D0C0;
  background:rgba(0,0,0,0.35); padding:14px; border:1px solid rgba(255,255,255,0.08);
  white-space:pre-wrap; word-break:break-word;
}
.bunker-viewer-generic { text-align:center; color:#E0D0C0; }
.bunker-viewer-icon { font-size:48px; display:block; margin-bottom:12px; }

.c-bunker-btn {
  display:flex; flex-direction:column; align-items:flex-start; gap:2px; line-height:1.2;
}
.c-bunker-meter { font-size:9px; color:var(--rouge); letter-spacing:.3px; }

.d-body {
  padding:22px; font-size:14px; line-height:1.85; color:var(--text-2);
  background:var(--bg-white);
}
.mail-plain-body {
  white-space:pre-wrap; word-break:break-word; font-family:Georgia,'Times New Roman',serif;
}
.mail-link { color:var(--rouge); text-decoration:underline; text-underline-offset:3px; word-break:break-all; }
.mail-link:hover { color:var(--rouge-dark); }
.mail-links-bar {
  display:flex; flex-direction:column; gap:10px; margin-bottom:18px;
  padding-bottom:16px; border-bottom:1px solid var(--bd);
}
.mail-link-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 16px; background:var(--gold-soft);
  border:1px solid var(--gold-dim); border-radius:4px;
  color:var(--gold-dark); font-family:Georgia,serif; font-size:13px;
  text-decoration:none; word-break:break-all; transition:all .2s;
}
.mail-link-btn:hover { background:var(--gold-dim); border-color:var(--gold); color:var(--rouge); }
.mail-iframe {
  width:100%; border:none; border-radius:4px; background:#fff;
  min-height:300px; display:block;
}

/* ═══════════════ MODAL ═════════════════════════════════════════ */
.modal-bg {
  position:fixed; inset:0; background:var(--bg-overlay);
  backdrop-filter:blur(3px); z-index:200;
  display:flex; align-items:center; justify-content:center; padding:20px;
}
.modal-box {
  background:var(--bg-white); border:1px solid var(--bd-hi); border-radius:4px;
  padding:28px; width:100%; max-width:340px;
  box-shadow:0 24px 64px rgba(44,24,16,0.18);
}
.modal-title {
  font-size:14px; letter-spacing:1.5px; color:var(--text); margin-bottom:16px; text-align:center;
}
.modal-input {
  width:100%; background:var(--bg-cream); border:1px solid var(--bd);
  outline:none; color:var(--text); font-family:'Georgia',serif; font-size:14px;
  padding:11px 14px; border-radius:4px; margin-bottom:14px; transition:border-color .25s;
}
.modal-input:focus { border-color:var(--rouge); }
.modal-acts { display:flex; gap:8px; }

/* ═══════════════ TOAST ═════════════════════════════════════════ */
.toast-wrap {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:999;
  display:flex; flex-direction:column; align-items:center; gap:8px; pointer-events:none;
}
.toast {
  background:var(--bg-sidebar); border:1px solid rgba(184,134,11,0.25);
  color:#E8D5C0; padding:10px 22px; border-radius:4px;
  font-size:13px; letter-spacing:.5px; box-shadow:0 8px 32px rgba(0,0,0,0.3);
  animation:toastIn .25s ease; pointer-events:auto; white-space:nowrap;
}
.toast.success { border-color:var(--gold); box-shadow:var(--gold-glow); }
.toast.error   { border-color:var(--rouge); box-shadow:var(--rouge-glow); }
@keyframes toastIn {
  from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)}
}

/* ═══════════════ MOBILE ════════════════════════════════════════ */
@media (max-width:640px) {
  .sidebar {
    position:fixed; top:0; left:0; bottom:0; z-index:50;
    transform:translateX(-100%); transition:transform .3s ease;
  }
  .sidebar.open { transform:translateX(0); }
  .topbar-menu { display:inline-flex; }
  .main { width:100%; }
  .compose-overlay { padding:0; }
  .compose-box { max-height:95vh; border-radius:0; }
  .auth-card { padding:32px 22px 28px; }
  .right-panel {
    position:fixed; top:52px; right:0; bottom:0; z-index:45;
    width:200px; box-shadow:-4px 0 20px rgba(0,0,0,0.15);
  }
  .right-panel.rp-collapsed { width:0; }
}

/* ═══════════════ Voice Notes ══════════════════════════════════ */
.vn-item {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 20px; border-bottom: 1px solid var(--bd);
  background: var(--bg-white); transition: background .2s;
  cursor: default;
}
.vn-item:hover { background: var(--bg-cream); }
.vn-item.vn-unread { border-left: 3px solid var(--rouge); padding-left: 17px; }
.vn-meta { flex: 1; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.vn-sender { font-size: 13px; color: var(--text); font-weight: bold; }
.vn-dur { font-size: 12px; color: var(--text-3); }
.vn-date { font-size: 11px; color: var(--text-4); margin-right: auto; }

.vn-play-btn {
  flex-shrink: 0;
}
.vn-play-btn:hover { color: var(--rouge); }

/* Recording ring */
.vn-recording-ring {
  width: 120px; height: 120px; border-radius: 50%;
  border: 3px solid var(--rouge);
  display: flex; align-items: center; justify-content: center;
  animation: vnRingPulse 1.5s ease-in-out infinite;
  position: relative;
}
@keyframes vnRingPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(139,26,43,0.4); border-color: var(--rouge); }
  50% { box-shadow: 0 0 0 18px rgba(139,26,43,0); border-color: var(--rouge-light); }
}
.vn-rec-icon { font-size: 40px; }

.vn-timer {
  font-size: 36px; color: var(--rouge); font-weight: bold;
  font-family: 'Georgia', serif;
}
.vn-rec-label {
  font-size: 13px; color: var(--text-3); letter-spacing: 1px;
}

/* ═══════════════ Audio Player Bar ════════════════════════════ */
.ap-bar {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
  background: var(--bg-white);
  border-top: 1px solid var(--bd-hi);
  box-shadow: 0 -4px 20px rgba(44,24,16,0.10);
  padding: 8px 14px;
  align-items: center; gap: 8px;
  height: 52px;
}
.ap-bar.ap-visible { display: flex; }

.ap-btn {
  background: none; border: 1px solid var(--bd);
  border-radius: 4px; cursor: pointer;
  font-size: 15px; padding: 5px 10px; color: var(--text-2);
  transition: all .2s; flex-shrink: 0; line-height: 1;
}
.ap-btn:hover { border-color: var(--rouge); color: var(--rouge); background: var(--rouge-soft); }
.ap-btn.ap-play { font-size: 17px; padding: 5px 11px; }
.ap-btn.ap-del:hover { border-color: var(--rouge-light); color: var(--rouge-light); }
.ap-btn.ap-close { margin-left: auto; color: var(--text-4); border-color: transparent; font-size: 16px; }
.ap-btn.ap-close:hover { color: var(--rouge); }

.ap-progress-wrap { flex: 1; min-width: 60px; }
.ap-progress {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 5px; border-radius: 3px;
  background: linear-gradient(to right, var(--rouge) var(--ap-val, 0%), var(--bd) var(--ap-val, 0%));
  outline: none; cursor: pointer;
}
.ap-progress::-webkit-slider-thumb {
  -webkit-appearance: none; width: 13px; height: 13px;
  border-radius: 50%; background: var(--rouge);
  border: 2px solid var(--bg-white); box-shadow: 0 0 2px rgba(0,0,0,0.15);
  cursor: pointer; margin-top: -1px;
}
.ap-progress::-moz-range-thumb {
  width: 13px; height: 13px; border-radius: 50%;
  background: var(--rouge); border: 2px solid var(--bg-white); cursor: pointer;
}

.ap-time, .ap-dur { font-size: 11px; color: var(--text-3); font-variant-numeric: tabular-nums; min-width: 32px; text-align: center; }
.ap-sep { font-size: 11px; color: var(--text-4); }
.ap-label { font-size: 11px; color: var(--text-3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 120px; display: none; }
@media (min-width: 600px) { .ap-label { display: inline; } }

/* ═══════════════ Contacts & Voice Picker ═════════════════════ */
.cp-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; cursor: pointer;
  border-bottom: 1px solid var(--bd);
  transition: background .2s;
}
.cp-row:hover { background: var(--bg-cream); }
.cp-avatar {
  width: 32px; height: 32px; border-radius: 4px;
  background: var(--rouge); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: bold; flex-shrink: 0;
}
.cp-info { flex: 1; min-width: 0; }
.cp-name { font-size: 13px; color: var(--text); }
.cp-addr { font-size: 11px; color: var(--text-3); }

.vn-pick-item {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; border-bottom: 1px solid var(--bd);
  background: var(--bg-white); transition: background .2s;
}
.vn-pick-item:hover { background: var(--bg-cream); }
.vn-pick-info { flex: 1; min-width: 0; }
