:root{
  --bg:#120d1a;
  --bg-alt:#191223;
  --panel:#20182f;
  --panel-hi:#2a2040;
  --line:#3a2c52;
  --gold:#c9a44c;
  --gold-bright:#e6c67c;
  --violet:#6a4a97;
  --violet-soft:#9077bb;
  --text:#ece6da;
  --text-dim:#b3a6cc;
  --rust:#b1543f;
  --done:#7fa66a;
  --radius:10px;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{color-scheme: dark;}
body{
  background:
    radial-gradient(ellipse at 20% -10%, #2a1f42 0%, transparent 55%),
    radial-gradient(ellipse at 100% 0%, #241a38 0%, transparent 45%),
    var(--bg);
  color:var(--text);
  font-family:'IBM Plex Sans', sans-serif;
  line-height:1.5;
  min-height:100vh;
}
a{color:var(--gold-bright);}
.wrap{max-width:1080px;margin:0 auto;padding:28px 20px 80px;}

/* ---------- CAPE TABS + OVERVIEW ---------- */
/* ---------- PLAYER SYNC ---------- */
.sync-panel{
  background:linear-gradient(160deg, var(--panel-hi), var(--panel) 80%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:16px 20px;
  margin-bottom:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.sync-top{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.sync-label{display:flex; align-items:center; gap:8px;}
.sync-label .lbl{font-family:'Cinzel', serif; font-size:0.95rem; color:var(--gold-bright); letter-spacing:0.3px;}
.api-badge{
  font-size:0.65rem; text-transform:uppercase; letter-spacing:0.06em; padding:2px 9px; border-radius:20px;
  border:1px solid var(--rust); color:#e08a72; white-space:nowrap;
}
.api-badge.ready{border-color:var(--done); color:var(--done);}
.sync-row{display:flex; gap:8px; flex-wrap:wrap;}
.sync-input{
  flex:1; min-width:200px; background:var(--bg-alt); border:1px solid var(--line); color:var(--text);
  border-radius:6px; padding:9px 12px; font-size:0.9rem; font-family:'IBM Plex Mono',monospace;
}
.sync-btn{
  background:var(--violet); color:var(--text); border:1px solid var(--violet-soft); border-radius:6px;
  padding:9px 18px; font-weight:600; cursor:pointer; font-size:0.85rem; white-space:nowrap;
}
.sync-btn:disabled{opacity:0.6; cursor:not-allowed;}
.sync-btn.loading{opacity:0.75;}
.sync-status{font-size:0.82rem; color:var(--text-dim); display:flex; align-items:flex-start; gap:6px; line-height:1.5;}
.sync-status .dot{width:7px; height:7px; border-radius:50%; margin-top:6px; flex-shrink:0; background:var(--rust);}
.sync-status.ok .dot{background:var(--done);}
.sync-meta{font-size:0.75rem; color:var(--text-dim); opacity:0.8;}

.cape-tabs{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px;}
.cape-tab{
  background:var(--panel); border:1px solid var(--line); color:var(--text-dim);
  padding:9px 16px; border-radius:20px; font-size:0.85rem; cursor:pointer;
  font-family:'IBM Plex Sans',sans-serif; display:flex; align-items:center; gap:8px;
}
.cape-tab .pct{font-family:'IBM Plex Mono',monospace; font-size:0.75rem; color:var(--text-dim);}
.cape-tab.active{background:var(--violet); color:var(--text); border-color:var(--violet-soft);}
.cape-tab.active .pct{color:var(--gold-bright);}
.cape-tab.locked{opacity:0.55;}

/* ---------- HERO ---------- */
.hero{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:28px;
  align-items:center;
  background:linear-gradient(160deg, var(--panel-hi), var(--panel) 70%);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:26px 28px;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 10px 10px, rgba(201,164,76,0.06) 1px, transparent 1.4px);
  background-size:22px 22px;
  pointer-events:none;
}
.cape-svg{width:150px;height:190px;filter:drop-shadow(0 8px 18px rgba(0,0,0,0.5));}
.hero h1{
  font-family:'Cinzel', serif;
  font-weight:700;
  font-size:2rem;
  margin:0 0 6px;
  letter-spacing:0.5px;
  color:var(--gold-bright);
}
.hero p.sub{color:var(--text-dim); margin:0 0 10px; max-width:58ch;}
.prereqs{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px;}
.prereq-badge{
  font-size:0.72rem; padding:3px 10px; border-radius:20px; border:1px solid var(--line); color:var(--text-dim);
  display:flex; align-items:center; gap:5px;
}
.prereq-badge.met{border-color:var(--done); color:var(--done);}
.hero-stats{display:flex; gap:28px; flex-wrap:wrap;}
.hero-stat .num{font-family:'IBM Plex Mono',monospace; font-size:1.6rem; color:var(--gold-bright); font-weight:500;}
.hero-stat .lbl{font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-dim);}

/* ---------- SECTION HEADERS ---------- */
section{margin-top:44px;}
.sec-head{display:flex; align-items:baseline; justify-content:space-between; gap:16px; margin-bottom:14px; flex-wrap:wrap;}
.sec-head h2{
  font-family:'Cinzel', serif;
  font-size:1.3rem;
  margin:0;
  color:var(--gold-bright);
  display:flex; align-items:center; gap:10px;
}
.sec-head h2::before{content:""; width:20px; height:1px; background:var(--gold); display:inline-block;}
.sec-head .note{color:var(--text-dim); font-size:0.85rem;}
.sec-head-toggle{cursor:pointer; user-select:none;}
.sec-head-toggle:hover h2{color:var(--gold);}
.sec-chev{
  font-size:0.85rem; color:var(--text-dim); transition:transform .2s ease;
  flex-shrink:0; align-self:center;
}
.sec-chev.collapsed{transform:rotate(-90deg);}
.sec-body.collapsed{display:none;}

/* ---------- SKILLS ---------- */
.skills-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(230px,1fr));
  gap:12px;
}
.skill-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:12px 14px;
  display:flex;
  flex-direction:column;
}
.skill-top{display:flex; align-items:center; margin-bottom:8px;}
.skill-icon{width:20px; height:20px; object-fit:contain; flex-shrink:0; vertical-align:middle;}
.skill-name-wrap{display:flex; align-items:center; gap:7px; min-width:0;}
.skill-name{font-weight:600;}
.skill-req-row{display:flex; align-items:center; gap:8px; margin-bottom:8px;}
.skill-tag{
  font-size:0.68rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--violet-soft);
  border:1px solid var(--violet); padding-block:2px; padding-inline:7px; border-radius:6px;
  margin-inline-start:auto; flex-shrink:0; white-space:nowrap;
}
.skill-req{font-size:0.78rem; color:var(--text-dim); min-width:0;}
.skill-inputs{display:flex; align-items:center; gap:10px; margin-top:auto; padding-top:8px;}
.skill-inputs input{
  width:76px; background:var(--bg-alt); border:1px solid var(--line); color:var(--text);
  border-radius:8px; padding:7px 10px; font-family:'IBM Plex Mono',monospace; font-size:0.95rem;
  color-scheme: dark;
}
.skill-inputs span{color:var(--text-dim); font-size:0.8rem;}
.bar{height:6px; border-radius:4px; background:var(--bg-alt); overflow:hidden; margin-top:8px;}
.bar > i{display:block; height:100%; background:linear-gradient(90deg, var(--violet), var(--gold)); transition:width .3s;}
.skill-card.met{border-color:var(--done);}
.skill-card.met .bar > i{background:var(--done);}

