:root {
  --bg: #131920;
  --surface: #0f1a24;
  --surface2: #131e2a;
  --border: #1c2d3e;
  --accent: #3ecfaa;
  --accent-dim: #1e8a72;
  --accent-glow: rgba(62,207,170,.12);
  --sky: #5ab8d4;
  --sky-dim: #2a7090;
  --text: #c8dce8;
  --text-dim: #7a96a8;
  --text-bright: #eef6ff;
  --red: #e05060;
  --green: #4dc890;
  --yellow: #c8b840;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Noto Sans KR',sans-serif;font-size:14px;line-height:1.7;min-height:100vh;}

body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 70% 50% at 10% 20%, rgba(62,207,170,.05) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 90% 80%, rgba(90,184,212,.04) 0%, transparent 60%),
    radial-gradient(1px 1px at 15% 30%, rgba(62,207,170,.6) 0%, transparent 0%),
    radial-gradient(1px 1px at 40% 15%, rgba(90,184,212,.5) 0%, transparent 0%),
    radial-gradient(1px 1px at 70% 45%, rgba(255,255,255,.4) 0%, transparent 0%),
    radial-gradient(1px 1px at 85% 20%, rgba(62,207,170,.5) 0%, transparent 0%),
    radial-gradient(1px 1px at 25% 70%, rgba(255,255,255,.3) 0%, transparent 0%),
    radial-gradient(1px 1px at 55% 85%, rgba(90,184,212,.4) 0%, transparent 0%),
    radial-gradient(1px 1px at 92% 55%, rgba(255,255,255,.3) 0%, transparent 0%);
}

.layout{display:flex;min-height:100vh;}

/* SIDEBAR */
.sidebar{
  position:fixed;top:0;left:0;height:100vh;
  width:52px;background:rgba(13,18,24,.96);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  z-index:200;transition:width .25s cubic-bezier(.4,0,.2,1);overflow:hidden;
}
.sidebar:hover{width:196px;}
.sidebar.open{width:196px;}

.sidebar-top{padding:14px 0 10px;border-bottom:1px solid var(--border);flex-shrink:0;}
.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 13px;height:34px;white-space:nowrap;overflow:hidden;}
.logo-icon{font-size:17px;flex-shrink:0;width:26px;text-align:center;}
.logo-text{font-size:11px;font-weight:700;color:var(--accent);opacity:0;transition:opacity .2s .05s;white-space:nowrap;letter-spacing:.04em;}
.sidebar:hover .logo-text{opacity:1;}

.sidebar-nav{flex:1;padding:6px 0;overflow-y:auto;scrollbar-width:none;}
.sidebar-nav::-webkit-scrollbar{display:none;}

.tab-btn{
  display:flex;align-items:center;gap:12px;
  width:100%;padding:9px 13px;
  background:none;border:none;
  font-family:'Noto Sans KR',sans-serif;font-size:12px;font-weight:500;
  color:var(--text-dim);cursor:pointer;
  white-space:nowrap;overflow:hidden;
  transition:color .15s,background .15s;text-align:left;
}
.t-icon{font-size:15px;flex-shrink:0;width:26px;text-align:center;}
.t-label{opacity:0;transition:opacity .2s .05s;}
.sidebar:hover .t-label{opacity:1;}
.tab-btn:hover{color:var(--text);background:rgba(255,255,255,.04);}
.tab-btn.active{color:var(--accent);}
.tab-btn.active .t-icon{filter:drop-shadow(0 0 5px var(--accent));}

.sidebar-bottom{padding:10px 0;border-top:1px solid var(--border);flex-shrink:0;}
.patch-badge{display:flex;align-items:center;gap:12px;padding:6px 13px;font-size:10px;color:var(--text-dim);white-space:nowrap;overflow:hidden;}
.patch-badge .t-icon{font-size:12px;flex-shrink:0;width:26px;text-align:center;}
.patch-badge .t-label{opacity:0;transition:opacity .2s .05s;}
.sidebar:hover .patch-badge .t-label{opacity:1;}

.theme-btn{display:none;}

/* 지역 필터 */
.region-filter{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:14px;}
.region-btn{padding:6px 14px;background:transparent;border:1px solid var(--border);border-radius:2px;font-family:'Noto Sans KR',sans-serif;font-size:12px;font-weight:500;color:var(--text-dim);cursor:pointer;transition:border-color .15s,color .15s,background .15s;display:flex;align-items:center;gap:5px;}
.region-btn:hover{border-color:var(--accent-dim);color:var(--text);}
.region-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-glow);}
.region-patch{font-size:9px;color:var(--text-dim);letter-spacing:.04em;}
.region-btn.active .region-patch{color:var(--accent-dim);}
.region-section{display:block;}
.region-section.hidden{display:none;}

