/* ===== Reset & Base ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    /* Dark theme (default) */
    --bg-base:        #0d1117;
    --bg-panel:       #161b22;
    --bg-widget:      #1c2333;
    --bg-header:      #0d1117;
    --border:         #30363d;
    --text-primary:   #e6edf3;
    --text-secondary: #8b949e;
    --text-muted:     #484f58;
    --accent-gold:    #d4a520;
    --accent-green:   #3fb950;
    --accent-red:     #f85149;
    --accent-blue:    #58a6ff;
    --btn-primary-bg: #238636;
    --btn-primary-fg: #ffffff;
    --radius:         8px;
    --shadow:         0 1px 6px rgba(0,0,0,.4);
}

[data-theme="light"] {
    --bg-base:        #f0f2f5;
    --bg-panel:       #ffffff;
    --bg-widget:      #f6f8fa;
    --bg-header:      #ffffff;
    --border:         #d0d7de;
    --text-primary:   #1f2328;
    --text-secondary: #57606a;
    --text-muted:     #adb5bd;
    --shadow:         0 1px 4px rgba(0,0,0,.12);
}

html, body {
    height: 100%;
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--bg-base);
}

a { color: var(--accent-blue); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ===== Auth Pages ===== */
.auth-page {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: var(--bg-base);
}

.auth-card {
    width: 100%;
    max-width: 400px;
    background: var(--bg-widget);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 2.5rem 2rem;
    box-shadow: var(--shadow);
}

.auth-title {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--accent-gold);
    text-align: center;
    margin-bottom: .25rem;
}

.auth-subtitle {
    font-size: 1rem;
    font-weight: 500;
    text-align: center;
    color: var(--text-secondary);
    margin-bottom: 1.5rem;
}

.auth-form label {
    display: block;
    font-size: .8rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: .3rem;
    margin-top: 1rem;
    text-transform: uppercase;
    letter-spacing: .05em;
}

.auth-form input {
    width: 100%;
    padding: .55rem .75rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: .95rem;
    outline: none;
    transition: border-color .15s;
}

.auth-form input:focus { border-color: var(--accent-blue); }

.auth-form .btn { width: 100%; margin-top: 1.5rem; }

.auth-switch {
    margin-top: 1.25rem;
    text-align: center;
    font-size: .85rem;
    color: var(--text-secondary);
}

/* ===== Buttons ===== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
    padding: .45rem .9rem;
    border: 1px solid transparent;
    border-radius: 6px;
    font-size: .85rem;
    font-weight: 600;
    cursor: pointer;
    transition: background .15s, opacity .15s;
    background: none;
    color: var(--text-primary);
    text-decoration: none;
}

.btn-primary {
    background: var(--btn-primary-bg);
    color: var(--btn-primary-fg);
    border-color: #2ea043;
}
.btn-primary:hover { opacity: .88; text-decoration: none; }

.btn:disabled {
    cursor: wait;
    opacity: .55;
}

.btn-ghost { color: var(--text-secondary); }
.btn-ghost:hover { color: var(--text-primary); text-decoration: none; }

.btn-icon {
    padding: .3rem .4rem;
    font-size: 1rem;
    color: var(--text-secondary);
    border-radius: 6px;
}
.btn-icon:hover { background: var(--bg-panel); color: var(--text-primary); }

.btn-sm { font-size: .75rem; padding: .2rem .35rem; }

/* ===== Alerts ===== */
.alert {
    padding: .6rem .85rem;
    border-radius: 6px;
    font-size: .88rem;
    margin-bottom: .5rem;
}
.alert-error { background: rgba(248,81,73,.15); border: 1px solid var(--accent-red); color: var(--accent-red); }

/* ===== Dashboard Layout ===== */
.dashboard-page {
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow: hidden;
    background: var(--bg-base);
}

/* Header */
.header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 1.25rem;
    height: 48px;
    background: var(--bg-header);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
    z-index: 100;
}

.header-left { display: flex; align-items: center; gap: .75rem; }
.header-right { display: flex; align-items: center; gap: .5rem; }

.header-logo {
    font-weight: 800;
    font-size: 1rem;
    color: var(--accent-gold);
    letter-spacing: .06em;
}

.header-title {
    font-size: .85rem;
    color: var(--text-secondary);
}

.header-user {
    font-size: .85rem;
    color: var(--text-secondary);
}

