/* === Panels & Overlays === */

/* === CK3-style Clan Overview Panel (Left) === */
#clan-panel {
    width: 320px;
    min-width: 320px;
    background: linear-gradient(180deg, #1e1e16 0%, #1a1a12 100%);
    border-right: 2px solid #3a3a28;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    z-index: 60;
    position: relative;
}

#clan-panel.hidden {
    display: none;
}

#clan-panel-header {
    display: flex;
    justify-content: flex-end;
    padding: 4px 8px;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
}

#clan-panel-content {
    display: flex;
    flex-direction: column;
}

/* Portrait Area - CK3 style large portrait */
#clan-portrait-area {
    position: relative;
    background: linear-gradient(180deg, #2a2a1c 0%, #1a1a12 100%);
    border-bottom: 2px solid #3a3a28;
    padding: 16px;
    display: flex;
    align-items: flex-end;
    gap: 14px;
    min-height: 140px;
}

.ck3-leader-portrait {
    position: relative;
    flex-shrink: 0;
}

.ck3-leader-portrait .roblox-avatar,
.ck3-leader-portrait .ck3-avatar {
    width: 100px;
    height: 100px;
    border-radius: 6px;
    border: 3px solid var(--accent-gold);
    object-fit: cover;
    background: var(--bg-card);
}

.ck3-spouse-portrait {
    position: absolute;
    bottom: -6px;
    right: -16px;
}

.ck3-spouse-portrait .roblox-avatar,
.ck3-spouse-portrait .ck3-avatar {
    width: 48px;
    height: 48px;
    border-radius: 4px;
    border: 2px solid #ff77aa;
    object-fit: cover;
    background: var(--bg-card);
}

.ck3-spouse-label {
    font-size: 8px;
    color: #ff77aa;
    text-align: center;
    display: block;
    margin-top: 1px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ck3-leader-details {
    flex: 1;
    padding-bottom: 4px;
}

.ck3-leader-name {
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
    margin-bottom: 2px;
}

.ck3-clan-name {
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 4px;
}

.ck3-leader-title {
    font-size: 11px;
    color: var(--text-muted);
    font-style: italic;
}

.ck3-capital-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    color: var(--text-secondary);
    background: rgba(200, 168, 78, 0.1);
    padding: 2px 8px;
    border-radius: 3px;
    margin-top: 4px;
    border: 1px solid rgba(200, 168, 78, 0.2);
}

/* Info Bar - Province count, territory name */
#clan-info-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 16px;
    background: var(--bg-card);
    border-bottom: 1px solid #3a3a28;
    font-size: 11px;
}

.ck3-realm-info {
    display: flex;
    align-items: center;
    gap: 12px;
}

.ck3-realm-stat {
    display: flex;
    align-items: center;
    gap: 4px;
    color: var(--text-secondary);
}

.ck3-realm-stat .stat-icon {
    font-size: 13px;
}

.ck3-realm-stat .stat-val {
    font-weight: 700;
    color: var(--text-primary);
}

/* Stats Bar - CK3 resource bar style */
#clan-stats-bar {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: #3a3a28;
    border-bottom: 2px solid #3a3a28;
}

.ck3-stat-cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 8px 4px;
    background: var(--bg-secondary);
}

.ck3-stat-icon {
    font-size: 16px;
    margin-bottom: 2px;
}

.ck3-stat-value {
    font-size: 15px;
    font-weight: 700;
    color: var(--accent-gold);
}

.ck3-stat-label {
    font-size: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-muted);
}

/* Family Grid - CK3 style portraits */
#clan-family-grid {
    padding: 10px 16px;
    border-bottom: 1px solid #3a3a28;
}

.ck3-family-header {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted);
    margin-bottom: 8px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--border);
}

.ck3-family-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.ck3-family-member {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
    cursor: default;
    position: relative;
}

.ck3-family-member .ck3-avatar {
    width: 48px;
    height: 48px;
    border-radius: 4px;
    border: 2px solid var(--border);
    object-fit: cover;
    background: var(--bg-card);
    transition: border-color 0.15s;
}

.ck3-family-member.married .ck3-avatar {
    border-color: #ff77aa;
}

.ck3-family-member .ck3-member-name {
    font-size: 9px;
    color: var(--text-secondary);
    max-width: 52px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: center;
}

.ck3-family-member .ck3-gender {
    position: absolute;
    top: -2px;
    right: -2px;
    font-size: 9px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-primary);
    border: 1px solid var(--border);
}

