/* ═══════════════════════════════════════════════════════════
   EYEMARK — STYLE.CSS
   Tutti gli stili del sito, organizzati per sezione.
═══════════════════════════════════════════════════════════ */

/* ─── THEMES ─────────────────────────────────────────────── */
:root {
  /* DARK (default) */
  --bg: #0a0b0f;
  --surface: #111318;
  --s2: #181b22;
  --s3: #1e222c;
  --accent: #4f8ef7;
  --accent2: #7df7c4;
  --accent3: #f74f7a;
  --text: #eef0f5;
  --text2: #8890a8;
  --muted: #3d4460;
  --border: rgba(79, 142, 247, .14);
  --border2: rgba(79, 142, 247, .28);
  --glow: rgba(79, 142, 247, .08);
  --shadow: 0 24px 64px rgba(0, 0, 0, .65);
  --eye-bg: #1a1c22;
  --sclera-hi: #ede6d4;
  --sclera-lo: #cec4aa;
}

[data-theme="light"] {
  --bg: #f7f8fa;
  --surface: #ffffff;
  --s2: #f0f1f4;
  --s3: #e4e6eb;
  --accent: #2563eb;
  --accent2: #059669;
  --accent3: #e11d48;
  --text: #111318;
  --text2: #5c6070;
  --muted: #a0a4b4;
  --border: rgba(37, 99, 235, .1);
  --border2: rgba(37, 99, 235, .2);
  --glow: rgba(37, 99, 235, .05);
  --shadow: 0 16px 48px rgba(0, 0, 0, .08);
  --eye-bg: #e8eaef;
  --sclera-hi: #ffffff;
  --sclera-lo: #f0f1f4;
}

/* ─── BASE RESET ─────────────────────────────────────────── */
*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  width: 100%;
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: 'Cabinet Grotesk', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
  transition: background .4s, color .4s;
}

/* Grain overlay (solo dark mode più marcato) */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.032'/%3E%3C/svg%3E");
  opacity: var(--grain-op, 0.5);
}
[data-theme="light"] { --grain-op: 0.15; }

/* Vignette */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 55;
  background: radial-gradient(ellipse 88% 82% at 50% 50%, transparent 30%, rgba(0, 0, 0, .18) 100%);
}
[data-theme="light"] body::before {
  background: radial-gradient(ellipse 88% 82% at 50% 50%, transparent 30%, rgba(0, 0, 0, .06) 100%);
}

/* ─── LOADING SCREEN ─────────────────────────────────────── */
#loading-screen {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
}
.loading-logo {
  display: flex;
  align-items: center;
  justify-content: center;
}
.loading-eye {
  width: 64px;
  height: 36px;
  border-top: 2px solid var(--accent);
  border-bottom: 2px solid var(--accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.loading-pupil {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 20px var(--accent);
  animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: .8; }
  50% { transform: scale(1.15); opacity: 1; }
}
.loading-text {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--text2);
  text-transform: uppercase;
}

/* ─── SPOTS BAR ──────────────────────────────────────────── */
#bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--border);
  z-index: 200;
}
#bar-fill {
  height: 100%;
  width: 2.847%;
  background: linear-gradient(90deg, var(--accent2), var(--accent));
  transition: width 1s ease;
}

/* ─── HEADER ─────────────────────────────────────────────── */
#hdr {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 150;
  padding: 18px 28px 70px;
  background: linear-gradient(to bottom, var(--bg) 0%, transparent 100%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  pointer-events: none;
}

.logo {
  pointer-events: all;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  text-decoration: none;
}
.logo-eye {
  width: 32px;
  height: 18px;
  position: relative;
  border-top: 1.5px solid var(--accent);
  border-bottom: 1.5px solid var(--accent);
  border-radius: 50%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-pupil {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 8px var(--accent);
}
.logo-text {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -.3px;
  color: var(--text);
  transition: color .4s;
}
.logo-text span { color: var(--accent); }

/* Nav menu */
.nav-menu {
  display: flex;
  align-items: center;
  gap: 4px;
  pointer-events: all;
}
.nav-link {
  background: none;
  border: none;
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 8px 14px;
  cursor: pointer;
  transition: color .2s;
  position: relative;
}
.nav-link:hover, .nav-link.active { color: var(--accent); }
.nav-link.active::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 14px;
  right: 14px;
  height: 1px;
  background: var(--accent);
}

/* Right side controls */
.hdr-r {
  display: flex;
  align-items: center;
  gap: 10px;
  pointer-events: all;
}
.lang-switch {
  display: flex;
  align-items: center;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 2px;
}
.lang-btn {
  background: none;
  border: none;
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 1px;
  font-weight: 500;
  padding: 5px 10px;
  cursor: pointer;
  border-radius: 16px;
  transition: all .2s;
}
.lang-btn.active {
  background: var(--accent);
  color: #fff;
}

#theme-btn {
  background: var(--s2);
  border: 1px solid var(--border2);
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 8px 14px;
  cursor: pointer;
  transition: all .3s;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
}
#theme-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.tb-icon { font-size: 13px; line-height: 1; }

