@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  color-scheme: dark;
  --bg: #0a0a1f;
  --bg2: #050510;
  --ink: #d4c8ff;
  --ink2: rgba(212,200,255,.78);
  --muted: rgba(212,200,255,.55);
  --faint: rgba(212,200,255,.18);
  --panel: rgba(5,5,16,.86);
  --panel-soft: rgba(10,10,31,.74);
  --panel2: rgba(212,200,255,.045);
  --line: rgba(212,200,255,.16);
  --line2: rgba(212,200,255,.30);
  --hot: #d4c8ff;
  --accent: #a78bfa;
  --green: #34d399;
  --good: #34d399;
  --warn: #ffbd38;
  --red: #fb2c36;
  --err: #fb2c36;
  --blue: #60a5fa;
  --shadow: 0 24px 80px rgba(0,0,0,.45);

  /* legacy aliases used by Notes */
  --arc-bg: var(--bg);
  --arc-ink: var(--ink);
  --arc-ink2: var(--ink2);
  --arc-muted: var(--muted);
  --arc-line: var(--line);
  --arc-line2: var(--line2);
  --arc-panel: var(--panel);
  --arc-panel2: var(--panel2);
}

:root[data-theme="amber"] {
  --bg: #170d02;
  --bg2: #050200;
  --ink: #ffbd38;
  --ink2: rgba(255,189,56,.78);
  --muted: rgba(255,189,56,.54);
  --faint: rgba(255,189,56,.18);
  --panel: rgba(23,13,2,.82);
  --panel-soft: rgba(23,13,2,.76);
  --panel2: rgba(255,189,56,.045);
  --line: rgba(255,189,56,.18);
  --line2: rgba(255,189,56,.34);
  --hot: #ffbd38;
  --accent: #ffbd38;
}

:root[data-theme="forest"] {
  --bg: #041c1c;
  --bg2: #020b0b;
  --ink: #ffe6cb;
  --ink2: rgba(255,230,203,.78);
  --muted: rgba(255,230,203,.54);
  --faint: rgba(255,230,203,.18);
  --panel: rgba(4,28,28,.82);
  --panel-soft: rgba(4,28,28,.76);
  --panel2: rgba(255,230,203,.04);
  --line: rgba(255,230,203,.16);
  --line2: rgba(255,230,203,.30);
  --hot: #ffe6cb;
  --accent: #34d399;
}

:root[data-theme="mono"] {
  --bg: #050505;
  --bg2: #000;
  --ink: #f4f4f5;
  --ink2: rgba(244,244,245,.76);
  --muted: rgba(244,244,245,.50);
  --faint: rgba(244,244,245,.16);
  --panel: rgba(5,5,5,.86);
  --panel-soft: rgba(5,5,5,.82);
  --panel2: rgba(244,244,245,.04);
  --line: rgba(244,244,245,.16);
  --line2: rgba(244,244,245,.32);
  --hot: #f4f4f5;
  --accent: #f4f4f5;
  --green: #f4f4f5;
  --good: #f4f4f5;
  --warn: #f4f4f5;
  --red: #f4f4f5;
  --err: #f4f4f5;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  min-width: 0;
}

html {
  background: var(--bg);
  color: var(--ink);
  font-size: 15px;
  -webkit-text-size-adjust: 100%;
}

body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

button, input, textarea, select {
  font: inherit;
}

button, a {
  -webkit-tap-highlight-color: transparent;
}

::selection {
  background: var(--ink);
  color: var(--bg);
}

.personal-grid-bg::before,
.personal-grid-bg::after {
  pointer-events: none;
}

.personal-mono {
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
}

.personal-theme-button,
.personal-button {
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  text-transform: uppercase;
  letter-spacing: .12em;
  border: 1px solid var(--line2);
  background: transparent;
  color: var(--ink2);
  cursor: pointer;
}

.personal-theme-button:hover,
.personal-button:hover {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

.personal-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 12px var(--green);
  flex: 0 0 auto;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }
}

/* WebView/mobile readiness guards for first-party personal apps */
html, body {
  overscroll-behavior-x: none;
}

