/* ═══════════════════════════════════════════════
   MailBox — Netflix Code Tool
   style.css
═══════════════════════════════════════════════ */

:root {
  --bg:      #0b0809;
  --bg2:     #110a0b;
  --bg3:     #180d0e;
  --card:    rgba(255,255,255,.032);
  --card2:   rgba(255,255,255,.055);
  --border:  rgba(220,60,80,.12);
  --border2: rgba(220,60,80,.22);
  --red:     #e11d48;
  --red2:    #fb7185;
  --red-d:   #9f1239;
  --rose:    #f43f5e;
  --ok:      #10b981;
  --ok2:     #6ee7b7;
  --warn:    #f59e0b;
  --warn2:   #fde68a;
  --bad:     #ef4444;
  --txt:     #f0e4e6;
  --txt2:    #a8909a;
  --txt3:    #6e4852;
  --r:       14px;
  --r2:      10px;
  --glow-red: 0 0 28px rgba(225,29,72,.4);
  --sh:      0 4px 32px rgba(0,0,0,.65);
  --sh2:     0 12px 56px rgba(0,0,0,.8);
  --grad:    linear-gradient(135deg,#e11d48,#f43f5e,#fb7185);
  --grad2:   linear-gradient(135deg,#e11d48,#f43f5e);
  --brand:   #e11d48;
}

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

html, body {
  font-family: 'Inter', 'Noto Sans Thai', sans-serif;
  background: var(--bg);
  color: var(--txt);
  min-height: 100vh;
  line-height: 1.6;
  font-size: 14.5px;
  overflow-x: hidden;
}

a { text-decoration: none; color: inherit; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(225,29,72,.3); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: rgba(225,29,72,.55); }

/* ══ ANIMATED BACKGROUND ══ */
.bg-orbs { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.orb { position: absolute; border-radius: 50%; filter: blur(90px); animation: orbFloat 20s ease-in-out infinite; }
.orb1 { width: 480px; height: 480px; background: radial-gradient(circle,rgba(225,29,72,.22),transparent 70%); top: -120px; left: -80px; animation-duration: 22s; }
.orb2 { width: 380px; height: 380px; background: radial-gradient(circle,rgba(244,63,94,.18),transparent 70%); top: 40%; right: -60px; animation-duration: 26s; animation-delay: -9s; }
.orb3 { width: 320px; height: 320px; background: radial-gradient(circle,rgba(159,18,57,.14),transparent 70%); bottom: -60px; left: 28%; animation-duration: 24s; animation-delay: -5s; }
.orb4 { width: 260px; height: 260px; background: radial-gradient(circle,rgba(251,113,133,.1),transparent 70%); bottom: 22%; right: 18%; animation-duration: 30s; animation-delay: -14s; }

@keyframes orbFloat {
  0%,100% { transform: translate(0,0) scale(1); }
  33%      { transform: translate(35px,-25px) scale(1.07); }
  66%      { transform: translate(-18px,45px) scale(.93); }
}

/* ══ LAYOUT ══ */
.app { display: flex; min-height: 100vh; position: relative; z-index: 1; }

/* ── Sidebar ── */
.sidebar {
  width: 268px; flex-shrink: 0;
  background: rgba(9,5,7,.92); backdrop-filter: blur(32px);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  z-index: 100;
  box-shadow: 2px 0 40px rgba(0,0,0,.4);
}

.sidebar-logo {
  display: flex; align-items: center; gap: 13px;
  padding: 20px 18px 16px;
  border-bottom: 1px solid var(--border);
}

.logo-ic {
  width: 48px; height: 48px; border-radius: 14px;
  background: var(--grad2);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; color: #fff; flex-shrink: 0;
  animation: logoPulse 3s ease-in-out infinite;
  position: relative;
}

.logo-ic::after {
  content: '♥'; position: absolute; top: -5px; right: -5px;
  font-size: .5rem; color: var(--red2);
  background: var(--bg2); border-radius: 50%;
  width: 14px; height: 14px; display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(225,29,72,.3);
}

@keyframes logoPulse {
  0%,100% { box-shadow: 0 0 14px rgba(225,29,72,.5),0 5px 18px rgba(225,29,72,.35); }
  50%      { box-shadow: 0 0 30px rgba(225,29,72,.8),0 8px 32px rgba(225,29,72,.6); }
}

.logo-txt  { font-size: 1.08rem; font-weight: 900; color: var(--txt); letter-spacing: -.02em; }
.logo-sub  { font-size: .68rem; color: var(--txt3); margin-top: 2px; font-weight: 500; }

.sidebar-nav { flex: 1; padding: 14px 10px; overflow-y: auto; display: flex; flex-direction: column; gap: 2px; }

.nav-section {
  font-size: .63rem; font-weight: 800; text-transform: uppercase; letter-spacing: .14em;
  color: var(--txt3); padding: 12px 11px 5px;
  display: flex; align-items: center; gap: 6px;
}
.nav-section::before { content: '·'; font-size: .9rem; color: var(--red); opacity: .55; }

.nav-item {
  display: flex; align-items: center; gap: 11px;
  padding: 10px 13px; border-radius: var(--r2);
  font-size: .86rem; font-weight: 500; color: var(--txt2);
  cursor: pointer; transition: all .18s cubic-bezier(.2,.8,.2,1); position: relative; overflow: hidden;
}
.nav-item i { font-size: .84rem; width: 18px; text-align: center; transition: all .18s; opacity: .7; flex-shrink: 0; }
.nav-item:hover { background: rgba(225,29,72,.1); color: var(--txt); transform: translateX(2px); }
.nav-item:hover i { color: var(--red2); opacity: 1; filter: drop-shadow(0 0 4px rgba(225,29,72,.5)); }
.nav-item.active {
  background: linear-gradient(135deg,rgba(225,29,72,.24),rgba(244,63,94,.1));
  color: #fff; font-weight: 700;
  box-shadow: inset 0 0 0 1px rgba(225,29,72,.28),0 3px 16px rgba(225,29,72,.14);
}
.nav-item.active i { color: var(--red2); opacity: 1; filter: drop-shadow(0 0 6px rgba(225,29,72,.6)); }
.nav-item.active::before {
  content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 3px; height: 62%; border-radius: 0 3px 3px 0;
  background: var(--grad2); box-shadow: 0 0 10px rgba(225,29,72,.7);
}

.nav-badge {
  margin-left: auto; background: var(--grad2); color: #fff;
  font-size: .64rem; font-weight: 800; padding: 2px 9px; border-radius: 99px;
  box-shadow: 0 2px 10px rgba(225,29,72,.5);
  animation: badgePop .35s cubic-bezier(.34,1.56,.64,1);
}
@keyframes badgePop { from { transform: scale(.6); } to { transform: scale(1); } }

.sidebar-footer { padding: 14px 12px 18px; border-top: 1px solid var(--border); }
.user-chip {
  display: flex; align-items: center; gap: 11px;
  padding: 11px 12px; border-radius: var(--r);
  background: rgba(255,255,255,.042); border: 1px solid var(--border2);
  transition: all .18s;
}
.user-chip:hover { background: rgba(225,29,72,.07); border-color: rgba(225,29,72,.22); }
.user-av {
  width: 40px; height: 40px; border-radius: 12px; flex-shrink: 0;
  background: var(--grad2);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 900; color: #fff;
  box-shadow: 0 0 16px rgba(225,29,72,.45),0 4px 14px rgba(225,29,72,.3);
}
.user-name  { font-size: .88rem; font-weight: 800; color: var(--txt); }
.user-role  { font-size: .64rem; color: var(--txt3); font-weight: 600; margin-top: 2px; }

.ham {
  display: none; align-items: center; justify-content: center;
  width: 34px; height: 34px; border-radius: 9px;
  background: var(--card2); border: 1px solid var(--border);
  color: var(--txt2); cursor: pointer; font-size: .88rem;
  transition: all .15s;
}
.ham:hover { border-color: var(--border2); color: var(--red2); }

/* ── Main ── */
.main { flex: 1; display: flex; flex-direction: column; min-width: 0; }

.topbar {
  height: 66px; display: flex; align-items: center; gap: 14px;
  padding: 0 26px;
  background: rgba(9,5,7,.9); backdrop-filter: blur(30px);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 90;
  box-shadow: 0 2px 24px rgba(0,0,0,.35);
}
.topbar-title {
  display: flex; align-items: center; gap: 10px;
  font-size: 1.02rem; font-weight: 800; color: var(--txt); flex: 1; letter-spacing: -.01em;
}
.topbar-title i { color: var(--red2); font-size: .9rem; filter: drop-shadow(0 0 6px rgba(225,29,72,.5)); }
.topbar-right { display: flex; align-items: center; gap: 9px; }
.topbar-time {
  font-size: .72rem; color: var(--txt3); font-weight: 600;
  background: var(--card2); border: 1px solid var(--border);
  padding: 6px 13px; border-radius: 9px; white-space: nowrap;
  display: flex; align-items: center; gap: 6px;
}
.topbar-time::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--ok); display: inline-block;
  box-shadow: 0 0 8px var(--ok); animation: pulse 2s infinite;
}
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: .25; } }