/* ─── MOSAIC CANVAS ──────────────────────────────────────── */
#mosaic-wrap {
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
}
#mosaic {
  position: absolute;
  top: 0;
  left: 0;
  transform-origin: 0 0;
  will-change: transform;
}
#mosaic-wrap.interactive { cursor: crosshair; }
#mosaic-wrap.non-interactive { pointer-events: none; }
#mosaic-wrap.non-interactive .ec { pointer-events: none; }
#mosaic-wrap.dimmed::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--bg);
  opacity: .78;
  pointer-events: none;
  transition: opacity .4s;
}

/* Cella singola */
.ec {
  position: absolute;
  border-radius: 4px;
  overflow: visible;
  cursor: pointer;
  transition: transform .17s cubic-bezier(.34, 1.56, .64, 1), filter .17s;
}
.ec:hover {
  z-index: 20 !important;
  transform: scale(1.28) !important;
  filter: drop-shadow(0 0 8px var(--accent));
}
.ec canvas {
  display: block;
  border-radius: 4px;
}

@keyframes pop {
  from { transform: scale(0) rotate(-8deg); opacity: 0; }
  to { transform: scale(1) rotate(0deg); opacity: 1; }
}
.ec.new { animation: pop .5s cubic-bezier(.34, 1.56, .64, 1) both; }

/* Badge like sulla cella */
.like-badge {
  position: absolute;
  bottom: -6px;
  right: -6px;
  background: var(--accent3);
  color: #fff;
  font-family: 'DM Mono', monospace;
  font-size: 7px;
  font-weight: 400;
  padding: 1px 4px;
  border-radius: 10px;
  display: none;
  pointer-events: none;
  box-shadow: 0 2px 6px rgba(0, 0, 0, .4);
  z-index: 5;
}
.like-badge.visible { display: block; }

/* Marker "YOU" sopra la cella dell'utente */
.you-marker {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'DM Mono', monospace;
  font-size: 7px;
  font-weight: 700;
  color: var(--accent);
  background: var(--bg);
  padding: 1px 5px;
  border-radius: 8px;
  border: 1px solid var(--accent);
  white-space: nowrap;
  animation: youPulse 2s ease-in-out infinite;
}
@keyframes youPulse {
  0%, 100% { opacity: .7; }
  50% { opacity: 1; }
}

/* ─── HOME UI ────────────────────────────────────────────── */
#home-ticker {
  position: fixed;
  top: 70px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 99;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  pointer-events: none;
}
.ticker-n {
  font-size: 34px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -1px;
}
.ticker-l {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 3px;
  color: var(--text2);
  text-transform: uppercase;
}

#find-me-btn {
  position: fixed;
  bottom: 100px;
  right: 28px;
  z-index: 99;
  background: var(--s2);
  border: 1px solid var(--border2);
  color: var(--accent);
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 10px 18px;
  cursor: pointer;
  border-radius: 20px;
  transition: all .25s;
  display: none;
  align-items: center;
  gap: 8px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .2);
}
#find-me-btn.visible { display: flex; }
#find-me-btn:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.fm-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent3);
  animation: dotBlink 1.5s ease-in-out infinite;
}
@keyframes dotBlink {
  0%, 100% { opacity: .4; }
  50% { opacity: 1; }
}

#home-controls {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 70px 28px 26px;
  background: linear-gradient(to top, var(--bg) 0%, transparent 100%);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  pointer-events: none;
  transition: opacity .4s;
}
#home-controls.hidden {
  opacity: 0;
  pointer-events: none;
}

@keyframes breathe {
  0%, 100% { opacity: .35; }
  50% { opacity: .85; }
}
.hint {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 3px;
  color: var(--text2);
  text-transform: uppercase;
  animation: breathe 4s ease-in-out infinite;
}
.gi {
  display: none;
}

#addbtn {
  pointer-events: all;
  position: absolute;
  left: 50%;
  bottom: 26px;
  transform: translateX(-50%);
  background: var(--accent);
  border: none;
  color: #fff;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .5px;
  padding: 13px 36px;
  cursor: pointer;
  border-radius: 3px;
  transition: all .25s ease;
  white-space: nowrap;
  box-shadow: 0 4px 20px rgba(79, 142, 247, .35);
}
#addbtn:hover {
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 8px 32px rgba(79, 142, 247, .5);
}

