/* ── Character Map ─────────────────────────────────────────── */

.character-map-wrap { margin: 0 0 2rem; }

/* Role filter tabs */
.char-filter-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1.5rem;
}
.char-filter-tab {
    padding: .3rem .85rem;
    border-radius: 20px;
    border: 1.5px solid #dee2e6;
    background: #fff;
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    color: #555;
    transition: all .18s;
    user-select: none;
}
.char-filter-tab.active,
.char-filter-tab:hover {
    background: var(--primary-color, #1a73e8);
    border-color: var(--primary-color, #1a73e8);
    color: #fff;
}
.char-filter-tab .tab-count {
    opacity: .75;
    font-size: .72rem;
    margin-left: .3rem;
}

/* Grid */
.character-map-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.25rem;
}

/* Card */
.char-card {
    background: #fff;
    border-radius: 14px;
    border: 1.5px solid #e8ecf0;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow .2s, transform .2s;
}
.char-card:hover {
    box-shadow: 0 6px 20px rgba(0,0,0,.1);
    transform: translateY(-2px);
}
.char-card[data-role="protagonist"] { --card-color: #1a73e8; --card-bg: #e8f0fe; }
.char-card[data-role="antagonist"]  { --card-color: #d93025; --card-bg: #fce8e6; }
.char-card[data-role="supporting"]  { --card-color: #1a8f3c; --card-bg: #e6f4ea; }
.char-card[data-role="minor"]       { --card-color: #666;    --card-bg: #f1f3f4; }
.char-card[data-role="narrator"]    { --card-color: #7b2d8b; --card-bg: #f3e8f9; }
.char-card[data-role="symbolic"]    { --card-color: #e37400; --card-bg: #fef3e2; }

/* Coloured top bar */
.char-card-bar {
    height: 5px;
    background: var(--card-color, #999);
}

/* Card body */
.char-card-body { padding: 1.1rem 1.1rem .9rem; flex: 1; }

/* Avatar */
.char-avatar-wrap { display: flex; align-items: center; gap: .85rem; margin-bottom: .75rem; }
.char-avatar {
    width: 50px; height: 50px;
    border-radius: 50%;
    background: var(--card-bg, #f1f3f4);
    border: 2px solid var(--card-color, #999);
    overflow: hidden;
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}
.char-avatar img  { width: 100%; height: 100%; object-fit: cover; }
.char-avatar-init {
    font-size: 1.1rem; font-weight: 700;
    color: var(--card-color, #555);
}

/* Name + role badge */
.char-name {
    font-size: 1rem; font-weight: 700;
    color: #1a1a2e; line-height: 1.25;
    margin: 0 0 .2rem;
}
.char-role-badge {
    display: inline-block;
    padding: .15rem .55rem;
    border-radius: 10px;
    font-size: .72rem; font-weight: 600;
    background: var(--card-bg, #f1f3f4);
    color: var(--card-color, #555);
    border: 1px solid var(--card-color, #ccc);
}

/* Aliases */
.char-aliases {
    font-size: .78rem; color: #777;
    margin: .3rem 0 .6rem;
    font-style: italic;
}

/* Traits */
.char-traits { display: flex; flex-wrap: wrap; gap: .3rem; margin-bottom: .75rem; }
.char-trait {
    padding: .18rem .55rem;
    border-radius: 10px;
    font-size: .72rem; font-weight: 500;
    background: #f5f6f8; color: #444;
    border: 1px solid #e0e3e8;
}

/* Description */
.char-desc {
    font-size: .83rem; color: #444; line-height: 1.55;
    margin-bottom: .6rem;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.char-desc.expanded { -webkit-line-clamp: unset; overflow: visible; }
.char-desc-toggle {
    font-size: .75rem; color: var(--primary-color, #1a73e8);
    cursor: pointer; font-weight: 600;
    background: none; border: none; padding: 0;
    display: inline;
}

/* Relationships */
.char-relations { margin-top: .5rem; border-top: 1px solid #f0f2f5; padding-top: .6rem; }
.char-relation-item {
    font-size: .78rem; color: #555;
    display: flex; align-items: center; gap: .3rem;
    margin-bottom: .25rem;
}
.char-relation-icon { font-size: .85rem; flex-shrink: 0; }
.char-relation-label { color: #888; }
.char-relation-name  { font-weight: 600; color: #333; }

/* Empty state */
.char-map-empty {
    text-align: center; padding: 3rem 1rem;
    color: #999; font-size: .9rem;
}

/* Responsive */
@media (max-width: 576px) {
    .character-map-grid { grid-template-columns: 1fr 1fr; gap: .75rem; }
    .char-card-body { padding: .85rem .85rem .7rem; }
    .char-name { font-size: .9rem; }
}
@media (max-width: 380px) {
    .character-map-grid { grid-template-columns: 1fr; }
}

/* ── View toggle ────────────────────────────────────────────────── */
.char-view-toggle {
    display: flex;
    gap: .4rem;
    margin-bottom: 1.25rem;
}
.char-view-btn {
    padding: .35rem 1rem;
    border-radius: 20px;
    border: 1.5px solid #dee2e6;
    background: #fff;
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    color: #555;
    transition: all .18s;
    user-select: none;
}
.char-view-btn.active,
.char-view-btn:hover {
    background: var(--primary-color, #1a73e8);
    border-color: var(--primary-color, #1a73e8);
    color: #fff;
}

/* ── Graph container ────────────────────────────────────────────── */
.char-graph-wrap {
    border: 1.5px solid #e8ecf0;
    border-radius: 14px;
    overflow: hidden;
    background: #fafbfc;
}
.char-graph-legend {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem .9rem;
    padding: .7rem 1.1rem;
    border-bottom: 1px solid #e8ecf0;
    background: #fff;
    font-size: .78rem;
}
.char-legend-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.char-legend-label { color: #444; font-weight: 500; }

.char-network-canvas {
    height: 520px;
    width: 100%;
}
.char-graph-hint {
    text-align: center;
    font-size: .73rem;
    color: #aaa;
    padding: .5rem 1rem .65rem;
    margin: 0;
    background: #fff;
    border-top: 1px solid #f0f2f5;
}

@media (max-width: 576px) {
    .char-network-canvas { height: 380px; }
}

/* ── Bubble map ─────────────────────────────────────────────────── */
.char-bubble-wrap {
    border: 1.5px solid #e8ecf0;
    border-radius: 14px;
    overflow: hidden;
    background: #f8f9fb;
}
.char-bubble-legend {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: .5rem .9rem;
    padding: .7rem 1.1rem;
    border-bottom: 1px solid #e8ecf0;
    background: #fff;
    font-size: .78rem;
}
.char-bubble-canvas-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.char-bubble-canvas-wrap svg {
    display: block;
    min-width: 720px;
    width: 100%;
}

/* ── Share button ───────────────────────────────────────────────── */
.char-share-btn {
    padding: .35rem 1rem;
    border-radius: 20px;
    border: none;
    background: linear-gradient(135deg, #17b9c8 0%, #0e9aaa 100%);
    font-size: .82rem;
    font-weight: 700;
    cursor: pointer;
    color: #fff;
    transition: all .18s;
    user-select: none;
    display: inline-flex;
    align-items: center;
    box-shadow: 0 2px 8px rgba(23,185,200,0.30);
    letter-spacing: .01em;
}
.char-share-btn:hover {
    background: linear-gradient(135deg, #14a8b6 0%, #0c8a9a 100%);
    box-shadow: 0 3px 12px rgba(23,185,200,0.42);
    transform: translateY(-1px);
    color: #fff;
}
.char-share-btn:disabled {
    opacity: .7;
    cursor: not-allowed;
    transform: none;
}
@media (max-width: 480px) {
    .char-share-label { display: none; }
    .char-share-btn { padding: .35rem .7rem; }
}