/* ── Pages ── */
.page { display: none; padding: 26px; animation: pageIn .32s cubic-bezier(.22,1,.36,1); }
.page.active { display: block; }
@keyframes pageIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }

.pg-hdr { margin-bottom: 24px; }
.pg-hdr h2 { font-size: 1.35rem; font-weight: 900; color: var(--txt); letter-spacing: -.03em; display: flex; align-items: center; gap: 13px; }
.pg-hdr p  { font-size: .78rem; color: var(--txt3); margin-top: 5px; }
.pg-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--grad2); font-size: .86rem; color: #fff;
  box-shadow: var(--glow-red); animation: logoPulse 3s ease-in-out infinite;
  flex-shrink: 0;
}

/* ── Warning Box ── */
.warn-box {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px; border-radius: 12px; margin-bottom: 20px;
  background: rgba(245,158,11,.1); border: 1px solid rgba(245,158,11,.25);
  color: var(--warn2); font-size: .82rem; font-weight: 600;
}
.warn-box i { color: var(--warn); flex-shrink: 0; }

/* ── Inbox Toolbar ── */
.inbox-toolbar { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; flex-wrap: wrap; }
.search-wrap { flex: 1; min-width: 200px; max-width: 440px; position: relative; display: flex; align-items: center; }
.search-ico { position: absolute; left: 14px; color: var(--txt3); font-size: .8rem; pointer-events: none; transition: color .17s; }
.search-wrap input {
  width: 100%; padding: 11px 38px 11px 38px;
  background: rgba(255,255,255,.055);
  border: 1.5px solid var(--border); border-radius: 12px;
  color: var(--txt); font-family: inherit; font-size: .88rem;
  transition: all .18s;
}
.search-wrap input:focus {
  outline: none; border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(225,29,72,.16),0 5px 24px rgba(225,29,72,.1);
  background: rgba(225,29,72,.04);
}
.search-wrap:focus-within .search-ico { color: var(--red2); }
.search-wrap input::placeholder { color: var(--txt3); }
.search-clear {
  position: absolute; right: 10px;
  width: 22px; height: 22px; border-radius: 7px;
  border: none; background: rgba(255,255,255,.1);
  color: var(--txt3); cursor: pointer; font-size: .68rem;
  align-items: center; justify-content: center; transition: all .14s;
  display: none;
}
.search-clear:hover { background: rgba(225,29,72,.22); color: var(--red2); }
.search-clear.visible { display: flex; }
.inbox-count {
  font-size: .7rem; color: var(--txt3); font-weight: 700; white-space: nowrap; margin-left: auto;
  background: var(--card2); border: 1px solid var(--border); padding: 6px 14px; border-radius: 10px;
}