/* ─── INTRO HINT ─────────────────────────────────────────── */
#intro-hint {
  position: fixed;
  bottom: 96px;
  left: 28px;
  z-index: 99;
  background: var(--s2);
  border: 1px solid var(--border2);
  padding: 14px 20px;
  border-radius: 4px;
  max-width: 280px;
  box-shadow: var(--shadow);
  transition: opacity .4s, transform .4s;
}
#intro-hint.gone {
  opacity: 0;
  transform: translateX(-20px);
  pointer-events: none;
}
.hint-kicker {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 2px;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.hint-text {
  font-size: 13px;
  color: var(--text);
  line-height: 1.5;
  margin-bottom: 10px;
}
.hint-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.hint-btn {
  background: none;
  border: none;
  color: var(--accent);
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  padding: 4px 0;
}
.hint-btn:hover { text-decoration: underline; }
.hint-dismiss {
  color: var(--text2);
  margin-left: auto;
}

/* ─── PAGE OVERLAYS ──────────────────────────────────────── */
.page-overlay {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 80px 20px 40px;
  overflow-y: auto;
  opacity: 0;
  pointer-events: none;
  transition: opacity .4s ease;
}
.page-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.page-content {
  background: var(--surface);
  border: 1px solid var(--border);
  max-width: 760px;
  width: 100%;
  border-radius: 6px;
  padding: 48px 56px 56px;
  box-shadow: var(--shadow);
  position: relative;
  transform: translateY(20px);
  transition: transform .4s ease;
}
.page-overlay.open .page-content { transform: translateY(0); }

.page-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: var(--s3);
  border: none;
  color: var(--text2);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  z-index: 5;
}
.page-close:hover {
  background: var(--border2);
  color: var(--text);
}

.page-kicker {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 4px;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 20px;
}

.page-title {
  font-family: 'Fraunces', serif;
  font-size: 56px;
  font-weight: 300;
  line-height: 1.05;
  color: var(--text);
  letter-spacing: -1.5px;
  margin-bottom: 14px;
}
.page-title em {
  font-style: italic;
  color: var(--accent);
}

.page-subtitle {
  font-size: 18px;
  color: var(--text2);
  line-height: 1.6;
  margin-bottom: 40px;
  font-weight: 300;
}

.page-content h2 {
  font-family: 'Fraunces', serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--text);
  letter-spacing: -.5px;
  margin: 40px 0 16px;
}

.page-content h3 {
  font-size: 16px;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: -.2px;
  margin: 24px 0 8px;
}

.page-content p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--text);
  margin-bottom: 18px;
  font-weight: 400;
}
.page-content p em {
  font-style: italic;
  color: var(--text2);
}
.page-content strong {
  color: var(--text);
  font-weight: 600;
}
.page-content a {
  color: var(--accent);
  text-decoration: none;
  border-bottom: 1px solid var(--border2);
}
.page-content a:hover { border-bottom-color: var(--accent); }

.signature {
  font-family: 'Fraunces', serif;
  font-style: italic;
  color: var(--text2);
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  font-size: 15px;
}

/* Steps row */
.steps-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 32px 0;
}
.step {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 24px;
}
.step-n {
  font-family: 'Fraunces', serif;
  font-size: 36px;
  font-weight: 300;
  color: var(--accent);
  letter-spacing: -1px;
  margin-bottom: 8px;
}
.step-t {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}
.step-d {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.5;
}

/* FAQ */
.faq-item {
  border-bottom: 1px solid var(--border);
  padding: 20px 0;
  cursor: pointer;
}
.faq-q {
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.faq-q::after {
  content: '+';
  color: var(--accent);
  font-weight: 300;
  font-size: 20px;
  transition: transform .2s;
}
.faq-item.open .faq-q::after { transform: rotate(45deg); }
.faq-a {
  font-size: 15px;
  line-height: 1.7;
  color: var(--text2);
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease;
}
.faq-item.open .faq-a {
  max-height: 500px;
  padding-top: 6px;
}

/* Hall of gazes */
.hall-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--border);
}
.hall-tab {
  background: none;
  border: none;
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 12px 16px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all .2s;
}
.hall-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.hall-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 16px;
}
.hall-card {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 14px;
  cursor: pointer;
  transition: all .2s;
}
.hall-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}
.hall-card canvas {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 3px;
  margin-bottom: 10px;
}
.hall-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 3px;
}
.hall-meta {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1.5px;
  color: var(--text2);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.hall-likes {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  color: var(--accent3);
}

/* Stories */
.stories-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
  margin-top: 24px;
}
.story-card {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 20px;
  cursor: pointer;
  transition: all .2s;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.story-card:hover { border-color: var(--accent); }
.story-phrase {
  font-family: 'Fraunces', serif;
  font-size: 17px;
  font-style: italic;
  color: var(--text);
  line-height: 1.5;
  flex: 1;
}
.story-author {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--text2);
  text-transform: uppercase;
  border-top: 1px solid var(--border);
  padding-top: 10px;
}

