/* ── Salon Circles ──────────────────────────────────────── */

.circles-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(240px,1fr)); gap: 1rem; }
.circle-card { border: 1px solid var(--border,#ddd); border-radius: 8px;
    padding: 1.1rem 1.3rem; text-decoration: none; color: inherit; display: block; }
.circle-card--mine { border-left: 3px solid var(--accent,#e94560); }
.circle-card-top { display: flex; justify-content: space-between; align-items: flex-start;
    margin-bottom: .4rem; }
.circle-name { font-size: 1.05rem; font-weight: 600; margin: 0; }
.circle-desc { font-size: .87rem; opacity: .65; margin: .3rem 0 .5rem; }
.circle-owner { font-size: .8rem; opacity: .55; margin: 0; }
.circle-meta { font-size: .78rem; opacity: .5; }
.circle-role-badge { font-size: .72rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: .05em; padding: .12rem .45rem; border-radius: 4px; }
.circle-role--owner { background: var(--accent,#e94560); color: #fff; }
.circle-role--admin { background: #8e44ad; color: #fff; }
.circle-role--member { background: var(--hover-bg,#eee); color: #555; }

.circle-detail-page { max-width: 1200px; margin: 0 auto; padding: 1.5rem 1rem; }
.circle-header { margin-bottom: 1.5rem; padding-bottom: 1rem;
    border-bottom: 1px solid var(--border,#ddd); }
.circle-detail-name { font-size: 1.9rem; font-weight: 700; margin-bottom: .3rem; }
.circle-detail-desc { opacity: .7; margin-bottom: .4rem; }
.circle-detail-meta { font-size: .88rem; opacity: .6; margin-bottom: .5rem; }
.circle-layout { display: grid; grid-template-columns: 1fr 320px; gap: 1.5rem; }
@media (max-width: 860px) { .circle-layout { grid-template-columns: 1fr; } }
/* circle-feed-col */
.circle-sidebar { display: flex; flex-direction: column; gap: 1rem; }
.circle-post-form-card, .circle-members-card, .circle-chat-card {
    border: 1px solid var(--border,#ddd); border-radius: 8px; padding: 1rem 1.1rem;
}
.card-subheading { font-size: .95rem; font-weight: 700; margin: 0 0 .7rem; }
.circle-posts { margin-top: 1rem; display: flex; flex-direction: column; gap: .8rem; }
.circle-post { border: 1px solid var(--border,#ddd); border-radius: 8px;
    padding: .9rem 1.1rem; }
.circle-post--pinned { border-left: 3px solid #f1c40f; }
.pin-badge { font-size: .75rem; font-weight: 700; color: #f1c40f; margin-bottom: .4rem;
    display: block; }
.post-header { display: flex; align-items: center; gap: .7rem; margin-bottom: .5rem;
    flex-wrap: wrap; }
.post-author { font-weight: 600; font-size: .88rem; text-decoration: none; color: inherit; }
.post-date { font-size: .78rem; opacity: .5; }
.post-body { font-size: .93rem; line-height: 1.6; margin: 0 0 .5rem; }
.post-poem-preview { background: var(--hover-bg,#f5f5f5); border-radius: 5px;
    padding: .7rem .9rem; margin-top: .4rem; }
.post-poem-link { font-size: .9rem; text-decoration: none; color: inherit; display: block; }
.post-poem-author { font-size: .8rem; opacity: .6; margin-left: .4rem; }
.post-poem-excerpt { font-size: .83rem; opacity: .65; margin: .3rem 0 0;
    font-style: italic; }
.invite-form { display: flex; gap: .4rem; margin-bottom: .8rem; }
.invite-form input { flex: 1; padding: .4rem .6rem; font-size: .87rem;
    border: 1px solid var(--border,#ddd); border-radius: 4px;
    background: var(--bg,#fff); color: inherit; }
.members-list { list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: .4rem; }
.member-item { display: flex; justify-content: space-between; align-items: center;
    font-size: .88rem; }
.member-name { text-decoration: none; color: inherit; }
.circle-chat-messages { height: 260px; overflow-y: auto; display: flex;
    flex-direction: column; gap: .4rem; padding: .4rem; margin-bottom: .7rem;
    border: 1px solid var(--border,#ddd); border-radius: 5px; }
.circle-chat-msg { font-size: .85rem; }
.circle-chat-author { font-weight: 600; margin-right: .35rem; }
.circle-chat-time { font-size: .72rem; opacity: .45; margin-left: .3rem; }
.circle-chat-msg--mine .circle-chat-author { color: var(--accent,#e94560); }
.circle-chat-form { display: flex; gap: .4rem; }
.circle-chat-form input { flex: 1; padding: .4rem .6rem; font-size: .87rem;
    border: 1px solid var(--border,#ddd); border-radius: 4px;
    background: var(--bg,#fff); color: inherit; }

.leave-circle-form {
    background: transparent;
    border: 0;
    padding: 0;
    margin: 0;
    display: inline; 
}


/* ── Circle Post Poem Search ────────────────────────────── */
.poem-link-group {
    position: relative;
}

.poem-search-input {
    width: 100%;
    padding: .6rem .8rem;
    border: 1px solid var(--border,#ddd);
    border-radius: 5px;
    font-family: inherit;
    font-size: .95rem;
    background: var(--bg,#fff);
    color: inherit;
    box-sizing: border-box;
}

.poem-search-results {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    right: 0;
    background: var(--bg,#fff);
    border: 1px solid var(--border,#ddd);
    border-radius: 6px;
    box-shadow: 0 8px 20px rgba(0,0,0,.08);
    z-index: 40;
    max-height: 220px;
    overflow-y: auto;
}

.poem-search-results.hidden {
    display: none;
}

.poem-result-item {
    padding: .7rem .85rem;
    cursor: pointer;
    border-bottom: 1px solid var(--border,#eee);
    transition: background .15s;
}

.poem-result-item:last-child {
    border-bottom: none;
}

.poem-result-item:hover {
    background: var(--hover-bg,#f5f5f5);
}

.poem-result-title {
    font-size: .9rem;
    font-weight: 600;
    margin: 0;
}

.poem-result-author {
    font-size: .8rem;
    opacity: .6;
    margin-top: .15rem;
}

.selected-poem-preview {
    margin-top: .6rem;
    background: var(--hover-bg,#f5f5f5);
    border: 1px solid var(--border,#ddd);
    border-radius: 6px;
    padding: .7rem .9rem;
}

.selected-poem-preview.hidden {
    display: none;
}

.selected-poem-title {
    font-size: .9rem;
    font-weight: 600;
    margin: 0;
}

.selected-poem-meta {
    font-size: .8rem;
    opacity: .6;
    margin-top: .2rem;
}

.selected-poem-clear {
    background: none;
    border: none;
    padding: 0;
    margin-top: .4rem;
    font-size: .8rem;
    cursor: pointer;
    opacity: .7;
    color: inherit;
}

.selected-poem-clear:hover {
    opacity: 1;
}