.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    border: 1px solid var(--border);
    background: var(--bg-widget);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    color: var(--text-secondary);
    transition: background .2s, color .2s, border-color .2s;
}
.theme-toggle:hover {
    background: var(--bg-hover);
    color: var(--accent-gold);
    border-color: var(--accent-gold);
}
.theme-toggle-icon { display: none; }
[data-theme="dark"]  .theme-toggle-icon--dark  { display: inline; }
[data-theme="light"] .theme-toggle-icon--light { display: inline; }

/* ===== Tab Panes ===== */
#tab-panes {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
}

.tab-pane          { display: none; flex: 1; min-height: 0; flex-direction: column; }
.tab-pane.active   { display: flex; }

/* Main grid */
.dashboard-grid {
    display: grid;
    grid-template-columns: 280px 1fr 280px;
    grid-template-rows: 1fr;
    flex: 1;
    min-height: 0;
    gap: .5rem;
    padding: .5rem;
}

.panel {
    display: flex;
    flex-direction: column;
    gap: .5rem;
    min-height: 0;
    overflow: hidden;
}

/* ===== Widget Cards ===== */
.widget {
    background: var(--bg-widget);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

.widget-grow { flex: 1; min-height: 0; }
.widget-chart { flex: 1; }

.widget-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .5rem .75rem;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.widget-title {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--text-secondary);
}

.widget-badge {
    font-size: .7rem;
    font-weight: 700;
    padding: .15rem .45rem;
    border-radius: 4px;
    background: rgba(63,185,80,.15);
    color: var(--accent-green);
    letter-spacing: .05em;
}

.widget-body {
    flex: 1;
    overflow-y: auto;
    padding: .6rem .75rem;
    min-height: 0;
}

.widget-body-chart {
    padding: 0;
    overflow: hidden;
}

.widget-body-video {
    padding: 0;
    overflow: hidden;
}

/* ===== Loading & Error States ===== */
.loading, .error-state {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 60px;
    color: var(--text-muted);
    font-size: .85rem;
    font-style: italic;
}

.error-state { color: var(--accent-red); font-style: normal; }

/* ===== Sessions Widget ===== */
.session-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .5rem 0;
    border-bottom: 1px solid var(--border);
}
.session-item:last-child { border-bottom: none; }

.session-info { display: flex; flex-direction: column; gap: .1rem; }

.session-name {
    font-size: .88rem;
    font-weight: 600;
    color: var(--text-primary);
}

.session-time {
    font-size: .82rem;
    color: var(--text-secondary);
    font-variant-numeric: tabular-nums;
}

.session-tz {
    font-size: .7rem;
    color: var(--text-muted);
}

.session-countdown {
    font-size: .72rem;
    color: var(--accent-gold);
    font-weight: 600;
}

.session-status {
    font-size: .72rem;
    font-weight: 700;
    padding: .2rem .5rem;
    border-radius: 4px;
    letter-spacing: .07em;
    flex-shrink: 0;
}

.session-status.open {
    background: rgba(63,185,80,.15);
    color: var(--accent-green);
}

.session-status.closed {
    background: rgba(248,81,73,.12);
    color: var(--accent-red);
}

/* ===== News Widget ===== */
.news-item {
    padding: .55rem 0;
    border-bottom: 1px solid var(--border);
}
.news-item:last-child { border-bottom: none; }

.news-title {
    font-size: .84rem;
    font-weight: 500;
    color: var(--text-primary);
    line-height: 1.35;
    margin-bottom: .25rem;
}

.news-meta {
    font-size: .72rem;
    color: var(--text-muted);
    display: flex;
    gap: .5rem;
}

.news-source { color: var(--accent-blue); }

/* ===== High / Low Filters ===== */
.hl-filters {
    display: flex;
    align-items: center;
    gap: .25rem;
}

.hl-filter {
    font-size: .68rem;
    font-weight: 700;
    padding: .15rem .45rem;
    border-radius: 4px;
    border: 1px solid var(--border);
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
    letter-spacing: .04em;
    transition: background .15s, color .15s, border-color .15s;
}

.hl-filter:hover {
    background: var(--bg-panel);
    color: var(--text-secondary);
}

.hl-filter.active {
    background: rgba(212,165,32,.15);
    border-color: var(--accent-gold);
    color: var(--accent-gold);
}

/* ===== High / Low Widget ===== */
.hl-section {
    margin-bottom: .6rem;
}

.hl-label {
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--text-muted);
    font-weight: 700;
    margin-bottom: .25rem;
}

