/* ═══════════════════════════════════════════════════════
   DirectDesire — V3 Plum Violet Design System
   ═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Cinzel:wght@400;600&family=Jost:wght@300;400;500&display=swap');

/* ── Tokens ──────────────────────────────────────────── */
:root {
  --bg:       #141018;
  --card:     #1E1425;
  --card2:    #261830;
  --plum:     #7020A0;
  --plum2:    #A840C8;
  --accent:   #D098C0;
  --muted:    #AC92A6;
  --text:     #F2E8F5;
  --online:   #6ED4A0;
  --gold:     #C9A050;
  --danger:   #C84040;
  --border:   rgba(160,64,200,0.18);
  --border2:  rgba(160,64,200,0.35);
  --radius:   10px;
  --radius-sm:6px;
  --nav-h:    54px;
  --nav-icon-h:52px;
  --sidebar-w:268px;
  --transition: 0.18s ease;
}

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:1.125rem; scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Jost', sans-serif;
  font-weight: 400;
  min-height: 100vh;
  line-height: 1.6;
}
a { color: var(--accent); text-decoration:none; }
a:hover { color: var(--plum2); }
img { display:block; max-width:100%; }
input, textarea, select, button { font-family:inherit; font-size:inherit; }

/* ── Scrollbar ───────────────────────────────────────── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background: var(--card); }
::-webkit-scrollbar-thumb { background: var(--plum); border-radius:3px; }

/* ═══════════════════════════════════════════════════════
   NAV BAR
   ═══════════════════════════════════════════════════════ */
.dd-nav-top {
  position: sticky; top:0; z-index:900;
  background: rgba(20,16,24,0.97);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  height: var(--nav-h);
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 20px;
}
.dd-nav-logo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  font-style: italic;
  color: var(--text);
  letter-spacing: .04em;
}
.dd-nav-logo span { color: var(--plum2); }

.dd-nav-actions { display:flex; align-items:center; gap:6px; }

.dd-free-toggle {
  display:flex; align-items:center; gap:8px;
  font-family:'Cinzel',serif; font-size:.62rem; letter-spacing:.1em;
  color: var(--muted); cursor:pointer; padding:6px 10px;
  border:1px solid var(--border); border-radius:20px;
  background:transparent; transition:var(--transition);
}
.dd-free-toggle:hover { border-color:var(--gold); color:var(--gold); }
.dd-free-toggle.active { border-color:var(--gold); color:var(--gold); background:rgba(201,160,80,.08); }
.dd-toggle-switch {
  width:30px; height:16px; border-radius:8px;
  background: var(--card2); position:relative;
  transition:var(--transition); flex-shrink:0;
  border:1px solid var(--border2);
}
.dd-toggle-switch::after {
  content:''; position:absolute; top:2px; left:2px;
  width:10px; height:10px; border-radius:50%;
  background:var(--muted); transition:var(--transition);
}
.dd-free-toggle.active .dd-toggle-switch { background:rgba(201,160,80,.3); border-color:var(--gold); }
.dd-free-toggle.active .dd-toggle-switch::after { left:16px; background:var(--gold); }

.dd-nav-avatar-wrap { position:relative; }
.dd-nav-avatar-btn {
  display:flex; align-items:center; gap:8px;
  background:transparent; border:none; cursor:pointer;
  color:var(--text); padding:4px 8px; border-radius:var(--radius);
}
.dd-nav-avatar-btn:hover { background:var(--card2); }
.dd-nav-avatar-btn img, .dd-nav-avatar-btn .dd-avatar {
  width:34px; height:34px; border-radius:50%; object-fit:cover;
  border:2px solid var(--plum);
}
.dd-nav-handle { font-family:'Cinzel',serif; font-size:.65rem; letter-spacing:.08em; }
.dd-dropdown {
  position:absolute; right:0; top:calc(100% + 6px);
  background:var(--card2); border:1px solid var(--border2);
  border-radius:var(--radius); min-width:160px;
  box-shadow:0 8px 30px rgba(0,0,0,.5);
  display:none; flex-direction:column; overflow:hidden; z-index:999;
}
.dd-dropdown.open { display:flex; }
.dd-dropdown a {
  padding:10px 16px; color:var(--text); font-size:.85rem;
  transition:var(--transition);
}
.dd-dropdown a:hover { background:var(--plum); color:#fff; }

/* Icon nav bar */
.dd-nav-icons {
  background:var(--card);
  border-bottom:1px solid var(--border);
  height:var(--nav-icon-h);
  display:flex; align-items:center; justify-content:center;
  gap:4px; padding:0 12px; position:sticky;
  top:var(--nav-h); z-index:800;
}
.dd-nav-tab {
  display:flex; flex-direction:column; align-items:center;
  gap:2px; padding:6px 14px; border-radius:var(--radius-sm);
  color:var(--accent); font-family:'Cinzel',serif; font-size:.66rem;
  letter-spacing:.07em; text-transform:uppercase; position:relative;
  cursor:pointer; text-decoration:none; transition:var(--transition);
  border:1px solid transparent;
}
.dd-nav-tab:hover { color:var(--text); }
.dd-nav-tab.active {
  color:#fff; border-color:var(--border2);
  background:rgba(112,32,160,.20);
}
.dd-nav-tab .icon { font-size:1.3rem; }
.dd-badge {
  position:absolute; top:2px; right:6px;
  background:var(--plum2); color:#fff;
  font-family:'Jost',sans-serif; font-weight:500;
  font-size:.6rem; min-width:16px; height:16px;
  border-radius:8px; display:flex; align-items:center;
  justify-content:center; padding:0 4px;
}

/* ═══════════════════════════════════════════════════════
   APP LAYOUT (left sidebar + main + optional right)
   ═══════════════════════════════════════════════════════ */
.app-layout {
  display:grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: calc(100vh - var(--nav-h) - var(--nav-icon-h));
  align-items:start;
}
.app-layout.with-right {
  grid-template-columns: var(--sidebar-w) 1fr 260px;
}

/* ── Left Sidebar ─────────────────────────────────────── */
.dd-sidebar-left {
  position:sticky; top:calc(var(--nav-h) + var(--nav-icon-h));
  height: calc(100vh - var(--nav-h) - var(--nav-icon-h));
  overflow-y:auto; overflow-x:hidden;
  border-right:1px solid var(--border);
  background:var(--card);
  display:flex; flex-direction:column;
}

.sb-section { padding:12px 14px; border-bottom:1px solid var(--border); }
.sb-section-title {
  font-family:'Cinzel',serif; font-size:.72rem;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--muted); margin-bottom:8px;
}

