/* === FORUM DETAIL — Modern Game Dev Discussion Platform === */

.fp-page{background:#070B14;color:#F5F7FA;font-family:'Inter',sans-serif;min-height:100vh}
.fp-container{max-width:1100px;margin:0 auto;padding:0 24px}

/* HERO */
.fp-hero{position:relative;padding:70px 24px 36px;overflow:hidden}
.fp-hero__bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 20%,rgba(124,92,255,.1) 0%,transparent 55%)}
.fp-hero__inner{position:relative;z-index:1;max-width:760px}
.fp-breadcrumb{display:flex;align-items:center;gap:6px;font-size:.78rem;color:#7A8599;margin-bottom:16px}
.fp-breadcrumb a{color:#7A8599;text-decoration:none!important}
.fp-breadcrumb a:hover{color:#7C5CFF}
.fp-hero__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.fp-type{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:5px;text-transform:uppercase}
.fp-type--idea{background:rgba(251,191,36,.15);color:#FBBF24}
.fp-type--question{background:rgba(239,68,68,.15);color:#F87171}
.fp-type--showcase{background:rgba(16,185,129,.15);color:#34D399}
.fp-type--job{background:rgba(99,102,241,.15);color:#818CF8}
.fp-type--review{background:rgba(236,72,153,.15);color:#F472B6}
.fp-badge{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:5px;background:rgba(124,92,255,.12);color:#B7C0D1}
.fp-badge--featured{background:rgba(251,191,36,.15);color:#FBBF24}
.fp-hero__title{font-family:'Space Grotesk',sans-serif;font-size:clamp(1.5rem,3.5vw,2.2rem);font-weight:800;line-height:1.25;margin-bottom:16px}

/* STATS BAR */
.fp-stats-bar{display:flex;gap:20px;flex-wrap:wrap;padding:14px 20px;background:rgba(17,24,39,.6);border:1px solid rgba(124,92,255,.08);border-radius:10px}
.fp-stat{display:flex;align-items:center;gap:6px;font-size:.82rem;color:#7A8599}
.fp-stat i{color:#7C5CFF}

/* LAYOUT */
.fp-layout{display:grid;grid-template-columns:1fr 280px;gap:28px;padding:32px 0}

/* MAIN */
.fp-main{min-width:0;display:flex;flex-direction:column;gap:20px}

/* AUTHOR CARD */
.fp-author-card{display:flex;align-items:center;gap:12px}
.fp-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#7C5CFF,#00D1FF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}
.fp-author__name{display:block;font-size:.88rem;font-weight:600;color:#F5F7FA}
.fp-author__time{font-size:.75rem;color:#7A8599}

/* TAGS */
.fp-tags{display:flex;gap:6px;flex-wrap:wrap}
.fp-tag{padding:4px 10px;border-radius:5px;font-size:.75rem;font-weight:500;text-decoration:none!important;background:rgba(124,92,255,.08);border:1px solid rgba(124,92,255,.15);color:#B7C0D1;transition:all .2s}
.fp-tag:hover{border-color:#7C5CFF;color:#F5F7FA}

/* CONTENT */
.fp-content{font-size:1rem;line-height:1.8;color:#D1D5DB;padding:24px;background:rgba(17,24,39,.4);border:1px solid rgba(124,92,255,.06);border-radius:12px;word-break:break-word}
.fp-content a{color:#7C5CFF}

/* POLL */
.fp-poll{background:rgba(17,24,39,.6);border:1px solid rgba(124,92,255,.1);border-radius:12px;padding:18px}
.fp-poll h4{margin:0 0 14px;font-size:1rem;color:#F5F7FA}
.fp-poll__opt{margin-bottom:10px}
.fp-poll__result{display:flex;justify-content:space-between;font-size:.85rem;color:#B7C0D1;margin-bottom:4px}
.fp-poll__bar{height:6px;background:rgba(124,92,255,.1);border-radius:3px;overflow:hidden}
.fp-poll__bar div{height:100%;background:#7C5CFF;border-radius:3px}
.fp-poll__btn{width:100%;text-align:left;padding:10px 14px;border:1px solid rgba(124,92,255,.15);border-radius:8px;background:rgba(17,24,39,.4);color:#D1D5DB;cursor:pointer;font-size:.88rem;transition:all .2s}
.fp-poll__btn:hover{border-color:#7C5CFF;background:rgba(124,92,255,.05)}
.fp-poll__info{font-size:.78rem;color:#7A8599;margin-top:10px}

/* REACTIONS */
.fp-reactions{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-top:1px solid rgba(124,92,255,.06);border-bottom:1px solid rgba(124,92,255,.06)}
.fp-reactions__btns{display:flex;gap:6px}
.fp-react{width:38px;height:38px;border-radius:8px;border:1px solid rgba(124,92,255,.1);background:rgba(17,24,39,.6);font-size:1.1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}
.fp-react:hover{border-color:#7C5CFF;transform:scale(1.15);background:rgba(124,92,255,.1)}
.fp-reactions__actions{display:flex;gap:8px}
.fp-action-btn{background:rgba(17,24,39,.6);border:1px solid rgba(124,92,255,.1);padding:6px 14px;border-radius:6px;color:#7A8599;font-size:.8rem;cursor:pointer;display:flex;align-items:center;gap:5px;transition:all .2s}
.fp-action-btn:hover{border-color:#7C5CFF;color:#F5F7FA}
.fp-action-btn.active{border-color:#FBBF24;color:#FBBF24;background:rgba(251,191,36,.05)}

/* COMMENTS */
.fp-comments{background:rgba(17,24,39,.3);border:1px solid rgba(124,92,255,.06);border-radius:12px;padding:24px}
.fp-comments__title{font-size:1.1rem;font-weight:700;margin:0 0 20px;color:#F5F7FA}
.fp-comments__list{display:flex;flex-direction:column;gap:14px}

/* COMMENT FORM */
.fp-comment-form{display:flex;gap:12px;align-items:flex-start;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(124,92,255,.06)}
.fp-comment-form__body{flex:1}
.fp-textarea{width:100%;padding:12px;background:rgba(17,24,39,.6);border:1px solid rgba(124,92,255,.1);border-radius:8px;color:#F5F7FA;font-size:.9rem;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}
.fp-textarea:focus{outline:none;border-color:#7C5CFF}
.fp-textarea::placeholder{color:#7A8599}
.fp-comment-form__footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.fp-comment-form__footer small{color:#7A8599;font-size:.78rem}

/* BUTTONS */
.fp-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:8px;font-weight:600;font-size:.85rem;text-decoration:none!important;transition:all .3s;border:none;cursor:pointer}
.fp-btn--primary{background:linear-gradient(135deg,#7C5CFF,#6B4FE0);color:#fff!important;box-shadow:0 4px 12px rgba(124,92,255,.25)}
.fp-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(124,92,255,.35)}
.fp-btn--sm{padding:8px 14px;font-size:.82rem}

/* LOGIN PROMPT */
.fp-login-prompt{text-align:center;padding:20px;background:rgba(17,24,39,.6);border:1px dashed rgba(124,92,255,.15);border-radius:10px;margin-bottom:20px}
.fp-login-prompt p{margin:0;color:#7A8599;font-size:.9rem}
.fp-login-prompt a{color:#7C5CFF;font-weight:600;text-decoration:none!important}
.fp-login-prompt a:hover{color:#00D1FF}

/* COMMENT CARD */
.fp-cmt{padding:14px 16px;background:rgba(17,24,39,.4);border:1px solid rgba(124,92,255,.06);border-radius:10px;transition:border-color .2s}
.fp-cmt:hover{border-color:rgba(124,92,255,.15)}
.fp-cmt-best{border-left:3px solid #34D399;background:rgba(16,185,129,.03)}
.fp-cmt-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.fp-cmt-author{display:flex;align-items:center;gap:8px}
.fp-cmt-name{font-weight:600;font-size:.85rem;color:#F5F7FA}
.fp-cmt-time{font-size:.72rem;color:#7A8599}
.fp-cmt-body{font-size:.9rem;line-height:1.65;color:#D1D5DB;margin:0}
.fp-cmt-footer{display:flex;gap:12px;margin-top:8px}
.fp-cmt-action{background:none;border:none;color:#7A8599;font-size:.78rem;cursor:pointer;padding:2px 0;display:flex;align-items:center;gap:4px;transition:color .2s}
.fp-cmt-action:hover{color:#7C5CFF}
.fp-best-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(16,185,129,.15);color:#34D399;font-size:.68rem;padding:2px 8px;border-radius:4px;font-weight:600}
.fp-cmt-replies{margin-top:10px;padding-left:20px;border-left:2px solid rgba(124,92,255,.08);display:flex;flex-direction:column;gap:10px}

/* REPLY FORM */
.fp-reply-form{margin-top:10px;padding:12px;background:rgba(17,24,39,.6);border-radius:8px;border:1px solid rgba(124,92,255,.08);display:none}
.fp-reply-form.show{display:block}
.fp-reply-textarea{width:100%;padding:8px;background:rgba(7,11,20,.6);border:1px solid rgba(124,92,255,.1);border-radius:6px;color:#F5F7FA;font-size:.85rem;font-family:inherit;resize:vertical;min-height:60px}
.fp-reply-textarea:focus{outline:none;border-color:#7C5CFF}
.fp-reply-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
.fp-btn-cancel{background:rgba(124,92,255,.08);border:none;padding:6px 12px;border-radius:6px;color:#7A8599;font-size:.8rem;cursor:pointer}
.fp-btn-cancel:hover{color:#F5F7FA}

/* EMPTY */
.fp-empty{text-align:center;padding:32px;color:#7A8599;font-size:.9rem}

/* SIDEBAR */
.fp-sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:16px}
.fp-widget{background:rgba(17,24,39,.6);border:1px solid rgba(124,92,255,.08);border-radius:12px;padding:18px}
.fp-widget--cta{background:radial-gradient(ellipse at 50% 100%,rgba(124,92,255,.06) 0%,rgba(17,24,39,.6) 100%)}
.fp-widget__title{font-size:.88rem;font-weight:700;margin-bottom:12px;color:#F5F7FA}
.fp-widget p{font-size:.82rem;color:#7A8599;margin:0 0 12px;line-height:1.5}
.fp-related-item{display:block;padding:8px 0;border-bottom:1px solid rgba(124,92,255,.05);text-decoration:none!important;transition:opacity .2s}
.fp-related-item:last-child{border-bottom:none}
.fp-related-item:hover{opacity:.8}
.fp-related-item__title{display:block;font-size:.82rem;font-weight:500;color:#F5F7FA;line-height:1.3;margin-bottom:2px}
.fp-related-item__meta{font-size:.72rem;color:#7A8599}
.fp-back-link{font-size:.85rem;color:#7C5CFF;text-decoration:none!important}
.fp-back-link:hover{color:#00D1FF}

/* RESPONSIVE */
@media(max-width:1024px){
    .fp-layout{grid-template-columns:1fr}
    .fp-sidebar{position:static;display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
}
@media(max-width:768px){
    .fp-hero{padding:50px 20px 24px}
    .fp-hero__title{font-size:1.4rem}
    .fp-stats-bar{flex-direction:column;gap:8px;padding:12px 16px}
    .fp-layout{padding:20px 0}
    .fp-sidebar{grid-template-columns:1fr}
    .fp-reactions{flex-direction:column;gap:12px;align-items:flex-start}
    .fp-comment-form{flex-direction:column}
    .fp-comment-form__footer{flex-direction:column;gap:8px;align-items:stretch}
    .fp-cmt-replies{padding-left:12px}
}

/* COMPAT: fm-avatar used in comment partial */
.fp-page .fm-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#7C5CFF,#00D1FF);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.7rem;flex-shrink:0}
.fp-page .fm-btn-create{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:6px;font-weight:600;font-size:.82rem;background:linear-gradient(135deg,#7C5CFF,#6B4FE0);color:#fff;border:none;cursor:pointer;transition:opacity .2s}
.fp-page .fm-btn-create:hover{opacity:.85}
.fp-pin-btn{background:none;border:1px dashed rgba(124,92,255,.2);padding:4px 10px;border-radius:5px;color:#7A8599;font-size:.75rem;cursor:pointer;transition:all .2s}
.fp-pin-btn:hover{border-color:#34D399;color:#34D399}
.fp-pin-btn.pinned{border-style:solid;border-color:#34D399;color:#34D399;background:rgba(16,185,129,.05)}
.fp-cmt-badge{font-size:.7rem;padding:1px 6px;border-radius:4px;background:rgba(124,92,255,.1);color:#B7C0D1}

/* REACTION COUNTS */
.fp-react__count{font-size:.72rem;color:#B7C0D1!important;margin-left:2px}
.fp-react.active{border-color:#7C5CFF;background:rgba(124,92,255,.15)}
.fp-react.active .fp-react__count{color:#F5F7FA!important}