.hl-values {
    display: flex;
    gap: .75rem;
    align-items: center;
}

.hl-high { color: var(--accent-green); font-weight: 700; font-size: .9rem; }
.hl-low  { color: var(--accent-red);   font-weight: 700; font-size: .9rem; }

.hl-range {
    font-size: .75rem;
    color: var(--text-muted);
}

.hl-divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: .4rem 0;
}

/* ===== Video Widget ===== */
.video-container {
    width: 100%;
    height: 100%;
}

.video-container iframe {
    width: 100%;
    height: 100%;
    border: none;
}

.video-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--text-muted);
    font-size: .85rem;
    gap: .5rem;
    text-align: center;
    padding: 1rem;
}

/* ===== Telegram Widget ===== */
.telegram-widget-body {
    min-height: 220px;
    overflow: auto;
}

.telegram-embed-wrap {
    width: 100%;
}

.telegram-placeholder {
    min-height: 180px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    padding: 1rem;
    text-align: center;
    color: var(--text-muted);
}

.telegram-placeholder-title {
    color: var(--text-primary);
    font-weight: 700;
    font-size: .9rem;
}

.telegram-placeholder-text {
    max-width: 280px;
    font-size: .8rem;
    line-height: 1.4;
}

.telegram-open-link {
    margin-top: .15rem;
}

/* ===== Footer ===== */
.footer {
    flex-shrink: 0;
    text-align: center;
    font-size: .7rem;
    color: var(--text-muted);
    padding: .35rem 1rem;
    border-top: 1px solid var(--border);
    background: var(--bg-header);
}

/* ===== Settings Panel ===== */
.settings-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 200;
}

.settings-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 340px;
    height: 100vh;
    background: var(--bg-widget);
    border-left: 1px solid var(--border);
    z-index: 201;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    box-shadow: -4px 0 20px rgba(0,0,0,.4);
}

.settings-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.settings-header h2 {
    font-size: 1rem;
    font-weight: 700;
}

.settings-form {
    padding: 1rem 1.25rem 2rem;
    display: flex;
    flex-direction: column;
    gap: .2rem;
}

.settings-form label {
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--text-secondary);
    margin-top: 1rem;
}

.settings-form input,
.settings-form select {
    width: 100%;
    padding: .5rem .7rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: .9rem;
    outline: none;
    transition: border-color .15s;
    margin-top: .3rem;
}

.settings-form input:focus,
.settings-form select:focus { border-color: var(--accent-blue); }

.settings-form .btn { margin-top: 1.5rem; width: 100%; }

.settings-status {
    margin-top: .75rem;
    font-size: .82rem;
    text-align: center;
    min-height: 1.2em;
}

.settings-status.success { color: var(--accent-green); }
.settings-status.error   { color: var(--accent-red); }

/* ===== Settings Danger Zone ===== */
.settings-danger-zone {
    padding: 1rem 1.25rem 1.5rem;
    border-top: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: .5rem;
}
.settings-hint {
    font-size: .75rem;
    color: var(--text-muted);
    margin: -.25rem 0 .25rem;
    line-height: 1.4;
}
.settings-hint code {
    font-family: monospace;
    background: var(--bg-input);
    padding: .1em .3em;
    border-radius: 3px;
}
.settings-danger-desc {
    font-size: .78rem;
    color: var(--text-muted);
    line-height: 1.45;
    margin: 0;
}
.settings-danger-zone .btn-danger { width: 100%; margin-top: .25rem; }
.settings-logout-btn { width: 100%; text-align: center; margin-top: .25rem; }

/* ===== Custom Feed Row ===== */
.custom-feed-row .btn,
.custom-feed-list .btn { margin-top: 0; width: auto; flex-shrink: 0; }

.custom-feed-row {
    display: flex;
    gap: .4rem;
    margin-top: .3rem;
}

.custom-feed-row input {
    flex: 1;
    margin-top: 0;
}

.custom-feed-list {
    display: flex;
    flex-direction: column;
    gap: .25rem;
    margin-top: .4rem;
}

.custom-feed-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .3rem .55rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 5px;
    font-size: .78rem;
}

.custom-feed-label {
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
    margin-right: .4rem;
}

.hidden { display: none !important; }

/* ===== Scrollbar ===== */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* ===== Widget Size Classes ===== */
.widget-size-sm { height: 160px; flex: none; }
.widget-size-md { height: 300px; flex: none; }
.widget-size-lg { flex: 1; }

