/* ============================================================
   RECELLA main.css  —  1200px 기준 + 완전 모바일 반응형
   ============================================================ */
:root {
  --gold:#F5A623; --gold2:#FFD580;
  --dark:#08080F; --dark2:#0F0F1E;
  --card:#13132A; --card2:#1A1A35;
  --blue:#60A5FA; --green:#10B981;
  --red:#EF4444;  --purple:#8B5CF6; --orange:#F97316;
  --text:#E8E8F4; --muted:#8080A8;
  --border:rgba(255,255,255,.07);
  --r:14px; --max:1200px; --hh:62px;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--dark); color:var(--text);
  font-family:'Noto Sans KR',sans-serif;
  font-size:14px; min-height:100vh; overflow-x:hidden;
}
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--dark2); }
::-webkit-scrollbar-thumb { background:var(--card2); border-radius:3px; }
a { color:inherit; text-decoration:none; }

/* ── HEADER ──────────────────────────────────────────────── */
.header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(8,8,15,.96); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  height:var(--hh); display:flex; align-items:center;
}
.header-inner {
  display:flex; align-items:center; gap:14px;
  width:100%; max-width:var(--max); margin:0 auto; padding:0 28px;
}
.logo {
  font-family:'Montserrat',sans-serif; font-size:22px;
  font-weight:900; color:#fff; letter-spacing:3px;
  cursor:pointer; flex-shrink:0; user-select:none;
}
.logo span { color:var(--gold); }
.header-nav { display:flex; gap:2px; flex:1; }
.hn-btn {
  background:none; border:none; color:var(--muted);
  font-size:13px; font-weight:500; padding:7px 13px;
  border-radius:20px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .2s;
  white-space:nowrap;
}
.hn-btn:hover, .hn-btn.active { background:rgba(255,255,255,.08); color:#fff; }
.header-right { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.cart-btn {
  position:relative; background:none; border:none;
  color:var(--muted); cursor:pointer; font-size:22px;
  padding:4px; transition:color .2s; line-height:1;
}
.cart-btn:hover { color:var(--gold); }
.cart-badge {
  position:absolute; top:-3px; right:-3px;
  background:var(--red); color:#fff; font-size:9px; font-weight:700;
  min-width:17px; height:17px; border-radius:9px; padding:0 3px;
  display:none; align-items:center; justify-content:center;
}
.grade-chip {
  font-size:11px; font-weight:700; padding:4px 10px;
  border-radius:20px; background:rgba(245,166,35,.12); color:var(--gold);
  white-space:nowrap;
}
.uname { font-size:13px; font-weight:600; white-space:nowrap; }
.login-btn {
  background:rgba(245,166,35,.12); border:1px solid rgba(245,166,35,.3);
  color:var(--gold); font-size:12px; font-weight:700;
  padding:8px 18px; border-radius:20px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .2s; white-space:nowrap;
}
.login-btn:hover { background:rgba(245,166,35,.24); }
.logout-btn {
  background:none; border:1px solid var(--border);
  color:var(--muted); font-size:11px; padding:6px 12px;
  border-radius:10px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .2s;
}
.logout-btn:hover { border-color:var(--red); color:var(--red); }

/* ── LAYOUT ──────────────────────────────────────────────── */
.container {
  max-width:var(--max); margin:0 auto;
  padding:0 28px; padding-top:var(--hh);
}
.section { padding:56px 0; }
.section + .section { padding-top:0; }
.sec-hd {
  display:flex; align-items:center;
  justify-content:space-between; margin-bottom:28px;
}
.sec-hd h2 { font-size:21px; font-weight:700; }
.sec-sub { font-size:12px; color:var(--muted); }
.sec-link { font-size:13px; color:var(--gold); cursor:pointer; font-weight:600; }
.sec-link:hover { text-decoration:underline; }

/* ── HERO ────────────────────────────────────────────────── */
.hero {
  background:linear-gradient(135deg,#08080F 0%,#0D0D28 45%,#080818 100%);
  padding:110px 28px 80px; text-align:center;
  position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 70% 55% at 50% 0%,rgba(245,166,35,.09) 0%,transparent 70%);
}
.hero::after {
  content:''; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(ellipse 50% 40% at 85% 85%,rgba(96,165,250,.06) 0%,transparent 60%);
}
.hero-inner { position:relative; z-index:1; max-width:680px; margin:0 auto; }
.hero-tag {
  display:inline-block;
  background:rgba(245,166,35,.1); border:1px solid rgba(245,166,35,.3);
  color:var(--gold); font-size:10px; font-weight:700; letter-spacing:3px;
  padding:5px 18px; border-radius:20px; margin-bottom:22px;
}
.hero h1 {
  font-family:'Montserrat',sans-serif;
  font-size:clamp(36px,6vw,66px); font-weight:900;
  color:#fff; line-height:1.08; margin-bottom:18px; position:relative;
}
.hero h1 span { color:var(--gold); }
.hero p {
  color:var(--muted); font-size:15px;
  max-width:500px; margin:0 auto 36px; line-height:1.7; position:relative;
}
.hero-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; }
.btn-primary {
  background:linear-gradient(135deg,var(--gold),#E8950F);
  color:#000; font-size:14px; font-weight:700;
  padding:14px 32px; border-radius:28px; border:none; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .25s;
  box-shadow:0 4px 22px rgba(245,166,35,.35);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(245,166,35,.45); }
.btn-secondary {
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
  color:var(--text); font-size:14px; font-weight:600;
  padding:14px 32px; border-radius:28px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .25s;
}
.btn-secondary:hover { background:rgba(255,255,255,.12); }

/* ── PRODUCT GRID ────────────────────────────────────────── */
.cat-btns { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:22px; }
.cat-btn {
  background:var(--card); border:1px solid var(--border);
  color:var(--muted); font-size:12px; font-weight:600;
  padding:6px 16px; border-radius:20px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .2s;
}
.cat-btn:hover, .cat-btn.active {
  border-color:var(--gold); color:var(--gold);
  background:rgba(245,166,35,.08);
}
.prod-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:18px;
}
.prod-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r); overflow:hidden; cursor:pointer;
  transition:transform .22s,box-shadow .22s,border-color .22s;
}
.prod-card:hover {
  transform:translateY(-5px);
  box-shadow:0 14px 44px rgba(0,0,0,.55);
  border-color:rgba(245,166,35,.22);
}
.pc-img {
  height:178px; display:flex; align-items:center; justify-content:center;
  font-size:58px; position:relative;
  background:linear-gradient(135deg,rgba(245,166,35,.05),rgba(96,165,250,.05));
}
.pc-badge {
  position:absolute; top:10px; left:10px;
  font-size:9px; font-weight:700; padding:3px 9px; border-radius:20px;
}
.badge-best { background:rgba(245,166,35,.2); color:var(--gold); }
.badge-new  { background:rgba(16,185,129,.2); color:var(--green); }
.badge-hot  { background:rgba(239,68,68,.2);  color:var(--red); }
.pc-body { padding:18px; }
.pc-cat  { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.pc-name { font-size:15px; font-weight:700; color:#fff; margin-bottom:5px; }
.pc-desc { font-size:12px; color:var(--muted); margin-bottom:14px; line-height:1.55; }
.pc-foot { display:flex; align-items:flex-end; justify-content:space-between; }
.pc-price { font-size:18px; font-weight:900; color:#fff; }
.pc-pv    { font-size:10px; color:var(--muted); margin-top:2px; }
.pc-add {
  background:rgba(245,166,35,.12); border:1px solid rgba(245,166,35,.28);
  color:var(--gold); font-size:11px; font-weight:700;
  padding:7px 14px; border-radius:10px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .2s;
}
.pc-add:hover { background:rgba(245,166,35,.26); }

/* ── PLAN GRID ───────────────────────────────────────────── */
.plan-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:16px;
}
.plan-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--r); padding:24px; position:relative;
  overflow:hidden; cursor:pointer; transition:all .25s;
}
.plan-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px; border-radius:var(--r) var(--r) 0 0;
}
.mc1::before{background:#60A5FA;} .mc2::before{background:var(--gold);}
.mc3::before{background:var(--green);} .mc4::before{background:var(--red);}
.mc1:hover{box-shadow:0 8px 32px rgba(96,165,250,.15);border-color:rgba(96,165,250,.22);}
.mc2:hover{box-shadow:0 8px 32px rgba(245,166,35,.15);border-color:rgba(245,166,35,.22);}
.mc3:hover{box-shadow:0 8px 32px rgba(16,185,129,.15);border-color:rgba(16,185,129,.22);}
.mc4:hover{box-shadow:0 8px 32px rgba(239,68,68,.15);border-color:rgba(239,68,68,.22);}
.mc-grade { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; margin-bottom:10px; }
.mc1 .mc-grade{color:#60A5FA;} .mc2 .mc-grade{color:var(--gold);}
.mc3 .mc-grade{color:var(--green);} .mc4 .mc-grade{color:var(--red);}
.mc-price { font-size:26px; font-weight:900; color:#fff; line-height:1; margin-bottom:4px; }
.mc-pv    { font-size:12px; color:var(--muted); margin-bottom:16px; }
.mc-value { background:rgba(255,255,255,.04); border-radius:8px; padding:8px 12px; margin-bottom:14px; }
.mc-value .mv-l { font-size:10px; color:var(--muted); }
.mc-value .mv-v { font-size:13px; font-weight:700; color:var(--gold2); }
.mc-prods { list-style:none; }
.mc-prods li { font-size:11px; color:var(--muted); padding:3px 0 3px 14px; position:relative; }
.mc-prods li::before { content:'›'; position:absolute; left:0; color:var(--gold); font-weight:700; }
.mc-btn {
  width:100%; margin-top:16px;
  background:rgba(245,166,35,.1); border:1px solid rgba(245,166,35,.28);
  color:var(--gold); font-size:12px; font-weight:700;
  padding:10px; border-radius:10px; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:all .2s;
}
.mc-btn:hover { background:rgba(245,166,35,.22); }

/* ── CART PANEL ──────────────────────────────────────────── */
.cart-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.72); z-index:2000; backdrop-filter:blur(5px);
}
.cart-overlay.open { display:flex; justify-content:flex-end; }
.cart-panel {
  background:var(--dark2); width:400px; max-width:100vw;
  height:100vh; border-left:1px solid var(--border);
  display:flex; flex-direction:column;
  animation:slideIn .25s ease;
}
@keyframes slideIn { from{transform:translateX(100%)} to{transform:translateX(0)} }
.cart-hdr {
  padding:20px 22px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; flex-shrink:0;
}
.cart-hdr h3 { font-size:17px; font-weight:700; }
.x-btn {
  background:none; border:none; color:var(--muted);
  font-size:22px; cursor:pointer; line-height:1;
  width:34px; height:34px; border-radius:8px;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.x-btn:hover { background:rgba(255,255,255,.08); color:#fff; }
.cart-body {
  flex:1; padding:16px;
  display:flex; flex-direction:column; gap:12px; overflow-y:auto;
}
.cart-empty { text-align:center; color:var(--muted); padding:60px 0; font-size:14px; line-height:2.2; }
.cart-item {
  background:var(--card); border:1px solid var(--border);
  border-radius:12px; padding:14px; display:flex; gap:12px; align-items:flex-start;
}
.ci-ico { font-size:30px; flex-shrink:0; line-height:1.2; }
.ci-info { flex:1; min-width:0; }
.ci-name { font-size:13px; font-weight:700; margin-bottom:3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ci-price { font-size:12px; color:var(--gold); font-weight:600; }
.ci-qty { display:flex; align-items:center; gap:8px; margin-top:8px; }
.qty-btn {
  background:rgba(255,255,255,.08); border:none; color:#fff;
  width:24px; height:24px; border-radius:7px; cursor:pointer;
  font-size:15px; display:flex; align-items:center; justify-content:center; transition:background .2s;
}
.qty-btn:hover { background:rgba(255,255,255,.16); }
.qty-n { font-size:13px; font-weight:700; min-width:22px; text-align:center; }
.ci-del { background:none; border:none; color:var(--muted); cursor:pointer; font-size:18px; flex-shrink:0; transition:color .2s; }
.ci-del:hover { color:var(--red); }
.cart-foot { padding:16px 22px; border-top:1px solid var(--border); flex-shrink:0; }
.cart-total-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.cart-total-row span { font-size:14px; color:var(--muted); }
.ct-amt { font-size:22px; font-weight:900; color:var(--gold) !important; }
.btn-checkout {
  width:100%; background:linear-gradient(135deg,var(--gold),#E8950F);
  color:#000; font-size:14px; font-weight:700; padding:15px;
  border-radius:14px; border:none; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; transition:opacity .2s;
}
.btn-checkout:hover { opacity:.9; }

/* ── MODAL ───────────────────────────────────────────────── */
.modal-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.82); z-index:3000;
  backdrop-filter:blur(8px);
  align-items:center; justify-content:center; padding:20px;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--dark2); border:1px solid var(--border);
  border-radius:20px; width:100%; max-width:460px;
  max-height:90vh; overflow-y:auto;
  animation:fadeUp .22s ease;
}
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.modal-hdr {
  padding:24px 24px 0;
  display:flex; align-items:center; justify-content:space-between;
}
.modal-hdr h3 { font-size:18px; font-weight:700; }
.modal-body { padding:22px 24px 26px; }
.fg { margin-bottom:16px; }
.fg label { display:block; font-size:12px; font-weight:600; color:var(--muted); margin-bottom:7px; }
.fi {
  width:100%; background:var(--card);
  border:1px solid var(--border); color:var(--text);
  font-size:13px; padding:12px 14px; border-radius:11px;
  font-family:'Noto Sans KR',sans-serif; outline:none; transition:border-color .2s;
}
.fi:focus { border-color:rgba(245,166,35,.45); }
.fi:disabled { opacity:.45; cursor:not-allowed; }
select.fi { cursor:pointer; }
.agree-row { display:flex; align-items:flex-start; gap:10px; }
.agree-row input { margin-top:3px; flex-shrink:0; width:16px; height:16px; cursor:pointer; }
.agree-row label { font-size:12px; color:var(--muted); cursor:pointer; line-height:1.5; }
.btn-submit {
  width:100%;
  background:linear-gradient(135deg,var(--gold),#E8950F);
  color:#000; font-size:14px; font-weight:700;
  padding:14px; border-radius:13px; border:none; cursor:pointer;
  font-family:'Noto Sans KR',sans-serif; margin-top:10px; transition:opacity .2s;
}
.btn-submit:hover { opacity:.88; }
.form-switch { text-align:center; margin-top:16px; font-size:13px; color:var(--muted); }
.form-switch a { color:var(--gold); cursor:pointer; font-weight:600; }
.form-switch a:hover { text-decoration:underline; }

/* CHECKOUT STEPS */
.co-steps { display:flex; margin-bottom:24px; }
.co-step {
  flex:1; text-align:center; font-size:11px; color:var(--muted);
  padding:9px 4px; border-bottom:2px solid var(--border); transition:all .2s; font-weight:500;
}
.co-step.active { color:var(--gold); border-bottom-color:var(--gold); font-weight:700; }
.co-step.done   { color:var(--green); border-bottom-color:var(--green); }
.o-summary { background:var(--card); border-radius:11px; padding:16px; margin-bottom:18px; }
.os-row { display:flex; justify-content:space-between; font-size:13px; padding:5px 0; }
.os-row.total { font-weight:700; font-size:15px; border-top:1px solid var(--border); margin-top:8px; padding-top:12px; }
.pay-methods { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:18px; }
.pm-btn {
  background:var(--card); border:1px solid var(--border);
  border-radius:12px; padding:14px 10px; text-align:center;
  cursor:pointer; transition:all .2s; font-size:12px; color:var(--muted); font-weight:600;
}
.pm-btn:hover, .pm-btn.selected { border-color:var(--gold); color:var(--gold); background:rgba(245,166,35,.07); }
.pm-ico { font-size:22px; margin-bottom:5px; }

/* ── MY OFFICE ───────────────────────────────────────────── */
.mo-layout {
  display:grid; grid-template-columns:230px 1fr;
  min-height:calc(100vh - var(--hh)); margin-top:var(--hh);
}
.mo-side {
  background:var(--dark2); border-right:1px solid var(--border);
  padding:24px 0; position:sticky; top:var(--hh);
  height:calc(100vh - var(--hh)); overflow-y:auto;
}
.mo-user-box { padding:0 20px 22px; border-bottom:1px solid var(--border); margin-bottom:14px; }
.mo-avatar {
  width:50px; height:50px; border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#E8950F);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; font-weight:700; color:#000; margin-bottom:12px;
}
.mo-uname { font-size:15px; font-weight:700; }
.mo-ugrade { display:inline-block; font-size:10px; font-weight:700; padding:3px 10px; border-radius:20px; margin-top:5px; background:rgba(245,166,35,.12); color:var(--gold); }
.mo-code { font-size:11px; color:var(--muted); margin-top:6px; }
.mo-nav { padding:0 12px; }
.mo-ni {
  display:flex; align-items:center; gap:11px; padding:11px 12px;
  border-radius:11px; cursor:pointer; font-size:13px; color:var(--muted);
  transition:all .2s; margin-bottom:2px;
}
.mo-ni:hover { background:rgba(255,255,255,.05); color:#fff; }
.mo-ni.active { background:rgba(245,166,35,.1); color:var(--gold); font-weight:600; }
.mo-ni span { font-size:17px; width:22px; text-align:center; }
.mo-main { padding:34px 32px; flex:1; }
.mo-panel { display:none; }
.mo-panel.active { display:block; }
.mo-title { font-size:22px; font-weight:700; margin-bottom:26px; }

/* STAT CARDS */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:14px; margin-bottom:26px; }
.stat-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:20px; }
.stat-lbl { font-size:11px; color:var(--muted); margin-bottom:9px; font-weight:600; letter-spacing:.5px; }
.stat-val { font-size:25px; font-weight:900; color:#fff; line-height:1; }
.stat-sub { font-size:11px; color:var(--muted); margin-top:5px; }
.sc-gold{border-color:rgba(245,166,35,.2);}   .sc-gold .stat-val{color:var(--gold);}
.sc-blue{border-color:rgba(96,165,250,.2);}    .sc-blue .stat-val{color:var(--blue);}
.sc-green{border-color:rgba(16,185,129,.2);}   .sc-green .stat-val{color:var(--green);}
.sc-purple{border-color:rgba(139,92,246,.2);}  .sc-purple .stat-val{color:var(--purple);}

/* TABLE */
.tbl-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; margin-bottom:18px; }
.tbl-hdr { padding:14px 18px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--border); }
.tbl-hdr h4 { font-size:14px; font-weight:700; }
.tbl-sub { font-size:11px; color:var(--muted); background:rgba(255,255,255,.04); padding:4px 10px; border-radius:8px; }
.dtbl { width:100%; border-collapse:collapse; }
.dtbl th { background:rgba(255,255,255,.03); padding:11px 16px; font-size:11px; font-weight:600; color:var(--muted); text-align:left; letter-spacing:.5px; white-space:nowrap; }
.dtbl td { padding:12px 16px; font-size:13px; border-top:1px solid var(--border); vertical-align:middle; }
.dtbl tr:hover td { background:rgba(255,255,255,.02); }
.tag { display:inline-block; font-size:10px; font-weight:700; padding:2px 9px; border-radius:6px; }
.tg{background:rgba(245,166,35,.15);color:var(--gold);}   .tgn{background:rgba(16,185,129,.15);color:var(--green);}
.tgb{background:rgba(96,165,250,.15);color:var(--blue);} .tgp{background:rgba(139,92,246,.15);color:var(--purple);}
.tgr{background:rgba(239,68,68,.15);color:var(--red);}

/* PV BARS */
.pv-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:22px; margin-bottom:18px; }
.pv-card-hdr { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; font-size:14px; font-weight:700; }
.pv-row { display:flex; align-items:center; gap:14px; margin-bottom:14px; }
.pv-lbl { font-size:12px; color:var(--muted); width:80px; flex-shrink:0; }
.pv-bar-wrap { flex:1; background:rgba(255,255,255,.05); border-radius:20px; height:9px; overflow:hidden; }
.pv-bar { height:100%; border-radius:20px; transition:width .9s ease; width:0; }
.pv-left  { background:linear-gradient(90deg,#60A5FA,#3B82F6); }
.pv-right { background:linear-gradient(90deg,var(--gold),#E8950F); }
.pv-val { font-size:13px; font-weight:700; width:95px; text-align:right; flex-shrink:0; }

/* RS MONTHS */
.rs-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:22px; }
.rs-hdr { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.rs-hdr h4 { font-size:14px; font-weight:700; }
.rs-badge { font-size:11px; font-weight:700; padding:4px 12px; border-radius:20px; }
.rs-ok  { background:rgba(16,185,129,.15); color:var(--green); }
.rs-fail{ background:rgba(239,68,68,.15);  color:var(--red); }
.rs-months { display:grid; grid-template-columns:repeat(6,1fr); gap:8px; }
.rs-month { text-align:center; padding:10px 4px; border-radius:9px; font-size:10px; }
.rs-month .rm-m { color:var(--muted); margin-bottom:4px; }
.rs-month .rm-i { font-size:20px; }
.rs-month.done   { background:rgba(16,185,129,.08); }
.rs-month.fail   { background:rgba(239,68,68,.08); }
.rs-month.pending{ background:rgba(255,255,255,.03); }

/* TREE */
.tree-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:26px; overflow-x:auto; }
.tree-node { display:inline-flex; flex-direction:column; align-items:center; }
.tree-box { background:var(--card2); border:1px solid var(--border); border-radius:10px; padding:10px 14px; text-align:center; min-width:90px; transition:all .2s; cursor:pointer; }
.tree-box:hover { border-color:rgba(245,166,35,.35); }
.tree-box.root  { background:rgba(245,166,35,.1); border-color:rgba(245,166,35,.42); }
.tree-box.act   { border-color:rgba(16,185,129,.42); background:rgba(16,185,129,.07); }
.tree-box.empty { border-style:dashed; opacity:.4; cursor:default; }
.tnb-g { font-size:9px; font-weight:700; letter-spacing:1px; color:var(--muted); margin-bottom:3px; }
.tnb-n { font-size:12px; font-weight:700; color:#fff; }
.tnb-p { font-size:10px; color:var(--muted); margin-top:2px; }
.tree-level { display:flex; justify-content:center; gap:24px; }
.tree-connector { display:flex; justify-content:center; }
.vline { width:2px; height:20px; background:var(--border); }
.hline-wrap { display:flex; justify-content:center; align-items:flex-start; }
.hline { height:2px; background:var(--border); }

/* ORDER / FORM CARDS */
.order-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:18px 20px; margin-bottom:14px; }
.oc-hdr { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.oc-date { font-size:12px; color:var(--muted); }
.oc-body { display:flex; align-items:center; gap:14px; }
.oc-ico  { font-size:30px; }
.oc-name { font-size:14px; font-weight:700; }
.oc-price{ font-size:13px; color:var(--gold); margin-top:3px; }
.form-card { background:var(--card); border:1px solid var(--border); border-radius:var(--r); padding:24px; max-width:480px; }
.bal-box { background:rgba(245,166,35,.06); border:1px solid rgba(245,166,35,.16); border-radius:12px; padding:16px 18px; margin-bottom:20px; }
.bal-lbl { font-size:11px; color:var(--muted); margin-bottom:5px; }
.bal-amt { font-size:28px; font-weight:900; color:var(--gold); }
.bal-sub { font-size:11px; color:var(--muted); margin-top:4px; }
.fee-box { background:rgba(255,255,255,.03); border-radius:9px; padding:13px 16px; margin:14px 0; font-size:12px; color:var(--muted); line-height:1.9; }
.fee-box strong { color:var(--text); }
.info-chip { border-radius:11px; padding:13px 16px; font-size:12px; color:var(--muted); line-height:1.9; margin-bottom:16px; }
.info-chip strong { color:var(--text); }
.info-chip.blue  { background:rgba(96,165,250,.06);  border:1px solid rgba(96,165,250,.16); }
.info-chip.orange{ background:rgba(249,115,22,.06);  border:1px solid rgba(249,115,22,.16); }
.info-chip.red   { background:rgba(239,68,68,.06);   border:1px solid rgba(239,68,68,.22); }

/* TOAST */
.toast {
  position:fixed; bottom:28px; right:28px;
  background:var(--card2); border:1px solid var(--border);
  border-radius:13px; padding:14px 20px; font-size:13px;
  z-index:9999; transform:translateY(110px); opacity:0;
  transition:all .3s cubic-bezier(.34,1.56,.64,1);
  max-width:320px; pointer-events:none;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}
.toast.show { transform:translateY(0); opacity:1; }
.toast.success { border-color:rgba(16,185,129,.35); }
.toast.success::before { content:'✓  '; color:var(--green); font-weight:700; }
.toast.error { border-color:rgba(239,68,68,.35); }
.toast.error::before { content:'✕  '; color:var(--red); font-weight:700; }
.toast.info { border-color:rgba(96,165,250,.35); }
.toast.info::before { content:'ℹ  '; color:var(--blue); font-weight:700; }

/* ── RESPONSIVE: 태블릿 ≤ 900px ──────────────────────────── */
@media(max-width:900px) {
  :root { --hh:58px; }
  .header-inner { padding:0 18px; }
  .container { padding:0 18px; padding-top:var(--hh); }
  .hero { padding:90px 20px 64px; }
  .prod-grid { grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:14px; }
  .plan-grid { grid-template-columns:1fr 1fr; }
  .mo-layout { grid-template-columns:200px 1fr; }
  .mo-main { padding:24px 20px; }
  .stat-grid { grid-template-columns:repeat(2,1fr); }
}

/* ── RESPONSIVE: 모바일 ≤ 680px ──────────────────────────── */
@media(max-width:680px) {
  :root { --hh:54px; }
  .header-inner { padding:0 14px; gap:8px; }
  .logo { font-size:18px; letter-spacing:2px; }
  .hn-btn { font-size:11px; padding:6px 9px; }
  .uname, .grade-chip { display:none; }
  .login-btn { font-size:11px; padding:6px 12px; }

  .container { padding:0 14px; padding-top:var(--hh); }
  .section { padding:40px 0; }
  .sec-hd h2 { font-size:18px; }

  .hero { padding:76px 16px 52px; }
  .hero h1 { font-size:clamp(28px,9vw,42px); }
  .hero p  { font-size:14px; }
  .hero-btns { flex-direction:column; align-items:center; }
  .btn-primary, .btn-secondary { width:100%; max-width:300px; padding:13px 20px; }

  .prod-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .pc-img  { height:130px; font-size:44px; }
  .pc-body { padding:12px; }
  .pc-name { font-size:13px; }
  .pc-price{ font-size:15px; }

  .plan-grid { grid-template-columns:1fr; }

  /* 마이오피스: 사이드바 → 수평 탭 */
  .mo-layout { grid-template-columns:1fr; }
  .mo-side {
    position:static; height:auto;
    border-right:none; border-bottom:1px solid var(--border); padding:0;
  }
  .mo-user-box { display:none; }
  .mo-nav {
    display:flex; overflow-x:auto; padding:0;
    -webkit-overflow-scrolling:touch; gap:0;
  }
  .mo-nav::-webkit-scrollbar { display:none; }
  .mo-ni {
    flex-shrink:0; border-radius:0; padding:12px 14px;
    border-bottom:2px solid transparent; margin-bottom:0; font-size:12px;
  }
  .mo-ni.active { border-bottom-color:var(--gold); background:none; }
  .mo-ni span { width:auto; }
  .mo-main { padding:20px 14px; }
  .mo-title { font-size:18px; margin-bottom:18px; }

  .stat-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .stat-val  { font-size:20px; }
  .dtbl { display:block; overflow-x:auto; white-space:nowrap; }
  .rs-months { grid-template-columns:repeat(4,1fr); }
  .cart-panel { width:100vw; }
  .modal { border-radius:16px; }
  .modal-body { padding:18px; }
  .toast { bottom:16px; right:14px; left:14px; max-width:none; text-align:center; }
}

/* ── RESPONSIVE: 소형 ≤ 400px ────────────────────────────── */
@media(max-width:400px) {
  .hn-btn { font-size:10px; padding:5px 7px; }
  .prod-grid { grid-template-columns:1fr; }
  .pc-img { height:160px; font-size:52px; }
  .stat-grid { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════════════
   마이오피스 모바일 햄버거 메뉴
══════════════════════════════════════════════ */

/* 모바일 오버레이 */
.mo-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); z-index:1100; backdrop-filter:blur(2px);
}
.mo-overlay.show { display:block; }

/* 모바일 상단바 */
.mo-topbar {
  display:none; position:fixed; top:0; left:0; right:0; height:56px;
  background:#0D0D24; border-bottom:1px solid rgba(255,255,255,.08);
  align-items:center; padding:0 16px; z-index:1050; gap:12px;
}
.mo-hamburger {
  display:flex; flex-direction:column; justify-content:space-between;
  width:28px; height:20px; background:none; border:none; cursor:pointer; padding:0;
}
.mo-hamburger span {
  display:block; height:2px; background:#fff; border-radius:2px; transition:all .3s;
}
.mo-topbar-title { flex:1; font-weight:700; font-size:15px; color:#fff; text-align:center; }
.mo-topbar-user {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg,#F5A623,#E8950F);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:13px; color:#000;
}

/* 사이드바 닫기 버튼 (모바일만) */
.mo-side-close { display:none; justify-content:flex-end; padding:12px 16px 0; }
.mo-close-btn {
  background:none; border:none; color:#8080A8; font-size:20px;
  cursor:pointer; line-height:1; padding:4px 8px;
}
.mo-close-btn:hover { color:#fff; }

/* 반응형: 768px 이하 */
@media (max-width:768px) {
  .mo-topbar { display:flex; }
  .mo-layout { padding-top:56px; flex-direction:column; }

  .mo-side {
    position:fixed; left:-280px; top:0; bottom:0; width:280px;
    z-index:1200; transition:left .3s cubic-bezier(.4,0,.2,1);
    overflow-y:auto; border-right:1px solid rgba(255,255,255,.08);
  }
  .mo-side.open { left:0; }
  .mo-side-close { display:flex; }

  .mo-main { padding:20px 16px; }
  .mo-user-box { padding-top:12px; }
}

/* 관리자 패널 모바일 메뉴 */
.adm-topbar {
  display:none; position:fixed; top:0; left:0; right:0; height:54px;
  background:#0a0a18; border-bottom:1px solid rgba(255,255,255,.08);
  align-items:center; padding:0 16px; z-index:1050; gap:12px;
}
.adm-hamburger {
  display:flex; flex-direction:column; justify-content:space-between;
  width:26px; height:18px; background:none; border:none; cursor:pointer; padding:0;
}
.adm-hamburger span { display:block; height:2px; background:#fff; border-radius:2px; }
.adm-topbar-logo { flex:1; font-family:'Montserrat',sans-serif; font-weight:900; font-size:16px; letter-spacing:2px; color:#fff; text-align:center; }
.adm-topbar-logo span { color:#F5A623; }
.adm-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.55); z-index:1100;
}
.adm-overlay.show { display:block; }

@media (max-width:768px) {
  .adm-topbar { display:flex; }
  .adm-layout { flex-direction:column; padding-top:54px; }
  .adm-side {
    position:fixed; left:-260px; top:0; bottom:0; width:260px;
    z-index:1200; transition:left .3s ease; overflow-y:auto;
  }
  .adm-side.open { left:0; }
  .adm-main { padding:20px 16px; }
}

/* 트리 깊이 선택 버튼 */
.tree-depth-btn.active {
  background: rgba(245,166,35,.15) !important;
  border-color: rgba(245,166,35,.5) !important;
  color: var(--gold) !important;
  font-weight: 700;
}
.tree-depth-btn:hover {
  border-color: rgba(255,255,255,.35) !important;
  color: #fff !important;
}
