/* ============================================================
   Glance — Nordic night theme
   Type: Schibsted Grotesk (UI) · Spline Sans Mono (data)
   ============================================================ */

:root {
  --ink:      #06090f;
  --panel:    #0d131d;
  --panel-hi: #121a27;
  --line:     rgba(148, 163, 184, 0.10);
  --line-hi:  rgba(148, 163, 184, 0.22);
  --text:     #e7edf6;
  --muted:    #8b97ab;
  --faint:    #5a6577;
  --green:    #45d6a0;
  --amber:    #efb454;
  --ember:    #ef6f6c;
  --ice:      #7fb8e8;
  --violet:   #8f8af4;
  --sans: 'Schibsted Grotesk', system-ui, -apple-system, sans-serif;
  --mono: 'Spline Sans Mono', ui-monospace, 'SF Mono', monospace;
  --radius: 16px;
}

* { box-sizing: border-box; }

/* Render native form controls (select dropdowns, scrollbars, autofill)
   in dark mode — fixes white-on-white option lists in settings. */
:root { color-scheme: dark; }
select, input, textarea, option, optgroup { color-scheme: dark; }
select option, select optgroup {
  background-color: #0d131d;
  color: #e7edf6;
}
select optgroup { font-style: normal; color: #8b97ab; }

html, body { margin: 0; padding: 0; }

body {
  background: var(--ink);
  color: var(--text);
  font-family: var(--sans);
  font-size: 15px;
  line-height: 1.45;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Aurora wash — static, GPU-cheap, sits behind everything */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(900px 420px at 12% -8%,  rgba(69, 214, 160, 0.10), transparent 62%),
    radial-gradient(1100px 480px at 62% -12%, rgba(143, 138, 244, 0.09), transparent 60%),
    radial-gradient(700px 380px at 96% -6%,  rgba(127, 184, 232, 0.07), transparent 60%);
}

body.idle, body.idle * { cursor: none !important; }

header.top, main.grid, footer.credits { position: relative; z-index: 1; }

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

:focus-visible { outline: 2px solid var(--ice); outline-offset: 2px; border-radius: 6px; }

/* ---------- Offline banner ---------- */
.offline {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: rgba(239, 180, 84, 0.14);
  border-bottom: 1px solid rgba(239, 180, 84, 0.4);
  color: var(--amber);
  font: 500 12px var(--mono);
  text-align: center;
  padding: 6px 12px;
  letter-spacing: 0.04em;
}

/* ---------- Header ---------- */
header.top {
  max-width: 1680px;
  margin: 0 auto;
  padding: 22px 26px 6px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.brand { display: flex; align-items: center; gap: 14px; }

.brand-dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: radial-gradient(circle at 32% 30%, var(--green), var(--violet) 78%);
  box-shadow: 0 0 14px rgba(69, 214, 160, 0.55);
  flex: none;
}

.brand h1 {
  margin: 0;
  font-size: 21px;
  font-weight: 800;
  letter-spacing: 0.055em;
  text-transform: uppercase;
}

.tagline {
  margin: 1px 0 0;
  font: 500 11px var(--mono);
  color: var(--muted);
  letter-spacing: 0.08em;
}

.top-actions { display: flex; align-items: center; gap: 8px; }

.loc-pill {
  font: 500 12px var(--mono);
  color: var(--muted);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 13px;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.icon-btn {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.icon-btn:hover { color: var(--text); border-color: var(--line-hi); }
.icon-btn svg { width: 18px; height: 18px; }

/* ---------- Grid ---------- */
main.grid {
  max-width: 1680px;
  margin: 0 auto;
  padding: 16px 26px 8px;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  align-items: stretch;
}

.area-clock   { grid-column: span 3; }
.area-weather { grid-column: span 9; }
.area-elec    { grid-column: span 8; }
.area-fx      { grid-column: span 4; }
.area-markets { grid-column: span 6; }
.area-commod  { grid-column: span 3; }
.area-crypto  { grid-column: span 3; }

@media (max-width: 1180px) {
  .area-clock   { grid-column: span 4; }
  .area-weather { grid-column: span 8; }
  .area-elec    { grid-column: span 12; }
  .area-fx      { grid-column: span 6; }
  .area-markets { grid-column: span 12; }
  .area-commod  { grid-column: span 6; }
  .area-crypto  { grid-column: span 6; }
  /* keep fx next to something: reorder */
  .area-fx { order: 4; }
  .area-markets { order: 3; }
  .area-commod { order: 5; }
  .area-crypto { order: 6; }
  .area-elec { order: 2; }
  .area-clock, .area-weather { order: 1; }
}

@media (max-width: 760px) {
  main.grid { padding: 12px 14px; gap: 12px; }
  header.top { padding: 16px 14px 2px; }
  main.grid > section { grid-column: span 12 !important; }
  .tagline { display: none; }
}

/* ---------- Card ---------- */
.card {
  background: linear-gradient(180deg, var(--panel-hi), var(--panel) 70%);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 16px 18px 12px;
  display: flex;
  flex-direction: column;
  min-width: 0;
  position: relative;
}

.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}

.card-label {
  font: 600 10.5px var(--mono);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}

.card-meta { font: 500 11px var(--mono); color: var(--faint); letter-spacing: 0.05em; }

.card-foot {
  margin-top: auto;
  padding-top: 10px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.card-foot .src { font: 400 10px var(--mono); color: var(--faint); letter-spacing: 0.03em; }
.card-foot .upd { font: 500 10px var(--mono); color: var(--faint); }
.card-foot .upd.err { color: var(--amber); }

.live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px rgba(69, 214, 160, 0.7);
  animation: pulse 2.6s ease-in-out infinite;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.35; } }
@media (prefers-reduced-motion: reduce) {
  .live-dot { animation: none; }
}

.placeholder { color: var(--faint); font: 400 13px var(--mono); padding: 8px 0 14px; }

.mini-select {
  background: rgba(148, 163, 184, 0.07);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 8px;
  font: 500 12px var(--mono);
  padding: 5px 8px;
  max-width: 210px;
  cursor: pointer;
}
.mini-select:hover { border-color: var(--line-hi); }

/* ---------- Clock ---------- */
.clock { display: flex; flex-direction: column; gap: 8px; flex: 1; justify-content: center; padding-bottom: 8px; }

.clock-time {
  font: 600 clamp(44px, 4.2vw, 62px)/1 var(--mono);
  letter-spacing: -0.01em;
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-variant-numeric: tabular-nums;
}
.clock-secs { font-size: 0.42em; color: var(--green); font-weight: 500; }

.clock-date { font-size: 15px; color: var(--muted); font-weight: 500; }

.clock-meta { display: flex; align-items: center; gap: 12px; margin-top: 4px; flex-wrap: wrap; }

.chip {
  font: 600 11px var(--mono);
  color: var(--text);
  background: rgba(148, 163, 184, 0.09);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 3px 10px;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.sun { font: 500 11.5px var(--mono); color: var(--muted); display: inline-flex; gap: 12px; }
.sun svg { width: 13px; height: 13px; vertical-align: -2px; margin-right: 3px; }

/* ---------- Weather ---------- */
.wx { display: flex; flex-direction: column; gap: 12px; flex: 1; }

.wx-now { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }

.wx-icon { width: 58px; height: 58px; color: var(--ice); flex: none; }
.wx-icon svg { width: 100%; height: 100%; }

.wx-temp {
  font: 600 44px/1 var(--mono);
  font-variant-numeric: tabular-nums;
  display: flex; align-items: flex-start; gap: 2px;
}
.wx-temp .unit { font-size: 20px; color: var(--muted); margin-top: 4px; font-weight: 500; }

.wx-desc { color: var(--muted); font-weight: 500; margin-top: 3px; }

.wx-stats {
  margin-left: auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(86px, auto));
  gap: 7px 18px;
}
@media (max-width: 900px) { .wx-stats { margin-left: 0; grid-template-columns: repeat(3, 1fr); width: 100%; } }

.wx-stat { display: flex; flex-direction: column; gap: 1px; }
.wx-stat b { font: 500 13.5px var(--mono); font-weight: 500; }
.wx-stat span { font: 500 9.5px var(--mono); color: var(--faint); text-transform: uppercase; letter-spacing: 0.1em; }

.aqi { display: inline-flex; align-items: center; gap: 6px; }
.aqi i { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }

.wx-hourly { width: 100%; height: 96px; display: block; }

.wx-days {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}
.wx-day { display: flex; flex-direction: column; align-items: center; gap: 3px; min-width: 0; }
.wx-day .d  { font: 600 10px var(--mono); color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; }
.wx-day .i  { width: 26px; height: 26px; color: var(--ice); }
.wx-day .i svg { width: 100%; height: 100%; }
.wx-day .t  { font: 500 12px var(--mono); }
.wx-day .t small { color: var(--faint); font-size: 11px; margin-left: 4px; }

/* ---------- Electricity (hero) ---------- */
.el-now {
  display: flex;
  align-items: baseline;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.el-price { display: flex; align-items: baseline; gap: 8px; }

.el-big {
  font: 600 clamp(40px, 3.6vw, 54px)/1 var(--mono);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.015em;
}
.el-unit { font: 500 14px var(--mono); color: var(--muted); }

.el-sub { font: 500 12.5px var(--mono); color: var(--faint); }

.el-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-left: auto; }
.el-chips .chip b { font-weight: 600; }
.el-chips .chip .lo { color: var(--green); }
.el-chips .chip .hi { color: var(--ember); }

.el-chart-wrap { position: relative; }
#elChart { width: 100%; height: 210px; display: block; }

.tip {
  position: absolute;
  pointer-events: none;
  background: #0a0f18;
  border: 1px solid var(--line-hi);
  border-radius: 8px;
  padding: 6px 10px;
  font: 500 11.5px var(--mono);
  white-space: nowrap;
  z-index: 5;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.5);
}
.tip b { color: var(--green); }

