/* tmirror — visore album. Mobile-first, responsive. */
:root {
    --bg: #14161a;
    --panel: #1e2229;
    --panel2: #262b34;
    --line: #333a45;
    --txt: #e8eaed;
    --muted: #9aa4b2;
    --accent: #4f8cff;
    --danger: #e5484d;
    --radius: 10px;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
    background: var(--bg);
    color: var(--txt);
    font: 16px/1.4 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    -webkit-text-size-adjust: 100%;
}
img { max-width: 100%; display: block; }
a { color: var(--accent); text-decoration: none; }

/* ---------- topbar ---------- */
.topbar {
    position: sticky; top: 0; z-index: 20;
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px;
    background: var(--panel);
    border-bottom: 1px solid var(--line);
}
.topbar h1 { font-size: 1.05rem; margin: 0; font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.topbar .spacer, .topbar .counter, .topbar .admin-link { margin-left: auto; }
.topbar .admin-link { color: #33456b; font-size: .78rem; text-decoration: none; letter-spacing: .3px; }
.topbar .admin-link:hover { color: var(--accent); }

/* "Tmirror" grande e centrato nell'header di ogni pagina */
.list-topbar .topbar-logo { height: 30px; width: 30px; margin-right: 0; }
.topbar .brand-center { position: absolute; left: 50%; transform: translateX(-50%); margin: 0; font-size: 1.5rem; font-weight: 800; letter-spacing: .5px; white-space: nowrap; color: var(--txt); text-decoration: none; }
.topbar .brand-center:hover { color: var(--accent); }
/* etichetta di pagina, piccola, a sinistra (non compete col brand centrato) */
.tb-label { font-size: .95rem; font-weight: 600; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 40%; }
.topbar .counter { color: var(--muted); font-size: .9rem; }

/* ---------- buttons ---------- */
.btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: 6px; padding: 9px 14px; border: 1px solid var(--line);
    background: var(--panel2); color: var(--txt); border-radius: var(--radius);
    cursor: pointer; font-size: .95rem; line-height: 1;
    -webkit-tap-highlight-color: transparent;
}
.btn:hover { border-color: var(--accent); }
.btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn.danger { background: transparent; border-color: var(--danger); color: var(--danger); }
.btn.danger:hover { background: var(--danger); color: #fff; }
.btn.ghost { background: transparent; }
.btn.block { width: 100%; }
.btn.sm { padding: 6px 10px; font-size: .82rem; }

/* ---------- login ---------- */
.page-login { display: flex; min-height: 100vh; align-items: center; justify-content: center; padding: 20px; }
.login-box {
    background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
    padding: 28px; width: 100%; max-width: 360px; text-align: center;
}
.login-box .brand { display: flex; flex-direction: column; align-items: center; gap: 8px; margin-bottom: 12px; font-size: 1.5rem; font-weight: 800; letter-spacing: .5px; color: var(--accent); }
.brand-mark { width: 52px; height: 52px; }
.topbar-logo { height: 26px; width: 26px; vertical-align: -6px; margin-right: 8px; }
.login-box h1 { margin: 0 0 14px; font-size: 1.1rem; font-weight: 600; color: var(--muted); }
.sub-brand { font-weight: 400; color: var(--muted); font-size: .9rem; }
.login-box input[type=password] {
    width: 100%; padding: 12px; margin-bottom: 12px; border-radius: var(--radius);
    border: 1px solid var(--line); background: var(--bg); color: var(--txt); font-size: 1rem;
}
.login-box .btn { width: 100%; }
.hint { color: var(--muted); font-size: .9rem; }
.error { color: var(--danger); font-size: .9rem; }

/* ---------- lista album ---------- */
.search-bar { display: flex; gap: 8px; padding: 14px 16px 0; align-items: center; }
.search-bar input[type=search] { flex: 1; max-width: 520px; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font-size: .95rem; }
.search-bar input[type=search]:focus { outline: none; border-color: var(--accent); }

/* finestra ricerca foto */
.modal { position: fixed; inset: 0; z-index: 80; background: rgba(0,0,0,.6); display: flex; align-items: flex-start; justify-content: center; padding: 40px 16px; overflow-y: auto; }
.modal.hidden { display: none; }
.modal-box { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 22px; width: 100%; max-width: 640px; position: relative; }
.modal-x { position: absolute; top: 10px; right: 14px; background: none; border: none; color: var(--muted); font-size: 1.6rem; cursor: pointer; line-height: 1; }
.modal-box h2 { margin: 0 0 14px; font-size: 1.2rem; }
.ps-form { display: flex; gap: 8px; margin-bottom: 14px; }
.ps-input { flex: 1; padding: 10px 12px; border-radius: 10px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font-size: .95rem; }
.ps-results { display: flex; flex-direction: column; gap: 8px; }
.ps-item { display: flex; gap: 12px; align-items: center; padding: 8px; border: 1px solid var(--line); border-radius: 8px; text-decoration: none; color: var(--txt); }
.ps-item:hover { border-color: var(--accent); }
.ps-item img { width: 56px; height: 56px; object-fit: cover; border-radius: 6px; flex: 0 0 auto; }
.ps-meta { display: flex; flex-direction: column; min-width: 0; }
.ps-meta b { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ps-desc { color: var(--muted); font-size: .85rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ps-album { color: var(--muted); font-size: .78rem; }
.group-chips { display: flex; flex-wrap: wrap; gap: 8px; padding: 14px 16px 0; }
.group-chips .chip { padding: 6px 14px; border-radius: 20px; border: 1px solid var(--line); background: var(--panel2); color: var(--muted); font-size: .85rem; text-decoration: none; }
.group-chips .chip:hover { border-color: var(--accent); }
.group-chips .chip.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.group-h { margin: 18px 16px 0; font-size: 1.05rem; color: var(--txt); border-bottom: 1px solid var(--line); padding-bottom: 6px; }
.grid-albums {
    display: grid; gap: 14px; padding: 16px;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}
.album-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.album-card .cover { position: relative; aspect-ratio: 4/3; background: var(--panel2); display: flex; align-items: center; justify-content: center; }
.album-card .cover img { width: 100%; height: 100%; object-fit: cover; }
.album-card .cover .nocover { color: var(--muted); font-size: .85rem; }
.album-card .cover .lock { position: absolute; top: 6px; right: 8px; }
.album-card .meta { padding: 8px 10px; }
.album-card .title { display: block; font-weight: 600; font-size: .95rem; }
.album-card .desc { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; color: var(--muted); font-size: .82rem; margin: 2px 0; }
.album-card .sub { color: var(--muted); font-size: .8rem; }

/* descrizione album nel visore */
.album-desc { max-width: 900px; margin: 12px auto 0; padding: 0 16px; color: var(--muted); text-align: center; line-height: 1.5; }

/* paginazione lista */
.pager { display: flex; align-items: center; justify-content: center; gap: 16px; padding: 20px; }
.pager-info { color: var(--muted); font-size: .9rem; }

/* pulsante copertina (admin) */
.setcover.iscover { border-color: #e6b800; color: #e6b800; }

/* banner di avviso admin */
.warn-banner { background: #4a2b00; border: 1px solid #e6a100; color: #ffd68a; padding: 10px 16px; text-align: center; font-size: .9rem; }
.empty { color: var(--muted); padding: 24px; text-align: center; }

/* ---------- viewer: fumetto ---------- */
.page-viewer main#stage { min-height: calc(100vh - 52px); }
.mode-fumetto #stage {
    display: flex; align-items: center; justify-content: center;
    padding: 8px; gap: 4px;
}
.mode-fumetto .frame { margin: 0; max-width: 100%; text-align: center; }
.mode-fumetto .frame img { max-height: calc(100vh - 90px); width: auto; margin: 0 auto; border-radius: 6px; cursor: pointer; }
.mode-fumetto .frame video { max-height: calc(100vh - 90px); max-width: 100%; width: auto; margin: 0 auto; border-radius: 6px; background: #000; }
.frame-marker { text-align: center; font-weight: 800; letter-spacing: 1.5px; color: var(--accent); padding: 4px 0 8px; font-size: 1rem; text-transform: uppercase; }
.frame-marker.end { color: #ff8a8a; font-size: 1.5rem; letter-spacing: 4px; }
.frame figcaption, .lb-frame figcaption {
    margin: 10px auto 0; max-width: 900px; padding: 12px 16px;
    background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
    text-align: center;
}
.cap-title {
    display: block; font-size: 1.15rem; font-weight: 700; color: var(--txt);
    letter-spacing: .2px; line-height: 1.3;
}
.cap-desc {
    display: block; margin-top: 5px; font-size: .95rem; color: var(--muted); line-height: 1.5;
}
.lb-frame figcaption { background: rgba(20,22,26,.85); backdrop-filter: blur(3px); }
.nav {
    flex: 0 0 auto; background: rgba(0,0,0,.35); color: #fff; border: none;
    font-size: 1.6rem; width: 46px; height: 64px; border-radius: 8px; cursor: pointer;
}
.nav:hover { background: rgba(0,0,0,.6); }

/* ---------- viewer: galleria ---------- */
.grid-gallery {
    display: grid; gap: 6px; padding: 10px;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
}
.gcell { padding: 0; border: none; background: var(--panel2); border-radius: 6px; overflow: hidden; cursor: pointer; aspect-ratio: 1; position: relative; }
.gcell img { width: 100%; height: 100%; object-fit: cover; }
/* badge sovraimpresso (▶ video · 🎞 animazione gif/webp) */
.media-badge { position: absolute; pointer-events: none; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
    background: rgba(0,0,0,.62); color: #fff; border-radius: 50%; font-size: .8rem; }
.media-badge.vid { bottom: 6px; right: 6px; padding-left: 2px; }
.media-badge.anim { bottom: 6px; left: 6px; font-size: .9rem; }

.lightbox {
    position: fixed; inset: 0; z-index: 50; background: rgba(0,0,0,.92);
    display: flex; align-items: center; justify-content: center; gap: 6px; padding: 8px;
}
.lightbox.hidden { display: none; }
.lightbox .lb-frame { margin: 0; max-width: 100%; text-align: center; }
.lightbox .lb-frame img { max-height: calc(100vh - 80px); max-width: calc(100vw - 120px); width: auto; cursor: pointer; }
.lightbox .lb-frame video { max-height: calc(100vh - 80px); max-width: calc(100vw - 120px); width: auto; background: #000; border-radius: 4px; }
.lb-close { position: absolute; top: 10px; right: 14px; background: none; border: none; color: #fff; font-size: 2rem; cursor: pointer; z-index: 2; }

/* ---------- admin ---------- */
.admin-layout { display: flex; min-height: calc(100vh - 53px); }
.sidebar { width: 260px; flex: 0 0 260px; border-right: 1px solid var(--line); padding: 12px; overflow: auto; }
.album-list { list-style: none; margin: 12px 0 0; padding: 0; }
.album-group { margin-bottom: 4px; }
.album-group-head { display: flex; align-items: center; gap: 8px; padding: 8px 10px; cursor: pointer; border-radius: 8px; font-weight: 600; user-select: none; }
.album-group-head:hover { background: var(--panel2); }
.agh-caret { font-size: .75rem; color: var(--muted); transition: transform .15s; }
.album-group.collapsed .agh-caret { transform: rotate(-90deg); }
.agh-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.agh-count { color: var(--muted); font-size: .78rem; background: var(--panel2); border: 1px solid var(--line); border-radius: 10px; padding: 0 7px; }
.album-group-items { padding-left: 10px; }
.album-group.collapsed .album-group-items { display: none; }
.album-li { display: flex; justify-content: space-between; align-items: center; gap: 8px; padding: 10px; border-radius: 8px; cursor: pointer; }
.album-li:hover { background: var(--panel2); }
.album-li.active { background: var(--panel2); outline: 1px solid var(--accent); }
.album-li.disabled .ttl { color: var(--muted); text-decoration: line-through; }
.album-li .agrip { color: var(--muted); cursor: grab; font-size: .9rem; flex: 0 0 auto; }
.album-li .ttl { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.album-li .grp-tag { display: inline-block; margin-left: 6px; padding: 1px 7px; border-radius: 10px; background: var(--panel2); border: 1px solid var(--line); color: var(--muted); font-size: .68rem; vertical-align: middle; }
.album-li .badges { color: var(--muted); font-size: .85rem; white-space: nowrap; flex: 0 0 auto; }
.album-li.dragging { opacity: .45; outline: 2px dashed var(--accent); }
.editor { flex: 1; padding: 18px; overflow: auto; }
.editor h2 { margin-top: 0; }
.ed-head { display: flex; align-items: flex-start; gap: 12px; }
.ed-head .ed-actions { margin-left: auto; }
.ed-comtot { display: inline-block; margin-left: 12px; padding: 2px 10px; border-radius: 12px; background: var(--panel2); border: 1px solid var(--line); color: var(--muted); font-size: .8rem; font-weight: 400; vertical-align: middle; }
.form { display: grid; gap: 12px; margin: 12px 0; max-width: 720px; }
.form.grid2 { grid-template-columns: 1fr 1fr; }
.form label { display: flex; flex-direction: column; gap: 5px; font-size: .85rem; color: var(--muted); }
.form label.chk { flex-direction: row; align-items: center; gap: 8px; color: var(--txt); }
.form input[type=text], .form input[type=number], .form input[type=password], .form select, .form textarea {
    padding: 9px; border-radius: 8px; border: 1px solid var(--line);
    background: var(--bg); color: var(--txt); font-size: .95rem;
}
.form textarea { min-height: 60px; resize: vertical; font-family: inherit; }
.form label.full { grid-column: 1 / -1; }
.form input:disabled { opacity: .5; cursor: not-allowed; }
.share { margin: 18px 0; max-width: 720px; }
.share label { color: var(--muted); font-size: .85rem; }
.share-row { display: flex; gap: 8px; margin: 6px 0; }
.share-row input { flex: 1; padding: 9px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); }
.share small { color: var(--muted); }
.up { margin-top: 18px; display: flex; flex-wrap: wrap; align-items: center; gap: 12px; }
.up h3 { margin: 0; width: 100%; }
.file-btn { position: relative; }
.prog { color: var(--accent); }
.hidden { display: none; }

.thumbs { display: grid; gap: 12px; margin-top: 14px; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); }
.tcard { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 8px; position: relative; }
.tcard.dragging { opacity: .4; outline: 2px dashed var(--accent); }
.tcard .grip { position: absolute; top: 6px; left: 8px; color: #fff; text-shadow: 0 1px 2px #000; cursor: grab; }
.tcard.has-comments { border-color: var(--accent); }
.tcard .tcom-badge { position: absolute; top: 6px; right: 8px; z-index: 1; background: var(--accent); color: #fff; font-size: .72rem; font-weight: 600; padding: 2px 7px; border-radius: 10px; box-shadow: 0 1px 3px rgba(0,0,0,.4); }
.tcard img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 6px; }
.tcard img.tclick { cursor: zoom-in; }
.tcard .media-badge { top: 6px; left: 34px; right: auto; bottom: auto; }
.imgmodal { align-items: center; justify-content: center; padding: 24px; }
.imgmodal-img { max-width: 96vw; max-height: 92vh; border-radius: 8px; display: block; }
.imgmodal .modal-x { color: #fff; z-index: 1; text-shadow: 0 1px 3px #000; }
.tcard .tfile { font-size: .72rem; color: var(--muted); margin: 5px 0 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: monospace; }
.tcard .ititle { width: 100%; margin: 8px 0 6px; border-radius: 6px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); padding: 7px; font: inherit; font-size: .88rem; font-weight: 600; }
.tcard .desc { width: 100%; margin: 0 0 8px; min-height: 44px; resize: vertical; border-radius: 6px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); padding: 6px; font: inherit; font-size: .85rem; }

/* ---------- log ---------- */
.log-wrap { padding: 16px; }
.log-filters {
    display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end;
    background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px;
}
.log-filters label { display: flex; flex-direction: column; gap: 4px; font-size: .78rem; color: var(--muted); }
.log-filters input, .log-filters select {
    padding: 8px; border-radius: 8px; border: 1px solid var(--line);
    background: var(--bg); color: var(--txt); font-size: .9rem;
}
.log-btns { display: flex; gap: 8px; }
.log-summary { display: flex; flex-wrap: wrap; gap: 18px; margin: 16px 2px; color: var(--muted); }
.log-summary strong { color: var(--txt); font-size: 1.05rem; }
.table-scroll { overflow-x: auto; border: 1px solid var(--line); border-radius: 10px; }
.log-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.log-table th, .log-table td { padding: 9px 12px; text-align: left; border-bottom: 1px solid var(--line); }
.log-table th { background: var(--panel2); color: var(--muted); font-weight: 600; position: sticky; top: 0; }
.log-table tr:hover td { background: var(--panel); }
.log-table .muted { color: var(--muted); }
.log-table .nowrap { white-space: nowrap; }
.tag { display: inline-block; padding: 2px 8px; border-radius: 20px; font-size: .74rem; }
.tag-open { background: rgba(79,140,255,.18); color: #9cc0ff; }
.tag-view { background: rgba(120,200,120,.16); color: #a7e0a7; }

/* ---------- social (viewer) ---------- */
.social { max-width: 900px; margin: 12px auto 0; padding: 12px 14px; background: var(--panel); border: 1px solid var(--line); border-radius: 10px; text-align: left; }
.soc-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; margin-bottom: 10px; }
.likebtn { background: var(--panel2); border: 1px solid var(--line); color: var(--muted); padding: 7px 13px; border-radius: 20px; cursor: pointer; font-size: .95rem; }
.likebtn.liked { color: #ff6b81; border-color: #ff6b81; }
.msgbtn { background: transparent; border: 1px solid var(--line); color: var(--muted); padding: 7px 13px; border-radius: 20px; cursor: pointer; font-size: .9rem; }
.msgbtn-sub { color: #8bd48b; font-size: .8rem; }

/* barra reazioni emoji */
.reactbar { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.reactbtn { display: inline-flex; align-items: center; gap: 4px; background: var(--panel2); border: 1px solid var(--line);
    border-radius: 18px; padding: 4px 9px; font-size: 1.1rem; line-height: 1; cursor: pointer; -webkit-tap-highlight-color: transparent; }
.reactbtn:hover { border-color: var(--accent); transform: scale(1.08); }
.reactbtn.active { background: rgba(79,140,255,.18); border-color: var(--accent); }
.reactbtn .rc { font-size: .8rem; color: var(--muted); font-weight: 600; }
.reactbtn.active .rc { color: var(--accent); }

/* schede pubblico / privato */
.tabbtn { background: var(--panel2); border: 1px solid var(--line); color: var(--muted); padding: 7px 13px; border-radius: 20px; cursor: pointer; font-size: .9rem; }
.tabbtn:hover { border-color: var(--accent); }
.tab-public.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.tab-private.active { background: #223052; border-color: #6f97ff; color: #cfe0ff; }
.cpanel[hidden] { display: none; }
.cpanel-hint { margin: 0 0 10px; font-size: .82rem; color: var(--muted); }
.cpanel-hint b { color: var(--txt); }

.msgform { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; padding: 12px; background: rgba(79, 140, 255, .10); border: 1px solid #6f97ff; border-radius: 8px; }
.msgform[hidden] { display: none; }   /* rispetta l'attributo hidden (default collassato) */
.msgintro { margin: 0 0 4px; font-size: .88rem; color: var(--muted); line-height: 1.5; }
.msgintro b { color: var(--txt); }
.msgform input, .msgform textarea, .cform input, .cform textarea { padding: 8px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font: inherit; font-size: .9rem; }
.msgform textarea { min-height: 70px; resize: vertical; }
.mrow { display: flex; align-items: center; gap: 10px; }
.mmsg { color: #8bd48b; font-size: .85rem; }
.comments { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.comment { background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; }
.comment .cmeta { display: block; font-size: .8rem; color: var(--muted); margin-bottom: 2px; }
.comment .cmeta b { color: var(--txt); }
.comment .ctxt { white-space: pre-wrap; word-break: break-word; }
.comment .cfoto-link { display: inline-block; margin-top: 8px; }
.comment .cfoto-img { max-width: 150px; max-height: 150px; border-radius: 8px; border: 1px solid var(--line); cursor: zoom-in; display: block; }
/* thread: risposte ai commenti */
.comment-thread { display: flex; flex-direction: column; gap: 6px; }
.comment-actions { display: flex; }
.reply-btn { background: none; border: none; color: var(--accent); font-size: .8rem; cursor: pointer; padding: 2px 4px; align-self: flex-start; }
.reply-btn:hover { text-decoration: underline; }
.comment-replies { display: flex; flex-direction: column; gap: 6px; margin-left: 18px; padding-left: 10px; border-left: 2px solid var(--line); }
.comment-replies:empty { display: none; }
.comment.reply { background: var(--panel2); }
.comment.deleted { opacity: .7; }
.comment .cdel { color: var(--muted); }
.tmodc.deleted span { color: var(--muted); font-style: italic; }
.reply-form { margin: 0 0 4px 18px; padding-left: 10px; border-left: 2px solid var(--accent); }
.tmodc.reply { margin-left: 16px; border-left: 2px solid var(--line); background: var(--panel2); }
.cform { display: flex; flex-direction: column; gap: 8px; }
.cform textarea { min-height: 56px; resize: vertical; }
.cform .btn, .msgform .btn { align-self: flex-start; }
.crow { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cfoto-btn { display: inline-flex; align-items: center; padding: 7px 12px; border: 1px solid var(--line); border-radius: 8px; background: var(--panel2); color: var(--muted); cursor: pointer; font-size: .88rem; }
.cfoto-btn:hover { border-color: var(--accent); }
.cfoto-name { color: var(--muted); font-size: .82rem; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.crow .btn { margin-left: auto; }
.tmodc-img { max-width: 60px; max-height: 60px; border-radius: 4px; border: 1px solid var(--line); }
.lb-frame .social { background: rgba(20, 22, 26, .92); }
/* quando c'è il pannello social il contenuto può superare lo schermo:
   scroll + allineamento "safe" (parte dall'alto invece di tagliare la cima) */
.mode-galleria .lightbox { align-items: safe center; overflow-y: auto; padding-top: 48px; padding-bottom: 24px; }

/* sezione "commenti all'album" a fine visore */
.album-social { max-width: 900px; margin: 24px auto 40px; padding: 0 12px; }
.as-invite { text-align: center; padding: 22px 16px; border-top: 1px solid var(--line); margin-bottom: 14px; }
.as-invite h2 { margin: 0 0 6px; font-size: 1.3rem; }
.as-invite p { margin: 0; color: var(--muted); }
.album-social .social { margin-top: 0; }

/* moderazione commenti album (admin) */
.albcom { margin: 18px 0; max-width: 720px; }
.albcom h3 { margin: 0 0 8px; }

/* ---------- moderazione commenti (admin) ---------- */
.tmodbtn { margin-top: 6px; }
.tmodlist { margin-top: 6px; display: flex; flex-direction: column; gap: 5px; }
.tmodlk { font-size: .82rem; color: #ff6b81; }
.tmodc { display: flex; gap: 6px; align-items: flex-start; justify-content: space-between; font-size: .82rem; background: var(--bg); border: 1px solid var(--line); border-radius: 6px; padding: 5px 7px; }
.tmodc.muted { color: var(--muted); }
.tmodc span { flex: 1; word-break: break-word; }

/* ---------- badge topbar ---------- */
.badge { display: inline-block; min-width: 18px; padding: 0 6px; border-radius: 10px; background: var(--danger); color: #fff; font-size: .75rem; line-height: 18px; text-align: center; }

/* ---------- messaggi (admin) ---------- */
.msg-wrap { padding: 16px; max-width: 820px; margin: 0 auto; }
.inbox-tabs { display: flex; gap: 8px; justify-content: center; padding: 12px 16px 0; }
.inbox-tabs .chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; border: 1px solid var(--line); background: var(--panel2); color: var(--txt); text-decoration: none; font-size: .9rem; }
.inbox-tabs .chip:hover { border-color: var(--accent); }
.inbox-h { margin: 22px 0 10px; font-size: 1.1rem; border-bottom: 1px solid var(--line); padding-bottom: 6px; scroll-margin-top: 70px; }
.msg-tools { margin-bottom: 12px; }
.msg-list { display: flex; flex-direction: column; gap: 12px; }
.msg-card { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px; }
.msg-card.unread { border-color: var(--accent); }
.msg-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 6px; }
.msg-from .dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); margin-left: 6px; }
.msg-body { margin: 6px 0 10px; line-height: 1.5; word-break: break-word; }
.msg-meta { font-size: .82rem; }
.msg-actions { display: flex; gap: 8px; margin-top: 10px; }
.msg-actions form { margin: 0; }

/* ---------- dashboard ---------- */
.dash-wrap { padding: 18px; max-width: 1100px; margin: 0 auto; }
.stat-grid { display: grid; gap: 12px; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
.stat-card { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 16px; display: flex; flex-direction: column; gap: 3px; }
.stat-card.hot { border-color: var(--accent); }
.stat-num { font-size: 2rem; font-weight: 800; line-height: 1.1; }
.stat-lbl { color: var(--muted); font-size: .85rem; }
.stat-sub { color: var(--muted); font-size: .78rem; margin-top: 4px; }
.dash-h2 { margin: 26px 0 12px; font-size: 1.15rem; }

/* ---------- rotolo (scroll verticale) ---------- */
.rotolo { max-width: 900px; margin: 0 auto; padding: 16px; }
.rotolo-item { margin-bottom: 34px; }
.rotolo-item img { width: 100%; height: auto; border-radius: 8px; display: block; }
.rotolo-item video { width: 100%; height: auto; border-radius: 8px; display: block; background: #000; }
.rotolo-cap { display: block; margin-top: 10px; text-align: center; }
.rotolo-com { margin-top: 10px; }
.rotolo-social { margin-top: 10px; }

/* ---------- pannello descrizione laterale ---------- */
.descpanel {
    position: fixed; top: 52px; bottom: 0; width: 320px; z-index: 60;
    background: var(--panel); padding: 22px 20px; overflow-y: auto;
    transition: transform .25s ease;
}
.descpanel-close { position: absolute; top: 8px; right: 10px; background: none; border: none; color: var(--muted); font-size: 1.5rem; cursor: pointer; line-height: 1; }
.descpanel-body { margin-top: 8px; }
.descpanel-body .cap-title { display: block; font-size: 1.25rem; font-weight: 700; margin-bottom: 10px; line-height: 1.3; }
.descpanel-body .cap-desc { display: block; color: var(--muted); line-height: 1.7; white-space: pre-wrap; }
.desc-toggle { margin-left: 8px; display: none; }
body.desc-active .desc-toggle { display: inline-flex; }
body.desc-active .topbar { z-index: 55; }   /* toggle raggiungibile sopra il lightbox */

.desc-destra .descpanel { right: 0; border-left: 1px solid var(--line); transform: translateX(100%); }
.desc-active.desc-destra.desc-open .descpanel { transform: none; }
.desc-sinistra .descpanel { left: 0; border-right: 1px solid var(--line); transform: translateX(-100%); }
.desc-active.desc-sinistra.desc-open .descpanel { transform: none; }

@media (min-width: 761px) {
    .desc-active.desc-destra.desc-open #stage { padding-right: 320px; }
    .desc-active.desc-sinistra.desc-open #stage { padding-left: 320px; }
    .desc-active.desc-destra.desc-open .lightbox { padding-right: 320px; }
    .desc-active.desc-sinistra.desc-open .lightbox { padding-left: 320px; }
    .desc-active.desc-destra.desc-open .lb-close { right: 334px; } /* × non coperta dal pannello */
}
@media (max-width: 760px) {
    .descpanel { top: auto; left: 0; right: 0; width: auto; max-height: 55vh; border: none; border-top: 1px solid var(--line); transform: translateY(100%); box-shadow: 0 -8px 24px rgba(0,0,0,.4); }
    .desc-open .descpanel { transform: none; }
}

/* ---------- libro (lettore) ---------- */
.book { max-width: 820px; margin: 0 auto; padding: 16px; }
.book-head { display: flex; gap: 18px; align-items: center; margin-bottom: 18px; }
.book-cover { width: 130px; height: auto; border-radius: 8px; border: 1px solid var(--line); }
.book-title { margin: 0; font-size: 1.6rem; }
.book-toc { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px 18px; margin-bottom: 18px; }
.book-toc h2 { margin: 0 0 8px; font-size: 1.05rem; }
.book-toc ol { margin: 0; padding-left: 22px; }
.book-toc li { margin: 4px 0; }
.book-toc a { color: var(--accent); text-decoration: none; }
.book-toc a:hover { text-decoration: underline; }
.book-reader { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 20px 24px; }
.book-reader[hidden] { display: none; }
.reader-nav { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.reader-nav.bottom { margin-top: 22px; border-top: 1px solid var(--line); padding-top: 14px; }
.reader-pos { color: var(--muted); font-size: .85rem; }
.chap-title { margin: 12px 0 16px; font-size: 1.5rem; }
.chap-body { line-height: 1.7; font-size: 1.02rem; }
.chap-body h1, .chap-body h2, .chap-body h3 { line-height: 1.3; margin: 1.2em 0 .5em; }
.chap-body p { margin: 0 0 1em; }
.chap-body img { max-width: 100%; border-radius: 8px; margin: 8px 0; }
.chap-body a { color: var(--accent); }
.chap-body ul, .chap-body ol { padding-left: 26px; margin: 0 0 1em; }
.chap-body blockquote { margin: 0 0 1em; padding: 6px 14px; border-left: 3px solid var(--accent); color: var(--muted); }
.chap-body code { background: var(--bg); border: 1px solid var(--line); border-radius: 4px; padding: 1px 5px; font-size: .9em; }
.chap-body pre { background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 12px; overflow-x: auto; }
.chap-body pre code { border: none; padding: 0; }
.chap-body hr { border: none; border-top: 1px solid var(--line); margin: 1.5em 0; }

/* ---------- editor capitoli (admin) ---------- */
.chapters { margin: 20px 0; max-width: 760px; }
.ch-list { display: flex; flex-direction: column; gap: 6px; margin: 10px 0; }
.ch-row { display: flex; align-items: center; gap: 8px; background: var(--panel); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; }
.ch-row.dragging { opacity: .45; outline: 2px dashed var(--accent); }
.ch-row .agrip { cursor: grab; color: var(--muted); }
.ch-row .ch-ttl { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ch-editor { margin-top: 12px; background: var(--panel); border: 1px solid var(--accent); border-radius: 10px; padding: 14px; }
.ch-editor[hidden] { display: none; }
.ce-lbl { display: flex; flex-direction: column; gap: 5px; font-size: .82rem; color: var(--muted); margin-bottom: 10px; }
.ce-lbl input { padding: 8px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font-size: .95rem; }
.ce-toolbar { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; align-items: center; }
.mdbtn { padding: 6px 10px; border: 1px solid var(--line); background: var(--panel2); color: var(--txt); border-radius: 6px; cursor: pointer; font-size: .85rem; line-height: 1; }
.mdbtn:hover { border-color: var(--accent); }
select.mdbtn { padding: 6px 8px; }
#cePrevToggle { margin-left: auto; }
.ce-split { display: flex; gap: 12px; align-items: stretch; }
.ce-split .ce-txt, .ce-split .ce-prev { flex: 1 1 0; min-width: 0; min-height: 340px; }
.ce-split.no-prev .ce-prev { display: none; }
.ce-txt { width: 100%; resize: vertical; padding: 12px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font-family: ui-monospace, Menlo, Consolas, monospace; font-size: .92rem; line-height: 1.5; }
.ce-prev { overflow: auto; background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 14px; }
.ce-prev:empty::before { content: "L'anteprima appare qui…"; color: var(--muted); }
.ce-actions { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
@media (max-width: 760px) { .ce-split { flex-direction: column; } .ce-split .ce-txt, .ce-split .ce-prev { min-height: 200px; } }

/* ---------- test / sondaggio (visore) ---------- */
.quiz { max-width: 780px; margin: 0 auto; padding: 16px; width: 100%; }
.quiz-start { text-align: center; padding: 30px 10px; }
.quiz-start h2 { font-size: 1.6rem; margin-bottom: 10px; }
.quiz-start-hint { color: var(--muted); margin-bottom: 16px; max-width: 460px; margin-left: auto; margin-right: auto; line-height: 1.5; }
.quiz-name { width: 100%; max-width: 360px; padding: 12px; border-radius: 10px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font-size: 1rem; }
.quiz-start-actions { margin-top: 16px; }
.quiz-progress { height: 6px; background: var(--panel2); border-radius: 4px; overflow: hidden; margin-bottom: 18px; }
.quiz-bar { height: 100%; width: 0; background: var(--accent); transition: width .2s; }
.quiz-img { max-width: 100%; max-height: 50vh; border-radius: 10px; display: block; margin: 0 auto 16px; }
.quiz-q { font-size: 1.2rem; line-height: 1.5; margin-bottom: 18px; }
.quiz-answers { display: flex; flex-direction: column; gap: 10px; }
.quiz-opt { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 10px; cursor: pointer; background: var(--panel); }
.quiz-opt:hover { border-color: var(--accent); }
.quiz-opt input { width: 18px; height: 18px; flex: 0 0 auto; }
.quiz-txt { width: 100%; min-height: 120px; padding: 12px; border-radius: 10px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font: inherit; resize: vertical; }
.quiz-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 22px; }
.quiz-result { text-align: center; padding: 10px; }
.quiz-result h2 { font-size: 1.6rem; margin: 10px 0; }
.quiz-score { color: var(--accent); font-size: 1.1rem; }
.quiz-restext { text-align: left; max-width: 640px; margin: 12px auto; line-height: 1.7; }

/* ---------- builder test (admin) ---------- */
.quizb { margin: 20px 0; max-width: 820px; }
.qb-q { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 12px; margin-bottom: 12px; }
.qb-q-head { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; flex-wrap: wrap; }
.qb-q-head b { margin-right: auto; }
.qb-q-move { display: flex; gap: 4px; }
.qb-q-testo, .qb-res-txt, .qb-fine-txt { width: 100%; min-height: 60px; margin: 6px 0; padding: 8px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); font: inherit; resize: vertical; }
.qb-lbl { display: block; font-size: .82rem; color: var(--muted); margin: 6px 0; }
.qb-lbl select, .qb-tipo, .qb-res-img, .qb-fine-img { padding: 6px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); }
.qb-answers { border-top: 1px solid var(--line); margin-top: 8px; padding-top: 8px; }
.qb-ans { display: flex; gap: 8px; align-items: center; margin-bottom: 6px; }
.qb-ans-t { flex: 1; padding: 7px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); }
.qb-ans-p { width: 72px; padding: 7px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); }
.qb-h { margin: 22px 0 10px; }
.qb-res { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 10px; margin-bottom: 10px; }
.qb-res-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.qb-res-min, .qb-res-max { width: 72px; padding: 7px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); }
.qb-res-tit { flex: 1; min-width: 120px; padding: 7px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); }
.qb-fine { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 10px; }
.qb-fine-tit { width: 100%; padding: 7px; border-radius: 8px; border: 1px solid var(--line); background: var(--bg); color: var(--txt); margin-bottom: 6px; }
.qb-actions { display: flex; align-items: center; gap: 10px; margin-top: 14px; }

/* ---------- statistiche test (admin) ---------- */
.qstat-block { display: flex; flex-direction: column; gap: 8px; margin: 8px 0 18px; }
.qstat-row { display: flex; align-items: center; gap: 10px; }
.qstat-lbl { flex: 0 0 34%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: .9rem; }
.qstat-bar { flex: 1; height: 16px; background: var(--panel2); border-radius: 8px; overflow: hidden; }
.qstat-bar span { display: block; height: 100%; background: var(--accent); }
.qstat-val { flex: 0 0 auto; color: var(--muted); font-size: .82rem; white-space: nowrap; }
.qstat-q { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 14px; margin-bottom: 12px; }
.qstat-qh { margin-bottom: 10px; }
.qstat-texts { display: flex; flex-direction: column; gap: 6px; }
.qstat-txt { background: var(--bg); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; font-size: .9rem; word-break: break-word; }

/* ---------- mobile ---------- */
@media (max-width: 760px) {
    .form.grid2 { grid-template-columns: 1fr; }
    .admin-layout { flex-direction: column; }
    .sidebar { width: 100%; flex: none; border-right: none; border-bottom: 1px solid var(--line); max-height: 40vh; }
    .nav { width: 40px; height: 56px; font-size: 1.3rem; }
    .lightbox .lb-frame img, .lightbox .lb-frame video { max-width: calc(100vw - 96px); }
    .grid-gallery { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
    .log-filters label { flex: 1 1 45%; }
    .log-filters input, .log-filters select { width: 100%; }
    .log-table { font-size: .8rem; }
    .log-table th, .log-table td { padding: 7px 8px; }
}
@media (hover: none) {
    /* su touch le frecce restano ma lo swipe è il gesto primario */
    .topbar h1 { font-size: 1rem; }
}

/* ---- condivisioni: banner lista pubblica ---- */
.share-banner { max-width: 1100px; margin: 10px auto 0; padding: 8px 14px; background: var(--panel2); border: 1px solid var(--line);
    border-radius: 8px; font-size: .9rem; color: var(--muted); }
.share-banner b { color: var(--txt); }

/* ---- condivisioni: pannello admin ---- */
.shares-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.shares-list { display: flex; flex-direction: column; gap: 10px; margin: 12px 0; }
.share-row { border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; background: var(--panel); }
.share-main { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.share-name { font-weight: 700; font-size: 1.02rem; }
.share-sub { font-size: .8rem; color: var(--muted); margin-left: auto; }
.share-linkrow { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.share-url { flex: 1 1 260px; min-width: 0; font-family: monospace; font-size: .82rem; padding: 6px 8px;
    border: 1px solid var(--line); border-radius: 6px; background: var(--bg); color: var(--txt); }
.sh-editor { margin-top: 16px; border-top: 1px dashed var(--line); padding-top: 14px; }
.sh-albs-head { margin: 6px 0 4px; font-weight: 600; }
.sh-albs { max-height: 320px; overflow: auto; border: 1px solid var(--line); border-radius: 8px; padding: 6px; background: var(--bg); }
.sh-alb { display: flex; align-items: center; gap: 8px; padding: 5px 6px; border-radius: 6px; cursor: pointer; }
.sh-alb:hover { background: var(--panel2); }
.sh-alb em { color: var(--muted); font-style: normal; font-size: .82rem; }
.sh-actions { display: flex; gap: 8px; margin-top: 12px; }