.ck3-gender.male { color: #5599ff; }
.ck3-gender.female { color: #ff77aa; }

.ck3-family-member .ck3-married-badge {
    font-size: 8px;
    color: #ff77aa;
}

/* Family sections */
.ck3-family-section {
    margin-bottom: 8px;
}

.ck3-family-section:last-child {
    margin-bottom: 0;
}

.ck3-family-member {
    cursor: pointer;
}

.ck3-family-member:hover .ck3-avatar {
    border-color: var(--accent-gold) !important;
}

.ck3-family-member.daimyo .ck3-avatar {
    border-color: var(--accent-gold);
}

/* Member Detail Popup */
#member-popup {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(180deg, #2a2a1c, #1e1e14);
    border-top: 2px solid var(--accent-gold);
    padding: 12px 16px;
    z-index: 10;
    box-shadow: 0 -4px 16px rgba(0,0,0,0.5);
}

#member-popup.hidden {
    display: none;
}

.popup-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.popup-info {
    flex: 1;
}

.popup-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--text-primary);
}

.popup-role {
    font-size: 11px;
    font-weight: 500;
}

.popup-status-text {
    font-size: 10px;
    color: var(--text-muted);
}

.popup-spouse {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    background: var(--bg-card);
    border-radius: 4px;
    margin-bottom: 8px;
}

.popup-spouse-name {
    font-size: 12px;
    font-weight: 500;
    color: var(--text-primary);
}

.popup-spouse-clan {
    font-size: 10px;
}

.popup-action {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 6px;
}

.popup-action label {
    font-size: 10px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.popup-action select {
    padding: 5px 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
    font-family: inherit;
    font-size: 11px;
}

.popup-action .small-btn {
    padding: 6px 12px;
    font-size: 11px;
}

.popup-status {
    font-size: 10px;
    color: var(--text-muted);
    font-style: italic;
    margin-top: 4px;
}

/* Alliances bar */
#clan-alliances-bar {
    padding: 10px 16px;
}

.ck3-dissolve {
    font-size: 14px;
    color: var(--text-muted);
    cursor: pointer;
    margin-left: auto;
    padding: 0 2px;
    line-height: 1;
}

.ck3-dissolve:hover {
    color: var(--accent-red);
}

.ck3-alliance-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 6px;
}

.ck3-alliance-chip {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px 4px 4px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 11px;
    border: 1px solid var(--border);
    cursor: pointer;
    transition: border-color 0.15s;
}

.ck3-alliance-chip:hover {
    border-color: var(--accent-gold);
}

.ck3-alliance-chip .ck3-ally-avatar {
    width: 24px;
    height: 24px;
    border-radius: 3px;
    border: 1px solid var(--border);
}

.ck3-alliance-chip .ck3-ally-name {
    color: var(--text-secondary);
    font-weight: 500;
}

/* Proposals bar */
#clan-proposals-bar {
    padding: 0 16px 10px;
}

.ck3-proposal-card {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    background: var(--bg-card);
    border-radius: 4px;
    margin-bottom: 4px;
    font-size: 11px;
}

.ck3-proposal-card.incoming {
    border-left: 3px solid var(--accent-gold);
}

.ck3-proposal-card.sent {
    opacity: 0.7;
    border-left: 3px solid var(--border);
}

.ck3-proposal-people {
    display: flex;
    align-items: center;
    gap: 3px;
    flex-shrink: 0;
}

.ck3-proposal-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.ck3-proposal-info span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ck3-proposal-from {
    font-size: 9px;
}

.ck3-proposal-actions {
    display: flex;
    gap: 3px;
    flex-shrink: 0;
}

/* === Side Panel (Province Details) === */
#side-panel {
    width: 320px;
    background: var(--bg-panel);
    border-left: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    transition: transform 0.3s ease;
    z-index: 60;
}

#side-panel.hidden {
    display: none;
}

#panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-secondary);
}

#panel-header h2 {
    font-size: 16px;
    color: var(--accent-gold);
}

.panel-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 20px;
    cursor: pointer;
    padding: 2px 6px;
}

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

#panel-content {
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.panel-section {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.panel-section h3 {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted);
    border-bottom: 1px solid var(--border);
    padding-bottom: 4px;
}

.panel-section .label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
}

/* Army entries */
.army-entry {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 10px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 12px;
}

.army-clan { font-weight: 600; }
.army-count { color: var(--text-secondary); }

/* Battle troops header */
.battle-troops-header {
    font-size: 11px;
    color: var(--accent-red);
    font-weight: bold;
    padding: 6px 0 2px;
    border-top: 1px solid var(--border);
    margin-top: 4px;
}