.skills-accordion{margin-top:14px; border:1px dashed var(--line); border-radius:var(--radius); overflow:hidden;}
.skills-accordion-toggle{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:var(--bg-alt); border:none; color:var(--text-dim); padding:11px 16px; cursor:pointer;
  font-family:'IBM Plex Sans',sans-serif; font-size:0.85rem; text-align:start;
}
.skills-accordion-toggle .chev{transition:transform .2s; font-size:0.75rem;}
.skills-accordion-toggle.open .chev{transform:rotate(90deg);}
.skills-accordion-body{display:none; padding:14px 16px; flex-wrap:wrap; gap:8px;}
.skills-accordion-body.open{display:flex;}
.skill-chip{
  display:flex; align-items:center; gap:6px; background:var(--panel); border:1px solid var(--line);
  border-radius:20px; padding-block:5px; padding-inline:6px 12px; font-size:0.78rem; color:var(--text-dim);
}
.skill-chip .skill-icon{width:16px; height:16px;}
.skill-chip .lvl{font-family:'IBM Plex Mono',monospace; color:var(--gold-bright);}
.skill-chip.met{border-color:var(--done);}

/* ---------- FILTERS ---------- */
.filters{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px;}
.filters button{
  background:var(--panel); border:1px solid var(--line); color:var(--text-dim);
  padding:6px 12px; border-radius:20px; font-size:0.78rem; cursor:pointer;
  font-family:'IBM Plex Sans',sans-serif;
}
.filters button.active{background:var(--violet); color:var(--text); border-color:var(--violet-soft);}

.controls-row{display:flex; gap:10px; flex-wrap:wrap; align-items:center;}
.search-wrap{position:relative; flex:1; min-width:180px;}
.search-icon{
  position:absolute; inset-inline-start:12px; top:50%; transform:translateY(-50%);
  width:14px; height:14px; color:var(--text-dim); pointer-events:none;
}
.search-box{
  width:100%; background:var(--panel); border:1px solid var(--line); border-radius:20px;
  padding-block:8px; padding-inline:34px 14px; color:var(--text); font-size:0.82rem;
}
.sort-select{
  background:var(--panel); border:1px solid var(--line); border-radius:20px;
  padding:8px 14px; color:var(--text-dim); font-size:0.78rem; font-family:'IBM Plex Sans',sans-serif;
  cursor:pointer; color-scheme: dark;
}

