/* listaschiaffi – UI v6
   Professional, linear and clean.
   Dark default with refined light mode.
   No visual noise, no aggressive gradients, better readability.
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root{
  --radius: 14px;
  --radius2: 20px;

  --bg:#0f172a;
  --bg-elev:#111c33;
  --fg:#e5e7eb;
  --muted:#94a3b8;
  --border:rgba(148,163,184,.18);
  --border2:rgba(148,163,184,.28);
  --glass:rgba(255,255,255,.04);
  --glass2:rgba(255,255,255,.06);
  --shadow:0 20px 50px rgba(2,6,23,.38);
  --shadow2:0 8px 24px rgba(2,6,23,.24);

  --accent:#2563eb;
  --accent2:#0f766e;
  --danger:#dc2626;
  --warning:#d97706;

  --surface:rgba(255,255,255,.04);
  --surface2:rgba(255,255,255,.06);

  --pageGlow:radial-gradient(1200px 420px at 50% -8%, rgba(96,165,250,.10), transparent 64%);
}

html[data-theme="light"]{
  --bg:#f5f5f7;
  --bg-elev:#ffffff;
  --fg:#1d1d1f;
  --muted:#6e6e73;
  --border:rgba(29,29,31,.08);
  --border2:rgba(29,29,31,.12);
  --glass:rgba(255,255,255,.78);
  --glass2:rgba(255,255,255,.92);
  --shadow:0 24px 60px rgba(17,24,39,.08);
  --shadow2:0 10px 30px rgba(17,24,39,.06);
  --surface:rgba(255,255,255,.78);
  --surface2:rgba(255,255,255,.90);
  --pageGlow:radial-gradient(1100px 340px at 50% -6%, rgba(0,113,227,.08), transparent 68%);
}

body.theme-slate  { --accent:#2563eb; --accent2:#0f766e; }
body.theme-emerald{ --accent:#059669; --accent2:#2563eb; }
body.theme-amber  { --accent:#d97706; --accent2:#92400e; }
body.theme-violet { --accent:#6d28d9; --accent2:#2563eb; }
body.theme-rose   { --accent:#e11d48; --accent2:#9f1239; }
body.theme-ice    { --accent:#0284c7; --accent2:#0369a1; }

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--pageGlow), var(--bg);
  background-attachment:fixed;
  color:var(--fg);
  line-height:1.55;
}

a{color:inherit}
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.spread{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.hidden{display:none !important}
.muted{color:var(--muted)}
hr.sep{border:none;height:1px;background:linear-gradient(90deg, transparent, var(--border2), transparent);margin:24px 0}

@keyframes popIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.reveal{animation:popIn .35s ease both}
.delay-1{animation-delay:.05s}
.delay-2{animation-delay:.10s}
.delay-3{animation-delay:.15s}

/* Header */
.site-header,.topbarShell{
  position:sticky;top:0;z-index:60;
  background:color-mix(in srgb, var(--bg-elev) 82%, transparent);
  backdrop-filter:blur(18px) saturate(150%);
  border-bottom:1px solid var(--border);
}
.header-inner{height:72px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.logoMark{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 72%, #ffffff 28%));
  color:#fff;
  box-shadow:0 10px 24px color-mix(in srgb, var(--accent) 20%, transparent);
  display:grid;place-items:center;
  font-weight:900;letter-spacing:-.02em;font-size:.92rem;
}
.wordmark{font-weight:800;letter-spacing:-.02em;line-height:1.05}
.wordmark small{display:block;color:var(--muted);font-weight:600;font-size:.78rem;letter-spacing:0;margin-top:2px}
.nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* Pills, chips, badges */
.chip,.pill,.badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--fg);
  padding:7px 11px;
  border-radius:999px;
  font-weight:700;
  font-size:.78rem;
}
.dot{width:8px;height:8px;border-radius:999px;background:var(--accent)}
.pill.ok,.badge.public{background:color-mix(in srgb, var(--accent) 12%, transparent);border-color:color-mix(in srgb, var(--accent) 30%, var(--border));}
.pill.warn,.badge.unlisted{background:color-mix(in srgb, var(--warning) 12%, transparent);border-color:color-mix(in srgb, var(--warning) 28%, var(--border));}
.pill.bad,.badge.private{background:color-mix(in srgb, var(--danger) 10%, transparent);border-color:color-mix(in srgb, var(--danger) 24%, var(--border));}
.badge{font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;font-weight:800}
.badge .dot{background:var(--accent)}
.badge.unlisted .dot{background:var(--warning)}
.badge.private .dot{background:var(--danger)}

