:root {
    --bg: #111110;
    --surface: #1e1e1b;
    --surface2: #2a2a25;
    --surface3: #333330;
    --orange: #e8801a;
    --orange-dim: #8a4e10;
    --text: #ccc8bc;
    --text-dim: #706b60;
    --text-dimmer: #3d3b35;
    --highlight: #2e2e28;
    --timeline-h: 64px;
    --ruler-h: 24px;
    --header-h: 96px;
  }
  * { margin:0; padding:0; box-sizing:border-box; }
  body {
    background: var(--bg); color: var(--text);
    font-family: 'DM Mono', monospace;
    overflow: hidden; height: 100vh; width: 100vw;
    cursor: none; user-select: none;
  }
  #cursor {
    position:fixed; width:10px; height:10px;
    border:1.5px solid var(--orange); border-radius:50%;
    pointer-events:none; z-index:10000;
    transform:translate(-50%,-50%);
  }
  #cursor-ring {
    position:fixed; width:30px; height:30px;
    border:1px solid rgba(232,128,26,0.22); border-radius:50%;
    pointer-events:none; z-index:9999;
    transform:translate(-50%,-50%);
    transition:width .25s,height .25s;
  }
  /* HEADER */
  #header {
    position:fixed; top:0; left:0; right:0; height:var(--header-h);
    background:var(--bg); border-bottom:1px solid var(--surface2);
    z-index:200; display:flex; align-items:center; padding:0 28px; gap:20px;
  }
  #title {
    font-family:'Bebas Neue'; font-size:28px; letter-spacing:.1em;
    color:var(--orange); white-space:nowrap; flex-shrink:0; line-height:1;
  }
  #title span {
    display:block; font-size:8px; letter-spacing:.25em;
    color:var(--text-dim); margin-top:4px; font-family:'DM Mono'; text-transform:uppercase;
  }
  /* MINIMAP */
  #mm-wrap { flex:1; max-width:540px; margin-left:auto; }
  #mm-era {
    display:flex; justify-content:space-between;
    font-size:10px; color:var(--text-dimmer); letter-spacing:.1em; margin-bottom:6px;
  }
  #mm-track {
    height:34px; background:var(--surface); border:1px solid var(--surface2);
    position:relative; overflow:hidden;
    cursor:crosshair; transition:border-color .15s;
  }
  #mm-track:hover { border-color:var(--surface3); }
  #mm-track.dragging { cursor:grabbing; border-color:var(--orange-dim); }
  #mm-canvas { position:absolute; inset:0; pointer-events:none; }
  #mm-vp {
    position:absolute; top:0; bottom:0;
    background:rgba(255,255,255,0.08);
    border-left:2px solid rgba(255,255,255,0.9);
    border-right:2px solid rgba(255,255,255,0.9);
    pointer-events:none;
  }
  #mm-label {
    position:absolute; top:-17px; font-size:9px; color:#fff;
    letter-spacing:.1em; white-space:nowrap; pointer-events:none;
    transform:translateX(-50%); opacity:0.7;
  }
  #mm-hover {
    position:absolute; bottom:-20px; font-size:9px; color:var(--orange);
    letter-spacing:.1em; background:var(--bg); padding:1px 5px;
    border:1px solid var(--orange-dim); white-space:nowrap;
    pointer-events:none; opacity:0; transition:opacity .15s;
    transform:translateX(-50%);
  }
  /* ADMIN BTN */
  #admin-btn {
    flex-shrink:0; padding:7px 16px; background:transparent;
    border:1px solid var(--surface2); color:var(--text-dim);
    font-family:'DM Mono'; font-size:10px; letter-spacing:.15em;
    text-transform:uppercase; cursor:pointer; transition:all .2s;
  }
  #admin-btn:hover { border-color:var(--orange); color:var(--orange); }
  /* TIMELINE */
  #tl-wrap { position:fixed; top:var(--header-h); left:0; right:0; bottom:0; overflow:hidden; }
  #tl-scroll { position:absolute; top:0; height:100%; will-change:transform; }
  /* RULER — two lines, dates float between them */
  #ruler {
    position:absolute; left:0; right:0; height:var(--ruler-h);
    background:transparent; border:none;
  }
  /* Top line — above-cards connectors touch this */
  #ruler::before {
    content:''; position:absolute; left:0; right:0;
    top:0; height:1px; background:var(--surface3);
  }
  /* Bottom line — below-cards connectors touch this */
  #ruler::after {
    content:''; position:absolute; left:0; right:0;
    bottom:0; height:1px; background:var(--surface3);
  }
  .r-mark {
    position:absolute; top:0; bottom:0;
    display:flex; align-items:center; justify-content:center;
    transform:translateX(-50%);
    padding:0 4px;
  }
  .r-label {
    font-size:10px; color:var(--text-dim); letter-spacing:.1em;
    white-space:nowrap; line-height:1; text-transform:uppercase;
  }
  .r-tick { display:none; }
  /* HIST BAR — fixed to bottom of window */
  #hist-bar {
    position:fixed; bottom:0; left:0; right:0; height:var(--timeline-h);
    background:var(--bg); border-top:1px solid var(--surface2); z-index:10;
  }
  .h-evt { position:absolute; transform:translateX(-50%); }
  .h-pill {
    background:var(--surface); border:1px solid var(--surface2);
    border-radius:20px; padding:5px 13px; font-size:11px;
    color:var(--text-dim); white-space:nowrap; letter-spacing:.03em;
    transition:all .18s; cursor:default;
  }
  .h-pill:hover { background:var(--highlight); color:var(--text); border-color:var(--surface3); }
  /* ART MOVEMENTS */
  .art-mv {
    position:absolute; cursor:pointer;
    border-top:2px solid var(--orange-dim); transition:border-color .2s;
  }
  .art-mv:hover { border-top-color:var(--orange); }
  .art-mv-bg { display:none; }
  .art-mv-label {
    position:absolute; top:-21px; left:4px; font-size:11px;
    color:var(--text-dim); letter-spacing:.1em; text-transform:uppercase;
    white-space:nowrap; transition:color .2s;
  }
  .art-mv:hover .art-mv-label { color:var(--orange); }
  /* CONNECTORS */
  .connector { position:absolute; width:1px; background:var(--surface2); pointer-events:none; }
  .ruler-dot {
    position:absolute; width:5px; height:5px; border-radius:50%;
    background:var(--orange); transform:translateX(-50%); pointer-events:none;
  }
  /* TYPO EVENT CARDS */
  .t-evt { position:absolute; cursor:pointer; transform:translateX(-50%); }
  .t-card {
    background:var(--surface); border:1px solid var(--surface2);
    border-radius:3px; padding:9px 12px; display:flex; gap:10px; align-items:center;
    min-width:160px; max-width:230px; transition:border-color .18s,background .18s;
  }
  .t-card:hover { border-color:var(--orange); background:var(--highlight); }
  .t-thumb {
    width:46px; height:46px; flex-shrink:0; background:var(--surface2);
    border-radius:2px; overflow:hidden; display:flex; align-items:center; justify-content:center; font-size:20px;
  }
  .t-thumb img { width:100%; height:100%; object-fit:cover; }
  .t-date { font-size:11px; color:var(--text-dim); letter-spacing:.07em; margin-bottom:3px; }
  .t-name { font-size:14px; color:var(--orange); line-height:1.3; font-family:'Crimson Pro',serif; font-style:italic; }
  /* POPUP */
  #popup {
    position:fixed; z-index:300; opacity:0; pointer-events:none;
    transition:opacity .22s, top .15s;
  }
  #popup.on { opacity:1; pointer-events:all; }
  #popup-box {
    background:var(--surface); color:var(--text); border-radius:5px; padding:24px;
    width:480px; max-height:80vh; overflow-y:auto;
    border:1px solid var(--surface2);
    box-shadow:0 24px 80px rgba(0,0,0,.75); position:relative;
  }
  #popup-x {
    position:absolute; top:10px; right:10px; width:24px; height:24px;
    border-radius:50%; background:var(--orange); border:none; cursor:pointer;
    color:var(--bg); font-size:13px; display:flex; align-items:center; justify-content:center;
  }
  #popup-date { font-size:11px; color:var(--orange); letter-spacing:.14em; margin-bottom:6px; font-family:'DM Mono'; text-transform:uppercase; }
  #popup-title { font-size:24px; font-family:'Crimson Pro',serif; font-weight:600; color:var(--text); margin-bottom:14px; line-height:1.2; }
  #popup-img { width:140px; height:105px; object-fit:cover; float:left; margin:0 16px 10px 0; border-radius:2px; }
  #popup-img.hidden { display:none; }
  #popup-desc { font-size:14px; line-height:1.7; color:var(--text-dim); font-family:'Crimson Pro',serif; }
  .popup-clear { clear:both; }
  /* ART TOOLTIP */
  #art-tt { position:fixed; z-index:300; opacity:0; pointer-events:none; transition:opacity .18s; }
  #art-tt.on { opacity:1; }
  #art-tt-box { background:rgba(14,13,11,.97); border:1px solid var(--orange-dim); padding:16px 20px; width:360px; }
  #att-dates { font-size:11px; color:var(--orange); letter-spacing:.12em; margin-bottom:4px; }
  #att-name { font-size:24px; font-family:'Bebas Neue'; letter-spacing:.08em; color:var(--orange); margin-bottom:10px; }
  #att-desc { font-size:14px; color:var(--text-dim); line-height:1.65; font-family:'Crimson Pro',serif; }
