/* ── Grimoire — Global Design System ───────────────────────── */

/* ─── Theme 1: Light (default, no data-theme attr) ─────────── */
:root {
  --bg:            #ffffff;
  --bg2:           #f7f8fc;
  --bg3:           #eef0f6;
  --bg4:           #e4e7f0;
  --border:        rgba(0,0,0,0.07);
  --border-hover:  rgba(0,0,0,0.14);
  --text:          #0f172a;
  --text2:         #64748b;
  --text3:         #94a3b8;
  --accent:        #4f46e5;
  --accent2:       #6366f1;
  --accent-hover:  #4338ca;
  --accent-dim:    rgba(79,70,229,0.08);
  --accent-border: rgba(79,70,229,0.22);
  --success:       #10b981;
  --danger:        #ef4444;
  --warn:          #f59e0b;
  --radius:        14px;
  --radius-sm:     10px;
  --radius-xs:     6px;
  --shadow:        0 20px 60px rgba(0,0,0,0.1);
  --shadow-sm:     0 4px 16px rgba(0,0,0,0.07);
  --shadow-glow:   0 4px 20px rgba(79,70,229,0.15);
  --shadow-card:   0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --font-display:  'Rajdhani', 'Share Tech Mono', monospace;
  --font-body:     'Rajdhani', 'Share Tech Mono', monospace;
  --sidebar-w:     252px;
}

/* ─── Theme 2: Dark — Trading Terminal ──────────────────────── */
[data-theme="dark"] {
  --bg:            #0A0E14;
  --bg2:           #111820;
  --bg3:           #111820;
  --bg4:           #1E2A38;
  --border:        rgba(30,42,56,0.9);
  --border-hover:  rgba(57,255,20,0.22);
  --text:          #FFFFFF;
  --text2:         #6B7A8D;
  --text3:         #4a5a6d;
  --accent:        #39FF14;
  --accent2:       #39FF14;
  --accent-hover:  #2bcc10;
  --accent-dim:    rgba(57,255,20,0.08);
  --accent-border: rgba(57,255,20,0.28);
  --success:       #00C853;
  --danger:        #E53935;
  --warn:          #FFB300;
  --shadow:        0 24px 64px rgba(0,0,0,0.85);
  --shadow-sm:     0 4px 16px rgba(0,0,0,0.6);
  --shadow-glow:   0 0 28px rgba(57,255,20,0.15);
  --shadow-card:   none;
  --font-display:  'Rajdhani', 'Share Tech Mono', monospace;
  --font-body:     'Rajdhani', 'Share Tech Mono', monospace;
}

/* ─── Theme 3: Geek ─────────────────────────────────────────── */
[data-theme="geek"] {
  --bg:            #f4f7f2;
  --bg2:           #ffffff;
  --bg3:           #eaf0e7;
  --bg4:           #dce8d8;
  --border:        rgba(0,100,0,0.1);
  --border-hover:  rgba(0,100,0,0.22);
  --text:          #1a2e1a;
  --text2:         #4a6741;
  --text3:         #8aab80;
  --accent:        #2f8d46;
  --accent2:       #3cb55e;
  --accent-hover:  #267a3b;
  --accent-dim:    rgba(47,141,70,0.1);
  --accent-border: rgba(47,141,70,0.3);
  --shadow:        0 20px 60px rgba(0,0,0,0.07);
  --shadow-sm:     0 4px 12px rgba(0,0,0,0.06);
  --shadow-glow:   0 4px 16px rgba(47,141,70,0.2);
  --shadow-card:   0 1px 3px rgba(0,0,0,0.06);
  --font-body:     'Consolas', 'SF Mono', 'Fira Code', 'Liberation Mono', 'Courier New', monospace;
  --font-display:  'Consolas', 'SF Mono', 'Fira Code', 'Liberation Mono', 'Courier New', monospace;
}