/* Toggle */
.toggle{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 10px;border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface);
  user-select:none;
}
.toggle[role="button"]{cursor:pointer}
.switch{
  width:42px;height:24px;border-radius:999px;border:1px solid var(--border2);
  background:color-mix(in srgb, var(--bg-elev) 92%, transparent);
  position:relative;
}
.knob{
  position:absolute;top:2px;left:2px;
  width:18px;height:18px;border-radius:999px;
  background:var(--accent);
  transition:left .18s ease, background .18s ease;
}
html[data-theme="light"] .knob{left:20px}
.toggle .label{font-weight:800;font-size:.78rem;color:var(--muted)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  text-decoration:none;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--surface2);
  color:var(--fg);
  font-weight:700;
  cursor:pointer;
  transition:background .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease,transform .08s ease;
}
.btn:hover{background:color-mix(in srgb, var(--surface2) 86%, #fff 14%);border-color:var(--border2);box-shadow:var(--shadow2)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}
.btn.primary{
  background:var(--accent);
  border-color:color-mix(in srgb, var(--accent) 74%, #ffffff 26%);
  color:#fff;
  box-shadow:0 12px 28px color-mix(in srgb, var(--accent) 18%, transparent);
}
.btn.primary:hover{background:color-mix(in srgb, var(--accent) 88%, #fff 12%)}
.btn.ghost{background:transparent}
.btn.bad,.btn.danger{background:color-mix(in srgb, var(--danger) 12%, transparent);border-color:color-mix(in srgb, var(--danger) 30%, var(--border))}
.btn.small{padding:8px 10px;border-radius:10px;font-size:.92rem}
.iconBtn{
  width:36px;height:36px;border-radius:10px;border:1px solid var(--border);
  background:var(--surface2);color:var(--fg);font-weight:900;cursor:pointer;
}

/* Sections */
.hero{padding:54px 0 18px}
.hero h1{font-size:2.4rem;line-height:1.04;margin:0 0 12px;letter-spacing:-.04em}
.hero p{margin:0;color:var(--muted);font-size:1.04rem;max-width:840px}
.section{padding:22px 0}
.panel{padding:18px 0}
.dashboard-actions{margin-top:14px;gap:10px;flex-wrap:wrap}
.h2{font-size:1.28rem;margin:0 0 14px;letter-spacing:-.02em}
.panelHead{margin-bottom:14px}
.panelHead h2{margin:0 0 8px;font-size:1.35rem;letter-spacing:-.02em}
.panelHead p{margin:0;color:var(--muted)}
.pills{display:flex;gap:10px;flex-wrap:wrap}
.pills.right{justify-content:flex-end}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:16px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gridAuto{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:16px}
.latest-created-grid{grid-template-columns:1fr}
.latest-created-grid--full{grid-template-columns:minmax(0,1fr)}
.updated-lists-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.your-lists-grid{grid-template-columns:repeat(auto-fit,minmax(270px,1fr))}
.exploreToolbar{margin:12px 0 16px}
.exploreSearchField{max-width:460px}

.card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:var(--shadow2);
  padding:18px;
}
.card p{margin:0;color:var(--muted)}
.card .title,.title{font-weight:800;letter-spacing:-.02em}
.name{font-weight:800;letter-spacing:-.02em}
.reason{color:var(--muted);margin-top:6px}
.metaRow{margin-top:10px}
.callout{
  border:1px solid var(--border);
  border-left:4px solid var(--accent);
  background:var(--surface);
  padding:14px 16px;
  border-radius:12px;
  color:var(--fg);
}

/* Forms */
.form{display:grid;gap:10px}
.field{display:grid;gap:6px}
label{font-weight:700;font-size:.82rem;color:var(--fg)}
input,textarea,select{
  width:100%;
  border:1px solid var(--border);
  border-radius:12px;
  padding:11px 12px;
  font:inherit;
  background:color-mix(in srgb, var(--bg-elev) 94%, transparent);
  color:var(--fg);
  outline:none;
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
input:focus,textarea:focus,select:focus{
  border-color:color-mix(in srgb, var(--accent) 58%, var(--border));
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);
}
input::placeholder,textarea::placeholder{color:color-mix(in srgb, var(--muted) 84%, transparent)}
textarea{min-height:100px;resize:vertical}
select{appearance:auto}
select option{background:var(--bg-elev);color:var(--fg)}
.select{background:color-mix(in srgb, var(--bg-elev) 94%, transparent) !important;color:var(--fg) !important}
.help{font-size:.86rem;color:var(--muted)}

/* Table */
.table{width:100%;border-collapse:separate;border-spacing:0 12px}
.table th{text-align:left;color:var(--muted);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.10em;padding:0 10px}
.table td{padding:18px 10px;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);vertical-align:top}
.table tr td:first-child{border-left:1px solid var(--border);border-top-left-radius:20px;border-bottom-left-radius:20px}
.table tr td:last-child{border-right:1px solid var(--border);border-top-right-radius:20px;border-bottom-right-radius:20px}
.rank{table-layout:fixed}
.rank th:first-child,.rank .rankIndexCell{width:72px}
.rank th:nth-child(3){text-align:center}
.rank th:nth-child(4){text-align:right}
.rank th:nth-child(3),.rank .rankScoreCell{width:150px}
.rank th:nth-child(4),.rank .rankActionsCell{width:250px}
.rank tbody tr{height:160px}
.rank td{height:160px}
.rankIndexCell{padding:0 10px 0 14px !important;vertical-align:middle !important}
.rankIndexBadge{
  width:42px;height:42px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:color-mix(in srgb, var(--surface2) 92%, transparent);
  border:1px solid color-mix(in srgb, var(--border2) 78%, var(--border));
  box-shadow:inset 0 1px 0 color-mix(in srgb, #fff 28%, transparent);
  font-weight:900;font-size:1.05rem;letter-spacing:-.03em;
}
.rank .cat{
  display:inline-flex;align-items:center;justify-content:center;
  width:fit-content;max-width:100%;align-self:start;
  font-size:.74rem;line-height:1.1;color:var(--muted);font-weight:800;
  margin-top:2px;padding:4px 10px;border-radius:999px;
  background:color-mix(in srgb, var(--surface2) 88%, transparent);
  border:1px solid color-mix(in srgb, var(--border) 82%, transparent);
  box-sizing:border-box;white-space:nowrap;
}
.rankScoreCell{padding-top:0 !important;padding-bottom:0 !important;vertical-align:middle !important}
.rankActionsCell{padding-top:0 !important;padding-bottom:0 !important;vertical-align:middle !important}
.rankRowTitle{font-weight:900;letter-spacing:-.03em;line-height:1.06;font-size:1.1rem;margin:0}
.personaggioCell{width:100%}
.personaggioCell__stack{
  display:grid;align-content:start;align-items:start;gap:8px;
  min-height:124px;height:124px;overflow:hidden;
  padding-right:8px;
}
.rankMotivation{
  font-size:.94rem;line-height:1.38;color:var(--fg-soft, var(--muted));
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;max-width:58ch;
}
.rankSignature{font-size:.86rem;line-height:1.3;color:var(--muted)}
.scoreBox{
  height:124px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
}
.scoreLabel{font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.count{
  font-weight:800;display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--border);border-radius:999px;padding:7px 12px;
  background:color-mix(in srgb, var(--bg-elev) 86%, transparent);
}
.count--hero{
  min-width:66px;justify-content:center;
  padding:10px 16px;
  font-size:1.15rem;
  border-color:color-mix(in srgb, var(--border2) 68%, var(--border));
  background:color-mix(in srgb, var(--surface2) 96%, transparent);
  box-shadow:inset 0 1px 0 color-mix(in srgb, #fff 20%, transparent);
}
.rankActions{
  height:124px;display:flex;align-items:flex-end;justify-content:flex-end;
}
.inline-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;align-items:center}
.inline-actions .btn{white-space:nowrap;min-height:40px;padding-inline:14px}
.countBadge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 7px;
  margin-left:6px;border-radius:999px;
  background:color-mix(in srgb, var(--accent) 14%, var(--surface));
  border:1px solid color-mix(in srgb, var(--accent) 32%, var(--border));
  color:var(--fg);font-size:.76rem;font-weight:900;line-height:1;
}
/* Cover cards */
.hero-cover{
  border:1px solid var(--border);
  border-radius:var(--radius2);
  overflow:hidden;
  background:var(--surface);
  box-shadow:var(--shadow);
  margin:8px 0 18px;
}
.coverShell{position:relative}
.cover-bg{
  height:160px;
  background-size:cover;
  background-position:center;
  filter:none;
  transform:scale(1.01);
}
.cover-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(15,23,42,.04), rgba(15,23,42,.22));
}
html[data-theme="light"] .cover-overlay{
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.16));
}
.cover-inner{padding:18px 20px}
.list-hero .cover-inner{background:var(--surface)}
.cardLink{display:block;color:inherit;text-decoration:none}
.cardLink:focus-visible{outline:none;box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent)}
a.hero-cover{display:block;color:inherit;text-decoration:none}
.cover-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

