/* admin.css — 관리자 대시보드 전용 */

.admtp{height:52px;display:flex;align-items:center;padding:0 16px;gap:10px;
  background:linear-gradient(90deg,#0f0d0c,#1e150a);
  border-bottom:.5px solid rgba(184,147,58,.18);flex-shrink:0}
.admbr{font-family:'Noto Serif KR',serif;font-size:15px;font-weight:700;
  color:var(--gold);letter-spacing:.04em;flex:1}
.admub{font-size:11px;color:rgba(255,255,255,.4);font-weight:500}
.admlo{font-size:11px;color:rgba(255,255,255,.35);background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:5px 10px;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;transition:all .2s}
.admlo:active{background:rgba(255,255,255,.12)}

/* ── 메인 탭바 (관리자/내정보 전환) ── */
.adm-main-bar{height:52px;display:flex;align-items:center;padding:0 16px;gap:10px;
  background:linear-gradient(90deg,#0f0d0c,#1e150a);
  border-bottom:.5px solid rgba(184,147,58,.18);flex-shrink:0}
.adm-main-tabs{display:flex;gap:4px;flex:1}
.adm-main-tab{font-size:12px;font-weight:600;padding:5px 14px;border-radius:20px;
  border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);
  color:rgba(255,255,255,.4);cursor:pointer;font-family:'Noto Sans KR',sans-serif;
  transition:all .2s}
.adm-main-tab.on{background:var(--stamp);border-color:var(--stamp);color:#fff}
.adm-main-tab:not(.on):active{background:rgba(255,255,255,.1)}

/* ── 관리자 탭 (6→4개 슬림) ── */
.admtabs{display:flex;gap:0;overflow-x:auto;flex-shrink:0;
  background:var(--paper);border-bottom:2px solid var(--paper2);
  -webkit-overflow-scrolling:touch;scrollbar-width:none}
.admtabs::-webkit-scrollbar{display:none}
.admtab{flex:1;min-width:0;padding:12px 4px;border:none;background:none;cursor:pointer;
  font-size:11px;font-weight:500;color:var(--muted);font-family:'Noto Sans KR',sans-serif;
  border-bottom:2.5px solid transparent;transition:all .2s;white-space:nowrap;
  margin-bottom:-2px;display:flex;flex-direction:column;align-items:center;gap:3px}
.admtab.on{color:var(--stamp);border-bottom-color:var(--stamp);font-weight:700}

/* ── 섹션 공통 헤더 ── */
.adm-sec-hd{display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px 8px;border-bottom:.5px solid var(--bd2)}
.adm-sec-ttl{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);display:flex;align-items:center;gap:6px}
.adm-sec-act{font-size:11px;color:var(--stamp);cursor:pointer;background:none;border:none;
  padding:4px 8px;font-family:'Noto Sans KR',sans-serif;border-radius:6px;
  background:var(--stamp-lt)}

/* ── 대시보드 스크롤 ── */
.dash-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding-bottom:calc(var(--th,62px) + var(--sb,0px) + 16px)}
.dash-scroll::-webkit-scrollbar{display:none}