/* ── ADMIN — full screen ───────────────────────────────────────── */
#admin-panel {
  position:fixed; inset:0; z-index:500; display:none;
  flex-direction:column; background:var(--bg);
}
#admin-panel.on { display:flex; }

/* Header bar */
#adm-header {
  display:flex; align-items:center; gap:0;
  height:56px; flex-shrink:0;
  background:var(--surface); border-bottom:1px solid var(--surface2);
  padding:0 24px;
}
#adm-title {
  display:flex; align-items:baseline; gap:12px; flex-shrink:0;
  font-family:'Bebas Neue'; font-size:20px; letter-spacing:.1em; color:var(--orange);
}
#adm-subtitle { font-size:10px; color:var(--text-dimmer); letter-spacing:.15em; font-family:'DM Mono'; }
#adm-tabs { display:flex; gap:2px; margin:0 24px; }
.a-tab {
  padding:6px 16px; background:transparent; border:1px solid transparent;
  color:var(--text-dim); font-family:'DM Mono'; font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; cursor:pointer; transition:all .15s;
  border-radius:3px;
}
.a-tab.on { background:var(--orange-bg,rgba(232,128,26,.1)); border-color:var(--orange-dim); color:var(--orange); }
.a-tab:hover:not(.on) { color:var(--text); border-color:var(--surface3); }
#adm-header-actions { display:flex; gap:8px; margin-left:auto; align-items:center; }
#adm-add-btn {
  padding:6px 16px; background:var(--orange); border:none;
  color:var(--bg); font-family:'DM Mono'; font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; cursor:pointer;
  border-radius:3px; transition:opacity .15s;
}
#adm-add-btn:hover { opacity:.85; }
#admin-x {
  padding:6px 14px; background:transparent; border:1px solid var(--surface2);
  color:var(--text-dim); font-family:'DM Mono'; font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; cursor:pointer;
  border-radius:3px; transition:all .15s;
}
#admin-x:hover { border-color:var(--orange); color:var(--orange); }

