*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* === THROUGH HISTORY palette: black + crimson + gold === */
  --bg-deep:#0a0907;          /* deepest black, like the logo bg */
  --bg-soft:#161108;          /* near-black with a warm tint */
  --bg-panel:#1f1709;         /* dark panel bg */
  --bg-card:#26190a;          /* slightly lifted dark surface */

  --parchment:#f4ead3;        /* warm cream for content surfaces */
  --parchment-2:#e7dab6;
  --parchment-3:#d3c298;

  --ink:#1a1308;              /* darkest text */
  --ink-2:#3a2c14;
  --ink-3:#6b563a;
  --ink-4:#9a8868;

  /* Brand colors from the logo */
  --gold:#e0a82e;             /* the ring of the logo */
  --gold-2:#f0c14a;           /* highlight gold */
  --gold-3:#a87a16;           /* deep gold */
  --gold-soft:rgba(224,168,46,.18);
  --crimson:#b91c1c;          /* the eye of Horus */
  --crimson-2:#dc2626;
  --crimson-3:#7c1818;

  /* Backwards compatibility aliases (CSS still references these) */
  --accent:#b91c1c;           /* was brown — now crimson */
  --accent-2:#e0a82e;         /* was brass — now gold */
  --accent-3:#7c1818;         /* deep crimson */
  --success:#1e8449;
  --danger:#dc2626;
  --header-h:80px;
  --sidebar-w:380px;
  --shadow:0 14px 34px rgba(0,0,0,.45);
  --shadow-soft:0 6px 18px rgba(0,0,0,.25);
  --map-bright:1;
}
html,body{height:100%}
body{font-family:'Crimson Pro',serif;background:var(--bg-deep);color:var(--ink);overflow:hidden}
button,input,select,textarea{font:inherit}
button{border:none;cursor:pointer}
main{height:calc(100vh - var(--header-h))}

header{height:var(--header-h);background:linear-gradient(180deg,#0c0905,#040302);display:flex;align-items:center;justify-content:space-between;padding:0 22px;gap:16px;border-bottom:1px solid rgba(224,168,46,.22);box-shadow:0 2px 18px rgba(0,0,0,.5)}
.logo{display:flex;align-items:center;gap:14px;min-width:280px}
.logo-img{width:46px;height:46px;border-radius:14px;object-fit:contain;padding:6px;background:linear-gradient(180deg,rgba(18,12,7,.95),rgba(8,5,3,.92));box-shadow:0 4px 14px rgba(224,168,46,.2),0 0 0 1px rgba(224,168,46,.38)}
.logo-text{font-family:'Cinzel',serif;font-size:18px;font-weight:700;color:var(--gold-2);letter-spacing:1.6px;text-transform:uppercase}
.logo-text span{color:var(--crimson-2)}
.logo-sub{font-size:11px;color:rgba(240,193,74,.55);letter-spacing:.6px;font-style:italic}
.tab-bar{display:flex;gap:4px;background:rgba(224,168,46,.05);padding:4px;border-radius:10px;border:1px solid rgba(224,168,46,.18)}
.tab-btn{padding:9px 16px;border-radius:8px;background:transparent;color:rgba(240,193,74,.6);font-size:13px;font-family:'Cinzel',serif;letter-spacing:.5px;transition:.18s}
.tab-btn:hover{color:var(--gold-2)}
.tab-btn.active{background:linear-gradient(180deg,#3a1818,#1a0a0a);color:var(--gold-2);box-shadow:inset 0 0 0 1px rgba(224,168,46,.45),0 2px 8px rgba(185,28,28,.3)}
.header-right{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.add-btn{padding:7px 12px;border:1px solid rgba(224,168,46,.5);background:rgba(224,168,46,.04);color:var(--gold-2);border-radius:8px;font-family:'Cinzel',serif;font-size:11px;font-weight:700;letter-spacing:.4px;transition:.18s}
.add-btn:hover{background:var(--gold);color:#1a0a0a;border-color:var(--gold)}

.page{display:none;height:100%}
.page.active{display:flex}

#mapPage{display:none}
#mapPage.active{display:flex}
.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,var(--parchment),#e7dab6);border-right:1px solid var(--gold-3);display:flex;flex-direction:column;overflow:hidden;box-shadow:inset -1px 0 0 rgba(224,168,46,.18)}
.sb-tabs{display:flex;border-bottom:1px solid var(--parchment-3);background:rgba(255,255,255,.4)}
.sb-tab{flex:1;padding:11px 8px;background:transparent;color:var(--ink-3);font-family:'Cinzel',serif;font-size:11px;letter-spacing:.6px;text-transform:uppercase;border-bottom:2px solid transparent}
.sb-tab.active{color:var(--crimson);border-bottom-color:var(--crimson);background:rgba(255,255,255,.5)}
.sb-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.sb-head,.page-toolbar,.table-head{display:flex;align-items:center;justify-content:space-between}
.sb-head{padding:14px 16px;border-bottom:1px solid var(--parchment-3);gap:10px}
.sb-head h2{font-family:'Cinzel',serif;font-size:15px}
.badge,.chip,.detail-label,.year-badge,.range-readout,.mini-chip{font-family:'JetBrains Mono',monospace}
.badge{font-size:11px;color:var(--ink-3);background:rgba(255,255,255,.55);padding:3px 10px;border-radius:999px;border:1px solid var(--parchment-3)}
.sb-search{padding:12px;border-bottom:1px solid var(--parchment-3);display:flex;flex-direction:column}
.stack-gap{gap:8px}
.sb-search input,.sb-search select,.form-grid input,.form-grid select,.form-grid textarea{width:100%;padding:9px 11px;border:1px solid var(--parchment-3);background:rgba(255,255,255,.58);border-radius:8px;color:var(--ink);outline:none}
.sb-search input:focus,.sb-search select:focus,.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,168,46,.18)}
.dual-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.ghost-btn{padding:9px 11px;border:1px solid var(--parchment-3);background:rgba(255,255,255,.5);border-radius:8px;color:var(--ink-2)}
.ghost-btn:hover{border-color:var(--crimson);color:var(--crimson)}
.brightness-row{display:flex;align-items:center;gap:8px;padding:4px 2px}
.brightness-row label{font-size:11px;color:var(--ink-3);min-width:62px;text-transform:uppercase;letter-spacing:.5px;font-family:'Cinzel',serif}
.brightness-row input[type=range]{flex:1;-webkit-appearance:none;appearance:none;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--crimson-3),var(--gold));outline:none}
.brightness-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--parchment);border:2px solid var(--gold)}
.brightness-row input[type=range]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--parchment);border:2px solid var(--gold)}
.brightness-val{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-3);min-width:38px;text-align:right}

