/* =============================================================
   Tujuan: stylesheet utama RathurMail, termasuk landing, inbox, login,
   dan halaman /domains dengan responsive mobile yang tidak tabrakan.
   Dipakai oleh: views/layout.ejs, views/index.ejs, views/domains.ejs,
   views/admin.ejs, dan route web Express.
   Dependensi utama: CSS custom properties, Font Awesome class icon,
   markup EJS di folder views.
   Fungsi public/utama: layout app shell, form, toolbar, DNS table,
   domain list, toast, dan responsive <=640px.
   Side effect penting: hanya mengatur tampilan browser; tidak melakukan
   DB read/write, HTTP call, atau file I/O.
   RathurMail v1.0 — Premium UI
   Adopted from mehmetkahya0/temp-mail v4.0 style
   ============================================================= */

/* ── CSS Custom Properties ── */
:root {
  --primary: #3B82F6;
  --primary-hover: #2563EB;
  --primary-light: rgba(59,130,246,0.1);
  --secondary: #60A5FA;
  --accent: #8B5CF6;
  --accent-light: rgba(139,92,246,0.1);
  --success: #10B981;
  --success-light: rgba(16,185,129,0.1);
  --warning: #F59E0B;
  --warning-light: rgba(245,158,11,0.1);
  --error: #EF4444;
  --error-light: rgba(239,68,68,0.1);
  --text: #1F2937;
  --text-secondary: #6B7280;
  --text-tertiary: #9CA3AF;
  --bg: #F3F4F6;
  --bg-secondary: #E5E7EB;
  --card: #FFFFFF;
  --card-hover: #FAFBFC;
  --border: #E5E7EB;
  --border-hover: #D1D5DB;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 4px 6px -1px rgba(0,0,0,0.08),0 2px 4px -2px rgba(0,0,0,0.04);
  --shadow-lg: 0 10px 25px -3px rgba(0,0,0,0.1),0 4px 6px -4px rgba(0,0,0,0.06);
  --radius-sm: 0.375rem;
  --radius: 0.625rem;
  --radius-lg: 1rem;
  --radius-xl: 1.25rem;
  --radius-full: 9999px;
  --transition: 0.2s cubic-bezier(0.4,0,0.2,1);
  --transition-spring: 0.4s cubic-bezier(0.34,1.56,0.64,1);
  --glass: rgba(255,255,255,0.7);
  --glass-border: rgba(255,255,255,0.2);
  --blob-1: rgba(99,102,241,0.12);
  --blob-2: rgba(139,92,246,0.12);
  --blob-3: rgba(6,182,212,0.10);
  --blob-4: rgba(236,72,153,0.08);
  --noise-opacity: 0.02;
}

[data-theme="dark"] {
  --primary: #60A5FA;
  --primary-hover: #3B82F6;
  --primary-light: rgba(96,165,250,0.12);
  --secondary: #93C5FD;
  --accent: #A78BFA;
  --accent-light: rgba(167,139,250,0.12);
  --success: #34D399;
  --success-light: rgba(52,211,153,0.12);
  --warning: #FBBF24;
  --warning-light: rgba(251,191,36,0.12);
  --error: #F87171;
  --error-light: rgba(248,113,113,0.12);
  --text: #F9FAFB;
  --text-secondary: #D1D5DB;
  --text-tertiary: #9CA3AF;
  --bg: #0F172A;
  --bg-secondary: #1E293B;
  --card: #1E293B;
  --card-hover: #263248;
  --border: #334155;
  --border-hover: #475569;
  --glass: rgba(30,41,59,0.8);
  --glass-border: rgba(51,65,85,0.5);
  --blob-1: rgba(37,99,235,0.28);
  --blob-2: rgba(124,58,237,0.25);
  --blob-3: rgba(8,145,178,0.22);
  --blob-4: rgba(219,39,119,0.15);
  --noise-opacity: 0.038;
}

