/* ============================================================
Report Modal
============================================================ */
.report-overlay{
position:fixed;
inset:0;
background:rgba(0,0,0,0.5);
z-index:1100;
display:flex;
align-items:center;
justify-content:center;
padding:20px;
}

.report-overlay[hidden]{display:none;}

.report-modal{
background:var(--color-card);
border-radius:8px;
width:100%;
max-width:500px;
max-height:85vh;
overflow-y:auto;
font-family:'Palatino Linotype',Palatino,'Book Antiqua',serif;
color:var(--color-text);
}

.report-modal__header{
display:flex;
align-items:center;
justify-content:space-between;
padding:14px 18px;
border-bottom:2px solid var(--color-primary);
}

.report-modal__header h3{
margin:0;
font-size:1rem;
color:var(--color-primary);
}

.report-modal__close{
background:none;
border:none;
font-size:1.25rem;
color:var(--color-primary);
cursor:pointer;
line-height:1;
padding:0;
}

.report-modal__body{
padding:16px 18px;
}

.report-modal__label{
display:block;
font-size:0.75rem;
font-weight:700;
text-transform:uppercase;
color:var(--color-muted);
margin-bottom:4px;
letter-spacing:0.5px;
}

.report-modal__label--optional::after{
content:' (optional)';
font-weight:400;
text-transform:none;
}

.report-modal__field{
margin-bottom:14px;
}

.report-modal__input,
.report-modal__textarea{
width:100%;
background:var(--color-input-bg);
border:1px solid var(--color-border);
border-radius:4px;
padding:8px 10px;
font-size:0.85rem;
font-family:inherit;
color:var(--color-text);
box-sizing:border-box;
}

.report-modal__textarea{
min-height:70px;
resize:vertical;
}

.report-modal__types{
display:flex;
gap:5px;
flex-wrap:wrap;
margin-bottom:14px;
}

.report-modal__type-pill{
padding:4px 10px;
border-radius:12px;
font-size:0.7rem;
cursor:pointer;
border:1px solid var(--color-border);
background:transparent;
color:var(--color-muted);
font-family:inherit;
transition:background 0.15s,color 0.15s;
}

.report-modal__type-pill.is-active{
background:var(--color-primary);
color:var(--color-on-primary);
border-color:var(--color-primary);
font-weight:600;
}

.report-modal__checkbox-row{
display:flex;
align-items:center;
gap:8px;
margin-bottom:16px;
font-size:0.85rem;
}

.report-modal__checkbox-row input[type="checkbox"]{
accent-color:var(--color-primary);
width:16px;
height:16px;
}

.report-modal__checkbox-hint{
color:var(--color-muted);
font-size:0.75rem;
}

