:root{
  --bg:#0b0b14;--bg2:#12121f;--bg3:#1a1a2e;--panel:#1e1e32;
  --gold:#c9a84c;--gold-l:#e8d5a3;--gold-d:#8a7230;
  --cream:#f5edd6;--cream-d:#e0d2b0;--cream-dd:#c9b896;
  --txt:#e8d9b8;--txt2:#a89a78;--txt-dark:#2d2418;
  --red:#8b2500;--red-l:#c44020;--green:#3a7a34;--blue:#2a5a8a;
  --border:#c9a84c33;--border2:#c9a84c55;
}
*{margin:0;padding:0;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:var(--gold-d) var(--bg2)}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--gold-d);border-radius:3px}
body{font-family:'IBM Plex Sans',sans-serif;background:var(--bg);color:var(--txt);overflow:hidden;height:100vh}
h1,h2,h3,h4,h5{font-family:'Playfair Display',serif;color:var(--gold)}

/* Sidebar */
#sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:var(--bg2);border-right:1px solid var(--border);z-index:50;display:flex;flex-direction:column;transition:transform .3s}
#sidebar .logo{padding:24px 20px;border-bottom:1px solid var(--border);text-align:center}
#sidebar .logo h1{font-size:1.3rem;letter-spacing:2px;line-height:1.3}
#sidebar .logo .sub{font-size:.7rem;color:var(--txt2);letter-spacing:4px;text-transform:uppercase;margin-top:4px}
#sidebar nav{flex:1;overflow-y:auto;padding:12px 0}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;transition:all .2s;color:var(--txt2);font-size:.88rem;border-left:3px solid transparent}
.nav-item:hover{background:var(--bg3);color:var(--gold-l)}
.nav-item.active{background:var(--bg3);color:var(--gold);border-left-color:var(--gold)}
.nav-item i{width:20px;text-align:center;font-size:.9rem}
.nav-sep{height:1px;background:var(--border);margin:8px 20px}

/* Main */
#main{margin-left:280px;height:100vh;overflow-y:auto;position:relative}
#main::before{content:'';position:fixed;top:0;right:0;width:600px;height:600px;background:radial-gradient(circle,rgba(139,37,0,.06) 0%,transparent 70%);pointer-events:none;z-index:0}
.section{display:none;padding:32px 40px 60px;min-height:100vh;position:relative;z-index:1}
.section.active{display:block}
.section-title{font-size:2rem;font-weight:900;margin-bottom:8px;letter-spacing:1px}
.section-sub{color:var(--txt2);font-size:.95rem;margin-bottom:28px}

/* Art Deco ornament */
.ornament{display:flex;align-items:center;gap:12px;margin:20px 0}
.ornament .line{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold-d),transparent)}
.ornament .diamond{width:8px;height:8px;background:var(--gold);transform:rotate(45deg);flex-shrink:0}
.ornament .fan{width:24px;height:12px;flex-shrink:0;position:relative}
.ornament .fan::before{content:'';position:absolute;bottom:0;left:50%;width:2px;height:12px;background:var(--gold);transform:translateX(-50%)}
.ornament .fan::after{content:'';position:absolute;bottom:0;left:50%;width:20px;height:10px;border:1.5px solid var(--gold);border-bottom:none;border-radius:10px 10px 0 0;transform:translateX(-50%)}

/* Cards */
.card{background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:20px;transition:all .3s;position:relative;overflow:hidden}
.card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.4)}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold-d),var(--gold),var(--gold-d),transparent)}
.card-title{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--gold-l);margin-bottom:8px}
.card .tag{display:inline-block;background:var(--bg);color:var(--gold);font-size:.7rem;padding:2px 8px;border:1px solid var(--border);border-radius:2px;margin:2px}

/* Paper card */
.paper{background:linear-gradient(135deg,var(--cream) 0%,var(--cream-d) 100%);color:var(--txt-dark);border:1px solid var(--cream-dd);border-radius:4px;padding:20px;position:relative;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.paper::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='40' height='40' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;border-radius:4px}