/* 지역별 섹션 타이틀 색상 */
.region-section[data-region="dongyeong"] .section-title .num{border-color:rgba(160,170,190,.4);color:#a0aabe;background:rgba(160,170,190,.08);}
.region-section[data-region="paenna"] .section-title .num{border-color:rgba(210,80,130,.4);color:#d2507e;background:rgba(210,80,130,.08);}
.region-section[data-region="oijis"] .section-title .num{border-color:rgba(200,170,110,.4);color:#c8aa6e;background:rgba(200,170,110,.08);}
.region-section[data-region="auksesia"] .section-title .num{border-color:rgba(90,180,100,.4);color:#5ab464;background:rgba(90,180,100,.08);}

/* 예시 테이블 상태 색상 */
.st-normal{color:var(--text-dim);}
.st-high{color:#e85a7a;font-weight:700;}
.st-best{color:#c060e0;font-weight:700;}
.st-efficient{color:#4dc890;font-weight:700;}
.st-stable{color:#d4b840;font-weight:700;}
.st-solid{color:#7aaed4;font-weight:700;}
.st-hq{color:#e85a7a;font-weight:700;}
.st-he{color:#4dc890;font-weight:700;}
.st-long{color:#b87ae0;font-weight:700;}
.st-fast{color:#4a7fd4;font-weight:700;}
.st-centered{color:#e8a030;font-weight:700;}
.st-good{color:#60c0e8;font-weight:700;}
.st-low{color:#888;font-weight:700;}

/* 햄버거 버튼 (모바일 전용) */
.menu-btn{
  display:none;
  align-items:center;justify-content:center;
  width:36px;height:36px;
  background:none;border:none;cursor:pointer;
  color:var(--text-dim);flex-shrink:0;
  transition:color .15s;
}
.menu-btn:hover{color:var(--accent);}
@media(max-width:640px){
  .menu-btn{display:flex;}
  .sidebar:hover{width:44px;}
  .sidebar.open{width:180px;}
  /* 오버레이 */
  .sidebar-overlay{display:none;position:fixed;inset:0;z-index:199;background:rgba(0,0,0,.4);}
  .sidebar-overlay.show{display:block;}
}

/* MAIN */
.main-wrap{margin-left:52px;padding:28px 32px 80px;max-width:920px;width:100%;position:relative;z-index:1;transition:margin-left .25s cubic-bezier(.4,0,.2,1);}
.tab-panel{display:none;}
.tab-panel.active{display:block;animation:fadeUp .3s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* ── PAGE HERO ── */
.page-hero{padding:28px 0 22px;margin-bottom:24px;border-bottom:1px solid var(--border);}
.eyebrow{font-size:9px;letter-spacing:.28em;color:var(--accent-dim);text-transform:uppercase;margin-bottom:8px;}
.page-hero h1{font-family:'Noto Sans KR',sans-serif;font-size:22px;font-weight:700;color:var(--text-bright);letter-spacing:.02em;margin-bottom:4px;}
.page-hero h1 em{color:var(--accent);font-style:normal;}
.page-hero p{color:var(--text-dim);font-size:12px;}

/* ── SECTION ── */
.section{margin-bottom:28px;}
.section-title{
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-dim);margin-bottom:12px;
  display:flex;align-items:center;gap:10px;
}
.section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.section-title .num{
  min-width:20px;height:20px;padding:0 5px;border:1px solid var(--accent-dim);
  border-radius:2px;display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:900;color:var(--accent);flex-shrink:0;white-space:nowrap;
}

/* ── GUIDE NOTE ── */
.guide-note{
  border-left:2px solid var(--accent-dim);
  padding:10px 14px;
  font-size:13px;line-height:1.8;color:var(--text);
  background:rgba(62,207,170,.04);
  border-radius:0 3px 3px 0;
}
.guide-note strong{color:var(--text-bright);}
.guide-note.key{
  border-left-width:3px;
  border-left-color:var(--accent);
  background:rgba(62,207,170,.07);
}
.guide-note.warn{
  border-left-color:var(--red);
  background:rgba(224,80,96,.05);
}
.guide-note.warn strong{color:var(--red);}
.guide-note.tip{
  border-left-color:var(--sky-dim);
  background:rgba(90,184,212,.04);
  font-size:12px;
  color:var(--text-dim);
}

/* 메인탭 전용 */
.home-intro{
  padding:36px 0 32px;
  border-bottom:1px solid var(--border);
  margin-bottom:32px;
}
.home-eyebrow{
  font-size:9px;letter-spacing:.3em;color:var(--accent-dim);
  text-transform:uppercase;margin-bottom:14px;
}
.home-title{
  font-size:28px;font-weight:900;color:var(--text-bright);
  line-height:1.25;letter-spacing:.01em;margin-bottom:10px;
}
.home-title em{color:var(--accent);font-style:normal;}
.home-sub{
  font-size:13px;color:var(--text-dim);line-height:1.8;
  max-width:480px;
}
.home-sub strong{color:var(--text);}
.home-cta{
  margin-top:24px;
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
}
.cta-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;
  background:var(--accent);border:none;border-radius:3px;
  font-family:'Noto Sans KR',sans-serif;font-size:13px;font-weight:700;
  color:var(--bg);cursor:pointer;
  transition:opacity .15s,transform .1s;letter-spacing:.02em;
}
.cta-btn:hover{opacity:.9;transform:translateY(-1px);}
.cta-sub-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:11px 18px;
  background:transparent;border:1px solid var(--border);border-radius:3px;
  font-family:'Noto Sans KR',sans-serif;font-size:12px;font-weight:500;
  color:var(--text-dim);cursor:pointer;
  transition:border-color .15s,color .15s;
}
.cta-sub-btn:hover{border-color:var(--accent-dim);color:var(--text);}
.home-links{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:4px;
  overflow:hidden;
  margin-bottom:32px;
}
.home-link{
  background:var(--surface);
  padding:14px 16px;
  cursor:pointer;
  transition:background .15s;
  display:flex;flex-direction:column;gap:3px;
}
.home-link:hover{background:var(--surface2);}
.home-link:hover .hl-title{color:var(--accent);}
.hl-num{font-size:9px;color:var(--text-dim);letter-spacing:.06em;margin-bottom:2px;}
.hl-title{font-size:13px;font-weight:700;color:var(--text-bright);transition:color .15s;}
.hl-desc{font-size:11px;color:var(--text-dim);line-height:1.5;}
.home-patch{
  font-size:11px;color:var(--text-dim);
  padding:10px 0 0;
  border-top:1px solid var(--border);
  display:flex;align-items:center;gap:6px;
}
.home-patch span{color:var(--accent-dim);font-weight:700;}
.update-section{
  margin-top:40px;
  padding-top:20px;
  border-top:1px solid var(--border);
}
.update-label{
  font-size:9px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-dim);margin-bottom:10px;
  display:flex;align-items:center;gap:8px;
}
.update-label::after{content:'';flex:1;height:1px;background:var(--border);}
.update-row{
  display:flex;gap:14px;align-items:baseline;
  padding:6px 0;
  border-bottom:1px solid rgba(28,45,62,.5);
  font-size:11px;
}
.update-row:last-child{border-bottom:none;}
.u-date{color:var(--accent-dim);font-weight:700;white-space:nowrap;min-width:50px;}
.u-text{color:var(--text-dim);}
.u-text.done{color:var(--text);}

/* 기타 레이아웃 요소 */
.yoshida-box{text-align:center;padding:14px 18px;margin-bottom:22px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.y-text{font-family:'Noto Sans KR',sans-serif;font-size:14px;font-weight:700;color:var(--accent);letter-spacing:.12em;margin-bottom:2px;}
.y-sub{font-size:11px;color:var(--text-dim);}
.worry-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px;}
.worry-card{padding:10px 12px;font-size:12px;color:var(--text-dim);border-bottom:1px solid var(--border);position:relative;}
.worry-card::before{content:'"';font-size:20px;color:var(--border);position:absolute;top:4px;left:6px;font-family:serif;line-height:1;}
.worry-card p{padding-left:10px;}
.checklist{display:grid;gap:5px;}
.checklist-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);}
.checklist-item:last-child{border-bottom:none;}
.check-icon{width:16px;height:16px;border:1px solid var(--accent-dim);border-radius:2px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:3px;color:var(--accent);font-size:9px;}
.item-name{font-weight:700;color:var(--text-bright);font-size:13px;}
.item-desc{font-size:11px;color:var(--text-dim);margin-top:1px;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
.stat-card{padding:12px 10px;border-bottom:2px solid var(--border);text-align:center;}
.stat-name{font-size:11px;font-weight:700;color:var(--accent);margin-bottom:4px;letter-spacing:.04em;}
.stat-desc{font-size:10px;color:var(--text-dim);margin-bottom:5px;line-height:1.5;}
.stat-goal{font-size:10px;color:var(--sky);letter-spacing:.02em;}
.rules-grid{display:grid;gap:6px;}
.rule-item{display:flex;gap:11px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border);}
.rule-item:last-child{border-bottom:none;}
.rule-item.danger .rule-title{color:var(--red);}
.rule-item.important .rule-title{color:var(--accent);}
.rule-icon{flex-shrink:0;margin-top:2px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--text-dim);}
.rule-item.danger .rule-icon{color:var(--red);}
.rule-item.important .rule-icon{color:var(--accent);}
.rule-title{font-weight:700;color:var(--text-bright);font-size:13px;margin-bottom:2px;}
.rule-desc{font-size:12px;color:var(--text-dim);line-height:1.6;}
.rule-desc strong{color:var(--red);}
.flow-steps{display:grid;gap:0;}
.flow-step{display:grid;grid-template-columns:36px 1fr;position:relative;}
.flow-step:not(:last-child) .step-line{position:absolute;left:17px;top:36px;bottom:0;width:1px;background:var(--border);}
.step-num-col{display:flex;flex-direction:column;align-items:center;padding-top:8px;}
.step-num{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:900;flex-shrink:0;z-index:1;}
.sp{background:var(--surface2);border:1px solid var(--border);color:var(--text-dim);}
.s1{background:rgba(62,207,170,.15);border:1px solid var(--accent-dim);color:var(--accent);}
.s2{background:rgba(90,184,212,.15);border:1px solid rgba(90,184,212,.4);color:var(--sky);}
.s3{background:rgba(77,200,144,.15);border:1px solid rgba(77,200,144,.4);color:var(--green);}
.s4{background:rgba(62,207,170,.2);border:1px solid var(--accent-dim);color:var(--accent);}
.s5{background:var(--accent);color:var(--bg);}
.step-body{padding:6px 0 14px 12px;}
.step-title{font-weight:700;color:var(--text-bright);font-size:13px;margin-bottom:2px;}
.step-desc{font-size:12px;color:var(--text-dim);line-height:1.6;}
.chips{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px;}
.chip{border:1px solid var(--border);border-radius:2px;padding:1px 7px;font-size:10px;color:var(--text-dim);}
.chip.hi{border-color:var(--accent-dim);color:var(--accent);}
.tag{display:inline-block;font-size:9px;padding:1px 5px;border-radius:2px;margin-left:4px;vertical-align:middle;font-weight:400;}
.tg{border:1px solid var(--accent-dim);color:var(--accent-dim);}
.tb{border:1px solid var(--sky-dim);color:var(--sky);}
.tr{border:1px solid rgba(224,80,96,.4);color:var(--red);}
.opener-compare{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.opener-card{padding:14px;border-top:2px solid var(--border);}
.opener-card.confirm{border-top-color:var(--accent-dim);}
.opener-card.jinga{border-top-color:var(--sky-dim);}
.opener-name{font-weight:900;font-size:14px;margin-bottom:2px;}
.opener-card.confirm .opener-name{color:var(--accent);}
.opener-card.jinga .opener-name{color:var(--sky);}
.opener-tag{font-size:11px;color:var(--text-dim);margin-bottom:6px;}
.opener-when{font-size:12px;color:var(--text);margin-bottom:5px;line-height:1.5;}
.opener-tip{font-size:11px;color:var(--text-dim);line-height:1.5;}
.beg-rec{margin-top:8px;font-size:11px;color:var(--accent-dim);border-top:1px solid var(--border);padding-top:6px;}
.nav-links{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.nav-link{padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;border-bottom:1px solid var(--border);transition:border-color .2s;}
.nav-link:hover{border-bottom-color:var(--accent-dim);}
.nav-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--surface2);border-radius:4px;flex-shrink:0;border:1px solid var(--border);color:var(--text-dim);}
.nav-title{font-weight:700;font-size:12px;color:var(--text-bright);}
.nav-desc{font-size:10px;color:var(--text-dim);margin-top:1px;}
.skill-group{margin-bottom:16px;}
.skill-group-title{font-size:10px;font-weight:700;color:var(--text-dim);letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;padding-left:8px;border-left:2px solid var(--border);}
.skill-cards{display:grid;gap:4px;}
.skill-card{padding:8px 0;border-bottom:1px solid var(--border);display:grid;grid-template-columns:minmax(140px,190px) 1fr;gap:0 12px;align-items:start;}
.skill-card.sp2 .sk-name{color:var(--accent);}
.skill-card.imp .sk-name{color:var(--red);}
.sk-header{display:flex;align-items:center;gap:8px;}
.sk-icon{width:28px;height:28px;border-radius:4px;flex-shrink:0;object-fit:cover;background:var(--surface2);}
.sk-name{font-weight:700;color:var(--text-bright);font-size:13px;}
.sk-sub{font-size:10px;color:var(--text-dim);margin-top:2px;padding-left:36px;}
.sk-desc{font-size:12px;color:var(--text-dim);line-height:1.6;}
.sk-stats{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px;}
.sp-pill{font-size:10px;padding:1px 6px;border-radius:10px;border:1px solid var(--border);color:var(--text-dim);}
.status-cards{display:grid;gap:5px;}
.status-card{padding:10px 0;border-bottom:1px solid var(--border);}
.status-card:last-child{border-bottom:none;}
.status-header{display:flex;align-items:baseline;gap:10px;margin-bottom:4px;}
.status-name{font-weight:700;font-size:13px;}
.status-effect{font-size:11px;color:var(--text-dim);}
.status-action{font-size:12px;color:var(--text-dim);line-height:1.7;}
.status-action strong{color:var(--text);font-weight:700;}
.recommend{margin-top:4px;padding-left:8px;border-left:1px solid var(--accent-dim);font-size:11px;color:var(--accent-dim);}
.tbl{width:100%;border-collapse:collapse;font-size:12px;}
.tbl th{padding:7px 10px;text-align:left;color:var(--accent);font-weight:700;font-size:10px;border-bottom:1px solid var(--border);letter-spacing:.06em;text-transform:uppercase;}
.tbl td{padding:7px 10px;border-bottom:1px solid rgba(24,36,54,.8);}
.tbl tr:last-child td{border-bottom:none;}
.tbl .col-s{font-weight:700;}
.tbl .col-k{color:var(--text-dim);}
.phase-row td{color:var(--accent-dim);font-weight:700;font-size:11px;letter-spacing:.04em;}
.ok{color:var(--green);font-size:11px;}
.fail{color:var(--red);font-size:11px;}
.cmt{color:var(--text-dim);font-size:11px;line-height:1.5;}
.sk-used{color:var(--text);font-weight:500;}
.stat-line{padding:5px 10px;font-size:11px;color:var(--accent-dim);border-top:1px solid var(--border);}
.finish-row td{color:var(--accent);}
.example-card{margin-bottom:20px;border-top:1px solid var(--border);padding-top:16px;}
.example-header{margin-bottom:10px;}
.example-title{font-weight:700;color:var(--text-bright);font-size:13px;margin-bottom:6px;}
.example-meta{display:flex;gap:5px;flex-wrap:wrap;}
.meta-pill{font-size:10px;padding:1px 8px;border:1px solid var(--border);border-radius:2px;color:var(--text-dim);}
.review-box{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim);line-height:1.7;}
.review-box strong{color:var(--text);}
.calc-card{padding:18px 0;max-width:440px;}
.calc-title{font-weight:900;font-size:14px;color:var(--text-bright);margin-bottom:2px;}
.calc-sub{font-size:12px;color:var(--text-dim);margin-bottom:14px;}
.f-row{margin-bottom:8px;}
.f-label{font-size:11px;font-weight:700;color:var(--text-dim);margin-bottom:3px;display:block;}
.f-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border);padding:7px 0;color:var(--text-bright);font-family:'Noto Sans KR',sans-serif;font-size:13px;outline:none;transition:border-color .2s;}
.f-input:focus{border-bottom-color:var(--accent);}
.calc-btn{margin-top:10px;padding:9px 24px;background:transparent;border:1px solid var(--accent-dim);border-radius:2px;color:var(--accent);font-family:'Noto Sans KR',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s,border-color .2s;letter-spacing:.04em;}
.calc-btn:hover{background:var(--accent-glow);border-color:var(--accent);}
.calc-result{margin-top:14px;display:none;border-top:1px solid var(--border);padding-top:12px;}
.calc-result.show{display:block;}
.r-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;border-bottom:1px solid rgba(24,36,54,.6);padding-bottom:6px;}
.r-row:last-of-type{border-bottom:none;}
.r-label{font-size:11px;color:var(--text-dim);}
.r-value{font-size:16px;font-weight:900;color:var(--accent);}
.r-sub{font-size:11px;color:var(--text-dim);margin-top:6px;}
.site-footer{margin-left:54px;padding:16px 32px;border-top:1px solid var(--border);font-size:11px;color:var(--text-dim);text-align:center;}
.gear-rows{display:grid;gap:8px;}
.gear-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px 0;border-bottom:1px solid var(--border);}
.gear-row:last-child{border-bottom:none;}
.gear-tier{font-size:11px;font-weight:700;padding:2px 8px;border-radius:2px;white-space:nowrap;flex-shrink:0;min-width:80px;text-align:center;}
.gear-tier.t-low{background:rgba(100,120,180,.12);border:1px solid rgba(100,120,180,.3);color:#7a9acc;}
.gear-tier.t-mid{background:rgba(62,207,170,.1);border:1px solid rgba(62,207,170,.25);color:var(--accent);}
.gear-tier.t-high{background:rgba(62,207,170,.15);border:1px solid rgba(62,207,170,.4);color:var(--accent);}
.gear-tier.t-full{background:rgba(62,207,170,.15);border:1px solid rgba(62,207,170,.4);color:var(--accent);}
.gear-tier.t-space{background:rgba(90,184,212,.1);border:1px solid rgba(90,184,212,.35);color:var(--sky);}
.gear-stats{display:flex;gap:8px;flex-wrap:wrap;flex:1;}
.gear-stat{font-size:12px;color:var(--text);}
.gear-stat strong{color:var(--text-bright);}
.gear-note{font-size:11px;color:var(--text-dim);white-space:nowrap;}
.gear-link{font-size:11px;text-decoration:none;border:1px solid var(--accent-dim);border-radius:2px;padding:2px 8px;white-space:nowrap;color:var(--accent);transition:border-color .15s;}
.gear-link:hover{border-color:var(--accent);}
.gear-link.sky{color:var(--sky);border-color:var(--sky-dim);}
.gear-link.sky:hover{border-color:var(--sky);}
.accordion{margin-bottom:8px;border-top:1px solid var(--border);}
.accordion:last-child{border-bottom:1px solid var(--border);}
.accordion-btn{
  width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:13px 0;background:none;border:none;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;text-align:left;
  gap:12px;
}
.accordion-btn:hover .ac-title{color:var(--accent);}
.ac-left{display:flex;flex-direction:column;gap:4px;}
.ac-label{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);}
.ac-title{font-size:13px;font-weight:700;color:var(--text-bright);transition:color .15s;}
.ac-meta{display:flex;gap:5px;flex-wrap:wrap;}
.ac-pill{font-size:10px;padding:1px 7px;border:1px solid var(--border);border-radius:2px;color:var(--text-dim);}
.ac-arrow{flex-shrink:0;color:var(--text-dim);transition:transform .2s;}
.accordion.open .ac-arrow{transform:rotate(180deg);}
.accordion-body{display:none;padding-bottom:16px;}
.accordion.open .accordion-body{display:block;}
.ac-empty{padding:20px 0;font-size:12px;color:var(--text-dim);font-style:italic;}

/* ── PHASE TABS (예시 구간 탭) ── */
.phase-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;margin-bottom:0;}
.phase-tabs::-webkit-scrollbar{display:none;}
.ptab{
  padding:8px 15px;font-size:12px;font-weight:500;
  background:none;border:none;border-bottom:2px solid transparent;
  font-family:'Noto Sans KR',sans-serif;
  color:var(--text-dim);cursor:pointer;white-space:nowrap;
  transition:color .15s,border-color .15s;margin-bottom:-1px;
}
.ptab:hover{color:var(--text);}
.ptab.pon{color:var(--accent);border-bottom-color:var(--accent);}
.phase-panel{display:none;padding-top:2px;}
.phase-panel.pon{display:block;}
.sub-phase-row td{
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent-dim);padding:10px 8px 4px;
  font-weight:700;border-bottom:none;
}

@media(max-width:640px){
  .sidebar{width:44px;}
  .main-wrap{margin-left:44px;padding:18px 14px 60px;}
  .worry-grid{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .opener-compare{grid-template-columns:1fr;}
  .nav-links{grid-template-columns:1fr;}
  .home-links{grid-template-columns:1fr;}
  .skill-card{grid-template-columns:1fr;}
  .tbl{font-size:11px;}
  .tbl th,.tbl td{padding:5px 7px;}
}

/* ===== 품질 계산기 ===== */

.qc-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 24px 16px;
  color: var(--text-main);
}

.qc-section-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--accent);
  border-left: 4px solid var(--accent);
  padding-left: 10px;
  margin: 28px 0 14px;
}

.qc-input-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}

