/* ═══════════════════════════════════════════════
   DryFairy — Berater-Panel (Advisor)
   Persistentes NPC-Infofenster links
   50/50 Split: Dialog oben, Systemnachrichten unten
   ═══════════════════════════════════════════════ */

/* ── Panel Container ── */
#sf-advisor-panel {
    position: fixed;
    top: 0; /* wird dynamisch von Dashboard._syncLayout() gesetzt */
    left: 0;
    width: 300px;
    bottom: 0;
    z-index: 50;
    background: var(--sf-bg-panel);
    border-right: 2px solid var(--sf-border);
    display: none;
    flex-direction: column;
    overflow: hidden;
    transition: width 0.3s ease, top 0.3s ease;
    font-family: var(--sf-font);
}

#sf-advisor-panel.sf-advisor-active {
    display: flex;
}

/* Layout-Shift für game-container */
body.sf-universe.has-advisor #game-container {
    left: 300px;
}

body.sf-universe.has-advisor.advisor-minimized #game-container {
    left: 48px;
}

body.sf-universe.has-advisor.advisor-minimized #sf-advisor-panel {
    width: 48px;
}

/* ════════════════════════════════════════════════
   OBERE HÄLFTE: Dialog (Portrait + Text + Controls)
   ════════════════════════════════════════════════ */