.report-modal__file-drop{
border:2px dashed var(--color-border,#ccc);
border-radius:6px;
padding:16px;
text-align:center;
cursor:pointer;
transition:border-color 0.15s,background 0.15s;
}

.report-modal__file-drop.is-dragover{
border-color:var(--color-accent);
background:rgba(var(--color-accent-rgb,100,100,200),0.08);
}

.report-modal__file-prompt{
color:var(--color-muted);
font-size:0.85rem;
}

.report-modal__file-browse{
background:none;
border:none;
color:var(--color-accent);
cursor:pointer;
font-size:inherit;
font-family:inherit;
padding:0;
text-decoration:underline;
}

.report-modal__file-name{
font-size:0.85rem;
color:var(--color-text);
word-break:break-all;
}

.report-modal__file-hint{
display:block;
color:var(--color-muted);
font-size:0.7rem;
margin-top:4px;
}

.report-modal__actions{
display:flex;
justify-content:flex-end;
gap:8px;
}

.report-modal__btn{
padding:8px 16px;
border-radius:4px;
font-size:0.85rem;
font-family:inherit;
cursor:pointer;
}

.report-modal__btn--cancel{
border:1px solid var(--color-border);
background:transparent;
color:var(--color-text);
}

.report-modal__btn--submit{
border:none;
background:var(--color-primary);
color:var(--color-on-primary);
font-weight:600;
}

.report-modal__btn--submit:disabled{
opacity:0.5;
cursor:not-allowed;
}

.report-modal__login{
display:flex;
flex-direction:column;
align-items:center;
gap:8px;
padding:12px;
margin-bottom:14px;
background:var(--color-background);
border:1px solid var(--color-border);
border-radius:6px;
font-size:0.85rem;
}

.report-modal__login-btn{
padding:8px 16px;
border-radius:4px;
border:1px solid var(--color-border);
background:var(--color-card);
color:var(--color-text);
font-family:inherit;
font-size:0.8rem;
cursor:pointer;
display:flex;
align-items:center;
gap:6px;
}

/* ============================================================
Forum Page Layout
============================================================ */
.forum-page{
min-height:100vh;
background:var(--color-background);
color:var(--color-text);
font-family:'Palatino Linotype',Palatino,'Book Antiqua',serif;
}

/* ============================================================
Split-Pane Layout
============================================================ */
.forum-split{
display:flex;
height:calc(100vh - 100px);
overflow:hidden;
}

.forum-split__list{
width:30%;
min-width:280px;
border-right:1px solid var(--color-border);
overflow-y:auto;
flex-shrink:0;
}

.forum-split__detail{
flex:1;
overflow-y:auto;
padding:20px 24px;
min-width:0;
}

.forum-split__placeholder{
display:flex;
align-items:center;
justify-content:center;
height:100%;
color:var(--color-muted);
font-size:0.95rem;
font-style:italic;
}

.forum-filters{
position:sticky;
top:0;
z-index:10;
display:flex;
align-items:center;
gap:6px;
padding:10px 16px;
background:var(--color-card);
border-bottom:1px solid var(--color-border);
}

.forum-filters__select{
flex:1;
min-width:0;
background:var(--color-input-bg);
color:var(--color-text);
border:1px solid var(--color-border);
border-radius:4px;
padding:5px 6px;
font-size:0.72rem;
font-family:inherit;
}

.forum-filters > .btn{
margin-left:auto;
flex-shrink:0;
padding:5px 14px;
font-size:0.75rem;
}

/* ============================================================
Issue Cards (list view)
============================================================ */
#issues-list{
padding:12px 16px 0;
transition:opacity 0.15s ease;
}

#issues-list.is-loading{
opacity:0.4;
pointer-events:none;
}

.issue-card{
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
padding:14px 16px;
margin-bottom:10px;
cursor:pointer;
display:flex;
gap:14px;
transition:border-color 0.15s;
}

.issue-card:hover{
border-color:var(--color-primary);
}

.issue-card--closed{
opacity:0.6;
}

.issue-card.is-active{
border-color:var(--color-primary);
background:var(--color-input-bg);
}

.vote-col{
display:flex;
flex-direction:column;
align-items:center;
min-width:40px;
gap:2px;
}

.vote-col--large{
min-width:44px;
padding-top:4px;
}

.vote-btn{
background:none;
border:none;
font-size:0.9rem;
color:var(--color-muted);
cursor:pointer;
padding:8px 12px;
line-height:1;
min-width:44px;
min-height:44px;
display:flex;
align-items:center;
justify-content:center;
}

.vote-btn:hover{
color:var(--color-primary);
}

.vote-btn.is-active{
color:var(--color-primary);
}

.vote-score{
font-size:0.95rem;
font-weight:700;
color:var(--color-secondary);
}

.badge{
padding:2px 8px;
border-radius:10px;
font-size:0.65rem;
font-weight:600;
display:inline-block;
}