/* ===== Widget Inline Config Panel ===== */
.widget-inline-config {
    padding: .5rem .75rem .6rem;
    border-bottom: 1px solid var(--border);
    background: var(--bg-panel);
    display: flex;
    flex-direction: column;
    gap: .4rem;
}
.widget-inline-config.hidden { display: none; }
.wic-label {
    font-size: .75rem;
    font-weight: 600;
    color: var(--text-secondary);
}
.wic-hint {
    font-weight: 400;
    color: var(--text-muted);
}
.wic-row {
    display: flex;
    gap: .4rem;
    align-items: center;
}
.wic-input {
    flex: 1;
    font-size: .78rem;
    padding: .3rem .5rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    background: var(--bg-input);
    color: var(--text-primary);
    outline: none;
    min-width: 0;
}
.wic-input:focus { border-color: var(--accent-gold); }
.widget-config-btn.active {
    color: var(--accent-gold);
    border-color: var(--accent-gold);
    background: var(--bg-panel);
}
.wic-period-btns {
    display: flex;
    gap: .3rem;
    flex-wrap: wrap;
}
.wic-period-btn {
    font-size: .72rem;
    font-weight: 600;
    padding: .2rem .55rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: background .12s, color .12s, border-color .12s;
}
.wic-period-btn:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}
.wic-period-btn.active {
    background: var(--accent-gold);
    border-color: var(--accent-gold);
    color: #000;
}

/* ===== Widget Header Controls ===== */
.widget-header-controls {
    display: flex;
    align-items: center;
    gap: .3rem;
    margin-left: auto;
}

/* ===== Size Buttons ===== */
.widget-size-btns {
    display: flex;
    gap: 2px;
    margin-right: .15rem;
}

.widget-size-btn {
    font-size: .62rem;
    font-weight: 700;
    padding: .1rem .3rem;
    border: 1px solid var(--border);
    border-radius: 3px;
    background: transparent;
    color: var(--text-muted);
    cursor: pointer;
    line-height: 1.4;
    transition: background .12s, color .12s, border-color .12s;
}

.widget-size-btn:hover {
    background: var(--bg-panel);
    color: var(--text-secondary);
}

.widget-size-btn.active {
    background: rgba(212,165,32,.15);
    border-color: var(--accent-gold);
    color: var(--accent-gold);
}

/* ===== Drag Handle ===== */
.widget-drag-handle {
    cursor: grab;
    color: var(--text-muted);
    font-size: .9rem;
    padding: 0 .35rem 0 0;
    letter-spacing: -2px;
    user-select: none;
    flex-shrink: 0;
    transition: color .12s;
}

.widget-drag-handle:hover  { color: var(--text-secondary); }
.widget-drag-handle:active { cursor: grabbing; }

/* Return-to-tray button */
.widget-remove-btn {
    opacity: 0;
    transition: opacity .15s;
    color: var(--text-muted);
    font-size: .85rem;
}
.widget:hover .widget-remove-btn          { opacity: 1; }
.widget-tray-open .widget-remove-btn      { opacity: 1; }
.widget-remove-btn:hover { color: var(--accent-red) !important; background: rgba(248,81,73,.12) !important; }

/* ===== SortableJS Drag States ===== */
.sortable-ghost {
    opacity: .35;
    background: var(--bg-panel);
    border: 2px dashed var(--accent-gold) !important;
}

.sortable-drag {
    opacity: .95;
    box-shadow: 0 8px 24px rgba(0,0,0,.6);
    cursor: grabbing !important;
}

.sortable-chosen {
    outline: 2px solid var(--accent-gold);
    outline-offset: -2px;
}

/* ===== Dashboard Layout Variants ===== */
.panel-panel4 { display: none; } /* hidden unless 4-col layout is active */

.dashboard-grid.layout-25-50-25   { grid-template-columns: 1fr 2fr 1fr; }
.dashboard-grid.layout-25-25-25-25 {
    grid-template-columns: 1fr 1fr 1fr 1fr;
}
.dashboard-grid.layout-25-25-25-25 .panel-panel4 { display: flex; }
.dashboard-grid.layout-33-34-33   { grid-template-columns: 1fr 1fr 1fr; }
.dashboard-grid.layout-20-60-20   { grid-template-columns: 1fr 3fr 1fr; }