.army-entry.in-battle {
    opacity: 0.7;
    background: rgba(231, 76, 60, 0.08);
}

.battle-side-tag {
    font-size: 9px;
    padding: 1px 4px;
    border-radius: 3px;
    font-weight: bold;
    letter-spacing: 0.5px;
}

.battle-side-tag.attacker {
    background: rgba(231, 76, 60, 0.2);
    color: #e74c3c;
}

.battle-side-tag.defender {
    background: rgba(52, 152, 219, 0.2);
    color: #3498db;
}

.army-entry.retreating {
    opacity: 0.6;
    border-style: dashed !important;
}

.battle-side-tag.retreating {
    background: rgba(240, 160, 40, 0.2);
    color: #f0a028;
}

/* Neighbor entries */
.neighbor-entry {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4px 8px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 11px;
    cursor: pointer;
    transition: background 0.15s;
}

.neighbor-entry:hover {
    background: var(--border);
}

.terrain-badge {
    font-size: 13px;
}

/* Action buttons */
.action-btn {
    width: 100%;
    padding: 8px 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
    cursor: pointer;
    font-family: inherit;
    font-size: 12px;
    transition: all 0.15s;
    text-align: center;
}

.action-btn:hover {
    background: var(--border);
    border-color: var(--accent-gold);
}

.action-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.action-btn.raise-levy { border-color: var(--accent-green); }
.action-btn.move-army { border-color: var(--accent-blue); }
.action-btn.gift { border-color: #aa44cc; }

.small-btn {
    padding: 3px 8px;
    font-size: 10px;
    border: 1px solid var(--border);
    background: var(--bg-card);
    color: var(--text-primary);
    border-radius: 3px;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s;
}

.small-btn:hover { background: var(--border); }
.small-btn.commit { border-color: var(--accent-green); color: var(--accent-green); }
.small-btn.cancel { border-color: var(--accent-red); color: var(--accent-red); }
.small-btn.uncommit { border-color: #ff9900; color: #ff9900; }
.small-btn.danger { border-color: var(--accent-red); color: var(--accent-red); }
.small-btn.spawn-btn { border-color: var(--accent-green); color: var(--accent-green); flex: 1; }
.small-btn.spawn-btn:disabled { border-color: #555; color: #555; cursor: not-allowed; }
.clan-color-input { width: 28px; height: 24px; padding: 0; border: 1px solid var(--border); cursor: pointer; background: none; }
.clan-jpname-input { background: var(--bg-dark); color: var(--text); border: 1px solid var(--border); padding: 2px 4px; font-size: 11px; }
.imperial-label { font-size: 11px; color: #d4af37; display: flex; align-items: center; gap: 4px; cursor: pointer; }
.imperial-check { accent-color: #d4af37; }

/* Order entries */
.orders-section {
    margin-top: 8px;
}

.orders-section h4 {
    font-size: 11px;
    color: var(--text-muted);
    margin-bottom: 6px;
}

.order-entry {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    padding: 6px 8px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 11px;
    margin-bottom: 4px;
}

.order-info { flex: 1; }

.order-status {
    padding: 1px 6px;
    border-radius: 8px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
}

.order-status.pending {
    background: rgba(240, 192, 64, 0.2);
    color: #f0c040;
}

.order-status.committed {
    background: rgba(64, 192, 96, 0.2);
    color: #40c060;
}

.order-actions {
    display: flex;
    gap: 4px;
    width: 100%;
}

/* === Overlay Panels (Dashboard, History, Admin) === */
.overlay-panel {
    position: absolute;
    top: 0;
    right: 0;
    width: 420px;
    height: 100%;
    background: var(--bg-panel);
    border-left: 1px solid var(--border);
    z-index: 80;
    display: flex;
    flex-direction: column;
    box-shadow: -4px 0 20px var(--shadow);
    transition: transform 0.3s ease;
}

.overlay-panel.hidden {
    display: none;
}

.overlay-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-secondary);
}

.overlay-header h2 {
    font-size: 16px;
    color: var(--accent-gold);
}

.overlay-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 22px;
    cursor: pointer;
}

.overlay-close:hover { color: var(--text-primary); }

.overlay-content {
    padding: 16px;
    overflow-y: auto;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* === Dashboard === */
.dash-header {
    padding: 8px 12px;
    border-left: 4px solid;
    background: var(--bg-card);
    border-radius: 0 4px 4px 0;
}

.dash-header h3 {
    font-size: 18px;
}

.dash-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}

.stat-card {
    padding: 10px;
    background: var(--bg-card);
    border-radius: 6px;
    text-align: center;
}

.stat-value {
    font-size: 22px;
    font-weight: 700;
    color: var(--accent-gold);
}

.stat-label {
    font-size: 10px;
    text-transform: uppercase;
    color: var(--text-muted);
    letter-spacing: 1px;
}

.rally-bar {
    position: relative;
    height: 24px;
    background: var(--bg-card);
    border-radius: 12px;
    overflow: hidden;
    margin-top: 8px;
}

.rally-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--accent-green), var(--accent-gold));
    border-radius: 12px;
    transition: width 0.3s ease;
}