/* Recently viewed thumbnails */
.sb-visited { display:flex; gap:6px; flex-wrap:wrap; }
.sb-visited-thumb {
  width:56px; height:56px; border-radius:var(--radius-sm);
  object-fit:cover; border:1px solid var(--border2);
  cursor:pointer; transition:var(--transition);
}
.sb-visited-thumb:hover { border-color:var(--plum2); transform:scale(1.05); }
.sb-visited-placeholder {
  width:56px; height:56px; border-radius:var(--radius-sm);
  background:var(--card2); border:1px dashed var(--border2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--muted);
}

/* Type filter pills */
.sb-type-filters { display:flex; gap:4px; flex-wrap:wrap; }
.sb-filter-pill {
  padding:3px 10px; border-radius:20px;
  font-family:'Cinzel',serif; font-size:.66rem;
  letter-spacing:.06em; cursor:pointer;
  border:1px solid var(--border2); color:var(--muted);
  background:transparent; transition:var(--transition);
  text-decoration:none;
}
.sb-filter-pill:hover, .sb-filter-pill.active {
  background:var(--plum); border-color:var(--plum); color:#fff;
}

/* Member list in sidebar */
.sb-member-list { flex:1; overflow-y:auto; }
.sb-member-row {
  display:flex; align-items:center; gap:8px;
  padding:7px 14px; cursor:pointer; transition:var(--transition);
  border-bottom:1px solid rgba(160,64,200,.07);
  text-decoration:none; color:inherit;
}
.sb-member-row:hover { background:rgba(112,32,160,.12); }
.sb-member-row-avatar { position:relative; flex-shrink:0; }
.sb-member-row-avatar img, .sb-member-row-avatar .dd-avatar {
  width:46px; height:46px; border-radius:50%; object-fit:cover;
  border:1px solid var(--border2);
}
.sb-pip {
  position:absolute; bottom:0; right:0;
  width:9px; height:9px; border-radius:50%;
  border:1px solid var(--card);
  background:var(--muted);
}
.sb-pip.online  { background:var(--online); }
.sb-pip.free    { background:var(--gold); }
.sb-member-info { flex:1; min-width:0; }
.sb-member-handle {
  font-size:.92rem; color:var(--text); font-weight:500;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sb-member-meta { font-size:.82rem; color:var(--muted); }
.sb-msg-btn {
  background:transparent; border:none; color:var(--muted);
  cursor:pointer; font-size:.9rem; padding:2px;
  transition:var(--transition);
}
.sb-msg-btn:hover { color:var(--plum2); }

/* ── Main content area ───────────────────────────────── */
.dd-main {
  padding: 20px 22px;
  min-width:0;
}

/* ── Right Sidebar ───────────────────────────────────── */
.dd-sidebar-right {
  position:sticky; top:calc(var(--nav-h) + var(--nav-icon-h));
  height:calc(100vh - var(--nav-h) - var(--nav-icon-h));
  overflow-y:auto; border-left:1px solid var(--border);
  background:var(--card); padding:14px;
  display:flex; flex-direction:column; gap:16px;
}
.rs-title {
  font-family:'Cinzel',serif; font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); margin-bottom:8px;
}

/* ═══════════════════════════════════════════════════════
   CARDS & COMPONENTS
   ═══════════════════════════════════════════════════════ */
.dd-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:var(--transition);
}
.dd-card:hover { border-color:var(--border2); }

.dd-card-body { padding:14px 16px; }

/* Member cards (grid layout) */
.dd-member-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:12px;
}
.dd-member-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  position:relative; cursor:pointer;
  transition:var(--transition);
}
.dd-member-card:hover { border-color:var(--plum2); transform:translateY(-2px); }
.dd-member-card .card-photo {
  width:100%; aspect-ratio:1; object-fit:cover;
  background:var(--card2);
}
.dd-member-card .card-photo-placeholder {
  width:100%; aspect-ratio:1; background:var(--card2);
  display:flex; align-items:center; justify-content:center;
  font-size:2rem;
}
.dd-member-card .card-info {
  padding:8px 10px;
}
.dd-member-card .card-handle {
  font-size:.82rem; font-weight:400; color:var(--text);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.dd-member-card .card-meta { font-size:.74rem; color:var(--muted); }

.dd-status-pip {
  display:inline-block; width:8px; height:8px;
  border-radius:50%; margin-right:4px;
}
.dd-status-pip.online  { background:var(--online); }
.dd-status-pip.offline { background:var(--muted); }
.dd-status-pip.free    { background:var(--gold); }

/* Feed cards */
.feed-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:12px;
  border-left:3px solid var(--border2);
  transition:var(--transition);
}
.feed-card.type-member   { border-left-color:var(--plum2); }
.feed-card.type-travel   { border-left-color:var(--online); }
.feed-card.type-event    { border-left-color:var(--gold); }
.feed-card.type-following{ border-left-color:var(--plum2); }
.feed-card-inner { padding:14px 16px; }
.feed-card-header {
  display:flex; align-items:center; gap:10px; margin-bottom:10px;
}
.feed-card-avatar { flex-shrink:0; }
.feed-card-avatar img, .feed-card-avatar .dd-avatar {
  width:42px; height:42px; border-radius:50%; object-fit:cover;
  border:2px solid var(--border2);
}
.feed-card-meta { flex:1; min-width:0; }
.feed-card-handle { font-size:.88rem; font-weight:400; color:var(--text); }
.feed-card-sub { font-size:.72rem; color:var(--muted); }
.feed-card-body { font-size:.88rem; color:var(--accent); }
.feed-card-actions { margin-top:10px; display:flex; gap:8px; }