/* Contact cards */
.contact-card {
  background: var(--s2);
  border: 1px solid var(--border);
  padding: 24px;
  border-radius: 4px;
  margin-bottom: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.contact-label {
  font-size: 14px;
  color: var(--text2);
}
.contact-email {
  font-family: 'DM Mono', monospace;
  font-size: 13px;
  color: var(--accent);
  text-decoration: none;
  letter-spacing: -.5px;
  border: none !important;
}

/* Loading / empty states */
.loading, .empty {
  text-align: center;
  padding: 40px;
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* Page footer */
.page-footer {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text2);
  text-transform: uppercase;
}
.page-footer-links { display: flex; gap: 16px; }
.page-footer-links a {
  color: var(--text2);
  text-decoration: none;
  transition: color .2s;
  border: none !important;
}
.page-footer-links a:hover { color: var(--accent); }

/* ─── POPUP ──────────────────────────────────────────────── */
#popup {
  position: fixed;
  z-index: 350;
  background: var(--surface);
  border: 1px solid var(--border2);
  width: 280px;
  pointer-events: all;
  opacity: 0;
  transform: scale(.92) translateY(6px);
  transition: opacity .22s, transform .22s;
  box-shadow: var(--shadow);
  border-radius: 4px;
  overflow: hidden;
}
#popup.on {
  opacity: 1;
  transform: scale(1) translateY(0);
}
.pop-eye-strip {
  height: 90px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--s2);
  position: relative;
}
#pop-canvas-big { display: block; }
.pop-country-flag {
  position: absolute;
  top: 10px;
  right: 12px;
  font-size: 20px;
  line-height: 1;
}
.pop-body { padding: 16px 18px 14px; }
.pop-name {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 400;
  color: var(--text);
  letter-spacing: -.4px;
  margin-bottom: 2px;
}
.pop-meta {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 2px;
  color: var(--text2);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.pop-phrase {
  font-family: 'Fraunces', serif;
  font-size: 14px;
  color: var(--text2);
  line-height: 1.6;
  font-style: italic;
  border-top: 1px solid var(--border);
  padding-top: 10px;
  margin-bottom: 14px;
  display: none;
}
.pop-phrase.has { display: block; }
.pop-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pop-like {
  display: flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: 1px solid var(--border2);
  color: var(--text2);
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 13px;
  font-weight: 500;
  padding: 7px 14px;
  cursor: pointer;
  border-radius: 3px;
  transition: all .2s;
}
.pop-like:hover, .pop-like.liked {
  background: rgba(247, 79, 122, .12);
  border-color: var(--accent3);
  color: var(--accent3);
}
.pop-like.liked .heart {
  animation: heartPop .3s cubic-bezier(.34, 1.8, .64, 1) both;
}
@keyframes heartPop {
  0% { transform: scale(1); }
  50% { transform: scale(1.5); }
  100% { transform: scale(1); }
}
.heart { font-size: 15px; display: inline-block; }
.pop-close {
  background: none;
  border: none;
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  cursor: pointer;
  padding: 6px;
  transition: color .2s;
}
.pop-close:hover { color: var(--accent); }
.pop-pos {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--muted);
  margin-top: 8px;
}

/* ─── MODAL ADD GAZE ─────────────────────────────────────── */
#add-mover {
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(0, 0, 0, .6);
  backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
#add-mover.open {
  opacity: 1;
  pointer-events: all;
}

@keyframes modalIn {
  from { transform: translateY(20px) scale(.96); opacity: 0; }
  to { transform: none; opacity: 1; }
}
#add-modal {
  background: var(--surface);
  border: 1px solid var(--border2);
  width: min(500px, 94vw);
  max-height: 92vh;
  overflow-y: auto;
  position: relative;
  box-shadow: var(--shadow);
  border-radius: 6px;
}
#add-modal.open {
  animation: modalIn .3s cubic-bezier(.34, 1.1, .64, 1) both;
}

.mh {
  padding: 32px 32px 0;
  position: relative;
}
.mt {
  font-family: 'Fraunces', serif;
  font-size: 30px;
  font-weight: 400;
  color: var(--text);
  letter-spacing: -.5px;
  margin-bottom: 4px;
}
.ms {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 3px;
  color: var(--text2);
  text-transform: uppercase;
}
.mcl {
  position: absolute;
  top: 28px;
  right: 28px;
  background: var(--s3);
  border: none;
  color: var(--text2);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-size: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
}
.mcl:hover {
  background: var(--border2);
  color: var(--text);
}
.mb { padding: 24px 32px 32px; }

.ua {
  border: 1.5px dashed var(--border2);
  padding: 24px 18px;
  text-align: center;
  margin-bottom: 24px;
  cursor: pointer;
  transition: all .25s;
  position: relative;
  min-height: 100px;
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.ua:hover {
  border-color: var(--accent);
  background: var(--glow);
}
.ua input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
}
.ua-ic {
  font-size: 28px;
  color: var(--text2);
}
.ua-tx {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text2);
  text-transform: uppercase;
  line-height: 1.9;
}
.ua-tx em {
  color: var(--accent);
  font-style: normal;
}

