
:root{
  --bg:#000;
  --fg:#fff;
  --muted:#9aa3af;
  --card:#0a0a0a;
  --border:#1f2937;
  --accent:#e5e7eb;
  --font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans","Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol",sans-serif;
}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;}
.tsp-root{max-width:1100px;margin:0 auto;padding:20px;}
.title{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;margin:0 0 18px 0;}
.title-brand{font-weight:800;letter-spacing:.18em;text-transform:uppercase;line-height:1;font-size:clamp(32px,5.6vw,58px);}
.title-portal{font-weight:600;letter-spacing:.12em;text-transform:uppercase;line-height:1.05;opacity:.95;font-size:clamp(18px,3.4vw,30px);}
.card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 16px;box-shadow:0 0 0 1px rgba(255,255,255,.02) inset;}
.lock,#tsp-apps{margin-top:24px;}
.card-title{margin:0 0 6px 0;font-size:18px;font-weight:700}
.card-desc{margin:0 0 14px 0;color:var(--muted);font-size:14px}
.pin-form{display:flex;gap:8px;align-items:center}
/* PIN input – clearer, larger, centered */
.pin-input{
  flex: 0 0 auto;
  width: 240px;
  max-width: 60vw;
  background:#0f0f0f;
  border:2px solid var(--border);
  border-radius:12px;
  color:var(--fg);
  padding:12px 14px;
  font-size:28px;
  letter-spacing:.35em;
  text-align:center;
  font-variant-numeric: lining-nums;
  outline:none;
}
.pin-input::placeholder{color:#444}
.btn{background:#1f2937;border:1px solid var(--border);color:var(--fg);padding:12px 16px;border-radius:12px;cursor:pointer;font-size:16px}
.btn:hover{background:#2a3647}
.error{color:#ff6b6b;min-height:1em;margin-top:8px;font-size:14px}
.infobar{display:flex;flex-direction:column;gap:10px;align-items:center;margin-top:18px;margin-bottom:8px}
.ticker{width:100%;overflow:hidden;border:1px solid var(--border);border-radius:10px;background:#0b0b0b}
.ticker-track{display:flex;align-items:center;gap:40px;white-space:nowrap;padding:8px 14px;will-change:transform}
.ticker-track .sep{display:inline-block;width:40px}
.weather{font-size:16px;color:var(--accent)}
.forecast-card{margin-top:8px;margin-bottom:28px}
#tsp-forecast{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}
.fx{display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px 10px;min-width:82px}
.fx .d{font-size:12px;color:var(--muted)}
.fx .i{font-size:20px;line-height:1}
.fx .t{font-size:12px}
/* Bigger provider cards */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.app{display:flex;align-items:center;justify-content:center;gap:10px;background:#111;border:1px solid var(--border);border-radius:12px;padding:24px 18px;text-decoration:none;color:var(--fg);transition:transform .15s ease;min-height:96px}
.app:hover{transform:scale(1.04);background:#151515}
.app .logo{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center}
.app .logo img{max-width:100%;max-height:100%;display:block}
.app .name{font-size:16px}

/* PIN keypad (screen keyboard) */
.pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px;user-select:none}
.key{background:#151515;border:1px solid var(--border);border-radius:12px;padding:14px 0;font-size:22px;color:var(--fg);cursor:pointer;touch-action:manipulation;transition:transform .06s ease,background .12s ease}
.key:active{transform:scale(0.96);background:#181818}
.key-del,.key-ok{font-weight:700}
.key-ok{background:#1f2937}
.key-ok:hover{background:#2a3647}