/* Dashed placeholder via pseudo-element — no DOM node, never interferes with drops */
.panel-panel4:not(:has(.widget:not(.widget-hidden)))::before {
    content: 'Drag widgets here';
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-height: 80px;
    border: 2px dashed var(--border);
    border-radius: var(--radius);
    color: var(--text-muted);
    font-size: .8rem;
    pointer-events: none;
}

/* ===== Layout Picker (settings panel) ===== */
.layout-picker {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
    margin-top: .4rem;
}

.layout-opt {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .35rem;
    padding: .5rem .4rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    cursor: pointer;
    transition: border-color .15s, background .15s;
    font-size: 0; /* hide inline spacing */
}
.layout-opt:hover { border-color: var(--text-secondary); }
.layout-opt.active {
    border-color: var(--accent-gold);
    background: rgba(212,165,32,.1);
}

.layout-opt span {
    font-size: .68rem;
    font-weight: 600;
    color: var(--text-secondary);
    white-space: nowrap;
}
.layout-opt.active span { color: var(--accent-gold); }

.layout-preview {
    display: flex;
    gap: 2px;
    width: 100%;
    height: 28px;
}
.layout-preview > div {
    background: var(--border);
    border-radius: 2px;
    transition: background .15s;
}
.layout-opt.active .layout-preview > div { background: var(--accent-gold); opacity: .7; }

/* ===== Widget Visibility ===== */
.widget-hidden { display: none !important; }
.widget-body-embed { padding: 0; overflow: hidden; flex: 1; min-height: 0; }
#widget-ticker .widget-body-embed { height: 140px; flex: none; overflow: hidden; }
#widget-ticker .widget-header { padding: .3rem .55rem; }
#widget-ticker .widget-title  { font-size: .7rem; }
#widget-ticker .widget-size-btn { font-size: .58rem; padding: .08rem .25rem; }
#ticker-container iframe {
    transform: scale(0.75);
    transform-origin: top left;
    width: 133.33% !important;
    height: 133.33% !important;
}

/* ===== Settings Section Titles ===== */
.settings-section-title {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--text-muted);
    margin-top: 1.4rem;
    margin-bottom: .4rem;
    padding-bottom: .3rem;
    border-bottom: 1px solid var(--border);
}

/* ===== Widget Toggle Rows ===== */
.widget-toggle-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .38rem 0;
    border-bottom: 1px solid var(--border);
}
.widget-toggle-row:last-child { border-bottom: none; }
.widget-toggle-label { font-size: .85rem; color: var(--text-primary); }

/* CSS Toggle Switch */
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 36px;
    height: 20px;
    flex-shrink: 0;
}
.toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-track {
    position: absolute;
    inset: 0;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 20px;
    cursor: pointer;
    transition: background .2s, border-color .2s;
}
.toggle-track::before {
    content: '';
    position: absolute;
    left: 2px;
    top: 50%;
    transform: translateY(-50%);
    width: 14px;
    height: 14px;
    background: var(--text-muted);
    border-radius: 50%;
    transition: transform .2s, background .2s;
}
.toggle-switch input:checked + .toggle-track {
    background: rgba(63,185,80,.2);
    border-color: var(--accent-green);
}
.toggle-switch input:checked + .toggle-track::before {
    transform: translate(16px, -50%);
    background: var(--accent-green);
}

/* ===== Fear & Greed Widget ===== */
.fg-gauge-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: .6rem .5rem .4rem;
    gap: .3rem;
}
.fg-gauge-wrap svg { width: 180px; height: 108px; overflow: visible; }
.fg-score  { font-size: 1.9rem; font-weight: 800; font-variant-numeric: tabular-nums; }
.fg-rating { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text-secondary); }
.fg-updated { font-size: .67rem; color: var(--text-muted); }
.fg-unavailable {
    min-height: 150px;
    justify-content: center;
}
.fg-na {
    font-size: 1.9rem;
    font-weight: 800;
    color: var(--text-muted);
}

/* ===== Currency Strength Widget ===== */
.cs-bar-row {
    display: flex;
    align-items: center;
    gap: .45rem;
    padding: .22rem 0;
}
.cs-currency { width: 2.6rem; font-size: .74rem; font-weight: 700; color: var(--text-secondary); flex-shrink: 0; }
.cs-bar-track { flex: 1; height: 8px; background: var(--bg-panel); border-radius: 4px; overflow: hidden; }
.cs-bar-fill  { height: 100%; border-radius: 4px; background: var(--accent-blue); transition: width .5s ease; }
.cs-bar-fill.cs-usd { background: var(--accent-gold); }
.cs-value { width: 2.6rem; text-align: right; font-size: .73rem; color: var(--text-muted); font-variant-numeric: tabular-nums; }