.qc-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.qc-label {
  width: 130px;
  font-size: 0.9rem;
  color: var(--text-dim);
  flex-shrink: 0;
}

.qc-input {
  flex: 1;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 7px 12px;
  color: var(--text-main);
  font-size: 0.95rem;
}

.qc-input:focus {
  outline: none;
  border-color: var(--accent);
}

.qc-btn {
  display: block;
  width: 100%;
  padding: 12px;
  background: var(--accent);
  color: #fff;
  font-size: 1rem;
  font-weight: 700;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  margin-top: 8px;
  transition: opacity 0.2s;
}

.qc-btn:hover { opacity: 0.85; }

.qc-result-box {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  margin-top: 20px;
}

.qc-result-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.95rem;
}

.qc-result-row:last-child { border-bottom: none; }

.qc-result-label { color: var(--text-dim); }

.qc-result-value {
  font-weight: 700;
  color: var(--accent);
}

.qc-hq-ok {
  color: #4caf50;
  font-weight: 900;
  font-size: 1.1rem;
}

.qc-hq-fail {
  color: #e85a7a;
  font-weight: 900;
  font-size: 1.1rem;
}

@media (max-width: 480px) {
  .qc-label { width: 100px; font-size: 0.82rem; }
  .qc-input { font-size: 0.88rem; }
}