.coverMini{
  position:relative;height:118px;border-radius:14px;overflow:hidden;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--surface) 72%, transparent);
}
.latest-list-card .coverMini{height:168px}
.latest-list-card h4{font-size:1.22rem}
.latest-list-card .meta{font-size:.95rem}
.coverMiniBg{position:absolute;inset:0;background-size:cover;background-position:center;filter:none}
.coverMiniOverlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(15,23,42,.03), rgba(15,23,42,.14))}
html[data-theme="light"] .coverMiniOverlay{background:linear-gradient(180deg, rgba(255,255,255,.01), rgba(255,255,255,.12))}
.list-card__titleRow{display:block;gap:14px;margin-top:12px}
.list-card__titleRow h4{margin:0;font-size:1.05rem;letter-spacing:-.02em;min-width:0}
.list-card__footer{display:flex;flex-direction:column;align-items:stretch;gap:12px;margin-top:10px}
.list-card__badges{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap;align-self:flex-end;max-width:100%}
.list-card .meta{font-size:.9rem;line-height:1.55;color:var(--muted);margin:0;width:100%;max-width:100%;word-break:normal;overflow-wrap:anywhere;text-wrap:pretty}
.owner-list-card .meta{margin-top:0}
.owner-list-card__actions{justify-content:flex-start}
.owner-list-card__actionsGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.owner-list-card__actionsGrid--two{grid-template-columns:repeat(2,minmax(0,1fr))}
.owner-list-card__actionsGrid .btn{width:100%;justify-content:center;white-space:nowrap}
.modalActionsRow{justify-content:flex-end;flex-wrap:wrap}

/* List page */
.list-hero{margin:10px 0 22px;background:none}
.list-hero .coverShell{background:none}
.list-hero .cover-bg{height:clamp(160px, 20vw, 220px)}
.list-hero__top{align-items:flex-start;gap:16px}
.list-hero__title{min-width:0}
.list-title{margin:0;letter-spacing:-.04em;line-height:1.05;font-size:clamp(24px, 3vw, 38px)}
.list-subtitle{margin-top:6px;color:var(--muted);font-size:13.5px}
.list-actions{margin-top:14px;gap:10px}
.list-actions .btn{white-space:nowrap}
.list-hero__description{margin:12px 0 0;max-width:78ch;color:var(--fg);line-height:1.62;font-size:.98rem}
.list-card__desc{margin:8px 0 0;color:var(--muted);font-size:.92rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.list-vote-panel{margin-top:16px;padding:16px 18px;border:1px solid var(--border);border-radius:20px;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, var(--surface2)), color-mix(in srgb, var(--accent2) 6%, var(--surface)));box-shadow:0 16px 34px rgba(0,0,0,.10)}
.list-vote-panel__top{align-items:flex-start;gap:12px}
.list-vote-panel__copy{margin:10px 0 0;max-width:74ch}
.list-vote-panel__actions{margin-top:14px;align-items:center;gap:10px;flex-wrap:wrap}
.voteLoreCard{border-radius:18px;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, var(--surface2)), color-mix(in srgb, var(--accent2) 5%, var(--surface)))}

/* Notifications */
.notifBell{position:relative;padding-right:14px}
.notifBell__icon{font-size:1rem;line-height:1}
.notifBell__badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 7px;border-radius:999px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 88%, #fff 0%), color-mix(in srgb, var(--accent2) 72%, #fff 0%));
  color:#fff;font-size:.76rem;font-weight:900;line-height:1;
}

.accountSettingsBtn{
  position:relative;
  padding-inline:14px 18px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, var(--surface2)), color-mix(in srgb, var(--accent2) 10%, var(--surface2)));
  border-color:color-mix(in srgb, var(--accent) 28%, var(--border));
  box-shadow:0 12px 34px color-mix(in srgb, var(--accent) 16%, transparent);
}
.accountSettingsBtn:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, var(--surface2)), color-mix(in srgb, var(--accent2) 14%, var(--surface2)));
}
.accountSettingsBtn__icon{display:inline-flex;align-items:center;justify-content:center;font-size:1rem;line-height:1}
.accountSettingsBtn__avatar{
  width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
  background:color-mix(in srgb, var(--accent) 18%, var(--surface));
  border:1px solid color-mix(in srgb, var(--accent) 30%, var(--border));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.userSettingsModalCard{width:min(920px, calc(100% - 28px))}
.userSettingsModalHead{
  padding:18px 20px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 72%, transparent), transparent);
}
.userSettingsModalBody{padding:18px 20px 20px}
.userSettingsHero{
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-bottom:16px;padding:16px;border:1px solid var(--border);border-radius:22px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, var(--surface2)), color-mix(in srgb, var(--accent2) 6%, var(--surface)));
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}
.userSettingsHero__identity{display:flex;align-items:center;gap:14px;min-width:0}
.userSettingsHero__avatar{
  width:54px;height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center;
  font-size:1.35rem;font-weight:900;
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 72%, #fff 0%), color-mix(in srgb, var(--accent2) 58%, #fff 0%));
  color:#fff;box-shadow:0 12px 28px color-mix(in srgb, var(--accent) 28%, transparent);
}
.userSettingsHero__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.userSettingsTabs{
  display:inline-flex;align-items:center;gap:8px;padding:6px;
  border:1px solid var(--border);border-radius:999px;background:var(--surface2);
  margin-bottom:18px;
}
.userSettingsTab{
  appearance:none;border:none;background:transparent;color:var(--muted);cursor:pointer;
  border-radius:999px;padding:10px 16px;font-weight:800;letter-spacing:-.01em;
  transition:.18s ease;
}
.userSettingsTab:hover{color:var(--fg);background:color-mix(in srgb, var(--surface) 78%, transparent)}
.userSettingsTab.is-active{
  color:#fff;background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 88%, #fff 0%), color-mix(in srgb, var(--accent2) 72%, #fff 0%));
  box-shadow:0 10px 24px color-mix(in srgb, var(--accent) 26%, transparent);
}
.userSettingsPanel{display:none}
.userSettingsPanel.is-active{display:block}
.userSettingsGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.userSettingsCard{
  border-radius:22px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 92%, transparent), color-mix(in srgb, var(--surface) 82%, transparent));
  box-shadow:0 14px 34px rgba(0,0,0,.10);
}
.userSettingsCard__eyebrow{margin-bottom:8px;font-size:.74rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.userSettingsCard--danger{border-color:color-mix(in srgb, var(--danger) 34%, var(--border))}
.userSettingsModal__footer{padding-top:6px}

.modal{
  position:fixed;inset:0;z-index:80;display:block;pointer-events:none;
  opacity:0;visibility:hidden;transition:opacity .22s ease, visibility .22s ease;
}
.modal[aria-hidden="false"]{opacity:1;visibility:visible;pointer-events:auto}
.modalBackdrop{
  position:absolute;inset:0;background:rgba(2,6,23,.56);
  backdrop-filter:blur(10px);
  opacity:0;transition:opacity .22s ease;
}
.modal[aria-hidden="false"] .modalBackdrop{opacity:1}
html[data-theme="light"] .modalBackdrop{background:rgba(15,23,42,.24)}
.modalCard{
  position:relative;
  width:min(760px, calc(100% - 28px));
  margin:92px auto 24px;
  border:1px solid var(--border);
  border-radius:var(--radius2);
  background:color-mix(in srgb, var(--bg-elev) 95%, transparent);
  backdrop-filter:blur(16px) saturate(140%);
  box-shadow:var(--shadow);
  overflow:hidden;
  transform:translateY(22px) scale(.985);
  opacity:0;
  transition:transform .24s cubic-bezier(.22,.8,.24,1), opacity .24s ease;
}
.modal[aria-hidden="false"] .modalCard{transform:translateY(0) scale(1);opacity:1}

.modalCard--narrow{width:min(720px, calc(100% - 28px))}
.notificationCard{padding:16px 18px}
.notificationCard__top{align-items:flex-start;gap:12px}
.notificationCard .reason{margin-top:6px}

/* Toast */
.toast{
  position:fixed;right:18px;top:88px;z-index:90;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--bg-elev) 90%, transparent);
  backdrop-filter:blur(12px) saturate(130%);
  padding:10px 12px;border-radius:12px;box-shadow:var(--shadow);
  font-weight:800;
}
.toast.ok{border-color:color-mix(in srgb, var(--accent) 32%, var(--border))}
.toast.bad{border-color:color-mix(in srgb, var(--danger) 42%, var(--border))}

