/* ========================================
   Numeral — Clean Dark Theme
   ======================================== */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --c-bg:     #09090b;
  --c-surface:#141417;
  --c-raised: #1c1c21;
  --c-border: #27272a;
  --c-border2:#3f3f46;
  --c-text:   #fafafa;
  --c-text2:  #a1a1aa;
  --c-text3:  #71717a;
  --c-green:  #22c55e;
  --c-cyan:   #06b6d4;
  --c-purple: #a78bfa;
  --c-orange: #f97316;
  --c-red:    #ef4444;
  --c-yellow: #eab308;
  --c-blue:   #3b82f6;
  --mono: 'JetBrains Mono', monospace;
  --sans: 'Inter', -apple-system, sans-serif;
  --r:  10px;
  --r2: 8px;
  --sidebar: 220px;
}

html{font-size:14px}
body{
  font-family:var(--sans);
  background:var(--c-bg);
  color:var(--c-text);
  display:flex;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:3px}

/* ===== Sidebar ===== */
.sidebar{
  width:var(--sidebar);
  background:var(--c-surface);
  border-right:1px solid var(--c-border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;
  z-index:90;
}
.sidebar-head{
  padding:20px 18px;
  border-bottom:1px solid var(--c-border);
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:30px;height:30px;
  background:var(--c-text);
  color:var(--c-bg);
  display:flex;align-items:center;justify-content:center;
  border-radius:8px;
  font-family:var(--mono);font-weight:700;font-size:.85rem;
}
.brand-name{font-weight:700;font-size:1.05rem;letter-spacing:-.02em}

.nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}
.nav-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;
  border-radius:var(--r2);
  color:var(--c-text3);
  text-decoration:none;
  font-size:.87rem;font-weight:500;
  transition:all .15s;
  cursor:pointer;
}
.nav-link:hover{color:var(--c-text2);background:var(--c-raised)}
.nav-link.active{color:var(--c-text);background:var(--c-raised)}
.nav-link svg{opacity:.5;flex-shrink:0}
.nav-link.active svg{opacity:1}

.sidebar-foot{
  padding:14px 18px;
  border-top:1px solid var(--c-border);
}
.sidebar-label{font-size:.72rem;color:var(--c-text3);font-family:var(--mono)}

/* ===== Main ===== */
.main{
  margin-left:var(--sidebar);
  flex:1;
  padding:0 48px 80px;
  max-width:960px;
}

.page{display:none}
.page.active{display:block}

.page-head{padding:40px 0 28px}
.page-title{font-size:1.55rem;font-weight:700;letter-spacing:-.03em}
.page-desc{color:var(--c-text3);font-size:.9rem;margin-top:6px}

/* ===== Card ===== */
.card{
  background:var(--c-surface);
  border:1px solid var(--c-border);
  border-radius:var(--r);
  padding:20px;
  margin-bottom:16px;
}
.card-head{
  display:flex;align-items:center;justify-content:space-between;
  font-size:.9rem;font-weight:600;
  margin-bottom:16px;
  color:var(--c-text2);
}

/* ===== Base Tabs ===== */
.base-tabs{
  display:flex;gap:0;
  background:var(--c-bg);
  border-radius:var(--r2);
  padding:3px;
  margin-bottom:16px;
}
.base-tab{flex:1;cursor:pointer}
.base-tab input{display:none}
.base-tab span{
  display:flex;flex-direction:column;align-items:center;
  padding:8px 0;
  border-radius:6px;
  font-family:var(--mono);font-size:.82rem;font-weight:600;
  color:var(--c-text3);
  transition:all .15s;
}
.base-tab small{
  font-size:.62rem;font-weight:400;
  margin-top:1px;opacity:.7;
  font-family:var(--sans);
}
.base-tab input:checked+span{
  background:var(--c-raised);
  color:var(--c-text);
  box-shadow:0 1px 3px rgba(0,0,0,.3);
}
.base-tab:hover span{color:var(--c-text2)}