.fi { margin-bottom: 20px; }
.fi label {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 3px;
  color: var(--text2);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.fi input, .fi select, .fi textarea {
  width: 100%;
  background: var(--s2);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 16px;
  padding: 11px 14px;
  outline: none;
  border-radius: 3px;
  transition: border-color .2s;
}
.fi input:focus, .fi select:focus, .fi textarea:focus {
  border-color: var(--accent);
}
.fi input::placeholder, .fi textarea::placeholder {
  color: var(--muted);
}
.fi select option { background: var(--surface); }
.fi textarea {
  resize: none;
  height: 72px;
  font-style: italic;
  line-height: 1.6;
}
.cc {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--text2);
  float: right;
  margin-top: 4px;
}
.cc.warn { color: var(--accent3); }
.fi-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.msub {
  width: 100%;
  margin-top: 8px;
  background: var(--accent);
  border: none;
  color: #fff;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 15px;
  font-weight: 600;
  padding: 15px;
  cursor: pointer;
  border-radius: 3px;
  transition: all .25s;
  box-shadow: 0 4px 16px rgba(79, 142, 247, .35);
}
.msub:hover {
  box-shadow: 0 6px 28px rgba(79, 142, 247, .5);
  transform: translateY(-1px);
}
.msub:disabled {
  opacity: .5;
  cursor: not-allowed;
}
.mleg {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1px;
  color: var(--text2);
  text-align: center;
  margin-top: 14px;
  line-height: 1.9;
}

/* ─── LOGIN MODAL ────────────────────────────────────────── */
#login-modal {
  position: fixed;
  inset: 0;
  z-index: 600;
  background: rgba(0, 0, 0, .7);
  backdrop-filter: blur(14px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
}
#login-modal.open {
  opacity: 1;
  pointer-events: all;
}
.login-box {
  background: var(--surface);
  border: 1px solid var(--border2);
  width: min(420px, 94vw);
  padding: 40px 36px;
  border-radius: 6px;
  position: relative;
  text-align: center;
  box-shadow: var(--shadow);
}
.login-title {
  font-family: 'Fraunces', serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--text);
  letter-spacing: -.4px;
  margin-bottom: 8px;
}
.login-sub {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.5;
  margin-bottom: 24px;
}
.login-sent-icon {
  font-size: 48px;
  color: var(--accent2);
  margin-bottom: 16px;
}

/* ─── TOAST ──────────────────────────────────────────────── */
#toast {
  position: fixed;
  bottom: 88px;
  left: 50%;
  transform: translateX(-50%) translateY(14px);
  background: var(--s2);
  border: 1px solid var(--border2);
  padding: 12px 26px;
  z-index: 700;
  border-radius: 3px;
  font-size: 14px;
  font-weight: 500;
  color: var(--accent2);
  opacity: 0;
  transition: all .35s ease;
  pointer-events: none;
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow);
}
#toast.on {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 768px) {
  #hdr {
    padding: 10px 12px 50px;
    flex-wrap: wrap;
    gap: 6px;
  }
  .logo-text { font-size: 14px; }
  .nav-menu {
    order: 3;
    width: 100%;
    justify-content: center;
    gap: 0;
    padding-top: 4px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .nav-link {
    padding: 5px 6px;
    font-size: 8px;
    letter-spacing: 1.5px;
  }
  .hdr-r { gap: 4px; }
  .hdr-user-btn { font-size: 7px; padding: 5px 8px; }
  .lang-btn { font-size: 8px; padding: 4px 8px; }
  #theme-btn { padding: 6px 10px; font-size: 8px; }

  /* Welcome bar mobile */
  #welcome-bar { top: 50px; right: 12px; }
  #welcome-text { font-size: 10px; }

  .page-content {
    padding: 28px 18px 36px;
    margin-top: 0;
    border-radius: 0;
    min-height: 100vh;
  }
  .page-overlay { padding: 0; }
  .page-title { font-size: 30px; }
  .page-subtitle { font-size: 15px; margin-bottom: 24px; }
  .page-content h2 { font-size: 22px; }
  .page-content p { font-size: 14px; }
  .steps-row { grid-template-columns: 1fr; gap: 12px; }

  #home-ticker { top: 90px; }
  .ticker-n { font-size: 24px; }
  .ticker-l { font-size: 7px; }

  /* Intro hint — più piccolo, non sovrappone */
  #intro-hint {
    left: 12px;
    right: 12px;
    bottom: 76px;
    max-width: none;
    padding: 10px 14px;
    font-size: 12px;
  }
  .hint-text { font-size: 12px; margin-bottom: 8px; }
  .hint-kicker { font-size: 7px; margin-bottom: 4px; }
  .hint-btn { font-size: 8px; }

  /* Nascondere hint tastiera e zoom su mobile — non servono */
  .gi { display: none !important; }
  .hint { display: none !important; }

  #find-me-btn {
    bottom: 72px;
    right: 12px;
    font-size: 8px;
    padding: 8px 12px;
  }
  #home-controls { padding: 50px 12px 14px; }
  #addbtn { font-size: 12px; padding: 11px 28px; bottom: 14px; }

  /* Popup mobile — centrato in basso */
  #popup {
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    top: auto !important;
    width: auto;
    max-width: none;
  }

  /* Modal add gaze */
  #add-modal { width: 100vw; max-height: 100vh; border-radius: 0; }
  .mh { padding: 24px 20px 0; }
  .mt { font-size: 24px; }
  .mb { padding: 16px 20px 24px; }

  /* Login modal */
  .login-box { width: 100vw; padding: 32px 24px; border-radius: 0; }
  .login-title { font-size: 22px; }

  /* Crop tool mobile */
  .crop-box { max-height: 200px; }
  .crop-confirm-btn { font-size: 13px; padding: 10px; }

  /* Contact cards mobile */
  .contact-card { flex-direction: column; gap: 6px; text-align: center; }

  /* FAQ mobile */
  .faq-q { font-size: 14px; }
  .faq-a { font-size: 13px; }

  /* My page mobile */
  .my-photo-box { height: 80px; }
  .fi-row { grid-template-columns: 1fr; gap: 0; }

  /* Hall/Stories grids */
  .hall-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; }
  .stories-grid { grid-template-columns: 1fr; }

  /* Success modal */
  .success-box { width: 100vw; padding: 32px 24px; border-radius: 0; }
  .success-title { font-size: 22px; }
}