/* ── Reset ── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  line-height: 1.6;
  min-height: 100vh;
  transition: background 0.35s ease, color var(--transition);
  -webkit-font-smoothing: antialiased;
}
body::before {
  content:''; position:fixed; inset:0; z-index:-1;
  background-image: radial-gradient(var(--border) 1px, transparent 1px);
  background-size: 24px 24px; opacity:0.4; pointer-events:none;
}
a { color: var(--primary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--primary-hover); }

/* ── Aurora & Noise (Optimized for Performance) ── */
.noise-overlay {
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  opacity: var(--noise-opacity);
  /* Removed heavy SVG feTurbulence filter to fix lag */
  background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyBAMAAADsEZWCAAAAGFBMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/OOTzAAAACHRSTlMAMwAAMwAAM2y1sCwAAAC2SURBVDjLpZFBSgMxEEW/wzW4cgGvIG7c9Qj1CkK9QtwruPcUeT2TzCSTlA7u/x+S/2Qy+U/btu1wOBzO5/Ptdrve7/fH4/F8Pt/v90+n0/1+/w+Hw+FwOBwOh8PhcDgcDofD4XA4HA6Hw+FwOBwOh8PhcDgcDofD4XA4HA6Hw+FwOBwOh8PhcDgcDofD4XA4HA6Hw+FwOBwOh8PhcDgcDofD4XA4HA6Hw+FwOBwOh8PhcDgc/gTf4Q/yK2+wQ3IAAAAASUVORK5CYII=");
  background-repeat: repeat;
}
.aurora-bg { position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none; }
.aurora-blob {
  position:absolute; width:48rem; height:48rem; border-radius:50%;
  filter:blur(100px); opacity:0.8; mix-blend-mode:normal;
  will-change: transform; transform: translateZ(0);
}
.aurora-blob:nth-child(1) { top:-16rem; left:-12rem; background:radial-gradient(circle at 40% 40%,var(--blob-1),transparent 70%); animation:bf1 25s ease-in-out infinite; }
.aurora-blob:nth-child(2) { top:15%; right:-16rem; background:radial-gradient(circle at 40% 40%,var(--blob-2),transparent 70%); animation:bf2 28s ease-in-out infinite; }
.aurora-blob:nth-child(3) { bottom:-20rem; left:5%; background:radial-gradient(circle at 40% 40%,var(--blob-3),transparent 70%); animation:bf3 32s ease-in-out infinite; }
.aurora-blob:nth-child(4) { bottom:15%; right:15%; background:radial-gradient(circle at 40% 40%,var(--blob-4),transparent 70%); animation:bf4 22s ease-in-out infinite; }
@keyframes bf1 { 0%{transform:translate3d(0,0,0) scale(1)} 33%{transform:translate3d(4rem,-3rem,0) scale(1.1)} 66%{transform:translate3d(-2rem,3rem,0) scale(0.95)} 100%{transform:translate3d(0,0,0) scale(1)} }
@keyframes bf2 { 0%{transform:translate3d(0,0,0) scale(1)} 50%{transform:translate3d(-5rem,4rem,0) scale(1.15)} 100%{transform:translate3d(0,0,0) scale(1)} }
@keyframes bf3 { 0%{transform:translate3d(0,0,0) scale(1)} 40%{transform:translate3d(3rem,5rem,0) scale(0.9)} 80%{transform:translate3d(-4rem,-2rem,0) scale(1.05)} 100%{transform:translate3d(0,0,0) scale(1)} }
@keyframes bf4 { 0%{transform:translate3d(0,0,0) scale(1)} 50%{transform:translate3d(6rem,-4rem,0) scale(1.1)} 100%{transform:translate3d(0,0,0) scale(1)} }

/* ── Layout ── */
.app-container { max-width:960px; margin:0 auto; padding:1.5rem; min-height:100vh; display:flex; flex-direction:column; gap:1.5rem; }
.main-content { display:flex; flex-direction:column; gap:1.25rem; flex:1; }