/* Modals */
.modalHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.modalHead h3{margin:0;letter-spacing:-.02em}
.modalBody{padding:16px;max-height:calc(100vh - 190px);overflow:auto}
html.modalOpen{overflow:hidden}

/* Mobile sticky bar */
.stickyBar,.mobilebar{position:fixed;left:0;right:0;bottom:0;z-index:70;padding:10px 14px}
.stickyBar{display:none;background:transparent}
.shell{
  max-width:1120px;margin:0 auto;
  display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap;
  padding:10px 12px;
  border:1px solid var(--border);
  background:color-mix(in srgb, var(--bg-elev) 92%, transparent);
  backdrop-filter:blur(12px) saturate(130%);
  border-radius:16px;
  box-shadow:var(--shadow);
}
.mini{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  text-decoration:none;padding:9px 12px;border-radius:10px;border:1px solid var(--border);
  background:var(--surface2);color:var(--fg);font-weight:700;cursor:pointer;
}

/* Footer */
.footer{border-top:1px solid var(--border);padding:22px 0;margin-top:40px;color:var(--muted);font-size:.9rem}

/* Home polish */
.panelSplit{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.panelLeft{flex:1 1 360px;min-width:280px}
.panelRight{flex:0 0 auto}
.card:hover{border-color:var(--border2)}
.hero .row{gap:12px}

@media (max-width: 980px){
  .grid3,.grid2,.updated-lists-grid{grid-template-columns:1fr}
  .hero h1{font-size:2.05rem}
  .header-inner{height:auto;padding:12px 0}
  .list-card__footer{align-items:stretch}
  .list-card__badges{justify-content:flex-start;align-self:flex-start}
}

@media (max-width: 880px){
  body{padding-bottom:88px}
  .stickyBar{display:block}
}
@media (min-width: 881px){
  body{padding-bottom:0}
}

@media (max-width: 640px){
  .container{padding:0 16px}
  .panelRight{width:100%}
  .pills.right{justify-content:flex-start}
  .list-hero .cover-inner{padding:16px 14px 14px}
  .list-hero__top{flex-direction:column;align-items:stretch}
  .list-actions .btn{flex:1 1 auto}
  .modalCard{margin:72px auto 18px}
  .table{display:block;overflow:auto}
}


@media (max-width: 640px){
  .rank tbody tr{height:auto}
  .rank td{height:auto}
  .rank .rankScoreCell,.rank .rankActionsCell{width:auto;text-align:left;vertical-align:top;padding-top:18px !important;padding-bottom:18px !important}
  .rank .rankIndexCell{padding-top:18px !important;padding-bottom:18px !important}
  .scoreBox,.rankActions{height:auto;align-items:flex-start;justify-content:flex-start}
  .inline-actions{justify-content:flex-start}
  .personaggioCell__stack{height:auto;min-height:auto;overflow:visible}
}

/* Reperti / fascicolo */
.uploadDrop{
  position:relative;
  display:grid;
  gap:6px;
  padding:16px;
  border:1px dashed color-mix(in srgb, var(--accent) 36%, var(--border));
  border-radius:16px;
  background:color-mix(in srgb, var(--surface2) 88%, transparent);
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.uploadDrop.isDrag{
  border-color:color-mix(in srgb, var(--accent) 72%, var(--border));
  background:color-mix(in srgb, var(--accent) 8%, var(--surface2));
  box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent);
}
.uploadDrop input[type="file"]{
  position:absolute; inset:0; opacity:0; cursor:pointer;
}
.uploadDrop__title{font-weight:800;letter-spacing:-.02em}
.uploadList{display:grid;gap:8px;margin-top:10px}
.uploadList__item{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--surface);
}
.uploadList__name{font-weight:700;min-width:0;overflow-wrap:anywhere}
.uploadList__meta{font-size:.84rem;color:var(--muted);white-space:nowrap}
.evidenceBlock{margin-top:auto;padding-top:0;border-top:0}
.evidenceBlock__head{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin:0;row-gap:4px}
.evidenceBlock--compact{margin-top:2px}

.evidencePill__short{display:none}