/* ═══════════════════════════════════════════════════════════
   SUCCESS MODAL (conferma submit gaze)
═══════════════════════════════════════════════════════════ */
#success-modal {
  position: fixed;
  inset: 0;
  z-index: 700;
  background: rgba(0, 0, 0, .75);
  backdrop-filter: blur(18px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s;
  padding: 20px;
}
#success-modal.open {
  opacity: 1;
  pointer-events: all;
}

.success-box {
  background: var(--surface);
  border: 1px solid var(--border2);
  width: min(460px, 100%);
  padding: 44px 40px 36px;
  border-radius: 8px;
  position: relative;
  text-align: center;
  box-shadow: var(--shadow);
  animation: successPop .4s cubic-bezier(.34, 1.4, .64, 1);
}
@keyframes successPop {
  from { transform: translateY(20px) scale(.95); opacity: 0; }
  to { transform: none; opacity: 1; }
}

.success-icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 24px;
  background: var(--accent2);
  color: var(--bg);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  font-weight: 300;
  box-shadow: 0 8px 32px rgba(125, 247, 196, .4);
  animation: successIconPop .5s .1s cubic-bezier(.34, 1.6, .64, 1) backwards;
}
@keyframes successIconPop {
  from { transform: scale(0) rotate(-20deg); }
  to { transform: scale(1) rotate(0deg); }
}

.success-title {
  font-family: 'Fraunces', serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--text);
  letter-spacing: -.5px;
  margin-bottom: 12px;
  line-height: 1.2;
}

.success-sub {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.6;
  margin-bottom: 24px;
}

.success-box-info {
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 16px 20px;
  margin-bottom: 20px;
  text-align: left;
}

.success-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.success-info-row:last-child {
  border-bottom: none;
}

.success-info-label {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--text2);
  text-transform: uppercase;
}

.success-info-value {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
}

.success-info-value.pending {
  color: var(--accent3);
}

.success-hint {
  font-size: 13px;
  color: var(--text2);
  line-height: 1.6;
  margin-bottom: 24px;
  padding: 12px 16px;
  background: var(--glow);
  border-radius: 4px;
  border-left: 2px solid var(--accent);
  text-align: left;
}

.success-cta {
  max-width: 200px;
  margin: 0 auto;
}

/* ═══════════════════════════════════════════════════════════
   CROP TOOL (selezione area occhi)
═══════════════════════════════════════════════════════════ */
#crop-container {
  margin-bottom: 24px;
}

.crop-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.crop-label {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--accent);
  text-transform: uppercase;
}

.crop-change {
  background: none;
  border: 1px solid var(--border2);
  color: var(--text2);
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 12px;
  cursor: pointer;
  border-radius: 3px;
  transition: all .2s;
}
.crop-change:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.crop-box {
  width: 100%;
  max-height: 300px;
  overflow: hidden;
  background: var(--s2);
  border: 1px solid var(--border);
  border-radius: 4px;
}

.crop-box img {
  display: block;
  max-width: 100%;
}

.crop-hint {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: 1.5px;
  color: var(--text2);
  text-transform: uppercase;
  text-align: center;
  margin-top: 8px;
  animation: breathe 3s ease-in-out infinite;
}

/* Bottone conferma crop */
.crop-confirm-btn {
  display: block;
  width: 100%;
  margin-top: 12px;
  background: var(--accent2);
  color: var(--bg);
  border: none;
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 14px;
  font-weight: 600;
  padding: 12px;
  border-radius: 3px;
  cursor: pointer;
  transition: all .2s;
  box-shadow: 0 4px 16px rgba(125, 247, 196, .3);
}
.crop-confirm-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(125, 247, 196, .45);
}

/* Anteprima crop confermato */
#crop-preview {
  margin-bottom: 24px;
}

.crop-preview-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.crop-preview-img-wrap {
  background: var(--s2);
  border: 2px solid var(--accent2);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
}

.crop-preview-img-wrap img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 3px;
}

.crop-preview-ok {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 2px;
  color: var(--accent2);
  text-transform: uppercase;
  text-align: center;
  margin-top: 8px;
}

