  :root{
    /* === 기본 테마: 석탄 앰버 (Coal Amber). 설정에서 data-theme로 교체 === */
    --bg:#16181c; --panel:#1f232a; --panel2:#282d35; --line:#3a414b;
    --ink:#eef0f2; --ink-dim:#9aa3ad;
    --gold:#e0a13a; --gold-dim:#9c6e22; --glow:rgba(255,170,90,0.7);
    --g-vip:#e0a13a; --g-r:#c06a3c; --g-s:#4e8c87; --g-a:#5a6b8a; --g-none:#6b6b66;
    --radius:10px;
    font-family: "Pretendard","Apple SD Gothic Neo","Malgun Gothic",sans-serif;
  }
  /* 미드나잇 스테이지 */
  :root[data-theme="midnight"]{
    --bg:#121620; --panel:#1a2030; --panel2:#232c40; --line:#36405a;
    --ink:#eef1f6; --ink-dim:#98a2b6;
    --gold:#e8b86a; --gold-dim:#a07d3a; --glow:rgba(255,190,120,0.7);
    --g-vip:#e8b86a; --g-r:#c8607a; --g-s:#5f9ea0; --g-a:#6a7fb0; --g-none:#5a6270;
  }
  /* 노던 슬레이트 */
  :root[data-theme="steel"]{
    --bg:#1a1d20; --panel:#232830; --panel2:#2c333c; --line:#3e4650;
    --ink:#eceff2; --ink-dim:#9aa3ad;
    --gold:#7d9bbd; --gold-dim:#4f6b8a; --glow:rgba(150,180,220,0.7);
    --g-vip:#7d9bbd; --g-r:#c98a4a; --g-s:#5fa39a; --g-a:#8a7fa0; --g-none:#6b7480;
  }
  /* 세이지 틸 */
  :root[data-theme="sage"]{
    --bg:#181b1a; --panel:#212624; --panel2:#2a302d; --line:#3c4541;
    --ink:#edf0ee; --ink-dim:#9aa39e;
    --gold:#6fb09c; --gold-dim:#3f7a68; --glow:rgba(130,200,175,0.7);
    --g-vip:#6fb09c; --g-r:#c98a4a; --g-s:#6f8fb0; --g-a:#8a7fa0; --g-none:#6b746e;
  }
  /* 튀튀 로즈 */
  :root[data-theme="rose"]{
    --bg:#17151a; --panel:#211d24; --panel2:#2a242d; --line:#3e3543;
    --ink:#f1ecef; --ink-dim:#aaa1a8;
    --gold:#d98aa0; --gold-dim:#9c4f63; --glow:rgba(255,160,185,0.7);
    --g-vip:#d98aa0; --g-r:#c98a4a; --g-s:#5f9ea0; --g-a:#6a7fb0; --g-none:#6e6670;
  }
  /* 솔리다리티 레드 */
  :root[data-theme="red"]{
    --bg:#15171b; --panel:#1d2026; --panel2:#262a31; --line:#3a414b;
    --ink:#f1ede7; --ink-dim:#a7aeb8;
    --gold:#d83a30; --gold-dim:#9c2a23; --glow:rgba(255,140,80,0.7);
    --g-vip:#d83a30; --g-r:#cf913a; --g-s:#4e8c87; --g-a:#5a6b8a; --g-none:#6b6b66;
  }
  *{box-sizing:border-box;}
  body{
    margin:0;
    background:var(--bg);
    color:var(--ink);
    min-height:100vh;
    overflow-x:hidden;
  }
  .table-scroll-wrap{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    border-radius:var(--radius);
  }
  .table-scroll-wrap table{
    min-width:600px;
  }

  /* ===== 탭 콘텐츠 영역만 자체 스크롤, 헤더는 항상 상단 고정 (모바일/데스크탑 공통) ===== */
  html, body{
    /* --app-height = JS가 측정한 '실제로 보이는 높이'(모바일 툴바 제외). 미설정 시 100% 폴백. */
    height: var(--app-height, 100%);
    overflow:hidden;
  }
  #appHeaderSticky{
    position:sticky;
    top:0;
    z-index:50;
    background:var(--bg);
  }
  main{
    height: calc(var(--app-height, 100vh) - var(--header-h, 100px));
    overflow:hidden;
    box-sizing:border-box;
  }
  .page{
    height:100%;
    overflow-y:auto;
  }
  #page-schedule.active{
    display:flex;
    flex-direction:column;
    overflow:hidden; /* .page의 overflow-y:auto를 덮어써서 바깥은 스크롤하지 않음 */
  }
  #page-schedule .toolbar,
  #page-schedule .floor-toggle-bar,
  #page-schedule #scheduleHiddenBar{
    flex-shrink:0;
  }
  #page-schedule .table-scroll-wrap{
    flex:1;
    overflow:auto; /* 세로/가로 모두 이 박스 안에서, 가로 스크롤바가 항상 박스 하단에 보임 */
  }
  /* 끝까지 스크롤하면 마지막 콘텐츠 아래에 여백이 나타나도록 실제 스페이서 블록을 둔다.
     (스크롤 컨테이너의 padding-bottom은 자식이 <table>이거나 WebKit에서 무시되므로 ::after 사용)
     각 탭에서 실제로 스크롤되는 컨테이너에 동일 적용. */
  #page-schedule .table-scroll-wrap::after,
  .stats-scroll-area::after,
  #page-seatmap::after,
  #page-settings::after{
    content:"";
    display:block;
    height: calc(60px + env(safe-area-inset-bottom, 0px));
  }
  #page-schedule .table-scroll-wrap table{
    overflow:visible; /* table의 overflow:hidden이 sticky 헤더의 스크롤 컨테이너 연결을 깨뜨리는 문제 수정 */
  }
  #page-schedule .table-scroll-wrap thead th{
    position:sticky;
    top:0;
    z-index:5;
  }
  header{
    padding:18px 20px 12px;
    border-bottom:1px solid var(--line);
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    flex-wrap:wrap;
    gap:8px;
  }
  header .title-block{display:flex; align-items:baseline; gap:14px;}
  header h1{
    margin:0;
    font-size:22px;
    font-weight:700;
    letter-spacing:0.5px;
  }
  header h1 .curtain{color:var(--gold);}
  header .sub{font-size:12px; color:var(--ink-dim); letter-spacing:1px; text-transform:uppercase;}
  nav{
    display:flex;
    gap:4px;
    padding:0 20px;
    border-bottom:1px solid var(--line);
    background:var(--panel);
  }
  nav button{
    background:none;
    border:none;
    color:var(--ink-dim);
    font-size:14px;
    padding:10px 14px;
    cursor:pointer;
    border-bottom:2px solid transparent;
    font-weight:600;
    letter-spacing:0.3px;
  }
  nav button.active{
    color:var(--gold);
    border-bottom-color:var(--gold);
  }
  main{
    /* 하단 여백은 각 스크롤 컨테이너 내부에서 처리(스크롤 끝에만 동적으로 보이도록) */
    padding:18px 20px 0;
    max-width:1180px;
    margin:0 auto;
  }
  .page{display:none;}
  .page.active{display:block;}
  .memo-popover{
    position:absolute;
    top:100%;
    left:0;
    z-index:20;
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:8px;
    padding:8px;
    width:max-content;
    min-width:240px;
    box-shadow:0 6px 16px rgba(0,0,0,0.35);
  }
  /* 메모: 여러 줄 입력 가능한 textarea (조금 크게) */
  .memo-popover-input{
    width:100%; box-sizing:border-box; margin-bottom:6px;
    min-height:64px; resize:vertical;
    background:var(--panel); border:1px solid var(--line); color:var(--ink);
    border-radius:6px; padding:6px 8px;
    font-family:inherit; font-size:13px; line-height:1.4;
  }
  .memo-popover-actions{display:flex; gap:6px;}
  .memo-popover-actions button{font-size:11px; padding:5px 8px; flex:1;}

  /* 메모·티켓 팝오버 맨 위 날짜 라벨 */
  .popover-date{
    font-size:11px; font-weight:700; color:var(--gold);
    margin-bottom:6px; letter-spacing:0.3px; white-space:nowrap;
  }

  .role-dropdown{
    position:absolute;
    top:100%;
    left:0;
    z-index:20;
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:8px;
    padding:10px;
    width:max-content;
    box-shadow:0 6px 16px rgba(0,0,0,0.35);
    text-transform:none;
    font-weight:400;
  }
  .role-dropdown.align-right{
    left:auto;
    right:0;
  }
  .role-dropdown-title{font-size:11px; color:var(--ink-dim); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.4px;}
  .role-dropdown-item{display:flex; align-items:center; gap:6px; font-size:12px; padding:4px 0; cursor:pointer; white-space:nowrap;}
  .role-dropdown-actions{display:flex; gap:6px; margin-top:8px; border-top:1px solid var(--line); padding-top:8px;}
  .role-dropdown-actions button{font-size:11px; padding:5px 8px; width:100%;}
  .hidden-roles-bar{
    display:flex;
    align-items:center;
    gap:8px;
    font-size:12px;
    color:var(--ink-dim);
    margin-bottom:10px;
  }

  .toolbar{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:10px;
    flex-wrap:wrap;
    gap:8px;
  }
  .toolbar .show-name{font-size:13px; color:var(--ink-dim);}
  .toolbar .show-name b{color:var(--ink); font-weight:700;}
  select, input[type=text], input[type=number]{
    background:var(--panel2);
    border:1px solid var(--line);
    color:var(--ink);
    border-radius:6px;
    padding:6px 8px;
    font-size:13px;
    font-family:inherit; /* 폼 입력도 본문과 같은 글꼴(Pretendard) 사용 — 기본 Arial 방지 */
  }
  table{
    width:100%;
    border-collapse:collapse;
    background:var(--panel);
    border-radius:var(--radius);
    overflow:hidden;
    font-size:13px;
  }
  thead th{
    background:var(--panel2);
    color:var(--gold);
    text-align:center;
    padding:8px 6px;
    font-weight:700;
    font-size:12px;
    letter-spacing:0.4px;
    text-transform:uppercase;
    border-bottom:1px solid var(--line);
    white-space:nowrap;
  }
  /* 헤더 버튼(드롭다운 포함)도 가운데 정렬 */
  .role-head-btn, .match-head-btn, .col-head-btn{ width:100%; justify-content:center; }
  tbody td{
    padding:4px 6px;
    border-bottom:1px solid var(--line);
    vertical-align:middle;
    line-height:1.5; /* 모든 셀 같은 줄 높이 → 날짜·시간 등 세로 정렬 일치 */
  }
  /* 스케줄 표: 마지막 행 아래 구분선 제거 (스크롤 끝 여백과 겹쳐 보이지 않도록) */
  #scheduleTable tbody tr:last-child > td{ border-bottom:none; }
  tbody tr:hover{background:rgba(255,255,255,0.02);}
  tbody tr.past > td:not(.memo-cell):not(.ticket-cell):not(.float-cell){opacity:0.55;}
  tbody tr.past > td.float-cell{color:var(--ink-dim);} /* 흐림 대신 색만 (sticky 배경 비침 방지) */
  /* 현재 관극 중/바로 다음 공연 하이라이트 */
  tbody tr.current-perf > td{ background:color-mix(in srgb, var(--gold) 16%, transparent); }
  tbody tr.current-perf .date-cell{ box-shadow:inset 3px 0 0 var(--gold); } /* 플로팅 켜져도 보이도록 date-cell에 직접 */

  /* === 방법1: 날짜 플로팅 오버레이 (컬럼 추가 없이 가로 스크롤 시 왼쪽에 겹쳐 표시) ===
     float-cell은 0폭 sticky 셀이고, 그 안의 .float-label을 절대배치해 오버레이로 띄운다. */
  #scheduleTable .float-cell{
    width:0; padding:0; position:sticky; left:0; z-index:4; background:transparent;
  }
  #scheduleTable thead th.float-cell{ z-index:6; }
  .float-label{
    display:none; position:absolute; top:0; bottom:0; left:0;
    align-items:center; padding:0 9px; white-space:nowrap;
    background:var(--panel); color:inherit;
    font-weight:700; font-size:12px;
    border-right:1px solid var(--line);
    box-shadow:3px 0 8px rgba(0,0,0,0.4);
  }
  /* 오버레이의 티켓 아이콘: 티켓 있으면 진하게, 없으면 옅게 (크기는 티켓 열 .tk-icon과 동일 12px) */
  .float-tk{ margin-left:5px; font-size:12px; line-height:1; opacity:0.25; }
  .float-tk.on{ opacity:1; }
  /* 가로로 '년도 폭'만큼 스크롤되면 오버레이 표시 */
  .table-scroll-wrap.h-scrolled .float-label{ display:flex; }

  /* === 방법2: 행 하이라이트(현재공연 골드와 확실히 구분되는 진한 파랑) === */
  #scheduleTable tbody tr.row-highlight > td{ background:rgba(74,128,210,0.45); }
  #scheduleTable tbody tr.row-highlight .date-cell{ box-shadow:inset 4px 0 0 #5b9bff; }
  #scheduleTable tbody tr.row-highlight .float-label{ background:color-mix(in srgb, #4a80d2 55%, var(--panel)); }
  /* 하이라이트 모드: 날짜 셀/오버레이 라벨 클릭 가능 */
  #scheduleTable.hl-mode .date-cell,
  #scheduleTable.hl-mode .float-label{ cursor:pointer; }

  /* 스케줄 보기 옵션 (Settings) */
  .opt-row{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink); margin-bottom:10px; cursor:pointer; }
  .opt-row b{ color:var(--ink); font-weight:700; }
  .opt-row input{ cursor:pointer; flex-shrink:0; }
  .opt-indent{ margin-left:24px; }
  .date-cell{white-space:nowrap; font-weight:700;}
  .time-cell{color:var(--ink-dim); white-space:nowrap;}
  .seat-cell{width:106px; min-width:106px; max-width:106px;}
  .seat-input, .note-input{
    width:100%;
    padding:2px 6px; /* 상하 패딩 축소로 행 높이↓ */
  }
  /* 양식이 틀리거나 등록되지 않은 좌석: 입력한 글자 아래에만 빨간 물결표 */
  .seat-input.invalid-seat{
    text-decoration:underline;
    text-decoration-style:wavy;
    text-decoration-color:#e0594a;
    text-decoration-skip-ink:none;
    text-underline-offset:2px;
  }
  /* 무효 좌석: 눈 버튼은 클릭 불가 + 빨간 느낌표 오버레이 */
  .seat-eye-btn{position:relative;}
  .seat-eye-btn.invalid{pointer-events:none; cursor:default;}
  .seat-eye-warn{
    position:absolute; top:-4px; right:-4px;
    min-width:11px; height:11px; padding:0 1px;
    display:flex; align-items:center; justify-content:center;
    background:#fff; color:#e0594a;
    font-size:9px; font-weight:900; line-height:1;
    border:1px solid #e0594a; border-radius:50%;
    pointer-events:none;
  }
  /* 대결(match) 결과 열 */
  .match-head{white-space:nowrap;}
  /* 필터 적용 개수 배지: 삼각형(▾)을 기준으로 배치 → 이름 길이와 무관하게 이름 끝에 살짝 겹침 */
  .col-arrow{ position:relative; font-size:9px; }
  .col-filter-badge{
    position:absolute; top:-9px; right:-3px;
    min-width:13.5px; height:13.5px; padding:0 3px;
    display:flex; align-items:center; justify-content:center;
    background:var(--gold); color:#1a1a1a;
    font-size:8px; font-weight:800; line-height:1; border-radius:7px;
    text-transform:none; letter-spacing:0;
    opacity:0.8; /* 투명도 — 가려진 이름이 비치도록 */
  }
  #page-schedule .floor-toggle-bar{ flex-wrap:wrap; }
  .match-cell{white-space:nowrap; font-weight:700; font-size:13px; text-align:center;}
  /* 승: 배역별 색은 인라인 style로 지정 */
  .match-cell.draw{color:color-mix(in srgb, var(--ink) 50%, transparent); font-weight:600;} /* 무승부: 조금 연하게 */
  .match-cell.none{color:var(--ink-dim); font-weight:400; font-style:italic;} /* 미정/모름: 기울임 */
  .cast-cell{min-width:56px; text-align:center;} /* 헤더(가운데)와 본문 배우 정렬 일치 */
  .cast-cell .name{display:block; line-height:1.5; white-space:nowrap;}
  .cast-cell .name.alt{color:#d8c08a;}
  .cast-cell .name.zero-weight{text-decoration:line-through; opacity:0.55;}
  .cast-cell .name.swing{color:#8aa3d8; font-style:italic;}
  .cast-cell .name.cover{color:#a3d8b8; font-style:italic;}
  .cast-cell .name.standby{color:#a3d8b8; font-style:italic;}
  .cast-cell .empty{color:var(--ink-dim); font-style:italic;}
  .role-head .role-name{display:block;}
  .role-head .role-sub{font-size:10px; color:var(--ink-dim); font-weight:400; text-transform:none;}
  .ticket-cell{width:96px; min-width:96px;}
  .tk-none{color:var(--ink-dim);}
  /* 티켓 트리거: 등급칩 + (아이콘 | 이름·할인율 배지) */
  .ticket-trigger{
    display:inline-flex; align-items:center; gap:5px;
    background:var(--panel2); border:1px solid var(--line);
    border-radius:7px; padding:3px 6px; cursor:pointer;
    color:var(--ink); line-height:1;
  }
  .ticket-trigger:hover{border-color:var(--gold-dim);}
  /* 세 요소가 서로 구분되도록: 등급=색칠한 사각칩 / 이름=굵은 글자 / 할인율=골드 알약 */
  .tk-grade{
    display:inline-flex; align-items:center; justify-content:center;
    width:16px; height:16px; border-radius:4px;
    font-size:10px; font-weight:800; color:#fff; flex-shrink:0;
  }
  .tk-name{font-size:12px; font-weight:700; color:var(--ink);}
  .tk-disc{
    font-size:10px; font-weight:700; color:var(--gold);
    background:color-mix(in srgb, var(--gold) 15%, transparent); border-radius:4px; padding:1px 4px;
  }
  .tk-icon{font-size:12px; line-height:1;}

  .ticket-popover{
    position:absolute; top:100%; left:0; z-index:25;
    background:var(--panel2); border:1px solid var(--line);
    border-radius:8px; padding:8px; width:max-content; min-width:200px;
    box-shadow:0 6px 16px rgba(0,0,0,0.35);
    /* 팝업 전체가 화면(가시영역)을 넘지 않도록: flex 컬럼 + 최대높이. 옵션 목록이 줄며 흡수. */
    display:flex; flex-direction:column;
    max-height: calc(var(--app-height, 100vh) - 180px);
  }
  .ticket-popover-title{
    font-size:11px; color:var(--ink-dim); margin-bottom:6px;
    text-transform:uppercase; letter-spacing:0.4px;
  }
  /* 옵션 목록: 내용만큼 늘되 화면(가시영역)의 1/3을 넘지 않음(넘으면 스크롤). 일반 화면에선 5개 이상 보임. */
  .ticket-options{display:flex; flex-direction:column; gap:1px; flex:1 1 auto; min-height:0; max-height:calc(var(--app-height, 100vh) / 3); overflow-y:auto;}
  .ticket-option{
    display:flex; align-items:center; gap:8px;
    padding:3px 6px; border-radius:6px; cursor:pointer; font-size:12px;
  }
  .ticket-option:hover{background:rgba(255,255,255,0.04);}
  .ticket-option input{margin:0; cursor:pointer;}
  .ticket-option .to-name{font-weight:700; color:var(--ink);}
  .ticket-option .to-disc{font-size:11px; color:var(--gold);}
  .ticket-option .to-price{margin-left:auto; font-variant-numeric:tabular-nums; color:var(--ink-dim); white-space:nowrap;}
  /* 직접 입력(임의 할인권) 행 */
  .ticket-option.ticket-custom{ border-top:1px solid var(--line); margin-top:3px; padding-top:5px; }
  .ticket-option .tk-custom-name{ flex:none; width:110px; padding:2px 6px; font-size:12px; } /* 한글 8자 폭 */
  .ticket-option .tk-custom-rate{ width:50px; padding:2px 6px; font-size:12px; margin-left:auto; }
  .ticket-option .tk-pct{ color:var(--ink-dim); font-size:12px; }
  /* 수수료 + 기타비용을 한 줄에 */
  .ticket-fee-row{
    display:flex; align-items:center; justify-content:space-between; gap:10px;
    margin-top:6px; padding-top:6px;
    border-top:1px solid var(--line); font-size:12px; color:var(--ink-dim);
  }
  .tk-fee-label{display:inline-flex; align-items:center; gap:6px; cursor:pointer;}
  .ticket-fee-row input[type=checkbox]{margin:0; cursor:pointer;}
  .tk-extra-group{display:inline-flex; align-items:center; gap:4px; white-space:nowrap;}
  .tk-extra-group input{width:72px; padding:4px 6px; font-size:12px;}
  .ticket-popover-actions{display:flex; gap:6px; margin-top:8px;}
  .ticket-popover-actions button{font-size:11px; padding:5px 8px; flex:1;}
  .price-cell{
    white-space:nowrap; text-align:right;
    font-variant-numeric:tabular-nums;
    color:var(--gold); font-weight:600;
  }
  .price-cell .empty{color:var(--ink-dim); font-weight:400;}

  .stat-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
    gap:8px;
    margin-bottom:10px;
  }
  .stat-card{
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:5px 10px 2px;
  }
  .stat-card .label{font-size:11px; color:var(--ink-dim); text-transform:uppercase; letter-spacing:0.5px;}
  .stat-card .value{font-size:19px; font-weight:700; color:var(--gold); margin-top:1px;}

  /* 총 티켓 금액 (지금까지/앞으로/총액) — 모바일에서도 3카드 한 줄 유지 */
  .ticket-totals{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:8px;
    margin-bottom:14px;
  }
  .tt-card{
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:7px 9px;
  }
  .tt-card.total{ border-color:var(--gold-dim); }
  .tt-card .label{font-size:10px; color:var(--ink-dim); text-transform:uppercase; letter-spacing:0.3px; white-space:nowrap;}
  .tt-card .value{font-size:14px; font-weight:700; color:var(--gold); margin-top:2px; font-variant-numeric:tabular-nums; white-space:nowrap;}

  .stats-sticky-bar{
    position:sticky;
    top:0;
    z-index:10;
    background:var(--bg);
    padding:8px 0 10px;
    border-bottom:1px solid var(--line);
    margin-bottom:10px;
  }
  .stats-scroll-area{
    flex:1;
    overflow-y:auto;
    padding:0 2px 0 0; /* 우측에 스크롤바 공간 확보 (하단 여백은 ::after 스페이서가 담당) */
  }
  #page-stats.active{
    display:flex;
    flex-direction:column;
    overflow:hidden;
  }
  .stat-section{margin-bottom:22px;}
  /* 접을 수 있는 섹션 제목 */
  .collapse-h2{cursor:pointer; user-select:none; display:flex; align-items:center; gap:8px;}
  .collapse-arrow{font-size:11px; color:var(--ink-dim);}
  /* 만들기 버튼: 우측 정렬 + 강조(골드) */
  .combo-create-actions{display:flex; justify-content:flex-end; margin-top:12px;}
  .primary-btn{
    border:1px solid var(--gold); color:#1a1a1a; background:var(--gold);
    font-weight:700; padding:8px 18px; border-radius:8px; cursor:pointer;
  }
  .primary-btn:hover{ filter:brightness(1.06); }
  .stat-del-btn{background:none;border:1px solid var(--line);border-radius:4px;cursor:pointer;color:var(--ink-dim);font-size:11px;padding:1px 6px;line-height:1.4;flex-shrink:0;}
  .stat-del-btn:hover{border-color:var(--ink-dim);color:var(--ink);}
  .stat-section h2{
    font-size:14px;
    color:var(--ink-dim);
    text-transform:uppercase;
    letter-spacing:1px;
    border-bottom:1px solid var(--line);
    padding-bottom:6px;
    margin-bottom:10px;
  }
  .bar-row{display:flex; align-items:center; gap:10px; margin-bottom:8px;}
  .bar-row .bar-label{width:130px; font-size:13px; flex-shrink:0; text-align:right;}
  .bar-row .bar-label small{display:block; color:var(--ink-dim); font-size:10px;}
  .bar-track{flex:1; background:var(--panel2); border-radius:4px; height:18px; position:relative;}
  .bar-fill{height:100%; border-radius:4px; background:var(--gold-dim);}
  .bar-count{width:28px; text-align:left; font-size:12px; color:var(--ink-dim);}

  .combo-picker{display:flex; flex-direction:column; gap:14px; margin-bottom:16px;}
  .combo-role-name{font-size:11px; color:var(--ink-dim); margin-bottom:6px; text-transform:uppercase; letter-spacing:0.5px;}
  .combo-actor-chips{display:flex; gap:8px; flex-wrap:wrap;}
  .combo-chip{
    position:relative;
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:20px;
    padding:6px 14px;
    font-size:13px;
    cursor:pointer;
    user-select:none;
  }
  .combo-chip.selected{
    border-color:var(--gold);
    color:var(--gold);
    background:color-mix(in srgb, var(--gold) 12%, transparent);
  }
  .combo-chip .chip-badge{
    position:absolute;
    top:-7px;
    right:-7px;
    width:16px;
    height:16px;
    border-radius:50%;
    background:var(--gold);
    color:#3a2c0c;
    font-size:9px;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
  }

  .combo-result-block{margin-bottom:14px;}
  .combo-result-title{font-size:13px; font-weight:700; color:var(--gold); margin-bottom:8px;}

  .role-stat-table{width:100%; border-collapse:collapse; background:var(--panel); border:1px solid var(--line); border-radius:8px; overflow:hidden; font-size:13px;}
  .role-stat-table th, .role-stat-table td{vertical-align:middle;}
  .role-stat-table thead th{background:var(--panel2); color:var(--gold); text-align:center; padding:8px 10px; font-size:11px; text-transform:uppercase; letter-spacing:0.4px; border-bottom:1px solid var(--line);}
  .role-stat-table thead th:first-child{text-align:left;}
  .role-stat-table tbody td{padding:8px 10px; text-align:center; border-bottom:1px solid var(--line);}
  .role-stat-table tbody td:first-child{text-align:center;}
  .role-stat-table tbody tr:last-child td{border-bottom:none;}

  .grade-pricing{display:flex; flex-wrap:wrap; gap:10px;}
  .grade-chip{
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:8px;
    padding:10px 14px;
    font-size:12px;
    min-width:130px;
  }
  .grade-chip .gname{font-weight:700; margin-bottom:4px;}
  .grade-chip .gprice{color:var(--ink-dim);}

  .seat-overlay{
    position:fixed;
    top:0; left:0; right:0; bottom:0;
    background:rgba(0,0,0,0.72);
    display:flex;
    align-items:center;
    justify-content:center;
    z-index:200;
    padding:20px;
  }
  .seat-overlay-content{
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:12px;
    padding:16px;
    max-width:92vw;
    max-height:88vh;
    overflow:auto;
  }
  .seat.highlighted{
    outline:3px solid #fff;
    outline-offset:1px;
    box-shadow:0 0 12px 3px var(--glow);
    transform:scale(1.25);
    z-index:5;
  }

  /* 좌석맵과 좌석 정보를 세로(다른 줄)로 쌓고, 둘 다 전체 너비로 */
  .seatmap-wrap{display:flex; flex-direction:column; gap:16px;}
  .seatmap-grid{
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:14px;
    width:100%;
  }
  .floor-toggle-bar{display:flex; align-items:center; gap:8px; margin-bottom:10px;}
  /* 숨긴 컬럼 바가 floor-toggle-bar 안에 들어가므로 자체 하단 여백 제거 */
  #scheduleHiddenBar .hidden-roles-bar{margin-bottom:0;}
  .floor-toggle-btn{
    background:var(--panel2);
    border:1px solid var(--line);
    color:var(--ink-dim);
    border-radius:16px;
    padding:4px 10px;
    font-size:12px;
    font-weight:600;
    cursor:pointer;
  }
  .floor-toggle-btn.active{
    background:color-mix(in srgb, var(--gold) 15%, transparent);
    border-color:var(--gold);
    color:var(--gold);
  }
  .floor-toggle-btn:disabled{ opacity:0.4; cursor:default; }

  .svg-viewport{
    position:relative;
    width:100%;
    /* 가시 높이(--app-height)에 맞춰 동적으로: 작을수록 맵을 줄여 아래 좌석 정보가 일부라도 보이게.
       예약분 240px = 비-맵 콘텐츠(층바·컨트롤바·범례·간격 ≈168) + 좌석 정보 최소 노출(≈70). */
    height: clamp(130px, calc(var(--app-height, 100vh) - var(--header-h, 100px) - 240px), 480px);
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:8px;
    overflow:hidden;
    touch-action:none;
  }
  #mainSeatSvg{display:block; cursor:grab;}
  #mainSeatSvg.dragging{cursor:grabbing;}
  .svg-seat rect{transition:opacity 0.15s;}
  .svg-seat:hover rect:first-of-type{filter:brightness(1.3);}
  .seatmap-controls-bar{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:6px;
    margin-bottom:8px;
  }
  .seatmap-controls-bar button{
    width:30px;
    height:28px;
    padding:0;
    font-size:14px;
    line-height:1;
    background:var(--panel2);
    color:var(--ink);
    border:1px solid var(--line);
    border-radius:6px;
  }
  .seatmap-controls-bar button#zoomResetBtn,
  .seatmap-controls-bar button#minimapToggleBtn{
    width:auto;
    font-size:11px;
    padding:0 10px;
  }
  .seatmap-controls-bar button#minimapToggleBtn.active{
    border-color:var(--gold);
    color:var(--gold);
    background:color-mix(in srgb, var(--gold) 15%, transparent);
  }
  .minimap-wrap{
    position:absolute;
    bottom:8px;
    right:8px;
    width:140px;
    height:88px;
    background:rgba(0,0,0,0.55);
    border:1px solid var(--line);
    border-radius:6px;
    overflow:hidden;
    z-index:10;
  }
  .minimap-wrap.hidden{display:none;}
  #minimapSvg{display:block; cursor:pointer; touch-action:none;}
  #minimapIndicator{ fill:var(--gold); fill-opacity:0.18; stroke:var(--gold); }

  /* 컬러 테마 선택 */
  .theme-picker{ display:flex; flex-wrap:wrap; gap:8px; }
  .theme-btn{
    display:inline-flex; align-items:center; gap:7px;
    background:var(--panel2); border:1px solid var(--line); color:var(--ink-dim);
    border-radius:16px; padding:6px 12px; font-size:12px; font-weight:600; cursor:pointer;
  }
  .theme-btn i{ width:13px; height:13px; border-radius:50%; display:inline-block; }
  .theme-btn.active{ border-color:var(--gold); color:var(--ink); background:color-mix(in srgb, var(--gold) 14%, transparent); }

  .seatmap-right-group{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
  #seatFilterBtn{ position:relative; }
  .filter-count{
    /* 배지를 버튼 오른쪽 '아래'로: 위로 두면 옵션 바가 nav 밑으로 스크롤될 때 상단에서 잘림 */
    position:absolute; bottom:-7px; right:-7px;
    min-width:16px; height:16px; padding:0 4px;
    display:flex; align-items:center; justify-content:center;
    background:var(--gold); color:#fff;
    font-size:10px; font-weight:800; line-height:1; border-radius:8px;
    z-index:60; /* 헤더(#appHeaderSticky z-index:50)보다 위로 — 겹칠 때 위에 표시 */
  }
  /* 배역 필터 모달 */
  #seatFilterBody{ max-height:55vh; overflow:auto; }
  .filter-role{ border-top:1px solid var(--line); padding:8px 0; }
  .filter-role:first-child{ border-top:none; }
  .filter-role-title{ font-size:12px; font-weight:700; color:var(--gold); margin-bottom:6px; }
  .filter-actor-list{ display:flex; flex-wrap:wrap; gap:6px 14px; }
  .filter-actor{ display:flex; align-items:center; gap:5px; font-size:12px; color:var(--ink); cursor:pointer; white-space:nowrap; }
  .filter-actor input{ margin:0; cursor:pointer; }
  .seat-row{min-width:max-content;}
  .stage{
    text-align:center;
    background:var(--panel2);
    border:1px solid var(--line);
    border-radius:6px;
    padding:6px;
    margin-bottom:12px;
    font-size:11px;
    letter-spacing:2px;
    color:var(--ink-dim);
    text-transform:uppercase;
  }
  .floor-block{margin-bottom:12px;}
  .floor-block .fb-title{font-size:11px; color:var(--ink-dim); margin-bottom:6px; letter-spacing:0.5px;}
  .seat-row{display:flex; gap:4px; margin-bottom:4px; justify-content:center;}
  .seat{
    width:20px;
    height:20px;
    border-radius:4px;
    font-size:8px;
    display:flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    color:rgba(0,0,0,0.55);
    font-weight:700;
    border:1px solid rgba(0,0,0,0.2);
    position:relative;
    transition:opacity 0.15s, box-shadow 0.15s;
  }
  .seat-count{
    position:absolute;
    top:-6px;
    right:-6px;
    width:13px;
    height:13px;
    border-radius:50%;
    background:radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--gold) 30%, #fff), var(--gold));
    color:#fff;
    font-size:8px;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(0,0,0,0.35);
    line-height:1;
  }
  .seat.vip{background:var(--g-vip);}
  .seat.r{background:var(--g-r); color:#fff0e8;}
  .seat.s{background:var(--g-s); color:#eafff2;}
  .seat.a{background:var(--g-a); color:#eef2ff;}
  .seat.selected{outline:2px solid #fff; outline-offset:1px;}
  .legend{display:flex; gap:3px 12px; margin-top:6px; flex-wrap:wrap; align-items:center; font-size:11px; color:var(--ink-dim);}
  .legend-break{ flex-basis:100%; height:0; }
  /* 관극 횟수 범례: 숫자를 가운데 적은 동그라미. 등급 사각형의 1.2배(약 14px), 간격은 좁게. */
  .legend .cnt-scale{ display:inline-flex; align-items:center; gap:6px; }
  .legend .cnt-dot{
    display:inline-flex; align-items:center; justify-content:center;
    width:14px; height:14px; border-radius:50%;
    color:#fff; font-size:8px; font-weight:800; line-height:1;
    text-shadow:0 0 1px rgba(0,0,0,0.85); border:1px solid rgba(0,0,0,0.35);
  }
  .legend span{display:inline-flex; align-items:center; gap:6px;}
  .legend i{width:12px; height:12px; border-radius:3px; display:inline-block;}

  .seat-detail{
    width:100%;
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:12px;
  }
  .seat-perf-table{width:100%; border-collapse:collapse; font-size:11px;}
  .seat-perf-table th{background:var(--panel2); color:var(--gold); padding:6px 8px; text-align:center; border-bottom:1px solid var(--line); white-space:nowrap; vertical-align:middle;}
  .seat-perf-table td{padding:6px 8px; border-bottom:1px solid var(--line); white-space:nowrap; vertical-align:middle;}
  .seat-perf-table tr:last-child td{border-bottom:none;}
  .seat-detail h3{margin:0 0 10px; font-size:14px; color:var(--gold);}
  .seat-detail .row{display:flex; justify-content:space-between; font-size:13px; padding:5px 0; border-bottom:1px solid var(--line);}
  .seat-detail .row span:first-child{color:var(--ink-dim);}
  .seat-detail .empty-msg{color:var(--ink-dim); font-size:13px;}

  /* ===========================================================
     모바일(≤600px) 간격 축소 — 좁은 화면에서 가용 폭 확보
     (600px = 스케줄 표 min-width와 동일: 이 아래에서 가로 스크롤 시작)
     =========================================================== */
  @media (max-width:600px){
    /* 화면 좌우 마진 축소 */
    main{ padding:14px 10px 0; }
    header{ padding:14px 12px 10px; }
    nav{ padding:0 8px; gap:2px; }
    /* 탭 버튼 패딩 축소 (4개 탭이 한 줄에 들어가도록) */
    nav button{ padding:9px 8px; font-size:13px; letter-spacing:0; }
    /* 스케줄 셀 내부 좌우 패딩 축소 */
    #scheduleTable thead th{ padding:8px 5px; }
    #scheduleTable tbody td{ padding:4px 5px; }
  }