/* ─── Theme 4: Midnight ─────────────────────────────────────── */
[data-theme="midnight"] {
  --bg:            #020c18;
  --bg2:           #041728;
  --bg3:           #062035;
  --bg4:           #083248;
  --border:        rgba(0,220,200,0.1);
  --border-hover:  rgba(0,220,200,0.22);
  --text:          #d8f0f8;
  --text2:         #6aa0c0;
  --text3:         #3a6a82;
  --accent:        #00d4c0;
  --accent2:       #00eedc;
  --accent-hover:  #00bfac;
  --accent-dim:    rgba(0,212,192,0.08);
  --accent-border: rgba(0,212,192,0.22);
  --shadow:        0 24px 64px rgba(0,0,0,0.85);
  --shadow-sm:     0 4px 16px rgba(0,0,0,0.5);
  --shadow-glow:   0 0 28px rgba(0,212,192,0.22);
  --shadow-card:   none;
  --font-body:     'Consolas', 'SF Mono', 'Fira Code', 'Liberation Mono', 'Courier New', monospace;
  --font-display:  'Consolas', 'SF Mono', 'Fira Code', 'Liberation Mono', 'Courier New', monospace;
}

/* ─── Smooth theme transitions ───────────────────────────────── */
.theme-transition,
.theme-transition *,
.theme-transition *::before,
.theme-transition *::after {
  transition: background-color .32s ease, border-color .32s ease,
              color .2s ease, box-shadow .32s ease !important;
}

/* ─── Text selection ─────────────────────────────────────────── */
::selection { background: var(--accent-dim); color: var(--accent2); }

/* ─── Base reset ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-weight: 500;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Buttons ────────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 7px;
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);
  color: #fff; border: none; border-radius: var(--radius-sm);
  padding: 10px 22px; font-size: 14px; font-weight: 600;
  cursor: pointer; transition: all .2s ease; text-decoration: none;
  font-family: var(--font-body); white-space: nowrap;
  letter-spacing: 0.01em; position: relative; overflow: hidden;
  box-shadow: 0 2px 16px rgba(0,0,0,0.15);
}
.btn-primary::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.14), transparent);
  opacity: 0; transition: opacity .2s;
}
.btn-primary:hover::after { opacity: 1; }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(0,0,0,0.2); }
.btn-primary:active { transform: translateY(0); }
.btn-primary.btn-lg { padding: 14px 32px; font-size: 15px; border-radius: var(--radius); }
.btn-primary.btn-full { width: 100%; justify-content: center; padding: 13px; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(128,128,128,0.07); color: var(--text2);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 10px 22px; font-size: 14px; font-weight: 500;
  cursor: pointer; transition: all .2s; text-decoration: none;
  font-family: var(--font-body); white-space: nowrap;
}
.btn-ghost:hover { color: var(--text); border-color: var(--border-hover); background: rgba(128,128,128,0.1); }
.btn-ghost.btn-lg { padding: 14px 32px; font-size: 15px; border-radius: var(--radius); }

.btn-icon {
  background: none; border: none; cursor: pointer;
  color: var(--text3); padding: 7px; border-radius: var(--radius-xs);
  transition: all .15s; line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.btn-icon:hover { color: var(--text2); background: rgba(128,128,128,0.1); }

/* ── Form Fields ─────────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 7px; }
.field label {
  font-size: 11px; font-weight: 700; color: var(--text2);
  letter-spacing: 0.06em; text-transform: uppercase;
}
.field label .hint { font-weight: 400; color: var(--text3); text-transform: none; letter-spacing: 0; margin-left: 4px; }
.field label .req { color: var(--accent); }

input[type=text], input[type=email], input[type=url],
input[type=password], select, textarea {
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text);
  font-family: var(--font-body); font-size: 14px;
  padding: 11px 16px; transition: border-color .2s, box-shadow .2s;
  outline: none; width: 100%;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
}
input::placeholder, textarea::placeholder { color: var(--text3); }
textarea { resize: vertical; min-height: 72px; line-height: 1.6; }
select { cursor: pointer; }
select option { background: var(--bg2); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* ── Modals ──────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6);
  backdrop-filter: blur(10px); z-index: 100;
  animation: fadeIn .2s ease;
}
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

.modal {
  position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 20px; width: min(540px, calc(100vw - 32px));
  max-height: 90vh; overflow-y: auto; z-index: 101;
  box-shadow: var(--shadow);
  animation: modalIn .28s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes modalIn {
  from { opacity:0; transform:translate(-50%,calc(-50% + 20px)) scale(0.95); }
  to   { opacity:1; transform:translate(-50%,-50%) scale(1); }
}
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 24px 28px 0;
}
.modal-header h3 { font-family: var(--font-display); font-size: 19px; font-weight: 700; }
.modal-body { padding: 20px 28px 4px; display: flex; flex-direction: column; gap: 18px; }
.modal-footer {
  padding: 16px 28px 24px; display: flex; justify-content: flex-end; gap: 10px;
  border-top: 1px solid var(--border); margin-top: 8px;
}

.hidden { display: none !important; }

/* ── Link Cards ──────────────────────────────────────────────── */
.links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(292px,1fr));
  gap: 16px; padding: 0 24px 52px;
}
.links-grid.list-layout { grid-template-columns: 1fr; }