.el-tomorrow { font: 500 11.5px var(--mono); color: var(--muted); margin-top: 6px; min-height: 16px; }

/* ---------- Data rows (markets, fx, commodities, crypto) ---------- */
.rows { display: flex; flex-direction: column; flex: 1; }

.row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 84px auto;
  align-items: center;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
}
.row:last-child { border-bottom: none; }

.row .nm { min-width: 0; }
.row .nm b { display: block; font-size: 13.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.row .nm span { font: 500 10.5px var(--mono); color: var(--faint); letter-spacing: 0.04em; }

.row canvas { width: 84px; height: 32px; display: block; }

.row .val { text-align: right; }
.row .val b { display: block; font: 500 14px var(--mono); font-variant-numeric: tabular-nums; white-space: nowrap; }
.row .val small { font: 500 10px var(--mono); color: var(--faint); }

.delta {
  display: inline-block;
  font: 600 11px var(--mono);
  border-radius: 6px;
  padding: 1.5px 6px;
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.delta.up   { color: var(--green); background: rgba(69, 214, 160, 0.11); }
.delta.down { color: var(--ember); background: rgba(239, 111, 108, 0.11); }
.delta.flat { color: var(--muted); background: rgba(148, 163, 184, 0.10); }

.row-err { font: 400 11px var(--mono); color: var(--amber); padding: 6px 0; }

/* ---------- Credits ---------- */
footer.credits {
  max-width: 1680px;
  margin: 0 auto;
  padding: 6px 26px 22px;
  font: 400 10.5px var(--mono);
  color: var(--faint);
  letter-spacing: 0.02em;
}

/* ---------- Settings dialog ---------- */
dialog {
  background: var(--panel-hi);
  color: var(--text);
  border: 1px solid var(--line-hi);
  border-radius: 18px;
  padding: 0;
  width: min(520px, calc(100vw - 32px));
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.65);
}
dialog::backdrop { background: rgba(4, 6, 10, 0.72); }

.dlg-form { padding: 24px 26px 20px; display: flex; flex-direction: column; gap: 16px; }

.dlg-form h2 { margin: 0 0 2px; font-size: 17px; letter-spacing: 0.02em; }

.field { display: flex; flex-direction: column; gap: 6px; }
.field > span { font: 600 10.5px var(--mono); color: var(--muted); text-transform: uppercase; letter-spacing: 0.12em; }
.field em { text-transform: none; letter-spacing: 0; font-style: normal; color: var(--faint); font-weight: 400; }

.field select, .field input, .field textarea {
  background: rgba(148, 163, 184, 0.06);
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--text);
  font: 500 13px var(--mono);
  padding: 9px 11px;
  width: 100%;
  resize: vertical;
}
.field select:focus, .field input:focus, .field textarea:focus {
  outline: none; border-color: var(--ice);
}