@media (max-width: 860px) {
  input, textarea, select {
    font-size: 16px !important;
  }

  button,
  input,
  select,
  textarea,
  .personal-button,
  .personal-theme-button,
  .nav a,
  .nav button {
    min-height: 38px;
  }
}


/* Shared shell aliases for older modules using app-* names. New modules should use personal-* classes. */
.app-shell{display:grid;grid-template-columns:230px minmax(0,1fr);min-height:100vh}
.app-side{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:rgba(5,5,16,.72);backdrop-filter:blur(16px);display:flex;flex-direction:column;z-index:10;overflow-y:auto}
.app-brand{min-height:72px;border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 1rem;gap:.8rem;flex-shrink:0}
.app-sig{width:34px;height:34px;border:1px solid var(--line2);display:grid;place-items:center;font:700 .75rem 'JetBrains Mono',monospace;letter-spacing:.12em;flex-shrink:0}
.app-wordmark{font:700 .76rem/.96 'JetBrains Mono',monospace;letter-spacing:.16em;text-transform:uppercase}
.app-nav{padding:.8rem 0;border-bottom:1px solid var(--line)}
.app-nav .nav-sep{display:block;margin:1rem 1rem .7rem;border-top:2px solid var(--line2);height:0}
.app-nav a,.app-nav button{display:flex;width:100%;align-items:center;gap:.7rem;padding:.68rem 1rem;color:var(--ink2);font:500 .68rem 'JetBrains Mono',monospace;letter-spacing:.13em;text-transform:uppercase;background:none;border:0;text-align:left;cursor:pointer;text-decoration:none}
.app-nav a::before,.app-nav button::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 10px currentColor;opacity:.55;flex:0 0 6px}
.app-nav .active,.app-nav a:hover,.app-nav button:hover{background:var(--ink);color:var(--bg)}
.app-meta{margin-top:auto;padding:1rem;display:grid;gap:.55rem;border-top:1px solid var(--line);flex-shrink:0}
.app-pill{border:1px solid var(--line);background:transparent;padding:.4rem .55rem;font:500 .66rem 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);display:flex;gap:.4rem;align-items:center}
button.app-pill{width:100%;cursor:pointer;text-align:left}
.app-main{min-width:0;overflow:hidden}
.theme-mobile{display:none!important}
@media(max-width:860px){
  .app-shell{display:block;min-height:100dvh}
  .app-side{position:sticky;top:0;width:100%;height:auto;z-index:30;border-right:0;border-bottom:1px solid var(--line);background:rgba(5,5,16,.92);overflow:visible}
  .app-brand{min-height:52px;padding:0 .75rem;gap:.55rem}
  .app-sig{width:28px;height:28px;font-size:.68rem}
  .app-wordmark{font-size:.68rem;letter-spacing:.11em}
  .app-nav{display:flex;overflow-x:auto;gap:.3rem;padding:.5rem .6rem;border-bottom:0;scrollbar-width:none;-webkit-overflow-scrolling:touch}
  .app-nav::-webkit-scrollbar{display:none}
  .app-nav a,.app-nav button{flex:0 0 auto;width:auto;border:1px solid var(--line);background:var(--panel2);padding:.5rem .55rem;min-height:36px;font-size:.6rem;letter-spacing:.08em}
  .app-nav a::before,.app-nav button::before{display:none}
  .app-nav .nav-sep{flex:0 0 2px;width:2px;height:28px;margin:.1rem .35rem;border-top:0;border-left:2px solid var(--line2)}
  .app-meta{display:none}
}

/* ═══════════════════════════════════════════════════════════════
   Shared layout & components for all personal web app modules
   ═══════════════════════════════════════════════════════════════ */