.link-card {
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
  transition: transform .22s ease, border-color .22s, box-shadow .22s;
  cursor: pointer; position: relative; display: flex; flex-direction: column;
  box-shadow: var(--shadow-card);
}
.link-card:hover {
  border-color: var(--accent-border);
  transform: translateY(-3px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.15), var(--shadow-glow);
}

.card-media {
  width: 100%; height: 150px; flex-shrink: 0;
  background: linear-gradient(140deg, var(--bg3) 0%, var(--bg4) 100%);
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.card-media img.card-image {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .4s ease;
}
.link-card:hover .card-media img.card-image { transform: scale(1.04); }
.card-media::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.15) 0%, transparent 55%);
  pointer-events: none;
}
.card-media--empty { }
.domain-initial {
  font-family: var(--font-display); font-size: 52px; font-weight: 800;
  color: var(--text3); opacity: 0.35; text-transform: uppercase; user-select: none;
}

.badge-public {
  position: absolute; top: 12px; right: 12px; z-index: 2;
  background: rgba(16,185,129,0.16); color: #10b981;
  font-size: 11px; font-weight: 700; border-radius: 100px; padding: 3px 9px;
  border: 1px solid rgba(16,185,129,0.3); letter-spacing: 0.06em;
  backdrop-filter: blur(8px);
}
.badge-private {
  position: absolute; top: 12px; right: 12px; z-index: 2;
  background: rgba(128,128,128,0.1); color: var(--text3);
  font-size: 11px; font-weight: 700; border-radius: 100px; padding: 3px 9px;
  border: 1px solid var(--border); letter-spacing: 0.06em;
  backdrop-filter: blur(8px);
}