.rally-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 11px;
    font-weight: 600;
    color: var(--text-primary);
    text-shadow: 0 1px 2px rgba(0,0,0,0.5);
}

.ally-entry, .request-entry {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 10px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 12px;
    margin-bottom: 4px;
}

.request-entry.sent {
    opacity: 0.7;
}

.status-pending {
    color: var(--text-muted);
    font-style: italic;
    font-size: 11px;
}

/* === History Log === */
#history-filters {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}

.filter-btn {
    padding: 4px 10px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    border-radius: 12px;
    cursor: pointer;
    font-family: inherit;
    font-size: 11px;
    transition: all 0.15s;
}

.filter-btn.active {
    background: var(--accent-gold);
    color: var(--bg-primary);
    border-color: var(--accent-gold);
}

.filter-btn:hover {
    border-color: var(--accent-gold);
}

.history-entry {
    display: flex;
    gap: 8px;
    padding: 8px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 12px;
    margin-bottom: 4px;
}

.history-icon {
    font-size: 16px;
    flex-shrink: 0;
}

.history-content { flex: 1; }

.history-message {
    margin-bottom: 2px;
}

.history-meta {
    font-size: 10px;
    color: var(--text-muted);
}

.type-battle { border-left: 2px solid var(--accent-red); }
.type-move { border-left: 2px solid var(--accent-blue); }
.type-diplomacy { border-left: 2px solid #aa44cc; }
.type-system { border-left: 2px solid var(--text-muted); }

/* === Modals === */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
}

.modal.hidden { display: none; }

.modal-content {
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
    min-width: 320px;
    max-width: 420px;
    box-shadow: 0 8px 32px var(--shadow);
}

.modal-content h3 {
    color: var(--accent-gold);
    margin-bottom: 12px;
}

.modal-content select,
.modal-content input[type="range"] {
    width: 100%;
    margin: 8px 0;
}

.modal-content select {
    padding: 6px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
    font-family: inherit;
}

.modal-content input[type="range"] {
    accent-color: var(--accent-gold);
}

#move-troop-count {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 8px 0;
}

#move-troop-count label {
    font-size: 12px;
    white-space: nowrap;
}

#move-count-display {
    font-weight: 700;
    color: var(--accent-gold);
    min-width: 40px;
}

.modal-buttons {
    display: flex;
    gap: 8px;
    margin-top: 12px;
}

.modal-btn {
    flex: 1;
    padding: 8px 16px;
    border-radius: 4px;
    border: 1px solid var(--border);
    font-family: inherit;
    font-size: 12px;
    cursor: pointer;
    transition: background 0.15s;
}

.modal-btn.confirm {
    background: var(--accent-green);
    color: #fff;
    border-color: var(--accent-green);
}

.modal-btn.cancel {
    background: var(--bg-card);
    color: var(--text-primary);
}

.modal-btn:hover {
    opacity: 0.85;
}

/* Player equivalent label */
.player-equiv {
    color: var(--text-muted);
    font-size: 11px;
    font-weight: normal;
}

/* === Clan Browser (Dashboard) === */
.clan-browser {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}

.clan-browser select {
    flex: 1;
    padding: 6px 8px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
    font-family: inherit;
    font-size: 12px;
}

.viewing-badge {
    padding: 2px 8px;
    background: rgba(240, 192, 64, 0.2);
    color: var(--accent-gold);
    border-radius: 10px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    flex-shrink: 0;
}

/* === Roblox Avatars === */
.roblox-avatar {
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--border);
    flex-shrink: 0;
}

.roblox-avatar.placeholder {
    background: var(--bg-card);
    border: 2px dashed var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-muted);
    font-size: 14px;
    border-radius: 50%;
}

.roblox-avatar.leader-avatar {
    border-color: var(--accent-gold);
    border-width: 2px;
}