/* Tables */
.tbl-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:4px}
table{width:100%;border-collapse:collapse;font-size:.85rem}
thead{background:var(--bg3)}
th{padding:10px 14px;text-align:left;color:var(--gold);font-weight:600;border-bottom:2px solid var(--gold-d);cursor:pointer;white-space:nowrap;user-select:none}
th:hover{color:var(--gold-l)}
th .sort-icon{margin-left:4px;font-size:.7rem;opacity:.5}
th.sorted .sort-icon{opacity:1;color:var(--gold)}
td{padding:8px 14px;border-bottom:1px solid var(--border);vertical-align:top}
tbody tr{transition:background .2s}
tbody tr:hover{background:var(--bg3)}
tbody tr:nth-child(even){background:var(--bg2)}

/* Timeline */
.tl-container{position:relative;padding-left:40px}
.tl-container::before{content:'';position:absolute;left:15px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--gold-d),var(--gold),var(--gold-d))}
.tl-item{position:relative;margin-bottom:24px;padding-left:24px}
.tl-item::before{content:'';position:absolute;left:-33px;top:6px;width:12px;height:12px;border-radius:50%;border:2px solid var(--gold);background:var(--bg);z-index:1}
.tl-item.mythos::before{background:var(--red);border-color:var(--red-l)}
.tl-item:hover::before{box-shadow:0 0 10px var(--gold)}
.tl-year{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--gold);font-weight:700}
.tl-event{margin-top:4px;color:var(--txt);line-height:1.5}
.tl-event .mythos-tag{color:var(--red-l);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px}

/* Stat block (CoC) */
.stat-block{background:linear-gradient(135deg,#1a1510 0%,#1e1a14 100%);border:1px solid var(--gold-d);border-radius:4px;padding:16px;font-family:'IBM Plex Sans',monospace;font-size:.82rem}
.stat-block h4{font-family:'Playfair Display',serif;color:var(--gold);font-size:1.1rem;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--gold-d)}
.stat-row{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.stat-cell{background:var(--bg);border:1px solid var(--border);padding:3px 8px;border-radius:2px;min-width:50px;text-align:center}
.stat-cell .label{font-size:.6rem;color:var(--txt2);text-transform:uppercase;letter-spacing:1px}
.stat-cell .value{color:var(--gold-l);font-weight:700;font-size:.95rem}
.stat-attacks{border-top:1px solid var(--border);padding-top:8px}
.stat-attacks div{margin-bottom:4px}
.stat-attacks .atk-name{color:var(--red-l);font-weight:600}
.stat-special{border-top:1px solid var(--border);padding-top:8px;color:var(--txt2);font-style:italic}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--gold-d);background:transparent;color:var(--gold);font-size:.85rem;cursor:pointer;border-radius:3px;transition:all .2s;font-family:'IBM Plex Sans',sans-serif}
.btn:hover{background:var(--gold);color:var(--bg)}
.btn-sm{padding:5px 10px;font-size:.78rem}
.btn-red{border-color:var(--red);color:var(--red-l)}
.btn-red:hover{background:var(--red);color:#fff}
.btn-green{border-color:var(--green);color:#5aaa54}
.btn-green:hover{background:var(--green);color:#fff}

/* Search */
#search-bar{position:fixed;top:16px;right:16px;z-index:100;display:flex;align-items:center;gap:8px}
#search-input{background:var(--panel);border:1px solid var(--border);color:var(--txt);padding:8px 14px 8px 36px;border-radius:3px;font-size:.85rem;width:260px;transition:all .3s;font-family:'IBM Plex Sans',sans-serif}
#search-input:focus{outline:none;border-color:var(--gold);width:320px;box-shadow:0 0 20px rgba(201,168,76,.1)}
#search-icon{position:absolute;left:12px;color:var(--txt2);font-size:.85rem;pointer-events:none}
#search-results{position:absolute;top:100%;right:0;margin-top:4px;width:400px;max-height:400px;overflow-y:auto;background:var(--panel);border:1px solid var(--border2);border-radius:4px;display:none;z-index:101}
#search-results.show{display:block}
.sr-item{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .2s}
.sr-item:hover{background:var(--bg3)}
.sr-item .sr-title{color:var(--gold-l);font-weight:600;font-size:.88rem}
.sr-item .sr-section{color:var(--txt2);font-size:.72rem;text-transform:uppercase;letter-spacing:1px}
.sr-item mark{background:var(--gold-d);color:var(--bg);padding:0 2px;border-radius:1px}

/* Tabs */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px}
.tab{padding:10px 20px;cursor:pointer;color:var(--txt2);font-size:.85rem;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}
.tab:hover{color:var(--gold-l)}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.show{display:flex}
.modal{background:var(--panel);border:1px solid var(--gold-d);border-radius:4px;width:90%;max-width:700px;max-height:85vh;overflow-y:auto;padding:28px;position:relative}
.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--txt2);font-size:1.2rem;cursor:pointer}
.modal-close:hover{color:var(--gold)}