.card-body { padding: 16px; display: flex; flex-direction: column; flex: 1; }
.card-top { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.card-favicon { width: 18px; height: 18px; border-radius: 4px; flex-shrink: 0; }
.card-domain { font-size: 11px; color: var(--text3); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 500; letter-spacing: 0.02em; }
.col-badge {
  font-size: 11px; font-weight: 600; border-radius: 100px;
  padding: 2px 8px; white-space: nowrap; letter-spacing: 0.03em;
  display: inline-flex; align-items: center;
}
.card-title {
  font-family: var(--font-display); font-size: 14px; font-weight: 600;
  color: var(--text); line-height: 1.4; margin-bottom: 8px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.card-desc {
  font-size: 13px; color: var(--text2); line-height: 1.55; flex: 1; font-weight: 500;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  margin-bottom: 10px;
}
.card-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.card-tag {
  font-size: 12px; color: var(--accent2); background: var(--accent-dim);
  border-radius: 100px; padding: 3px 9px; font-weight: 600;
  cursor: pointer; transition: all .15s; letter-spacing: 0.02em;
}
.card-tag:hover { background: var(--accent-dim); opacity: 0.8; }
.card-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 10px; border-top: 1px solid var(--border); margin-top: auto;
}
.card-meta { font-size: 12px; color: var(--text3); font-weight: 500; }
.card-actions { display: flex; gap: 2px; opacity: 0; transition: opacity .18s; }
.link-card:hover .card-actions { opacity: 1; }
.card-act {
  width: 28px; height: 28px; padding: 0; border-radius: 7px;
  color: var(--text3); background: none; border: none;
  cursor: pointer; transition: all .15s;
  display: flex; align-items: center; justify-content: center;
}
.card-act:hover { color: var(--text2); background: rgba(128,128,128,0.12); }
.card-act.danger:hover { color: var(--danger); background: rgba(239,68,68,0.1); }

/* List layout */
.list-layout .link-card { flex-direction: row; }
.list-layout .card-media { width: 112px; height: auto; min-height: 88px; flex-shrink: 0; border-radius: 0; }
.list-layout .badge-public, .list-layout .badge-private { top: 8px; right: 8px; }

/* ── Toast ───────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  background: var(--bg3); border: 1px solid var(--border);
  color: var(--text); padding: 11px 22px; border-radius: 100px;
  font-size: 13px; font-weight: 500; box-shadow: var(--shadow);
  z-index: 999; white-space: nowrap;
  animation: toastIn .3s cubic-bezier(0.34,1.56,0.64,1);
}
.toast.success { border-color: rgba(16,185,129,0.4); color: #10b981; background: rgba(16,185,129,0.08); }
.toast.error   { border-color: rgba(239,68,68,0.4);  color: #ef4444; background: rgba(239,68,68,0.08); }
@keyframes toastIn {
  from { opacity:0; transform:translateX(-50%) translateY(16px) scale(0.9); }
  to   { opacity:1; transform:translateX(-50%) translateY(0) scale(1); }
}

/* ── Logo ────────────────────────────────────────────────────── */
.logo {
  display: flex; align-items: center; gap: 9px;
  font-family: 'Rajdhani', sans-serif; font-size: 19px; font-weight: 700;
  letter-spacing: 0.07em; color: var(--text); text-decoration: none;
}
.logo svg { flex-shrink: 0; }
.logo-text { transition: color .15s; }
@media (max-width: 300px) { .logo-text { display: none; } }

/* ── Divider ─────────────────────────────────────────────────── */
.divider { display: flex; align-items: center; gap: 12px; color: var(--text3); font-size: 12px; }
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }

/* ── Error msg ───────────────────────────────────────────────── */
.error-msg {
  background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.24);
  color: var(--danger); border-radius: var(--radius-sm); padding: 11px 16px; font-size: 13px;
}

/* ── Empty state ─────────────────────────────────────────────── */
.empty-state {
  text-align: center; padding: 80px 24px;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.empty-icon {
  width: 72px; height: 72px; background: var(--accent-dim); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); margin-bottom: 4px;
  border: 1px solid var(--accent-border);
}
.empty-state h3 { font-family: var(--font-display); font-size: 20px; font-weight: 700; }
.empty-state p { color: var(--text2); font-size: 14px; max-width: 280px; line-height: 1.55; }

/* ── Load more ───────────────────────────────────────────────── */
.load-more-wrap { text-align: center; padding: 16px 0 52px; }

/* ── Fetch preview ───────────────────────────────────────────── */
.fetch-preview {
  display: flex; align-items: center; gap: 10px;
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 10px 14px;
}
.preview-favicon { width: 20px; height: 20px; border-radius: 5px; }
.preview-domain { font-size: 13px; color: var(--text2); flex: 1; }
.preview-check { font-size: 11px; color: var(--success); font-weight: 700; letter-spacing: 0.04em; }