/* Two-panel body */
#adm-body {
  display:flex; flex:1; overflow:hidden;
}

/* LEFT — list panel */
#adm-list-col {
  width:320px; flex-shrink:0;
  border-right:1px solid var(--surface2);
  display:flex; flex-direction:column;
  background:var(--surface);
}
#adm-list-search {
  padding:12px 16px; border-bottom:1px solid var(--surface2); flex-shrink:0;
}
#adm-search {
  width:100%; background:var(--bg); border:1px solid var(--surface2);
  border-radius:3px; padding:7px 10px; color:var(--text);
  font-family:'DM Mono'; font-size:11px; outline:none; transition:border-color .15s;
}
#adm-search:focus { border-color:var(--orange-dim); }
#adm-list {
  flex:1; overflow-y:auto; padding:8px;
}
#adm-list::-webkit-scrollbar { width:4px; }
#adm-list::-webkit-scrollbar-thumb { background:var(--surface3); border-radius:2px; }
.adm-row {
  padding:10px 12px; border-radius:4px; cursor:pointer;
  border:1px solid transparent; margin-bottom:2px;
  transition:background .12s, border-color .12s;
}
.adm-row:hover { background:var(--surface2); }
.adm-row-active { background:var(--surface2) !important; border-color:var(--orange-dim) !important; }
.adm-row-name {
  font-family:'Crimson Pro',serif; font-style:italic;
  font-size:13px; color:var(--text); line-height:1.3; margin-bottom:2px;
}
.adm-row-date { font-size:9px; color:var(--text-dimmer); letter-spacing:.08em; }
.adm-empty-list { padding:24px; text-align:center; font-size:11px; color:var(--text-dimmer); }