/* === FAQ === */
.faq-section {
    margin-bottom: 12px;
}

.faq-section h3 {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--accent-gold);
    border-bottom: 1px solid var(--border);
    padding-bottom: 4px;
    margin-bottom: 6px;
}

.faq-section p {
    font-size: 11px;
    color: var(--text-secondary);
    margin: 4px 0;
    line-height: 1.5;
}

.faq-section ul {
    margin: 4px 0 4px 16px;
    padding: 0;
}

.faq-section li {
    font-size: 11px;
    color: var(--text-secondary);
    margin: 2px 0;
    line-height: 1.4;
}

/* === Clan Leader Row (Dashboard Header) === */
.clan-leader-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.clan-leader-info h3 {
    margin: 0;
}

.leader-name {
    font-size: 13px;
    color: var(--text-secondary);
    font-weight: 500;
}

.leader-title {
    font-size: 11px;
    color: var(--text-muted);
    font-style: italic;
}

.daimyo-info {
    margin-top: 2px;
}

.daimyo-name {
    font-size: 13px;
    color: var(--text-secondary);
    font-weight: 500;
}

.daimyo-username {
    font-size: 11px;
    color: var(--text-muted);
}

.daimyo-last-seen {
    font-size: 11px;
    color: var(--text-muted);
    font-style: italic;
}

.clan-description {
    margin-top: 8px;
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.4;
    border-top: 1px solid var(--border);
    padding-top: 8px;
}

/* === Family Tree === */
.family-tree {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.family-leader {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    background: var(--bg-card);
    border-radius: 6px;
    border-left: 3px solid var(--accent-gold);
}

.family-person-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.family-person-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}

.family-person-role {
    font-size: 10px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.gender-icon {
    font-size: 12px;
    margin-left: 3px;
}

.gender-icon.male {
    color: #5599ff;
}

.gender-icon.female {
    color: #ff77aa;
}

.family-children {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding-left: 16px;
    border-left: 2px solid var(--border);
    margin-left: 24px;
}

.family-child {
    padding: 6px 8px;
    background: var(--bg-card);
    border-radius: 4px;
}

.family-child.married {
    border-left: 2px solid #ff77aa;
}

.family-child-main {
    display: flex;
    align-items: center;
    gap: 8px;
}

.marriage-link {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px;
    padding: 4px 8px 4px 44px;
    font-size: 11px;
}

.marriage-heart {
    color: #ff4466;
    font-size: 12px;
    flex-shrink: 0;
}

.marriage-heart-lg {
    color: #ff4466;
    font-size: 18px;
    flex-shrink: 0;
}

.spouse-name {
    font-weight: 500;
    font-size: 11px;
}

.spouse-clan {
    font-size: 10px;
    color: var(--text-muted);
}

.spouse-avatar {
    border-width: 1px;
}

/* === Alliance Entry Cards === */
.ally-entry-card {
    padding: 10px;
    background: var(--bg-card);
    border-radius: 6px;
    margin-bottom: 6px;
}

.ally-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}

.ally-info {
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.ally-name {
    font-size: 13px;
    font-weight: 600;
}

.ally-leader-name {
    font-size: 11px;
    color: var(--text-muted);
}

.ally-leader-avatar {
    border-color: var(--border);
}

.alliance-marriage-detail {
    padding: 6px 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    margin: 6px 0;
}

.marriage-couple {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.marriage-person {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    text-align: center;
}

.person-name-small {
    font-size: 10px;
    color: var(--text-secondary);
    max-width: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ally-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 4px;
}

/* === Marriage Proposals === */
.proposal-detail {
    flex: 1;
}

.proposal-people {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    flex-wrap: wrap;
}

.proposal-from {
    font-size: 10px;
    color: var(--text-muted);
    margin-top: 3px;
}

.proposal-actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

/* === Marriage Proposal Modal === */
.marriage-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.marriage-form .form-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.marriage-form label {
    font-size: 11px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.person-preview {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    background: var(--bg-secondary);
    border-radius: 4px;
    font-size: 12px;
    min-height: 40px;
}

.person-preview span {
    color: var(--text-secondary);
}

/* Pulse animation for pending requests */
@keyframes pulse-border {
    0%, 100% { border-color: var(--border); }
    50% { border-color: var(--accent-gold); }
}

.pulse-border {
    animation: pulse-border 2s ease-in-out infinite;
}

/* Empty state */
.empty-state {
    padding: 12px;
    text-align: center;
    color: var(--text-muted);
    font-size: 12px;
    font-style: italic;
}
