/* =====================================================================
   ESAGAMES — Topic view (v2). Clean, premium, no nested backgrounds.
   Created by ESAGAMES HOSTING SHIELD SRL
   ===================================================================== */

.breadcrumbs{ display:flex; flex-wrap:wrap; align-items:center; gap:6px; font-size:13px; color:var(--text-mute); margin-bottom:18px; }
.breadcrumbs a{ color:var(--text-dim); } .breadcrumbs a:hover{ color:var(--primary-2); }
.breadcrumbs .sep{ opacity:.4; }

/* ---- Topic hero ---- */
.topic-hero{ display:flex; align-items:flex-start; justify-content:space-between; gap:20px; flex-wrap:wrap;
    background:linear-gradient(120deg, rgba(var(--primary-rgb),.12), transparent 60%), var(--surface);
    border:1px solid var(--border); border-radius:18px; padding:24px 26px; margin-bottom:18px; }
.topic-hero-main{ min-width:0; flex:1 1 0; }
.topic-hero h1{ font-size:25px; letter-spacing:-.03em; margin:0 0 12px; line-height:1.25; overflow-wrap:break-word; word-break:break-word; min-width:0; }
.topic-hero h1 .prefix{ font-size:13px; padding:3px 11px; border-radius:8px; vertical-align:middle; margin-right:9px; font-weight:700; }
.topic-hero-meta{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; font-size:13px; color:var(--text-mute); }
.topic-hero-meta .thm{ display:inline-flex; align-items:center; gap:6px; }
.topic-hero-meta .thm a{ color:var(--text-dim); font-weight:600; } .topic-hero-meta .thm a:hover{ color:var(--primary-2); }
.topic-hero-meta .avatar.sm{ width:22px; height:22px; }
.topic-hero-meta .badge{ padding:3px 10px; border-radius:20px; font-weight:700; font-size:12px; }
.topic-hero-tags{ display:flex; gap:7px; flex-wrap:wrap; margin-top:12px; }
.topic-hero-actions{ display:flex; gap:8px; flex-shrink:0; }

/* ---- Mod bar ---- */
.mod-bar{ display:flex; flex-wrap:wrap; gap:8px; align-items:center; background:rgba(255,77,109,.06); border:1px solid rgba(255,77,109,.2); border-radius:14px; padding:12px 16px; margin-bottom:18px; }
.mod-bar-label{ font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--red); margin-right:4px; }
.mod-bar form{ display:inline; }
.mod-subform{ display:none !important; width:100%; gap:8px; align-items:center; margin-top:8px; }
.mod-subform.show{ display:flex !important; }
.mod-subform label{ font-size:13px; color:var(--text-dim); }
.mod-subform .input{ width:130px; }

/* ---- Poll ---- */
.poll-card{ background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:20px 22px; margin-bottom:18px; }
.poll-head{ font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--text-mute); margin-bottom:8px; display:flex; justify-content:space-between; }
.poll-status{ color:var(--amber); }
.poll-q{ font-size:18px; margin:0 0 16px; }
.poll-res{ margin-bottom:13px; }
.poll-res-top{ display:flex; justify-content:space-between; font-size:14px; margin-bottom:6px; }
.poll-res-top .poll-mine{ color:var(--green); font-weight:700; }
.poll-res-top b{ color:var(--text-mute); font-weight:700; font-size:13px; }
.poll-bar-wrap{ height:9px; background:var(--bg-1); border-radius:20px; overflow:hidden; box-shadow:inset 0 0 0 1px var(--border); }
.poll-bar{ height:100%; border-radius:20px; background:var(--grad-primary); transition:width .5s ease; }
.poll-total{ font-size:12.5px; color:var(--text-mute); margin-top:10px; }
.poll-vote{ display:flex; align-items:center; gap:10px; padding:11px 14px; border:1px solid var(--border); border-radius:11px; margin-bottom:8px; cursor:pointer; font-size:14px; transition:border-color .15s,background .15s; }
.poll-vote:hover{ border-color:var(--primary); background:var(--surface-2); }

/* ---- Posts ---- */
.posts-list{ display:flex; flex-direction:column; gap:18px; margin-bottom:24px; }
.post{ display:grid; grid-template-columns:210px minmax(0,1fr); background:var(--surface); border:1px solid var(--border); border-radius:16px; overflow:hidden; }
.post-cols{ display:contents; }
.best-banner{ grid-column:1 / -1; }
.post.is-op{ border-color:rgba(var(--primary-rgb),.4); box-shadow:0 0 0 1px rgba(var(--primary-rgb),.18); }
.post.is-best{ border-color:rgba(46,230,166,.5); box-shadow:0 0 0 1px rgba(46,230,166,.25); }
.post.post-flash{ animation: postFlash 1.6s ease; }
@keyframes postFlash{ 0%{ box-shadow:0 0 0 2px var(--primary); } 100%{ box-shadow:none; } }
.best-banner{ background:linear-gradient(90deg, rgba(46,230,166,.18), transparent); color:var(--green); font-weight:800; font-size:12px; padding:7px 16px; letter-spacing:.04em; border-bottom:1px solid rgba(46,230,166,.2); }

