.hidden{display:none!important}

:root{--bg:#101114;--bg2:#171a20;--panel:#181b20;--panel2:#242a34;--panel3:#2d3440;--border:#313949;--text:#eef3ff;--muted:#99a5bf;--accent:#49f29c;--accent2:#ffc64a;--danger:#ff6666;--radius:18px;--shadow:0 14px 32px rgba(0,0,0,.22)}
*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:Inter,system-ui,sans-serif;color:var(--text);background:radial-gradient(circle at top,var(--bg2),var(--bg));min-height:100%}
button,input,select{font:inherit}button{cursor:pointer}
.topbar{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);background:rgba(13,15,19,.92);backdrop-filter:blur(14px)}
.brand-wrap{display:flex;gap:12px;align-items:center}.brand-icon{width:46px;height:46px;display:grid;place-items:center;background:linear-gradient(180deg,var(--panel3),var(--panel));border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);font-size:24px}.brand-title{font-weight:900}.brand-sub{font-size:12px;color:var(--muted)}
.topbar-right{display:flex;gap:8px;flex-wrap:wrap}.pill{border:none;padding:10px 12px;border-radius:999px;background:linear-gradient(180deg,var(--panel3),var(--panel));color:var(--text);box-shadow:var(--shadow);font-weight:800}.pill.coin{color:#2b1b00;background:linear-gradient(180deg,#ffd978,#eca92f)}.pill.action{color:#071c10;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 75%, black 25%))}
.tabs{position:sticky;top:76px;z-index:12;display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding:10px 12px;background:rgba(16,17,20,.9);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}
.tab-btn{border:none;padding:12px 8px;border-radius:999px;background:rgba(255,255,255,.04);color:var(--muted);font-weight:800}.tab-btn.active{background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 75%, black 25%));color:#071c10}
.app-shell{max-width:1320px;margin:0 auto;padding:16px}.tab-panel{display:none}.tab-panel.active{display:block}
.grid2,.grid3,.grid4,.reward-grid,.skill-grid{display:grid;gap:14px}.grid2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid4{grid-template-columns:repeat(4,minmax(0,1fr))}.reward-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.skill-grid{grid-template-columns:repeat(2,minmax(0,1fr))}@media (max-width:1100px){.grid4,.reward-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:860px){.grid2,.grid3,.grid4,.reward-grid,.skill-grid{grid-template-columns:1fr}}
.card,.skill-card,.reward-card,.quest-card,.stat-card{background:linear-gradient(180deg,rgba(36,42,52,.92),rgba(22,25,32,.98));border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.section-header,.row{display:flex;justify-content:space-between;align-items:center;gap:10px}.card-title{font-size:18px;font-weight:900}.card-sub,.muted{font-size:12px;color:var(--muted)}.label{font-weight:800}.list-stack{display:grid;gap:10px}
.row{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:14px;padding:11px 12px}.row-left{display:flex;gap:10px;align-items:center}.iconbox{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(180deg,var(--panel3),var(--panel));border:1px solid var(--border)}
.hero{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:center}.avatar-card{min-height:190px;display:grid;place-items:center;background:linear-gradient(180deg,var(--panel3),var(--panel));border:1px solid var(--border);border-radius:calc(var(--radius) + 4px)}.avatar{font-size:84px}.rank{font-size:13px;color:var(--accent2);font-weight:900;margin-top:8px}.hero-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.stat-chip{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:14px;padding:12px}.value{font-size:24px;font-weight:900}.name{font-size:12px;color:var(--muted)}@media (max-width:860px){.hero{grid-template-columns:1fr}.hero-stats{grid-template-columns:1fr 1fr}}@media (max-width:560px){.hero-stats{grid-template-columns:1fr}}
.progress{width:100%;height:12px;background:#0f1217;border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent2),color-mix(in srgb,var(--accent2) 75%, black 25%))}
.btn,.small-btn,.filter-pill{border:none;border-radius:12px;padding:10px 12px}.btn.primary,.small-btn.primary{background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 75%, black 25%));color:#071c10;font-weight:900}.btn.secondary,.small-btn.secondary{background:linear-gradient(180deg,var(--panel3),var(--panel));color:var(--text)}.btn.danger,.small-btn.danger{background:linear-gradient(180deg,#ff8989,#d84a4a);color:#290000;font-weight:900}.small-btn{padding:8px 10px}.button-row,.filters,.meta-chips{display:flex;gap:8px;flex-wrap:wrap}.filter-pill{background:rgba(255,255,255,.05);color:var(--text)}.filter-pill.active{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%, transparent);background:color-mix(in srgb,var(--accent) 11%, #1e2c27)}
.habit-list{display:grid;gap:10px;margin-top:12px;padding-left:18px;position:relative}.habit-list:before{content:"";position:absolute;left:7px;top:4px;bottom:4px;width:2px;background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 55%, white 10%),rgba(159,121,255,.3))}.habit-item{position:relative;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px 12px 12px 14px;margin-left:10px}.habit-item:before{content:"";position:absolute;left:-10px;top:22px;width:12px;height:2px;background:color-mix(in srgb,var(--accent) 60%, white 10%)}.chip{font-size:12px;padding:6px 8px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);color:var(--muted)}.chip.bad{background:rgba(255,102,102,.12);border-color:rgba(255,102,102,.28);color:#ffd1d1}
.reward-plate{min-height:96px;border-radius:16px;background:linear-gradient(180deg,var(--panel3),var(--panel));display:grid;place-items:center;font-size:46px;border:1px solid rgba(255,255,255,.06);margin-bottom:10px}
.toast-stack{position:fixed;right:16px;bottom:90px;display:grid;gap:10px;z-index:60}.toast{min-width:220px;max-width:300px;padding:12px 14px;border-radius:16px;background:linear-gradient(180deg,#2c3342,#1d2230);border:1px solid var(--border);box-shadow:var(--shadow)}.toast.good{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 35%, transparent),var(--shadow)}.toast.bad{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--danger) 35%, transparent),var(--shadow)}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(4px);z-index:80}.modal-host{position:fixed;inset:0;display:grid;place-items:center;z-index:81;padding:16px}.modal{width:min(92vw,620px);max-height:88vh;overflow:auto;background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow)}.modal-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:16px;border-bottom:1px solid rgba(255,255,255,.06)}.modal-body{padding:16px;display:grid;gap:12px}.modal-body label{display:grid;gap:6px;font-size:13px;color:var(--muted)}.modal-body input,.modal-body select{width:100%;background:#12161d;color:var(--text);border:1px solid var(--border);border-radius:12px;padding:12px}
.close-btn{width:40px;height:40px;border:none;border-radius:12px;background:linear-gradient(180deg,var(--panel3),var(--panel));color:var(--text)}.picker-trigger{border:1px dashed rgba(255,255,255,.16);border-radius:14px;padding:12px;background:rgba(255,255,255,.03);display:flex;justify-content:space-between;align-items:center}.theme-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}@media (max-width:900px){.theme-grid{grid-template-columns:1fr}}.theme-card{border:1px solid var(--border);border-radius:16px;padding:14px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01));text-align:left;color:var(--text)}.theme-card.active{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%, transparent),0 12px 28px rgba(0,0,0,.16)}.theme-card-title{font-weight:900;margin-bottom:4px}.theme-card-sub{font-size:12px;color:var(--muted)}
.icon-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:10px}.icon-btn{border:none;border-radius:14px;min-height:54px;font-size:26px;background:#1f2430;color:var(--text)}@media (max-width:700px){.icon-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}
/* overworld */ body.theme-overworld{--bg:#101114;--bg2:#171a20;--panel:#181b20;--panel2:#242a34;--panel3:#2d3440;--border:#313949;--text:#eef3ff;--muted:#99a5bf;--accent:#49f29c;--accent2:#ffc64a;--radius:18px}
/* nether */ body.theme-nether{--bg:#120c0c;--bg2:#3b1511;--panel:#241414;--panel2:#341f1f;--panel3:#472828;--border:#6b3a33;--text:#fff2ee;--muted:#d6a7a1;--accent:#ff7a59;--accent2:#ffbf57;--radius:8px} body.theme-nether .tabs{gap:4px;padding:8px;background:linear-gradient(180deg,rgba(59,21,17,.96),rgba(18,12,12,.98))} body.theme-nether .tab-btn{text-transform:uppercase;letter-spacing:.06em;border-radius:8px;background:linear-gradient(180deg,#4a2222,#251111)} body.theme-nether .app-shell{display:grid;gap:16px} body.theme-nether .hero{grid-template-columns:1fr} body.theme-nether .hero-stats{grid-template-columns:repeat(2,minmax(0,1fr))} body.theme-nether .reward-grid{grid-template-columns:repeat(5,minmax(0,1fr))} body.theme-nether .card,body.theme-nether .skill-card,body.theme-nether .reward-card,body.theme-nether .quest-card,body.theme-nether .modal{border-radius:8px} body.theme-nether .reward-card{background:linear-gradient(180deg,#55251d,#2b1410)} body.theme-nether .reward-plate{min-height:80px;border-radius:8px;background:linear-gradient(180deg,#5d2c22,#2a1511)}
/* end */ body.theme-end{--bg:#0d0b14;--bg2:#221c42;--panel:#171525;--panel2:#221d35;--panel3:#2f2850;--border:#5a4d86;--text:#f7f2ff;--muted:#bbb0de;--accent:#8d79ff;--accent2:#69e8ff;--radius:26px} body.theme-end .topbar{border-bottom:none;background:rgba(17,12,28,.82)} body.theme-end .tabs{max-width:260px;position:fixed;left:16px;top:96px;bottom:16px;height:auto;grid-template-columns:1fr;align-content:start;background:rgba(18,15,31,.72);border:1px solid rgba(105,232,255,.1);border-radius:24px;padding:12px} body.theme-end .app-shell{padding-left:300px;max-width:none;margin:0}@media (max-width:980px){body.theme-end .tabs{position:sticky;left:auto;top:76px;bottom:auto;max-width:none;height:auto;grid-template-columns:repeat(5,1fr);border-radius:18px}body.theme-end .app-shell{padding-left:16px}} body.theme-end .tab-btn,body.theme-end .pill,body.theme-end .btn,body.theme-end .small-btn{border-radius:999px} body.theme-end .hero{grid-template-columns:280px 1fr}@media (max-width:980px){body.theme-end .hero{grid-template-columns:1fr}} body.theme-end .reward-grid{grid-template-columns:repeat(3,minmax(0,1fr))} body.theme-end .reward-card,body.theme-end .card,body.theme-end .skill-card,body.theme-end .quest-card,body.theme-end .modal{box-shadow:0 0 0 1px rgba(105,232,255,.08),0 16px 34px rgba(0,0,0,.28)}


/* ===== V6 Theme-specific component templates ===== */
.merchant-board{background:
  linear-gradient(180deg, rgba(73,242,156,.035), rgba(255,255,255,.01)),
  linear-gradient(180deg, rgba(36,42,52,.92), rgba(22,25,32,.98));
}
.merchant-quest-list{display:grid;gap:10px}
.merchant-note{
  padding:12px 14px;border-radius:16px;border:1px dashed rgba(255,255,255,.12);
  background:linear-gradient(180deg, rgba(73,242,156,.04), rgba(255,255,255,.01));
}
.merchant-skill-grid,.merchant-reward-shelf,.merchant-skill-layout{
  display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))
}
.merchant-skill-card,.merchant-reward-card,.merchant-shelf-item{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:12px;
}
@media (max-width:860px){
  .merchant-skill-grid,.merchant-reward-shelf,.merchant-skill-layout{grid-template-columns:1fr}
}

.nether-shell{display:grid;gap:14px}
.nether-banner{
  border-radius:10px!important;
  background:
    linear-gradient(180deg, rgba(255,122,89,.1), rgba(255,255,255,.01)),
    linear-gradient(180deg, #4f211a, #210f0d);
}
.nether-banner-grid{display:grid;grid-template-columns:180px 1fr;gap:14px;align-items:center}
.nether-stat-wall{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.nether-stat{
  border:1px solid rgba(255,122,89,.22);border-radius:8px;padding:10px 12px;
  background:linear-gradient(180deg, rgba(255,122,89,.08), rgba(255,255,255,.01));
}
.nether-stat span{display:block;font-size:11px;color:var(--muted);letter-spacing:.08em}
.nether-stat strong{display:block;font-size:22px;margin-top:4px}
.nether-reward-strip,.nether-reward-grid,.nether-skill-grid{
  display:grid;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))
}
.nether-reward-box,.nether-crate-card,.nether-skill-card-full{
  border:1px solid rgba(255,122,89,.18);border-radius:8px;padding:12px;
  background:linear-gradient(180deg, rgba(255,122,89,.08), rgba(255,255,255,.01));
}
.nether-reward-icon{
  min-height:72px;border-radius:8px;display:grid;place-items:center;font-size:36px;
  background:linear-gradient(180deg,#5d2c22,#2a1511);margin-bottom:10px;border:1px solid rgba(255,191,87,.16);
}
.nether-quest-line,.nether-skill-line{
  border:1px solid rgba(255,122,89,.16);border-radius:8px;padding:10px 12px;background:rgba(255,122,89,.05)
}
.nether-mini-bar{height:8px;background:#220f0d;border-radius:999px;overflow:hidden;margin-top:8px}
.nether-mini-bar span{display:block;height:100%;background:linear-gradient(90deg,#ffbf57,#ff7a59)}
.nether-analytics{display:grid;gap:14px}
.nether-analytics-bar{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
@media (max-width:1100px){
  .nether-reward-strip,.nether-reward-grid,.nether-skill-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .nether-stat-wall,.nether-analytics-bar{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:860px){
  .nether-banner-grid{grid-template-columns:1fr}
  .nether-reward-strip,.nether-reward-grid,.nether-skill-grid,.nether-stat-wall,.nether-analytics-bar{grid-template-columns:1fr}
}

.end-shell{display:grid;gap:14px}
.end-hero-grid{display:grid;grid-template-columns:260px 1fr;gap:14px}
.end-command{
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
    linear-gradient(180deg, rgba(37,30,66,.95), rgba(18,15,31,.99));
}
.end-widget-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px
}
.end-widget{
  border-radius:20px;padding:14px;border:1px solid rgba(105,232,255,.1);
  background:linear-gradient(180deg, rgba(141,121,255,.08), rgba(255,255,255,.01));
}
.end-widget span{display:block;font-size:11px;color:var(--muted)}
.end-widget strong{display:block;font-size:24px;margin-top:6px}
.end-module{border-radius:28px!important}
.end-skill-stack,.end-reward-column,.end-quest-stack{display:grid;gap:10px}
.end-skill-card,.end-reward-card,.end-quest-card{
  border-radius:20px;padding:12px 14px;border:1px solid rgba(105,232,255,.08);
  background:rgba(141,121,255,.05)
}
.end-reward-left{display:flex;gap:10px;align-items:center}
.end-catalog{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.end-catalog-item,.end-index-card{min-width:0}
.end-skill-index{display:grid;grid-template-columns:1fr;gap:14px}
.end-analytics-shell{display:grid;gap:14px}
@media (max-width:980px){
  .end-hero-grid{grid-template-columns:1fr}
  .end-widget-grid,.end-catalog{grid-template-columns:1fr}
}


/* ===== V6.2 modal hard fix ===== */
.modal-backdrop.hidden,
.modal-host.hidden{
  display:none !important;
  pointer-events:none !important;
}
.modal-backdrop{
  pointer-events:auto;
}
.modal-host{
  pointer-events:none;
}
.modal-host .modal{
  pointer-events:auto;
}
body:not(.modal-open) .modal-backdrop,
body:not(.modal-open) .modal-host{
  display:none !important;
  pointer-events:none !important;
}
body.modal-open{
  overflow:hidden;
}


/* ===== V6.3 mobile tab scroll fix ===== */
html, body {
  max-width: 100%;
  overflow-x: hidden !important;
}

.topbar,
.app-shell,
.card,
.skill-card,
.reward-card,
.quest-card,
.stat-card,
.hero,
.grid2,
.grid3,
.grid4,
.reward-grid,
.skill-grid,
.end-shell,
.nether-shell,
.end-hero-grid,
.nether-banner-grid,
.end-widget-grid {
  min-width: 0;
}

.tabs {
  width: 100%;
  max-width: 100%;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center;
}
.tabs::-webkit-scrollbar {
  display: none;
}
.tabs .tab-btn {
  flex: 0 0 auto;
  min-width: 120px;
  white-space: nowrap;
}

@media (max-width: 980px) {
  .tabs {
    gap: 8px;
    padding: 8px 10px;
  }

  .tabs .tab-btn {
    min-width: 110px;
  }

  body.theme-end .tabs {
    position: sticky !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    top: 76px !important;
    max-width: 100% !important;
    width: 100% !important;
    grid-template-columns: none !important;
    border-radius: 18px !important;
  }

  body.theme-end .app-shell {
    padding-left: 12px !important;
    margin: 0 auto !important;
    max-width: 1320px !important;
  }

  body.theme-end .end-hero-grid,
  body.theme-end .grid2,
  body.theme-end .grid3 {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .topbar {
    overflow-x: hidden;
  }

  .topbar-right {
    width: 100%;
    max-width: 100%;
  }

  .tabs {
    border-radius: 16px;
  }

  .tabs .tab-btn {
    min-width: 104px;
    font-size: 13px;
  }

  .app-shell {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  body.theme-nether .reward-grid,
  body.theme-overworld .reward-grid,
  body.theme-end .reward-grid,
  .merchant-skill-grid,
  .merchant-reward-shelf,
  .merchant-skill-layout,
  .nether-reward-strip,
  .nether-reward-grid,
  .nether-skill-grid,
  .end-catalog,
  .end-skill-index,
  .end-widget-grid {
    grid-template-columns: 1fr !important;
  }
}