/* ===== Sentiment Widget ===== */
.sent-gauge-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: .6rem .5rem .25rem;
    gap: .25rem;
}
.sent-gauge-wrap svg { width: 180px; height: 102px; overflow: visible; }
.sent-labels {
    display: flex;
    justify-content: space-between;
    width: 100%;
    padding: 0 .5rem;
    font-size: .75rem;
}
.sent-long  { color: var(--accent-green); font-weight: 700; }
.sent-short { color: var(--accent-red);   font-weight: 700; }
.sent-input-row {
    display: flex;
    align-items: center;
    gap: .3rem;
}
.sent-input {
    width: 48px;
    text-align: center;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 5px;
    color: var(--text-primary);
    font-size: .82rem;
    padding: .15rem .3rem;
    outline: none;
}
.sent-input:focus { border-color: var(--accent-blue); }

/* ===== Notes Widget ===== */
.notes-widget-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: .5rem .75rem;
    min-height: 0;
}
.notes-textarea {
    flex: 1;
    width: 100%;
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-size: .85rem;
    font-family: inherit;
    line-height: 1.55;
    resize: none;
    outline: none;
    min-height: 80px;
}
.notes-save-indicator {
    font-size: .68rem;
    color: var(--text-muted);
    text-align: right;
    padding-top: .2rem;
    min-height: 1em;
    flex-shrink: 0;
}

/* ===== Price Alerts Widget ===== */
.alerts-list { display: flex; flex-direction: column; gap: .3rem; margin-bottom: .5rem; }

.alert-item {
    display: flex;
    align-items: center;
    gap: .35rem;
    padding: .3rem .45rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 5px;
    font-size: .78rem;
}
.alert-item.triggered { opacity: .5; }
.alert-symbol { font-weight: 700; color: var(--text-primary); flex-shrink: 0; }
.alert-dir-above { color: var(--accent-green); flex-shrink: 0; }
.alert-dir-below { color: var(--accent-red);   flex-shrink: 0; }
.alert-price { font-variant-numeric: tabular-nums; color: var(--text-secondary); flex-shrink: 0; }
.alert-label { flex: 1; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Sound checkbox */
.alert-sound-label {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    cursor: pointer;
    font-size: .85rem;
    color: var(--text-muted);
    user-select: none;
}
.alert-sound-label input[type="checkbox"] {
    accent-color: var(--accent-gold);
    width: 13px;
    height: 13px;
    cursor: pointer;
}
.alert-sound-label:has(input:checked) { color: var(--accent-gold); }

.alert-add-row {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    padding-top: .5rem;
    border-top: 1px solid var(--border);
}
.alert-inputs {
    display: grid;
    grid-template-columns: 1fr 90px 80px;
    gap: .3rem;
}
.alert-add-row input,
.alert-add-row select {
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 5px;
    color: var(--text-primary);
    font-size: .78rem;
    padding: .25rem .4rem;
    outline: none;
    width: 100%;
}
.alert-add-row input:focus,
.alert-add-row select:focus { border-color: var(--accent-blue); }

/* Alert banner (triggered notification fallback) */
.alert-banner {
    position: fixed;
    top: 56px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--accent-gold);
    color: #000;
    font-weight: 700;
    font-size: .9rem;
    padding: .55rem 1.3rem;
    border-radius: var(--radius);
    z-index: 300;
    box-shadow: 0 4px 16px rgba(0,0,0,.5);
    cursor: pointer;
    animation: alert-flash .6s ease-in-out infinite alternate;
    white-space: nowrap;
}
@keyframes alert-flash {
    from { opacity: 1; }
    to   { opacity: .4; }
}

/* ===== Tab Bar ===== */
.tab-bar {
    display: flex;
    align-items: flex-end;
    height: 28px;
    background: var(--bg-header);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
    padding: 0 .5rem;
    gap: .4rem;
    overflow: hidden;
}

.tab-list {
    display: flex;
    align-items: stretch;
    gap: 2px;
    flex: 1;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    min-width: 0;
}
.tab-list::-webkit-scrollbar { display: none; }