/* Shell layout (sidebar + main) */
.personal-shell{display:grid;grid-template-columns:230px minmax(0,1fr);min-height:100vh}
.personal-side{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:rgba(5,5,16,.72);backdrop-filter:blur(16px);display:flex;flex-direction:column;z-index:10;overflow-y:auto}
.personal-brand{min-height:72px;border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 1rem;gap:.8rem;flex-shrink:0}
.personal-sig{width:34px;height:34px;border:1px solid var(--line2);display:grid;place-items:center;font:700 .75rem 'JetBrains Mono',monospace;letter-spacing:.12em;flex-shrink:0}
.personal-wordmark{font:700 .76rem/.96 'JetBrains Mono',monospace;letter-spacing:.16em}
.personal-nav{padding:.8rem 0;border-bottom:1px solid var(--line)}
.personal-nav .personal-nav-sep{display:block;margin:1rem 1rem .7rem;border-top:2px solid var(--line2);height:0}
.personal-nav a,.personal-nav button{display:flex;width:100%;align-items:center;gap:.7rem;padding:.68rem 1rem;color:var(--ink2);font:500 .68rem 'JetBrains Mono',monospace;letter-spacing:.13em;text-transform:uppercase;background:none;border:0;text-align:left;cursor:pointer;text-decoration:none}
.personal-nav a::before,.personal-nav button::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 10px currentColor;opacity:.55;flex:0 0 6px}
.personal-nav .active,.personal-nav a:hover,.personal-nav button:hover{background:var(--ink);color:var(--bg)}
.personal-meta{margin-top:auto;padding:1rem;display:grid;gap:.55rem;border-top:1px solid var(--line);flex-shrink:0}
.personal-pill{border:1px solid var(--line);background:transparent;padding:.4rem .55rem;font:500 .66rem 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);display:flex;gap:.4rem;align-items:center}
button.personal-pill{width:100%;cursor:pointer;text-align:left}

/* Main content */
.personal-main{padding:1.5rem clamp(1rem,3vw,3rem) calc(2.5rem + env(safe-area-inset-bottom));min-width:0;overflow:hidden}
.personal-top{display:flex;justify-content:space-between;gap:1.5rem;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap}

/* Typography */
.personal-eyebrow{font:500 .7rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.16em;color:var(--muted);margin-bottom:.5rem}
.personal-tag{font:500 .62rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border:1px solid var(--line);padding:.2rem .45rem;background:var(--panel2)}
.personal-subtle{font-size:.82rem;color:var(--muted);line-height:1.5}
.personal-muted{color:var(--muted)}

/* Buttons */
.personal-btn{font:500 .7rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.12em;border:1px solid var(--line2);background:var(--panel2);color:var(--ink);padding:.5rem .75rem;min-width:38px;min-height:38px;cursor:pointer;white-space:nowrap;flex-shrink:0}
.personal-btn:hover,.personal-btn.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.personal-btn.disabled{opacity:.45;cursor:not-allowed}