/* ---------- ACHIEVEMENT CARDS ---------- */
.ach-list{display:flex; flex-direction:column; gap:10px;}
.ach-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:14px 16px;
  display:grid;
  grid-template-columns:30px 1fr auto;
  gap:12px;
  align-items:start;
  transition:opacity .2s, border-color .2s;
}
.ach-card.done{opacity:0.5;}
.ach-card.done .ach-title{text-decoration:line-through;}
.ach-check{
  width:22px;height:22px;border-radius:6px;border:1.5px solid var(--gold);
  background:transparent; cursor:pointer; margin-top:2px;
  display:flex; align-items:center; justify-content:center; color:var(--bg);
  font-size:0.8rem;
}
.ach-card.done .ach-check{background:var(--done); border-color:var(--done); color:#12210f;}
.ach-title{font-weight:600; font-size:1rem; margin-bottom:4px;}
.ach-req{color:var(--text-dim); font-size:0.87rem; margin-bottom:6px;}
.ach-tip{color:var(--violet-soft); font-size:0.8rem; border-inline-start:2px solid var(--violet); padding-inline-start:8px; margin-top:6px;}
.ach-meta{display:flex; flex-direction:column; align-items:flex-end; gap:6px; min-width:120px;}
.ach-time{font-family:'IBM Plex Mono',monospace; font-size:0.85rem; color:var(--gold-bright); white-space:nowrap;}
.ach-tags{display:flex; gap:4px; flex-wrap:wrap; justify-content:flex-end;}
.pill{font-size:0.65rem; text-transform:uppercase; letter-spacing:0.05em; padding:2px 7px; border-radius:20px; border:1px solid var(--line); color:var(--text-dim);}
.pill.RNG{border-color:var(--rust); color:#e08a72;}
.pill.Timegated{border-color:var(--gold); color:var(--gold-bright);}
.pill.Archaeology{border-color:var(--violet-soft); color:var(--violet-soft);}
.pill.PvM{border-color:#7096b3; color:#8fb4d1;}
.pill.type-quest{border-color:var(--violet-soft); color:var(--violet-soft);}
.pill.type-miniquest{border-color:var(--gold); color:var(--gold-bright);}
.pill.type-saga{border-color:#7096b3; color:#8fb4d1;}
.wiki-link{font-size:0.75rem; color:var(--gold-bright); text-decoration:none; border-bottom:1px dotted var(--gold);}

/* ---------- CUSTOM / NOTES / STUBS ---------- */
.panel-box{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:18px 20px;
}
.tips-list{margin:0; padding-inline-start:18px; color:var(--text-dim); font-size:0.88rem;}
.tips-list li{margin-bottom:8px;}
.tips-list b{color:var(--text);}

.custom-form{display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px;}
.custom-form input{
  flex:1; min-width:160px; background:var(--bg-alt); border:1px solid var(--line); color:var(--text);
  border-radius:6px; padding:8px 10px; font-size:0.85rem;
}
.custom-form button{
  background:var(--gold); color:#231a0e; border:none; border-radius:6px; padding:8px 16px;
  font-weight:600; cursor:pointer; font-size:0.85rem;
}
.custom-item{
  display:flex; align-items:center; gap:10px; padding:8px 4px; border-bottom:1px solid var(--line); font-size:0.9rem;
}
.custom-item:last-child{border-bottom:none;}
.custom-item.done{opacity:0.5; text-decoration:line-through;}
.custom-item button.del{
  margin-inline-start:auto; background:none; border:none; color:var(--rust); cursor:pointer; font-size:0.85rem;
}
.empty{color:var(--text-dim); font-size:0.85rem; font-style:italic; padding:10px 0;}
.stub-banner{
  border:1px dashed var(--line); border-radius:var(--radius); padding:16px 18px; color:var(--text-dim);
  font-size:0.88rem; background:var(--bg-alt);
}
.stub-banner b{color:var(--gold-bright);}

footer{margin-top:56px; text-align:center; color:var(--text-dim); font-size:0.78rem;}
footer a{color:var(--text-dim);}

@media(max-width:640px){
  .hero{grid-template-columns:1fr; text-align:center;}
  .hero-stats{justify-content:center;}
  .prereqs{justify-content:center;}
  .cape-svg{margin:0 auto;}
  .ach-card{grid-template-columns:26px 1fr;}
  .ach-meta{grid-column:1/-1; flex-direction:row; justify-content:space-between; align-items:center; margin-top:6px;}
}