/* ── Badges ──────────────────────────────────────────── */
.dd-badge-free {
  display:inline-flex; align-items:center; gap:3px;
  background:rgba(201,160,80,.15); border:1px solid rgba(201,160,80,.4);
  color:var(--gold); font-size:.65rem; font-family:'Cinzel',serif;
  letter-spacing:.06em; padding:1px 7px; border-radius:10px;
}
.dd-badge-type {
  display:inline-flex; align-items:center; gap:3px;
  background:rgba(112,32,160,.15); border:1px solid var(--border2);
  color:var(--accent); font-size:.65rem; font-family:'Cinzel',serif;
  letter-spacing:.05em; padding:2px 8px; border-radius:10px;
}
.dd-badge-online {
  display:inline-flex; align-items:center; gap:3px;
  color:var(--online); font-size:.68rem;
}

/* ── Buttons ─────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  gap:6px; padding:8px 18px; border-radius:var(--radius);
  font-family:'Cinzel',serif; font-size:.65rem;
  letter-spacing:.1em; text-transform:uppercase;
  cursor:pointer; border:none; transition:var(--transition);
  text-decoration:none;
}
.btn-primary {
  background:var(--plum); color:#fff;
}
.btn-primary:hover { background:var(--plum2); color:#fff; }
.btn-outline {
  background:transparent; color:var(--accent);
  border:1px solid var(--border2);
}
.btn-outline:hover { border-color:var(--plum2); color:var(--plum2); }
.btn-gold {
  background:rgba(201,160,80,.15); color:var(--gold);
  border:1px solid rgba(201,160,80,.4);
}
.btn-gold:hover { background:rgba(201,160,80,.25); color:var(--gold); }
.btn-danger {
  background:rgba(200,64,64,.15); color:var(--danger);
  border:1px solid rgba(200,64,64,.4);
}
.btn-danger:hover { background:rgba(200,64,64,.25); }
.btn-sm { padding:5px 12px; font-size:.58rem; }
.btn-icon {
  width:34px; height:34px; padding:0; border-radius:50%;
}

/* ── Forms ───────────────────────────────────────────── */
.dd-form-group { margin-bottom:14px; }
.dd-label {
  display:block; font-family:'Cinzel',serif;
  font-size:.6rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); margin-bottom:6px;
}
.dd-input, .dd-select, .dd-textarea {
  width:100%; background:var(--card2);
  border:1px solid var(--border2); border-radius:var(--radius-sm);
  color:var(--text); padding:9px 12px; outline:none;
  transition:var(--transition);
}
.dd-input:focus, .dd-select:focus, .dd-textarea:focus {
  border-color:var(--plum2); box-shadow:0 0 0 3px rgba(112,32,160,.15);
}
.dd-input::placeholder, .dd-textarea::placeholder { color:var(--muted); }
.dd-select { cursor:pointer; }
.dd-select option { background:var(--card); }
.dd-textarea { resize:vertical; min-height:90px; }
.dd-checkbox { display:flex; align-items:center; gap:8px; cursor:pointer; }
.dd-checkbox input[type=checkbox] { accent-color:var(--plum2); width:14px; height:14px; }

/* ── Tabs ────────────────────────────────────────────── */
.dd-tabs {
  display:flex; gap:2px; border-bottom:1px solid var(--border);
  margin-bottom:16px; overflow-x:auto; scrollbar-width:none;
}
.dd-tabs::-webkit-scrollbar { display:none; }
.dd-tab {
  padding:10px 18px; font-family:'Cinzel',serif;
  font-size:.74rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--accent); cursor:pointer; border-bottom:2px solid transparent;
  white-space:nowrap; text-decoration:none; transition:var(--transition);
  background:transparent; border-top:none; border-left:none; border-right:none;
}
.dd-tab:hover { color:var(--text); background:rgba(112,32,160,.10); }
.dd-tab.active { color:#fff; border-bottom-color:var(--plum2); background:rgba(112,32,160,.18); }

/* ── Page header ─────────────────────────────────────── */
.dd-page-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:18px; flex-wrap:wrap; gap:10px;
}
.dd-page-title {
  font-family:'Cinzel',serif;
  font-size:1.15rem; font-weight:600;
  letter-spacing:.1em; text-transform:uppercase; color:var(--text);
}
.dd-page-title em { color:var(--accent); font-style:normal; }

/* ── Stats bar ───────────────────────────────────────── */
.dd-stats-bar {
  display:flex; gap:14px; flex-wrap:wrap;
  padding:12px 16px; background:var(--card);
  border:1px solid var(--border); border-radius:var(--radius);
  margin-bottom:16px;
}
.dd-stat-item { text-align:center; }
.dd-stat-val {
  font-family:'Cinzel',serif; font-weight:600;
  font-size:1.25rem; color:var(--plum2); display:block;
}
.dd-stat-label { font-size:.62rem; color:var(--muted); font-family:'Cinzel',serif; letter-spacing:.06em; }

/* ── Avatar ──────────────────────────────────────────── */
.dd-avatar {
  object-fit:cover; border-radius:50%;
  border:2px solid var(--border2);
}
.dd-avatar-placeholder {
  border-radius:50%; background:var(--plum);
  display:inline-flex; align-items:center; justify-content:center;
  font-family:'Cinzel',serif; color:#fff; flex-shrink:0;
}

/* ── Alerts / flash ──────────────────────────────────── */
.dd-alert {
  padding:10px 14px; border-radius:var(--radius-sm);
  font-size:.85rem; margin-bottom:12px;
  border-left:3px solid currentColor;
}
.dd-alert-success { color:var(--online); background:rgba(110,212,160,.08); }
.dd-alert-error   { color:var(--danger); background:rgba(200,64,64,.08); }
.dd-alert-info    { color:var(--accent); background:rgba(208,152,192,.08); }