/* Forms */
.form-group{margin-bottom:14px}
.form-group label{display:block;color:var(--gold);font-size:.8rem;margin-bottom:4px;text-transform:uppercase;letter-spacing:1px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--txt);padding:8px 12px;border-radius:3px;font-size:.88rem;font-family:'IBM Plex Sans',sans-serif}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--gold)}
.form-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}
.form-row .form-group{margin-bottom:0}

/* Calendar */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-header{padding:8px;text-align:center;color:var(--gold);font-weight:600;font-size:.75rem;text-transform:uppercase}
.cal-day{padding:8px;text-align:center;border-radius:2px;font-size:.82rem;cursor:pointer;transition:all .2s;min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.cal-day:hover{background:var(--bg3)}
.cal-day.today{background:var(--gold-d);color:var(--bg);font-weight:700}
.cal-day.has-event{position:relative}
.cal-day.has-event::after{content:'';position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--red-l)}
.cal-day.other-month{color:var(--txt2);opacity:.4}
.cal-day .evt-dot{width:4px;height:4px;border-radius:50%;background:var(--gold);margin-top:2px}

/* Calendar year view */
.cal-year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cal-month-card{background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:10px;overflow:hidden}
.cal-month-name{text-align:center;color:var(--gold);font-weight:700;font-size:.82rem;margin-bottom:6px;font-family:'Playfair Display',serif}
.cal-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;font-size:.62rem;text-align:center}
.cal-mini-hdr{color:var(--txt2);padding:1px 0;font-weight:600}
.cal-mini-day{padding:1px 0;cursor:pointer;border-radius:2px;transition:background .15s}
.cal-mini-day:hover{background:var(--bg3)}
.cal-mini-ev{position:relative;color:var(--gold-l);font-weight:600}
.cal-mini-ev::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:3px;height:3px;border-radius:50%;background:var(--red-l)}
.cal-mini-dim{padding:1px 0;color:var(--txt2);opacity:.3}
.cal-month-evts{margin-top:6px;border-top:1px solid var(--border);padding-top:6px;max-height:80px;overflow-y:auto}
.cal-month-evt{font-size:.6rem;color:var(--txt2);line-height:1.35;margin-bottom:1px}
@media(max-width:1200px){.cal-year-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:800px){.cal-year-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.cal-year-grid{grid-template-columns:1fr}}