/* ── A. 매출 히어로 카드 (개선) ── */
.rev-hero{margin:12px 16px 0;background:linear-gradient(135deg,#0f0d0c 0%,#1e150a 50%,#2a1a08 100%);
  border-radius:var(--r);padding:0;position:relative;overflow:hidden;
  border:.5px solid rgba(184,147,58,.2)}
.rh-glow{position:absolute;right:-20px;top:-20px;width:140px;height:140px;
  background:radial-gradient(circle,rgba(184,147,58,.25) 0%,transparent 65%);pointer-events:none}
.rh-glow2{position:absolute;left:-20px;bottom:-20px;width:100px;height:100px;
  background:radial-gradient(circle,rgba(27,45,79,.15) 0%,transparent 65%);pointer-events:none}
/* 상단: 누적매출 */
.rh-top{padding:18px 20px 14px;border-bottom:.5px solid rgba(255,255,255,.06)}
.rh-lbl{font-size:10px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:5px}
.rh-amt{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;
  color:var(--gold);line-height:1;letter-spacing:-.01em}
.rh-sub{font-size:11px;color:rgba(255,255,255,.35);margin-top:7px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rh-sub-item{display:flex;align-items:center;gap:4px}
.rh-sub-dot{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.25)}
/* 하단: 4격자 */
.rh-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.rh-item{padding:12px 10px;border-right:.5px solid rgba(255,255,255,.06);text-align:center}
.rh-item:last-child{border-right:none}
.rh-il{font-size:10px;color:rgba(255,255,255,.3);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rh-iv{font-size:14px;font-weight:700;color:#fff}

/* ── B. 오늘의 현황 4카드 ── */
.today-status{margin:10px 16px 0}
.ts-hd{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:8px;padding-left:2px}
.task-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.tc{background:var(--paper);border-radius:var(--rs);padding:14px;border:.5px solid var(--bd2);
  position:relative;overflow:hidden;cursor:pointer;transition:all .18s}
.tc:active{transform:scale(.96);background:var(--paper2)}
.tc-bar{position:absolute;top:0;left:0;right:0;height:3px}
.tc-ico{font-size:20px;margin-bottom:6px;line-height:1}
.tc-n{font-family:'Playfair Display',serif;font-size:30px;line-height:1;margin-bottom:3px}
.tc-l{font-size:10px;color:var(--muted);line-height:1.3}
.tc-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:8px;
  display:inline-block;margin-top:5px;letter-spacing:.05em}

/* ── C. 매출 차트 섹션 ── */
.weekly-section{margin:10px 16px 0;background:var(--paper);border-radius:var(--r);
  border:.5px solid var(--bd2);overflow:hidden}
.ws-hd{padding:12px 14px 0;font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  display:flex;align-items:center;justify-content:space-between}
.ws-total{font-size:10px;color:var(--stamp);font-weight:600;text-transform:none;letter-spacing:0}
.week-bars{display:flex;align-items:flex-end;gap:4px;height:88px;padding:8px 14px 0}
.wb-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.wb-bar{width:100%;border-radius:4px 4px 0 0;min-height:4px;transition:height .7s cubic-bezier(.34,1.56,.64,1)}
.wb-lbl{font-size:10px;color:var(--muted);padding:4px 0;border-top:.5px solid var(--bd2);width:100%;text-align:center}
.wb-amt{font-size:10px;color:var(--ink);font-weight:600;display:none}

/* ── D. 주문 상태 + 발송유형 도넛 ── */
.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 16px 0}
.donut-section{background:var(--paper);border-radius:var(--rs);padding:12px;border:.5px solid var(--bd2)}
.ds-ttl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px}
.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}
.donut-svg{flex-shrink:0}
.donut-legend{width:100%;display:flex;flex-direction:column;gap:5px}
.dl-item{display:flex;align-items:center;gap:6px;font-size:10px}
.dl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dl-lbl{flex:1;color:var(--muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dl-val{font-weight:700;color:var(--ink);font-size:10px}

/* ── E. 최근 주문 리스트 ── */
.dash-ord-list{margin:10px 16px 0;display:flex;flex-direction:column;gap:5px}
.do-item{background:var(--paper);border:.5px solid var(--bd);border-radius:var(--rs);
  padding:10px 12px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:background .15s}
.do-item:active{background:var(--paper2)}
.do-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.do-info{flex:1;min-width:0}
.do-nm{font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.do-sb{font-size:10px;color:var(--muted);margin-top:1px}
.do-st{font-size:10px;font-weight:700;flex-shrink:0;padding:3px 7px;border-radius:8px}

/* ── F. 빠른 실행 그리드 ── */
.qagrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:10px 16px 0}
.qabt{background:var(--paper);border:.5px solid var(--bd2);border-radius:var(--rs);
  padding:13px 10px;display:flex;flex-direction:column;align-items:center;gap:7px;
  font-size:11px;font-weight:600;cursor:pointer;font-family:'Noto Sans KR',sans-serif;
  color:var(--ink);transition:all .15s}
.qabt:active{transform:scale(.96)}
.qai{font-size:20px;line-height:1}
.qa-s{background:var(--stamp-lt);border-color:var(--stamp);color:var(--stamp)}
.qa-g{background:var(--sage-lt);border-color:rgba(74,140,92,.2);color:var(--sage)}
.qa-k{background:rgba(123,104,238,.08);border-color:rgba(123,104,238,.2);color:#7b68ee}
.qa-b{background:rgba(37,99,235,.07);border-color:rgba(37,99,235,.2);color:var(--blue)}

/* ── G. 주문관리 패널 ── */
.ap{display:none}.ap.on{display:block}
/* 발송유형 카드 */
.del-card{background:var(--paper);border:2px solid var(--bd);border-radius:var(--rs);padding:10px 8px 8px;
  display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;
  transition:all .15s;position:relative;text-align:center}
.del-card:active,.del-card.on{background:var(--paper2);transform:scale(.97)}
.del-card.on{box-shadow:0 0 0 2px currentColor}
.dc-ico{font-size:20px;line-height:1;margin-bottom:2px}
.dc-lbl{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.04em}
.dc-cnt{font-size:22px;font-weight:800;color:var(--ink);line-height:1.1}
.dc-sub{font-size:10px;color:var(--muted);margin-bottom:4px}
.dc-prt{width:100%;padding:5px 0;border:none;border-radius:6px;font-size:10px;font-weight:700;
  cursor:pointer;background:var(--muted);color:#fff;font-family:'Noto Sans KR',sans-serif;
  transition:opacity .15s}
.dc-prt:active{opacity:.7}
.flt{display:flex;gap:6px;overflow-x:auto;padding:10px 16px;flex-shrink:0;
  scrollbar-width:none;-webkit-overflow-scrolling:touch}
.flt::-webkit-scrollbar{display:none}
.fp{flex-shrink:0;padding:7px 13px;border-radius:18px;border:1.5px solid var(--bd);
  background:var(--paper);color:var(--muted);font-size:11px;font-weight:500;cursor:pointer;
  font-family:'Noto Sans KR',sans-serif;transition:all .18s;white-space:nowrap}
.fp.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.olist{padding:0 16px 12px;display:flex;flex-direction:column;gap:8px}
.oc{background:var(--paper);border:.5px solid var(--bd);border-radius:var(--rs);overflow:hidden}
.och{display:flex;align-items:center;justify-content:space-between;padding:11px 13px}
.ocm{flex:1;min-width:0}
.ocid{font-size:13px;font-weight:700;display:flex;align-items:center;gap:7px}
.ocsb{font-size:11px;color:var(--muted);margin-top:2px}
.ocft{display:flex;gap:7px;padding:8px 13px;border-top:.5px solid var(--bd2);
  flex-wrap:wrap}
.trin{padding:8px 13px;border-top:.5px solid var(--bd2);display:flex;gap:8px}
.trin input{flex:1;padding:8px 10px;border:1.5px solid var(--bd);border-radius:8px;
  font-size:12px;outline:none;font-family:'Noto Sans KR',sans-serif}
.trin input:focus{border-color:var(--sage)}
.flbg{background:var(--stamp-lt);color:var(--stamp);font-size:10px;
  padding:2px 6px;border-radius:6px;font-weight:700}

/* ── H. 매출 통계 패널 ── */
.rvg{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:12px 16px 0}
.rvb{background:var(--paper);border:.5px solid var(--bd2);border-radius:var(--rs);padding:14px}
.rvn{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;line-height:1;margin-bottom:4px}
.rvl{font-size:10px;color:var(--muted);font-weight:500}
.barw{margin:10px 16px 0;background:var(--paper);border:.5px solid var(--bd2);border-radius:var(--rs);padding:14px}
.barw-ttl{font-size:11px;font-weight:700;color:var(--ink);margin-bottom:10px}
.barit{margin-bottom:10px}.barit:last-child{margin-bottom:0}
.barl{display:flex;justify-content:space-between;font-size:11px;margin-bottom:5px}
.bartr{background:var(--paper2);border-radius:4px;height:7px;overflow:hidden}
.barf{height:100%;border-radius:4px;transition:width .8s cubic-bezier(.34,1.56,.64,1)}

/* ── I. 관리자 패널 공통 ── */
.admlw{display:flex;align-items:center;justify-content:center;
  background:var(--paper);padding:20px}
.admbx{width:100%;max-width:320px;background:var(--paper);border-radius:var(--r);
  padding:28px 24px;border:.5px solid var(--bd);
  box-shadow:0 8px 32px rgba(26,26,26,.08)}
.admtt{font-family:'Noto Serif KR',serif;font-size:20px;font-weight:700;
  margin-bottom:5px;color:var(--ink)}
.admst{font-size:12px;color:var(--muted);margin-bottom:22px}

/* 모달 공통 */
.modal-bg{position:absolute;inset:0;z-index:990;background:rgba(0,0,0,.6);display:none;align-items:flex-end;justify-content:center}
.modal-bg.on{display:flex!important}
.modal-box{background:var(--paper);color:var(--ink);border-radius:var(--r) var(--r) 0 0;width:100%;max-height:88%;overflow-y:auto;animation:slideUp .25s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-hd{padding:16px 20px;border-bottom:.5px solid var(--bd);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--paper);z-index:1}
.modal-tt{font-family:'Noto Serif KR',serif;font-size:16px;font-weight:600}
.modal-cl{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);line-height:1}
.modal-bd{padding:16px 20px}

/* ── 탭바 2탭 ── */
.tabbar{position:absolute;bottom:0;left:0;right:0;z-index:80;background:var(--paper);border-top:1px solid var(--bd);padding-bottom:var(--sb);box-shadow:0 -1px 0 rgba(26,26,26,.08),0 -6px 20px rgba(26,26,26,.04)}
.tab-two{display:flex;align-items:center;height:62px;padding:8px 12px;gap:8px;box-sizing:border-box;width:100%}
.t2-item{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;height:46px;border-radius:14px;border:1.5px solid var(--bd);background:var(--paper2);cursor:pointer;transition:all .2s cubic-bezier(.34,1.3,.64,1);min-width:0;overflow:hidden;padding:0 12px}
.t2-item:active{transform:scale(.95)}
.t2-ico{font-size:19px;line-height:1;flex-shrink:0}
.t2-lbl{font-size:12px;font-weight:500;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.t2-item.on.user-tab{background:var(--stamp-lt);border-color:var(--stamp)}
.t2-item.on.user-tab .t2-lbl{color:var(--stamp);font-weight:700}
.t2-item.on.adm-tab{background:var(--stamp);border-color:var(--stamp)}
.t2-item.on.adm-tab .t2-lbl{color:#fff;font-weight:700}
.tbw{position:relative;display:inline-flex;align-items:center;flex-shrink:0}
.tbdg{position:absolute;top:-5px;right:-8px;min-width:15px;height:15px;background:var(--stamp);color:#fff;font-size:10px;border-radius:8px;display:none;align-items:center;justify-content:center;font-weight:700;padding:0 4px;border:2px solid var(--paper)}
.tbdg.on{display:flex}
/* 인쇄 모드 */
.printing-mode 
.printing-mode 
/* 보내는분 저장 주소 */
.sndr-saved-item{padding:10px 36px 10px 12px;border-bottom:.5px solid var(--bd2);cursor:pointer;position:relative;transition:background .15s}
.sndr-saved-item:last-child{border:none}
.sndr-saved-item:hover{background:var(--paper2)}
#sndr-dropdown{display:none;background:var(--paper);border:1.5px solid var(--stamp);border-radius:var(--rs);margin-bottom:10px;max-height:160px;overflow-y:auto}
/* 저장된 수신자 in write */
.ab-sec{background:rgba(37,99,235,.06);border:1.5px solid rgba(37,99,235,.2);border-radius:var(--rs);padding:12px 14px;margin-bottom:12px}
.ab-sec-t{font-size:12px;font-weight:600;color:var(--blue);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.ab-it{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:.5px solid rgba(37,99,235,.1);cursor:pointer}
.ab-it:last-child{border:none}.ab-it:hover{opacity:.7}
.ab-nm{font-size:13px;font-weight:500;flex:1}.ab-sb{font-size:11px;color:var(--muted)}


/* ── 온보딩 슬라이드 2,3 ── */

.ob-inner{position:relative;z-index:2;width:100%;padding:calc(env(safe-area-inset-top,0px) + 52px) 26px 28px;display:flex;flex-direction:column;gap:0;min-height:min-content}
.ob-inner-dk{color:#fff}
.ob-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--stamp);font-weight:700;margin:0 0 10px}
.ob-ttl2{font-family:'Noto Serif KR',serif;font-size:24px;font-weight:700;line-height:1.35;color:var(--ink);margin:0 0 6px}
.ob-sub2{font-size:12px;color:var(--muted);margin:0 0 22px}
.ob-steps{display:flex;flex-direction:column;gap:0;margin-bottom:18px}
.ob-step{display:flex;align-items:flex-start;gap:14px;margin-bottom:0}
.ob-step-line{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:44px}
.ob-step-ico{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.ob-line{width:2px;height:18px;margin:3px 0}
.ob-step-card{flex:1;background:var(--paper);border-radius:14px;padding:13px 15px;box-shadow:0 2px 12px rgba(26,26,26,.07);margin-bottom:10px}
.ob-step-num{font-size:10px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-bottom:4px}
.ob-step-nm{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px}
.ob-step-sb{font-size:11px;color:var(--muted)}
.ob-badges{display:flex;gap:8px}
.ob-badge{flex:1;border-radius:12px;padding:11px 8px;text-align:center}
.ob-badge span{display:block;font-size:17px;font-weight:800;line-height:1}
.ob-badge small{display:block;font-size:10px;color:var(--muted);margin-top:3px}
.ob-badge-r{background:var(--stamp-lt);border:1.5px solid var(--stamp)}.ob-badge-r span{color:var(--stamp)}
.ob-badge-g{background:rgba(184,151,90,.07);border:1.5px solid rgba(184,151,90,.18)}.ob-badge-g span{color:var(--gold)}
.ob-badge-s{background:rgba(74,140,92,.07);border:1.5px solid rgba(74,140,92,.18)}.ob-badge-s span{color:var(--sage)}
/* 슬라이드3 */
.ob-price-hero{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);border-radius:18px;padding:18px 20px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.ob-price-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:6px}
.ob-price-num{font-size:36px;font-weight:800;color:#fff;line-height:1;letter-spacing:-.02em}
.ob-price-num span{font-size:16px;color:rgba(255,255,255,.6)}
.ob-price-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:5px}
.ob-price-icon{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:22px}
.ob-options{display:flex;flex-direction:column;gap:0;margin-bottom:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.11);border-radius:14px;overflow:hidden}
.ob-option{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.07)}
.ob-option:last-child{border:none}
.ob-opt-ico{font-size:16px;width:24px;text-align:center}
.ob-opt-nm{flex:1;font-size:12px;color:rgba(255,255,255,.7)}
.ob-opt-pr{font-size:13px;font-weight:700;color:#fff}
.ob-benefit{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.13);border-radius:12px;padding:12px 14px;font-size:12px}
.ob-benefit b{color:#fff;font-size:13px}
.ob-benefit small{color:rgba(255,255,255,.5);font-size:10px}