/* ── Email Grid ── */
.email-grid { display: grid; gap: 13px; }
.email-card {
  background: rgba(255,255,255,.036); backdrop-filter: blur(24px);
  border: 1px solid var(--border); border-radius: var(--r);
  padding: 18px 22px;
  display: flex; align-items: flex-start; gap: 17px;
  transition: all .24s cubic-bezier(.2,.8,.2,1); position: relative; overflow: hidden;
}
.email-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--grad2); border-radius: 0 3px 3px 0;
  opacity: .4; transition: all .24s;
}
.email-card::after {
  content: ''; position: absolute; top: 0; left: -120%; width: 55%; height: 100%;
  background: linear-gradient(90deg,transparent,rgba(225,29,72,.035),transparent);
  transition: left .55s ease; pointer-events: none;
}
.email-card:hover { border-color: rgba(225,29,72,.35); box-shadow: 0 10px 40px rgba(225,29,72,.15),var(--sh); transform: translateY(-3px); }
.email-card:hover::before { opacity: 1; width: 4px; box-shadow: 0 0 14px rgba(225,29,72,.6); }
.email-card:hover::after { left: 160%; }

.email-av {
  width: 54px; height: 54px; border-radius: 15px; flex-shrink: 0;
  background: var(--grad2);
  display: flex; align-items: center; justify-content: center;
  font-size: .94rem; font-weight: 900; color: #fff;
  box-shadow: 0 5px 18px rgba(225,29,72,.4);
  transition: transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .22s;
}
.email-card:hover .email-av { transform: scale(1.08) rotate(-3deg); box-shadow: 0 8px 26px rgba(225,29,72,.6); }