/* RIGHT — edit panel */
#adm-edit-col {
  flex:1; display:flex; flex-direction:column;
  overflow-y:auto; background:var(--bg);
}
#adm-edit-empty {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  color:var(--text-dimmer); gap:12px;
}
#adm-edit-empty-icon { font-size:36px; opacity:.2; }
#adm-edit-empty div:last-child { font-size:11px; letter-spacing:.1em; }
#adm-edit-form {
  flex-direction:column; padding:28px 32px; gap:0;
}
#adm-edit-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:28px; padding-bottom:18px;
  border-bottom:1px solid var(--surface2);
}
#adm-edit-title {
  font-family:'Crimson Pro',serif; font-size:20px;
  font-style:italic; color:var(--text);
}
#adm-edit-actions { display:flex; gap:8px; }
#adm-save-btn {
  padding:7px 20px; background:var(--orange); border:none;
  color:var(--bg); font-family:'DM Mono'; font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; cursor:pointer;
  border-radius:3px; transition:opacity .15s;
}
#adm-save-btn:hover { opacity:.85; }
#adm-delete-btn {
  padding:7px 14px; background:transparent; border:1px solid var(--surface2);
  color:var(--text-dim); font-family:'DM Mono'; font-size:10px;
  letter-spacing:.12em; text-transform:uppercase; cursor:pointer;
  border-radius:3px; transition:all .15s;
}
#adm-delete-btn:hover { border-color:#d04444; color:#d04444; }

/* Fields */
.adm-fields { display:flex; flex-direction:column; gap:18px; }
.adm-field { display:flex; flex-direction:column; gap:5px; }
.adm-field-row { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.adm-field label {
  font-size:9px; color:var(--text-dimmer); letter-spacing:.16em;
  text-transform:uppercase; display:flex; align-items:center; gap:8px;
}
.adm-hint { color:var(--text-dimmer); font-size:8px; letter-spacing:.08em; text-transform:none; opacity:.7; }
.adm-fields input, .adm-fields textarea, .adm-fields select {
  background:var(--surface); border:1px solid var(--surface2);
  border-radius:3px; padding:9px 12px; color:var(--text);
  font-family:'DM Mono'; font-size:12px; outline:none;
  transition:border-color .15s;
}
.adm-fields input:focus, .adm-fields textarea:focus, .adm-fields select:focus {
  border-color:var(--orange-dim);
}
.adm-fields textarea { resize:vertical; line-height:1.6; }
.adm-fields select option { background:var(--surface); }
#adm-save-status {
  margin-top:16px; font-size:11px; color:var(--green,#4a9e6b); letter-spacing:.08em;
}
  /* ZONES */
  #zone-l,#zone-r {
    position:fixed; top:var(--header-h); bottom:0; width:90px;
    pointer-events:none; z-index:2; display:flex; align-items:center;
  }
  #zone-l { left:0; background:linear-gradient(to right,rgba(6,6,4,.5),transparent); }
  #zone-r { right:0; background:linear-gradient(to left,rgba(6,6,4,.5),transparent); }
  .z-arr { font-size:20px; color:var(--text-dimmer); opacity:0; transition:opacity .25s; }
  #zone-l .z-arr { margin-left:16px; }
  #zone-r .z-arr { margin-left:auto; margin-right:16px; }