/* author column — distinct darker panel, accent from group color */
.post-author{ background:var(--bg-1); border-right:1px solid var(--border); padding:22px 16px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px; position:relative; }
.post-author::before{ content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gc,var(--primary)); opacity:.85; }
.pa-avatar{ display:block; }
.pa-avatar .avatar{ width:80px; height:80px; border-radius:18px; box-shadow:0 0 0 3px color-mix(in srgb, var(--gc,var(--primary)) 33%, transparent), 0 6px 16px rgba(0,0,0,.4); object-fit:cover; }
.pa-name{ font-weight:800; font-size:15px; color:#fff; } .pa-name:hover{ color:var(--primary-2); }
.pa-role{ font-size:11px; font-weight:800; padding:3px 11px; border-radius:20px; background:color-mix(in srgb, var(--gc,var(--primary)) 18%, transparent); color:var(--gc,var(--primary)); }
.pa-title{ font-size:12px; color:var(--text-mute); font-style:italic; }
.pa-level{ font-size:11.5px; font-weight:700; color:var(--amber); background:rgba(245,179,1,.12); padding:3px 10px; border-radius:20px; }
.pa-stats{ display:flex; gap:18px; margin-top:8px; padding-top:12px; border-top:1px solid var(--border); width:100%; justify-content:center; }
.pa-stats div{ display:flex; flex-direction:column; }
.pa-stats b{ color:#fff; font-size:15px; font-weight:800; } .pa-stats span{ font-size:11px; color:var(--text-mute); }
.pa-joined{ font-size:11px; color:var(--text-mute); }

/* XP mini progress bar — desktop sidebar */
.pa-xp-mini{ width:100%; padding:0 2px; }
.pa-xp-track{ height:4px; background:var(--surface-3); border-radius:4px; overflow:hidden; width:100%; }
.pa-xp-fill{ height:100%; border-radius:4px; background:var(--grad-primary); min-width:2px; }

/* pa-info / pa-badges / pa-stats-row — layout wrappers used on mobile.
   On desktop (sidebar mode) they are transparent pass-throughs.
   display:contents makes them invisible to the flex layout. */
.pa-info{ display:contents; }
.pa-badges{ display:contents; }
.pa-stats-row{ display:contents; }

/* Subtle divider between badge cluster and stats on desktop */
.pa-badges + .pa-xp-mini{ margin-top:2px; }

/* body column */
.post-body{ padding:20px 24px; display:flex; flex-direction:column; min-width:0; }
.post-top{ display:flex; justify-content:space-between; align-items:center; padding-bottom:13px; margin-bottom:16px; border-bottom:1px solid var(--border-soft); }
.post-num{ font-size:12.5px; color:var(--text-mute); display:flex; align-items:center; gap:7px; min-width:0; overflow:hidden; }
.post-num a{ color:var(--text-mute); } .post-num a:hover{ color:var(--primary-2); }
.op-badge{ background:var(--grad-primary); color:var(--on-accent,#fff); font-weight:800; font-size:10px; padding:2px 7px; border-radius:6px; letter-spacing:.04em; }
.edited{ font-style:italic; }
.post-tools{ display:flex; gap:4px; align-items:center; flex-wrap:wrap; }
.post-tools form{ display:inline; }
/* 44×44 min touch target; visual box stays 30px via inner sizing trick */
.ptool{ width:44px; height:44px; display:grid; place-items:center; border-radius:8px; background:var(--surface-2); border:1px solid var(--border); color:var(--text-dim); cursor:pointer; font-size:13px; transition:all .15s; }
.ptool:hover{ border-color:var(--primary); color:#fff; }
.ptool-danger:hover{ border-color:var(--red); color:var(--red); }

/* ---- Post content: BBCode-rendered output ---- */
.post-content{
    font-size:15px; line-height:1.78; color:var(--text); flex:1;
    /* Prevent any long word/URL from breaking the layout */
    overflow-wrap:break-word;
    word-break:break-word;
    min-width:0;
}
.post-content p{ margin:0 0 .85em; }
.post-content p:last-child{ margin-bottom:0; }

/* Lists */
.post-content ul,
.post-content ol{ margin:.6em 0 .85em 1.4em; padding:0; }
.post-content ul{ list-style:disc; }
.post-content ol{ list-style:decimal; }
.post-content li{ margin-bottom:.35em; }
.post-content li:last-child{ margin-bottom:0; }

/* Headings inside post content */
.post-content h1,.post-content h2,.post-content h3,
.post-content h4,.post-content h5,.post-content h6{
    color:#fff; font-weight:700; line-height:1.3;
    margin:.9em 0 .45em; letter-spacing:-.02em;
}
.post-content h1{ font-size:1.4em; }
.post-content h2{ font-size:1.25em; }
.post-content h3{ font-size:1.1em; }

/* Horizontal rule */
.post-content hr{
    border:none;
    border-top:1px solid var(--border);
    margin:1.1em 0;
}

/* Images from [img] tag */
.post-content img,
.post-content .post-image{
    max-width:100%;
    height:auto;
    border-radius:12px;
    margin:10px 0;
    display:block;
}
/* Custom emoji are inline, not block */
.post-content .custom-emoji{
    display:inline;
    vertical-align:middle;
    width:auto;
    height:1.4em;
    max-height:1.4em;
    border-radius:3px;
    margin:0 1px;
}

/* Code blocks — [code] renders as <pre class="code-block"><code> */
.post-content .code-block{
    background:var(--bg-0);
    border:1px solid var(--border);
    border-top:2px solid var(--primary);
    border-radius:10px;
    padding:14px 16px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    font-family:'JetBrains Mono','Fira Code',monospace;
    font-size:13px;
    margin:12px 0;
    color:#cdd3e6;
    /* preserve whitespace but let the block scroll rather than overflow */
    white-space:pre;
    word-break:normal;
    overflow-wrap:normal;
    max-width:100%;
    box-shadow:inset 0 0 0 0 transparent, 0 2px 8px rgba(0,0,0,.25);
}
.post-content .code-block code{
    font-family:inherit;
    font-size:inherit;
    color:inherit;
    background:none;
    padding:0;
}
/* Bare <pre>/<code> not wrapped in .code-block */
.post-content pre{
    background:var(--bg-0);
    border:1px solid var(--border);
    border-top:2px solid var(--primary);
    border-radius:10px;
    padding:14px 16px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    font-family:'JetBrains Mono','Fira Code',monospace;
    font-size:13px;
    margin:12px 0;
    white-space:pre;
    word-break:normal;
    overflow-wrap:normal;
    max-width:100%;
    box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.post-content code{
    font-family:'JetBrains Mono','Fira Code',monospace;
    font-size:.88em;
    background:rgba(var(--primary-rgb),.1);
    color:var(--primary-2);
    padding:2px 6px;
    border-radius:5px;
    border:1px solid rgba(var(--primary-rgb),.18);
}

/* Quotes — [quote] renders as <blockquote class="post-quote"> */
.post-content .post-quote{
    background:rgba(var(--primary-rgb),.05);
    border-left:3px solid var(--primary);
    border-radius:0 10px 10px 0;
    padding:11px 16px;
    margin:12px 0;
    color:var(--text-dim);
    overflow-wrap:break-word;
    word-break:break-word;
    position:relative;
}
.post-content .post-quote::before{
    content:'\201C';
    position:absolute;
    top:-4px;
    right:12px;
    font-size:48px;
    line-height:1;
    color:rgba(var(--primary-rgb),.14);
    font-family:Georgia,serif;
    pointer-events:none;
    user-select:none;
}
.post-content .post-quote cite{
    display:block;
    font-size:12px;
    color:var(--primary-2);
    margin-bottom:6px;
    font-style:normal;
    font-weight:700;
    letter-spacing:.01em;
}
.post-content .post-quote img{
    max-width:100%;
    height:auto;
    border-radius:8px;
}

/* Spoilers — [spoiler] renders as <details class="spoiler"><summary>Spoiler</summary>…</details> */
.post-content .spoiler{
    background:var(--bg-1);
    border:1px solid var(--border);
    border-radius:10px;
    padding:0;
    margin:10px 0;
    overflow:hidden;
    transition:border-color .15s;
}
.post-content .spoiler:hover{
    border-color:rgba(var(--primary-rgb),.35);
}
.post-content .spoiler summary{
    padding:10px 14px;
    cursor:pointer;
    font-size:13px;
    font-weight:700;
    color:var(--text-mute);
    user-select:none;
    list-style:none;
    display:flex;
    align-items:center;
    gap:7px;
    transition:color .15s, background .15s;
}
.post-content .spoiler summary::-webkit-details-marker{ display:none; }
.post-content .spoiler summary::before{
    content:'';
    display:inline-block;
    width:14px;
    height:14px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236c7591' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");
    background-size:contain;
    background-repeat:no-repeat;
    flex-shrink:0;
    opacity:.7;
    transition:opacity .15s;
}
.post-content .spoiler summary:hover{ color:var(--text-dim); }
.post-content .spoiler summary:hover::before{ opacity:1; }
.post-content .spoiler summary::after{
    content:'▶';
    font-size:9px;
    margin-left:auto;
    color:var(--text-mute);
    transition:transform .2s ease;
    opacity:.6;
}
.post-content .spoiler[open] summary{
    border-bottom:1px solid var(--border);
    color:var(--text-dim);
    background:rgba(var(--primary-rgb),.04);
}
.post-content .spoiler[open] summary::after{
    transform:rotate(90deg);
}
.post-content .spoiler > *:not(summary){
    padding:12px 14px;
    overflow-wrap:break-word;
    word-break:break-word;
}

/* Mentions, links */
.post-content .mention{ color:var(--primary-2); font-weight:600; background:rgba(var(--primary-rgb),.12); padding:1px 6px; border-radius:6px; }
.post-content a{ color:var(--accent-2); overflow-wrap:break-word; word-break:break-all; }

/* Embedded media: never overflow */
.post-content iframe,
.post-content video,
.post-content embed,
.post-content object{
    max-width:100%;
}

.post-sig{
    margin-top:18px; padding-top:12px;
    border-top:1px dashed rgba(255,255,255,.08);
    font-size:12.5px; color:var(--text-mute);
    overflow-wrap:break-word; word-break:break-word;
    font-style:italic;
}
.post-sig a{ color:var(--text-dim); }
.post-sig a:hover{ color:var(--primary-2); }

/* footer — clean reactions */
.post-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:18px; padding-top:13px; border-top:1px solid var(--border-soft); flex-wrap:wrap; gap:8px; }
.reactions{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
/* min 44×44 touch target on react-main */
.react-main{ display:inline-flex; align-items:center; gap:7px; padding:7px 14px; min-height:44px; border-radius:10px; background:var(--surface-2); border:1px solid var(--border); color:var(--text-dim); cursor:pointer; font-size:13px; font-weight:600; transition:all .15s; font-family:inherit; }
.react-main:hover{ border-color:var(--primary); color:#fff; }
.react-main.reacted{ background:rgba(var(--primary-rgb),.14); border-color:var(--primary); color:var(--primary-2); }
.react-main .rm-ico{ font-size:15px; }
.react-summary{ display:inline-flex; align-items:center; gap:3px; padding:5px 11px; border-radius:20px; background:var(--bg-1); border:1px solid var(--border); }
.react-summary .rs-emoji{ font-size:14px; margin-right:-3px; }
.react-summary .rs-count{ font-size:12.5px; font-weight:700; color:var(--text-dim); margin-left:6px; }
.report-form{ margin:0; }
/* min 44×44 touch target on report button */
.report-btn{ background:none; border:none; color:var(--text-mute); cursor:pointer; font-size:15px; padding:0; min-width:44px; min-height:44px; display:inline-flex; align-items:center; justify-content:center; border-radius:8px; transition:color .15s; }
.report-btn:hover{ color:var(--red); }

/* Reaction picker — hover bridge to prevent flicker on gap */
.react-wrap::after{
    content:'';
    position:absolute;
    left:0;
    right:0;
    bottom:calc(100%);
    height:10px;
    /* invisible bridge between button and picker */
}

/* ---- Editor ---- */
.esa-editor{ border:1px solid var(--border); border-radius:12px; overflow:hidden; background:var(--bg-1); position:relative; transition:border-color .18s; }
.esa-editor:focus-within{ border-color:rgba(var(--primary-rgb),.45); }
.editor-toolbar{
    display:flex; flex-wrap:wrap; gap:3px; padding:9px 11px;
    background:var(--surface-2); border-bottom:1px solid var(--border);
    align-items:center;
}
.editor-toolbar button{
    padding:6px 11px; background:none; border:1px solid transparent;
    border-radius:7px; cursor:pointer; font-size:13px; color:var(--text-dim);
    font-weight:600; transition:background .15s, color .15s, border-color .15s;
    font-family:inherit; min-height:32px;
}
.editor-toolbar button:hover{ background:var(--surface-3); color:#fff; border-color:var(--border); }
.editor-toolbar button:active{ background:rgba(var(--primary-rgb),.18); border-color:rgba(var(--primary-rgb),.4); color:var(--primary-2); transform:translateY(1px); }
.editor-toolbar .tb-sep{ width:1px; height:20px; background:var(--border); margin:0 5px; flex-shrink:0; opacity:.6; }
.esa-editor textarea{
    border:none; background:transparent; padding:14px 16px; width:100%;
    box-sizing:border-box; color:var(--text); font-size:15px; line-height:1.65;
    resize:vertical; min-height:150px; font-family:inherit;
}
.esa-editor textarea:focus{ outline:none; }
.emoji-picker{ display:flex; flex-wrap:wrap; gap:4px; padding:10px 12px; background:var(--surface-2); border-bottom:1px solid var(--border); }
.emoji-picker span{ font-size:20px; cursor:pointer; padding:5px; border-radius:7px; transition:background .15s, transform .12s; line-height:1; }
.emoji-picker span:hover{ background:var(--surface-3); transform:scale(1.2); }
.emoji-picker.hidden{ display:none; }

/* reply card / notes */
.reply-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:16px;
    padding:22px 24px;
    box-shadow:0 2px 16px rgba(0,0,0,.16);
}
.reply-card h3{
    font-size:17px; margin:0 0 16px;
    display:flex; align-items:center; gap:8px;
    color:#fff;
}
.reply-actions{ display:flex; align-items:center; gap:14px; margin-top:14px; flex-wrap:wrap; }
.reply-actions .text-mute{ font-size:12.5px; }
.locked-note{
    background:var(--surface); border:1px solid var(--border); border-radius:14px;
    padding:22px; text-align:center; color:var(--text-dim); font-size:14.5px;
}
.locked-note a{ color:var(--primary-2); font-weight:600; }

/* pagination */
.pagination{ display:flex; gap:5px; justify-content:center; margin:24px 0; flex-wrap:wrap; }
.pagination a,.pagination span{
    min-width:38px; height:38px; padding:0 12px;
    display:grid; place-items:center; border-radius:10px;
    background:var(--surface); border:1px solid var(--border);
    color:var(--text-dim); font-size:14px; font-weight:600;
    transition:all .15s;
}
.pagination a:hover{ border-color:var(--primary); color:#fff; background:var(--surface-2); }
.pagination .current{
    background:var(--grad-primary); color:var(--on-accent,#fff); border-color:transparent;
    box-shadow:0 3px 12px rgba(var(--primary-rgb),.4);
}
.pagination .dots{ border:none; background:none; }

/* =====================================================================
   v2 — reaction picker, best answer, viewers, attachments, follow, toast
   ===================================================================== */
/* Best answer highlight box */
.best-answer-box{
    background:linear-gradient(120deg, rgba(46,230,166,.10), var(--surface));
    border:1px solid rgba(46,230,166,.35);
    border-radius:16px;
    padding:18px 22px;
    margin-bottom:18px;
    overflow-wrap:break-word;
    word-break:break-word;
    position:relative;
}
.ba-head{
    font-size:13px; font-weight:800; color:var(--green);
    margin-bottom:10px; display:flex; align-items:center; gap:8px;
}
.ba-head a{ color:#fff; font-weight:700; }
.ba-head a:hover{ color:var(--green); }
.ba-content{
    color:var(--text-dim); font-size:14.5px; line-height:1.65;
    max-height:130px; overflow:hidden;
    overflow-wrap:break-word; word-break:break-word;
    position:relative;
}
/* Fade out at the bottom when content is clipped */
.ba-content::after{
    content:'';
    position:absolute;
    bottom:0; left:0; right:0;
    height:40px;
    background:linear-gradient(to bottom, transparent, var(--surface));
    pointer-events:none;
}
.ba-jump{
    display:inline-flex; align-items:center; gap:5px;
    margin-top:10px; font-size:13px; color:var(--green); font-weight:600;
}
.ba-jump:hover{ color:#fff; }

/* Who's viewing */
.viewers-bar{
    display:flex; align-items:center; gap:8px;
    margin-top:14px;
    padding:7px 12px;
    background:rgba(0,0,0,.18);
    border:1px solid rgba(255,255,255,.05);
    border-radius:30px;
    font-size:12px; color:var(--text-mute);
    flex-wrap:wrap;
    width:fit-content;
    max-width:100%;
}
.viewers-bar .vb-label{ font-weight:700; letter-spacing:.01em; }
.viewers-bar .vb-list{ display:flex; align-items:center; }
.viewers-bar .vb-list a img{ width:22px; height:22px; border-radius:50%; border:2px solid var(--surface); margin-left:-5px; object-fit:cover; }
.viewers-bar .vb-list a:first-child img{ margin-left:0; }
.viewers-bar .vb-count{ color:var(--text-dim); font-weight:600; font-size:12px; }

/* Follow button */
.topic-follow.following{ border-color:var(--primary) !important; color:var(--primary-2) !important; background:rgba(var(--primary-rgb),.12) !important; }

/* Reaction picker */
.reactions{ position:relative; }
.react-wrap{ position:relative; display:inline-block; }
.react-picker{ position:absolute; bottom:calc(100% + 8px); left:0; display:flex; gap:4px; padding:7px 9px; background:var(--elev); border:1px solid var(--border); border-radius:30px; box-shadow:var(--shadow); opacity:0; visibility:hidden; transform:translateY(8px) scale(.9); transform-origin:bottom left; transition:all .18s cubic-bezier(.2,.8,.2,1); z-index:20; }
.react-wrap:hover .react-picker{ opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.rp-btn{ font-size:22px; background:none; border:none; cursor:pointer; padding:3px; border-radius:8px; transition:transform .12s; line-height:1; }
.rp-btn:hover{ transform:scale(1.35) translateY(-2px); }
.react-summary{ cursor:pointer; }
.react-summary.empty{ display:none; }

/* Attachments */
.esa-editor.drag{ outline:2px dashed var(--primary); outline-offset:-4px; }
.attach-list{ display:flex; flex-wrap:wrap; gap:8px; padding:0 14px 12px; }
.attach-list:empty{ padding:0; }
.att-chip{ font-size:12.5px; background:var(--surface-2); border:1px solid var(--border); padding:5px 11px; border-radius:8px; color:var(--text-dim); }

/* Toast */
.esa-toast{ position:fixed; bottom:24px; left:50%; transform:translateX(-50%); background:var(--elev); border:1px solid var(--border); color:#fff; padding:11px 20px; border-radius:12px; box-shadow:var(--shadow); z-index:9999; font-size:14px; font-weight:600; animation:toastIn .25s ease; }
@keyframes toastIn{ from{ opacity:0; transform:translate(-50%,12px); } to{ opacity:1; transform:translate(-50%,0); } }

/* Server sub-ranks on post author (e.g. [GOLD CS] Admin Server) */
.pa-srv-rank{ display:inline-block; margin-top:4px; padding:2px 8px; border-radius:7px; font-size:10.5px; font-weight:800; letter-spacing:.02em; line-height:1.5; }
.pa-srv-manager{ background:rgba(var(--primary-rgb),.16); color:var(--primary-2); border:1px solid rgba(var(--primary-rgb),.4); }
.pa-srv-admin_server{ background:rgba(245,179,1,.16); color:#f5b301; border:1px solid rgba(245,179,1,.4); }
.pa-srv-vip_server{ background:rgba(46,230,166,.16); color:#2ee6a6; border:1px solid rgba(46,230,166,.4); }

/* =====================================================================
   DESKTOP POLISH (≥1024px) — Topic view refined spacing & hierarchy
   ===================================================================== */
@media (min-width: 1024px) {
    /* ── Topic hero: richer card ── */
    .topic-hero {
        padding: 28px 30px;
        margin-bottom: 22px;
        border-radius: 20px;
        box-shadow: 0 2px 20px rgba(0,0,0,.22);
    }
    .topic-hero h1 {
        font-size: 27px;
        letter-spacing: -.035em;
        margin-bottom: 14px;
    }
    .topic-hero-meta { gap: 16px; }
    .topic-hero-actions { gap: 10px; }

    /* ── Post card: more breathing room ── */
    .post {
        grid-template-columns: 220px minmax(0, 1fr);
        border-radius: 18px;
        transition: box-shadow .18s ease;
    }
    .post:hover {
        box-shadow: 0 4px 24px rgba(0,0,0,.28);
    }
    .post.is-op {
        box-shadow: 0 0 0 1px rgba(var(--primary-rgb),.22), 0 4px 20px rgba(var(--primary-rgb),.08);
    }
    .post.is-op:hover {
        box-shadow: 0 0 0 1px rgba(var(--primary-rgb),.32), 0 6px 28px rgba(var(--primary-rgb),.14);
    }
    .post.is-best {
        box-shadow: 0 0 0 1px rgba(46,230,166,.3), 0 4px 20px rgba(46,230,166,.08);
    }

    /* ── Author sidebar: tighter internal gaps ── */
    .post-author { padding: 24px 18px; gap: 10px; }
    .pa-avatar .avatar {
        width: 86px; height: 86px; border-radius: 20px;
        box-shadow: 0 0 0 3px color-mix(in srgb, var(--gc, var(--primary)) 38%, transparent),
                    0 8px 22px rgba(0,0,0,.45);
    }
    .pa-name { font-size: 15.5px; }
    .pa-stats { gap: 20px; padding-top: 13px; margin-top: 10px; }
    .pa-stats b { font-size: 16px; }
    .pa-xp-track { height: 5px; }

    /* ── Post body: more padding, better post-top line ── */
    .post-body { padding: 22px 26px; }
    .post-top { padding-bottom: 13px; margin-bottom: 16px; }
    .post-num { font-size: 12.5px; }

    /* ── Post tools: refined button sizing (desktop — mouse, smaller visual ok) ── */
    .ptool {
        width: 36px; height: 36px; border-radius: 9px; font-size: 14px;
        transition: all .14s ease, transform .12s ease;
    }
    .ptool:hover { transform: translateY(-1px); }

    /* ── Post content: better reading rhythm on desktop ── */
    .post-content {
        font-size: 15.5px;
        line-height: 1.82;
    }
    .post-content p { margin-bottom: .9em; }
    .post-content .code-block { font-size: 13.5px; padding: 16px 18px; }
    .post-content pre { font-size: 13.5px; padding: 16px 18px; }
    .post-content .post-quote { padding: 13px 18px; margin: 13px 0; }
    .post-content .post-quote cite { font-size: 12.5px; margin-bottom: 7px; }

    /* ── Post footer: better spacing ── */
    .post-foot { margin-top: 18px; padding-top: 14px; gap: 10px; }

    /* ── Reactions: refined hover on main button ── */
    .react-main { padding: 8px 16px; min-height: 36px; gap: 8px; border-radius: 11px; font-size: 13.5px; }
    .react-main:hover { transform: translateY(-1px); box-shadow: 0 3px 12px rgba(var(--primary-rgb),.18); }
    .react-main.reacted { box-shadow: 0 0 0 1px rgba(var(--primary-rgb),.3); }
    .react-summary { padding: 6px 13px; gap: 4px; }
    .react-summary .rs-count { font-size: 13px; }

    /* Reaction picker: smoother appearance */
    .react-picker { padding: 8px 11px; gap: 5px; }
    .rp-btn { font-size: 24px; padding: 4px; }

    /* ── Reply card ── */
    .reply-card { padding: 28px 30px; border-radius: 18px; }
    .reply-card h3 { font-size: 18px; margin-bottom: 18px; }

    /* ── Editor ── */
    .editor-toolbar { padding: 10px 14px; gap: 4px; }
    .editor-toolbar button { padding: 7px 13px; font-size: 13.5px; border-radius: 8px; min-height:34px; }
    .esa-editor textarea { font-size: 15px; padding: 18px; min-height: 180px; }

    /* ── Poll card ── */
    .poll-card { padding: 24px 26px; border-radius: 18px; }
    .poll-q { font-size: 19px; margin-bottom: 18px; }
    .poll-vote { padding: 12px 16px; font-size: 14.5px; border-radius: 12px; }

    /* ── Best answer box ── */
    .best-answer-box { padding: 20px 26px; border-radius: 18px; }
    .ba-content { font-size: 15px; max-height: 150px; }

    /* ── Mod bar ── */
    .mod-bar { padding: 13px 18px; border-radius: 16px; gap: 10px; }

    /* ── Posts list gap ── */
    .posts-list { gap: 18px; }

    /* ── Pagination: bigger touch targets ── */
    .pagination a, .pagination span { min-width: 40px; height: 40px; font-size: 14px; }

    /* ── Viewers bar: slightly larger avatars ── */
    .viewers-bar .vb-list a img { width: 26px; height: 26px; }

    /* ── Signature block ── */
    .post-sig { margin-top: 18px; padding-top: 13px; }
}

/* =====================================================================
   MOBILE RESPONSIVE — 360–768 px  (phones & tablets)
   Desktop layout (>768px) is completely untouched.
   ===================================================================== */

/* ---- Shared mobile helper: post-author info cluster ---------------
   On mobile the sidebar flips into a compact HEADER ROW:
     [avatar]  [name + role/rank badges]  ···  [stats pills]
   The `.pa-info` wrapper groups name + badges; `.pa-stats-row` groups
   the two stat pills. Both wrappers are in _post.php HTML.
------------------------------------------------------------------- */

/* ---- Tablet: ≤768px ----------------------------------------------- */
@media (max-width:768px){

    /* ── Breadcrumbs ── */
    .breadcrumbs{ gap:4px; font-size:12px; }

    /* ── Topic hero ── */
    .topic-hero{
        flex-direction:column;
        padding:16px;
        gap:12px;
        border-radius:14px;
    }
    .topic-hero h1{ font-size:20px; margin-bottom:8px; line-height:1.3; }
    .topic-hero h1 .prefix{ font-size:12px; padding:2px 9px; }
    .topic-hero-meta{ gap:8px; font-size:12.5px; }
    .topic-hero-tags{ gap:5px; }

    /* Action buttons — full-width row, items wrap evenly */
    .topic-hero-actions{
        display:flex;
        flex-wrap:wrap;
        gap:8px;
        width:100%;
        flex-shrink:unset;
    }
    .topic-hero-actions .btn{
        flex:1 1 auto;
        text-align:center;
        justify-content:center;
        min-height:44px;
        min-width:80px;
        padding:8px 12px;
    }

    /* ── Post card → single column ── */
    .post{
        grid-template-columns:1fr;
        border-radius:13px;
    }

    /* ── Author aside → compact header row ── */
    .post-author{
        display:flex;
        flex-direction:row;
        flex-wrap:wrap;
        align-items:center;
        text-align:left;
        border-right:none;
        border-bottom:1px solid var(--border);
        padding:10px 14px;
        gap:10px;
        position:relative;
    }
    /* accent stripe across the full top */
    .post-author::before{
        width:100%;
        height:3px;
        left:0; right:0;
        top:0; bottom:auto;
    }

    /* Avatar — medium size, no shrink */
    .pa-avatar{
        flex-shrink:0;
        display:flex;
        align-items:center;
    }
    .pa-avatar .avatar{
        width:42px;
        height:42px;
        border-radius:11px;
        flex-shrink:0;
    }

    /* Name + badges cluster — becomes a real flex column */
    .pa-info{
        display:flex;
        flex-direction:column;
        align-items:flex-start;
        gap:3px;
        flex:1 1 0;
        min-width:0;
    }
    .pa-name{ font-size:13.5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%; display:block; }

    /* Badge row inside .pa-info: role + server-rank pills wrap together */
    .pa-badges{
        display:flex;
        flex-wrap:wrap;
        align-items:center;
        gap:4px;
    }
    .pa-role{ font-size:10.5px; padding:2px 9px; }
    .pa-srv-rank{ font-size:10px; padding:2px 7px; margin-top:0; }

    /* Title hidden on tablet — not enough room */
    .pa-title{ display:none; }

    /* Level pill — kept but compact */
    .pa-level{ font-size:10.5px; padding:2px 8px; }

    /* XP bar — hide on mobile (not enough room in horizontal header) */
    .pa-xp-mini{ display:none; }

    /* Stats row pushed to right side of the header */
    .pa-stats-row{
        display:flex;
        align-items:center;
        gap:10px;
        margin-left:auto;
        flex-shrink:0;
    }
    .pa-stats{
        flex-direction:row;
        width:auto;
        border:none;
        padding:0;
        margin:0;
        gap:10px;
    }
    .pa-stats div{
        flex-direction:row;
        align-items:baseline;
        gap:3px;
    }
    .pa-stats b{ font-size:13px; }
    .pa-stats span{ font-size:10px; color:var(--text-mute); }

    /* Joined — hidden on tablet */
    .pa-joined{ display:none; }

    /* ── Post body ── */
    .post-body{ padding:14px 16px; }
    .post-top{
        flex-wrap:wrap;
        gap:6px;
        padding-bottom:10px;
        margin-bottom:12px;
        align-items:flex-start;
    }
    .post-num{ flex:1 1 auto; overflow-wrap:anywhere; }
    .post-tools{ flex-shrink:0; }

    /* Post tools — touch-friendly: 44px min targets, wrap */
    .post-tools{ flex-wrap:wrap; gap:5px; }
    .ptool{
        width:44px;
        height:44px;
        border-radius:9px;
        font-size:15px;
    }

    /* ── Post content — prevent overflow ── */
    .post-content{
        font-size:14px;
        line-height:1.7;
    }
    .post-content img,
    .post-content .post-image{
        max-width:100% !important;
        height:auto !important;
        border-radius:8px;
    }
    .post-content .code-block{
        font-size:12px;
        padding:11px 12px;
    }
    .post-content pre{
        font-size:12px;
        padding:11px 12px;
    }
    .post-content .post-quote{ padding:8px 12px; }

    /* ── Post footer ── */
    .post-foot{ flex-wrap:wrap; gap:8px; align-items:center; }
    .react-main{ padding:7px 12px; min-height:44px; }
    /* Keep picker from overflowing viewport on narrow screens */
    .react-picker{
        left:0;
        right:auto;
        max-width:calc(100vw - 32px);
        flex-wrap:wrap;
    }

    /* ── Reply editor ── */
    .reply-card{ padding:16px; border-radius:14px; }
    .reply-card h3{ font-size:15px; }
    .esa-editor textarea{
        width:100%;
        box-sizing:border-box;
        font-size:14px;
        min-height:120px;
    }
    .editor-toolbar{ padding:7px 8px; gap:3px; flex-wrap:wrap; }
    .editor-toolbar button{ padding:6px 9px; font-size:12.5px; min-height:44px; }
    .reply-actions{ flex-wrap:wrap; gap:8px; }
    .reply-actions .btn{ flex:1 1 100%; text-align:center; justify-content:center; min-height:44px; }

    /* ── Mod bar ── */
    .mod-bar{ padding:10px 12px; gap:6px; border-radius:12px; }
    .mod-subform .input{ width:110px; }

    /* ── Poll ── */
    .poll-card{ padding:16px; border-radius:14px; }
    .poll-q{ font-size:16px; }
    .poll-res-top{ flex-wrap:wrap; gap:4px; }
    .poll-vote{ min-height:44px; }

    /* ── Best answer box ── */
    .best-answer-box{ padding:14px 16px; border-radius:14px; }

    /* ── Viewers bar ── */
    .viewers-bar{ gap:6px; font-size:12px; }

    /* ── Pagination ── */
    .pagination{ gap:5px; justify-content:center; }
    .pagination a,
    .pagination span{
        min-width:38px;
        height:38px;
        font-size:13px;
        border-radius:9px;
    }

    /* ── Lock / login note ── */
    .locked-note{ padding:16px; font-size:13.5px; border-radius:12px; }
}

/* ---- Phone: ≤480px ------------------------------------------------ */
@media (max-width:480px){

    /* ── Breadcrumbs ── */
    .breadcrumbs{ font-size:11.5px; gap:3px; }

    /* ── Topic hero ── */
    .topic-hero{ padding:12px; border-radius:12px; gap:10px; }
    .topic-hero h1{ font-size:17px; line-height:1.3; }
    .topic-hero h1 .prefix{ font-size:11px; padding:2px 8px; }
    .topic-hero-meta{ gap:6px; font-size:12px; }

    /* Action buttons — pair-up or full width on very small */
    .topic-hero-actions .btn{
        flex:1 1 calc(50% - 4px);
        min-width:0;
        font-size:12.5px;
        min-height:44px;
        padding:8px 8px;
    }

    /* ── Post card ── */
    .post{ border-radius:11px; }

    /* ── Author header on phone — tighter, avatar a bit smaller ── */
    .post-author{ padding:8px 10px; gap:8px; }
    .pa-avatar .avatar{ width:36px; height:36px; border-radius:9px; }
    .pa-name{ font-size:12.5px; }

    /* Badge row — role pill hidden on tiny screens to save space;
       server-rank badges stay (meaningful identity markers) */
    .pa-role{ display:none; }
    /* Level hidden too — stats row covers level implicitly */
    .pa-level{ display:none; }
    .pa-srv-rank{ font-size:9.5px; padding:2px 6px; }

    /* Stats row inline, very compact */
    .pa-stats{ gap:8px; }
    .pa-stats b{ font-size:12px; }
    .pa-stats span{ font-size:9.5px; }

    /* ── Post body ── */
    .post-body{ padding:10px 12px; }
    .post-content{ font-size:13.5px; line-height:1.65; }
    .post-content .code-block{ font-size:11.5px; padding:10px; }
    .post-content pre{ font-size:11.5px; padding:10px; }

    /* Post tools — 44px min touch targets */
    .ptool{ width:44px; height:44px; font-size:13px; }

    /* ── Editor toolbar ── */
    .editor-toolbar{ padding:6px; gap:2px; }
    .editor-toolbar button{ padding:5px 7px; font-size:12px; min-height:44px; }
    .esa-editor textarea{ padding:10px; font-size:13.5px; }

    /* Hide text hint — saves vertical space */
    .reply-actions .text-mute{ display:none; }

    /* ── Poll ── */
    .poll-card{ padding:12px; border-radius:12px; }
    .poll-q{ font-size:14.5px; }

    /* ── React picker — clamp so it never exits viewport ── */
    .react-picker{ left:0; right:auto; max-width:calc(100vw - 24px); }

    /* ── Mod subform ── */
    .mod-subform .input{ width:90px; }

    /* ── Pagination ── */
    .pagination{ gap:3px; }
    .pagination a,
    .pagination span{
        min-width:36px;
        height:40px;
        padding:0 6px;
        font-size:12px;
        border-radius:8px;
    }

    /* ── Best answer box ── */
    .best-answer-box{ padding:10px 12px; border-radius:12px; }

    /* ── Catch-all: no horizontal scroll ──
       NOTE: .post is intentionally excluded because it contains the absolutely
       positioned .react-picker — overflow:hidden on a containing block would
       clip the picker. Instead, overflow is controlled inside .post-body. */
    .topic-hero,
    .reply-card,
    .poll-card,
    .mod-bar,
    .best-answer-box,
    .posts-list,
    .pagination{ max-width:100%; overflow-x:hidden; }
    /* post itself: contain horizontally without hiding abs-positioned children */
    .post{ max-width:100%; }
}

/* ---- Smallest phones: ≤360px -------------------------------------- */
@media (max-width:360px){

    /* Hero — absolute minimum padding */
    .topic-hero{ padding:10px; border-radius:10px; gap:8px; }
    .topic-hero h1{ font-size:15px; }
    .topic-hero-actions .btn{ flex:1 1 100%; }

    /* Post author — single compact row */
    .post-author{ padding:7px 9px; gap:6px; }
    .pa-avatar{ flex-shrink:0; }
    .pa-avatar .avatar{ width:32px; height:32px; border-radius:8px; }
    .pa-name{ font-size:12px; }

    /* Stats extremely compact */
    .pa-stats-row{ gap:6px; }
    .pa-stats{ gap:6px; }
    .pa-stats b{ font-size:11.5px; }
    .pa-stats span{ font-size:9px; }

    /* Post body — tight */
    .post-body{ padding:8px 10px; }
    .post-content{ font-size:13px; }

    /* Editor */
    .editor-toolbar button{ padding:4px 6px; font-size:11.5px; min-height:44px; }
    .esa-editor textarea{ font-size:13px; padding:9px; }

    /* Pagination — very compact but still tappable */
    .pagination a,
    .pagination span{ min-width:32px; height:36px; font-size:11.5px; border-radius:7px; padding:0 4px; }
}

/* ---- Reduced motion ------------------------------------------------ */
@media (prefers-reduced-motion:reduce){
    .post.post-flash{ animation:none; }
    .poll-bar{ transition:none; }
    .react-picker{ transition:none; }
    .esa-toast{ animation:none; }
}

/* =====================================================================
   MOBILE POLISH PASS — Topic view (phones 360–768px)
   ===================================================================== */

/* ── Reaction picker: always open upward and never exit viewport ── */
@media (max-width: 768px) {
    /* Force picker above the button (bottom: 100% + gap) */
    .react-picker {
        bottom: calc(100% + 6px);
        top: auto;
        left: 0;
        right: auto;
        max-width: calc(100vw - 28px);
        flex-wrap: wrap;
        row-gap: 4px;
    }
    /* Show on touch (hover doesn't work on mobile) — JS handles this;
       keep the CSS fallback so hover still works on desktop */
}

/* ── Author header: prevent overflow at very narrow widths ── */
@media (max-width: 480px) {
    .post-author { flex-wrap: nowrap; }
    .pa-info { overflow: hidden; }
    /* Stats row: drop to column on truly tiny screens */
    .pa-stats-row { flex-wrap: wrap; gap: 6px; }
}

/* ── Post content: clamp wide tables + media ── */
@media (max-width: 768px) {
    .post-content table {
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        max-width: 100%;
    }
    .post-content iframe {
        max-width: 100%;
        width: 100%;
    }
    /* Quotes: tighter indentation on phone */
    .post-content .post-quote { padding: 8px 10px; margin: 8px 0; }
    .post-content .post-quote cite { font-size: 11.5px; }
}

/* ── Attachment chips: wrap on phone ── */
@media (max-width: 480px) {
    .attach-list { padding: 0 10px 10px; gap: 6px; }
    .att-chip { font-size: 12px; padding: 4px 9px; }
}

/* ── Emoji picker in editor: tighter ── */
@media (max-width: 480px) {
    .emoji-picker { padding: 8px; gap: 2px; }
    .emoji-picker span { font-size: 18px; padding: 3px; }
}

/* ── Toast: keep above cookie bar on phone ── */
@media (max-width: 480px) {
    .esa-toast { bottom: 80px; font-size: 13px; padding: 10px 16px; max-width: calc(100vw - 32px); }
}

/* ── Viewers bar: compact on phone ── */
@media (max-width: 480px) {
    .viewers-bar { font-size: 12px; }
    .viewers-bar .vb-list a img { width: 20px; height: 20px; }
}

/* ── Best answer box: no overflow ── */
@media (max-width: 480px) {
    .best-answer-box { overflow-x: hidden; }
    .ba-content { font-size: 13.5px; max-height: 100px; }
}

/* ── Reply actions: tighten on phone ── */
@media (max-width: 480px) {
    .reply-actions { gap: 8px; }
    /* Preview button gets its own full row */
    .reply-actions .btn-ghost { flex: 1 1 100%; }
    .reply-actions .btn-primary { flex: 1 1 100%; }
}

/* ── Topic hero: ensure action buttons don't overflow ── */
@media (max-width: 360px) {
    .topic-hero-actions .btn { font-size: 12px; padding: 7px 8px; min-height: 44px; }
    .topic-hero-meta .thm { gap: 4px; }
}

/* ── Poll: compact options on phone ── */
@media (max-width: 360px) {
    .poll-vote { padding: 9px 10px; font-size: 13.5px; min-height: 40px; }
    .poll-q { font-size: 14px; }
}

/* ── Ensure post body doesn't overflow at 360px ── */
@media (max-width: 360px) {
    .post-body { padding: 8px 10px; }
    .post-content { font-size: 13px; line-height: 1.65; }
    .post-content .code-block,
    .post-content pre { font-size: 11px; padding: 9px; }
}