/* ===== Input ===== */
.input-row{display:flex;gap:8px;align-items:center}
#numIn{
  flex:1;
  padding:12px 16px;
  background:var(--c-bg);
  border:1px solid var(--c-border);
  border-radius:var(--r2);
  color:var(--c-text);
  font-family:var(--mono);
  font-size:1.35rem;font-weight:600;
  outline:none;
  transition:border-color .2s;
}
#numIn:focus{border-color:var(--c-border2)}
#numIn::placeholder{color:var(--c-text3);font-weight:400;font-size:.95rem}
.btn-icon{
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  background:transparent;
  border:1px solid var(--c-border);
  border-radius:var(--r2);
  color:var(--c-text3);
  font-size:1.2rem;cursor:pointer;
  transition:all .15s;
}
.btn-icon:hover{background:var(--c-raised);color:var(--c-text)}
.input-msg{
  font-size:.78rem;margin-top:8px;min-height:1.1em;
  color:var(--c-red);
}

/* ===== Results Grid ===== */
.grid-4{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin-bottom:16px;
}
.res-card{
  position:relative;
  padding:18px 20px;
  transition:border-color .2s;
}
.res-card:hover{border-color:var(--c-border2)}
.res-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.res-label{font-size:.78rem;color:var(--c-text3);font-weight:500}
.res-badge{
  font-family:var(--mono);font-size:.65rem;font-weight:700;
  padding:2px 7px;border-radius:4px;
  letter-spacing:.06em;
}
.res-dec .res-badge{background:rgba(34,197,94,.1);color:var(--c-green)}
.res-bin .res-badge{background:rgba(6,182,212,.1);color:var(--c-cyan)}
.res-oct .res-badge{background:rgba(167,139,250,.1);color:var(--c-purple)}
.res-hex .res-badge{background:rgba(249,115,22,.1);color:var(--c-orange)}

.res-val{
  font-family:var(--mono);
  font-size:1.4rem;font-weight:700;
  word-break:break-all;
  min-height:2em;display:flex;align-items:center;
  line-height:1.4;
}
.res-dec .res-val{color:var(--c-green)}
.res-bin .res-val{color:var(--c-cyan)}
.res-oct .res-val{color:var(--c-purple)}
.res-hex .res-val{color:var(--c-orange)}

.res-bar{height:2px;background:var(--c-border);border-radius:1px;margin-top:12px;overflow:hidden}
.res-fill{height:100%;width:0;border-radius:1px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.fill-dec{background:var(--c-green)}
.fill-bin{background:var(--c-cyan)}
.fill-oct{background:var(--c-purple)}
.fill-hex{background:var(--c-orange)}

.btn-copy{
  position:absolute;top:10px;right:10px;
  background:none;border:none;
  font-size:.7rem;color:var(--c-text3);
  cursor:pointer;padding:4px 8px;border-radius:4px;
  opacity:0;transition:opacity .15s;
  font-family:var(--sans);
}
.res-card:hover .btn-copy{opacity:1}
.btn-copy:hover{background:var(--c-raised);color:var(--c-text)}

/* ===== Bits ===== */
.bits{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:center;
  padding:8px 0;
}
.empty{
  width:100%;text-align:center;
  color:var(--c-text3);font-size:.85rem;
  padding:20px 0;
}
.bit-grp{display:flex;flex-direction:column;align-items:center;gap:3px}
.bit-grp .row{display:flex;gap:3px}
.bit-grp .powers{display:flex;gap:3px}
.bit-cell{
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:.82rem;font-weight:700;
  border-radius:6px;
  transition:all .2s;
}
.bit-cell.on{background:rgba(34,197,94,.12);color:var(--c-green);border:1px solid rgba(34,197,94,.2)}
.bit-cell.off{background:var(--c-bg);color:var(--c-text3);border:1px solid var(--c-border)}
.bit-pw{
  width:32px;text-align:center;
  font-size:.52rem;color:var(--c-text3);
  font-family:var(--mono);
}
.bit-lbl{font-size:.6rem;color:var(--c-text3);font-family:var(--mono);margin-top:1px}

.tag{
  font-family:var(--mono);font-size:.72rem;
  color:var(--c-text3);
  background:var(--c-bg);
  padding:2px 8px;border-radius:4px;
}

/* ===== Explanation ===== */
.exp-tabs{
  display:flex;gap:0;
  background:var(--c-bg);
  border-radius:var(--r2);
  padding:3px;
  margin-bottom:16px;
}
.exp-tab{
  flex:1;
  padding:7px 0;
  background:transparent;border:none;
  font-family:var(--mono);font-size:.8rem;font-weight:600;
  color:var(--c-text3);
  border-radius:6px;
  cursor:pointer;
  transition:all .15s;
}
.exp-tab:hover{color:var(--c-text2)}
.exp-tab.on{background:var(--c-raised);color:var(--c-text);box-shadow:0 1px 3px rgba(0,0,0,.3)}

.exp-body{font-family:var(--mono);font-size:.85rem;color:var(--c-text2);line-height:1.8}

.st{
  padding:14px 16px;
  background:var(--c-bg);
  border-radius:var(--r2);
  margin-bottom:8px;
  border-left:3px solid var(--c-border2);
}
.st:hover{border-left-color:var(--c-green)}
.st-head{
  font-weight:600;color:var(--c-text);
  margin-bottom:4px;font-size:.85rem;
  display:flex;align-items:center;gap:8px;
}
.st-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:50%;
  background:var(--c-border);color:var(--c-text);
  font-size:.65rem;font-weight:700;flex-shrink:0;
}
.st-body{color:var(--c-text2);font-size:.82rem;line-height:1.8;margin-left:28px}
.st-body .hl{color:var(--c-cyan);font-weight:600}
.st-body .rs{color:var(--c-green);font-weight:700}
.st-body .dm{color:var(--c-text3);margin:0 4px}
.st-note{
  margin:8px 0 0 28px;
  padding:8px 12px;
  background:var(--c-surface);
  border-radius:6px;
  font-family:var(--sans);
  font-size:.78rem;
  color:var(--c-text3);
  line-height:1.6;
  border:1px solid var(--c-border);
}
.st-note b{color:var(--c-text2)}
.st.final{border-left-color:var(--c-green)}