.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px;border-bottom:1px solid var(--parchment-3)}
.stat-card{padding:10px;border-radius:12px;background:rgba(255,255,255,.54);border:1px solid var(--parchment-3);box-shadow:var(--shadow-soft)}
.stat-card .label{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.5px}
.stat-card .value{font-family:'Cinzel',serif;font-size:22px;font-weight:700;color:var(--crimson)}
.stat-card .sub{font-size:10px;color:var(--ink-3)}

.map-list{flex:1;overflow:auto;padding:8px;min-height:0}
.map-list::-webkit-scrollbar,.table-wrap::-webkit-scrollbar,.timeline-wrap::-webkit-scrollbar,.detail-body::-webkit-scrollbar{width:7px;height:7px}
.map-list::-webkit-scrollbar-thumb,.table-wrap::-webkit-scrollbar-thumb,.timeline-wrap::-webkit-scrollbar-thumb,.detail-body::-webkit-scrollbar-thumb{background:var(--gold-3);border-radius:999px}
.map-card{display:flex;gap:10px;padding:10px;border-radius:12px;border:1px solid transparent;background:rgba(255,255,255,.4);cursor:pointer;transition:.15s;margin-bottom:8px}
.map-card:hover{border-color:var(--parchment-3);transform:translateY(-1px);background:rgba(255,255,255,.78)}
.map-card.active{border-color:var(--crimson);box-shadow:0 8px 22px rgba(185,28,28,.18);background:rgba(255,255,255,.88)}
.thumb{width:78px;height:58px;border-radius:8px;overflow:hidden;background:var(--parchment-2);flex-shrink:0;border:1px solid rgba(0,0,0,.04)}
.thumb canvas{width:100%;height:100%}
.map-info{min-width:0;flex:1}
.map-info h3{font-family:'Cinzel',serif;font-size:12px;line-height:1.35;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-meta{font-size:11px;color:var(--ink-3);margin-bottom:6px}
.map-description{font-size:12px;color:var(--ink-2);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mini-chip{display:inline-flex;align-items:center;gap:6px;background:var(--crimson);color:var(--gold-2);padding:3px 8px;border-radius:999px;font-size:10px;margin-bottom:6px}
.empty-state{padding:18px;border:1px dashed var(--parchment-3);border-radius:12px;background:rgba(255,255,255,.44);color:var(--ink-3);line-height:1.5}

/* sidebar detail panel */
.detail-body{padding:14px;overflow:auto;flex:1}
.detail-label{font-size:10px;color:var(--ink-3);letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px}
#detailTitle{font-family:'Cinzel',serif;font-size:18px;line-height:1.25}
.detail-meta{font-size:12px;color:var(--ink-3);margin-bottom:10px}
#detailCanvas{width:100%;height:170px;border-radius:12px;background:var(--parchment-2);margin-bottom:10px}
.detail-description{font-size:13px;line-height:1.5;color:var(--ink-2);margin-bottom:10px}
.tag-wrap{display:flex;flex-wrap:wrap;gap:6px}
.tag{padding:4px 10px;border-radius:999px;background:rgba(185,28,28,.08);border:1px solid rgba(185,28,28,.18);font-size:11px;color:var(--ink-2)}
.detail-actions{display:flex;gap:6px;flex-shrink:0}
.mini-btn{padding:7px 10px;border-radius:8px;background:rgba(255,255,255,.7);border:1px solid var(--parchment-3);font-size:12px;color:var(--ink-2);transition:.14s}
.mini-btn:hover{border-color:var(--crimson);color:var(--crimson)}
.mini-btn:disabled{opacity:.5;cursor:not-allowed}
.mini-btn.danger:hover{border-color:var(--danger);color:var(--danger)}

.area-control{margin:8px 0 10px;padding:8px 10px;border:1px dashed var(--parchment-3);border-radius:10px;background:rgba(255,255,255,.5)}
.area-label{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-family:'Cinzel',serif}
.area-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-2);margin-bottom:4px}
.area-row span:first-child{min-width:46px}
.area-val{font-family:'JetBrains Mono',monospace;min-width:44px;text-align:center;color:var(--ink)}

