/* ===== Nave Trading OS — Charts page: toolbar, drawing tools, indicators, panels, settings ===== */
/* Extracted from style.css — 2026-06-19 */

/* ===== CHARTS ===== */
#page-charts.page.active {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 4rem);
    width: 100%;
}
#page-charts { padding: 0; }
.charts-toolbar { min-height: 48px; }
.main-content:has(#page-charts.active) {
    padding: 0;
}
.charts-toolbar {
    display: flex;
    align-items: center;
    gap: var(--gap-md);
    padding: 0.6rem 1.5rem;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-300);
    flex-shrink: 0;
}
.charts-toolbar-left { display: flex; align-items: center; gap: 0.8rem; }
.charts-toolbar-left h2 { font-size: 1rem; }
.charts-toolbar-left select {
    padding: 0.4rem 0.7rem;
    background: var(--gray-0);
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-sm);
    color: var(--gray-800);
    font-size: 0.85rem;
    font-family: inherit;
    cursor: pointer;
}
.charts-toolbar-left select:focus { outline: none; border-color: var(--brand-400); }
.charts-timeframes { display: flex; gap: 2px; background: var(--gray-0); border-radius: var(--radius-sm); padding: 2px; }
.tf-btn {
    padding: 0.3rem 0.7rem;
    border: none;
    background: transparent;
    color: var(--gray-600);
    cursor: pointer;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 4px;
    transition: all 0.2s;
    font-family: inherit;
}
.tf-btn:hover { color: var(--gray-800); }
.tf-btn.tf-active { background: var(--brand-400); color: var(--gray-950); }
.charts-toolbar-right { margin-left: auto; display: flex; align-items: center; gap: var(--gap-sm); }