/* ===== Table ===== */
.table-ctrl{
  display:flex;gap:8px;align-items:center;margin-bottom:16px;
}
.table-ctrl input{
  width:70px;padding:7px 10px;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:6px;color:var(--c-text);
  font-family:var(--mono);font-size:.82rem;
  outline:none;
}
.table-ctrl input:focus{border-color:var(--c-border2)}
.table-sep{color:var(--c-text3);font-size:.85rem}
.table-wrap{overflow-x:auto}
.table-wrap table{
  width:100%;border-collapse:collapse;
  font-family:var(--mono);font-size:.82rem;
}
.table-wrap th{
  text-align:left;padding:8px 14px;
  font-weight:600;color:var(--c-text2);
  border-bottom:1px solid var(--c-border);
  font-size:.72rem;text-transform:uppercase;
  letter-spacing:.04em;
}
.table-wrap td{
  padding:7px 14px;
  border-bottom:1px solid var(--c-border);
  color:var(--c-text3);
}
.table-wrap tr:hover td{background:var(--c-raised)}
.td-d{color:var(--c-green)}
.td-b{color:var(--c-cyan)}
.td-o{color:var(--c-purple)}
.td-h{color:var(--c-orange)}

/* ===== Quiz ===== */
.quiz-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.diff-group{display:flex;gap:4px}
.diff{
  padding:5px 14px;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:6px;
  font-size:.78rem;font-weight:600;
  color:var(--c-text3);cursor:pointer;
  transition:all .15s;
}
.diff:hover{color:var(--c-text2);border-color:var(--c-border2)}
.diff.active{background:var(--c-raised);color:var(--c-text);border-color:var(--c-border2)}
.quiz-score{font-family:var(--mono);font-size:.82rem;color:var(--c-text3)}

.quiz-q{
  padding:20px;
  background:var(--c-bg);
  border-radius:var(--r2);
  font-family:var(--mono);
  font-size:1.1rem;
  font-weight:600;
  text-align:center;
  margin-bottom:16px;
  line-height:1.6;
  border:1px solid var(--c-border);
}
.quiz-input{
  width:100%;padding:10px 14px;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:var(--r2);color:var(--c-text);
  font-family:var(--mono);font-size:1.05rem;font-weight:600;
  outline:none;margin-bottom:12px;
  transition:border-color .2s;
}
.quiz-input:focus{border-color:var(--c-border2)}
.quiz-btns{display:flex;gap:8px}

.btn{
  padding:8px 20px;
  background:var(--c-text);color:var(--c-bg);
  border:none;border-radius:var(--r2);
  font-size:.82rem;font-weight:600;
  cursor:pointer;transition:opacity .15s;
}
.btn:hover{opacity:.85}
.btn-ghost{
  background:transparent;color:var(--c-text2);
  border:1px solid var(--c-border);
}
.btn-ghost:hover{background:var(--c-raised);color:var(--c-text);opacity:1}