.sf-adv-dialog-half {
    flex: 0 0 50%;
    max-height: 50%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-bottom: 2px solid var(--sf-accent, #d4a017);
}

/* ── Portrait-Bereich ── */
.sf-adv-portrait-area {
    padding: 12px 16px 8px;
    text-align: center;
    flex-shrink: 0;
    transition: opacity 0.3s ease;
}

.sf-adv-portrait {
    width: 72px;
    height: 72px;
    margin: 0 auto 6px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 38px;
    border: 3px solid var(--sf-border);
    background: var(--sf-bg-card);
    box-shadow: 0 0 16px rgba(138, 32, 144, 0.12);
    transition: border-color 0.4s ease, box-shadow 0.4s ease;
    overflow: hidden;
    position: relative;
}

.sf-adv-portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.sf-adv-name {
    font-family: 'Cinzel', serif;
    font-size: 14px;
    font-weight: 700;
    color: var(--sf-accent);
    margin-bottom: 1px;
    transition: color 0.4s ease;
}

.sf-adv-role {
    font-size: 10px;
    color: var(--sf-text-dim);
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ── Text-Bereich (scrollbar innerhalb der oberen Hälfte) ── */
.sf-adv-text-area {
    flex: 1 1 auto;
    padding: 10px 16px;
    overflow-y: auto;
    min-height: 0;
}

.sf-adv-text {
    font-family: 'Cormorant Garamond', Georgia, serif;
    font-size: 15px;
    line-height: 1.6;
    color: var(--sf-text);
    position: relative;
}

.sf-adv-text::after {
    content: '▎';
    color: var(--sf-accent);
    animation: sfAdvBlink 0.8s step-end infinite;
    margin-left: 1px;
}

.sf-adv-text.sf-adv-done::after {
    display: none;
}

@keyframes sfAdvBlink {
    0%, 50% { opacity: 1; }
    51%, 100% { opacity: 0; }
}

/* ── Queue Controls ── */
.sf-adv-controls {
    padding: 6px 16px;
    border-top: 1px solid var(--sf-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
}

.sf-adv-dots {
    display: flex;
    gap: 5px;
    align-items: center;
}

.sf-adv-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--sf-border);
    transition: background 0.2s;
}

.sf-adv-dot.active {
    background: var(--sf-accent);
}

.sf-adv-btn {
    padding: 5px 14px;
    background: var(--sf-accent);
    color: #fff;
    border: none;
    border-radius: var(--sf-radius-sm);
    font-family: 'Cinzel', serif;
    font-size: 12px;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
}

.sf-adv-btn:hover {
    background: var(--sf-accent-dim);
    transform: translateY(-1px);
}

.sf-adv-btn:active {
    transform: translateY(0);
}

.sf-adv-counter {
    font-size: 11px;
    color: var(--sf-text-dim);
    font-family: 'Cinzel', serif;
}

/* Kein Button wenn Queue leer */
.sf-adv-controls.sf-adv-idle {
    border-top-color: transparent;
    padding: 2px 16px;
}

.sf-adv-controls.sf-adv-idle .sf-adv-btn,
.sf-adv-controls.sf-adv-idle .sf-adv-dots,
.sf-adv-controls.sf-adv-idle .sf-adv-counter {
    display: none;
}

/* ════════════════════════════════════════════════
   UNTERE HÄLFTE: Systemnachrichten
   ════════════════════════════════════════════════ */

.sf-adv-notifs {
    flex: 0 0 50%;
    max-height: 50%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: max-height 0.3s ease;
    background: rgba(0, 0, 0, 0.15);
}

.sf-adv-notifs.sf-adv-notifs-collapsed {
    flex: 0 0 auto;
    max-height: none;
}

.sf-adv-notifs.sf-adv-notifs-collapsed .sf-adv-notifs-list {
    display: none;
}

.sf-adv-notifs-header {
    padding: 8px 16px;
    font-size: 11px;
    font-weight: 600;
    color: var(--sf-accent, #d4a017);
    text-transform: uppercase;
    letter-spacing: 0.8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    user-select: none;
    flex-shrink: 0;
    border-bottom: 1px solid rgba(200, 184, 152, 0.15);
}

.sf-adv-notifs-header:hover {
    color: var(--sf-accent);
}

.sf-adv-notifs-arrow {
    font-size: 10px;
    transition: transform 0.2s;
}

.sf-adv-notifs-collapsed .sf-adv-notifs-arrow {
    transform: rotate(-90deg);
}

.sf-adv-notifs-badge {
    font-size: 10px;
    font-weight: 700;
    background: var(--sf-red, #c0392b);
    color: #fff;
    border-radius: 8px;
    padding: 1px 5px;
    display: none;
    margin-left: auto;
}

.sf-adv-notifs-badge.sf-adv-notifs-has {
    display: inline-block;
}

.sf-adv-notifs-list {
    padding: 0 8px 8px;
    overflow-y: auto;
    flex: 1 1 auto;
}

.sf-adv-notifs-empty {
    padding: 16px 8px;
    font-size: 12px;
    color: var(--sf-text-dim);
    text-align: center;
}

/* ── Notification Item ── */
.sf-adv-nitem {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 6px 8px;
    border-radius: var(--sf-radius-sm);
    margin-bottom: 2px;
    transition: background 0.15s;
}

.sf-adv-nitem:hover {
    background: rgba(200, 184, 152, 0.1);
}

.sf-adv-nitem-nav {
    cursor: pointer;
}

.sf-adv-nitem-unread {
    background: rgba(200, 184, 152, 0.08);
    border-left: 2px solid var(--n-color, var(--sf-accent));
}

.sf-adv-nitem-icon {
    font-size: 16px;
    flex-shrink: 0;
    width: 22px;
    text-align: center;
    line-height: 1.3;
}

.sf-adv-nitem-body {
    flex: 1;
    min-width: 0;
}

.sf-adv-nitem-msg {
    font-size: 12px;
    color: var(--sf-text);
    line-height: 1.45;
}

.sf-adv-nitem-msg em {
    color: var(--n-color, #DEA726);
    font-style: normal;
    font-weight: 600;
}

.sf-adv-nitem-msg strong {
    color: #fff;
    font-weight: 700;
}

.sf-adv-nitem-time {
    font-size: 10px;
    color: var(--sf-text-dim);
    margin-top: 2px;
}

.sf-adv-nitem-count {
    font-size: 10px;
    font-weight: 700;
    color: #fff;
    border-radius: 8px;
    padding: 1px 6px;
    flex-shrink: 0;
    align-self: center;
}

/* ── Live-Notification Flash ── */
.sf-adv-nitem-flash {
    animation: sf-nitem-flash 2s ease-out;
}

@keyframes sf-nitem-flash {
    0%   { background: rgba(200, 184, 152, 0.25); }
    50%  { background: rgba(200, 184, 152, 0.15); }
    100% { background: rgba(200, 184, 152, 0.08); }
}

/* ── Minimize-Button ── */
.sf-adv-minimize {
    padding: 6px 16px;
    border-top: 1px solid var(--sf-border);
    flex-shrink: 0;
    text-align: center;
}

.sf-adv-minimize button {
    background: none;
    border: 1px solid var(--sf-border);
    border-radius: var(--sf-radius-sm);
    padding: 4px 12px;
    font-size: 11px;
    color: var(--sf-text-dim);
    cursor: pointer;
    font-family: var(--sf-font);
    transition: all 0.15s;
    width: 100%;
}

.sf-adv-minimize button:hover {
    border-color: var(--sf-accent);
    color: var(--sf-accent);
}

/* ── Minimized State ── */
.advisor-minimized #sf-advisor-panel .sf-adv-dialog-half,
.advisor-minimized #sf-advisor-panel .sf-adv-notifs {
    display: none;
}

.advisor-minimized #sf-advisor-panel .sf-adv-portrait-area {
    padding: 8px 4px;
    border-bottom: none;
}

.advisor-minimized #sf-advisor-panel .sf-adv-portrait {
    width: 36px;
    height: 36px;
    font-size: 22px;
    border-width: 2px;
    cursor: pointer;
}

.advisor-minimized #sf-advisor-panel .sf-adv-name,
.advisor-minimized #sf-advisor-panel .sf-adv-role {
    display: none;
}

.advisor-minimized #sf-advisor-panel .sf-adv-minimize button {
    font-size: 0;
    padding: 6px;
    border: none;
}

.advisor-minimized #sf-advisor-panel .sf-adv-minimize button::after {
    content: '▶';
    font-size: 12px;
}

/* ── Unread Badge (minimized) ── */
.sf-adv-badge {
    position: absolute;
    top: -4px;
    right: -4px;
    background: var(--sf-red);
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
}

.advisor-minimized .sf-adv-badge.has-messages {
    display: flex;
}