.email-info { flex: 1; min-width: 0; }
.email-addr { font-size: .94rem; font-weight: 700; color: var(--txt); word-break: break-all; display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.email-meta { font-size: .7rem; color: var(--txt3); margin-top: 5px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.email-actions { display: flex; gap: 7px; flex-shrink: 0; flex-wrap: wrap; justify-content: flex-end; align-items: flex-start; }

/* ── Buttons ── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 18px; border-radius: 11px;
  font-family: inherit; font-size: .82rem; font-weight: 700;
  border: none; cursor: pointer; transition: all .18s cubic-bezier(.2,.8,.2,1); line-height: 1.2; white-space: nowrap;
  position: relative; overflow: hidden;
}
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg,rgba(255,255,255,.12),transparent 55%);
  opacity: 0; transition: opacity .18s; pointer-events: none; border-radius: inherit;
}
.btn:hover::after { opacity: 1; }
.btn:active { transform: scale(.95) !important; transition-duration: .08s; }

.btn-brand  { background: var(--grad2); color: #fff; box-shadow: 0 4px 18px rgba(225,29,72,.45); }
.btn-brand:hover { transform: translateY(-2px); box-shadow: 0 9px 30px rgba(225,29,72,.6); }

.btn-sm { padding: 7px 13px; font-size: .76rem; border-radius: 9px; }
.btn-xs { padding: 5px 11px; font-size: .69rem; border-radius: 7px; }

.btn-code   { background: rgba(16,185,129,.13); color: var(--ok2); border: 1px solid rgba(16,185,129,.26); }
.btn-code:hover { background: rgba(16,185,129,.24); box-shadow: 0 4px 16px rgba(16,185,129,.24); transform: translateY(-2px); }

.btn-link   { background: rgba(245,158,11,.13); color: var(--warn2); border: 1px solid rgba(245,158,11,.26); }
.btn-link:hover { background: rgba(245,158,11,.24); box-shadow: 0 4px 16px rgba(245,158,11,.24); transform: translateY(-2px); }

.btn-6pins  { background: rgba(234,67,53,.13); color: #f87171; border: 1px solid rgba(234,67,53,.26); }
.btn-6pins:hover { background: rgba(234,67,53,.24); box-shadow: 0 4px 16px rgba(234,67,53,.24); transform: translateY(-2px); }

.btn-house  { background: rgba(139,92,246,.13); color: #c4b5fd; border: 1px solid rgba(139,92,246,.3); }
.btn-house:hover { background: rgba(139,92,246,.26); box-shadow: 0 4px 16px rgba(139,92,246,.24); transform: translateY(-2px); }

.btn-hist   { background: rgba(225,29,72,.1); color: var(--red2); border: 1px solid rgba(225,29,72,.22); }
.btn-hist:hover { background: rgba(225,29,72,.24); box-shadow: 0 4px 16px rgba(225,29,72,.24); transform: translateY(-2px); }

.btn-del    { background: rgba(239,68,68,.09); color: #fca5a5; border: 1px solid rgba(239,68,68,.2); }
.btn-del:hover { background: rgba(239,68,68,.22); box-shadow: 0 4px 14px rgba(239,68,68,.2); transform: translateY(-2px); }

.btn-ghost  { background: rgba(255,255,255,.055); color: var(--txt2); border: 1px solid var(--border); }
.btn-ghost:hover { background: rgba(255,255,255,.1); color: var(--txt); transform: translateY(-1px); }
.btn-ghost:disabled { opacity: .35; cursor: not-allowed; transform: none !important; }

/* ── Forms ── */
.fg { margin-bottom: 16px; }
.fg label { display: block; font-size: .67rem; font-weight: 800; text-transform: uppercase; letter-spacing: .5px; color: var(--txt3); margin-bottom: 7px; }
.fg input, .fg select {
  width: 100%; padding: 11px 15px;
  background: rgba(255,255,255,.055);
  border: 1.5px solid var(--border); border-radius: 11px;
  color: var(--txt); font-family: inherit; font-size: .9rem;
  transition: all .18s;
}
.fg input:focus, .fg select:focus {
  outline: none; border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(225,29,72,.16),0 5px 24px rgba(225,29,72,.1);
  background: rgba(225,29,72,.04);
}
.fg input::placeholder { color: var(--txt3); }
.fg select option { background: #180d0e; }
.fg-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pw-wrap { position: relative; }
.pw-wrap input { padding-right: 44px; }
.pw-eye {
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  color: var(--txt3); cursor: pointer; font-size: .8rem;
  border: none; background: none; transition: color .14s; padding: 3px;
}
.pw-eye:hover { color: var(--red2); }

textarea {
  background: rgba(255,255,255,.055) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 11px !important;
  color: var(--txt) !important;
  transition: all .18s !important;
}
textarea:focus {
  outline: none !important;
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(225,29,72,.16) !important;
}
textarea::placeholder { color: var(--txt3) !important; }

/* ── Cards ── */
.card {
  background: rgba(255,255,255,.034); backdrop-filter: blur(24px);
  border: 1px solid var(--border); border-radius: var(--r);
  padding: 22px; box-shadow: var(--sh);
  transition: border-color .22s, box-shadow .22s;
}
.card:hover { border-color: rgba(225,29,72,.18); box-shadow: 0 8px 40px rgba(0,0,0,.55),0 0 0 1px rgba(225,29,72,.06); }
.card-title {
  font-size: .94rem; font-weight: 800; color: var(--txt);
  display: flex; align-items: center; gap: 11px; margin-bottom: 20px;
}
.card-title i {
  width: 34px; height: 34px; border-radius: 10px;
  background: linear-gradient(135deg,rgba(225,29,72,.32),rgba(244,63,94,.18));
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--red2); font-size: .82rem;
  box-shadow: 0 3px 14px rgba(225,29,72,.25);
}
.sec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 18px; }

/* ── Code blocks ── */
.code-pre {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 16px;
  font-size: 12px;
  overflow-x: auto;
  margin-bottom: 0;
  white-space: pre-wrap;
  word-break: break-all;
}
.code-pre code { font-family: monospace; color: var(--txt2); }

/* ── Empty state ── */
.empty-state { text-align: center; padding: 40px 20px; color: var(--txt3); }
.empty-state i { font-size: 2.2rem; display: block; margin-bottom: 12px; opacity: .15; color: var(--red2); }
.empty-state p { font-size: .8rem; font-weight: 600; }

/* ══ TOAST NOTIFICATIONS ══ */
#toastWrap {
  position: fixed; bottom: 28px; right: 28px; z-index: 9999;
  display: flex; flex-direction: column; gap: 10px;
  pointer-events: none;
}
.toast-noti {
  pointer-events: all;
  min-width: 290px; max-width: 350px;
  background: linear-gradient(135deg,#16151b 0%,#1e1c25 100%);
  border: 1px solid rgba(225,29,72,.3);
  border-left: 3px solid var(--brand);
  border-radius: 14px;
  padding: 14px 14px 10px 14px;
  box-shadow: 0 12px 40px rgba(0,0,0,.55),0 0 20px rgba(225,29,72,.12);
  position: relative; overflow: hidden;
  animation: toastSlideIn .38s cubic-bezier(.22,.68,0,1.15) both;
}
.toast-noti.removing { animation: toastSlideOut .28s ease forwards; }

@keyframes toastSlideIn { from { transform: translateX(115%) scale(.95); opacity: 0; } to { transform: translateX(0) scale(1); opacity: 1; } }
@keyframes toastSlideOut { from { transform: translateX(0); opacity: 1; max-height: 220px; } to { transform: translateX(115%); opacity: 0; max-height: 0; padding: 0; margin-bottom: -10px; } }

.toast-hdr    { display: flex; align-items: center; gap: 9px; margin-bottom: 7px; }
.toast-icon   { width: 32px; height: 32px; border-radius: 9px; background: rgba(225,29,72,.18); border: 1px solid rgba(225,29,72,.25); display: flex; align-items: center; justify-content: center; font-size: 14px; color: var(--brand); flex-shrink: 0; }
.toast-badge  { display: inline-flex; align-items: center; gap: 4px; background: rgba(225,29,72,.18); border: 1px solid rgba(225,29,72,.3); border-radius: 20px; padding: 1px 8px; font-size: .6rem; font-weight: 800; letter-spacing: .5px; color: var(--brand); text-transform: uppercase; }
.toast-title-row { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.toast-email-txt { font-size: .62rem; color: #888; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.toast-close { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); color: #666; cursor: pointer; font-size: 11px; padding: 3px 5px; border-radius: 6px; line-height: 1; transition: .15s; }
.toast-close:hover { color: #fff; background: rgba(255,255,255,.14); }
.toast-val-wrap { display: flex; align-items: center; gap: 8px; background: rgba(0,0,0,.3); border: 1px solid rgba(255,255,255,.06); border-radius: 9px; padding: 8px 10px; margin-bottom: 10px; }
.toast-val-code { font-family: monospace; font-size: 1.3rem; font-weight: 900; color: #fff; letter-spacing: 4px; flex: 1; text-shadow: 0 0 14px rgba(225,29,72,.7); }
.toast-val-link { font-size: .65rem; font-weight: 600; color: #a78bfa; flex: 1; word-break: break-all; line-height: 1.4; }
.toast-copy-btn { background: rgba(225,29,72,.18); border: 1px solid rgba(225,29,72,.3); border-radius: 7px; padding: 5px 8px; color: var(--brand); font-size: 11px; cursor: pointer; white-space: nowrap; transition: .15s; flex-shrink: 0; }
.toast-copy-btn:hover { background: rgba(225,29,72,.35); }
.toast-progress { position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: rgba(255,255,255,.06); }
.toast-progress-bar { height: 100%; border-radius: 0 0 0 14px; background: linear-gradient(90deg,var(--brand),#ff7eb3); animation: toastProg 4s linear forwards; }
@keyframes toastProg { from { width: 100%; } to { width: 0%; } }

/* ══ RESULT BOTTOM SHEET ══ */
.overlay-sheet {
  position: fixed; inset: 0;
  background: rgba(2,1,3,.72); backdrop-filter: blur(28px) saturate(1.6);
  display: flex; align-items: flex-end; justify-content: center;
  z-index: 700; opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.overlay-sheet.open { opacity: 1; pointer-events: all; }
.sheet {
  width: 100%; max-width: 620px;
  background: linear-gradient(180deg,rgba(225,29,72,.055) 0%,transparent 40%),linear-gradient(175deg,#1a0d12 0%,#100608 55%,#090405 100%);
  border: 1px solid rgba(225,29,72,.18);
  border-bottom: none;
  border-radius: 32px 32px 0 0;
  box-shadow: 0 -32px 100px rgba(0,0,0,.9),0 -1px 0 rgba(225,29,72,.22),0 0 60px rgba(225,29,72,.06) inset;
  max-height: 90vh; overflow-y: auto;
  transform: translateY(100%);
  transition: transform .38s cubic-bezier(.28,1.22,.6,1);
}
.overlay-sheet.open .sheet { transform: translateY(0); }
.sheet-drag { display: flex; justify-content: center; padding: 14px 0 6px; cursor: grab; }
.sheet-drag::before { content: ''; width: 44px; height: 4px; border-radius: 4px; background: linear-gradient(90deg,transparent,rgba(225,29,72,.35),transparent); }
.sheet-hdr { display: flex; align-items: center; justify-content: space-between; padding: 6px 28px 20px; border-bottom: 1px solid rgba(255,255,255,.06); }
.sheet-icon { width: 46px; height: 46px; border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1rem; color: #fff; flex-shrink: 0; box-shadow: 0 6px 24px rgba(0,0,0,.55); }
.sheet-title { display: flex; align-items: center; gap: 13px; }
.sheet-title-txt { font-size: 1rem; font-weight: 800; color: var(--txt); letter-spacing: -.01em; }
.sheet-sub { font-size: .65rem; color: var(--txt3); margin-top: 3px; max-width: 320px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sheet-body { padding: 28px 28px 52px; }

.modal-close {
  width: 30px; height: 30px; border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08); background: rgba(255,255,255,.04);
  color: var(--txt3); cursor: pointer; font-size: .78rem;
  display: flex; align-items: center; justify-content: center; transition: all .16s; flex-shrink: 0;
}
.modal-close:hover { background: rgba(239,68,68,.14); border-color: rgba(239,68,68,.28); color: #fca5a5; transform: rotate(90deg) scale(1.1); }

/* Sheet content */
.sheet-code { text-align: center; padding: 28px 20px 20px; }
.sheet-code-num {
  font-size: 5rem; font-weight: 900; letter-spacing: .18em;
  background: linear-gradient(150deg,#a7f3d0 0%,#6ee7b7 30%,#34d399 65%,#10b981 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  line-height: 1; cursor: pointer; user-select: all;
  animation: codeIn .45s cubic-bezier(.34,1.56,.64,1); display: inline-block;
  filter: drop-shadow(0 0 28px rgba(16,185,129,.5)) drop-shadow(0 6px 18px rgba(16,185,129,.25));
}
@keyframes codeIn { from { opacity: 0; transform: scale(.84); } to { opacity: 1; transform: none; } }
.sheet-code-lbl { font-size: .7rem; font-weight: 700; color: var(--txt3); letter-spacing: .1em; text-transform: uppercase; margin-top: 14px; }
.sheet-code-subj { font-size: .76rem; color: var(--txt2); margin-bottom: 20px; display: flex; align-items: center; justify-content: center; gap: 6px; }
.sheet-code-subj i { color: var(--red2); font-size: .65rem; }
.sheet-link-url { background: rgba(245,158,11,.06); border: 1px solid rgba(245,158,11,.18); border-radius: 16px; padding: 16px 18px; margin-bottom: 20px; font-size: .74rem; color: #fcd34d; word-break: break-all; line-height: 1.8; }
.sheet-copy-big {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  padding: 15px 28px; border-radius: 16px; font-size: .92rem; font-weight: 800;
  cursor: pointer; font-family: inherit; transition: all .22s cubic-bezier(.2,.8,.2,1);
  width: 100%; box-sizing: border-box; letter-spacing: .01em;
}
.sheet-copy-code { background: linear-gradient(135deg,rgba(16,185,129,.22),rgba(16,185,129,.07)); border: 1px solid rgba(16,185,129,.35); color: #6ee7b7; box-shadow: 0 4px 22px rgba(16,185,129,.12); }
.sheet-copy-code:hover { background: linear-gradient(135deg,rgba(16,185,129,.38),rgba(16,185,129,.16)); transform: translateY(-2px); }
.sheet-reset-btn {
  display: flex; align-items: center; justify-content: center; gap: 9px;
  padding: 15px 28px; border-radius: 16px;
  background: linear-gradient(135deg,rgba(245,158,11,.22),rgba(245,158,11,.07));
  border: 1px solid rgba(245,158,11,.34); color: #fde68a;
  font-size: .92rem; font-weight: 800; text-decoration: none;
  font-family: inherit; transition: all .22s; width: 100%; text-align: center;
}
.sheet-reset-btn:hover { background: linear-gradient(135deg,rgba(245,158,11,.38),rgba(245,158,11,.18)); transform: translateY(-2px); color: #fff; }
.sheet-err { display: flex; flex-direction: column; align-items: center; gap: 14px; padding: 44px 24px; text-align: center; }
.sheet-err i { font-size: 2.8rem; color: #f87171; opacity: .75; }
.sheet-err p { font-size: .84rem; color: #fca5a5; margin: 0; line-height: 1.8; max-width: 320px; }

/* Retry UI */
.retry-box { display: flex; flex-direction: column; gap: 7px; padding: 12px 14px; border-radius: 14px; background: rgba(225,29,72,.05); border: 1px solid rgba(225,29,72,.14); }
.retry-row { display: flex; align-items: center; gap: 8px; font-size: .78rem; color: var(--txt2); }
.retry-row i.fa-spinner { animation: spin .9s linear infinite; color: var(--red2); flex-shrink: 0; }
.retry-attempt { font-size: .62rem; color: var(--txt3); padding-left: 2px; }
.retry-countdown { display: inline-flex; align-items: center; justify-content: center; min-width: 22px; height: 22px; padding: 0 6px; border-radius: 7px; background: rgba(225,29,72,.16); border: 1px solid rgba(225,29,72,.25); font-size: .72rem; font-weight: 800; color: var(--red2); font-variant-numeric: tabular-nums; }
.retry-bar-wrap { height: 2px; border-radius: 2px; background: rgba(255,255,255,.06); overflow: hidden; }
.retry-bar { height: 100%; border-radius: 2px; background: linear-gradient(90deg,var(--brand),#fb7185); transition: width .1s linear; }
.retry-stop { align-self: flex-start; font-size: .62rem; font-weight: 700; padding: 4px 10px; border-radius: 7px; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); color: var(--txt3); cursor: pointer; transition: .14s; }
.retry-stop:hover { background: rgba(225,29,72,.14); color: var(--red2); border-color: rgba(225,29,72,.25); }

@keyframes spin { to { transform: rotate(360deg); } }
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

/* ── Sidebar overlay (mobile) ── */
.sidebar-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 99; }

/* ══ RESPONSIVE ══ */
@media (max-width: 820px) {
  .sidebar { position: fixed; top: 0; left: 0; height: 100dvh; width: min(268px,85vw); transform: translateX(-100%); z-index: 200; background: #0a0508; overflow-y: auto; }
  .sidebar.open { transform: translateX(0); }
  .sidebar-overlay.open { display: block; }
  .ham { display: flex; }
  .sec-grid { grid-template-columns: 1fr; }
  .email-actions { flex-direction: column; align-items: flex-end; }
}
@media (max-width: 500px) {
  .page { padding: 16px 14px; }
  .topbar { padding: 0 14px; height: 58px; }
  .email-card { flex-direction: column; padding: 16px; }
  .email-av { align-self: flex-start; }
  .email-actions { flex-direction: row; align-self: flex-end; }
  .fg-row { grid-template-columns: 1fr; }
  #toastWrap { right: 12px; bottom: 12px; }
}

/* ══ BTN HOUSE ══ */
.btn-house{background:rgba(139,92,246,.13);color:#c4b5fd;border:1px solid rgba(139,92,246,.3)}
.btn-house:hover{background:rgba(139,92,246,.26);box-shadow:0 4px 16px rgba(139,92,246,.24);transform:translateY(-2px)}

/* ══ BTN HIST ══ */
.btn-hist{background:rgba(225,29,72,.08);color:var(--red2);border:1px solid rgba(225,29,72,.2)}
.btn-hist:hover{background:rgba(225,29,72,.2);box-shadow:0 4px 14px rgba(225,29,72,.2);transform:translateY(-2px)}

/* ══ OVERLAY MODAL (history) ══ */
.overlay{
  position:fixed;inset:0;
  background:rgba(3,2,4,.72);backdrop-filter:blur(18px) saturate(1.4);
  display:flex;align-items:center;justify-content:center;padding:20px;
  z-index:600;opacity:0;pointer-events:none;transition:opacity .22s;
}
.overlay.open{opacity:1;pointer-events:all}
.modal{
  background:rgba(14,8,11,.97);
  border:1px solid rgba(225,29,72,.15);
  border-radius:26px;
  padding:0;width:100%;max-width:700px;max-height:88vh;overflow:hidden;
  display:flex;flex-direction:column;
  box-shadow:0 40px 100px rgba(0,0,0,.9);
  transform:translateY(24px) scale(.96);
  transition:transform .32s cubic-bezier(.34,1.44,.64,1);
}
.overlay.open .modal{transform:none}
.modal-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 20px 16px;
  border-bottom:1px solid rgba(255,255,255,.06);
  flex-shrink:0;
}
.modal-title{font-size:.92rem;font-weight:800;color:var(--txt);display:flex;align-items:center;gap:10px}
.modal-title i{
  width:32px;height:32px;border-radius:9px;
  background:var(--grad2);
  display:inline-flex;align-items:center;justify-content:center;
  color:#fff;font-size:.74rem;
  box-shadow:0 3px 12px rgba(225,29,72,.4);
  flex-shrink:0;
}
.modal-close{
  width:30px;height:30px;border-radius:8px;
  border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.04);
  color:var(--txt3);cursor:pointer;font-size:.78rem;
  display:flex;align-items:center;justify-content:center;transition:all .16s;
}
.modal-close:hover{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.28);color:#fca5a5;transform:rotate(90deg) scale(1.1)}