.badge--open{background:#2d5a2d;color:#8fbc8f;}

.badge--acknowledged{background:#2a3d5a;color:#7aaacc;}

.badge--in_progress{background:#5a4a2a;color:#d4b86a;}

.badge--resolved{background:#1a3d1a;color:#6aaa6a;}

.badge--wont_fix{background:#3d2222;color:#cc7a7a;}

.badge--type{border:1px solid var(--color-border);color:var(--color-muted);background:transparent;}

.badge-select{
padding:2px 6px;
border-radius:10px;
font-size:0.65rem;
font-weight:600;
font-family:inherit;
border:1px solid var(--color-border);
background:transparent;
color:var(--color-muted);
cursor:pointer;
}

.issue-card__title{
font-size:0.9rem;
font-weight:600;
color:var(--color-text);
margin:0;
}

.issue-card--closed .issue-card__title{
text-decoration:line-through;
text-decoration-color:var(--color-muted);
}

.issue-card__preview{
font-size:0.78rem;
color:var(--color-muted);
margin-top:4px;
}

.issue-card__meta{
display:flex;
align-items:center;
gap:12px;
margin-top:8px;
font-size:0.7rem;
color:var(--color-muted);
}

.issue-card__author{
display:flex;
align-items:center;
gap:4px;
}

.avatar-sm{
width:18px;
height:18px;
border-radius:50%;
display:inline-flex;
align-items:center;
justify-content:center;
font-size:0.5rem;
font-weight:700;
background:var(--color-secondary);
color:var(--color-on-primary);
}

/* ============================================================
Issue Detail View
============================================================ */
.issue-detail__header{
display:flex;
gap:16px;
margin-bottom:20px;
}

.issue-detail__title{
font-size:1.25rem;
color:var(--color-text);
margin:0 0 8px 0;
line-height:1.3;
}

.issue-detail__meta{
display:flex;
align-items:center;
gap:10px;
font-size:0.78rem;
color:var(--color-muted);
}

.admin-panel{
margin-top:10px;
padding:8px 12px;
background:var(--color-card);
border:1px dashed var(--color-border);
border-radius:4px;
display:flex;
align-items:center;
gap:10px;
font-size:0.78rem;
}

.admin-panel__label{
color:var(--color-secondary);
font-weight:600;
font-size:0.65rem;
text-transform:uppercase;
letter-spacing:0.5px;
}

.admin-panel__select{
background:var(--color-input-bg);
color:var(--color-text);
border:1px solid var(--color-border);
border-radius:4px;
padding:3px 8px;
font-size:0.7rem;
font-family:inherit;
}

.admin-panel__delete{
margin-left:auto;
padding:3px 10px;
border-radius:4px;
border:1px solid #cc5555;
background:transparent;
color:#cc5555;
font-size:0.7rem;
cursor:pointer;
font-family:inherit;
}

/* ============================================================
Inline editing
============================================================ */
.issue-body-card__label-row{
display:flex;
align-items:center;
gap:8px;
}

.inline-edit-btn{
background:none;
border:none;
color:var(--color-muted);
font-size:0.85rem;
cursor:pointer;
padding:2px 4px;
line-height:1;
border-radius:3px;
opacity:0;
transition:opacity 0.15s,color 0.15s;
}

.issue-body-card:hover .inline-edit-btn,
.issue-body-card__label-row:hover .inline-edit-btn,
.issue-detail__header:hover .inline-edit-btn,
.json-collapsible:hover .inline-edit-btn{
opacity:0.6;
}

.inline-edit-btn:hover{
opacity:1 !important;
color:var(--color-primary);
}

.inline-edit-btn--danger:hover{
color:#cc5555 !important;
}

.inline-edit-input{
width:100%;
background:var(--color-input-bg);
border:1px solid var(--color-border);
border-radius:4px;
padding:6px 10px;
font-size:1.1rem;
font-weight:600;
font-family:inherit;
color:var(--color-text);
box-sizing:border-box;
}

.inline-edit-textarea{
width:100%;
background:var(--color-input-bg);
border:1px solid var(--color-border);
border-radius:4px;
padding:8px 10px;
font-size:0.85rem;
font-family:inherit;
color:var(--color-text);
min-height:80px;
resize:vertical;
box-sizing:border-box;
}

.inline-edit-actions{
display:flex;
gap:6px;
margin-top:6px;
}

.inline-edit-save{
padding:4px 14px;
border-radius:4px;
border:none;
background:var(--color-primary);
color:var(--color-on-primary);
font-size:0.75rem;
font-weight:600;
cursor:pointer;
font-family:inherit;
}

.inline-edit-save:disabled{
opacity:0.5;
cursor:not-allowed;
}

.inline-edit-cancel{
padding:4px 14px;
border-radius:4px;
border:1px solid var(--color-border);
background:transparent;
color:var(--color-text);
font-size:0.75rem;
cursor:pointer;
font-family:inherit;
}

.hidden{display:none;}

.issue-body-card{
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
padding:16px;
margin-bottom:12px;
line-height:1.6;
font-size:0.9rem;
}

.issue-body-card__label{
font-size:0.7rem;
font-weight:700;
text-transform:uppercase;
color:var(--color-primary);
letter-spacing:0.5px;
margin-bottom:8px;
}

.issue-body-card__attachment{
margin-bottom:24px;
}

.issue-body-card__attachment-img{
max-width:100%;
max-height:400px;
border-radius:6px;
border:1px solid var(--color-border);
margin-top:8px;
display:block;
}

.issue-body-card__attachment-link{
display:inline-block;
margin-top:8px;
color:var(--color-accent);
text-decoration:underline;
}

.json-collapsible{
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
margin-bottom:24px;
overflow:hidden;
}

.json-collapsible__header{
padding:10px 16px;
display:flex;
align-items:center;
justify-content:space-between;
cursor:pointer;
}

.json-collapsible__body{
padding:12px 16px;
background:var(--color-background);
display:none;
font-family:'Courier New',monospace;
font-size:0.75rem;
white-space:pre-wrap;
word-break:break-all;
max-height:400px;
overflow-y:auto;
}

.json-collapsible__body.is-open{
display:block;
}

/* ============================================================
Comments
============================================================ */
.comments-section__title{
font-size:0.9rem;
color:var(--color-secondary);
margin:0 0 14px 0;
padding-bottom:8px;
border-bottom:1px solid var(--color-border);
}

.comment{
display:flex;
gap:10px;
margin-bottom:16px;
}

.comment__avatar{
width:28px;
height:28px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
font-size:0.65rem;
font-weight:700;
background:var(--color-secondary);
color:var(--color-on-primary);
flex-shrink:0;
}

.comment__body{
flex:1;
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
padding:10px 14px;
}

.comment__meta{
display:flex;
align-items:center;
gap:8px;
font-size:0.7rem;
margin-bottom:6px;
}

.comment__author{
font-weight:600;
color:var(--color-text);
}

.comment__author--admin{
color:var(--color-secondary);
}

.comment__date{
color:var(--color-muted);
}

.comment__delete{
margin-left:auto;
color:#cc5555;
cursor:pointer;
font-size:0.65rem;
background:none;
border:none;
font-family:inherit;
}

.comment__text{
font-size:0.85rem;
line-height:1.5;
color:var(--color-text);
}

.comment-form{
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
padding:14px;
}

.comment-form__textarea{
width:100%;
background:var(--color-input-bg);
border:1px solid var(--color-border);
border-radius:4px;
padding:10px;
min-height:50px;
font-size:0.85rem;
font-family:inherit;
color:var(--color-text);
resize:vertical;
margin-bottom:10px;
box-sizing:border-box;
}

.comment-form__submit{
float:right;
padding:7px 16px;
border-radius:4px;
border:none;
background:var(--color-primary);
color:var(--color-on-primary);
font-size:0.78rem;
font-weight:600;
cursor:pointer;
font-family:inherit;
}

/* ============================================================
Empty state
============================================================ */
.forum-empty{
text-align:center;
padding:60px 20px;
color:var(--color-muted);
}

.forum-empty__text{
font-size:1rem;
margin-bottom:16px;
}

/* ============================================================
Load more
============================================================ */
.load-more{
text-align:center;
padding:16px;
}

.load-more__btn{
padding:8px 24px;
border-radius:4px;
border:1px solid var(--color-border);
background:var(--color-card);
color:var(--color-text);
font-family:inherit;
font-size:0.85rem;
cursor:pointer;
}

/* ============================================================
Login dropdown
============================================================ */
.login-dropdown{
position:absolute;
top:100%;
right:0;
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
padding:8px;
display:flex;
flex-direction:column;
gap:6px;
z-index:1200;
min-width:160px;
box-shadow:0 4px 12px rgba(0,0,0,0.2);
}

.login-dropdown__btn{
padding:8px 12px;
border-radius:4px;
border:1px solid var(--color-border);
background:var(--color-card);
color:var(--color-text);
font-family:inherit;
font-size:0.8rem;
cursor:pointer;
display:flex;
align-items:center;
gap:8px;
}

.login-dropdown__btn:hover{
background:var(--color-background);
}

.login-dropdown__divider{
text-align:center;
font-size:0.75rem;
color:var(--color-text-secondary,#888);
padding:2px 0;
}

.login-dropdown__email-form{
display:flex;
flex-direction:column;
gap:6px;
}

.login-dropdown__input{
padding:7px 10px;
border-radius:4px;
border:1px solid var(--color-border);
background:var(--color-background);
color:var(--color-text);
font-family:inherit;
font-size:0.8rem;
}

.login-dropdown__submit{
padding:8px 12px;
border-radius:4px;
border:1px solid var(--color-primary,#5865F2);
background:var(--color-primary,#5865F2);
color:#fff;
font-family:inherit;
font-size:0.8rem;
cursor:pointer;
}

.login-dropdown__submit:hover{opacity:0.9;}

.login-dropdown__submit:disabled{opacity:0.5;cursor:default;}

.login-dropdown__toggle{
background:none;
border:none;
color:var(--color-primary,#5865F2);
font-family:inherit;
font-size:0.7rem;
cursor:pointer;
padding:0;
text-align:center;
}

.login-dropdown__toggle:hover{text-decoration:underline;}

.login-dropdown__msg{
font-size:0.75rem;
padding:4px 6px;
border-radius:4px;
text-align:center;
}

.login-dropdown__msg--error{
background:#fdd;
color:#c00;
}

.login-dropdown__msg--success{
background:#dfd;
color:#080;
}

/* ============================================================
Toast notifications
============================================================ */
.issue-toast{
position:fixed;
bottom:20px;
left:50%;
transform:translateX(-50%) translateY(20px);
background:var(--color-card);
color:var(--color-text);
border:1px solid var(--color-border);
border-radius:6px;
padding:10px 20px;
font-size:0.85rem;
font-family:inherit;
box-shadow:0 4px 12px rgba(0,0,0,0.3);
z-index:1300;
opacity:0;
transition:opacity 0.2s,transform 0.2s;
pointer-events:none;
}

.issue-toast.is-visible{
opacity:1;
transform:translateX(-50%) translateY(0);
pointer-events:auto;
}

.issue-toast--error{
border-color:#cc5555;
}

.issue-toast--success{
border-color:#55aa55;
}

/* ============================================================
My Monsters Modal
============================================================ */
.my-monsters-modal{
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:8px;
width:520px;
max-width:92vw;
max-height:80vh;
display:flex;
flex-direction:column;
box-shadow:0 8px 32px rgba(0,0,0,0.3);
}

.my-monsters-modal__header{
display:flex;
align-items:center;
justify-content:space-between;
padding:14px 18px 10px;
border-bottom:2px solid var(--color-primary);
}

.my-monsters-modal__header-left{
display:flex;
align-items:center;
gap:12px;
}

.my-monsters-modal__header h3{
font-size:1.05rem;
font-weight:700;
color:var(--color-primary);
margin:0;
}

.my-monsters-modal__hint{
font-size:0.75rem;
color:var(--color-muted);
font-style:italic;
margin-left:auto;
margin-right:12px;
}

.my-monsters-modal__storage{
font-size:0.7rem;
font-weight:600;
padding:2px 8px;
border-radius:10px;
background:var(--color-input-bg);
color:var(--color-muted);
}

.my-monsters-modal__storage--warn{
background:#fff3cd;
color:#856404;
}

.my-monsters-modal__storage--full{
background:#f8d7da;
color:#721c24;
animation:storage-pulse 1.5s ease-in-out infinite;
}

@keyframes storage-pulse{
0%,100%{opacity:1;}

50%{opacity:0.6;}

}

.my-monsters-modal__body{
flex:1;
overflow-y:auto;
padding:12px 18px 18px;
}

.my-monsters-modal__loading,
.my-monsters-modal__empty{
text-align:center;
color:var(--color-muted);
padding:32px 0;
font-size:0.9rem;
}

.my-monsters-card{
display:flex;
align-items:center;
gap:12px;
padding:10px 12px;
border:1px solid var(--color-border);
border-radius:6px;
margin-bottom:6px;
cursor:pointer;
transition:border-color 0.15s,background 0.15s;
}

.my-monsters-card:hover{
border-color:var(--color-primary);
background:var(--color-input-bg);
}

.my-monsters-card__avatar{
width:40px;
height:40px;
border-radius:50%;
border:1px solid var(--color-border);
overflow:hidden;
flex-shrink:0;
background:var(--color-input-bg);
display:flex;
align-items:center;
justify-content:center;
font-weight:700;
font-size:1rem;
color:var(--color-muted);
}

.my-monsters-card__avatar img{
width:100%;
height:100%;
object-fit:cover;
}

.my-monsters-card__avatar--empty{
border:1px solid var(--color-border);
}

.my-monsters-card__type-icon{
width:60%;
height:60%;
object-fit:contain;
opacity:0.9;
}

.my-monsters-card__info{
display:flex;
flex-direction:column;
gap:2px;
min-width:0;
flex:1;
}

.my-monsters-card__name{
font-weight:600;
font-size:0.9rem;
color:var(--color-text);
}

.my-monsters-card__stats{
font-size:0.75rem;
color:var(--color-muted);
}

.my-monsters-card__tag{
display:inline-block;
font-size:0.65rem;
font-weight:600;
padding:1px 6px;
border-radius:3px;
background:var(--color-primary);
color:var(--color-on-primary);
text-transform:uppercase;
letter-spacing:0.03em;
vertical-align:middle;
}

.my-monsters-card__pin{
background:none;
border:none;
color:var(--color-muted);
cursor:pointer;
padding:4px 6px;
border-radius:4px;
opacity:0.4;
transition:opacity 0.15s,color 0.15s,transform 0.15s;
flex-shrink:0;
}

.my-monsters-card__pin:hover{
opacity:0.8;
color:var(--color-primary);
}

.my-monsters-card__pin.is-pinned{
opacity:1;
color:var(--color-primary);
transform:rotate(-45deg);
}

.my-monsters-card__delete{
background:none;
border:none;
color:var(--color-muted);
font-size:1rem;
cursor:pointer;
padding:4px 8px;
border-radius:4px;
transition:color 0.15s,background 0.15s;
}

.my-monsters-card__delete:hover{
color:#c44;
background:rgba(204,68,68,0.1);
}

/* ============================================================
Loading skeleton
============================================================ */
.skeleton-card{
background:var(--color-card);
border:1px solid var(--color-border);
border-radius:6px;
padding:14px 16px;
margin-bottom:10px;
display:flex;
gap:14px;
animation:skeleton-pulse 1.2s ease-in-out infinite;
}

.skeleton-bar{
background:var(--color-border);
border-radius:4px;
height:14px;
}

.skeleton-bar--short{width:40%;}

.skeleton-bar--long{width:80%;}

.skeleton-bar--circle{width:40px;height:40px;border-radius:50%;}

@keyframes skeleton-pulse{
0%,100%{opacity:1;}

50%{opacity:0.5;}

}

/* ============================================================
Mobile
============================================================ */
@media (max-width:800px){
.forum-split{
flex-direction:column;
height:auto;
}

.forum-split__list{
width:100%;
min-width:0;
border-right:none;
border-bottom:1px solid var(--color-border);
max-height:45vh;
overflow-y:auto;
}

.forum-split__detail{
padding:16px;
}

}

@media (max-width:600px){
.report-modal{
max-width:100%;
max-height:100vh;
border-radius:0;
}

.report-overlay{
padding:0;
}

.forum-split__detail{
padding:12px;
}

#issues-list{
padding:10px 12px 0;
}

.forum-filters{
padding:8px 12px;
}

}