/* ── URL row ─────────────────────────────────────────────────── */
.url-row { display: flex; gap: 8px; }
.url-row input { flex: 1; }
.btn-fetch {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--accent-dim); color: var(--accent);
  border: 1px solid var(--accent-border); border-radius: var(--radius-sm);
  padding: 11px 16px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all .2s; white-space: nowrap;
  font-family: var(--font-body);
}
.btn-fetch:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ── Tag suggestions ─────────────────────────────────────────── */
.tag-suggestions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.tag-sug {
  font-size: 11px; color: var(--text3); background: var(--bg3);
  border: 1px solid var(--border); border-radius: 100px;
  padding: 3px 10px; cursor: pointer; transition: all .15s; font-weight: 500;
}
.tag-sug:hover { color: var(--accent2); border-color: var(--accent-border); background: var(--accent-dim); }

/* ── Toggle group ────────────────────────────────────────────── */
.toggle-group { display: flex; gap: 8px; }
.toggle-opt {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 7px;
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 10px 14px;
  cursor: pointer; font-size: 13px; font-weight: 500;
  transition: all .2s; color: var(--text2);
}
.toggle-opt input { display: none; }
.toggle-opt:has(input:checked) { border-color: var(--accent); background: var(--accent-dim); color: var(--text); }

/* ── Icon / Color pickers ────────────────────────────────────── */
.emoji-picker { display: flex; flex-wrap: wrap; gap: 7px; }
.emoji-opt {
  font-size: 12px; font-weight: 600; cursor: pointer;
  border-radius: var(--radius-sm); padding: 7px 13px;
  border: 1.5px solid var(--border); transition: all .15s;
  color: var(--text2); background: var(--bg3); letter-spacing: 0.02em;
}
.emoji-opt.selected, .emoji-opt:hover { border-color: var(--accent); background: var(--accent-dim); color: var(--text); }
.color-picker { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.color-swatch {
  width: 30px; height: 30px; border-radius: 50%; cursor: pointer;
  border: 3px solid transparent; transition: all .2s;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.color-swatch.selected, .color-swatch:hover { border-color: var(--text); transform: scale(1.15); }

/* ── Grad text ───────────────────────────────────────────────── */
.grad-text {
  background: linear-gradient(135deg, var(--accent2), #c4b5fd, #f0abfc);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* ── Misc ────────────────────────────────────────────────────── */
.loading-sm { color: var(--text3); font-size: 13px; padding: 10px 4px; }
.avatar-sm { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; }
.avatar-lg { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; border: 3px solid var(--border); }

/* ── Scrollbar ───────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--accent-border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 640px) {
  .field-row { grid-template-columns: 1fr; }
  .links-grid { grid-template-columns: 1fr; padding: 0 16px 40px; }
  .modal { border-radius: 16px 16px 0 0; top: auto; bottom: 0; left: 0; right: 0; transform: none; width: 100%; max-height: 92vh; animation: sheetIn .28s cubic-bezier(0.34,1.56,0.64,1); }
  @keyframes sheetIn { from { transform: translateY(40px); opacity:0; } to { transform: translateY(0); opacity:1; } }
}

/* ════════════════════════════════════════════════════════════════
   THEME SWITCHER COMPONENT
   ════════════════════════════════════════════════════════════════ */
.theme-switcher { position: relative; }

.theme-toggle {
  width: 34px; height: 34px; padding: 0; border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  background: rgba(128,128,128,0.08); border: 1px solid var(--border);
  color: var(--text2); cursor: pointer; transition: all .15s;
}
.theme-toggle:hover { color: var(--accent); border-color: var(--accent-border); background: var(--accent-dim); }

.theme-picker {
  position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--bg2); border: 1px solid var(--border-hover);
  border-radius: var(--radius-sm); padding: 8px;
  min-width: 170px; z-index: 200; box-shadow: var(--shadow);
  animation: pickerIn .18s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes pickerIn { from { opacity:0; transform:translateY(-6px) scale(0.97); } to { opacity:1; transform:translateY(0) scale(1); } }

.theme-picker-title {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--text3); padding: 4px 8px 8px;
}

.theme-option {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: var(--radius-xs);
  cursor: pointer; font-size: 13px; font-weight: 500;
  color: var(--text2); transition: all .14s; user-select: none;
}
.theme-option:hover { background: var(--bg3); color: var(--text); }
.theme-option.active { color: var(--accent2); background: var(--accent-dim); }

.theme-swatch {
  width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
  border: 2px solid rgba(128,128,128,0.2);
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}

.theme-check {
  margin-left: auto; color: var(--accent2); display: flex; align-items: center;
}

/* ════════════════════════════════════════════════════════════════
   THEME-SPECIFIC OVERRIDES
   ════════════════════════════════════════════════════════════════ */

/* ─── Light theme extras ─────────────────────────────────────── */
[data-theme="light"] .topbar { background: rgba(255,255,255,0.94); }
[data-theme="light"] .explore-header { background: rgba(255,255,255,0.94); }
[data-theme="light"] .land-nav {
  background: rgba(255,255,255,0.94);
  border-bottom: 1px solid rgba(79,70,229,0.12);
  box-shadow: 0 1px 0 rgba(79,70,229,0.06), 0 4px 24px rgba(0,0,0,0.06);
}
[data-theme="light"] .land-footer {
  background: rgba(247,248,252,0.97);
  border-top: 1px solid rgba(79,70,229,0.14);
}
[data-theme="light"] .auth-panel { background: #ffffff; }
[data-theme="light"] .user-menu { background: #ffffff; }
[data-theme="light"] .modal { box-shadow: 0 8px 48px rgba(0,0,0,0.12); }
[data-theme="light"] .link-card:hover { box-shadow: 0 12px 40px rgba(0,0,0,0.1), var(--shadow-glow); }
[data-theme="light"] .orb { opacity: 0.07; }
[data-theme="light"] .btn-primary { box-shadow: 0 2px 12px rgba(79,70,229,0.28); }
[data-theme="light"] .btn-primary:hover { box-shadow: 0 6px 20px rgba(79,70,229,0.38); }

/* ─── Geek theme extras ──────────────────────────────────────── */
[data-theme="geek"] .topbar { background: rgba(244,247,242,0.94); }
[data-theme="geek"] .explore-header { background: rgba(244,247,242,0.94); }
[data-theme="geek"] .land-nav {
  background: rgba(244,247,242,0.94);
  border-bottom: 1px solid rgba(47,141,70,0.18);
  box-shadow: 0 1px 0 rgba(47,141,70,0.08), 0 4px 24px rgba(0,0,0,0.05);
}
[data-theme="geek"] .land-footer {
  background: rgba(234,240,231,0.96);
  border-top: 1px solid rgba(47,141,70,0.15);
}
[data-theme="geek"] .auth-panel { background: #ffffff; }
[data-theme="geek"] .hero-title { letter-spacing: -0.01em; font-size: clamp(22px, 6.8vw, 68px); }
[data-theme="midnight"] .hero-title { font-size: clamp(22px, 6.8vw, 68px); }
/* mono font is wider — shrink feat tags on desktop so all 4 stay on one line */
@media (min-width: 601px) {
  [data-theme="geek"] .feat,
  [data-theme="midnight"] .feat { font-size: 11px; padding: 8px 16px; }
}
[data-theme="geek"] .link-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.08), var(--shadow-glow); }
[data-theme="geek"] .orb-1 { background: radial-gradient(circle, #2f8d46 0%, transparent 70%); opacity: 0.1; }
[data-theme="geek"] .orb-2 { background: radial-gradient(circle, #1a6634 0%, transparent 70%); opacity: 0.07; }
[data-theme="geek"] .orb-3 { background: radial-gradient(circle, #3cb55e 0%, transparent 70%); opacity: 0.07; }
[data-theme="geek"] .grad-text {
  background: linear-gradient(135deg, #2f8d46, #3cb55e, #5dd97e);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
[data-theme="geek"] input[type=text], [data-theme="geek"] input[type=email],
[data-theme="geek"] input[type=url], [data-theme="geek"] input[type=password],
[data-theme="geek"] textarea { font-family: var(--font-body); }
[data-theme="geek"] .btn-primary { box-shadow: 0 2px 12px rgba(47,141,70,0.3); }
[data-theme="geek"] .btn-primary:hover { box-shadow: 0 6px 20px rgba(47,141,70,0.4); }

/* ─── Midnight theme extras ──────────────────────────────────── */
[data-theme="midnight"] .topbar { background: rgba(2,12,24,0.92); }
[data-theme="midnight"] .explore-header { background: rgba(2,12,24,0.92); }
[data-theme="midnight"] .land-nav {
  background: linear-gradient(100deg, rgba(2,10,24,0.97) 0%, rgba(4,23,40,0.93) 100%);
  border-bottom: 1px solid rgba(0,212,192,0.2);
  box-shadow: 0 1px 0 rgba(0,212,192,0.1), 0 8px 48px rgba(0,0,0,0.5);
}
[data-theme="midnight"] .land-footer {
  background: linear-gradient(100deg, rgba(2,10,24,0.92) 0%, rgba(4,23,40,0.88) 100%);
  border-top: 1px solid rgba(0,212,192,0.15);
}
[data-theme="midnight"] .link-card:hover {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 8px 40px rgba(0,0,0,0.6), 0 0 28px rgba(0,212,192,0.15);
}
[data-theme="midnight"] .nav-item.active::before { box-shadow: 0 0 8px var(--accent); }
[data-theme="midnight"] .stat-chip:hover::before { box-shadow: 0 0 8px var(--accent); }
[data-theme="midnight"] .btn-primary { box-shadow: 0 2px 16px rgba(0,212,192,0.28); }
[data-theme="midnight"] .btn-primary:hover { box-shadow: 0 0 24px rgba(0,212,192,0.4); }
[data-theme="midnight"] .tag-pill.active,
[data-theme="midnight"] .tag-pill:hover { box-shadow: 0 0 8px var(--accent-dim); }
[data-theme="midnight"] .orb-1 { background: radial-gradient(circle, #00d4c0 0%, transparent 70%); opacity: 0.15; }
[data-theme="midnight"] .orb-2 { background: radial-gradient(circle, #0048cc 0%, transparent 70%); opacity: 0.12; }
[data-theme="midnight"] .orb-3 { background: radial-gradient(circle, #00d4c0 0%, transparent 70%); opacity: 0.08; }
[data-theme="midnight"] .grad-text {
  background: linear-gradient(135deg, #00d4c0, #00eedc, #7fffef);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
[data-theme="midnight"] .search-wrap:focus-within { box-shadow: 0 0 0 3px rgba(0,212,192,0.15); }
[data-theme="midnight"] input:focus,
[data-theme="midnight"] select:focus,
[data-theme="midnight"] textarea:focus { box-shadow: 0 0 0 3px rgba(0,212,192,0.12); }

/* ─── Dark theme extras — Trading Terminal ───────────────────── */
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 0 rgba(57,255,20,0.7); opacity: 1; }
  50%       { box-shadow: 0 0 0 5px rgba(57,255,20,0); opacity: 0.7; }
}
[data-theme="dark"] .topbar { background: rgba(10,14,20,0.94); border-bottom: 1px solid #1E2A38; }
[data-theme="dark"] .explore-header { background: rgba(10,14,20,0.94); border-bottom: 1px solid #1E2A38; }
[data-theme="dark"] .land-nav {
  background: rgba(10,14,20,0.96);
  border-bottom: 1px solid #1E2A38;
  box-shadow: 0 1px 0 rgba(57,255,20,0.06), 0 8px 48px rgba(0,0,0,0.7);
}
[data-theme="dark"] .land-footer {
  background: rgba(10,14,20,0.97);
  border-top: 1px solid #1E2A38;
}
[data-theme="dark"] .sidebar { border-right: 1px solid #1E2A38; }
[data-theme="dark"] .stat-chip { border: 1px solid #1E2A38; }
[data-theme="dark"] .stat-chip::before {
  background: linear-gradient(90deg, #39FF14, #00C853);
}
[data-theme="dark"] .stat-n { font-size: 28px; letter-spacing: 0.04em; }
[data-theme="dark"] .stat-l {
  text-transform: uppercase; letter-spacing: 0.1em;
  color: #6B7A8D; font-size: 10px;
}
[data-theme="dark"] .stat-icon { color: #39FF14; opacity: 0.85; }
[data-theme="dark"] .link-card {
  border: 1px solid #1E2A38; border-radius: 10px;
}
[data-theme="dark"] .link-card:hover {
  border-color: rgba(57,255,20,0.35);
  box-shadow: 0 0 0 1px rgba(57,255,20,0.15), 0 8px 40px rgba(0,0,0,0.7), 0 0 24px rgba(57,255,20,0.08);
}
[data-theme="dark"] .nav-item.active { color: #39FF14; }
[data-theme="dark"] .nav-item.active::before { background: #39FF14; box-shadow: 0 0 8px #39FF14; }
[data-theme="dark"] .tag-pill.active,
[data-theme="dark"] .tag-pill:hover { color: #39FF14; border-color: rgba(57,255,20,0.35); background: rgba(57,255,20,0.07); }
[data-theme="dark"] .orb-1 { background: radial-gradient(circle, #39FF14 0%, transparent 70%); opacity: 0.06; }
[data-theme="dark"] .orb-2 { background: radial-gradient(circle, #00C853 0%, transparent 70%); opacity: 0.05; }
[data-theme="dark"] .orb-3 { background: radial-gradient(circle, #39FF14 0%, transparent 70%); opacity: 0.04; }
[data-theme="dark"] .grad-text {
  background: linear-gradient(135deg, #39FF14, #00C853, #7fff6a);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
[data-theme="dark"] .search-wrap:focus-within {
  border-color: rgba(57,255,20,0.5);
  box-shadow: 0 0 0 3px rgba(57,255,20,0.1);
}
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus { box-shadow: 0 0 0 3px rgba(57,255,20,0.1); }
[data-theme="dark"] .btn-primary {
  background: linear-gradient(135deg, #39FF14, #2bcc10);
  color: #0A0E14; font-weight: 700;
  box-shadow: 0 2px 16px rgba(57,255,20,0.25);
  letter-spacing: 0.06em; text-transform: uppercase;
}
[data-theme="dark"] .btn-primary:hover {
  box-shadow: 0 0 24px rgba(57,255,20,0.4);
  background: linear-gradient(135deg, #4fff2a, #39FF14);
}
[data-theme="dark"] .section-label { color: #FFB300; letter-spacing: 0.12em; }
[data-theme="dark"] .modal { border: 1px solid #1E2A38; box-shadow: 0 8px 48px rgba(0,0,0,0.9), 0 0 40px rgba(57,255,20,0.06); }
[data-theme="dark"] .user-menu { background: #111820; border: 1px solid #1E2A38; }
[data-theme="dark"] .auth-panel { background: #111820; border: 1px solid #1E2A38; }
[data-theme="dark"] .col-count { color: #FFB300; background: rgba(255,179,0,0.08); }
[data-theme="dark"] .links-title { letter-spacing: 0.06em; text-transform: uppercase; font-size: 16px; color: #39FF14; }
[data-theme="dark"] .links-count { color: #6B7A8D; background: rgba(30,42,56,0.8); letter-spacing: 0.08em; }
[data-theme="dark"] .hero-title { letter-spacing: 0.02em; }
[data-theme="dark"] .search-wrap input,
[data-theme="dark"] .search-wrap input::placeholder { letter-spacing: 0.04em; }
[data-theme="dark"] .stat-chip:hover { border-color: rgba(57,255,20,0.3); box-shadow: 0 0 16px rgba(57,255,20,0.08); }