.tab-btn {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .22rem .6rem;
    background: transparent;
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: 5px 5px 0 0;
    color: var(--text-secondary);
    font-size: .8rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background .12s, color .12s;
    min-width: 68px;
    max-width: 160px;
}
.tab-btn:hover { background: var(--bg-widget); color: var(--text-primary); }
.tab-btn.active {
    background: var(--bg-widget);
    border-color: var(--border);
    color: var(--text-primary);
    font-weight: 600;
}

.tab-label {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: left;
}

.tab-label-input {
    background: var(--bg-base);
    border: 1px solid var(--accent-blue);
    border-radius: 3px;
    color: var(--text-primary);
    font-size: .78rem;
    padding: .1rem .3rem;
    width: 90px;
    outline: none;
}

.tab-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 15px;
    height: 15px;
    background: transparent;
    border: none;
    border-radius: 3px;
    color: var(--text-muted);
    font-size: .72rem;
    cursor: pointer;
    flex-shrink: 0;
    padding: 0;
    line-height: 1;
    transition: background .12s, color .12s;
}
.tab-close:hover { background: rgba(248,81,73,.2); color: var(--accent-red); }

.tab-sortable-ghost {
    opacity: .35;
    border: 1px dashed var(--accent-gold) !important;
    border-bottom: none !important;
}

.tab-bar-actions { display: flex; align-items: center; gap: .2rem; flex-shrink: 0; }
.tab-action-btn  { font-size: 1rem; padding: .22rem .4rem; }

/* ===== Widget Dialog ===== */
/* ===== Widget Tray (slide-in from right, no overlay) ===== */
.widget-tray {
    position: fixed;
    top: 86px;          /* header 48px + tab-bar 38px */
    right: 0;
    width: 220px;
    height: calc(100vh - 86px);
    background: var(--bg-widget);
    border-left: 1px solid var(--border);
    box-shadow: -4px 0 18px rgba(0,0,0,.35);
    z-index: 150;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* .hidden on the tray uses display:none from the global rule — no override needed */

.widget-tray-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .6rem .75rem;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}
.widget-tray-header h3 { font-size: .85rem; font-weight: 700; }

.widget-tray-hint {
    font-size: .7rem;
    color: var(--text-muted);
    padding: .4rem .75rem .15rem;
    flex-shrink: 0;
    line-height: 1.4;
}

.widget-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .4rem;
    padding: .5rem .75rem .75rem;
    overflow-y: auto;
    list-style: none;
}

.widget-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .28rem;
    padding: .55rem .35rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 6px;
    cursor: grab;
    transition: border-color .15s, background .15s, opacity .15s;
    user-select: none;
    text-align: center;
}
.widget-card:hover { border-color: var(--accent-gold); background: var(--bg-base); }
.widget-card.in-tab { opacity: .38; cursor: default; }
.widget-card.in-tab:hover { border-color: var(--border); background: var(--bg-panel); }

.wc-icon  { font-size: 1.15rem; line-height: 1; }
.wc-label { font-size: .65rem; font-weight: 600; color: var(--text-secondary); line-height: 1.3; }

/* ===== Confirm Dialog ===== */
.confirm-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 300;
}
.confirm-dialog {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: var(--bg-widget);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.4rem 1.6rem;
    z-index: 301;
    min-width: 270px;
    box-shadow: 0 8px 32px rgba(0,0,0,.5);
}
#confirm-msg { font-size: .9rem; color: var(--text-primary); margin-bottom: 1.2rem; line-height: 1.45; }
.confirm-actions { display: flex; justify-content: flex-end; gap: .5rem; }

.btn-danger { background: var(--accent-red); color: #fff; border-color: var(--accent-red); }

/* ===== Widget Tooltip (?) ===== */
.widget-tooltip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    font-size: .6rem;
    font-weight: 700;
    line-height: 1;
    color: var(--text-muted);
    border: 1px solid var(--text-muted);
    cursor: default;
    position: relative;
    flex-shrink: 0;
    user-select: none;
    margin-left: .25rem;
    margin-right: .25rem;
}
.widget-tooltip::after {
    content: attr(data-tip);
    position: absolute;
    top: calc(100% + 7px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--bg-widget);
    border: 1px solid var(--border);
    color: var(--text-secondary);
    font-size: .72rem;
    font-weight: 400;
    line-height: 1.45;
    white-space: normal;
    width: 210px;
    padding: .4rem .55rem;
    border-radius: 5px;
    box-shadow: var(--shadow);
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s ease;
    z-index: 200;
    text-transform: none;
    letter-spacing: 0;
}
.widget-tooltip::before {
    content: '';
    position: absolute;
    top: calc(100% + 2px);
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-bottom-color: var(--border);
    pointer-events: none;
    opacity: 0;
    transition: opacity .15s ease;
    z-index: 201;
}
.widget-tooltip:hover::after,
.widget-tooltip:hover::before { opacity: 1; }
.btn-danger:hover { opacity: .85; text-decoration: none; }