/* ── SEARCH BUTTON ─────────────────────────────────────────────── */
#search-btn {
  flex-shrink:0; padding:7px 16px; background:transparent;
  border:1px solid var(--surface2); color:var(--text-dim);
  font-family:'DM Mono'; font-size:10px; letter-spacing:.15em;
  text-transform:uppercase; cursor:pointer; transition:all .2s;
  margin-left:auto;
}
#search-btn:hover { border-color:var(--orange); color:var(--orange); }

/* ── SEARCH BACKDROP ───────────────────────────────────────────── */
#search-backdrop {
  position:fixed; inset:0; z-index:390;
  background:rgba(6,6,4,0.6);
  opacity:0; pointer-events:none;
  transition:opacity .25s;
  backdrop-filter:blur(3px);
}
#search-backdrop.on { opacity:1; pointer-events:all; }

/* ── SEARCH PANEL — floating centered, slides up from bottom ────── */
#search-panel {
  position:fixed;
  bottom:48px;
  left:50%; transform:translateX(-50%) translateY(32px);
  width:min(660px, 90vw);
  z-index:400;
  background:var(--surface);
  border:1px solid var(--surface3);
  border-radius:10px;
  box-shadow:0 32px 80px rgba(0,0,0,0.7), 0 0 0 1px rgba(232,128,26,0.08);
  display:flex; flex-direction:column;
  max-height:60vh;
  opacity:0; pointer-events:none;
  transition:transform .3s cubic-bezier(.16,1,.3,1), opacity .25s;
}
#search-panel.on {
  opacity:1; pointer-events:all;
  transform:translateX(-50%) translateY(0);
}

/* Input row */
#search-bar {
  display:flex; align-items:center; gap:10px;
  padding:14px 18px;
  border-bottom:1px solid var(--surface2);
  flex-shrink:0;
  border-radius:10px 10px 0 0;
}
#search-icon { font-size:16px; color:var(--orange); flex-shrink:0; }
#search-input {
  flex:1; background:transparent; border:none; outline:none;
  color:var(--text); font-family:'DM Mono',monospace;
  font-size:16px; letter-spacing:.02em;
  caret-color:var(--orange);
}
#search-input::placeholder { color:var(--text-dimmer); }
#search-shortcut {
  font-size:9px; color:var(--text-dimmer);
  letter-spacing:.14em; text-transform:uppercase; flex-shrink:0;
}
#search-close {
  background:none; border:none; color:var(--text-dim);
  font-size:15px; cursor:pointer; padding:3px 6px;
  transition:color .15s; flex-shrink:0;
}
#search-close:hover { color:var(--orange); }

/* Results list */
#search-results {
  overflow-y:auto; padding:8px 12px 16px;
  flex:1;
}
#search-results::-webkit-scrollbar { width:4px; }
#search-results::-webkit-scrollbar-thumb { background:var(--surface3); border-radius:2px; }

.sr-empty {
  padding:28px 0; text-align:center;
  color:var(--text-dimmer); font-size:12px; letter-spacing:.05em;
}
.sr-empty em { color:var(--text-dim); font-style:normal; }