.quiz-fb{
  margin-top:14px;padding:12px 16px;
  border-radius:var(--r2);
  font-size:.85rem;font-weight:500;
  line-height:1.6;
  min-height:0;
}
.quiz-fb:empty{display:none}
.quiz-fb.ok{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.15);color:var(--c-green)}
.quiz-fb.no{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.15);color:var(--c-red)}
.quiz-fb.hint{background:rgba(234,179,8,.06);border:1px solid rgba(234,179,8,.12);color:var(--c-yellow)}

/* ===== Guide ===== */
.guide-section{}
.guide-h2{
  font-size:1.05rem;font-weight:700;letter-spacing:-.02em;
  margin-bottom:12px;
}
.guide-p{
  color:var(--c-text2);font-size:.88rem;line-height:1.75;
  margin-bottom:8px;
}
.guide-p b{color:var(--c-text)}

.guide-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-top:14px;
}
.guide-item{
  background:var(--c-bg);border-radius:var(--r2);padding:14px 16px;
  display:flex;flex-direction:column;gap:6px;
  border:1px solid var(--c-border);
}
.guide-tag,.why-badge{
  font-family:var(--mono);font-size:.68rem;font-weight:700;
  padding:2px 8px;border-radius:4px;width:fit-content;
  letter-spacing:.05em;
}
.tag-dec{background:rgba(34,197,94,.1);color:var(--c-green)}
.tag-bin{background:rgba(6,182,212,.1);color:var(--c-cyan)}
.tag-oct{background:rgba(167,139,250,.1);color:var(--c-purple)}
.tag-hex{background:rgba(249,115,22,.1);color:var(--c-orange)}
.guide-sym{
  font-family:var(--mono);font-size:.85rem;color:var(--c-text);
  font-weight:600;letter-spacing:.04em;
}
.guide-note{font-size:.72rem;color:var(--c-text3)}

/* count table */
.count-table{margin-top:12px}
.count-row{
  display:grid;grid-template-columns:70px 100px 1fr;
  padding:7px 14px;font-size:.84rem;
  border-bottom:1px solid var(--c-border);
  align-items:center;
}
.count-sm .count-row{grid-template-columns:80px 1fr}
.count-header{
  font-weight:600;color:var(--c-text3);font-size:.74rem;
  text-transform:uppercase;letter-spacing:.04em;
  border-bottom:1px solid var(--c-border2);
}
.ct-dec{color:var(--c-green);font-family:var(--mono);font-weight:600}
.ct-bin{color:var(--c-cyan);font-family:var(--mono);font-weight:600}
.ct-oct{color:var(--c-purple);font-family:var(--mono);font-weight:600}
.ct-hex{color:var(--c-orange);font-family:var(--mono);font-weight:600}
.ct-desc{color:var(--c-text3);font-size:.78rem}
.ct-bump{background:rgba(6,182,212,.04)}

.guide-tip{
  margin-top:10px;padding:14px 18px;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:var(--r2);border-left:3px solid var(--c-cyan);
  font-size:.82rem;color:var(--c-text2);line-height:1.8;
}
.guide-tip b{color:var(--c-text)}
.guide-tip code{
  font-family:var(--mono);color:var(--c-cyan);font-weight:600;
  font-size:.82rem;
}