/* ── App Bar ── */
.app-bar {
  position:sticky; top:0.75rem; z-index:60; display:flex; align-items:center;
  justify-content:space-between; gap:0.75rem; padding:0.65rem 1rem;
  border-radius:var(--radius-lg); background:var(--glass);
  border:1px solid var(--glass-border); box-shadow:var(--shadow-sm);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
}
.app-bar-logo { display:flex; align-items:center; gap:0.5rem; font-weight:700; text-decoration:none; color:var(--text); }
.app-bar-logo-img { width:28px; height:28px; object-fit:contain; }
.app-bar-logo h1 { font-size:1rem; letter-spacing:-0.01em; }
.app-bar-version {
  font-size:0.625rem; color:var(--text-tertiary); background:var(--bg);
  border:1px solid var(--border); padding:0.1rem 0.35rem; border-radius:var(--radius-full);
}
.app-bar-center { display:flex; align-items:center; gap:0.5rem; flex:1; justify-content:center; }
.app-bar-right { display:flex; align-items:center; gap:0.5rem; }
.app-bar-separator { width:1px; height:1.25rem; background:var(--border); display:inline-block; }

/* ── Badge & Status ── */
.badge {
  display:inline-flex; align-items:center; gap:0.375rem; font-size:0.75rem;
  color:var(--text-secondary); padding:0.25rem 0.6rem; background:var(--bg);
  border:1px solid var(--border); border-radius:var(--radius-full);
}
.status-led { width:6px; height:6px; border-radius:50%; }
.status-led.online { background:#10B981; box-shadow:0 0 6px rgba(16,185,129,0.5); }
.badge-count {
  background:var(--primary-light); color:var(--primary); font-size:0.75rem;
  font-weight:600; padding:0.125rem 0.5rem; border-radius:var(--radius-full);
}

/* ── Theme Switch ── */
.theme-switch-wrapper { display:flex; align-items:center; gap:0.4rem; }
.theme-switch-wrapper i { font-size:0.8rem; color:var(--text-tertiary); transition:all var(--transition); }
[data-theme="dark"] .fa-moon { color:var(--primary) !important; }
[data-theme="light"] .fa-sun { color:var(--primary) !important; }
.switch { position:relative; display:inline-block; width:36px; height:20px; }
.switch input { opacity:0; width:0; height:0; }
.slider {
  position:absolute; cursor:pointer; inset:0; background:var(--border);
  border-radius:20px; transition:var(--transition);
}
.slider::before {
  content:''; position:absolute; height:14px; width:14px; left:3px; bottom:3px;
  background:white; border-radius:50%; transition:var(--transition);
}
.switch input:checked + .slider { background:var(--primary); }
.switch input:checked + .slider::before { transform:translateX(16px); }

/* ── Buttons ── */
.btn {
  display:inline-flex; align-items:center; gap:0.4rem; padding:0.5rem 1rem;
  border:1px solid transparent; border-radius:var(--radius); font-family:inherit;
  font-size:0.8125rem; font-weight:500; cursor:pointer; transition:all var(--transition);
  text-decoration:none; white-space:nowrap;
}
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn-sm { padding:0.35rem 0.65rem; font-size:0.75rem; }
.btn-primary { background:var(--primary); color:white; }
.btn-primary:hover { background:var(--primary-hover); box-shadow:0 4px 12px rgba(59,130,246,0.3); }
.btn-accent { background:linear-gradient(135deg,var(--primary),var(--accent)); color:white; border:none; }
.btn-accent:hover { box-shadow:0 4px 16px rgba(99,102,241,0.4); }
.btn-outline { background:transparent; color:var(--text); border-color:var(--border); }
.btn-outline:hover { border-color:var(--primary); color:var(--primary); background:var(--primary-light); }
.btn-ghost { background:transparent; color:var(--text-secondary); }
.btn-ghost:hover { color:var(--primary); background:var(--primary-light); }
.btn-danger { background:var(--error); color:white; }
.btn-danger:hover { background:#DC2626; }
.btn-danger-outline { background:transparent; color:var(--error); border-color:var(--error); }
.btn-danger-outline:hover { background:var(--error-light); }
.btn-block { width:100%; justify-content:center; }
.btn-copy { min-width:auto; }

/* ── Hero Email Card (Optimized) ── */
.hero-email-card {
  position:relative; border-radius:var(--radius-lg); padding:2px;
  background: linear-gradient(135deg, var(--primary), var(--accent), #06B6D4);
  box-shadow:var(--shadow-lg);
}
.hero-email-inner {
  background:var(--card); border-radius:calc(var(--radius-lg) - 2px);
  padding:1.5rem; display:flex; flex-direction:column; gap:1rem;
}
.hero-label { font-size:0.75rem; color:var(--text-tertiary); text-transform:uppercase; letter-spacing:0.05em; font-weight:600; }
.hero-email-row { display:flex; align-items:center; gap:0.75rem; }
.hero-email-display {
  flex:1; display:flex; align-items:center; gap:0.6rem; padding:0.65rem 1rem;
  background:var(--bg); border:1px solid var(--border); border-radius:var(--radius);
  font-size:1.05rem; font-weight:500; letter-spacing:0.01em;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.hero-email-display i { color:var(--primary); flex-shrink:0; }
#email-address { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; flex:1; }
.hero-controls { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.hero-generate-form { display:flex; align-items:center; gap:0.5rem; }
.domain-select-wrapper {
  position:relative; display:flex; align-items:center;
}
.domain-select-wrapper i { position:absolute; left:0.75rem; color:var(--text-tertiary); font-size:0.8rem; pointer-events:none; z-index:1; }
.domain-select {
  appearance:none; padding:0.5rem 2rem 0.5rem 2rem; font-family:inherit;
  font-size:0.8125rem; background:var(--bg); color:var(--text);
  border:1px solid var(--border); border-radius:var(--radius); cursor:pointer;
  transition:all var(--transition);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 0.6rem center;
}
.domain-select:hover { border-color:var(--primary); }
.hero-refresh-controls { display:flex; align-items:center; gap:0.5rem; margin-left:auto; }
.auto-refresh-label { display:flex; align-items:center; gap:0.35rem; font-size:0.75rem; color:var(--text-secondary); cursor:pointer; }
.auto-refresh-label input { accent-color:var(--primary); }
.refresh-select {
  appearance:none; padding:0.25rem 0.5rem; font-family:inherit; font-size:0.7rem;
  background:var(--bg); color:var(--text-secondary); border:1px solid var(--border);
  border-radius:var(--radius-sm); cursor:pointer;
}

/* ── Inbox Card ── */
.inbox-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow-sm);
}
.inbox-header {
  display:flex; align-items:center; gap:0.75rem; padding:1rem 1.25rem;
  border-bottom:1px solid var(--border);
}
.inbox-header h2 { font-size:0.9375rem; font-weight:600; display:flex; align-items:center; gap:0.4rem; }
.inbox-header h2 i { color:var(--primary); }
.inbox-actions { display:flex; gap:0.5rem; margin-left:auto; }
.inbox-search {
  display:flex; align-items:center; gap:0.5rem; padding:0.6rem 1.25rem;
  border-bottom:1px solid var(--border);
}
.inbox-search i { color:var(--text-tertiary); font-size:0.8rem; }
.inbox-search input {
  flex:1; border:none; background:transparent; color:var(--text); font-family:inherit;
  font-size:0.8125rem; outline:none;
}
.inbox-search input::placeholder { color:var(--text-tertiary); }

/* ── Email List ── */
.email-list { display:flex; flex-direction:column; }
.email-row {
  display:flex; align-items:center; gap:0.75rem; padding:0.85rem 1.25rem;
  border-bottom:1px solid var(--border); color:var(--text); text-decoration:none;
  transition:background var(--transition);
}
.email-row:last-child { border-bottom:none; }
.email-row:hover { background:var(--card-hover); }
.email-row.unread { font-weight:500; }
.email-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.email-dot.active { background:var(--primary); box-shadow:0 0 6px rgba(59,130,246,0.4); }
.email-avatar {
  width:36px; height:36px; border-radius:50%; display:flex; align-items:center;
  justify-content:center; color:white; font-weight:700; font-size:0.875rem; flex-shrink:0;
}
.email-content { flex:1; min-width:0; }
.email-from { font-size:0.8125rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.email-subject { font-size:0.75rem; color:var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.email-meta { flex-shrink:0; }
.email-time { font-size:0.6875rem; color:var(--text-tertiary); }
.inbox-empty {
  padding:3rem 1.5rem; text-align:center; color:var(--text-tertiary);
  display:flex; flex-direction:column; align-items:center; gap:0.5rem;
}
.inbox-empty i { font-size:2.5rem; opacity:0.3; }
.inbox-empty p { font-weight:500; color:var(--text-secondary); }

/* ── Email Reader (Full Page) ── */
.email-toolbar {
  display:flex; align-items:center; justify-content:space-between; gap:0.75rem;
}
.email-toolbar-right { display:flex; align-items:center; gap:0.4rem; }
.read-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow);
}
.read-header { padding:1.5rem 1.5rem 0; }
.read-subject { font-size:1.25rem; font-weight:700; line-height:1.4; margin-bottom:1rem; }
.read-meta { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:0.75rem; }
.read-sender { display:flex; align-items:center; gap:0.75rem; }
.read-sender-info { display:flex; flex-direction:column; }
.read-from { font-size:0.875rem; font-weight:600; }
.read-to { font-size:0.75rem; color:var(--text-tertiary); }
.read-date { font-size:0.75rem; color:var(--text-tertiary); display:flex; align-items:center; gap:0.35rem; }
.read-divider { height:1px; background:var(--border); margin:1.25rem 0 0; }
.read-body { padding:1.5rem; min-height:200px; }
.read-text {
  font-family:inherit; font-size:0.875rem; line-height:1.7; white-space:pre-wrap;
  word-wrap:break-word; color:var(--text);
}
.email-iframe {
  width:100%; min-height:300px; border:none; background:white; border-radius:var(--radius);
}
.read-footer {
  display:flex; align-items:center; gap:1.5rem; padding:0.85rem 1.5rem;
  border-top:1px solid var(--border); font-size:0.7rem; color:var(--text-tertiary);
}
.read-footer i { margin-right:0.25rem; }

/* ── Welcome Card ── */
.welcome-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:3rem 2rem; text-align:center; box-shadow:var(--shadow-sm);
}
.welcome-icon { font-size:3rem; color:var(--primary); margin-bottom:1rem; opacity:0.7; }
.welcome-card h2 { font-size:1.25rem; margin-bottom:0.5rem; }
.welcome-card p { color:var(--text-secondary); font-size:0.875rem; margin-bottom:1.5rem; }
.welcome-features { display:flex; justify-content:center; gap:2rem; flex-wrap:wrap; }
.feature { display:flex; align-items:center; gap:0.5rem; font-size:0.8125rem; color:var(--text-secondary); }
.feature i { color:var(--primary); }
.welcome-notice {
  display:flex; align-items:center; gap:0.5rem; padding:0.75rem 1rem;
  background:var(--warning-light); border:1px solid var(--warning);
  border-radius:var(--radius); font-size:0.8125rem; color:var(--warning);
  margin-bottom:1.5rem; justify-content:center;
}

/* ── Login ── */
.login-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:2.5rem 2rem; text-align:center; max-width:380px; margin:3rem auto;
  box-shadow:var(--shadow-lg);
}
.login-icon { font-size:2.5rem; color:var(--primary); margin-bottom:1rem; }
.login-card h2 { margin-bottom:0.5rem; }
.login-card p { color:var(--text-secondary); font-size:0.8125rem; margin-bottom:1.5rem; }
.login-form { display:flex; flex-direction:column; gap:0.75rem; }
.login-error {
  background:var(--error-light); color:var(--error); padding:0.6rem 1rem;
  border-radius:var(--radius); font-size:0.8125rem; margin-bottom:0.5rem;
  display:flex; align-items:center; gap:0.4rem;
}
.login-back { display:block; margin-top:1.25rem; font-size:0.8125rem; color:var(--text-tertiary); }

/* ── Input Group ── */
.input-group {
  position:relative; display:flex; align-items:center;
}
.input-group i { position:absolute; left:0.85rem; color:var(--text-tertiary); font-size:0.85rem; }
.input-group input {
  width:100%; padding:0.6rem 1rem 0.6rem 2.5rem; font-family:inherit;
  font-size:0.875rem; background:var(--bg); color:var(--text);
  border:1px solid var(--border); border-radius:var(--radius);
  transition:all var(--transition); outline:none;
}
.input-group input:focus { border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-light); }