/* =============================================
   계산기 공통 레이아웃 (calculator.html 기반)
   ============================================= */

.calc-body {
  display: grid;
  grid-template-columns: 185px 1fr;
  gap: 16px;
  align-items: start;
}

/* 계산기 내부 탭 버튼 */
.calc-tab-btn {
  padding: 8px 14px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-dim);
  cursor: pointer;
  border: none;
  border-bottom: 2px solid transparent;
  background: none;
  font-family: 'Noto Sans KR', sans-serif;
  letter-spacing: .04em;
  transition: color .15s;
}
.calc-tab-btn.active { color: var(--accent); border-bottom-color: var(--accent); }
.calc-tab-btn:hover:not(.active) { color: var(--text); }
@media (max-width: 768px) {
  .calc-body { grid-template-columns: 1fr; }
}

.input-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.input-section-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.input-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

.mode-toggle {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.mode-btn {
  flex: 1;
  padding: 7px 10px;
  background: none;
  border: none;
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-dim);
  cursor: pointer;
  letter-spacing: .04em;
  transition: color .15s, background .15s;
}
.mode-btn + .mode-btn { border-left: 1px solid var(--border); }
.mode-btn.active { color: var(--accent); background: var(--accent-glow); }
.mode-btn:hover:not(.active) { color: var(--text); background: rgba(255,255,255,.03); }