.evidencePill,
.evidenceMeta{
  min-height:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  max-width:max-content;
  border-radius:999px;
  font-weight:700;
  letter-spacing:-.015em;
  text-transform:none;
  background:color-mix(in srgb, var(--surface2) 92%, transparent);
  line-height:1;
  white-space:nowrap;
}
.evidencePill{
  color:var(--fg);
  border-color:color-mix(in srgb, var(--border2) 88%, transparent);
  padding:5px 8px;
  font-size:.74rem;
}
.evidencePill:hover{transform:translateY(-1px)}
.evidenceMeta{
  color:var(--muted);
  border-color:color-mix(in srgb, var(--border) 92%, transparent);
  font-size:.74rem;
  padding:5px 8px;
}
.attachmentGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.attachmentGrid--compact{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.attachmentCard{
  display:flex;align-items:center;gap:10px;
  min-height:56px;padding:12px;border-radius:14px;border:1px solid var(--border);
  background:var(--surface2);text-decoration:none;color:var(--fg);
}
.attachmentCard:hover{border-color:var(--border2);box-shadow:var(--shadow2)}
.attachmentCard--file{justify-content:flex-start}
.attachmentCard__meta{font-size:.82rem;font-weight:700;line-height:1.35;overflow-wrap:anywhere}
.attachmentCard__icon{
  flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;
  min-width:44px;height:44px;padding:0 10px;border-radius:12px;background:color-mix(in srgb, var(--accent) 12%, transparent);
  border:1px solid color-mix(in srgb, var(--accent) 28%, var(--border));font-weight:900
}

.badgeButton{
  appearance:none;
  -webkit-appearance:none;
  font:inherit;
  cursor:pointer;
  text-transform:uppercase;
}
.badgeButton:hover{border-color:var(--border2);box-shadow:var(--shadow2)}
.evidencePill.badgeButton{text-transform:none;letter-spacing:-.01em}
.attachmentListModal{display:grid;gap:10px}
.attachmentListModal .attachmentCard{min-height:60px;border-radius:16px}
.attachmentListEntry{display:grid;gap:8px}
.attachmentEntryActions{display:flex;justify-content:flex-end}
.attachmentRemoveBtn{
  width:30px;height:30px;min-width:30px;padding:0;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.86rem;line-height:1;
  background:color-mix(in srgb, var(--danger) 10%, var(--surface2));
  border-color:color-mix(in srgb, var(--danger) 26%, var(--border));
}
.attachmentRemoveBtn:hover{transform:translateY(-1px)}
.attachmentRemoveBtn:disabled{transform:none}

.rank .cat, .evidencePill, .evidenceMeta{max-width:100%;}

@media (max-width: 900px){
  .userSettingsGrid{grid-template-columns:1fr}
  .userSettingsModalCard{width:min(calc(100% - 20px), 920px)}
}
@media (max-width: 640px){
  .userSettingsModalHead,.userSettingsModalBody{padding:16px}
  .userSettingsHero{padding:14px;border-radius:20px}
  .userSettingsHero__avatar{width:48px;height:48px;border-radius:16px}
  .userSettingsTabs{display:flex;width:100%}
  .userSettingsTab{flex:1;text-align:center;padding:11px 12px}
}


/* =========================================================
   Premium pass v6.16 — sitewide visual alignment
   ========================================================= */
:root{
  --radius:18px;
  --radius2:28px;
  --shadow:0 34px 90px rgba(2,6,23,.42);
  --shadow2:0 18px 44px rgba(2,6,23,.24);
  --surface:color-mix(in srgb, rgba(255,255,255,.08) 82%, transparent);
  --surface2:color-mix(in srgb, rgba(255,255,255,.10) 86%, transparent);
  --pageGlow:
    radial-gradient(760px 320px at 8% -2%, rgba(59,130,246,.14), transparent 68%),
    radial-gradient(720px 340px at 92% 0%, rgba(14,165,233,.10), transparent 70%),
    radial-gradient(980px 520px at 50% -10%, rgba(96,165,250,.10), transparent 66%);
}
html[data-theme="light"]{
  --shadow:0 34px 90px rgba(15,23,42,.10);
  --shadow2:0 18px 44px rgba(15,23,42,.08);
  --surface:color-mix(in srgb, rgba(255,255,255,.86) 92%, transparent);
  --surface2:color-mix(in srgb, rgba(255,255,255,.96) 96%, transparent);
  --pageGlow:
    radial-gradient(780px 320px at 8% -2%, rgba(0,113,227,.10), transparent 68%),
    radial-gradient(760px 360px at 92% 0%, rgba(14,165,233,.08), transparent 72%),
    radial-gradient(1100px 520px at 50% -8%, rgba(59,130,246,.06), transparent 70%);
}
body{
  min-height:100vh;
  background:var(--bg);
}
body::before,
body::after{
  content:none;
}
main,.footer,.site-header{position:relative;z-index:1}

.site-header,.topbarShell{
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 88%, transparent), color-mix(in srgb, var(--bg-elev) 76%, transparent));
  backdrop-filter:blur(22px) saturate(160%);
  border-bottom:1px solid color-mix(in srgb, var(--border2) 84%, transparent);
  box-shadow:0 10px 34px rgba(2,6,23,.10);
}
.site-header::after,.topbarShell::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-1px;height:1px;
  background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 30%, var(--border)), transparent);
}
.header-inner{height:78px;gap:16px}
.brand{gap:14px}
.logoMark{
  width:42px;height:42px;border-radius:14px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 84%, #fff 16%), color-mix(in srgb, var(--accent2) 64%, var(--accent)));
  box-shadow:
    0 14px 34px color-mix(in srgb, var(--accent) 24%, transparent),
    inset 0 1px 0 rgba(255,255,255,.18);
}
.wordmark{font-size:1rem}
.wordmark small{font-size:.75rem;color:color-mix(in srgb, var(--muted) 92%, transparent)}
.nav{gap:12px}

.hero{padding:68px 0 26px}
.hero h1{font-size:clamp(2.35rem, 4.8vw, 3.8rem);letter-spacing:-.05em}
.hero p{font-size:1.05rem;max-width:860px}
.section{padding:28px 0}
.panel{
  padding:20px 22px;
  border:1px solid color-mix(in srgb, var(--border2) 78%, var(--border));
  border-radius:26px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 84%, transparent), color-mix(in srgb, var(--surface) 88%, transparent));
  box-shadow:var(--shadow2), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
  backdrop-filter:blur(16px) saturate(135%);
}
.panelHead{margin-bottom:16px}
.panelHead h2,.h2{font-size:1.34rem;letter-spacing:-.03em}
.panelSplit{align-items:center;gap:20px}