/* ── Modal ───────────────────────────────────────────── */
.dd-modal-overlay {
  position:fixed; inset:0; background:rgba(10,6,14,.85);
  z-index:1000; display:none; align-items:center; justify-content:center;
  padding:20px;
}
.dd-modal-overlay.open { display:flex; }
.dd-modal {
  background:var(--card); border:1px solid var(--border2);
  border-radius:var(--radius); width:100%; max-width:480px;
  max-height:90vh; overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.7);
}
.dd-modal-head {
  padding:16px 20px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.dd-modal-title {
  font-family:'Cinzel',serif; font-weight:600;
  font-size:.9rem; letter-spacing:.08em; text-transform:uppercase; color:var(--text);
}
.dd-modal-close {
  background:transparent; border:none; color:var(--muted);
  font-size:1.1rem; cursor:pointer; padding:2px 6px;
}
.dd-modal-close:hover { color:var(--text); }
.dd-modal-body { padding:20px; }
.dd-modal-foot {
  padding:14px 20px; border-top:1px solid var(--border);
  display:flex; justify-content:flex-end; gap:8px;
}

/* ── Divider ─────────────────────────────────────────── */
.dd-divider {
  border:none; border-top:1px solid var(--border);
  margin:14px 0;
}

/* ── Empty state ─────────────────────────────────────── */
.dd-empty {
  text-align:center; padding:50px 20px;
  color:var(--muted); font-family:'Jost',sans-serif;
  font-size:1rem; font-style:italic;
}

/* ── Message thread ──────────────────────────────────── */
.msg-layout { display:grid; grid-template-columns:280px 1fr; height:calc(100vh - var(--nav-h) - var(--nav-icon-h)); }
.msg-inbox { border-right:1px solid var(--border); overflow-y:auto; background:var(--card); }
.msg-inbox-item {
  display:flex; align-items:center; gap:10px; padding:10px 14px;
  cursor:pointer; border-bottom:1px solid var(--border);
  transition:var(--transition);
}
.msg-inbox-item:hover { background:var(--card2); }
.msg-inbox-item.active { background:rgba(112,32,160,.15); border-left:2px solid var(--plum2); }
.msg-inbox-item img, .msg-inbox-item .dd-avatar { width:40px; height:40px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.msg-inbox-meta { flex:1; min-width:0; }
.msg-inbox-handle { font-size:.82rem; color:var(--text); }
.msg-inbox-preview { font-size:.72rem; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.msg-unread-dot { width:8px; height:8px; border-radius:50%; background:var(--plum2); flex-shrink:0; }
.msg-thread { display:flex; flex-direction:column; background:var(--bg); }
.msg-thread-head { padding:12px 16px; border-bottom:1px solid var(--border); background:var(--card); display:flex; align-items:center; gap:10px; }
.msg-thread-body { flex:1; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:8px; }
.msg-bubble { max-width:70%; padding:8px 12px; border-radius:12px; font-size:.85rem; line-height:1.5; }
.msg-bubble.mine { background:var(--plum); color:#fff; align-self:flex-end; border-bottom-right-radius:3px; }
.msg-bubble.theirs { background:var(--card2); color:var(--text); align-self:flex-start; border-bottom-left-radius:3px; }
.msg-time { font-size:.62rem; color:var(--muted); text-align:center; margin:4px 0; }
.msg-compose { padding:12px 16px; border-top:1px solid var(--border); background:var(--card); display:flex; gap:8px; }
.msg-compose textarea { flex:1; background:var(--card2); border:1px solid var(--border2); border-radius:var(--radius); color:var(--text); padding:8px 12px; resize:none; height:40px; outline:none; }
.msg-compose textarea:focus { border-color:var(--plum2); }

/* ── Admin ───────────────────────────────────────────── */
.admin-table { width:100%; border-collapse:collapse; font-size:.82rem; }
.admin-table th { font-family:'Cinzel',serif; font-size:.6rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); padding:8px 12px; text-align:left; border-bottom:1px solid var(--border); }
.admin-table td { padding:8px 12px; border-bottom:1px solid rgba(160,64,200,.08); vertical-align:middle; }
.admin-table tr:hover td { background:rgba(112,32,160,.06); }

/* ── Public page ─────────────────────────────────────── */
.pub-hero {
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:60px 24px;
  background:radial-gradient(ellipse at 60% 40%, rgba(112,32,160,.2) 0%, transparent 60%),
             radial-gradient(ellipse at 20% 80%, rgba(168,64,200,.1) 0%, transparent 50%),
             var(--bg);
  position:relative; overflow:hidden;
}
.pub-hero::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%237020a0' fill-opacity='0.04'%3E%3Ccircle cx='30' cy='30' r='1'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none;
}
.pub-eyebrow {
  font-family:'Cinzel',serif; font-size:.7rem; letter-spacing:.25em;
  text-transform:uppercase; color:var(--plum2); margin-bottom:20px;
}
.pub-h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,7vw,5.5rem); font-weight:300;
  line-height:1.1; color:var(--text); margin-bottom:24px;
}
.pub-h1 em { color:var(--accent); font-style:italic; }
.pub-sub {
  font-size:1rem; color:var(--muted); max-width:540px; margin:0 auto 36px;
  line-height:1.8;
}
.pub-section {
  padding:80px 24px; max-width:1100px; margin:0 auto;
}
.pub-section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.8rem,4vw,2.8rem); font-weight:300;
  color:var(--text); text-align:center; margin-bottom:10px;
}
.pub-section-title em { color:var(--accent); font-style:italic; }
.pub-section-sub {
  text-align:center; color:var(--muted); margin-bottom:48px;
  font-family:'Cinzel',serif; font-size:.65rem; letter-spacing:.12em; text-transform:uppercase;
}

/* Tile cards on homepage */
.pub-tiles {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;
}
.pub-tile {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:24px;
  transition:var(--transition); position:relative; overflow:hidden;
}
.pub-tile::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg, rgba(112,32,160,.05) 0%, transparent 100%);
  pointer-events:none;
}
.pub-tile:hover { border-color:var(--plum2); transform:translateY(-3px); }
.pub-tile-icon { font-size:1.8rem; margin-bottom:12px; }
.pub-tile-title {
  font-family:'Cinzel',serif; font-size:.75rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent); margin-bottom:8px;
}
.pub-tile-text { font-size:.88rem; color:var(--muted); line-height:1.7; }

/* How to join steps */
.pub-steps { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:20px; }
.pub-step {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:22px;
}
.pub-step-num {
  font-family:'Cormorant Garamond',serif; font-size:3rem;
  color:var(--plum); opacity:.4; line-height:1; margin-bottom:8px;
}
.pub-step-title {
  font-family:'Cinzel',serif; font-size:.7rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent); margin-bottom:8px;
}
.pub-step-text { font-size:.85rem; color:var(--muted); line-height:1.7; }