/* Override Cropper.js per adattarsi al tema scuro */
.cropper-container {
  border-radius: 4px;
}
.cropper-view-box {
  outline: 2px solid var(--accent) !important;
  outline-color: rgba(79, 142, 247, .75) !important;
}
.cropper-line {
  background-color: var(--accent) !important;
  opacity: .3 !important;
}
.cropper-point {
  background-color: var(--accent) !important;
  width: 8px !important;
  height: 8px !important;
  opacity: .9 !important;
}
.cropper-modal {
  background-color: var(--bg) !important;
  opacity: .6 !important;
}
.cropper-dashed {
  border-color: var(--accent) !important;
  opacity: .3 !important;
}

/* Admin crop tool (dentro admin.html) */
.admin-crop-modal {
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(0, 0, 0, .8);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.admin-crop-box {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 24px;
  max-width: 600px;
  width: 100%;
}
.admin-crop-box img {
  max-width: 100%;
  display: block;
}
.admin-crop-actions {
  display: flex;
  gap: 10px;
  margin-top: 16px;
  justify-content: flex-end;
}
.admin-crop-actions button {
  padding: 8px 20px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  border: none;
}

/* ═══════════════════════════════════════════════════════════
   MY PAGE (pagina personale utente)
═══════════════════════════════════════════════════════════ */
.my-section { margin-bottom: 24px; }
.my-label { display: block; font-family: 'DM Mono', monospace; font-size: 9px; letter-spacing: 2px; color: var(--accent); text-transform: uppercase; margin-bottom: 8px; }
.my-photo-box { width: 100%; height: 120px; background: var(--s2); border: 1px solid var(--border); border-radius: 4px; overflow: hidden; display: flex; align-items: center; justify-content: center; margin-bottom: 10px; }
.my-photo-box img { width: 100%; height: 100%; object-fit: contain; }
.my-change-photo-area { position: relative; display: inline-block; }
.my-change-photo-area input[type="file"] { position: absolute; inset: 0; opacity: 0; cursor: pointer; width: 100%; }
.my-account-info { margin-top: 32px; padding: 20px; background: var(--s2); border: 1px solid var(--border); border-radius: 6px; }
.my-account-info h3 { font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 12px; letter-spacing: -.2px; }
.my-info-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.my-info-row:last-child { border-bottom: none; }
.my-info-row span:first-child { color: var(--text2); font-family: 'DM Mono', monospace; font-size: 9px; letter-spacing: 2px; text-transform: uppercase; }
.my-info-row span:last-child { color: var(--text); }
.my-status-badge { padding: 2px 8px; border-radius: 3px; font-size: 11px; font-weight: 600; }
.status-pending { background: rgba(247,142,79,.15); color: #f78e4f; }
.status-approved { background: rgba(125,247,196,.15); color: var(--accent2); }
.status-rejected { background: rgba(247,79,122,.15); color: var(--accent3); }
.delete-btn { display: block; width: 100%; margin-top: 20px; background: none; border: 1px solid var(--accent3); color: var(--accent3); font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; padding: 12px; cursor: pointer; border-radius: 3px; transition: all .2s; }
.delete-btn:hover { background: rgba(247,79,122,.1); }
.personal-btn { display: block; width: 100%; background: none; border: 1px solid var(--border2); color: var(--accent); font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; padding: 12px; cursor: pointer; border-radius: 3px; transition: all .2s; text-align: center; }
.personal-btn:hover { border-color: var(--accent); background: var(--glow); }

/* Header user buttons */
.hdr-user-btn { background: var(--s2); border: 1px solid var(--border); color: var(--text2); font-family: 'DM Mono', monospace; font-size: 9px; letter-spacing: 1px; text-transform: uppercase; padding: 7px 12px; cursor: pointer; border-radius: 20px; transition: all .2s; }
.hdr-user-btn:hover { border-color: var(--accent); color: var(--accent); }

/* Welcome bar (sotto la nav, centrata) */
#welcome-bar {
  position: fixed;
  top: 46px;
  left: 0;
  right: 0;
  z-index: 140;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  padding: 0 28px;
}
#welcome-text {
  font-family: 'Cabinet Grotesk', sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: 0.3px;
}

/* Age checkbox */
.age-check { margin-bottom: 16px; }
.checkbox-label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-size: 13px; color: var(--text2); line-height: 1.5; }
.checkbox-label input[type="checkbox"] { margin-top: 3px; accent-color: var(--accent); width: 16px; height: 16px; cursor: pointer; flex-shrink: 0; }
.required-note { font-family: 'DM Mono', monospace; font-size: 8px; letter-spacing: 1px; color: var(--text2); margin-bottom: 12px; }