/* ── Domains Page ── */
.domains-page { display:flex; flex-direction:column; gap:1.25rem; }
.page-title { font-size:1.125rem; font-weight:700; display:flex; align-items:center; gap:0.5rem; }
.page-title i { color:var(--primary); }
.domain-add-card, .domain-list-card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1.5rem; box-shadow:var(--shadow-sm);
}
.domain-add-card h3, .domain-list-card h3 { font-size:0.9375rem; font-weight:600; margin-bottom:1rem; }
.domain-add-form { display:flex; gap:0.5rem; margin-bottom:1.25rem; }
.domain-add-form .input-group { flex:1; }
.dns-instructions { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); padding:1.25rem; }
.dns-instructions h4 { font-size:0.8125rem; font-weight:600; margin-bottom:0.5rem; display:flex; align-items:center; gap:0.4rem; }
.dns-instructions h4 i { color:var(--primary); }
.dns-instructions p { font-size:0.75rem; color:var(--text-secondary); margin-bottom:0.75rem; }
.dns-table-wrapper { width:100%; overflow-x:auto; }
.dns-table { width:100%; border-collapse:collapse; font-size:0.8125rem; min-width: 400px; }
.dns-table th { text-align:left; padding:0.4rem 0.6rem; color:var(--text-tertiary); font-weight:500; font-size:0.7rem; text-transform:uppercase; letter-spacing:0.05em; }
.dns-table td { padding:0.5rem 0.6rem; border-top:1px solid var(--border); }
.dns-table code { font-family:'JetBrains Mono',monospace; font-size:0.75rem; background:var(--card); padding:0.15rem 0.4rem; border-radius:4px; }
.dns-badge { font-size:0.625rem; font-weight:700; padding:0.15rem 0.5rem; border-radius:var(--radius-sm); text-transform:uppercase; letter-spacing:0.05em; }
.dns-badge.mx { background:var(--primary-light); color:var(--primary); }
.dns-badge.txt { background:var(--accent-light); color:var(--accent); }