/* ===== ICT Kill Zones Widget ===== */
#ict-body { padding: .5rem .75rem .75rem; display: flex; flex-direction: column; gap: .25rem; }

.ict-section-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--text-muted);
    margin-bottom: .15rem;
}
.ict-section-label--p3 { margin-top: .75rem; }

.kz-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .3rem .4rem;
    border-radius: 5px;
    background: var(--bg-panel);
    border: 1px solid transparent;
    transition: border-color .15s;
}
.kz-item.kz-active { border-color: var(--accent-gold); background: rgba(212,165,32,.07); }

.kz-name { font-size: .78rem; font-weight: 600; color: var(--text-primary); flex: 1; }

.kz-right { display: flex; flex-direction: column; align-items: flex-end; gap: .1rem; }

.kz-badge {
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .06em;
    padding: .1rem .4rem;
    border-radius: 3px;
}
.kz-open   { background: rgba(63,185,80,.18);  color: var(--accent-green); }
.kz-closed { background: var(--bg-base);        color: var(--text-muted);  }

.kz-countdown { font-size: .68rem; color: var(--text-muted); }

.p3-phase {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .45rem .6rem;
    border-radius: 6px;
    border-left: 3px solid transparent;
    background: var(--bg-panel);
}
.p3-accum   { border-color: var(--accent-blue); }
.p3-manip   { border-color: var(--accent-red);  }
.p3-distrib { border-color: var(--accent-green);}

.p3-name { font-size: .82rem; font-weight: 700; color: var(--text-primary); }
.p3-desc { font-size: .7rem;  color: var(--text-muted); }

.p3-clock { font-size: .72rem; color: var(--text-muted); margin-top: .3rem; }
.p3-tz    { color: var(--text-muted); font-size: .68rem; }

/* ===== CRT / CISD Checklist Widgets ===== */
.checklist {
    display: flex;
    flex-direction: column;
    gap: .45rem;
    padding: .6rem .75rem .75rem;
}

.cl-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .4rem;
}

.cl-label {
    font-size: .75rem;
    font-weight: 600;
    color: var(--text-secondary);
    flex-shrink: 0;
}

.cl-toggles { display: flex; gap: .3rem; flex-wrap: wrap; }

.cl-tog {
    font-size: .72rem;
    font-weight: 600;
    padding: .2rem .55rem;
    border-radius: 4px;
    border: 1px solid var(--border);
    background: var(--bg-panel);
    color: var(--text-secondary);
    cursor: pointer;
    transition: background .12s, color .12s, border-color .12s;
}
.cl-tog:hover { border-color: var(--text-secondary); color: var(--text-primary); }
.cl-tog.cl-bull { background: rgba(63,185,80,.18);  color: var(--accent-green); border-color: var(--accent-green); }
.cl-tog.cl-bear { background: rgba(248,81,73,.18);  color: var(--accent-red);   border-color: var(--accent-red);   }
.cl-tog.cl-active { background: rgba(88,166,255,.18); color: var(--accent-blue); border-color: var(--accent-blue); }

.cl-check {
    display: flex;
    align-items: center;
    gap: .45rem;
    font-size: .78rem;
    color: var(--text-secondary);
    cursor: pointer;
    user-select: none;
}
.cl-check input[type="checkbox"] {
    width: 14px;
    height: 14px;
    accent-color: var(--accent-gold);
    cursor: pointer;
    flex-shrink: 0;
}

.cl-notes {
    width: 100%;
    min-height: 60px;
    resize: vertical;
    padding: .4rem .55rem;
    background: var(--bg-panel);
    border: 1px solid var(--border);
    border-radius: 5px;
    color: var(--text-primary);
    font-size: .78rem;
    font-family: inherit;
    outline: none;
    transition: border-color .15s;
    margin-top: .15rem;
}
.cl-notes:focus { border-color: var(--accent-blue); }

.cl-reset { align-self: flex-end; margin-top: .1rem; }