/* Roll display */
.roll-display{font-family:'Playfair Display',serif;font-size:3rem;color:var(--gold);text-align:center;padding:20px;text-shadow:0 0 30px rgba(201,168,76,.3)}
.roll-result{text-align:center;padding:10px;font-size:1.1rem;font-weight:600}
.roll-success{color:#5aaa54}
.roll-fail{color:var(--red-l)}
.roll-crit{color:var(--gold);text-shadow:0 0 20px rgba(201,168,76,.5)}
.roll-fumble{color:#ff3333;text-shadow:0 0 20px rgba(255,0,0,.5)}

/* Resistance table */
.res-table{display:grid;grid-template-columns:40px repeat(21,1fr);font-size:.65rem;border:1px solid var(--border);border-radius:2px;overflow:hidden}
.res-table .rh{background:var(--bg3);color:var(--gold);padding:4px 2px;text-align:center;font-weight:600}
.res-table .rc{padding:3px 1px;text-align:center;border:1px solid var(--border);cursor:pointer;transition:all .15s}
.res-table .rc:hover{background:var(--gold-d);color:var(--bg)}
.res-table .rc.highlight{background:var(--gold);color:var(--bg);font-weight:700}

/* Mobile */
#menu-toggle{display:none;position:fixed;top:12px;left:12px;z-index:60;background:var(--panel);border:1px solid var(--border);color:var(--gold);width:40px;height:40px;border-radius:3px;cursor:pointer;font-size:1.1rem}
@media(max-width:900px){
  #sidebar{transform:translateX(-100%)}
  #sidebar.open{transform:translateX(0)}
  #main{margin-left:0}
  #menu-toggle{display:flex;align-items:center;justify-content:center}
  .section{padding:24px 16px 60px}
  #search-input{width:180px}
  #search-input:focus{width:220px}
  #search-results{width:300px}
}

/* Animations */
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.section.active{animation:fadeIn .3s ease}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.loading{animation:pulse 1.5s infinite}

/* SVG map styles */
.map-container{background:var(--bg);border:1px solid var(--border);border-radius:4px;overflow:hidden;position:relative}
.map-container svg{width:100%;height:auto}
.map-label{fill:var(--gold-l);font-family:'Playfair Display',serif;font-size:8px}
.map-road{stroke:var(--cream-dd);stroke-width:1.5;fill:none}
.map-building{fill:var(--cream-dd);stroke:var(--cream-dd);stroke-width:.5;opacity:.6}
.map-water{fill:var(--blue);opacity:.3}
.map-park{fill:var(--green);opacity:.2}
.map-marker{fill:var(--red-l);cursor:pointer}
.map-marker:hover{fill:var(--gold);filter:drop-shadow(0 0 6px var(--gold))}

/* Tooltip */
.tooltip{position:fixed;background:var(--panel);border:1px solid var(--gold-d);padding:10px 14px;border-radius:3px;font-size:.8rem;max-width:250px;z-index:300;pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,.5);display:none}
.tooltip.show{display:block}
.tooltip .tt-title{color:var(--gold);font-weight:600;margin-bottom:4px}

/* Filter pills */
.filter-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.pill{padding:5px 12px;border:1px solid var(--border);border-radius:20px;font-size:.78rem;cursor:pointer;transition:all .2s;color:var(--txt2)}
.pill:hover,.pill.active{border-color:var(--gold);color:var(--gold);background:rgba(201,168,76,.1)}

/* Grid layouts */
.grid-2{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}

/* Accordion */
.accordion-item{border:1px solid var(--border);border-radius:3px;margin-bottom:6px;overflow:hidden}
.accordion-header{padding:12px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;background:var(--bg2);transition:all .2s}
.accordion-header:hover{background:var(--bg3)}
.accordion-header i{color:var(--gold);transition:transform .3s;font-size:.8rem}
.accordion-header.open i{transform:rotate(180deg)}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.accordion-body.open{max-height:2000px}
.accordion-body-inner{padding:16px}

/* Print */
@media print{
  #sidebar,#search-bar,#menu-toggle{display:none!important}
  #main{margin-left:0!important}
  .section{display:block!important;padding:10px!important}
  body{background:#fff;color:#000;overflow:visible;height:auto}
  .stat-block{border:1px solid #000;background:#fff!important}
  .stat-block h4,.stat-cell .value{color:#000!important}
}