/* place value demo */
.place-demo{display:flex;flex-direction:column;gap:18px;margin-top:14px}
.place-example{}
.place-label{font-size:.82rem;color:var(--c-text3);margin-bottom:8px;display:block}
.place-label b{color:var(--c-text)}
.place-boxes{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.place-box{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:var(--r2);padding:10px 16px;
}
.place-box.pb-bin{border-color:rgba(6,182,212,.2)}
.place-dig{font-family:var(--mono);font-size:1.1rem;font-weight:700;color:var(--c-text)}
.place-val{font-family:var(--mono);font-size:.68rem;color:var(--c-text3)}
.place-eq{font-family:var(--mono);font-size:.72rem;color:var(--c-cyan);font-weight:600}
.place-plus{color:var(--c-text3);font-size:.85rem}

/* why grid */
.why-grid{display:flex;flex-direction:column;gap:10px}
.why-item{
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:var(--r2);padding:16px 18px;
  display:flex;align-items:flex-start;gap:14px;
}
.why-item p{color:var(--c-text2);font-size:.84rem;line-height:1.7}

@media(max-width:560px){
  .guide-grid{grid-template-columns:1fr}
  .count-row{grid-template-columns:50px 80px 1fr}
  .place-boxes{gap:4px}
  .place-box{padding:8px 10px}
  .hex-map{grid-template-columns:repeat(4,1fr)}
  .pattern-list .pat-item{flex-wrap:wrap}
}

/* ===== Tips ===== */
.power-row{
  display:flex;flex-wrap:wrap;gap:6px;
  margin:12px 0 10px;
}
.power-cell{
  display:flex;flex-direction:column;align-items:center;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:var(--r2);padding:10px 14px;gap:4px;
  min-width:56px;
}
.pw-exp{font-family:var(--mono);font-size:.72rem;color:var(--c-text3)}
.pw-val{font-family:var(--mono);font-size:1rem;font-weight:700;color:var(--c-cyan)}

.tip-example{
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:var(--r2);padding:16px 18px;
  margin-bottom:10px;
}
.tip-q{
  font-family:var(--mono);font-size:1rem;font-weight:700;
  color:var(--c-text);margin-bottom:12px;
}
.tip-q sub{color:var(--c-text3);font-size:.7rem}
.tip-work{display:flex;flex-direction:column;gap:10px}
.tip-bits{display:flex;gap:6px;flex-wrap:wrap}
.tip-bit{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  width:38px;height:48px;
  border-radius:6px;
  font-family:var(--mono);font-weight:700;
  justify-content:center;
}
.tip-bit.on{background:rgba(34,197,94,.1);color:var(--c-green);border:1px solid rgba(34,197,94,.2)}
.tip-bit.off{background:var(--c-surface);color:var(--c-text3);border:1px solid var(--c-border)}
.tip-pw{font-size:.6rem;color:var(--c-text3);font-weight:400}
.tip-calc{
  font-family:var(--mono);font-size:.88rem;
  color:var(--c-text2);line-height:1.8;
}
.tip-calc b{color:var(--c-green)}

.tip-steps{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.tip-step{
  display:grid;grid-template-columns:40px 100px 28px 1fr;
  align-items:center;gap:6px;
  padding:5px 10px;
  font-family:var(--mono);font-size:.82rem;
  border-bottom:1px solid var(--c-border);
}
.ts-num{color:var(--c-text);font-weight:600}
.ts-try{color:var(--c-text3)}
.ts-yn{font-weight:700;text-align:center;border-radius:4px;padding:1px 6px;font-size:.72rem}
.ts-yn.y{color:var(--c-green);background:rgba(34,197,94,.1)}
.ts-yn.n{color:var(--c-red);background:rgba(239,68,68,.08)}
.ts-rest{color:var(--c-text2);font-size:.78rem}

.hex-map{
  display:grid;grid-template-columns:repeat(8,1fr);
  gap:4px;margin:12px 0;
}
.hm-item{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  background:var(--c-bg);border:1px solid var(--c-border);
  border-radius:6px;padding:8px 4px;
}
.hm-hex{font-family:var(--mono);font-size:.9rem;font-weight:700;color:var(--c-orange)}
.hm-bin{font-family:var(--mono);font-size:.68rem;color:var(--c-cyan)}

.pattern-list{display:flex;flex-direction:column;gap:4px;margin-top:10px}
.pat-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 14px;
  background:var(--c-bg);border-radius:6px;
  border:1px solid var(--c-border);
  font-family:var(--mono);font-size:.82rem;
}
.pat-bin{color:var(--c-cyan);font-weight:600;min-width:90px}
.pat-eq{color:var(--c-text3)}
.pat-dec{color:var(--c-green);font-weight:700;min-width:36px}
.pat-hex{color:var(--c-orange);min-width:40px}
.pat-note{color:var(--c-text3);font-size:.72rem;font-family:var(--sans);margin-left:auto}

/* ===== Toast ===== */
.toast{
  position:fixed;bottom:24px;right:24px;
  padding:10px 20px;
  background:var(--c-raised);
  border:1px solid var(--c-border);
  border-radius:var(--r2);
  color:var(--c-text);
  font-size:.82rem;font-weight:500;
  z-index:999;
  opacity:0;transform:translateY(8px);
  transition:all .25s;
  pointer-events:none;
}
.toast.show{opacity:1;transform:translateY(0)}

/* ===== Responsive ===== */
@media(max-width:860px){
  .sidebar{display:none}
  .main{margin-left:0;padding:0 20px 60px}
}
@media(max-width:560px){
  .grid-4{grid-template-columns:1fr}
  .res-val{font-size:1.15rem}
  #numIn{font-size:1.1rem}
}