.city-results {
  margin-top: -10px;
  border: 1px solid var(--line-hi);
  border-radius: 10px;
  overflow: hidden;
  background: #0a0f18;
}
.city-results button {
  display: block; width: 100%;
  text-align: left;
  background: none; border: none;
  color: var(--text);
  font: 500 12.5px var(--mono);
  padding: 9px 12px;
  cursor: pointer;
  border-bottom: 1px solid var(--line);
}
.city-results button:last-child { border-bottom: none; }
.city-results button:hover { background: rgba(127, 184, 232, 0.09); }
.city-results button small { color: var(--faint); }

.hint { margin: -6px 0 0; font: 500 11px var(--mono); color: var(--green); min-height: 14px; }

.dlg-actions { display: flex; align-items: center; gap: 10px; margin-top: 4px; }
.dlg-actions .spacer { flex: 1; }

.btn {
  font: 600 13px var(--sans);
  border-radius: 10px;
  padding: 9px 16px;
  cursor: pointer;
  border: 1px solid var(--line-hi);
  background: transparent;
  color: var(--text);
}
.btn.ghost:hover { border-color: var(--muted); }
.btn.solid {
  background: linear-gradient(135deg, var(--green), #2fb586);
  border: none;
  color: #04110b;
}
.btn.solid:hover { filter: brightness(1.08); }

/* clock card head right side (timezone label + live dot) */
.clock-right { display: inline-flex; align-items: center; gap: 8px; }