/* Positions dropdown */
.positions-dd-wrapper { position: relative; }
.toolbar-pos-btn {
    background: var(--bg-tertiary, var(--gray-150));
    border: 1px solid var(--gray-300);
    color: var(--gray-800);
    padding: 0.3rem 0.6rem;
    border-radius: var(--radius-sm);
    font-size: 0.75rem;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    transition: all 0.15s;
}
.toolbar-pos-btn:hover { background: var(--gray-0); border-color: var(--brand-400); }
.toolbar-pos-btn.active { background: var(--brand-400); color: var(--gray-950); border-color: var(--brand-400); }
.positions-dropdown {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 520px;
    max-height: 75vh;
    background: var(--card-bg, var(--gray-100));
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-lg);
    box-shadow: 0 16px 48px rgba(0,0,0,0.6);
    z-index: 300;
    overflow-y: auto;
}
.pd-section { padding: 0.5rem 0.75rem; border-bottom: 1px solid var(--gray-300); }
.pd-section:last-child { border-bottom: none; }
.pd-section-title {
    font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.5px;
    color: var(--gray-600); margin-bottom: 0.4rem; font-weight: 600;
}
.pd-positions-list { max-height: 280px; overflow-y: auto; }
.pd-history-list { max-height: 200px; overflow-y: auto; }
.pd-empty { font-size: 0.72rem; color: var(--gray-600); text-align: center; padding: 0.5rem; font-style: italic; }
.pd-position-item {
    padding: 0.45rem 0;
    border-bottom: 1px solid var(--gray-300);
}
.pd-position-item:last-child { border-bottom: none; }
.pd-pos-header {
    display: flex; align-items: center; gap: 0.4rem; margin-bottom: 0.35rem;
}
.pd-pos-symbol { font-weight: 700; min-width: 55px; font-size: 0.74rem; color: var(--gray-800); }
.pd-pos-type { font-size: 0.6rem; padding: 0.1rem 0.4rem; border-radius: 4px; font-weight: 600; text-transform: uppercase; }
.pd-pos-type.buy { background: var(--brand-400-bg); color: var(--brand-400); }
.pd-pos-type.sell { background: rgba(226,232,239,0.08); color: var(--gray-950); }
.pd-pos-info { font-size: 0.65rem; color: var(--gray-600); }
.pd-pos-profit { font-weight: 700; margin-left: auto; font-size: 0.78rem; }
.pd-pos-profit.positive { color: var(--brand-400); }
.pd-pos-profit.negative { color: var(--gray-950); }
.pd-pos-actions {
    display: flex; align-items: center; gap: 0.4rem; justify-content: space-between;
}
.pd-pos-sl-tp {
    display: flex; align-items: center; gap: 0.25rem;
}
.pd-input-label {
    font-size: 0.55rem; font-weight: 600; color: var(--gray-600);
    text-transform: uppercase; letter-spacing: 0.3px; min-width: 14px;
}
.pd-pos-sl-tp input {
    width: 58px; background: var(--gray-50); border: 1px solid var(--gray-300);
    color: var(--gray-800); padding: 0.2rem 0.3rem; border-radius: 5px;
    font-size: 0.68rem; font-family: inherit; text-align: center;
    transition: border-color 0.15s;
}
.pd-pos-sl-tp input:focus {
    border-color: var(--brand-400); outline: none; box-shadow: 0 0 0 2px rgba(37,99,235,0.2);
}
.pd-save-sltp-btn {
    background: var(--brand-400); border: none; color: var(--gray-950); cursor: pointer;
    font-size: 0.62rem; padding: 0.2rem 0.45rem; border-radius: 4px;
    font-weight: 600; font-family: inherit;
}
.pd-save-sltp-btn:hover { opacity: 0.85; }
.pd-close-btn {
    background: rgba(226,232,239,0.08); border: 1px solid rgba(226,232,239,0.15);
    color: var(--gray-800); cursor: pointer; font-size: 0.62rem; padding: 0.2rem 0.5rem;
    border-radius: 4px; font-weight: 600; font-family: inherit;
}
.pd-close-btn:hover { background: rgba(226,232,239,0.12); }
.pd-history-item {
    display: flex; align-items: center; gap: 0.4rem; padding: 0.3rem 0;
    border-bottom: 1px solid var(--gray-300); font-size: 0.68rem;
}
.pd-history-item:last-child { border-bottom: none; }
.pd-history-side { font-weight: 600; min-width: 30px; font-size: 0.62rem; padding: 0.05rem 0.3rem; border-radius: 3px; }
.pd-history-side.buy { background: var(--brand-400-bg); color: var(--brand-400); }
.pd-history-side.sell { background: rgba(226,232,239,0.08); color: var(--gray-950); }
.pd-history-symbol { font-weight: 600; min-width: 50px; font-size: 0.68rem; }
.pd-history-info { font-size: 0.62rem; color: var(--gray-600); min-width: 55px; text-align: right; }
.pd-history-pnl { font-weight: 600; min-width: 50px; text-align: right; font-size: 0.68rem; }
.pd-history-pnl.positive { color: var(--brand-400); }
.pd-history-pnl.negative { color: var(--gray-950); }
.pd-history-date { font-size: 0.58rem; color: var(--gray-600); min-width: 60px; text-align: right; }


.live-indicator {
    padding: 0.3rem 0.7rem;
    border: 1px solid var(--gray-600);
    background: transparent;
    color: var(--gray-600);
    font-size: 0.7rem;
    font-weight: 700;
    border-radius: var(--radius-sm);
    font-family: inherit;
    letter-spacing: 0.5px;
    opacity: 0.7;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.live-indicator.live-on {
    border-color: var(--brand-400);
    color: var(--brand-400);
    box-shadow: 0 0 8px rgba(37,99,235,0.3);
    opacity: 1;
    animation: live-pulse 1.5s ease-in-out infinite;
}
.live-indicator.live-on svg { stroke: var(--brand-400); }
.live-indicator.live-off {
    opacity: 0.5;
}

/* Chart toolbar price display */
.chart-price-display {
    font-family: var(--font-mono);
    font-size: var(--text-lg);
    font-weight: var(--font-bold);
    font-variant-numeric: tabular-nums;
    color: var(--brand-400);
}
.chart-change-display {
    font-size: 0.8rem;
    font-weight: var(--font-medium);
    font-variant-numeric: tabular-nums;
    color: var(--gray-800);
}
.chart-range-display {
    font-size: 0.7rem;
    color: var(--gray-600);
}
@keyframes live-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}
#chart-container, .panel-chart-container {
    flex: 1;
    width: 100%;
    min-height: 0;
    position: relative;
}
.nave-chart-canvas { border: none; }
/* LW chart integration — ensures chart fills its container */
.panel-chart-container .tv-lightweight-charts {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
}