/* clear terrain map with blue oceans — no tint */
.map-area{position:relative;flex:1;background:#a8c8de}
#map{position:absolute;inset:0 0 70px 0;background:#9cc2da}
.leaflet-control-container{display:none}
.leaflet-tile-pane{filter:brightness(calc(var(--map-bright) * 1.0));opacity:1}
.leaflet-container{background:linear-gradient(180deg,#a8c8de,#8fb5cf)}
.leaflet-container::before{content:"";position:absolute;inset:0;pointer-events:none;z-index:401;box-shadow:inset 0 0 30px rgba(0,0,0,.06)}
.leaflet-overlay-pane path{filter:drop-shadow(0 1px 2px rgba(0,0,0,.22))}

/* centered square popup for clicked map items */
.map-info-popup-overlay{position:absolute;inset:0 0 70px 0;display:none;align-items:center;justify-content:center;z-index:900;background:rgba(7,10,16,.16);backdrop-filter:blur(1.5px)}
.map-info-popup-overlay.active{display:flex}
.map-info-popup{position:relative;width:min(360px,calc(100% - 28px));min-height:220px;padding:24px 22px 20px;border-radius:24px;background:linear-gradient(180deg,rgba(244,234,211,.97),rgba(231,218,182,.96));border:1px solid rgba(123,79,138,.18);box-shadow:0 24px 48px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.28) inset;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.map-info-popup-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.72);color:var(--ink);font-size:22px;line-height:1;box-shadow:var(--shadow-soft)}
.map-info-popup-close:hover{background:#fff}
.map-info-popup-icon{display:grid;place-items:center;width:68px;height:68px;border-radius:20px;background:linear-gradient(180deg,#fff8e7,#f3e4b9);border:1px solid rgba(224,168,46,.42);font-size:32px;box-shadow:0 10px 24px rgba(0,0,0,.08);margin-bottom:16px}
.map-info-popup-title{font-family:'Cinzel',serif;font-size:18px;font-weight:700;line-height:1.45;color:var(--crimson-3);letter-spacing:.3px;max-width:100%}
.map-info-popup-sub{margin-top:10px;font-family:'JetBrains Mono',monospace;font-size:11px;line-height:1.5;color:rgba(26,19,8,.72);max-width:100%}

.floating-panel{position:absolute;z-index:650;pointer-events:auto}
.top-left{top:12px;left:12px}
.top-right{top:12px;right:12px}
.z-stack{display:flex;flex-direction:column;gap:6px}
.zoom-btn{width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.92);border:1px solid rgba(0,0,0,.08);font-size:18px;color:var(--ink);box-shadow:var(--shadow)}
.zoom-btn:hover{background:var(--parchment)}
.chip-row{display:flex;flex-wrap:wrap;gap:6px;max-width:calc(100vw - 460px);background:rgba(26,17,8,.82);padding:8px 12px;border-radius:12px;border:1px solid rgba(224,168,46,.3);backdrop-filter:blur(6px)}
.chip{padding:5px 10px;font-size:11px;border-radius:999px;background:linear-gradient(180deg,#1a1108,#0c0905);color:var(--gold-2);box-shadow:var(--shadow-soft);border:1px solid rgba(224,168,46,.35);font-family:'JetBrains Mono',monospace}

/* marker labels below icons */
.marker-label{position:absolute;left:50%;transform:translateX(-50%);top:100%;white-space:nowrap;font-family:'Cinzel',serif;font-size:10px;font-weight:700;color:#1a1308;text-shadow:0 0 3px #fff,0 0 6px #fff,1px 1px 0 #fff,-1px -1px 0 #fff;pointer-events:none;line-height:1.1;text-align:center;margin-top:2px;max-width:120px;overflow:hidden;text-overflow:ellipsis}
.marker-label-battle{color:#6b1010}
.marker-label-event{color:#5a1616}
.marker-label-ruler{color:#3a2c14;font-size:9px;font-weight:600}
.marker-label-person{color:#6b563a;font-size:9px;font-weight:600}

/* polygon center label */
.poly-label{font-family:'Cinzel',serif;font-weight:700;text-align:center;white-space:nowrap;pointer-events:none;text-shadow:0 0 4px #fff,0 0 8px #fff,1px 1px 0 rgba(255,255,255,.85),-1px -1px 0 rgba(255,255,255,.85);letter-spacing:.5px}

/* event marker on map */
.event-marker{width:14px;height:14px;background:var(--crimson-3);border:2px solid var(--gold-2);transform:rotate(45deg);box-shadow:0 4px 12px rgba(0,0,0,.45)}
.place-marker{width:12px;height:12px;border-radius:50%;border:2px solid #f4efe1;box-shadow:0 3px 10px rgba(0,0,0,.4)}

.timeline-bar{position:absolute;left:0;right:0;bottom:0;height:70px;background:linear-gradient(180deg,#0c0905,#040302);display:flex;align-items:center;gap:14px;padding:0 16px;z-index:700;border-top:1px solid rgba(224,168,46,.22);box-shadow:0 -4px 20px rgba(0,0,0,.5)}
.year-input-group{display:flex;align-items:center;gap:3px;background:rgba(0,0,0,.5);border:1px solid rgba(224,168,46,.45);border-radius:10px;padding:4px}
.year-step-btn{width:28px;height:32px;background:transparent;color:var(--gold-2);font-size:16px;font-weight:700;border-radius:6px;transition:.14s;line-height:1}
.year-step-btn:hover{background:rgba(224,168,46,.22)}
.year-input{width:86px;height:32px;background:linear-gradient(180deg,#f4ead3,#e7dab6);border:none;border-radius:6px;text-align:center;font-family:'Cinzel',serif;font-size:15px;font-weight:700;color:var(--ink);outline:none;-moz-appearance:textfield}
.year-input::-webkit-outer-spin-button,.year-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.year-input:focus{box-shadow:0 0 0 2px rgba(224,168,46,.7)}
.slider-wrap{flex:1;display:flex;flex-direction:column;gap:5px}
.ticks{display:flex;justify-content:space-between;font-family:'JetBrains Mono',monospace;font-size:10px;color:rgba(240,193,74,.4)}
#yearSlider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:linear-gradient(90deg,var(--crimson-3),var(--gold),var(--crimson-3))}
#yearSlider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--parchment);border:3px solid var(--gold);box-shadow:0 6px 14px rgba(0,0,0,.4)}
#yearSlider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--parchment);border:3px solid var(--gold)}
.range-readout{font-size:11px;color:rgba(240,193,74,.55);min-width:88px;text-align:right;font-family:'JetBrains Mono',monospace}

/* flag marker (emoji on parchment chip) */
.flag-marker{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:rgba(244,234,211,.95);border:2px solid var(--crimson);font-size:18px;box-shadow:0 4px 12px rgba(0,0,0,.45);cursor:pointer;transform:translateY(-2px)}
.flag-marker.selected{background:var(--gold-2);border-color:var(--crimson-3);transform:translateY(-2px) scale(1.15)}
.country-marker{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;background:rgba(244,234,211,.95);border:2px solid var(--gold-3);font-size:18px;box-shadow:0 4px 12px rgba(0,0,0,.4);cursor:pointer;transform:translateY(-2px)}
.country-marker.selected{background:var(--gold-2);border-color:var(--crimson);transform:translateY(-2px) scale(1.15)}
.battle-marker{width:18px;height:18px;background:var(--crimson-3);border:2px solid #f4efe1;border-radius:3px;display:grid;place-items:center;color:#f4efe1;font-size:11px;font-weight:700;box-shadow:0 3px 10px rgba(0,0,0,.4);transform:rotate(45deg)}
.battle-marker span{transform:rotate(-45deg)}

#timelinePage,#dataPage,#postsPage{flex-direction:column;overflow:hidden;background:linear-gradient(180deg,#f4ead3,#e7dab6)}
#postsPage.active{display:flex;flex-direction:column}
.page-toolbar{padding:14px 20px;border-bottom:1px solid var(--gold-3);background:linear-gradient(180deg,#1a1108,#0c0905);display:flex;justify-content:space-between;align-items:center;gap:12px;z-index:12;box-shadow:0 2px 14px rgba(0,0,0,.4)}
.page-toolbar.compact{padding-bottom:12px}
.page-toolbar h1{font-family:'Cinzel',serif;font-size:20px;margin-bottom:2px;color:var(--gold-2);letter-spacing:1.2px}
.page-toolbar p{color:rgba(240,193,74,.6);font-size:12px;font-style:italic}
.toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.tc-btn{padding:8px 12px;border-radius:8px;border:1px solid rgba(224,168,46,.4);background:rgba(224,168,46,.06);color:var(--gold-2);font-size:12px;font-family:'Cinzel',serif;letter-spacing:.4px;transition:.16s}
.tc-btn:hover{border-color:var(--gold);background:rgba(224,168,46,.18);color:var(--gold-2)}
.tc-btn.pri{background:linear-gradient(180deg,var(--crimson-2),var(--crimson-3));border-color:rgba(224,168,46,.5);color:var(--gold-2);font-weight:700}
.tc-btn.pri:hover{filter:brightness(1.15);box-shadow:0 4px 14px rgba(185,28,28,.4)}
.upload-btn{position:relative;overflow:hidden}

.timeline-wrap{position:relative;flex:1;overflow:auto;touch-action:none;overscroll-behavior:none}
#timelineBg{position:absolute;left:0;top:0;z-index:0;pointer-events:none}
.timelineInner{position:relative;z-index:1;min-height:100%;min-width:max-content}
.timeline-hint{position:sticky;left:14px;top:60px;z-index:25;display:inline-flex;align-items:center;gap:8px;margin:6px 0 0 14px;padding:9px 12px;border-radius:999px;background:rgba(244,234,211,.95);border:1px solid var(--gold-3);box-shadow:0 6px 20px rgba(0,0,0,.18);font-family:'Cinzel',serif;font-size:10px;letter-spacing:.7px;text-transform:uppercase;color:var(--ink-2);backdrop-filter:blur(6px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}
.timeline-hint.hidden{opacity:0;transform:translateY(-8px)}
.timelineColumns{position:sticky;top:0;z-index:20;display:flex;background:linear-gradient(180deg,#1a1108,#0c0905);border-bottom:2px solid rgba(224,168,46,.35);box-shadow:0 2px 12px rgba(0,0,0,.4)}
.timelineColumns span{text-align:center;padding:7px 4px;font-family:'Cinzel',serif;font-size:10px;color:var(--gold-2)}
.era-label{position:absolute;left:2px;font-family:'Cinzel',serif;font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-4);writing-mode:vertical-rl;transform:rotate(180deg);z-index:3;background:rgba(244,234,211,.72);padding:6px 3px;border-radius:4px;backdrop-filter:blur(2px)}
.era-band{position:absolute;left:0;right:0;z-index:0}
.year-line{position:absolute;z-index:1}
.year-line span{position:absolute;left:-40px;top:-6px;width:38px;text-align:right;font-family:'JetBrains Mono',monospace}

/* Civilization bars: solid, filled */
.civ-bar{position:absolute;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;opacity:.92;transition:.14s;z-index:3;box-shadow:0 1px 8px rgba(0,0,0,.25);border:1px solid rgba(0,0,0,.25)}
.civ-bar:hover{filter:brightness(1.12);z-index:5;opacity:1}

/* Country bars: striped (diagonal pattern) so they look distinct from civilizations */
.country-bar{position:absolute;border-radius:4px;cursor:pointer;display:flex;align-items:center;overflow:hidden;opacity:.95;transition:.14s;z-index:4;box-shadow:0 1px 6px rgba(0,0,0,.22);border:none}
.country-bar:hover{filter:brightness(1.15);z-index:5}

.civ-label{writing-mode:vertical-rl;transform:rotate(180deg);font-family:'Cinzel',serif;font-size:9px;font-weight:700;letter-spacing:.7px;color:rgba(255,255,255,.95);text-shadow:0 1px 2px rgba(0,0,0,.45);max-height:92%;overflow:hidden}
.event-dot{position:absolute;z-index:6;cursor:pointer;transition:.12s}
.event-dot:hover{transform:scale(1.35)}
.event-dot-inner{width:10px;height:10px;border-radius:50%;background:var(--gold-2);border:2px solid var(--crimson-3);box-shadow:0 2px 8px rgba(0,0,0,.25)}
.event-tooltip{display:none;position:absolute;left:14px;top:-8px;background:#0c0905;color:var(--gold-2);padding:6px 10px;border-radius:8px;font-size:11px;white-space:nowrap;box-shadow:0 8px 20px rgba(0,0,0,.45);line-height:1.5;z-index:20;border:1px solid rgba(224,168,46,.35)}
.event-dot:hover .event-tooltip{display:block}
.map-pin{position:absolute;z-index:7;cursor:pointer;width:14px;height:14px;background:var(--crimson);border:2px solid var(--gold-2);transform:rotate(45deg);transition:.12s}
.map-pin:hover{transform:rotate(45deg) scale(1.4);z-index:9}

.data-shell{display:flex;flex-direction:column;height:100%}
.table-grid{padding:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;height:100%;overflow:auto}
.table-card{background:linear-gradient(180deg,rgba(255,255,255,.85),rgba(244,234,211,.78));border:1px solid var(--gold-3);border-radius:18px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-soft);min-height:280px;max-height:520px}
.table-head{padding:14px;border-bottom:1px solid var(--parchment-3);background:linear-gradient(180deg,rgba(224,168,46,.1),transparent)}
.table-head h2{font-family:'Cinzel',serif;font-size:14px;color:var(--crimson-3);letter-spacing:.6px;text-transform:uppercase}
.table-wrap{overflow:auto;flex:1}
.table-wrap table{width:100%;border-collapse:collapse;font-size:13px}
.table-wrap th,.table-wrap td{padding:10px 12px;border-bottom:1px solid rgba(0,0,0,.06);vertical-align:top;text-align:left}
.table-wrap th{position:sticky;top:0;background:linear-gradient(180deg,#1a1108,#0c0905);color:var(--gold-2);font-family:'Cinzel',serif;font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.table-actions{display:flex;gap:6px;justify-content:flex-end}
.text-muted{color:var(--ink-3);font-size:11px}

.modal-overlay{display:none;position:fixed;inset:0;background:rgba(8,5,3,.72);z-index:2000;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex}
.modal-box{width:min(680px,92vw);max-height:88vh;overflow:auto;background:linear-gradient(180deg,var(--parchment),#e7dab6);border-radius:20px;border:1px solid var(--gold-3);box-shadow:0 24px 48px rgba(0,0,0,.55),0 0 0 1px rgba(224,168,46,.2) inset;padding:20px}
.modal-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid rgba(224,168,46,.3)}
.modal-head h2{font-family:'Cinzel',serif;font-size:22px;margin-bottom:2px;color:var(--crimson-3);letter-spacing:.5px}
.modal-head p{color:var(--ink-3);font-size:13px;font-style:italic}
.icon-close{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.65);border:1px solid var(--parchment-3);font-size:18px;color:var(--ink-3);transition:.14s}
.icon-close:hover{background:var(--crimson);color:var(--gold-2);border-color:var(--crimson-3)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid .full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group label{font-size:12px;color:var(--ink-2);font-weight:600;font-family:'Cinzel',serif;letter-spacing:.3px}
.form-grid textarea{min-height:80px;resize:vertical}
.color-swatches{display:flex;flex-wrap:wrap;gap:8px;padding-top:4px}
.color-swatch{width:28px;height:28px;border-radius:8px;border:2px solid transparent;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);cursor:pointer;transition:.14s}
.color-swatch:hover{transform:scale(1.05)}
.color-swatch.active{border-color:var(--crimson);transform:scale(1.08);box-shadow:0 0 0 2px rgba(224,168,46,.45)}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
.btn-c,.btn-s{padding:10px 16px;border-radius:10px;font-family:'Cinzel',serif;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;transition:.14s}
.btn-c{background:transparent;border:1px solid var(--parchment-3);color:var(--ink-3)}
.btn-s{background:linear-gradient(180deg,var(--crimson-2),var(--crimson-3));color:var(--gold-2);border:1px solid rgba(224,168,46,.45)}
.btn-c:hover{border-color:var(--crimson);color:var(--crimson)}
.btn-s:hover{filter:brightness(1.15);box-shadow:0 4px 14px rgba(185,28,28,.4)}

/* civilization places sub-section in modal */
.places-section{grid-column:1/-1;border-top:1px dashed var(--gold-3);padding-top:12px;margin-top:4px}
.places-section h3{font-family:'Cinzel',serif;font-size:13px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;color:var(--crimson-3)}
.places-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow:auto}
.place-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:rgba(255,255,255,.55);border:1px solid var(--parchment-3);border-radius:8px;font-size:12px}
.place-row .place-name{font-weight:600;color:var(--ink)}
.place-row .place-coord{font-family:'JetBrains Mono',monospace;color:var(--ink-3);font-size:11px}
.place-row-actions{display:flex;gap:4px}

.toast{position:fixed;right:18px;bottom:18px;z-index:2500;background:linear-gradient(180deg,#1a1108,#0c0905);color:var(--gold-2);padding:12px 16px;border-radius:12px;box-shadow:0 14px 30px rgba(0,0,0,.5);opacity:0;transform:translateY(8px);pointer-events:none;transition:.18s;max-width:320px;border:1px solid rgba(224,168,46,.4);font-family:'Cinzel',serif;font-size:12px;letter-spacing:.4px}
.toast.show{opacity:1;transform:translateY(0)}

@media (max-width:1180px){
  .sidebar{width:340px}
  .table-grid{grid-template-columns:1fr}
}
@media (max-width:920px){
  header{padding:10px 14px;height:auto;min-height:var(--header-h);flex-wrap:wrap}
  main{height:calc(100vh - 92px)}
  .tab-bar{order:3;width:100%;justify-content:center}
  .sidebar{display:none}
}
@media (max-width:640px){
  .chip-row{max-width:none}
  .form-grid,.dual-row{grid-template-columns:1fr}
  .timeline-bar{gap:10px;padding:0 12px}
  .year-badge{min-width:78px;font-size:18px}
  .range-readout{min-width:86px}
}

/* ===== LOGIN ===== */
.login-overlay{position:fixed;inset:0;z-index:3000;display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse at 30% 25%, rgba(185,28,28,.18), transparent 55%),
    radial-gradient(ellipse at 75% 80%, rgba(224,168,46,.12), transparent 60%),
    repeating-linear-gradient(45deg, rgba(224,168,46,.025) 0 2px, transparent 2px 8px),
    linear-gradient(180deg,#0c0905 0%,#040302 100%);
  backdrop-filter:blur(2px)}
.login-overlay.hidden{display:none}
.login-box{width:min(420px,92vw);background:linear-gradient(180deg,#1a1108,#0a0604);border-radius:20px;border:1px solid rgba(224,168,46,.35);box-shadow:0 30px 60px rgba(0,0,0,.7),0 0 0 1px rgba(224,168,46,.1) inset;padding:32px 28px;position:relative}
.login-box::before{content:'';position:absolute;inset:-2px;border-radius:22px;background:linear-gradient(135deg,rgba(224,168,46,.4),rgba(185,28,28,.2),rgba(224,168,46,.4));z-index:-1;filter:blur(8px);opacity:.55}
.login-logo{display:flex;justify-content:center;margin-bottom:14px}
.login-logo-img{width:84px;height:84px;border-radius:22px;object-fit:contain;padding:10px;background:linear-gradient(180deg,rgba(18,12,7,.96),rgba(8,5,3,.93));box-shadow:0 8px 26px rgba(224,168,46,.18),0 0 0 1px rgba(224,168,46,.42)}
.login-box h1{font-family:'Cinzel',serif;font-size:24px;text-align:center;color:var(--gold-2);margin-bottom:4px;letter-spacing:2px;text-transform:uppercase}
.login-sub{text-align:center;color:rgba(240,193,74,.55);font-size:12px;margin-bottom:24px;font-style:italic;letter-spacing:.5px}
.login-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.login-field label{font-size:11px;color:var(--gold-2);text-transform:uppercase;letter-spacing:.8px;font-family:'Cinzel',serif}
.login-field input{width:100%;padding:11px 13px;border:1px solid rgba(224,168,46,.3);background:rgba(244,234,211,.95);border-radius:10px;color:var(--ink);outline:none;font-size:14px}
.login-field input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(224,168,46,.18)}
.login-error{color:#ff6b6b;font-size:12px;min-height:18px;margin-bottom:8px;text-align:center}
.login-submit{width:100%;padding:12px;background:linear-gradient(180deg,var(--crimson-2),var(--crimson-3));color:var(--gold-2);border-radius:10px;font-family:'Cinzel',serif;font-size:13px;font-weight:700;letter-spacing:1px;transition:.16s;text-transform:uppercase;border:1px solid rgba(224,168,46,.45)}
.login-submit:hover{filter:brightness(1.15);transform:translateY(-1px);box-shadow:0 6px 20px rgba(185,28,28,.35)}
.login-submit:disabled{opacity:.6;cursor:wait}

/* ===== USER CHIP IN HEADER ===== */
.user-chip{display:flex;align-items:center;gap:6px;margin-left:8px;padding:4px 4px 4px 12px;background:rgba(224,168,46,.1);border:1px solid rgba(224,168,46,.4);border-radius:999px}
.user-name{color:var(--gold-2);font-family:'Cinzel',serif;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.user-menu-btn{width:26px;height:26px;border-radius:50%;background:transparent;color:var(--gold-2);font-size:13px;display:grid;place-items:center;border:1px solid transparent;transition:.14s}
.user-menu-btn:hover{background:rgba(224,168,46,.2);border-color:rgba(224,168,46,.5)}

/* hide tab when not admin */
.tab-btn.hidden{display:none}

.emoji-picker{display:flex;flex-wrap:wrap;gap:6px;padding-top:4px}
.emoji-btn{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.6);border:1px solid var(--parchment-3);font-size:18px;display:grid;place-items:center;transition:.12s}
.emoji-btn:hover{border-color:var(--accent);background:rgba(255,255,255,.9)}
.emoji-btn.active{border-color:var(--crimson);background:var(--gold-2);transform:scale(1.08)}

.ruler-chip{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--gold-2);border:2px solid var(--crimson-3);font-size:14px;box-shadow:0 3px 8px rgba(0,0,0,.4);cursor:pointer;line-height:1}
.person-chip{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:rgba(244,234,211,.98);border:2px solid var(--ink-2);font-size:13px;box-shadow:0 3px 8px rgba(0,0,0,.35);cursor:pointer;line-height:1}

.timeline-wrap{cursor:grab;user-select:none}
.timeline-wrap.grabbing{cursor:grabbing}
.timeline-wrap.drag-ready{cursor:grab}
.timeline-wrap .civ-bar-h,
.timeline-wrap .country-bar-h,
.timeline-wrap .event-dot{cursor:pointer}

/* Civilization detail panel */
.civ-meta{display:flex;flex-wrap:wrap;gap:6px;margin:0 0 12px}
.civ-chip{display:inline-block;padding:4px 10px;border-radius:999px;font-family:'Cinzel',serif;font-size:10px;letter-spacing:.6px;text-transform:uppercase;font-weight:700;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.civ-chip-years{background:rgba(255,255,255,.65);color:var(--ink-2);border:1px solid var(--parchment-3)}
.civ-chip-muted{background:rgba(74,63,48,.08);color:var(--ink-2);border:1px solid rgba(74,63,48,.12)}
.civ-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin:0 0 14px}
.civ-summary-card{padding:10px 12px;border-radius:8px;background:rgba(255,255,255,.42);border:1px solid rgba(74,63,48,.08);box-shadow:0 1px 4px rgba(0,0,0,.04)}
.civ-summary-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-4);margin-bottom:4px}
.civ-summary-value{font-family:'Cinzel',serif;font-size:18px;font-weight:700;color:var(--ink-1);line-height:1.15}
.civ-summary-sub{font-size:11px;color:var(--ink-3);margin-top:3px;line-height:1.35}
.civ-map-grid{display:grid;grid-template-columns:1fr;gap:8px}
.civ-map-card{width:100%;text-align:left;padding:10px 12px;border-radius:8px;border:1px solid rgba(74,63,48,.12);background:rgba(255,255,255,.48);cursor:pointer;transition:.12s;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.civ-map-card:hover{background:rgba(255,255,255,.78);border-color:var(--accent);transform:translateY(-1px)}
.civ-map-year{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-3);margin-bottom:4px}
.civ-map-title{font-family:'Cinzel',serif;font-size:13px;font-weight:700;color:var(--ink-1);line-height:1.35}
.civ-map-meta{font-size:11px;color:var(--ink-3);margin-top:3px;line-height:1.35}
.civ-description{font-size:13px;line-height:1.55;color:var(--ink-2);margin:0 0 14px;padding:10px 12px;background:rgba(255,255,255,.4);border-left:3px solid var(--accent);border-radius:4px}
.civ-section{margin:14px 0 0;padding-top:12px;border-top:1px solid var(--parchment-3)}
.civ-section:first-of-type{border-top:none;padding-top:0}
.civ-section-title{font-family:'Cinzel',serif;font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-3);font-weight:700;margin:0 0 8px;display:flex;align-items:center;gap:6px}
.civ-count{display:inline-block;padding:1px 7px;border-radius:999px;background:var(--parchment-3);font-size:10px;color:var(--ink-3);letter-spacing:0;font-weight:600}
.civ-empty{font-size:12px;color:var(--ink-4);font-style:italic}
.civ-religion{font-size:12.5px;line-height:1.55;color:var(--ink-2);padding:8px 10px;background:rgba(244,239,225,.6);border-radius:4px;border:1px dashed var(--parchment-3)}
.civ-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.civ-item{padding:8px 10px;border-radius:6px;background:rgba(255,255,255,.35);border:1px solid transparent;cursor:pointer;transition:.12s}
.civ-item:hover{background:rgba(255,255,255,.7);border-color:var(--accent)}
.civ-item-main{font-size:13px;color:var(--ink-1);line-height:1.35}
.civ-item-main strong{font-family:'Cinzel',serif;font-weight:700}
.civ-item-sub{font-size:11px;color:var(--ink-3);font-family:'JetBrains Mono',monospace;margin-top:2px}
.civ-item-desc{font-size:11.5px;color:var(--ink-3);margin-top:4px;line-height:1.4}
.civ-item-tag{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:3px;background:var(--gold-2);font-size:9px;font-family:'Cinzel',serif;letter-spacing:.5px;text-transform:uppercase;color:var(--crimson-3);font-weight:700}
#civDetailBody{padding:14px 16px;overflow-y:auto;flex:1;min-height:0}
#civDetailHead{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--parchment-3)}
#civDetailHead .detail-label{font-family:'Cinzel',serif;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-4);margin-bottom:4px}
#civDetailHead h2{font-family:'Cinzel',serif;font-size:19px;margin:0;line-height:1.2;color:var(--ink-1)}

/* ========== SUMMARY PANEL (read-only popup) ========== */
#summaryPanel{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:rgba(7,10,16,.35);backdrop-filter:blur(2px);animation:fadeInOverlay .18s ease-out}
@keyframes fadeInOverlay{from{opacity:0}to{opacity:1}}
.summary-panel-inner{position:relative;width:min(400px,calc(100% - 32px));max-height:70vh;padding:28px 24px 22px;border-radius:20px;background:linear-gradient(180deg,rgba(244,234,211,.97),rgba(231,218,182,.96));border:1px solid rgba(123,79,138,.18);box-shadow:0 24px 48px rgba(0,0,0,.28),0 0 0 1px rgba(255,255,255,.28) inset;display:flex;flex-direction:column;align-items:center;text-align:center;animation:popIn .2s ease-out}
@keyframes popIn{from{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}
.summary-popup-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:rgba(255,255,255,.72);color:var(--ink);font-size:22px;line-height:1;box-shadow:var(--shadow-soft);cursor:pointer;display:grid;place-items:center}
.summary-popup-close:hover{background:#fff}
.summary-panel-title{font-family:'Cinzel',serif;font-size:17px;font-weight:700;color:var(--crimson-3);line-height:1.4;margin-bottom:6px}
.summary-panel-title em{font-family:'Crimson Pro',serif;font-weight:400;font-size:13px;color:var(--ink-3)}
.summary-panel-body{padding:6px 0 0;overflow-y:auto;width:100%}
.summary-meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-3);margin-bottom:8px}


/* ===== POSTS ===== */
.posts-shell{overflow-y:auto;overflow-x:hidden}
.posts-meta{margin:4px 0 16px;color:var(--ink-3);font-size:13px}
.posts-grid{display:flex;flex-direction:column;flex-wrap:nowrap;gap:16px;padding-bottom:14px;width:100%}
.post-card{background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(244,234,211,.82));border:1px solid var(--gold-3);border-radius:20px;padding:18px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:10px;width:100%;flex-shrink:0}
.post-card h3{font-family:'Cinzel',serif;font-size:18px;line-height:1.35;color:var(--ink);margin:0}
.post-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.post-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:rgba(224,168,46,.14);border:1px solid rgba(224,168,46,.3);font-family:'Cinzel',serif;font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-2)}
.post-content{font-size:14px;line-height:1.65;color:var(--ink-2);white-space:pre-wrap}
.post-video{position:relative;padding-top:56.25%;border-radius:14px;overflow:hidden;border:1px solid rgba(74,63,48,.12);background:#120b06}
.post-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.posts-empty{padding:28px;border:1px dashed var(--gold-3);border-radius:18px;background:rgba(255,255,255,.45);color:var(--ink-3);font-style:italic}
#loginOpenBtn{display:inline-flex;align-items:center;justify-content:center;min-width:92px}

.post-card.out-of-window{opacity:.92}
.post-chip-active{background:rgba(32,115,76,.14);border-color:rgba(32,115,76,.35);color:#205c3c;font-weight:700}

/* ===== WORLD STORY ===== */
#storyPage{flex-direction:column;overflow:hidden;background:linear-gradient(180deg,#f4ead3,#e7dab6)}
.story-shell{display:flex;flex-direction:column;height:100%;overflow:hidden}
.story-scroll{flex:1;overflow-y:auto;display:flex;justify-content:center;padding:24px 16px 80px;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(224,168,46,.08), transparent 60%),
    linear-gradient(180deg,#f4ead3,#e7dab6)}
.story-scroll::-webkit-scrollbar{width:8px}
.story-scroll::-webkit-scrollbar-thumb{background:var(--gold-3);border-radius:999px}
.story-chapters{max-width:780px;width:100%;position:relative;padding-left:40px}
.story-chapters::before{content:'';position:absolute;left:16px;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold-3),var(--crimson-3),var(--gold-3));border-radius:999px;opacity:.6}
.story-empty{padding:40px;text-align:center;color:var(--ink-3);font-style:italic;font-size:15px}
.story-chapter{position:relative;margin-bottom:36px;padding:24px 28px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(244,234,211,.85));border:1px solid var(--gold-3);border-radius:18px;box-shadow:0 8px 28px rgba(0,0,0,.12)}
.story-chapter::before{content:'';position:absolute;left:-32px;top:28px;width:14px;height:14px;border-radius:50%;background:var(--gold-2);border:3px solid var(--crimson-3);box-shadow:0 2px 8px rgba(0,0,0,.25);z-index:2}
.story-chapter-era{display:inline-block;padding:4px 12px;border-radius:999px;background:rgba(185,28,28,.08);border:1px solid rgba(185,28,28,.2);font-family:'Cinzel',serif;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--crimson);font-weight:700;margin-bottom:10px}
.story-chapter-title{font-family:'Cinzel',serif;font-size:22px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:6px}
.story-chapter-years{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-3);margin-bottom:14px}
.story-chapter-content{font-family:'Crimson Pro',serif;font-size:16px;line-height:1.75;color:var(--ink-2);white-space:pre-wrap}
.story-chapter-actions{display:flex;gap:6px;margin-top:14px;padding-top:12px;border-top:1px dashed var(--parchment-3)}

/* ===== TIMELINE REGION SELECT ===== */
.tl-region-select{padding:8px 12px;border-radius:8px;border:1px solid rgba(224,168,46,.4);background:rgba(224,168,46,.06);color:var(--gold-2);font-size:12px;font-family:'Cinzel',serif;outline:none;min-width:140px}
.tl-region-select option{background:#1a1108;color:var(--gold-2)}

/* ===== LEAFLET PANE FIX ===== */
.leaflet-tooltip{display:none!important}
.map-area{overflow:hidden;position:relative}
#map{overflow:hidden}
.leaflet-pane{will-change:transform}