/* Policy cards */
.pub-policies { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.pub-policy {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px;
}
.pub-policy-title {
  font-family:'Cinzel',serif; font-size:.65rem;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--gold); margin-bottom:6px;
}
.pub-policy-text { font-size:.82rem; color:var(--muted); line-height:1.6; }

/* Public nav */
.pub-nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 32px; height:60px;
  background:rgba(20,16,24,.92); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.pub-nav-logo {
  font-family:'Cormorant Garamond',serif; font-size:1.4rem;
  font-style:italic; color:var(--text); letter-spacing:.04em;
}
.pub-nav-logo span { color:var(--plum2); }
.pub-nav-links { display:flex; align-items:center; gap:20px; }
.pub-nav-link {
  font-family:'Cinzel',serif; font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--muted); text-decoration:none; transition:var(--transition);
}
.pub-nav-link:hover { color:var(--accent); }

/* ── Footer ──────────────────────────────────────────── */
.dd-footer {
  border-top:1px solid var(--border); padding:30px 24px;
  text-align:center; color:var(--muted); font-size:.75rem;
  font-family:'Cinzel',serif; letter-spacing:.06em;
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
/* "More" tab + dropdown (mobile nav overflow) */
.more-toggle { display:none; background:none; }
.more-toggle.open { color:#fff; background:rgba(112,32,160,.20); border-color:var(--border2); }
.dd-more-sheet {
  display:none; position:fixed; left:0; right:0;
  top:calc(var(--nav-h) + var(--nav-icon-h));
  background:var(--card); border-bottom:1px solid var(--border);
  box-shadow:0 10px 28px rgba(0,0,0,.45); z-index:850;
  padding:10px; grid-template-columns:repeat(3,1fr); gap:6px;
}
.dd-more-item {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:5px; padding:14px 6px; border-radius:var(--radius-sm);
  border:1px solid var(--border); color:var(--accent); text-decoration:none;
  font-family:'Cinzel',serif; font-size:.58rem; letter-spacing:.06em;
  text-transform:uppercase; position:relative; text-align:center;
}
.dd-more-item:hover { color:var(--text); border-color:var(--border2); }
.dd-more-item.active { color:#fff; background:rgba(112,32,160,.20); border-color:var(--border2); }
.dd-more-icon { font-size:1.5rem; }

@media (max-width:900px) {
  .app-layout,
  .app-layout.with-right { grid-template-columns:1fr; }
  /* On mobile, stack the side panels below the feed instead of hiding them,
     so Recently Viewed / New Members / etc. stay reachable. */
  .dd-sidebar-left,
  .dd-sidebar-right {
    position:static; height:auto; max-height:none; overflow:visible;
    border-left:none; border-right:none; border-top:1px solid var(--border);
  }
  .dd-main          { order:0; }
  .dd-sidebar-right { order:1; }
  .dd-sidebar-left  { order:2; }
  /* Tab bar: share the full width evenly so all 10 icons always fit, no overflow */
  .dd-nav-icons { gap:3px; padding:0 6px; }
  .dd-nav-tab { flex:1 1 0; min-width:0; padding:6px 2px; }
  .dd-nav-tab.secondary { display:none; }       /* moved into the More menu on mobile */
  .more-toggle { display:flex; }
  .dd-nav-tab .label { display:block; font-size:.5rem; letter-spacing:.03em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%; }
  .dd-nav-tab .icon { font-size:1.25rem; }
  .dd-badge { right:4px; }
  .dd-more-sheet.open { display:grid; }
  .msg-layout { grid-template-columns:1fr; }
  .msg-inbox { display:none; }
  .msg-inbox.show { display:block; }
}
/* Desktop guard: the mobile "More" overflow + toggle must NEVER show on wide
   screens. Belt-and-suspenders against a stale/cached dd.css leaking the sheet
   as a stray secondary row on Mac/PC. */
@media (min-width:901px) {
  .dd-more-sheet,
  .more-toggle { display:none !important; }
}
@media (max-width:600px) {
  .dd-nav-tab { padding:5px 1px; }
  .dd-nav-tab .icon { font-size:1.1rem; }
  .dd-member-grid { grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); }
}

/* ═══════════════════════════════════════════════════════
   MESSAGES PAGE
   ═══════════════════════════════════════════════════════ */
.messages-page { padding:0; }
.msg-layout { display:grid; grid-template-columns:300px 1fr; height:calc(100vh - 110px); overflow:hidden; }

.msg-inbox { background:var(--card); border-right:1px solid var(--border); display:flex; flex-direction:column; overflow:hidden; }
.msg-inbox-header { display:flex; align-items:center; justify-content:space-between; padding:16px; border-bottom:1px solid var(--border); }
.msg-new-search { padding:8px 12px; border-bottom:1px solid var(--border); }
.msg-new-search input { width:100%; background:var(--bg); border:1px solid var(--border); border-radius:6px; padding:8px 12px; color:var(--text); font-family:'Jost',sans-serif; font-size:0.812rem; }
.member-search-results { margin-top:8px; }
.search-result-item { display:flex; align-items:center; gap:10px; padding:8px; border-radius:6px; color:var(--text); text-decoration:none; font-size:0.812rem; }
.search-result-item:hover { background:rgba(112,32,160,.15); }
.search-result-item img { width:32px; height:32px; border-radius:50%; object-fit:cover; }
.no-results { font-size:0.75rem; color:var(--muted); padding:8px; }

.inbox-list { flex:1; overflow-y:auto; }
.inbox-item { display:flex; align-items:center; gap:12px; padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.04); text-decoration:none; color:var(--text); transition:background .15s; }
.inbox-item:hover,.inbox-item.active { background:rgba(112,32,160,.15); }
.inbox-avatar { position:relative; flex-shrink:0; }
.inbox-avatar img { width:44px; height:44px; border-radius:50%; object-fit:cover; }
.inbox-meta { flex:1; min-width:0; }
.inbox-top { display:flex; justify-content:space-between; margin-bottom:3px; }
.inbox-handle { font-size:0.812rem; font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.inbox-time { font-size:0.688rem; color:var(--muted); flex-shrink:0; margin-left:8px; }
.inbox-preview { font-size:0.75rem; color:var(--muted); display:flex; align-items:center; gap:8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.msg-thread { display:flex; flex-direction:column; background:var(--bg); overflow:hidden; }
.thread-header { display:flex; align-items:center; gap:12px; padding:16px 20px; border-bottom:1px solid var(--border); background:var(--card); flex-shrink:0; }
.thread-avatar { width:44px; height:44px; border-radius:50%; object-fit:cover; }
.thread-name { font-size:0.938rem; font-weight:500; }
.thread-sub { font-size:0.75rem; color:var(--muted); }
.online-label { color:var(--online); }
.ml-auto { margin-left:auto; }

.thread-messages { flex:1; overflow-y:auto; padding:20px; display:flex; flex-direction:column; gap:12px; }
.msg-bubble { display:flex; align-items:flex-end; gap:10px; max-width:75%; }
.msg-bubble.mine { align-self:flex-end; flex-direction:row-reverse; }
.msg-bubble.theirs { align-self:flex-start; }
.bubble-avatar { width:32px; height:32px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.bubble-content { display:flex; flex-direction:column; gap:4px; }
.bubble-body { padding:10px 14px; border-radius:16px; font-size:0.875rem; line-height:1.5; }
.mine .bubble-body { background:var(--plum); color:#fff; border-bottom-right-radius:4px; }
.theirs .bubble-body { background:var(--card); color:var(--text); border-bottom-left-radius:4px; }
.bubble-time { font-size:0.625rem; color:var(--muted); }
.mine .bubble-time { text-align:right; }

.thread-compose { display:flex; gap:10px; padding:16px 20px; border-top:1px solid var(--border); background:var(--card); flex-shrink:0; align-items:flex-end; }
.thread-compose textarea { flex:1; background:var(--bg); border:1px solid var(--border); border-radius:8px; padding:10px 14px; color:var(--text); font-family:'Jost',sans-serif; font-size:0.875rem; resize:none; max-height:120px; }
.thread-empty { flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; color:var(--muted); gap:12px; }
.thread-empty-icon { font-size:3rem; }

/* ═══════════════════════════════════════════════════════
   ALBUMS PAGE
   ═══════════════════════════════════════════════════════ */
.upload-panel { padding:24px; margin-bottom:24px; }
.upload-form { display:flex; flex-direction:column; gap:16px; }
.radio-row { display:flex; flex-direction:column; gap:8px; }
.radio-opt { display:flex; align-items:center; gap:8px; font-size:0.875rem; cursor:pointer; }
.radio-opt input { accent-color:var(--plum); }

.album-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:12px; }
.album-card { position:relative; border-radius:8px; overflow:hidden; aspect-ratio:1; cursor:pointer; background:var(--card); }
.album-card img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.album-card:hover img { transform:scale(1.05); }
.album-overlay { position:absolute; inset:0; background:linear-gradient(to bottom, rgba(0,0,0,.5) 0%, transparent 40%, transparent 60%, rgba(0,0,0,.6) 100%); opacity:0; transition:opacity .2s; display:flex; align-items:flex-start; justify-content:flex-end; padding:8px; }
.album-card:hover .album-overlay { opacity:1; }
.album-badge-priv { background:rgba(0,0,0,.7); border:1px solid var(--border); border-radius:20px; padding:3px 10px; font-size:0.688rem; font-family:'Cinzel',serif; }
.album-delete-btn { background:rgba(220,50,50,.85); border:none; border-radius:50%; width:28px; height:28px; color:#fff; cursor:pointer; font-size:0.875rem; display:flex; align-items:center; justify-content:center; }
.album-time { position:absolute; bottom:8px; left:8px; font-size:0.625rem; color:rgba(255,255,255,.7); }

.lightbox { position:fixed; inset:0; background:rgba(0,0,0,.92); display:none; align-items:center; justify-content:center; z-index:9999; }
.lightbox.open { display:flex; }
.lightbox img { max-width:90vw; max-height:90vh; border-radius:4px; object-fit:contain; }
.lightbox-close { position:absolute; top:20px; right:28px; font-size:1.75rem; color:#fff; cursor:pointer; opacity:.7; }
.lightbox-close:hover { opacity:1; }

/* ═══════════════════════════════════════════════════════
   EVENTS PAGE
   ═══════════════════════════════════════════════════════ */
.events-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:20px; }
.event-card { display:flex; gap:20px; align-items:flex-start; padding:24px; transition:border-color .2s; }
.event-card.event-going { border-color:var(--online); }
.event-card.event-past { opacity:.65; }
.event-date-badge { display:flex; flex-direction:column; align-items:center; background:rgba(112,32,160,.2); border:1px solid var(--plum); border-radius:8px; padding:10px 14px; min-width:56px; flex-shrink:0; }
.event-month { font-family:'Cinzel',serif; font-size:0.625rem; letter-spacing:.1em; color:var(--accent); text-transform:uppercase; }
.event-day { font-family:'Cinzel',serif; font-size:1.6rem; font-weight:600; color:var(--text); line-height:1; }
.event-year { font-size:0.625rem; color:var(--muted); }
.event-body { flex:1; min-width:0; }
.event-title { font-family:'Cinzel',serif; font-size:.95rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; margin-bottom:8px; }
.event-location { font-size:0.812rem; color:var(--muted); margin-bottom:6px; }
.event-soon { font-size:0.75rem; color:var(--gold); margin-bottom:8px; }
.event-desc { font-size:0.812rem; color:var(--muted); line-height:1.6; margin-bottom:16px; }
.event-footer { display:flex; align-items:center; justify-content:space-between; }
.event-rsvp-count { font-size:0.812rem; color:var(--muted); }
.rsvp-btn { padding:8px 20px; border-radius:20px; font-family:'Cinzel',serif; font-size:0.688rem; letter-spacing:.08em; border:none; cursor:pointer; transition:all .2s; }
.rsvp-going { background:rgba(110,212,160,.15); border:1px solid var(--online) !important; color:var(--online); }
.badge-attended { background:rgba(110,212,160,.15); border:1px solid var(--online); border-radius:20px; padding:4px 12px; font-size:0.688rem; color:var(--online); }
.events-past { margin-top:8px; }
.section-divider { display:flex; align-items:center; margin:28px 0 16px; gap:12px; }
.section-divider::before,.section-divider::after { content:''; flex:1; height:1px; background:var(--border); }

/* ═══════════════════════════════════════════════════════
   NOTIFICATIONS PAGE
   ═══════════════════════════════════════════════════════ */
.notif-day-label { font-family:'Cinzel',serif; font-size:0.625rem; letter-spacing:.15em; color:var(--muted); text-transform:uppercase; padding:20px 0 8px; border-bottom:1px solid var(--border); margin-bottom:4px; }
.notif-list { display:flex; flex-direction:column; gap:2px; margin-bottom:8px; }
.notif-row { display:flex; align-items:center; gap:14px; padding:14px 16px; border-radius:8px; text-decoration:none; color:var(--text); transition:background .15s; }
.notif-row:hover { background:rgba(112,32,160,.1); }
.notif-unread { background:rgba(112,32,160,.08); }
.notif-icon-wrap { position:relative; flex-shrink:0; width:44px; height:44px; }
.notif-avatar { width:44px; height:44px; border-radius:50%; object-fit:cover; }
.notif-type-icon { position:absolute; bottom:-2px; right:-4px; font-size:0.875rem; line-height:1; }
.notif-icon-only { width:44px; height:44px; border-radius:50%; background:rgba(112,32,160,.2); display:flex; align-items:center; justify-content:center; font-size:1.25rem; }
.notif-text { flex:1; font-size:0.875rem; line-height:1.4; }
.notif-time { font-size:0.688rem; color:var(--muted); flex-shrink:0; }

/* ═══════════════════════════════════════════════════════
   DASHBOARD PAGE
   ═══════════════════════════════════════════════════════ */
.dashboard-page {}
.dash-header { display:flex; align-items:center; gap:20px; padding:24px; background:var(--card); border:1px solid var(--border); border-radius:12px; margin-bottom:24px; }
.dash-avatar { width:72px; height:72px; border-radius:50%; object-fit:cover; border:2px solid var(--plum); }
.dash-name { font-family:'Cinzel',serif; font-size:1.15rem; font-weight:600; letter-spacing:.05em; }
.dash-sub { font-size:0.812rem; color:var(--muted); margin-top:4px; }
.dash-actions { margin-left:auto; display:flex; gap:10px; }

.stats-row { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:12px; margin-bottom:24px; }
.stat-tile { background:var(--card); border:1px solid var(--border); border-radius:10px; padding:20px 16px; text-align:center; }
.stat-tile-accent { border-color:var(--plum); background:rgba(112,32,160,.1); }
.stat-tile-num { font-family:'Cinzel',serif; font-size:1.7rem; font-weight:600; color:var(--text); }
.stat-tile-label { font-family:'Cinzel',serif; font-size:0.562rem; letter-spacing:.12em; color:var(--muted); text-transform:uppercase; margin-top:4px; }

.dash-chart-card { padding:24px; margin-bottom:24px; }
.bar-chart { display:flex; align-items:flex-end; gap:4px; height:120px; padding-bottom:24px; }
.bar-col { flex:1; display:flex; flex-direction:column; align-items:center; height:100%; }
.bar-wrap { flex:1; display:flex; align-items:flex-end; width:100%; }
.bar-fill { width:100%; background:rgba(112,32,160,.3); border-radius:4px 4px 0 0; transition:height .5s; position:relative; min-height:2px; }
.bar-fill.bar-active { background:var(--plum); }
.bar-val { position:absolute; top:-18px; left:50%; transform:translateX(-50%); font-size:0.562rem; color:var(--accent); white-space:nowrap; }
.bar-label { font-size:0.562rem; color:var(--muted); margin-top:4px; }

.dash-two-col { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:24px; }
.activity-list { display:flex; flex-direction:column; gap:4px; }
.activity-row { display:flex; align-items:center; gap:12px; padding:10px 8px; border-radius:8px; text-decoration:none; color:var(--text); transition:background .15s; }
.activity-row:hover { background:rgba(112,32,160,.1); }
.activity-avatar { width:40px; height:40px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.activity-info { flex:1; display:flex; flex-direction:column; gap:2px; font-size:0.812rem; }
.activity-icon { font-size:1rem; }
.card-link { display:inline-block; margin-top:12px; font-size:0.75rem; color:var(--accent); text-decoration:none; font-family:'Cinzel',serif; letter-spacing:.06em; }
.card-link:hover { color:var(--plum2); }
.muted-text { font-size:0.75rem; color:var(--muted); }

.quick-links { display:flex; flex-wrap:wrap; gap:10px; }
.quick-link-btn { background:rgba(112,32,160,.12); border:1px solid var(--border); border-radius:8px; padding:10px 18px; color:var(--text); text-decoration:none; font-size:0.812rem; transition:all .2s; }
.quick-link-btn:hover { background:rgba(112,32,160,.25); border-color:var(--plum); }

/* ═══════════════════════════════════════════════════════
   ADMIN PAGE
   ═══════════════════════════════════════════════════════ */
.admin-page {}
.admin-tabs { display:flex; gap:4px; margin-bottom:24px; border-bottom:1px solid var(--border); padding-bottom:1px; overflow-x:auto; }
.admin-tab { padding:10px 20px; font-family:'Cinzel',serif; font-size:0.688rem; letter-spacing:.08em; color:var(--muted); text-decoration:none; border-radius:6px 6px 0 0; white-space:nowrap; }
.admin-tab:hover { color:var(--text); background:rgba(255,255,255,.05); }
.admin-tab.active { color:var(--accent); background:rgba(112,32,160,.15); border-bottom:2px solid var(--plum); }
.badge-admin { background:var(--plum); color:#fff; border-radius:20px; padding:4px 14px; font-family:'Cinzel',serif; font-size:0.625rem; letter-spacing:.1em; }

.admin-member-filters { display:flex; justify-content:space-between; align-items:flex-start; gap:16px; margin-bottom:16px; flex-wrap:wrap; }
.filter-tabs { display:flex; gap:4px; flex-wrap:wrap; }
.filter-tab { padding:7px 16px; font-family:'Cinzel',serif; font-size:0.625rem; letter-spacing:.08em; color:var(--muted); text-decoration:none; border:1px solid var(--border); border-radius:20px; white-space:nowrap; }
.filter-tab:hover { color:var(--text); }
.filter-tab.active { color:var(--accent); border-color:var(--plum); background:rgba(112,32,160,.12); }
.admin-search-form { display:flex; gap:8px; }

.admin-member-row { display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid rgba(255,255,255,.04); }
.admin-member-row:last-child { border-bottom:none; }
.admin-actions { display:flex; gap:8px; flex-shrink:0; flex-wrap:wrap; }

.log-list { display:flex; flex-direction:column; gap:8px; }
.log-row { display:flex; align-items:center; gap:14px; font-size:0.812rem; padding:8px 0; border-bottom:1px solid rgba(255,255,255,.04); }
.log-action { font-family:'Cinzel',serif; font-size:0.562rem; letter-spacing:.1em; padding:3px 10px; border-radius:20px; text-transform:uppercase; }
.log-approve { background:rgba(110,212,160,.15); color:var(--online); border:1px solid var(--online); }
.log-suspend { background:rgba(201,160,80,.15); color:var(--gold); border:1px solid var(--gold); }
.log-delete { background:rgba(220,80,80,.15); color:#e05555; border:1px solid #e05555; }

.event-form { display:flex; flex-direction:column; gap:16px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.checkbox-label { display:flex; align-items:center; gap:10px; font-size:0.875rem; cursor:pointer; }
.checkbox-label input { accent-color:var(--plum); width:16px; height:16px; }

.btn-warning { background:rgba(201,160,80,.2); border:1px solid var(--gold); color:var(--gold); border-radius:20px; padding:6px 14px; font-family:'Cinzel',serif; font-size:0.625rem; letter-spacing:.06em; cursor:pointer; transition:all .2s; }
.btn-warning:hover { background:rgba(201,160,80,.35); }
.btn-danger { background:rgba(220,80,80,.15); border:1px solid #e05555; color:#e05555; border-radius:20px; padding:6px 14px; font-family:'Cinzel',serif; font-size:0.625rem; letter-spacing:.06em; cursor:pointer; transition:all .2s; }
.btn-danger:hover { background:rgba(220,80,80,.3); }

/* ═══════════════════════════════════════════════════════
   SHARED UTILITIES
   ═══════════════════════════════════════════════════════ */
.empty-state { text-align:center; padding:60px 20px; color:var(--muted); }
.empty-icon { font-size:3rem; margin-bottom:16px; }
.empty-state-sm { text-align:center; padding:24px; color:var(--muted); font-size:0.875rem; }
.badge-count { background:var(--plum); color:#fff; border-radius:20px; padding:1px 7px; font-size:0.625rem; font-family:'Cinzel',serif; }
.alert { padding:14px 18px; border-radius:8px; margin-bottom:20px; font-size:0.875rem; }
.alert-error { background:rgba(220,80,80,.15); border:1px solid #e05555; color:#ff9090; }
.alert-success { background:rgba(110,212,160,.1); border:1px solid var(--online); color:var(--online); }
.pagination { display:flex; gap:6px; padding:16px 0; flex-wrap:wrap; }
.page-btn { padding:6px 12px; border-radius:6px; background:var(--card); border:1px solid var(--border); color:var(--muted); text-decoration:none; font-size:0.812rem; }
.page-btn.active { background:var(--plum); border-color:var(--plum); color:#fff; }
.page-btn:hover:not(.active) { border-color:var(--plum); color:var(--text); }

/* ═══════════════════════════════════════════════════════
   Mobile & installed-app (PWA) polish
   ═══════════════════════════════════════════════════════ */
html { -webkit-text-size-adjust:100%; }
* { -webkit-tap-highlight-color: rgba(168,64,200,.18); }
@media (max-width:600px) {
  /* 16px keeps iOS Safari from auto-zooming when a field gains focus */
  input, select, textarea, .dd-input { font-size:16px; }
}

/* ════════════════════════════════════════════════════════════
   Mobile hamburger + full-screen vertical menu (Wellify-style)
   Desktop keeps the icon tab bar; mobile swaps it for this menu.
   ════════════════════════════════════════════════════════════ */
.dd-hamburger{ display:none; flex-direction:column; justify-content:center; gap:5px;
  width:42px; height:42px; padding:0 9px; background:none; border:none; cursor:pointer; }
.dd-hamburger span{ display:block; width:24px; height:2px; background:var(--text);
  border-radius:2px; transition:var(--transition); }
.dd-mobile-menu{ display:none; position:fixed; inset:0; z-index:1200;
  background:var(--bg); overflow-y:auto; -webkit-overflow-scrolling:touch; }
.dd-mobile-menu.open{ display:block; }
.dd-mm-bar{ display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border-bottom:1px solid var(--border);
  position:sticky; top:0; background:var(--bg); z-index:1; }
.dd-mm-account{ display:flex; align-items:center; gap:10px; color:var(--text);
  text-decoration:none; font-family:'Cinzel',serif; font-size:.9rem; letter-spacing:.04em; }
.dd-mm-close{ background:none; border:none; color:var(--text); font-size:1.9rem;
  line-height:1; cursor:pointer; padding:2px 8px; }
.dd-mm-links{ display:flex; flex-direction:column; align-items:center;
  padding:26px 16px 64px; gap:2px; }
.dd-mm-link{ font-family:'Cinzel',serif; font-size:1.55rem; color:var(--accent);
  text-decoration:none; padding:13px 8px; letter-spacing:.04em; text-align:center; }
.dd-mm-link:hover{ color:var(--text); }
.dd-mm-link.active{ color:var(--plum2); }
.dd-mm-link.sub{ font-size:.92rem; color:var(--muted); padding:8px;
  letter-spacing:.1em; text-transform:uppercase; }
.dd-mm-sep{ width:64px; height:1px; background:var(--border); margin:18px 0; }
body.dd-noscroll{ overflow:hidden; }

@media (min-width:901px){
  .dd-hamburger, .dd-mobile-menu{ display:none !important; }
}
@media (max-width:900px){
  .dd-nav-icons{ display:none; }            /* icon row replaced by the hamburger menu */
  .dd-hamburger{ display:flex; }
  .dd-nav-avatar-wrap{ display:none; }      /* account now lives inside the menu */
  .dd-free-toggle span:not(.dd-badge-free){ display:none; } /* compact toggle on mobile */
  .dd-free-toggle{ padding:6px 9px; gap:0; }
}