/* Users table (admin) — ultra compatta */
.users-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.users-table th { font-family: 'DM Mono', monospace; font-size: 8px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); text-align: left; padding: 6px 4px; border-bottom: 1px solid var(--border2); white-space: nowrap; }
.users-table td { padding: 4px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.user-row { cursor: pointer; transition: background .15s; }
.user-row:hover { background: var(--s2); }
.user-micro-thumb { width: 36px; height: 14px; overflow: hidden; border-radius: 2px; background: var(--s3); }
.user-micro-thumb img { width: 100%; height: 100%; object-fit: contain; display: block; }
.user-nick-cell { font-weight: 600; white-space: nowrap; }
.user-id-mono { font-family: 'DM Mono', monospace; font-size: 9px; color: var(--muted); word-break: break-all; }
.user-actions-cell { display: flex; gap: 2px; }
.status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }
.status-dot.status-pending { background: #f78e4f; }
.status-dot.status-approved { background: var(--accent2); }
.status-dot.status-rejected { background: var(--accent3); }
.status-dot.status-hidden { background: var(--muted); }

/* Gaze rows (In attesa, Approvati, Rifiutati) — compatte */
.gaze-row { display: flex; align-items: center; gap: 10px; padding: 6px 8px; border-bottom: 1px solid var(--border); transition: background .15s; }
.gaze-row:hover { background: var(--s2); }
.gr-thumb { width: 40px; height: 16px; border-radius: 2px; overflow: hidden; background: var(--s3); flex-shrink: 0; }
.gr-thumb img { width: 100%; height: 100%; object-fit: contain; display: block; }
.gr-info { flex: 1; min-width: 0; }
.gr-info strong { font-size: 12px; display: block; }
.gr-meta { font-family: 'DM Mono', monospace; font-size: 8px; letter-spacing: 1px; color: var(--text2); text-transform: uppercase; }
.gr-phrase { display: block; font-size: 11px; color: var(--text2); font-style: italic; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 300px; }
.gr-actions { display: flex; gap: 3px; flex-shrink: 0; }

/* Micro buttons */
.btn-micro { width: 24px; height: 24px; border-radius: 3px; border: none; cursor: pointer; font-size: 11px; display: flex; align-items: center; justify-content: center; transition: opacity .15s; }
.btn-micro:hover { opacity: .8; }
.btn-micro.btn-approve { background: var(--accent2); color: #000; }
.btn-micro.btn-reject { background: var(--accent3); color: #fff; }
.btn-micro.btn-delete { background: var(--accent3); color: #fff; }
.btn-micro.btn-ban { background: #8b1a2b; color: #fff; }
.btn-micro.btn-edit { background: var(--accent); color: #fff; }
.btn-micro.btn-hide { background: var(--s3); color: var(--text); }

/* User detail modal */
.user-detail-overlay { position: fixed; inset: 0; z-index: 900; background: rgba(0,0,0,.7); display: flex; align-items: center; justify-content: center; padding: 20px; backdrop-filter: blur(8px); }
.user-detail-box { background: var(--surface); border: 1px solid var(--border2); border-radius: 8px; padding: 28px 24px; max-width: 480px; width: 100%; position: relative; box-shadow: var(--shadow); max-height: 90vh; overflow-y: auto; }
.user-detail-close { position: absolute; top: 12px; right: 12px; background: var(--s3); border: none; color: var(--text2); width: 28px; height: 28px; border-radius: 50%; cursor: pointer; font-size: 12px; display: flex; align-items: center; justify-content: center; }
.user-detail-close:hover { color: var(--text); }
.user-detail-photo { width: 100%; height: 80px; background: var(--s2); border-radius: 4px; overflow: hidden; margin-bottom: 16px; }
.user-detail-photo img { width: 100%; height: 100%; object-fit: contain; }
.user-detail-name { font-size: 20px; font-weight: 600; margin-bottom: 4px; }
.user-detail-phrase { font-size: 13px; font-style: italic; color: var(--text2); margin-bottom: 16px; }
.user-detail-grid { background: var(--s2); border-radius: 4px; padding: 12px; margin-bottom: 16px; }
.udg-row { display: flex; justify-content: space-between; padding: 5px 0; border-bottom: 1px solid var(--border); font-size: 12px; }
.udg-row:last-child { border-bottom: none; }
.udg-row span:first-child { color: var(--text2); font-family: 'DM Mono', monospace; font-size: 8px; letter-spacing: 1.5px; text-transform: uppercase; }
.user-detail-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.user-detail-actions button { padding: 6px 12px; border-radius: 3px; font-size: 11px; font-weight: 600; cursor: pointer; border: none; font-family: inherit; }

.status-badge { padding: 2px 8px; border-radius: 3px; font-size: 10px; font-weight: 600; }
.no-photo-sm { color: var(--text2); font-size: 9px; }

/* Admin crop section */
.admin-crop-section { margin: 12px 0; }
.btn-admin-crop { display: block; width: 100%; background: none; border: 1px dashed var(--border2); color: var(--accent); font-family: 'DM Mono', monospace; font-size: 10px; letter-spacing: 1px; text-transform: uppercase; padding: 10px; cursor: pointer; border-radius: 3px; transition: all .2s; }
.btn-admin-crop:hover { border-color: var(--accent); background: var(--glow); }
