/* jammy-site 공통 스타일 — v3 디자인 시스템 */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f4ed;--sf:#fff;--sf2:#faf9f5;--sf3:#f0eee6;
  --bd:#e8e6dc;--bd2:#d5d0c4;
  --t1:#141413;--t2:#5e5d59;--t3:#87867f;
  --ac:#c96442;--ac-lt:rgba(201,100,66,.12);--ac-dk:#a84f32;
  --kk:#ffe812;--kk-dk:#3c1e1e;
  --gn:#16a34a;--gn-lt:#f0fdf4;
  --or:#d97706;--or-lt:#fffbeb;
  --rd:#b53333;--rd-lt:#fef2f2;
  --bl:#2563eb;--bl-lt:#eff6ff;
  --nav-w:236px;--top-h:58px;
  --r:10px;--r-sm:6px;--r-lg:16px;
  --sh:0 1px 3px rgba(20,20,19,.08);--sh-md:0 4px 14px rgba(20,20,19,.10);
}
html{scroll-behavior:smooth}
body{font-family:'Apple SD Gothic Neo','Noto Sans KR',-apple-system,sans-serif;background:var(--bg);color:var(--t1);font-size:14px;line-height:1.65;min-height:100vh}
/* topbar */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--top-h);background:var(--sf);border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 20px;gap:14px;z-index:100;box-shadow:var(--sh)}
.logo{font-size:17px;font-weight:800;color:var(--ac);text-decoration:none;display:flex;align-items:center;gap:8px}
.logo-b{background:var(--ac);color:#fff;border-radius:6px;width:24px;min-width:24px;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.topbar-sp{flex:1}
.topbar-user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--t2)}
.av{width:32px;min-width:32px;aspect-ratio:1/1;border-radius:50%;background:var(--ac-lt);color:var(--ac);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;border:2px solid var(--bd)}
/* layout */
.layout{display:flex;padding-top:var(--top-h);min-height:100vh}
.sidebar{width:var(--nav-w);background:var(--sf);border-right:1px solid var(--bd);position:fixed;top:var(--top-h);left:0;bottom:0;overflow-y:auto;z-index:90;padding:6px 0 24px}
.main{flex:1;margin-left:var(--nav-w);padding:28px 32px;min-width:0}
/* nav */
.ns{margin-top:2px}
.ns-lbl{font-size:10.5px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;padding:10px 16px 3px}
.nav-role-bar{padding:8px 16px 8px;border-bottom:1px solid var(--bd);margin-bottom:2px}
/* 운영자 구분선 */
.nav-divider{display:flex;align-items:center;gap:8px;padding:14px 16px 4px;margin-top:4px}
.nav-divider::before,.nav-divider::after{content:'';flex:1;height:1px;background:var(--bd)}
.nav-divider span{font-size:9px;font-weight:800;letter-spacing:.1em;color:var(--or);white-space:nowrap;text-transform:uppercase}
.nav-divider-admin span{color:var(--ac)}
.nav-divider-admin::before,.nav-divider-admin::after{background:var(--ac-lt)}
/* 운영자 섹션 스타일 */
.ns-op .ns-lbl{color:var(--or)}
/* 관리자 섹션 스타일 */
.ns-admin .ns-lbl{color:var(--ac)}
.nl{display:flex;align-items:center;gap:9px;padding:7px 16px;color:var(--t2);text-decoration:none;font-size:13px;border-left:3px solid transparent;transition:all .15s}
.nl:hover{background:var(--ac-lt);color:var(--ac)}
.nl.on{background:var(--ac-lt);color:var(--ac);border-left-color:var(--ac);font-weight:600}
.nl-ic{font-size:14px;width:16px;text-align:center;flex-shrink:0}
.nl-bd{margin-left:auto;font-size:10px;font-weight:700;background:var(--rd);color:#fff;border-radius:100px;padding:1px 6px}
/* page head */
.ph{margin-bottom:22px}
.pt{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}
.ps{font-size:13px;color:var(--t2)}
/* cards */
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:20px;box-shadow:var(--sh)}
.ct{font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px}
/* grid */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}
/* kpi */
.kpi{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:18px 20px;box-shadow:var(--sh)}
.kpi-ic{font-size:22px;margin-bottom:8px}
.kpi-v{font-size:26px;font-weight:800;line-height:1.1;letter-spacing:-.02em}
.kpi-l{font-size:11.5px;color:var(--t3);font-weight:600;margin-top:4px}
.kpi-d{font-size:11px;margin-top:3px}
.up{color:var(--gn)}.dn{color:var(--rd)}
/* buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;text-decoration:none;font-family:inherit;white-space:nowrap}
.bp{background:var(--ac);color:#fff}.bp:hover{background:var(--ac-dk)}
.bk{background:var(--kk);color:var(--kk-dk);font-weight:700}.bk:hover{background:#ffd900}
.bo{background:transparent;border:1.5px solid var(--bd);color:var(--t2)}.bo:hover{border-color:var(--ac);color:var(--ac)}
.bg{background:transparent;color:var(--t2)}.bg:hover{background:var(--sf3)}
.bd2{background:var(--rd);color:#fff}
.btn-lg{padding:13px 28px;font-size:15px;border-radius:var(--r)}
.btn-sm{padding:5px 11px;font-size:12px}
.btn:disabled{opacity:.5;cursor:not-allowed}
/* forms */
.fg{margin-bottom:15px}
.lbl{display:block;font-size:12px;font-weight:700;color:var(--t2);margin-bottom:5px}
.inp,.sel,.ta{width:100%;padding:9px 12px;border:1.5px solid var(--bd);border-radius:var(--r-sm);font-size:13.5px;color:var(--t1);background:var(--sf);font-family:inherit;outline:none;transition:border-color .15s}
.inp:focus,.sel:focus,.ta:focus{border-color:var(--ac)}
.ta{resize:vertical;min-height:96px}
.inp-row{display:flex;gap:8px}.inp-row .inp{flex:1}
/* table */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;padding:9px 14px;font-size:11px;font-weight:700;color:var(--t3);border-bottom:1.5px solid var(--bd);background:var(--sf2);white-space:nowrap}
td{padding:11px 14px;border-bottom:1px solid var(--bd);color:var(--t1);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--sf2)}
/* badges */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:100px;font-size:11px;font-weight:700;white-space:nowrap}
.b-gn{background:var(--gn-lt);color:var(--gn)}.b-or{background:var(--or-lt);color:var(--or)}.b-rd{background:var(--rd-lt);color:var(--rd)}.b-bl{background:var(--bl-lt);color:var(--bl)}.b-gy{background:var(--sf3);color:var(--t3)}.b-ac{background:var(--ac-lt);color:var(--ac)}.b-kk{background:var(--kk);color:var(--kk-dk)}
/* helpers */
.div{height:1px;background:var(--bd);margin:18px 0}
.flex{display:flex}.fca{display:flex;align-items:center}.fcb{display:flex;align-items:center;justify-content:space-between}
.g6{gap:6px}.g8{gap:8px}.g12{gap:12px}.g16{gap:16px}.g20{gap:20px}
.f1{flex:1}.mla{margin-left:auto}
.mt4{margin-top:4px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}.mt24{margin-top:24px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.d-gn{background:var(--gn)}.d-or{background:var(--or)}.d-rd{background:var(--rd)}.d-gy{background:var(--t3)}
/* progress */
.prog{height:6px;background:var(--bd);border-radius:100px;overflow:hidden;margin-top:5px}
.pf{height:100%;background:var(--ac);border-radius:100px;transition:width .4s}
/* chat */
.chat-area{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--sf2);border-radius:var(--r);border:1px solid var(--bd);max-height:280px;overflow-y:auto}
.bub{padding:9px 13px;border-radius:14px;font-size:13px;line-height:1.5;max-width:76%}
.bub-j{background:var(--sf);border:1px solid var(--bd);border-radius:4px 14px 14px 14px;align-self:flex-start}
.bub-u{background:var(--ac);color:#fff;border-radius:14px 4px 14px 14px;align-self:flex-end}
/* toast */
#toast{position:fixed;bottom:22px;right:22px;background:var(--t1);color:#fff;padding:11px 18px;border-radius:var(--r);font-size:13px;z-index:9999;opacity:0;transform:translateY(8px);transition:all .2s;pointer-events:none;max-width:300px}
#toast.show{opacity:1;transform:translateY(0)}
#toast.ok{background:var(--gn)}
#toast.err{background:var(--rd)}
/* spinner */
.spin{display:inline-block;width:13px;min-width:13px;aspect-ratio:1/1;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
/* timeline */
.tl{position:relative;padding-left:26px}
.tl::before{content:'';position:absolute;left:9px;top:0;bottom:0;width:2px;background:var(--bd)}
.tl-it{position:relative;margin-bottom:18px}
.tl-dot{position:absolute;left:-21px;top:4px;width:12px;min-width:12px;aspect-ratio:1/1;border-radius:50%;background:var(--ac);border:2px solid var(--sf)}
.tl-d{font-size:11px;color:var(--t3);font-weight:600;margin-bottom:2px}
.tl-t{font-size:13.5px;font-weight:700;margin-bottom:2px}
.tl-s{font-size:12.5px;color:var(--t2)}
/* log */
.log{background:#1a1918;border-radius:var(--r);padding:14px;font-family:monospace;font-size:11.5px;color:#c8c5be;max-height:190px;overflow-y:auto}
.log-ok{color:#4ade80}.log-warn{color:#fbbf24}.log-err{color:#f87171}
/* funnel */
.fn-step{position:relative;padding:14px 16px 14px 52px;border:1px solid var(--bd);border-radius:var(--r-sm);margin-bottom:8px;background:var(--sf)}
.fn-num{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:26px;min-width:26px;aspect-ratio:1/1;border-radius:50%;background:var(--ac);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
/* auth page */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.auth-box{width:100%;max-width:400px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--r-lg);padding:38px;box-shadow:var(--sh-md)}
/* hero */
.hero{background:linear-gradient(135deg,#fdf8f4 0%,#f5f4ed 55%,#ede8e0 100%);border-bottom:1px solid var(--bd);padding:80px 40px 64px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-100px;right:-60px;width:360px;height:360px;background:radial-gradient(circle,rgba(201,100,66,.07),transparent 70%);pointer-events:none}
.hero h1{font-size:42px;font-weight:900;letter-spacing:-.04em;line-height:1.12;margin-bottom:16px}
.hero h1 em{color:var(--ac);font-style:normal}
.hero-p{font-size:17px;color:var(--t2);max-width:520px;margin:0 auto 30px}
.hero-cta{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.hero-stats{display:flex;justify-content:center;gap:40px;margin-top:52px;flex-wrap:wrap}
.hs-num{font-size:30px;font-weight:900;color:var(--ac)}
.hs-lbl{font-size:11.5px;color:var(--t3);font-weight:600;margin-top:2px}
/* public topbar override */
.pub-top a.nav-pub{font-size:13px;color:var(--t2);text-decoration:none;padding:6px 10px;border-radius:var(--r-sm);transition:.15s}
.pub-top a.nav-pub:hover{background:var(--sf3);color:var(--t1)}
/* calendar */
.cal-hd{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:3px}
.cal-dh{font-size:11px;font-weight:700;color:var(--t3);text-align:center;padding:4px 0}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-d{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);font-size:12.5px;font-weight:600;cursor:pointer;border:1.5px solid transparent;transition:.15s;position:relative}
.cal-d:hover{border-color:var(--ac);background:var(--ac-lt)}
.cal-d.today{background:var(--ac);color:#fff;border-color:var(--ac)}
.cal-d.has-ev::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--or)}
.cal-d.em{opacity:.25;cursor:default}
/* 햄버거 버튼 */
.ham-btn{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;cursor:pointer;border:none;background:transparent;border-radius:var(--r-sm)}
.ham-btn span{display:block;height:2px;background:var(--t1);border-radius:2px;transition:.25s}
.ham-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham-btn.open span:nth-child(2){opacity:0}
.ham-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* 모바일 오버레이 */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:199}
.nav-overlay.show{display:block}
@media(max-width:768px){
  .ham-btn{display:flex}
  .sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;z-index:200;transform:translateX(-100%);transition:transform .25s;box-shadow:var(--sh-md)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;padding:18px 14px}
  .g2,.g3,.g4{grid-template-columns:1fr}
}