/* Controls */
.personal-controls{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.personal-controls input,.personal-controls select{background:rgba(0,0,0,.25);border:1px solid var(--line);color:var(--ink);padding:.5rem .65rem;font:500 .82rem 'JetBrains Mono',monospace;min-width:0;flex:0 1 auto}
.personal-controls input:focus,.personal-controls select:focus{border-color:var(--line2);outline:none}
.personal-controls input{flex:1 1 140px;min-width:80px}
.personal-sel-sm{font-size:.6rem!important;padding:.15rem .2rem!important;min-width:0!important;border:none!important;background:var(--bg)!important;color:var(--muted)!important;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='4'%3E%3Cpath d='M0 0l3 4 3-4z' fill='%23d4c8ff' opacity='.5'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right center!important;padding-right:10px!important}
.personal-sel-sm option{background:var(--bg)!important;color:var(--ink)!important}

/* Tabs */
.personal-tabs{display:flex;flex-wrap:wrap;gap:.4rem;margin:1rem 0 1.2rem}
.personal-tab{font:500 .7rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.12em;border:1px solid var(--line);background:var(--panel2);color:var(--muted);padding:.5rem .85rem;cursor:pointer;white-space:nowrap;flex-shrink:0}
.personal-tab.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.personal-tab:hover:not(.active){border-color:var(--line2);color:var(--ink2)}

/* Card grid */
.personal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(360px,100%),1fr));gap:.9rem}
.personal-card{background:var(--panel);border:1px solid var(--line);backdrop-filter:blur(12px);min-width:0;overflow:hidden}
.personal-card.full{grid-column:1/-1}
.personal-head{display:flex;align-items:center;gap:.75rem;padding:.8rem 1rem;border-bottom:1px solid var(--line);min-height:52px;min-width:0;overflow:hidden;flex-wrap:wrap}
.personal-head .personal-label{font:600 .72rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.14em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.personal-head .personal-tag{margin-left:auto;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.personal-body{padding:.85rem 1rem;min-width:0;overflow:hidden}

/* Stat cards */
.personal-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(170px,100%),1fr));gap:.65rem}
.personal-mini{background:var(--panel2);border:1px solid var(--line);padding:.75rem .85rem;min-width:0;overflow:hidden}
.personal-mini .personal-stat-label{font:500 .62rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.13em;color:var(--muted);margin-bottom:.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.personal-mini .personal-metric{font:600 clamp(.9rem,2.5vw,1.2rem) 'JetBrains Mono',monospace;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.personal-metric.pos{color:var(--green)}.personal-metric.neg{color:var(--red)}

/* Tables */
.personal-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
.personal-table{width:100%;border-collapse:collapse;font:500 .78rem 'JetBrains Mono',monospace;min-width:0}
.personal-table thead th{font:600 .66rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);padding:.55rem .6rem;border-bottom:1px solid var(--line);text-align:right;white-space:nowrap;cursor:pointer;position:sticky;top:0;background:var(--panel)}
.personal-table thead th:hover{color:var(--ink)}
.personal-table thead th.sorted{color:var(--ink)}
.personal-table thead th:first-child,.personal-table tbody td:first-child{text-align:left}
.personal-table tbody td{padding:.45rem .6rem;border-bottom:1px solid rgba(212,200,255,.06);text-align:right;white-space:nowrap;color:var(--ink2)}
.personal-table tbody tr:hover td{background:rgba(212,200,255,.03)}

/* Status dot */
.personal-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green);flex-shrink:0}
.personal-dot.on{background:var(--green)}.personal-dot.warn{background:var(--warn)}.personal-dot.bad{background:var(--red);animation:personal-blink .8s infinite}
@keyframes personal-blink{50%{opacity:.3}}

/* Status box */
.personal-statusbox{border:1px solid var(--line);background:var(--panel);padding:.85rem 1rem;min-width:180px;backdrop-filter:blur(8px)}
.personal-statusbox .personal-stat-label{font:500 .68rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}
.personal-statusbox .personal-metric{font:500 1.15rem 'JetBrains Mono',monospace}

/* Chart containers */
.personal-chart{width:100%;min-height:320px;overflow:hidden}
.personal-chart-sm{width:100%;min-height:280px;overflow:hidden}

/* Side-by-side */
.personal-two{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:1rem}
.personal-sidebyside{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.9rem}
.personal-splitline{height:1px;background:var(--line);margin:1rem 0}

/* Raw / view */
.personal-raw{white-space:pre-wrap;font:500 .74rem 'JetBrains Mono',monospace;color:var(--muted);max-width:100%;overflow:auto;max-height:70vh;line-height:1.6;overflow-wrap:anywhere}
.personal-view{display:none}.personal-view.active{display:block}

/* Bid/ask bar */
.personal-bar{height:8px;border-radius:4px;overflow:hidden;display:flex;margin-top:.4rem;background:var(--line)}
.personal-bar .bid{background:var(--green);height:100%}.personal-bar .ask{background:var(--red);height:100%}

