/* ============================================
   투어브릿지 공통 스타일
============================================ */
:root{
  --ink:#1a2332;--ink-2:#3a4a5e;--ink-3:#6b7a8f;--ink-4:#9aa4b2;
  --paper:#f7f4ed;--paper-2:#ede7d8;--paper-3:#faf8f1;
  --line:#d8d2c1;--line-2:#ede7d8;
  --accent:#d4622a;--accent-2:#2d5a4f;--accent-3:#c9a14a;--accent-4:#8b3a62;
  --accent-soft:#fdf3e7;--accent2-soft:#e8f0ec;--accent3-soft:#faf0d9;--accent4-soft:#f5e8ee;
  --shadow:0 1px 0 rgba(26,35,50,.04),0 8px 24px rgba(26,35,50,.06);
  --kakao:#FEE500;--naver:#03C75A;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:'Pretendard',-apple-system,sans-serif;font-weight:400;-webkit-font-smoothing:antialiased;line-height:1.5}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.serif{font-family:'Gowun Batang',serif}

/* ===== 공통 헤더 (B2C) ===== */
.b2c-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.b2c-header-inner{max-width:var(--maxw);margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.b2c-logo{display:flex;align-items:center;gap:8px;font-family:'Gowun Batang',serif;font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.b2c-logo .mark{width:24px;height:24px;border-radius:50%;background:var(--accent);position:relative;flex-shrink:0}
.b2c-logo .mark::after{content:'';position:absolute;inset:5px;border-radius:50%;background:var(--paper)}
.b2c-nav{display:flex;gap:24px;font-size:13px;color:var(--ink-2);font-weight:500}
.b2c-nav a{position:relative;padding:6px 0;transition:color .2s}
.b2c-nav a.on,.b2c-nav a:hover{color:var(--accent);font-weight:600}
.b2c-nav a.on::after{content:'';position:absolute;left:0;right:0;bottom:-15px;height:2px;background:var(--accent)}
.b2c-actions{display:flex;align-items:center;gap:10px}
.b2c-actions .icon-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-2);background:#fff;transition:all .2s}
.b2c-actions .icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.b2c-actions .icon-btn svg{width:14px;height:14px}
.b2c-actions .avatar{width:36px;height:36px;border-radius:50%;background:var(--accent2-soft);color:var(--accent-2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px}
.b2c-actions .login-btn{height:36px;padding:0 16px;border-radius:8px;background:var(--ink);color:#fff;font-size:13px;font-weight:600;border:0}
.mobile-menu-btn{display:none;width:36px;height:36px;border-radius:8px;border:1px solid var(--line);background:#fff;align-items:center;justify-content:center}

/* ===== 공통 푸터 ===== */
.footer{background:#1a2332;color:#9aa4b2;padding:48px 20px 32px;margin-top:48px}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}
.footer-brand{font-family:'Gowun Batang',serif}
.footer-brand .logo{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;color:#fff;margin-bottom:14px}
.footer-brand .logo .mark{width:22px;height:22px;border-radius:50%;background:var(--accent);position:relative}
.footer-brand .logo .mark::after{content:'';position:absolute;inset:5px;border-radius:50%;background:#1a2332}
.footer-brand p{font-family:'Pretendard';font-size:12px;line-height:1.7;color:#9aa4b2}
.footer-col h5{color:#fff;font-size:13px;margin-bottom:14px;font-weight:600}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col a{font-size:12px;color:#9aa4b2;transition:color .2s}
.footer-col a:hover{color:var(--accent-3)}
.footer-bottom{max-width:var(--maxw);margin:32px auto 0;padding-top:24px;border-top:1px solid #2a3548;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:11px;color:#6b7a8f}

/* ===== 페이지 컨테이너 ===== */
.page{max-width:var(--maxw);margin:0 auto;padding:32px 20px}
.page-title-bar{background:linear-gradient(180deg,#fdf3e7 0%,#fff 100%);padding:48px 20px 36px;border-bottom:1px solid var(--line)}
.page-title-bar .inner{max-width:var(--maxw);margin:0 auto}
.page-title-bar .crumb{font-size:11px;color:var(--ink-3);letter-spacing:.05em;margin-bottom:8px;font-weight:500}
.page-title-bar .crumb em{color:var(--accent);font-style:normal;font-weight:600}
.page-title-bar h1{font-family:'Gowun Batang',serif;font-size:32px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.2}
.page-title-bar h1 em{font-style:normal;color:var(--accent)}
.page-title-bar .lede{margin-top:10px;font-size:14px;color:var(--ink-2);max-width:640px;line-height:1.7}

/* ===== 카드/패널 공통 ===== */
.panel{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:20px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.panel-head h3{font-family:'Gowun Batang',serif;font-size:17px;font-weight:700;color:var(--ink)}
.panel-head .panel-sub{font-size:12px;color:var(--ink-3);margin-top:2px}

/* ===== 버튼 ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 18px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid transparent;font-family:inherit;transition:all .2s}
.btn svg{width:13px;height:13px}
.btn-pri{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-pri:hover{background:var(--accent);border-color:var(--accent)}
.btn-sec{background:#fff;color:var(--ink-2);border-color:var(--line)}
.btn-sec:hover{border-color:var(--ink-3);color:var(--ink)}
.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-accent:hover{background:#b54e1e;border-color:#b54e1e}
.btn-danger{background:#fff;color:#a8403c;border-color:#f5d4d3}
.btn-danger:hover{background:#fef5f4}
.btn-sm{height:32px;padding:0 12px;font-size:12px}
.btn-lg{height:48px;padding:0 24px;font-size:14px}

/* ===== 폼 ===== */
.form-row{margin-bottom:14px}
.form-row label{display:block;font-size:12px;color:var(--ink-2);font-weight:500;margin-bottom:6px}
.form-row label em{font-style:normal;color:var(--accent);margin-left:2px}
.form-row input,.form-row select,.form-row textarea{width:100%;height:42px;padding:0 14px;border:1px solid var(--line);border-radius:8px;font-size:13px;background:#fff;color:var(--ink);font-family:inherit;transition:border-color .2s}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:0;border-color:var(--accent)}
.form-row input::placeholder{color:var(--ink-4)}
.form-row textarea{height:auto;min-height:90px;padding:12px 14px;resize:vertical}
.form-row select{appearance:none;background:#fff url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7a8f' stroke-width='2'%3e%3cpath d='m6 9 6 6 6-6'/%3e%3c/svg%3e") no-repeat right 12px center/14px;padding-right:34px;cursor:pointer}
.form-row .helper{margin-top:5px;font-size:11px;color:var(--ink-3)}
.form-row .helper.error{color:#a8403c}
.form-row .helper.success{color:var(--accent-2)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1 / -1}

/* ===== 테이블 ===== */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}
.tbl thead th{text-align:left;padding:12px 14px;font-size:11px;color:var(--ink-3);letter-spacing:.05em;border-bottom:1px solid var(--line);font-weight:600;background:var(--paper-3);text-transform:uppercase}
.tbl tbody td{padding:14px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr:hover{background:var(--paper-3)}
.tbl .num{text-align:right;font-family:'Gowun Batang',serif;font-weight:700;color:var(--ink)}

/* 상태 뱃지 */
.stat{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:99px;font-size:11px;font-weight:600}
.stat.ok{background:var(--accent2-soft);color:var(--accent-2)}
.stat.wait{background:#fdf3e7;color:#a85a1a}
.stat.no{background:#f5e8e8;color:#a8403c}
.stat.completed{background:#eee;color:var(--ink-3)}

/* ===== KPI 카드 ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;position:relative;overflow:hidden}
.kpi .label{font-size:11px;color:var(--ink-3);font-weight:500;letter-spacing:.05em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.kpi .label .ind{width:6px;height:6px;border-radius:50%}
.kpi .value{font-family:'Gowun Batang',serif;font-size:26px;font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.1}
.kpi .value em{font-style:normal;font-size:13px;color:var(--ink-3);margin-left:2px;font-family:'Pretendard';font-weight:500}
.kpi .trend{margin-top:8px;font-size:11px;font-weight:600;display:inline-flex;align-items:center;gap:3px}
.kpi .trend.up{color:var(--accent-2)}
.kpi .trend.down{color:#a8403c}

/* ===== 모바일 하단 탭 ===== */
.mobile-tab-bar{display:none;position:sticky;bottom:0;background:#fff;border-top:1px solid var(--line);padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:40;grid-template-columns:repeat(5,1fr)}
.mobile-tab-bar a{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;color:var(--ink-3);padding:6px 0;font-weight:500}
.mobile-tab-bar a svg{width:20px;height:20px}
.mobile-tab-bar a.on{color:var(--accent)}

/* ===== 사이드 메뉴 (마이페이지/사업자/지자체 공통) ===== */
.split-layout{display:grid;grid-template-columns:240px 1fr;gap:20px;max-width:var(--maxw);margin:0 auto;padding:24px 20px}
.split-aside{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;height:fit-content;position:sticky;top:80px}
.split-aside .aside-title{font-family:'Gowun Batang',serif;font-size:14px;font-weight:700;color:var(--ink);padding:0 6px 14px;border-bottom:1px solid var(--line);margin-bottom:10px}
.split-aside .menu-item{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:8px;font-size:13px;color:var(--ink-2);font-weight:500;margin-bottom:2px;transition:all .15s}
.split-aside .menu-item svg{width:14px;height:14px;color:var(--ink-3);flex-shrink:0}
.split-aside .menu-item:hover{background:var(--paper-3)}
.split-aside .menu-item.on{background:var(--ink);color:#fff}
.split-aside .menu-item.on svg{color:var(--accent)}
.split-aside .menu-item.danger{margin-top:10px;border-top:1px solid var(--line);padding-top:14px;border-radius:0;color:#a8403c}
.split-aside .menu-item.danger svg{color:#a8403c}

/* ===== 모바일 반응형 ===== */
@media (max-width:1024px){
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .b2c-nav,.b2c-actions .icon-btn{display:none}
  .mobile-menu-btn{display:inline-flex}
  .b2c-actions .login-btn{height:32px;padding:0 12px;font-size:12px}
  .page-title-bar{padding:28px 20px 22px}
  .page-title-bar h1{font-size:24px}
  .page{padding:20px 16px}
  .panel{padding:18px;border-radius:12px}
  .form-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .kpi{padding:14px}
  .kpi .value{font-size:20px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:24px}
  .footer{padding:32px 20px 24px}
  .split-layout{grid-template-columns:1fr;padding:16px}
  .split-aside{position:static;padding:8px;display:flex;overflow-x:auto;gap:4px;border-radius:10px}
  .split-aside .aside-title{display:none}
  .split-aside .menu-item{flex-shrink:0;padding:8px 12px;font-size:12px;margin-bottom:0;white-space:nowrap}
  .split-aside .menu-item.danger{margin-top:0;border-top:0;padding-top:8px}
  .mobile-tab-bar{display:grid}
  body.has-mobile-tab{padding-bottom:60px}
}

/* 색상 유틸 */
.txt-accent{color:var(--accent)}
.txt-accent-2{color:var(--accent-2)}
.txt-mute{color:var(--ink-3)}
.bg-accent-soft{background:var(--accent-soft)}

/* 차트 SVG 컨테이너 */
.chart-wrap{height:260px;position:relative}
.chart-wrap svg{width:100%;height:100%;display:block}
@media (max-width:768px){.chart-wrap{height:200px}}