/* ===== DRAWING TOOLS BUBBLE ===== */
.chart-tools-bubble {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 50;
    background: var(--gray-100);
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-md);
    overflow: hidden;
    min-width: 140px;
    user-select: none;
    box-shadow: 0 4px 16px rgba(0,0,0,0.4);
}
.tools-bubble-header {
    padding: 0.5rem 0.8rem;
    font-size: 0.75rem;
    font-weight: var(--font-semibold);
    cursor: grab;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-300);
    color: var(--gray-600);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}
.tools-bubble-header:active { cursor: grabbing; }
.tools-bubble-body {
    display: flex;
    gap: 2px;
    padding: 4px;
}
.tool-btn {
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    color: var(--gray-600);
    cursor: pointer;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--duration-fast);
}
.tool-btn svg { width: 18px; height: 18px; }
.tool-btn:hover { background: var(--gray-0); color: var(--gray-800); }
.tool-btn.tool-active { background: var(--brand-400); color: var(--gray-950); }

/* Indicators button & popup */
.indicators-wrapper { position: relative; }
.indicators-btn {
    padding: 0.35rem 0.75rem;
    border-radius: var(--radius-sm);
    background: var(--gray-150);
    border: 1px solid var(--gray-300);
    color: var(--gray-600);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
}
.indicators-btn:hover { background: var(--gray-0); color: var(--gray-800); border-color: var(--brand-400); }
.indicators-btn.active { background: var(--brand-400); color: var(--gray-950); border-color: var(--brand-400); }
.indicators-popup {
    position: absolute;
    top: 110%;
    left: 0;
    min-width: 200px;
    background: var(--gray-50);
    border: 1px solid var(--gray-300);
    border-radius: 8px;
    padding: 0.5rem;
    z-index: 100;
    box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
.indicator-option {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    padding: 0.45rem 0.65rem;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.82rem;
    color: var(--gray-800);
    transition: background 0.15s;
}
.indicator-option:hover { background: var(--gray-150); }
.indicator-option input[type="checkbox"] { accent-color: var(--brand-400); width: 15px; height: 15px; cursor: pointer; }

#chart-drawings-svg, .chart-drawings-svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 20;
    pointer-events: none;
}

/* Multi-panel layout */
.charts-panels {
    display: flex;
    gap: 4px;
    flex: 1;
    min-height: 0;
    position: relative;
}
.chart-panel-wrap {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    min-width: 0;
    border: 2px solid transparent;
    border-radius: 8px;
    transition: border-color 0.3s;
}
.chart-panel-wrap.panel-active {
    border-color: rgba(37,99,235,0.4);
}
.panel-chart-container {
    flex: 1;
    min-height: 0;
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-sm);
    background: var(--gray-0);
}
/* Compact per-panel mini toolbar (shown in dual mode) */
.panel-mini-toolbar {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 6px;
    background: var(--gray-50);
    border-radius: 6px 6px 0 0;
    flex-wrap: wrap;
    min-height: 34px;
}
.panel-mini-toolbar select {
    padding: 2px 6px;
    font-size: 0.7rem;
    background: var(--gray-150);
    border: 1px solid var(--gray-300);
    color: var(--gray-800);
    border-radius: 4px;
    max-width: 80px;
}
.panel-mini-toolbar .mini-tf-btn {
    padding: 2px 6px;
    font-size: 0.65rem;
    background: var(--gray-150);
    border: 1px solid var(--gray-300);
    color: var(--gray-600);
    border-radius: 4px;
    cursor: pointer;
}
.panel-mini-toolbar .mini-tf-btn.tf-active {
    background: var(--brand-400);
    color: var(--gray-950);
    border-color: var(--brand-400);
}
.panel-mini-toolbar .mini-price {
    font-size: 0.7rem;
    font-weight: 700;
    margin-left: auto;
}
.panel-mini-toolbar .mini-live {
    font-size: 0.65rem;
    padding: 2px 6px;
    border-radius: 3px;
    background: var(--brand-400-bg);
    color: var(--brand-400);
}