/* Performance controls */
.personal-perf-controls{display:grid;grid-template-columns:minmax(92px,.75fr) minmax(0,1fr) minmax(0,1fr);gap:.45rem;margin-bottom:.65rem;align-items:stretch}
.personal-perf-group{border:1px solid var(--line);background:var(--panel2);padding:.35rem;display:grid;grid-template-rows:auto 1fr;gap:.28rem;min-width:0}
.personal-perf-label{font:600 .52rem 'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);line-height:1}
.personal-perf-seg{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.25rem;min-width:0}
.personal-perf-readout{margin-top:.45rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ═══════════ RESPONSIVE ═══════════ */
@media(max-width:1100px){.personal-two{grid-template-columns:1fr}.personal-cards{grid-template-columns:repeat(auto-fill,minmax(min(150px,100%),1fr))}}
@media(min-width:1400px){.personal-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.personal-card.wide{grid-column:span 2}}
@media(min-width:1800px){.personal-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.personal-card.wide{grid-column:span 2}.personal-main{max-width:2200px;margin:0 auto}}

@media(max-width:860px){
html{font-size:14px}body{min-height:100dvh}
.personal-shell{display:block}
.personal-side{position:sticky;top:0;width:100%;height:auto;z-index:30;border-right:0;border-bottom:1px solid var(--line);background:rgba(5,5,16,.92);overflow:visible}
.personal-brand{min-height:52px;padding:0 .75rem;gap:.55rem}
.personal-sig{width:28px;height:28px;font-size:.68rem}
.personal-wordmark{font-size:.68rem;letter-spacing:.11em}
.personal-nav{display:flex;overflow-x:auto;gap:.3rem;padding:.5rem .6rem;border-bottom:0;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.personal-nav::-webkit-scrollbar{display:none}
.personal-nav a,.personal-nav button{flex:0 0 auto;width:auto;border:1px solid var(--line);background:var(--panel2);padding:.5rem .55rem;min-height:36px;font-size:.6rem;letter-spacing:.08em}
.personal-nav a::before,.personal-nav button::before{display:none}
.personal-nav .personal-nav-sep{flex:0 0 2px;width:2px;height:28px;margin:.1rem .35rem;border-top:0;border-left:2px solid var(--line2)}
.personal-meta{display:none}
.personal-main{padding:1rem .75rem calc(1.5rem + env(safe-area-inset-bottom))}
.personal-top{display:block;margin-bottom:1rem}
.personal-statusbox{margin-top:.7rem;width:100%}
.personal-grid{grid-template-columns:1fr!important;gap:.65rem}
.personal-cards{grid-template-columns:repeat(auto-fill,minmax(min(140px,100%),1fr));gap:.5rem}
.personal-controls input,.personal-controls select{font-size:16px;min-height:40px;flex:1 1 100px}
.personal-sel-sm{font-size:16px!important;min-width:42px!important;min-height:38px!important;padding:.35rem 1.3rem .35rem .45rem!important;border:1px solid var(--line)!important;background-color:var(--panel2)!important}
.personal-btn{font-size:.65rem;padding:.45rem .6rem;min-height:38px}
.personal-perf-controls{grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.55rem}
.personal-perf-group:first-child{grid-column:1/-1}
.personal-tab{font-size:.62rem;padding:.45rem .6rem;min-height:38px}
.personal-table{font-size:.72rem}
.personal-table thead th{font-size:.6rem;padding:.45rem .4rem}
.personal-table tbody td{padding:.4rem;font-size:.7rem}
.personal-sidebyside{grid-template-columns:1fr}
}

@media(max-width:480px){
.personal-main{padding:.75rem .55rem calc(1.2rem + env(safe-area-inset-bottom))}
.personal-mini{padding:.6rem}
.personal-mini .personal-metric{font-size:.95rem}
.personal-cards{grid-template-columns:repeat(auto-fill,minmax(min(130px,100%),1fr));gap:.4rem}
.personal-controls{flex-direction:column}
.personal-controls input,.personal-controls select,.personal-controls button{width:100%;flex:1 1 auto}
.personal-btn,.personal-tab{padding:.4rem .5rem;font-size:.6rem;min-height:38px}
.personal-sel-sm{font-size:16px!important;min-height:38px!important;padding:.35rem 1.3rem .35rem .45rem!important;border:1px solid var(--line)!important;background-color:var(--panel2)!important}
.personal-head{padding:.6rem .7rem}
.personal-body{padding:.65rem .7rem}
.personal-chart{min-height:260px}.personal-chart-sm{min-height:220px}
}