/* ── Domain List ── */
.domain-list { display:flex; flex-direction:column; gap:0.5rem; }
.domain-row {
  display:flex; align-items:center; gap:0.75rem; padding:0.85rem 1rem;
  background:var(--bg); border:1px solid var(--border); border-radius:var(--radius);
  transition:all var(--transition);
}
.domain-row:hover { border-color:var(--border-hover); }
.domain-info { flex:1; display:flex; flex-direction:column; }
.domain-name { font-weight:600; font-size:0.875rem; }
.domain-meta { font-size:0.7rem; color:var(--text-tertiary); }
.domain-badges { display:flex; gap:0.4rem; }
.status-badge {
  font-size:0.625rem; font-weight:600; padding:0.2rem 0.6rem;
  border-radius:var(--radius-full); text-transform:uppercase; letter-spacing:0.03em;
}
.status-badge.verified { background:var(--success-light); color:var(--success); }
.status-badge.pending { background:var(--warning-light); color:var(--warning); }
.domain-actions { display:flex; gap:0.35rem; }

/* ── Toast ── */
.toast-container { position:fixed; top:1rem; right:1rem; z-index:9999; display:flex; flex-direction:column; gap:0.5rem; }
.toast {
  padding:0.75rem 1.25rem; border-radius:var(--radius); font-size:0.8125rem;
  font-weight:500; box-shadow:var(--shadow-lg); backdrop-filter:blur(12px);
  animation:toastIn 0.3s var(--transition-spring);
  display:flex; align-items:center; gap:0.5rem;
}
.toast.success { background:var(--success); color:white; }
.toast.error { background:var(--error); color:white; }
.toast.warning { background:var(--warning); color:#1F2937; }
.toast.info { background:var(--primary); color:white; }
@keyframes toastIn { from { transform:translateX(100%); opacity:0; } to { transform:translateX(0); opacity:1; } }

/* ── Footer ── */
.app-footer {
  text-align:center; padding:1rem 0; font-size:0.75rem; color:var(--text-tertiary);
  display:flex; align-items:center; justify-content:center; gap:0.5rem;
}
.app-footer-dot { opacity:0.4; }

/* ── Responsive ── */
@media (max-width: 640px) {
  .app-container { padding:1rem; }
  .app-bar { flex-wrap:wrap; gap:0.5rem; padding:0.5rem 0.75rem; }
  .app-bar-center { display:none; }
  .hero-email-display { font-size:0.85rem; }
  .hero-email-row { flex-direction:column; align-items:stretch; }
  .hero-controls { flex-direction:column; align-items:stretch; }
  .hero-generate-form { flex-direction:column; align-items:stretch; }
  .domain-select { background-position: right 0.6rem center; padding-right: 2rem; }
  .hero-refresh-controls { margin-left:0; justify-content:space-between; }
  .email-toolbar { flex-direction:column; gap:0.5rem; align-items:stretch; }
  .email-toolbar-right { justify-content:space-between; width:100%; }
  .read-meta { flex-direction:column; align-items:flex-start; }
  .read-footer { flex-wrap:wrap; gap:0.75rem; }
  .hide-mobile { display:none; }
  .domains-page { gap:0.8rem; }
  .page-title { align-items:center; font-size:1rem; line-height:1.25; }
  .domain-add-card,
  .domain-list-card { padding:0.9rem; border-radius:0.85rem; }
  .domain-add-card h3,
  .domain-list-card h3 { margin-bottom:0.7rem; }
  .domain-add-card p { margin-bottom:1rem !important; line-height:1.45 !important; overflow-wrap:anywhere; }
  .domain-add-card code,
  .dns-table code { max-width:100%; overflow-wrap:anywhere; word-break:break-word; }
  .domain-add-form { flex-direction:column; margin-bottom:0; }
  .domain-add-form .btn { width:100%; }
  .domain-row {
    display:grid;
    grid-template-columns:auto minmax(0, 1fr);
    align-items:start;
    gap:0.55rem 0.75rem;
    padding:0.85rem;
  }
  .domain-status { padding-top:0.1rem; }
  .domain-info { min-width:0; flex:initial; }
  .domain-name {
    display:block;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .domain-badges {
    grid-column:2;
    width:auto;
    min-width:0;
    flex-wrap:wrap;
  }
  .domain-actions {
    grid-column:1 / -1;
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(86px, 1fr));
    width:100%;
    gap:0.45rem;
    justify-content:stretch;
  }
  .domain-actions .btn {
    width:100%;
    min-height:2.25rem;
    justify-content:center;
    padding-inline:0.6rem;
    white-space:nowrap;
  }
  .domain-actions .btn-delete { min-width:2.5rem; }
  .dns-instructions { padding:0.85rem; border-radius:0.75rem; }
  .dns-instructions h4 { margin-bottom:0.65rem; }
  .dns-table-wrapper { overflow-x: hidden; }
  .dns-table { min-width: auto; font-size: 0.8rem; }
  .dns-table thead { display: none; }
  .dns-table tr {
    display:block;
    position:relative;
    padding-right:2.35rem;
    background:transparent;
  }
  .dns-table td {
    display:grid;
    grid-template-columns:4rem minmax(0, 1fr);
    align-items:center;
    gap:0.45rem;
    min-height:2.1rem;
    border-top:1px solid var(--border);
    padding:0.35rem 0;
  }
  .dns-table td:first-child { border-top:0; }
  .dns-table td::before { content: attr(data-label); color:var(--text-tertiary); font-weight:700; font-size:0.63rem; text-transform:uppercase; letter-spacing:0.04em; }
  .dns-table td[data-label="Value"] code {
    display:inline-block;
    width:auto;
    max-width:100%;
    box-sizing:border-box;
    font-size:0.66rem;
    line-height:1.4;
    padding:0.3rem 0.38rem;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:clip;
    word-break:normal;
  }
  .dns-table td[data-label="Copy"] { position:absolute; right:0; top:0; margin:0; display:block; min-height:0; border:0; padding:0; }
  .dns-table td[data-label="Copy"]::before { display: none; }
  .email-row { flex-wrap:wrap; gap:0.75rem; }
  .email-content { flex: 1 1 100%; order: 3; }
  .email-meta { margin-left: auto; }
}