/* Split button */
.split-btn {
    padding: 0.35rem 0.5rem;
    border-radius: var(--radius-sm);
    background: var(--gray-150);
    border: 1px solid var(--gray-300);
    color: var(--gray-600);
    cursor: pointer;
    transition: all var(--duration-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}
.split-btn svg { width: 16px; height: 16px; }
.split-btn:hover { background: var(--gray-0); color: var(--gray-800); }
.split-btn.active { background: var(--brand-400); color: var(--gray-950); border-color: var(--brand-400); }

/* ===== HIDDEN PAGES ===== */
.page { display: none; }
.page.active { display: block; }

/* ===== CHART SETTINGS ===== */
.chart-settings-btn {
    background: transparent;
    border: 1px solid var(--gray-300);
    color: var(--gray-600);
    padding: 2px 7px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--duration-fast);
    display: flex;
    align-items: center;
    justify-content: center;
}
.chart-settings-btn svg { width: 18px; height: 18px; }
.chart-settings-btn:hover, .chart-settings-btn.active { color: var(--gray-800); border-color: var(--brand-400); background: var(--gray-150); }

.chart-settings-popup {
    position: absolute;
    top: 44px;
    right: 8px;
    background: var(--gray-100);
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-md);
    padding: 1rem 1.25rem;
    z-index: 200;
    min-width: 320px;
    max-width: 400px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.chart-settings-popup h4,
.settings-section-title { margin: 1rem 0 0.75rem; font-size: 0.9rem; color: var(--gray-800); }
.setting-group { margin-bottom: 0.65rem; }
.setting-group label { display: block; font-size: 0.75rem; color: var(--gray-600); margin-bottom: 3px; }
.setting-hint { font-size: 0.7rem; color: var(--gray-600); }
.settings-actions { display: flex; gap: var(--space-2); margin-top: var(--space-4); }
.setting-input, .setting-select {
    width: 100%;
    padding: 5px 8px;
    font-size: 0.8rem;
    background: var(--gray-150);
    border: 1px solid var(--gray-300);
    color: var(--gray-800);
    border-radius: 5px;
}
.setting-select option { background: var(--gray-100); }
.kbd-grid { display: flex; flex-direction: column; gap: 4px; max-height: 260px; overflow-y: auto; }
.kbd-row { display: flex; align-items: center; gap: 8px; font-size: 0.75rem; }
.kbd-row label { min-width: 90px; color: var(--gray-600); text-align: right; }
.kbd-row input {
    width: 80px; padding: 3px 6px; font-size: 0.75rem; text-align: center;
    background: var(--gray-150); border: 1px solid var(--gray-300); color: var(--gray-800); border-radius: 4px;
    font-family: monospace;
}

/* ===== CHART WATERMARK ===== */
.chart-watermark {
    position: absolute;
    bottom: 12px;
    right: 14px;
    font-size: 0.68rem;
    font-weight: 500;
    color: rgba(226,232,239,0.15);
    pointer-events: none;
    z-index: 15;
    letter-spacing: 0.3px;
    user-select: none;
}

/* Compass toggle en toolbar */
.chart-compass-toggle {
    background: transparent;
    border: 1px solid var(--gray-300);
    border-radius: var(--radius-sm);
    color: var(--gray-600);
    cursor: pointer;
    padding: 3px 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--duration-fast);
    flex-shrink: 0;
}
.chart-compass-toggle:hover {
    color: var(--brand-400);
    border-color: var(--brand-400);
    background: var(--brand-400-bg);
}

/* Fullscreen mode — el JS maneja el hide del topbar directo */
/* Compass activo en fullscreen */
.chart-compass-toggle.active {
    color: var(--brand-400) !important;
    border-color: var(--brand-400) !important;
    background: var(--brand-400-bg) !important;
}

/* Text input overlay (drawing tools) */
.chart-text-input-wrap {
    position: absolute;
    z-index: 100;
    pointer-events: all;
}
.chart-text-input {
    padding: 4px 8px;
    background: var(--gray-100);
    border: 1px solid var(--brand-400);
    border-radius: var(--radius-sm);
    color: var(--gray-800);
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    outline: none;
    box-shadow: 0 0 0 2px var(--brand-400-bg);
}
.chart-text-input::placeholder { color: var(--gray-600); }

/* ===== COMPACT MODE ===== */
.chart-compact .charts-toolbar { display: none !important; }
.chart-compact .trading-panel { display: none !important; }
.chart-compact .topbar { display: none !important; }
.chart-compact .main-content { height: 100vh !important; }
.chart-compact .chart-watermark { bottom: 8px; right: 10px; }
.chart-compact .panel-mini-toolbar { display: none !important; }