.card,
.hero-cover,
.modalCard,
.shell,
.coverMini,
.uploadDrop,
.callout{
  border:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 92%, transparent), color-mix(in srgb, var(--surface) 84%, transparent));
  box-shadow:var(--shadow2), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
  backdrop-filter:blur(16px) saturate(135%);
}
.card{border-radius:22px;padding:20px}
.card:hover,.hero-cover:hover,.coverMini:hover{
  border-color:color-mix(in srgb, var(--accent) 18%, var(--border2));
  box-shadow:0 22px 48px rgba(2,6,23,.20), inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
}
.title,.card .title,.name,.rankRowTitle{letter-spacing:-.03em}
.card p,.reason,.help,.muted{color:color-mix(in srgb, var(--muted) 96%, transparent)}

.btn,.mini{
  min-height:44px;
  padding:10px 16px;
  border-radius:14px;
  border:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 90%, transparent), color-mix(in srgb, var(--surface) 92%, transparent));
  box-shadow:0 10px 24px rgba(2,6,23,.10), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}
.btn:hover,.mini:hover{transform:translateY(-1px)}
.btn.primary{
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 92%, #fff 0%), color-mix(in srgb, var(--accent2) 72%, #fff 0%));
  border-color:color-mix(in srgb, var(--accent) 74%, #ffffff 26%);
  box-shadow:0 16px 32px color-mix(in srgb, var(--accent) 22%, transparent), inset 0 1px 0 rgba(255,255,255,.20);
}
.btn.primary:hover{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 84%, #fff 10%), color-mix(in srgb, var(--accent2) 74%, #fff 8%))}
.btn.ghost{background:linear-gradient(180deg, color-mix(in srgb, var(--surface) 64%, transparent), color-mix(in srgb, transparent 56%, transparent))}
.btn.bad,.btn.danger{
  background:linear-gradient(135deg, color-mix(in srgb, var(--danger) 16%, var(--surface2)), color-mix(in srgb, var(--danger) 10%, var(--surface)));
}
.iconBtn{
  width:38px;height:38px;border-radius:12px;
  box-shadow:0 10px 22px rgba(2,6,23,.10), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}

.chip,.pill,.badge,.count,.toggle{
  border-color:color-mix(in srgb, var(--border2) 84%, var(--border));
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 90%, transparent), color-mix(in srgb, var(--surface) 92%, transparent));
  box-shadow:inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}
.chip,.pill,.badge{padding:8px 12px}
.badge{font-size:.7rem}
.count--hero{padding:12px 18px;border-radius:16px}
.countBadge,.notifBell__badge{
  box-shadow:0 10px 20px color-mix(in srgb, var(--accent) 18%, transparent), inset 0 1px 0 rgba(255,255,255,.18);
}

input,textarea,select{
  min-height:48px;
  border-radius:14px;
  border:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 96%, transparent), color-mix(in srgb, var(--surface) 84%, transparent));
  box-shadow:inset 0 1px 0 color-mix(in srgb, #fff 6%, transparent);
}
textarea{min-height:112px}
label{font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:color-mix(in srgb, var(--muted) 78%, var(--fg))}
.help{font-size:.88rem;line-height:1.5}

.table{border-spacing:0 14px}
.table th{padding:0 12px 2px}
.table td{
  padding:20px 12px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 92%, transparent), color-mix(in srgb, var(--surface) 84%, transparent));
  border-top:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));
  border-bottom:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));
  box-shadow:0 14px 32px rgba(2,6,23,.08), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}
.table tr td:first-child{border-left:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));border-top-left-radius:24px;border-bottom-left-radius:24px}
.table tr td:last-child{border-right:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));border-top-right-radius:24px;border-bottom-right-radius:24px}
.rank tbody tr{height:168px}
.rank td{height:168px}
.rankIndexBadge{
  width:46px;height:46px;border-radius:16px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 94%, transparent), color-mix(in srgb, var(--surface) 84%, transparent));
  box-shadow:0 10px 24px rgba(2,6,23,.08), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
}
.rank .cat{
  border-radius:999px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 92%, transparent), color-mix(in srgb, var(--surface) 86%, transparent));
}
.scoreBox,.rankActions{height:128px}
.rankMotivation{line-height:1.42}
.inline-actions .btn{min-height:42px}

.hero-cover{border-radius:30px;overflow:hidden;box-shadow:var(--shadow)}
.cover-bg{height:172px}
.list-hero .cover-bg{height:clamp(180px, 22vw, 248px)}
.cover-overlay{background:linear-gradient(180deg, rgba(15,23,42,.06), rgba(15,23,42,.32))}
html[data-theme="light"] .cover-overlay{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.18))}
.cover-inner{padding:22px 24px}
.list-title{font-size:clamp(28px, 3.4vw, 42px)}
.list-subtitle{font-size:.88rem}
.cover-actions,.list-actions{gap:12px}
.coverMini{height:122px;border-radius:18px}
.latest-list-card .coverMini{height:178px}
.list-card__titleRow{margin-top:14px}
.list-card__titleRow h4{font-size:1.1rem}
.list-card__footer{gap:14px;margin-top:12px}
.owner-list-card__actionsGrid{gap:12px}

.accountSettingsBtn{
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, var(--surface2)), color-mix(in srgb, var(--accent2) 12%, var(--surface2)));
  box-shadow:0 16px 38px color-mix(in srgb, var(--accent) 18%, transparent), inset 0 1px 0 rgba(255,255,255,.12);
}
.userSettingsHero{
  border-radius:24px;
  box-shadow:0 20px 48px rgba(2,6,23,.14), inset 0 1px 0 rgba(255,255,255,.10);
}
.userSettingsCard{box-shadow:0 18px 42px rgba(2,6,23,.12), inset 0 1px 0 rgba(255,255,255,.08)}

.modalBackdrop{background:rgba(2,6,23,.62);backdrop-filter:blur(14px)}
.modalCard{
  margin:84px auto 24px;
  border-radius:30px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 96%, transparent), color-mix(in srgb, var(--surface) 88%, transparent));
  box-shadow:0 38px 100px rgba(2,6,23,.42), inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
}
.modalHead{
  padding:18px 20px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 74%, transparent), transparent);
}
.modalBody{padding:20px;max-height:calc(100vh - 180px)}
.toast{
  top:94px;right:20px;padding:12px 14px;border-radius:16px;
  box-shadow:0 18px 42px rgba(2,6,23,.18), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}

.stickyBar,.mobilebar{padding:12px 14px}
.shell{
  padding:12px 14px;
  border-radius:20px;
  box-shadow:0 22px 56px rgba(2,6,23,.24), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}
.mini{border-radius:12px}

.footer{
  margin-top:56px;
  padding:28px 0 34px;
  border-top:1px solid color-mix(in srgb, var(--border2) 86%, var(--border));
  background:linear-gradient(180deg, transparent, color-mix(in srgb, var(--surface) 52%, transparent));
}
.footer::before{
  content:"";
  position:absolute;left:0;right:0;top:-1px;height:1px;
  background:linear-gradient(90deg, transparent, color-mix(in srgb, var(--accent) 24%, var(--border)), transparent);
}