.recipe-chain { display: flex; flex-direction: column; gap: 8px; }
.chain-arrow {
  font-size: 10px;
  color: var(--text-dim);
  text-align: center;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 4px;
}
.chain-arrow::before, .chain-arrow::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

.c-field { display: flex; flex-direction: column; gap: 4px; }
.c-field label { font-size: 10px; color: var(--text-dim); font-weight: 500; }
/* 가로 배치용 - 두 필드를 한 줄에 */
.c-field-row { display: flex; gap: 8px; }
.c-field-row .c-field { flex: 1; }
.c-field input[type="number"],
.c-field select {
  width: 100%;
  padding: 5px 8px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--text-bright);
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 11px;
  transition: border-color .15s;
  outline: none;
}
.c-field input[type="number"]:focus,
.c-field select:focus { border-color: var(--accent-dim); }
.c-field input[type="number"].filled { border-color: var(--accent-dim); background: rgba(62,207,170,.04); }
.c-field select option { background: #1a2535; }
.c-hint { font-size: 10px; color: var(--text-dim); }

.custom-box {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 3px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.c-divider { height: 1px; background: var(--border); margin: 4px 0; }

.c-result-panel { display: flex; flex-direction: column; gap: 14px; }

.c-empty-state {
  padding: 40px 20px;
  text-align: center;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--surface);
}
.c-empty-icon { font-size: 28px; margin-bottom: 10px; opacity: .4; }
.c-empty-state p { font-size: 12px; color: var(--text-dim); }

.recipe-info-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 14px 18px;
}
.recipe-info-header {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 10px;
}
.recipe-name { font-size: 15px; font-weight: 700; color: var(--text-bright); }
.recipe-badge {
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .08em;
  padding: 3px 7px;
  border-radius: 2px;
  border: 1px solid;
}
.badge-ex   { color: #e85a7a; border-color: rgba(232,90,122,.3); background: rgba(232,90,122,.08); }
.badge-explus { color: #c060e0; border-color: rgba(192,96,224,.3); background: rgba(192,96,224,.08); }
.badge-normal { color: #7aaccc; border-color: rgba(122,172,204,.3); background: rgba(122,172,204,.08); }

.recipe-stats {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 3px;
  overflow: hidden;
}
.recipe-stat { flex: 1; padding: 8px 10px; text-align: center; border-right: 1px solid var(--border); }
.recipe-stat:last-child { border-right: none; }
.stat-lbl { font-size: 9px; color: var(--text-dim); letter-spacing: .06em; text-transform: uppercase; }
.stat-val { font-size: 15px; font-weight: 700; color: var(--text-bright); margin-top: 1px; }
.stat-val.warn { color: var(--yellow); }
.stat-val.ok   { color: var(--green); }

.c-result-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 14px 18px;
}
.c-result-card-title {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.c-result-card-title::after { content: ''; flex: 1; height: 1px; background: var(--border); }

.rotation-table { width: 100%; border-collapse: collapse; }
.rotation-table th {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-dim);
  padding: 5px 8px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.rotation-table th.num { text-align: right; }
.rotation-table td {
  padding: 6px 8px;
  font-size: 12px;
  color: var(--text);
  border-bottom: 1px solid rgba(28,45,62,.5);
}
.rotation-table td.num { text-align: right; font-variant-numeric: tabular-nums; }
.rotation-table tr:last-child td { border-bottom: none; }
.rotation-table tr.highlight td { color: var(--text-bright); }
.rotation-table tr.highlight td:first-child { color: var(--accent); }
.rotation-table .ok   { color: var(--green); }
.rotation-table .warn { color: var(--yellow); }
.rotation-table .bad  { color: var(--red); }

.skill-chips { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.chip.work    { color: #5ab8d4; border: none; background: rgba(90,184,212,.12); }
.chip.buff    { color: #c8b840; border: none; background: rgba(200,184,64,.12); }
.chip.state   { color: #a06ccc; border: none; background: rgba(160,108,204,.15); }
.chip.sep     { color: var(--border); background: none; border: none; padding: 2px; font-size: 12px; }
.chip.quality { color: #3ecfaa; border: none; background: rgba(62,207,170,.12); }

.work-total-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  padding: 10px 12px;
  background: rgba(62,207,170,.06);
  border: 1px solid var(--accent-dim);
  border-radius: 3px;
}
.work-total-label { font-size: 11px; color: var(--text-dim); }
.work-total-val   { font-size: 18px; font-weight: 700; }
.work-total-val.ok   { color: var(--green); }
.work-total-val.warn { color: var(--yellow); }
.work-total-val.bad  { color: var(--red); }
.work-remain-info {
  display: flex;
  gap: 12px;
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-dim);
}
.work-remain-info b { color: var(--text); }

.action-box {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 3px;
  margin-top: 10px;
}
.action-icon  { font-size: 16px; flex-shrink: 0; }
.action-text  { font-size: 11px; color: var(--text-dim); line-height: 1.5; }
.action-text b { color: var(--text-bright); }
.action-box.ok   { border-color: rgba(77,200,144,.3);  background: rgba(77,200,144,.04); }
.action-box.ok   .action-icon { color: var(--green); }
.action-box.warn { border-color: rgba(200,184,64,.3);  background: rgba(200,184,64,.04); }
.action-box.warn .action-icon { color: var(--yellow); }
.action-box.bad  { border-color: rgba(224,80,96,.3);   background: rgba(224,80,96,.04); }
.action-box.bad  .action-icon { color: var(--red); }

.variant-selector { display: flex; flex-direction: column; gap: 4px; margin-bottom: 14px; }
.variant-btn {
  padding: 8px 12px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 3px;
  text-align: left;
  cursor: pointer;
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 11px;
  color: var(--text-dim);
  transition: border-color .15s, color .15s;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.variant-btn.active { border-color: var(--accent-dim); color: var(--text-bright); background: rgba(62,207,170,.06); }
.variant-btn:hover:not(.active) { border-color: var(--border); color: var(--text); }
.variant-meta { font-size: 10px; color: var(--text-dim); display: flex; gap: 10px; }
.variant-meta span b { color: var(--text); }

/* ── 요약 탭 스킬 아이콘 인라인 표시 ── */
.si {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  vertical-align: middle;
}
.si img {
  width: 20px;
  height: 20px;
  border-radius: 3px;
  flex-shrink: 0;
  object-fit: cover;
  vertical-align: middle;
}
.si span {
  font-size: 11px;
  color: var(--text);
}

/* 프리셋 버튼 그룹 */
.preset-btn-group {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.preset-btn {
  padding: 4px 9px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 3px;
  font-family: 'Noto Sans KR', sans-serif;
  font-size: 11px;
  color: var(--text-dim);
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
  white-space: nowrap;
}
.preset-btn:hover:not(.active) {
  color: var(--text);
  border-color: var(--accent-dim);
}
.preset-btn.active {
  color: var(--accent);
  border-color: var(--accent-dim);
  background: rgba(62,207,170,.08);
  font-weight: 600;
}

/* ── 품질계산기 레시피 선택 바 ── */
.qual-recipe-bar {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
}
.qual-recipe-bar .c-field {
  flex: 1;
  min-width: 140px;
  max-width: 260px;
}
.qual-recipe-arrow {
  font-size: 11px;
  color: var(--text-dim);
  padding-bottom: 10px;
  flex-shrink: 0;
}

/* ── 품질 진행 바 ── */
.quality-progress {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 12px;
}
.qp-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
}
.qp-label {
  width: 52px;
  color: var(--text-dim);
  flex-shrink: 0;
  text-align: right;
  font-size: 10px;
  letter-spacing: .04em;
}
.qp-bar-wrap {
  flex: 1;
  height: 6px;
  background: var(--surface2);
  border-radius: 2px;
  overflow: hidden;
  border: 1px solid var(--border);
}
.qp-bar {
  height: 100%;
  border-radius: 2px;
  transition: width .4s cubic-bezier(.4,0,.2,1);
}
.qp-bar.current  { background: var(--sky); }
.qp-bar.needed   { background: var(--yellow); }
.qp-bar.max      { background: var(--accent); }
.qp-num {
  width: 56px;
  text-align: right;
  color: var(--text-bright);
  font-weight: 700;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.qp-footer {
  display: flex;
  gap: 16px;
  font-size: 11px;
  color: var(--text-dim);
  padding: 8px 0 0;
  border-top: 1px solid var(--border);
  margin-top: 4px;
}
.qp-footer b { color: var(--text-bright); }
.qp-footer .highlight { color: var(--yellow); }

/* ── 로테이션 카드  ── */
.rota-cards { display: flex; flex-direction: column; gap: 8px; }
.rota-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 12px 14px;
  transition: border-color .15s;
}
.rota-card.recommended {
  border-color: var(--accent-dim);
  background: rgba(62,207,170,.04);
}
.rota-card.possible   { opacity: .88; }
.rota-card.impossible { opacity: .4;  }
.rota-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.rota-badge {
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .08em;
  padding: 3px 7px;
  border-radius: 2px;
  flex-shrink: 0;
}
.badge-recommend {
  color: var(--accent);
  background: var(--accent-glow);
  border: 1px solid var(--accent-dim);
}
.badge-possible {
  color: var(--sky);
  background: rgba(90,184,212,.10);
  border: 1px solid rgba(90,184,212,.3);
}
.badge-impossible {
  color: var(--text-dim);
  background: none;
  border: 1px solid var(--border);
}
.rota-quality-val {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-bright);
  font-variant-numeric: tabular-nums;
}
.rota-quality-val.ok   { color: var(--green); }
.rota-quality-val.warn { color: var(--yellow); }
.rota-pct {
  font-size: 11px;
  color: var(--text-dim);
  margin-left: auto;
}
.rota-pct b { color: var(--text); }
.rota-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 6px;
}
.rota-meta {
  display: flex;
  gap: 10px;
  font-size: 10px;
  color: var(--text-dim);
  padding-top: 6px;
  border-top: 1px solid rgba(28,45,62,.5);
}
.rota-meta b  { color: var(--text); }
.rota-meta .bad { color: var(--red); }

/* ── 품질 로테이션 테이블 아이콘 ── */
.rota-skill-icon {
  width: 24px;
  height: 24px;
  border-radius: 3px;
  object-fit: cover;
  vertical-align: middle;
}
.rota-icons {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-wrap: wrap;
}

/* ── 로테이션 카드 ── */
.rota-section-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text-dim);
  padding: 8px 0 4px;
}
.rota-card {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 8px 12px;
  margin-bottom: 5px;
  position: relative;
  overflow: hidden;
  min-width: 0;   /* 추가 */
}
.rota-card-best {
  border-color: var(--green);
  border-width: 1.5px;
}
.rota-card-disabled {
  opacity: .35;
  pointer-events: none;
}
.rota-card-disabled::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  border-radius: 4px;
}
.rota-card-icons {
  display: flex;
  align-items: center;
  gap: 3px;
  flex-wrap: wrap;      /* nowrap → wrap */
  flex-shrink: 1;       /* 0 → 1 */
  min-width: 0;         /* 추가 */
  overflow: hidden;     /* visible → hidden */
}
.rota-card-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  margin-left: auto;
  flex-shrink: 0;
}

.rota-card-meta {
  display: flex;
  gap: 10px;
  font-size: 11px;
  color: var(--text-dim);
}
.rota-card-meta b { color: var(--text-bright); }
.rota-card-tags { display: flex; gap: 4px; }
.rota-badge {
  font-size: 9px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 3px;
  letter-spacing: .04em;
}
.tag-expert { background: rgba(99,179,237,.12); color: #63b3ed; border: 1px solid rgba(99,179,237,.3); }
.tag-lowdur { background: rgba(236,201,75,.12); color: var(--yellow); border: 1px solid rgba(236,201,75,.3); }
.rota-card-quality {
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
}
.rota-card-qdiff {
  font-size: 10px;
  color: var(--text-dim);
  font-weight: 400;
  margin-left: 3px;
}
.rota-card-meta {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--text-dim);
}
.rota-meta-sep {
  color: var(--border);
}
.rota-divider {
  font-size: 10px;
  color: var(--text-dim);
  margin: 8px 0 5px;
}
.rota-divider hr {
  flex: 1;
  border: none;
  border-top: 1px solid var(--border);
}

/* ── 통합 계산기 탭 버튼 ── */
.calc-tab-btn {
  padding: 8px 14px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  cursor: pointer;
  border: none;
  border-bottom: 2px solid transparent;
  background: none;
  font-family: inherit;
  transition: color .15s;
}
.calc-tab-btn.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.calc-tab-panel { display: none; }
.calc-tab-panel.active { display: block; }

/* ── 레시피 pill (통합 계산기용) ── */
.recipe-pill-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px;
  margin-bottom: 6px;
}
.recipe-pill-row:last-child { margin-bottom: 0; }
.recipe-chain-arrow {
  font-size: 10px;
  color: var(--text-dim);
}
.rpill {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 4px 9px;
  border-radius: 3px;
  cursor: pointer;
  border: 1px solid var(--border);
  font-size: 10px;
  font-family: inherit;
  background: var(--surface2);
  transition: border-color .15s;
  text-align: left;
}
.rpill:hover { border-color: var(--accent-dim); }
.rpill.active { background: var(--accent-glow); border-color: var(--accent); }
.rpill.active .rpill-tag { color: var(--accent); }
.rpill-tag { font-weight: 600; color: var(--text); font-size: 10px; }
.rpill-meta { font-size: 9px; color: var(--text-dim); }

