.stock { display: grid; gap: 28px; /* Prevent overflow on small screens */ width: 100%; } .stock-header { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); gap: 24px; align-items: center; } .stock-kicker { text-transform: uppercase; letter-spacing: 0.3em; font-size: 12px; color: var(--accent); margin: 0 0 10px; } .stock-header h1 { margin: 0 0 12px; font-family: var(--font-display); font-size: clamp(30px, 4vw, 40px); } .stock-sub { margin: 0; color: var(--muted); } .stock-actions { display: flex; gap: 12px; margin-top: 18px; flex-wrap: wrap; } .stock-card { border: 1px solid var(--line); border-radius: 20px; padding: 20px; background: var(--surface); display: grid; gap: 14px; } .stock-ideas { margin: 0; padding-left: 18px; color: var(--muted); font-size: 13px; display: grid; gap: 6px; } .stock-card__title { margin: 0; font-weight: 600; } .stock-status { display: grid; gap: 10px; color: var(--muted); font-size: 13px; } .stock-status>div { display: flex; justify-content: space-between; gap: 12px; } .stock-status strong { color: var(--text); } .stock-status__note { margin: 0; color: var(--muted); font-size: 12px; } .stock-pill { padding: 4px 10px; border-radius: 999px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; border: 1px solid var(--line); } .stock-pill.is-ok { border-color: rgba(106, 220, 187, 0.6); color: #b5f0dd; } .stock-pill.is-warn { border-color: rgba(245, 200, 115, 0.6); color: #f5d28a; } .stock-pill.is-unknown { color: var(--muted); } .stock-error { margin: 0; color: #f9b6b1; border: 1px solid rgba(249, 182, 177, 0.4); border-radius: 14px; padding: 12px; background: rgba(249, 182, 177, 0.1); } .stock-success { margin: 0; color: #b5f0dd; border: 1px solid rgba(106, 220, 187, 0.4); border-radius: 14px; padding: 12px; background: rgba(106, 220, 187, 0.12); } .stock-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; } .stock-panel { border: 1px solid var(--line); background: var(--surface); border-radius: 24px; padding: 20px; display: grid; gap: 16px; } .stock-panel--wide { grid-column: 1 / -1; } .stock-filter-row { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); align-items: stretch; } .stock-filter-row .stock-panel { width: 100%; max-width: none; } .stock-panel__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; flex-wrap: wrap; } .stock-panel__eyebrow { margin: 0 0 6px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.22em; color: var(--accent); } .stock-panel__sub { margin: 6px 0 0; color: var(--muted); font-size: 13px; } .stock-panel__actions { display: flex; gap: 8px; align-items: center; } .stock-chip { font-size: 11px; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--line); color: var(--muted); text-transform: uppercase; letter-spacing: 0.12em; } .stock-snapshot { display: grid; gap: 12px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); } .stock-snapshot__card { border: 1px solid var(--line); border-radius: 14px; padding: 12px; display: grid; gap: 6px; background: rgba(0, 0, 0, 0.2); min-height: 94px; } .stock-snapshot__card.is-highlight { border-color: rgba(255, 255, 255, 0.4); background: rgba(255, 255, 255, 0.05); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08); } .stock-snapshot__card p { margin: 0; font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); } .stock-snapshot__card strong { font-size: 20px; } .stock-snapshot__card span { color: var(--muted); font-size: 12px; } .stock-snapshot__change { font-size: 12px; color: var(--muted); } .stock-snapshot__change.is-up { color: #f3a7a7; } .stock-snapshot__change.is-down { color: #9fc5ff; } .stock-schedule { display: grid; gap: 12px; font-size: 13px; color: var(--muted); } .stock-schedule strong { color: var(--text); } .stock-filter { display: grid; gap: 12px; color: var(--muted); font-size: 13px; } .stock-filter label { display: grid; gap: 8px; } .stock-filter select { border: 1px solid var(--line); background: rgba(0, 0, 0, 0.25); color: var(--text); border-radius: 12px; padding: 10px 12px; } .stock-filter__note { margin: 0; font-size: 12px; } .stock-news { display: grid; gap: 14px; } .stock-tabs { display: flex; gap: 8px; margin-bottom: 10px; } .stock-tab { border: 1px solid var(--line); background: rgba(0, 0, 0, 0.2); color: var(--muted); border-radius: 999px; padding: 6px 12px; font-size: 12px; cursor: pointer; transition: border-color 0.2s ease, color 0.2s ease; } .stock-tab.is-active { border-color: rgba(255, 255, 255, 0.5); color: var(--text); } .stock-news__item { border: 1px solid var(--line); border-radius: 16px; padding: 16px; display: grid; gap: 10px; background: rgba(0, 0, 0, 0.2); } .stock-news__title { margin: 0; font-weight: 600; font-size: 16px; } .stock-news__summary { margin: 6px 0 0; color: var(--muted); font-size: 13px; } .stock-news__meta { display: flex; gap: 12px; flex-wrap: wrap; font-size: 12px; color: var(--muted); align-items: center; } .stock-news__meta a { color: var(--accent); } .stock-empty { margin: 0; color: var(--muted); } .stock-trade { display: grid; gap: 16px; } .stock-balance { display: grid; gap: 12px; } .stock-balance__summary { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; } .stock-balance__card { border: 1px solid var(--line); border-radius: 14px; padding: 10px; display: grid; gap: 6px; background: rgba(0, 0, 0, 0.2); font-size: 12px; color: var(--muted); } .stock-balance__card strong { font-size: 16px; color: var(--text); } .stock-holdings { display: grid; gap: 8px; } .stock-holdings__item { border: 1px solid var(--line); border-radius: 12px; padding: 10px; display: grid; grid-template-columns: minmax(0, 1.2fr) repeat(5, minmax(0, 0.6fr)); gap: 10px; font-size: 13px; color: var(--muted); background: rgba(255, 255, 255, 0.02); align-items: center; } .stock-holdings__name { margin: 0; font-weight: 600; color: var(--text); font-size: 14px; } .stock-holdings__code { font-size: 12px; } .stock-holdings__metric { display: grid; gap: 4px; justify-items: start; } .stock-holdings__metric span { font-size: 11px; color: var(--muted); } .stock-holdings__metric strong { font-size: 14px; color: var(--text); } .stock-profit { color: var(--text); } .stock-profit.is-up { color: #f3a7a7; } .stock-profit.is-down { color: #9fc5ff; } .stock-profit.is-flat { color: var(--muted); } .stock-result { border: 1px solid var(--line); border-radius: 14px; padding: 12px; background: rgba(0, 0, 0, 0.2); margin-top: 10px; } .stock-result__title { margin: 0; font-size: 12px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--muted); } .stock-result pre { margin: 8px 0 0; white-space: pre-wrap; font-size: 12px; color: var(--muted); } .stock-modal { position: fixed; inset: 0; z-index: 50; display: grid; place-items: center; } .stock-modal__backdrop { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.55); } .stock-modal__card { position: relative; width: min(520px, 90vw); border: 1px solid var(--line); border-radius: 16px; background: var(--surface); padding: 16px; display: grid; gap: 12px; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4); } .stock-modal__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; } .stock-modal__head h4 { margin: 0; font-size: 16px; } .stock-modal pre { margin: 0; white-space: pre-wrap; font-size: 12px; color: var(--muted); } .stock-order { display: grid; gap: 10px; } .stock-order label { display: grid; gap: 6px; font-size: 12px; color: var(--muted); } .stock-order input, .stock-order select { border: 1px solid var(--line); border-radius: 12px; padding: 10px 12px; background: rgba(0, 0, 0, 0.25); color: var(--text); outline: none; } @media (max-width: 900px) { .stock-header { grid-template-columns: 1fr; } } @media (max-width: 768px) { .stock { gap: 20px; } .stock-panel { padding: 16px; gap: 12px; } .stock-filter-row { gap: 12px; grid-template-columns: 1fr; } .stock-header h1 { font-size: 28px; } .stock-actions { width: 100%; } .stock-actions .button { flex: 1; text-align: center; justify-content: center; } .stock-card { padding: 16px; } .stock-status>div { gap: 8px; } .stock-status strong { font-size: 14px; word-break: break-word; } .stock-balance__summary { grid-template-columns: 1fr; } .stock-holdings__item { grid-template-columns: minmax(0, 1fr); gap: 12px; align-items: start; } .stock-holdings__name { font-size: 15px; } .stock-holdings__metric { grid-template-columns: repeat(2, 1fr); align-items: center; justify-items: start; gap: 8px 16px; } /* Make the last item span full width if it's odd */ .stock-holdings__metric>*:last-child:nth-child(odd) { grid-column: 1 / -1; } .stock-holdings__metric span { font-size: 11px; } .stock-holdings__metric strong { font-size: 15px; word-break: break-word; } } @media (max-width: 520px) { .stock-holdings__metric { grid-template-columns: minmax(0, 1fr); } .stock-holdings__metric strong { font-size: 14px; } }