.exploreToolbar,.dashboard-actions,.pills,.row{row-gap:12px}
.notificationCard,.uploadList__item{
  border-radius:18px;
  background:linear-gradient(180deg, color-mix(in srgb, var(--bg-elev) 94%, transparent), color-mix(in srgb, var(--surface) 86%, transparent));
  box-shadow:0 14px 32px rgba(2,6,23,.10), inset 0 1px 0 color-mix(in srgb, #fff 8%, transparent);
}
.uploadList__item{border:1px solid color-mix(in srgb, var(--border2) 82%, var(--border))}

@media (max-width: 980px){
  .header-inner{height:auto;padding:14px 0}
  .hero{padding-top:58px}
  .panel{padding:18px}
}
@media (max-width: 640px){
  .hero{padding-top:46px}
  .card{padding:18px}
  .cover-inner,.modalBody,.userSettingsModalBody{padding:18px}
  .modalCard{margin:70px auto 16px;border-radius:24px}
  .list-title{font-size:clamp(26px, 8vw, 34px)}
}


/* v6.16.1 alignment and modal stability */
.dashboardHeroPanel{
  padding:16px 18px;
}
.dashboard-actions{
  margin-top:0;
  align-items:center;
  width:fit-content;
  max-width:100%;
}
.dashboard-actions .btn{
  min-height:48px;
}
.homeHeroPanel{
  margin-top:18px;
}
.panelSplit--hero{
  align-items:center;
}
.heroCtaRow{
  align-items:center;
}
.homeHeroStats .pills.right{
  justify-content:flex-end;
}
.heroSupport{
  margin-top:24px;
  max-width:none;
  padding-left:2px;
}
.userSettingsGrid{
  align-items:start;
}
.userSettingsCard .form .row:last-child{
  margin-top:16px;
}
.userSettingsModal__footer{
  margin-top:24px !important;
  padding-top:16px;
  border-top:1px solid color-mix(in srgb, var(--border2) 78%, var(--border));
}
.modal{
  overflow-y:auto;
  padding:24px 0;
}
.modalCard{
  margin:0 auto;
  display:flex;
  flex-direction:column;
  max-height:min(calc(100dvh - 48px), 960px);
}
.modalBody{
  flex:1 1 auto;
  min-height:0;
  max-height:none;
  overflow:auto;
  padding:20px 20px 28px;
}
.modalHead{
  flex:0 0 auto;
}
.modalBody > .card:last-child,
.modalBody > .form:last-child{
  margin-bottom:2px;
}
@media (max-width: 900px){
  .dashboardHeroPanel{
    padding:14px 14px;
  }
  .dashboard-actions{
    width:100%;
  }
  .dashboard-actions .btn{
    flex:0 1 auto;
  }
}
@media (max-width: 640px){
  .heroSupport{
    margin-top:12px;
  }
  .homeHeroStats{
    width:100%;
  }
  .homeHeroStats .pills.right{
    justify-content:flex-start;
  }
  .modal{
    padding:14px 0;
  }
  .modalCard{
    max-height:min(calc(100dvh - 20px), 960px);
  }
  .modalBody{
    padding:18px 18px 24px;
  }
}


/* v6.16.2 create item modal footer overlap fix */
.modal--createItem{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:36px 14px 56px;
}
.modal--createItem .modalBackdrop{
  background:rgba(2,6,23,.80);
  backdrop-filter:blur(18px);
}
.createItemModalCard{
  width:min(780px, calc(100% - 28px));
  margin:0;
  max-height:min(calc(100dvh - 92px), 860px);
}
.createItemModalHead{
  flex:0 0 auto;
}
.createItemModalBody{
  padding:18px 20px 28px;
  overscroll-behavior:contain;
  scrollbar-gutter:stable both-edges;
}
.createItemModalInnerCard{
  padding-bottom:28px;
}
.createItemForm > .muted:last-child{
  margin-bottom:0;
}
html.modalOpen .stickyBar,
html.modalOpen .mobilebar{
  opacity:0;
  pointer-events:none;
}
html.modalOpen--createItem .footer{
  opacity:0;
  pointer-events:none;
}
@media (max-width: 640px){
  .modal--createItem{
    padding:14px 10px 24px;
  }
  .createItemModalCard{
    width:min(100%, calc(100% - 4px));
    max-height:min(calc(100dvh - 38px), 860px);
    border-radius:24px;
  }
  .createItemModalBody{
    padding:16px 16px 22px;
  }
  .createItemModalInnerCard{
    padding:16px 16px 20px;
  }
}

/* v6.16.7 explore archive */
.exploreArchiveSection{padding-top:8px}
.exploreArchivePanel{padding:20px 22px}
.exploreArchivePanel__head{align-items:center;margin-bottom:10px}
.exploreArchiveIntro{margin-top:6px}
.exploreArchiveToolbar{margin-top:8px}
.exploreArchiveSearchField{max-width:620px}
.exploreArchiveSearchWrap{position:relative}
.exploreArchiveSearchInput{padding-right:112px}
.exploreArchiveClear{position:absolute;right:8px;top:50%;transform:translateY(-50%);min-height:36px;padding:0 12px}
.exploreArchiveClear[hidden]{display:none}
.list-card__searchHint{margin:8px 0 0;font-size:.88rem;line-height:1.45;color:var(--muted)}
.list-card__searchHint span{color:var(--fg)}
.searchMark{padding:.02em .28em;border-radius:999px;background:color-mix(in srgb, var(--accent) 24%, transparent);color:inherit}

.exploreArchiveMeta{margin:18px 0 14px;row-gap:8px}
.exploreArchiveGrid{min-height:220px}
.exploreArchiveSentinel{height:1px;margin-top:2px}

@media (max-width: 640px){
  .exploreArchivePanel{padding:18px}
  .exploreArchivePanel__head{align-items:flex-start}
  .exploreArchiveSearchField{max-width:none}
  .exploreArchiveSearchInput{padding-right:104px}
  .exploreArchiveClear{right:6px}
}

/* =========================================================
   v6.16.8 — mobile navigation + mobile ranking cards
   Desktop intentionally unchanged
   ========================================================= */
.hamburgerBtn{
  display:none;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  width:44px;
  height:44px;
  padding:0;
  border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 88%, transparent), color-mix(in srgb, var(--surface) 88%, transparent));
  color:var(--fg);
  box-shadow:var(--shadow2);
  cursor:pointer;
}
.hamburgerBtn span{
  display:block;
  width:18px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transition:transform .18s ease, opacity .18s ease;
}
.hamburgerBtn[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburgerBtn[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburgerBtn[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width: 880px){
  .site-header{
    z-index:120;
    overflow:visible;
  }

  .header-inner{
    position:relative;
    isolation:isolate;
    min-height:78px;
    padding:14px 0;
    align-items:center;
  }

  .hamburgerBtn{display:inline-flex}

  .nav{
    position:fixed;
    top:calc(env(safe-area-inset-top, 0px) + 88px);
    left:max(16px, env(safe-area-inset-left, 0px));
    right:max(16px, env(safe-area-inset-right, 0px));
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:14px;
    max-height:calc(100dvh - 104px);
    overflow:auto;
    border:1px solid color-mix(in srgb, var(--border2) 88%, var(--border));
    border-radius:22px;
    background:var(--bg-elev);
    box-shadow:0 20px 60px rgba(2, 6, 23, .42), var(--shadow);
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    z-index:130;
  }

  html[data-theme="dark"] .nav{
    background:linear-gradient(180deg, rgba(10, 18, 40, .985), rgba(10, 18, 40, .97));
  }

  html[data-theme="light"] .nav{
    background:linear-gradient(180deg, rgba(255, 255, 255, .992), rgba(248, 250, 252, .985));
  }

  .nav[data-open="true"]{display:flex}

  .nav .toggle,
  .nav .btn{
    width:100%;
    justify-content:center;
  }

  .nav .toggle{
    padding:10px 12px;
  }

  html.mobileNavOpen,
  html.mobileNavOpen body{
    overflow:hidden;
  }

  html.mobileNavOpen body::before{
    content:"";
    position:fixed;
    inset:0;
    background:rgba(2,6,23,.46);
    z-index:119;
    pointer-events:none;
  }
}

@media (min-width: 881px){
  .nav{
    display:flex !important;
    position:static;
    padding:0;
    border:0;
    background:none;
    box-shadow:none;
    backdrop-filter:none;
  }
}

@media (max-width: 640px){
  .table.rank{
    display:block;
    overflow:visible;
    border-spacing:0;
  }

  .table.rank thead{
    display:none;
  }

  .table.rank tbody{
    display:grid;
    gap:14px;
  }

  .table.rank tbody tr{
    display:grid;
    grid-template-columns:auto minmax(0, 1fr) auto;
    grid-template-areas:
      "index personaggio score"
      "actions actions actions";
    align-items:start;
    column-gap:12px;
    row-gap:14px;
    padding:16px;
    border:1px solid color-mix(in srgb, var(--border2) 82%, var(--border));
    border-radius:24px;
    background:linear-gradient(180deg, color-mix(in srgb, var(--surface2) 88%, transparent), color-mix(in srgb, var(--surface) 94%, transparent));
    box-shadow:var(--shadow2), inset 0 1px 0 color-mix(in srgb, #fff 7%, transparent);
    min-width:0;
    height:auto;
  }

  .table.rank td{
    display:block;
    min-width:0;
    height:auto !important;
    padding:0 !important;
    background:transparent;
    border:0 !important;
    box-shadow:none;
  }

  .table.rank .rankIndexCell{grid-area:index; align-self:flex-start; padding-top:2px !important}
  .table.rank .personaggioCell{grid-area:personaggio; min-width:0}
  .table.rank .rankScoreCell{grid-area:score; align-self:start; justify-self:end; min-width:88px}
  .table.rank .rankActionsCell{grid-area:actions; margin-top:2px}

  .table.rank .rankIndexBadge{
    width:38px;
    height:38px;
    border-radius:12px;
    font-size:.98rem;
  }

  .table.rank .personaggioCell__stack{
    min-height:0;
    height:auto;
    overflow:visible;
    gap:9px;
    padding-right:8px;
  }

  .table.rank .rankRowTitle{
    font-size:1.05rem;
    line-height:1.08;
    overflow-wrap:anywhere;
  }

  .table.rank .rankMotivation,
  .table.rank .rankSignature,
  .table.rank .attachmentCard__meta,
  .table.rank .list-card .meta{
    overflow-wrap:anywhere;
    word-break:break-word;
  }

  .table.rank .rankMotivation{
    display:block;
    -webkit-line-clamp:unset;
    overflow:visible;
    font-size:.94rem;
    line-height:1.42;
    max-width:none;
  }

  .table.rank .rankSignature{
    font-size:.92rem;
    line-height:1.35;
  }

  .table.rank .rankScoreCell{
    align-self:start;
    justify-self:end;
  }

  .table.rank .scoreBox{
    width:auto;
    height:auto;
    min-width:0;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    justify-content:flex-start;
    gap:8px;
    padding:0;
  }

  .table.rank .scoreLabel{
    font-size:.72rem;
    letter-spacing:.12em;
    text-align:right;
  }

  .table.rank .count--hero{
    min-width:72px;
    padding:8px 12px;
    font-size:1rem;
    justify-content:center;
  }

  .table.rank .rankActions,
  .table.rank .inline-actions{
    width:100%;
    height:auto;
    align-items:stretch;
    justify-content:stretch;
  }

  .table.rank .inline-actions{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
  }

  .table.rank .inline-actions .btn{
    width:100%;
    min-height:42px;
    justify-content:center;
    white-space:normal;
    text-align:center;
  }

  .table.rank .evidenceBlock{
    margin-top:0;
  }

  .table.rank .evidenceBlock__head{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:8px;
    row-gap:6px;
    flex-wrap:wrap;
  }

  .table.rank .evidencePill{
    min-height:34px;
    padding:0 10px;
    border-radius:999px;
  }

  .table.rank .evidencePill__long{display:none}
  .table.rank .evidencePill__short{display:inline}

  .table.rank .evidenceMeta{
    font-size:.82rem;
    padding:0 10px;
    min-height:34px;
  }
}


/* Hotfix mobile rank score + remove bottom sticky share/suggest */
@media (max-width: 640px){
  .table.rank .scoreBox{
    min-width:auto;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
  }

  .table.rank .scoreLabel{
    text-align:right;
  }

  .table.rank .count,
  .table.rank .count--hero{
    border:1px solid color-mix(in srgb, var(--accent) 22%, var(--border));
    border-radius:999px;
    background:color-mix(in srgb, var(--accent) 8%, var(--surface));
    box-shadow:none;
    padding:8px 12px;
    min-width:64px;
  }
}

@media (max-width: 880px){
  .stickyBar{
    display:none !important;
  }

  body{
    padding-bottom:0;
  }
}


.headerLogoutForm{display:inline-flex;margin:0}