/* 그룹 색상 */
.rpill.gc0 { border-color: rgba(90,184,212,.3); }
.rpill.gc0 .rpill-tag { color: #5ab8d4; }
.rpill.gc1 { border-color: rgba(200,184,64,.3); }
.rpill.gc1 .rpill-tag { color: #c8b840; }
.rpill.gc2 { border-color: rgba(160,108,204,.3); }
.rpill.gc2 .rpill-tag { color: #a06ccc; }
.rpill.gc3 { border-color: rgba(77,200,144,.3); }
.rpill.gc3 .rpill-tag { color: #4dc890; }
.rpill.gc4 { border-color: rgba(232,90,122,.3); }
.rpill.gc4 .rpill-tag { color: #e85a7a; }
.rpill.gc5 { border-color: rgba(250,160,80,.3); }
.rpill.gc5 .rpill-tag { color: #f0a050; }
.rpill.active.gc0, .rpill.active.gc1, .rpill.active.gc2,
.rpill.active.gc3, .rpill.active.gc4, .rpill.active.gc5 {
  background: var(--accent-glow);
  border-color: var(--accent);
}
.rpill.active .rpill-tag { color: var(--accent) !important; }

/* 카테고리 섹션 헤더 */
.pill-cat-header {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-dim);
  padding: 4px 0;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}
.pill-cat-header:first-child { margin-top: 0; }
.pill-cat-header::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}
.pill-cat-sub {
  font-size: 8px;
  opacity: .6;
  margin-left: 2px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