.sr-group-label {
  font-size:9px; color:var(--text-dimmer);
  letter-spacing:.2em; text-transform:uppercase;
  padding:12px 6px 6px; display:flex; align-items:center; gap:8px;
}
.sr-group-label span {
  background:var(--surface2); border:1px solid var(--surface3);
  border-radius:20px; padding:1px 7px;
  color:var(--text-dim); font-size:9px;
}
.sr-item {
  padding:9px 12px; margin-bottom:2px;
  background:transparent; border-radius:5px;
  cursor:pointer; transition:background .12s, border-color .12s;
  border:1px solid transparent;
  display:flex; align-items:baseline; gap:12px;
}
.sr-item:hover { background:var(--surface2); border-color:var(--orange-dim); }
.sr-item-body { flex:1; min-width:0; }
.sr-item-name {
  font-family:'Crimson Pro',serif; font-style:italic;
  font-size:14px; color:var(--orange); margin-bottom:1px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sr-item-meta {
  font-size:9px; color:var(--text-dimmer);
  letter-spacing:.08em; flex-shrink:0;
}
.sr-item-desc {
  font-size:11px; color:var(--text-dim);
  line-height:1.45; font-family:'Crimson Pro',serif;
  margin-top:2px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
#search-results mark {
  background:rgba(232,128,26,0.22);
  color:var(--orange);
  border-radius:2px; padding:0 1px;
}

/* ── TEXT-ONLY INFO EVENTS (no description, no connector) ── */
.t-info {
  position:absolute; cursor:default;
  transform:translateX(-50%);
  text-align:left; max-width:160px;
}
.t-info-date {
  font-size:10px; color:var(--text-dimmer);
  letter-spacing:.08em; margin-bottom:3px;
}
.t-info-name {
  font-size:13px; color:var(--text-dim);
  line-height:1.35; font-family:'Crimson Pro',serif;
}

/* ── LOGIN MODAL ───────────────────────────────────────────────── */
#login-modal {
  position:fixed; inset:0; z-index:600;
  background:rgba(6,6,4,0.92);
  backdrop-filter:blur(8px);
  display:none; align-items:center; justify-content:center;
}
#login-modal.on { display:flex; }
#login-box {
  background:var(--surface);
  border:1px solid var(--surface2);
  border-radius:8px;
  padding:40px 44px;
  width:360px;
  display:flex; flex-direction:column; gap:20px;
  box-shadow:0 32px 80px rgba(0,0,0,0.6);
}
#login-title {
  font-family:'Bebas Neue'; font-size:22px;
  letter-spacing:.12em; color:var(--orange);
  line-height:1;
}
#login-subtitle {
  font-size:10px; color:var(--text-dimmer);
  letter-spacing:.18em; text-transform:uppercase;
  margin-top:-14px;
}
#login-error {
  font-size:11px; color:#d04444;
  letter-spacing:.05em; min-height:16px;
  margin-top:-8px;
}
.login-field { display:flex; flex-direction:column; gap:6px; }
.login-field label {
  font-size:9px; color:var(--text-dimmer);
  letter-spacing:.16em; text-transform:uppercase;
}
.login-field input {
  background:var(--bg); border:1px solid var(--surface2);
  border-radius:3px; padding:10px 12px;
  color:var(--text); font-family:'DM Mono'; font-size:13px;
  outline:none; transition:border-color .15s;
}
.login-field input:focus { border-color:var(--orange-dim); }
#login-btn {
  padding:10px; background:var(--orange); border:none;
  border-radius:3px; color:var(--bg);
  font-family:'DM Mono'; font-size:11px;
  letter-spacing:.14em; text-transform:uppercase;
  cursor:pointer; margin-top:4px; transition:opacity .15s;
}
#login-btn:hover { opacity:.85; }

/* ── FONT SPECIMEN ─────────────────────────────────────────────── */
#popup-specimen {
  margin-top: 16px;
  padding: 18px 20px;
  background: #1a1a17;
  border: 1px solid #2e2e2a;
  border-radius: 3px;
  font-size: 15px;
  line-height: 1.9;
  color: #ccc8bc;
}
#popup-specimen .sp-display { display:block; font-size:36px; font-weight:700; letter-spacing:-0.01em; line-height:1.1; color:#e8801a; margin-bottom:14px; }
#popup-specimen .sp-pangram { display:block; font-size:21px; line-height:24px; color:#ccc8bc; }

#popup-font-links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid #2e2e2a;
}
#popup-font-name {
  font-size: 10px;
  color: var(--text-dim);
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}
#popup-font-btns {
  display: flex;
  gap: 6px;
}
#popup-font-btns a {
  font-size: 9px;
  font-family: 'DM Mono', monospace;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 5px 13px;
  border-radius: 3px;
  text-decoration: none;
  transition: all 0.15s;
  border: 1px solid var(--surface2);
  color: var(--text-dim);
  background: transparent;
}
#popup-font-btns a:hover {
  border-color: var(--orange-dim);
  color: var(--orange);
  background: var(--orange-bg);
}