
:root {
  --bg-top: #edf6ff;
  --bg-mid: #f6fbff;
  --bg-shape-1: rgba(85, 184, 238, 0.18);
  --bg-shape-2: rgba(255, 180, 120, 0.18);
  --bg-shape-3: rgba(181, 124, 255, 0.12);
  --primary: #55b8ee;
  --primary-strong: #2196d7;
  --primary-soft: #eaf8ff;
  --orange: #ff9f4a;
  --orange-strong: #f2871f;
  --text: #1d2b3a;
  --muted: #66788a;
  --line: #dde6ef;
  --soft-line: #edf3f8;
  --surface: #ffffff;
  --surface-soft: #f7fbff;
  --shadow: 0 20px 25px -5px rgba(24,24,24,0.10), 0 10px 10px -5px rgba(24,24,24,0.04);
  --radius-sm: 6px;
}
* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; font-family: "Noto Sans JP", system-ui, sans-serif; color: var(--text); background:
  radial-gradient(circle at 12% 12%, var(--bg-shape-1), transparent 30%),
  radial-gradient(circle at 84% 14%, var(--bg-shape-2), transparent 28%),
  radial-gradient(circle at 72% 72%, var(--bg-shape-3), transparent 22%),
  linear-gradient(180deg, var(--bg-top), var(--bg-mid)); }
body.modal-open { overflow: hidden; }
button, input, textarea, select { font: inherit; }
button { cursor: pointer; }
#app { min-height: 100vh; }
.app-shell { display: flex; min-height: 100vh; }
.sidebar { width: 252px; background: rgba(255,255,255,0.86); border-right: 1px solid rgba(221,230,239,0.8); backdrop-filter: blur(10px); padding: 28px 18px; }
.icon-rail { width: 92px; background: rgba(255,255,255,0.82); border-right: 1px solid rgba(221,230,239,0.8); backdrop-filter: blur(10px); padding: 22px 18px; display: flex; flex-direction: column; align-items: center; gap: 18px; }
.brand-box { display: flex; align-items: center; gap: 12px; padding: 12px 10px 20px; }
.brand-icon { width: 44px; height: 44px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, var(--primary), #78d3ff); color: #fff; font-weight: 800; box-shadow: 0 14px 24px rgba(85,184,238,0.28); }
.brand-title { font-size: 16px; font-weight: 800; }
.brand-sub { font-size: 12px; color: var(--muted); }
.nav-list { display: grid; gap: 8px; }
.nav-item, .rail-icon { border: 0; background: transparent; color: var(--muted); border-radius: 14px; display: flex; align-items: center; gap: 10px; padding: 14px 14px; text-align: left; }
.nav-item.active, .rail-icon.active { background: linear-gradient(180deg, rgba(85,184,238,0.14), rgba(85,184,238,0.22)); color: var(--primary-strong); font-weight: 800; }
.nav-dot { width: 10px; height: 10px; border-radius: 999px; background: currentColor; opacity: 0.7; }
.workspace { flex: 1; padding: 24px 28px 110px; }
.main-card { background: rgba(255,255,255,0.94); border: 1px solid rgba(221,230,239,0.92); border-radius: 28px; box-shadow: var(--shadow); overflow: hidden; }
.utility-bar, .editor-header { padding: 30px 34px 18px; display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; }
.utility-left { max-width: 820px; }
.eyebrow { color: var(--primary-strong); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 800; }
.page-title, .editor-title { margin: 6px 0 8px; font-size: 30px; line-height: 1.15; }
.page-copy, .panel-copy, .section-subcopy, .modal-copy, .footer-copy { color: var(--muted); font-size: 13px; line-height: 1.7; }
.utility-actions, .footer-actions, .helper-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.user-chip, .mini-pill, .save-state { border-radius: 999px; background: var(--surface-soft); color: var(--muted); border: 1px solid var(--line); padding: 7px 12px; font-size: 12px; }
.save-state.dirty { background: #fff4ea; color: #b26b12; border-color: #ffd4a6; }
.list-page { padding: 0 28px 26px; }
.local-tabs { display: flex; gap: 10px; flex-wrap: wrap; padding: 0 6px 18px; }
.local-tab { display: inline-flex; padding: 12px 16px; border-radius: 999px; background: #fff; border: 1px solid var(--line); color: var(--muted); font-size: 14px; }
.local-tab.active { background: var(--primary-soft); color: var(--primary-strong); border-color: rgba(85,184,238,0.3); font-weight: 800; }
.filter-band { background: linear-gradient(180deg, #fafdff, #f6fbff); border: 1px solid var(--soft-line); border-radius: 22px; padding: 18px; display: grid; gap: 18px; }
.summary-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.metric { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 16px; }
.metric-label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.metric-value { font-size: 28px; font-weight: 800; color: var(--text); }
.filters { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 14px; }
.field, .field-stack { display: grid; gap: 8px; }
.field.full, .field-stack.full, .full { grid-column: 1 / -1; }
label { font-size: 13px; font-weight: 700; color: var(--text); }
.input, .select, .textarea, .readonly-trigger { width: 100%; min-height: 44px; border-radius: var(--radius-sm); border: 2px solid #e6e6e6; background: #fff; color: var(--text); padding: 10px 12px; transition: border-color .15s ease, box-shadow .15s ease; }
.input:focus, .select:focus, .textarea:focus { outline: 0; border-color: rgba(85,184,238,0.55); box-shadow: 0 0 0 4px rgba(85,184,238,0.12); }
.textarea { min-height: 132px; resize: vertical; }
.list-card, .section-card, .placeholder-card { background: #fff; border: 1px solid var(--line); border-radius: 22px; }
.list-card { margin-top: 18px; padding: 20px; }
.section-card { padding: 20px; }
.placeholder-card { padding: 18px; color: var(--muted); background: linear-gradient(180deg, #fff, #fbfdff); }
.section-head, .panel-top { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; margin-bottom: 16px; }
.section-head h3, .panel-title { margin: 0 0 6px; font-size: 20px; }
.card-list { display: grid; gap: 16px; }
.job-item { display: grid; grid-template-columns: 212px 1fr 178px; gap: 18px; align-items: stretch; border: 1px solid var(--soft-line); border-radius: 20px; padding: 18px; background: linear-gradient(180deg, #fff, #fcfeff); }
.job-thumb { border-radius: 18px; overflow: hidden; min-height: 188px; background: linear-gradient(180deg, #8ad7ff, #55b8ee); color: #fff; display: flex; flex-direction: column; justify-content: space-between; padding: 16px; }
.job-thumb-top { font-size: 12px; letter-spacing: .06em; opacity: .95; }
.job-thumb-bottom { font-size: 22px; font-weight: 800; line-height: 1.35; }
.job-title-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 10px; }
.status-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 7px 10px; font-size: 12px; font-weight: 800; }
.status-pill.live { background: #e7fbef; color: #0c9b45; }
.status-pill.prep { background: #fff7e8; color: #cc8400; }
.status-pill.stop { background: #f1f4f8; color: #6e7a87; }
.job-name { margin: 0 0 4px; font-size: 22px; }
.job-sub { margin: 0 0 12px; color: var(--muted); font-size: 13px; }
.job-meta-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px; }
.meta-kv { background: #f9fcff; border: 1px solid var(--soft-line); border-radius: 14px; padding: 12px; }
.meta-k { font-size: 11px; color: var(--muted); margin-bottom: 6px; }
.meta-v { font-size: 14px; color: var(--text); font-weight: 600; line-height: 1.5; }
.job-actions { display: flex; flex-direction: column; justify-content: space-between; gap: 12px; align-items: stretch; }
.btn { min-height: 42px; border-radius: 12px; border: 1px solid transparent; padding: 0 16px; font-weight: 700; }
.btn.primary { background: linear-gradient(180deg, var(--primary), var(--primary-strong)); color: #fff; }
.btn.orange { background: linear-gradient(180deg, #ffb564, var(--orange-strong)); color: #fff; }
.btn.ghost { background: #fff; color: var(--text); border-color: var(--line); }
.btn.linkish { background: transparent; border-color: transparent; color: var(--primary-strong); padding: 0; min-height: auto; }
.btn.is-disabled, .readonly-trigger:disabled { background: #eef2f6; color: #8292a3; border-color: #dde6ef; cursor: not-allowed; }
.list-footer-bar, .fixed-footer { position: sticky; bottom: 0; margin-top: 20px; border-top: 1px solid rgba(221,230,239,0.9); background: rgba(255,255,255,0.92); backdrop-filter: blur(12px); padding: 16px 10px 6px; display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.fixed-footer { position: fixed; left: 120px; right: 28px; bottom: 16px; border: 1px solid rgba(221,230,239,0.92); border-radius: 20px; box-shadow: var(--shadow); padding: 18px 20px; z-index: 30; }
.tab-strip { display: flex; gap: 4px; padding: 0 28px 18px; border-bottom: 1px solid var(--soft-line); overflow: auto; }
.top-tab { border: 0; background: transparent; color: var(--muted); padding: 14px 18px; border-bottom: 3px solid transparent; font-weight: 800; white-space: nowrap; }
.top-tab[aria-current="page"] { color: var(--primary-strong); border-bottom-color: var(--primary); }
.editor-body { padding-bottom: 24px; }
.editor-title-row { display: flex; justify-content: space-between; gap: 16px; align-items: flex-start; }
.breadcrumb { font-size: 12px; color: var(--muted); margin-bottom: 12px; }
.editor-main { display: grid; grid-template-columns: 244px 1fr; gap: 20px; padding: 22px 24px 0; }
.toc { position: sticky; top: 24px; align-self: start; background: #f8fbff; border: 1px solid var(--soft-line); border-radius: 20px; padding: 14px; display: grid; gap: 8px; }
.toc-title, .minor-title { font-size: 12px; font-weight: 800; color: var(--primary-strong); letter-spacing: .06em; text-transform: uppercase; }
.toc-item { border: 0; background: transparent; text-align: left; border-radius: 12px; padding: 12px 10px; color: var(--muted); }
.toc-item.active { background: rgba(85,184,238,0.12); color: var(--primary-strong); font-weight: 800; }
.tab-panel { display: grid; gap: 18px; }
.form-grid.two { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 16px; }
.form-grid.three { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 16px; }
.field-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.help-button { width: 28px; height: 28px; border-radius: 999px; border: 0; background: linear-gradient(180deg, var(--primary), var(--primary-strong)); color: #fff; font-weight: 900; }
.inline-help { overflow: hidden; opacity: 0; max-height: 0; transition: all .2s ease; border-radius: 10px; background: transparent; color: var(--muted); font-size: 12px; line-height: 1.7; padding: 0 10px; }
.inline-help.open { opacity: 1; max-height: 120px; padding: 10px 12px; background: #eef9ff; border: 1px solid rgba(85,184,238,0.22); }
.notice-box, .publish-note { border-radius: 14px; background: #eef9ff; border: 1px solid rgba(85,184,238,0.2); padding: 14px; color: var(--muted); line-height: 1.8; }
.readonly-dropdown { position: relative; }
.readonly-trigger { display: flex; justify-content: space-between; align-items: center; text-align: left; background: #fff; }
.caret { color: var(--primary-strong); font-size: 12px; }
.dropdown-menu { position: absolute; z-index: 20; inset: calc(100% + 6px) 0 auto 0; background: #fff; border: 1px solid var(--line); border-radius: 14px; box-shadow: var(--shadow); overflow: hidden; }
.dropdown-option { width: 100%; border: 0; background: transparent; text-align: left; padding: 12px 14px; color: var(--text); }
.dropdown-option:hover, .dropdown-option.active { background: var(--primary-soft); color: var(--primary-strong); }
.repeater-row { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; }
.repeater-note { color: #d56c3b; font-size: 12px; }
.tag-row { display: flex; flex-wrap: wrap; gap: 10px; }
.tag { display: inline-flex; align-items: center; gap: 6px; background: #eaf8ff; color: var(--primary-strong); border: 1px solid rgba(85,184,238,0.24); border-radius: 999px; padding: 8px 12px; font-size: 12px; font-weight: 700; }
.tag button { border: 0; background: transparent; color: inherit; font-weight: 800; padding: 0; min-height: auto; }
.channel-grid, .settings-grid { display: grid; gap: 16px; }
.settings-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
.setting-row { display: grid; grid-template-columns: 180px 1fr auto; gap: 12px; align-items: center; padding: 10px 0; border-top: 1px dashed var(--soft-line); }
.setting-row:first-of-type { border-top: 0; }
.setting-label { font-size: 13px; font-weight: 700; }
.setting-value, .media-input { color: var(--muted); line-height: 1.7; }
.media-row { display: grid; grid-template-columns: 1fr 260px auto; gap: 16px; align-items: center; padding: 14px 0; border-top: 1px dashed var(--soft-line); }
.media-row:first-of-type { border-top: 0; }
.media-label { font-size: 15px; font-weight: 800; }
.disabled-row .readonly-trigger { pointer-events: none; background: #f1f4f7; opacity: 0.82; }
.modal-backdrop { position: fixed; inset: 0; background: rgba(12,20,30,0.42); backdrop-filter: blur(4px); display: grid; place-items: center; padding: 24px; z-index: 40; }
.modal-card { width: min(1180px, 92vw); max-height: 88vh; background: #fff; border: 1px solid rgba(221,230,239,0.95); border-radius: 24px; box-shadow: 0 28px 60px rgba(15,28,42,0.24); display: flex; flex-direction: column; overflow: hidden; }
.modal-card.medium { width: min(1040px, 88vw); }
.modal-card.small { width: min(650px, 92vw); }
.modal-head, .modal-foot { padding: 20px 24px; display: flex; justify-content: space-between; gap: 12px; align-items: center; border-bottom: 1px solid var(--soft-line); }
.modal-foot { border-top: 1px solid var(--soft-line); border-bottom: 0; justify-content: flex-end; }
.modal-title { margin: 0 0 6px; font-size: 24px; }
.modal-body { padding: 22px 24px; overflow: auto; }
.keyword-layout, .two-col-picker { display: grid; grid-template-columns: 260px 1fr; gap: 18px; }
.keyword-sidebar { background: #f8fbff; border: 1px solid var(--soft-line); border-radius: 18px; padding: 12px; display: grid; gap: 8px; align-content: start; max-height: 62vh; overflow: auto; }
.keyword-cat { border: 0; background: #fff; border-radius: 12px; padding: 14px 12px; text-align: left; color: var(--muted); font-weight: 700; border: 1px solid var(--line); }
.keyword-cat.active { background: linear-gradient(180deg, var(--primary), var(--primary-strong)); color: #fff; border-color: transparent; }
.keyword-main { display: grid; gap: 14px; }
.keyword-toolbar { display: flex; justify-content: space-between; gap: 10px; align-items: center; }
.search-wrap { flex: 1; }
.group-block { border: 1px solid var(--line); border-radius: 16px; overflow: hidden; }
.group-toggle { width: 100%; border: 0; background: #fbfdff; padding: 14px 16px; text-align: left; display: flex; justify-content: space-between; align-items: center; color: var(--text); font-weight: 800; }
.group-count { color: var(--muted); font-size: 12px; }
.group-content { display: none; padding: 14px 16px 18px; background: #fff; border-top: 1px solid var(--soft-line); }
.group-content.open { display: block; }
.checkbox-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px 14px; }
.checkbox-item, .radio-item { display: flex; gap: 8px; align-items: flex-start; padding: 8px 10px; border-radius: 10px; border: 1px solid var(--soft-line); background: #fbfdff; color: var(--text); }
.checkbox-item input, .radio-item input { margin-top: 3px; }
.tag-tray { border-top: 1px solid var(--soft-line); padding-top: 12px; }
.asset-drop { border-radius: 20px; min-height: 240px; border: 1px dashed rgba(85,184,238,0.4); background: #f5fbff; display: grid; place-items: center; text-align: center; padding: 20px; }
.asset-grid { margin-top: 18px; display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 14px; }
.asset-card { border-radius: 16px; border: 1px solid var(--line); padding: 12px; display: grid; gap: 10px; }
.asset-preview { border-radius: 12px; height: 88px; display: grid; place-items: center; background: linear-gradient(135deg, #caecff, #f3fbff); color: var(--primary-strong); font-weight: 800; }
.table-wrap { border: 1px solid var(--line); border-radius: 18px; overflow: hidden; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 12px 14px; border-bottom: 1px solid var(--soft-line); text-align: left; font-size: 13px; vertical-align: top; }
.table th { background: #f8fbff; color: var(--muted); font-weight: 700; }
.table tr:last-child td { border-bottom: 0; }
.small-form { display: grid; gap: 14px; }
@media (max-width: 1180px) {
  .sidebar { width: 220px; }
  .summary-grid, .filters, .settings-grid, .job-meta-grid, .form-grid.two, .form-grid.three, .keyword-layout, .two-col-picker, .editor-main, .asset-grid { grid-template-columns: 1fr; }
  .job-item { grid-template-columns: 1fr; }
  .fixed-footer { left: 16px; right: 16px; }
}

.standard-page-body { display: grid; gap: 18px; }
.flash-banner { margin: 0 28px; border-radius: 16px; padding: 12px 16px; display: flex; justify-content: space-between; gap: 12px; align-items: center; font-size: 13px; }
.flash-banner.info { background: #eef9ff; border: 1px solid rgba(85,184,238,0.22); color: var(--primary-strong); }
.flash-banner.success { background: #eefcf4; border: 1px solid rgba(92,185,120,0.22); color: #2c7c4f; }
.flash-banner.error { background: #fff4ea; border: 1px solid rgba(242,135,31,0.22); color: #a45a15; }
.flash-close { border: 0; background: transparent; color: inherit; font-weight: 700; }
.dashboard-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.summary-grid.compact { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.notice-list, .stack-list, .detail-right-stack { display: grid; gap: 12px; }
.notice-row, .stack-row { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 12px 0; border-top: 1px dashed var(--soft-line); }
.notice-row:first-child, .stack-row:first-child { border-top: 0; }
.stack-time { font-weight: 700; color: var(--text); }
.info-grid { display: grid; gap: 14px; }
.info-grid.two-col { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.info-grid.one-col { grid-template-columns: 1fr; }
.info-card { background: #f9fcff; border: 1px solid var(--soft-line); border-radius: 14px; padding: 14px; display: grid; gap: 6px; }
.empty-state { border-radius: 18px; background: #f8fbff; border: 1px dashed rgba(85,184,238,0.28); padding: 26px; display: grid; gap: 12px; }
.nested-tabs { padding: 0 0 18px; }
.applicants-table td strong { display: block; }
.detail-header-card { background: rgba(255,255,255,0.94); border: 1px solid var(--line); border-radius: 20px; box-shadow: var(--shadow); padding: 18px 20px; display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.detail-two-col { display: grid; grid-template-columns: 360px 1fr; gap: 16px; }
.native-upload-label { position: relative; overflow: hidden; }
.native-file-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
.memo-card { border-radius: 14px; border: 1px solid var(--soft-line); background: #fbfdff; padding: 14px; }
.memo-card p { margin: 8px 0 0; color: var(--muted); line-height: 1.7; }
.messages-layout { display: grid; grid-template-columns: 360px 1fr; gap: 16px; }
.message-sidebar { background: #f8fbff; border: 1px solid var(--soft-line); border-radius: 20px; padding: 14px; display: grid; gap: 14px; align-content: start; }
.thread-list { display: grid; gap: 8px; }
.thread-item { border: 1px solid var(--line); background: #fff; border-radius: 14px; padding: 12px; text-align: left; color: var(--text); display: grid; gap: 6px; }
.thread-item.active { border-color: rgba(85,184,238,0.32); background: var(--primary-soft); }
.thread-head { display: flex; justify-content: space-between; gap: 8px; }
.message-body-card { min-height: 520px; }
.message-body { display: grid; gap: 12px; }
.message-bubble { max-width: 72%; border-radius: 18px; padding: 14px; line-height: 1.8; }
.message-bubble.in { background: #f8fbff; border: 1px solid var(--soft-line); }
.message-bubble.out { background: #eaf8ff; border: 1px solid rgba(85,184,238,0.2); margin-left: auto; }
.bubble-meta { font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.analysis-kpis { margin-bottom: 16px; }
.analysis-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 16px; }
.chart-bars { display: flex; align-items: end; gap: 12px; min-height: 220px; padding-top: 10px; }
.chart-col { flex: 1; display: grid; gap: 10px; align-items: end; justify-items: center; }
.chart-bar { width: 100%; max-width: 54px; border-radius: 14px 14px 8px 8px; background: linear-gradient(180deg, #8fdcff, #55b8ee); box-shadow: 0 10px 18px rgba(85,184,238,0.24); }
.demographic-bars { display: grid; gap: 12px; }
.demo-row { display: grid; grid-template-columns: 74px 1fr 34px; gap: 12px; align-items: center; }
.demo-track { height: 12px; background: #eef4f8; border-radius: 999px; overflow: hidden; }
.demo-fill { height: 100%; background: linear-gradient(90deg, #8fdcff, #55b8ee); }
.settings-overview-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.signature-area { min-height: 160px; }
.radio-clean { border: 0; background: transparent; padding: 0; }
.small-table { width: min(944px, 90vw); }
.default-modal { width: min(1184px, 92vw); }
.tiny { width: min(650px, 92vw); }
.applicant-interview { width: min(722px, 92vw); }
.applicant-memo { width: min(532px, 92vw); }
.compact-drop { min-height: 220px; }
.media-meta { display: grid; gap: 4px; }
.placeholder-card { border: 1px dashed rgba(85,184,238,0.22); background: #fbfdff; border-radius: 18px; padding: 18px; color: var(--muted); }
@media (max-width: 1180px) {
  .dashboard-grid, .detail-two-col, .messages-layout, .analysis-grid, .settings-overview-grid, .info-grid.two-col, .summary-grid.compact { grid-template-columns: 1fr; }
}

/* route detail stage v0_004_000 */
.route-connected .route-table th:last-child,
.route-connected .route-table td:last-child { min-width: 180px; }
.row-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.settings-detail-shell .main-card { min-height: calc(100vh - 48px); }
.settings-route-body { padding-bottom: 108px; }
.route-header { border-bottom: 1px solid var(--soft-line); margin-bottom: 18px; }
.route-pill { max-width: 440px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; border-radius: 999px; border: 1px solid var(--soft-line); background: #f8fbff; padding: 8px 12px; font-size: 11px; color: var(--muted); }
.detail-edit-grid { display: grid; gap: 16px; }
.route-section { box-shadow: none; }
.question-list { display: grid; gap: 12px; }
.question-row { display: grid; grid-template-columns: 34px 1fr 1.4fr 84px 84px; gap: 12px; align-items: end; padding: 12px; border: 1px solid var(--soft-line); border-radius: 16px; background: #fbfdff; }
.drag-handle { align-self: center; color: var(--muted); font-size: 20px; letter-spacing: -5px; transform: rotate(90deg); }
.toggle-line { display: inline-flex; align-items: center; gap: 6px; min-height: 42px; font-size: 13px; color: var(--text); }
.detail-footer { left: 88px; right: 32px; }
.entry-preview-shell { display: grid; place-items: center; gap: 18px; padding-bottom: 110px; }
.entry-preview-hero { width: min(760px, 100%); border-radius: 26px; background: linear-gradient(135deg, #eaf8ff, #ffffff); border: 1px solid rgba(85,184,238,0.18); padding: 24px; display: flex; gap: 16px; align-items: center; box-shadow: var(--shadow); }
.entry-preview-logo { width: 56px; height: 56px; border-radius: 18px; background: var(--primary); color: #fff; display: grid; place-items: center; font-weight: 900; }
.entry-steps { width: min(760px, 100%); display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.entry-steps span { border-radius: 999px; background: #f2f6fb; border: 1px solid var(--soft-line); padding: 10px 12px; text-align: center; font-size: 13px; color: var(--muted); }
.entry-steps span.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.preview-form-card { width: min(760px, 100%); box-shadow: var(--shadow); }
.required, .optional { display: inline-flex; margin-left: 6px; padding: 2px 7px; border-radius: 999px; font-size: 11px; }
.required { background: #fff0ea; color: #c66a32; }
.optional { background: #edf5fb; color: var(--muted); }
.privacy-line { display: flex; gap: 8px; align-items: center; margin: 18px 0; color: var(--muted); }
.token-row { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.mail-body { min-height: 360px; white-space: pre-wrap; }
.route-status { max-width: 280px; }
@media (max-width: 980px) {
  .question-row { grid-template-columns: 1fr; }
  .detail-footer { left: 16px; right: 16px; }
  .route-pill { max-width: 220px; }
}

/* route list stage v0_005_000 */
.settings-route-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.settings-route-tab { border: 1px solid var(--soft-line); background: #fff; color: var(--muted); border-radius: 999px; padding: 10px 14px; font-weight: 800; cursor: pointer; }
.settings-route-tab.active { background: var(--primary); border-color: var(--primary); color: #fff; box-shadow: 0 10px 22px rgba(85,184,238,0.18); }
.route-map-card { display: flex; justify-content: space-between; gap: 12px; align-items: center; border: 1px solid rgba(85,184,238,0.18); background: linear-gradient(135deg, #f5fcff, #fff); border-radius: 18px; padding: 14px 16px; margin-bottom: 16px; }
.route-map-card strong { display: block; color: var(--text); font-size: 13px; margin-bottom: 4px; }
.route-map-card span { display: block; color: var(--muted); font-size: 12px; max-width: 720px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.route-map-links { display: flex; flex-wrap: wrap; gap: 8px; justify-content: flex-end; }
.settings-hub-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-bottom: 16px; }
.settings-hub-card { min-height: 190px; display: flex; flex-direction: column; justify-content: space-between; }
.route-matrix code { display: inline-block; max-width: 360px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; background: #f6f9fc; border: 1px solid var(--soft-line); border-radius: 8px; padding: 4px 8px; color: var(--muted); }
.settings-list-toolbar { display: flex; justify-content: space-between; align-items: end; gap: 12px; margin-bottom: 16px; padding: 14px; border: 1px solid var(--soft-line); border-radius: 18px; background: #fff; }
.settings-list-toolbar .search-field { min-width: min(460px, 100%); }
.list-route-card { min-height: 420px; }
.asset-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.asset-card { border: 1px solid var(--soft-line); border-radius: 18px; padding: 14px; background: #fff; display: grid; gap: 10px; box-shadow: 0 6px 16px rgba(24,24,24,0.04); }
.asset-thumb { height: 108px; border-radius: 16px; display: grid; place-items: center; font-weight: 900; letter-spacing: .08em; background: linear-gradient(135deg, #eaf8ff, #f8fbff); color: var(--primary); border: 1px dashed rgba(85,184,238,0.28); }
.asset-thumb.video { background: linear-gradient(135deg, #fff5ec, #fff); color: #f08445; border-color: rgba(240,132,69,0.24); }
.signature-route-card { max-width: 980px; }
.signature-area.large { min-height: 320px; }
.btn.disabled { opacity: .55; cursor: not-allowed; background: #f3f5f7; color: var(--muted); }
@media (max-width: 1180px) {
  .settings-hub-grid, .asset-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .settings-hub-grid, .asset-grid, .settings-list-toolbar { grid-template-columns: 1fr; display: grid; }
  .route-map-card { display: grid; }
}


/* public route and fallback expansion */
.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 18%, rgba(85,184,238,.42), transparent 32%),
    radial-gradient(circle at 88% 22%, rgba(255,171,96,.38), transparent 30%),
    radial-gradient(circle at 70% 92%, rgba(109,226,190,.32), transparent 36%),
    linear-gradient(135deg, #eef8ff 0%, #fff 54%, #f8fbff 100%);
}
.auth-orb { position: absolute; border-radius: 999px; filter: blur(5px); opacity: .7; }
.orb-a { width: 320px; height: 320px; left: -80px; bottom: 12%; background: rgba(85,184,238,.22); }
.orb-b { width: 240px; height: 240px; right: 6%; top: 8%; background: rgba(255,171,96,.24); }
.auth-panel {
  width: min(520px, calc(100vw - 48px));
  border-radius: 18px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.88);
  box-shadow: 0 24px 70px rgba(36, 70, 98, .18);
  backdrop-filter: blur(18px);
  padding: 42px;
  display: grid;
  gap: 20px;
  position: relative;
  z-index: 1;
}
.auth-logo { display:flex; align-items:center; gap:12px; }
.auth-logo span { display:block; color:#7d8a95; font-size:12px; margin-top:4px; }
.auth-title { margin: 0; font-size: 30px; letter-spacing: -.02em; }
.auth-copy { margin: 0; color:#687480; line-height: 1.75; }
.auth-form { display:grid; gap:16px; }
.auth-submit { width: 100%; justify-content:center; }
.link-button { border:none; background:transparent; color:#279dd8; font-weight:700; cursor:pointer; padding:6px 4px; }
.link-button.center { justify-self: center; }
.auth-route-strip { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; border-top:1px solid #e9eef3; padding-top:16px; }
.public-shell { min-height: 100vh; padding: 32px; }
.public-workspace { width:min(1180px, 100%); margin: 0 auto; }
.public-card { min-height: calc(100vh - 64px); }
.public-route-tabs { margin-bottom: 12px; }
.public-page-body { display:grid; gap:16px; }
.public-notice-list { display:grid; gap:12px; }
.public-notice-row { align-items:center; }
.public-notice-row strong { display:block; margin: 8px 0 4px; }
.notice-detail-card h3 { font-size: 24px; margin: 10px 0 4px; }
.rich-text-block { background:#f7fbfe; border:1px solid #e2f1fb; border-radius:12px; padding:22px; line-height:1.9; color:#384450; }
.notification-filters { display:flex; flex-wrap:wrap; gap:8px; margin: 12px 0 18px; }
.mini-filter { border:1px solid #d8e4ec; background:#fff; border-radius:999px; padding:7px 12px; cursor:pointer; font-weight:700; color:#546270; }
.mini-filter.active { background:#55b8ee; color:#fff; border-color:#55b8ee; }
.notification-list { display:grid; gap:10px; }
.notification-row { display:flex; justify-content:space-between; gap:18px; padding:16px; border:1px solid #e4edf3; border-radius:12px; background:#fff; }
.notification-row.unread { border-color:#bfe8ff; background:#f4fbff; }
.notification-row.read { opacity:.78; }
.notice-title-line { display:flex; align-items:center; flex-wrap:wrap; gap:8px; }
.unread-dot { border-radius:999px; background:#ff8a34; color:#fff; padding:2px 8px; font-size:11px; font-weight:800; }
.setup-steps { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:14px; }
.setup-step { background:#fff; border:1px solid #e6edf2; border-radius:14px; padding:18px; }
.step-number { display:inline-grid; place-items:center; width:30px; height:30px; border-radius:999px; background:#55b8ee; color:#fff; font-weight:800; margin-bottom:12px; }
.notfound-hero { display:flex; gap:18px; align-items:center; margin-bottom:18px; }
.notfound-code { font-size:56px; font-weight:900; color:#55b8ee; letter-spacing:-.06em; }
.compact-btn { padding-inline: 12px; }
.btn.active { background:#e8f7ff; border-color:#55b8ee; color:#178fca; }
@media (max-width: 880px) {
  .setup-steps { grid-template-columns: 1fr; }
  .public-shell { padding: 12px; }
  .auth-panel { padding: 28px; }
}

/* public route and fallback expansion */
.auth-screen{
  min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
  background:radial-gradient(circle at 10% 10%,rgba(85,184,238,.24),transparent 30%),radial-gradient(circle at 90% 80%,rgba(255,172,87,.22),transparent 36%),linear-gradient(135deg,#f7fbff,#eef8ff 55%,#fff8ee);
}
.auth-art{position:absolute;border-radius:999px;filter:blur(8px);opacity:.75;}
.auth-art.art-a{width:420px;height:420px;background:rgba(85,184,238,.22);left:-120px;top:80px;}
.auth-art.art-b{width:520px;height:520px;background:rgba(255,172,87,.18);right:-170px;bottom:-120px;}
.auth-panel{position:relative;width:min(520px,92vw);background:rgba(255,255,255,.82);backdrop-filter:blur(22px);border:1px solid rgba(255,255,255,.9);border-radius:18px;box-shadow:0 24px 80px rgba(24,24,24,.12);padding:44px;display:flex;flex-direction:column;gap:18px;}
.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:6px;}
.auth-brand span:not(.brand-icon){display:block;color:#7b8794;font-size:12px;margin-top:3px;}
.brand-icon.large{width:44px;height:44px;font-size:22px;}
.btn.wide{width:100%;justify-content:center;margin-top:6px;}
.link-button{border:0;background:transparent;color:var(--primary);font-weight:700;cursor:pointer;text-align:center;padding:4px;}
.public-mini-nav,.public-route-actions,.public-route-grid{display:flex;flex-wrap:wrap;gap:8px;}
.public-shell{min-height:100vh;padding:32px;background:radial-gradient(circle at 0% 20%,rgba(85,184,238,.16),transparent 32%),linear-gradient(135deg,#f4fbff,#fff);}
.public-workspace{max-width:1220px;margin:0 auto;}
.public-card{min-height:calc(100vh - 64px);}
.public-page-body{padding:6px 0 96px;display:flex;flex-direction:column;gap:18px;}
.btn.compact{padding:8px 10px;font-size:12px;}
.public-filter{align-items:end;}
.public-notice-list .notice-row{border:1px solid #edf1f5;border-radius:12px;margin-bottom:10px;padding:16px;background:#fff;}
.notice-detail-card h2{font-size:26px;margin:8px 0 16px;}
.rich-text{background:#f8fbfd;border:1px solid #e6eef5;border-radius:12px;padding:18px;line-height:1.8;}
.route-note{margin-top:16px;font-size:12px;color:#7b8794;background:#f4f7fa;border-radius:999px;display:inline-flex;padding:8px 12px;}
.notification-toolbar{grid-template-columns:1.4fr .8fr auto;}
.toggle-row{display:flex;align-items:end;gap:8px;padding-bottom:2px;}
.notification-table td{vertical-align:top;}
.notfound-card{text-align:center;padding:42px;}
.notfound-code{font-size:72px;font-weight:900;color:var(--primary);letter-spacing:.04em;}
.route-table-wrap{overflow:auto;}
.public-route-lab{grid-column:1 / -1;}
.public-route-grid .btn{min-width:142px;}
@media (max-width: 860px){.notification-toolbar{grid-template-columns:1fr}.auth-panel{padding:28px}.public-shell{padding:16px}.public-route-actions{margin-top:12px}}

/* interaction fix v0_007_001 */
.job-preview-modal {
  width: min(1180px, 92vw);
  max-height: 88vh;
}
.preview-shell-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 18px;
}
.preview-paper {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  padding: 24px;
  box-shadow: inset 0 0 0 1px rgba(85,184,238,.05);
}
.preview-status-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 12px;
}
.preview-job-title {
  margin: 0;
  color: var(--text);
  font-size: 24px;
  line-height: 1.35;
}
.preview-job-subtitle {
  color: var(--muted);
  margin: 8px 0 18px;
}
.preview-meta-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
.preview-meta-row {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--soft);
}
.preview-meta-row span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 4px;
}
.preview-meta-row strong {
  color: var(--text);
  font-size: 13px;
}
.preview-appeal-box {
  border-left: 4px solid var(--primary);
  background: #f7fcff;
  padding: 14px 16px;
  border-radius: 8px;
  margin-bottom: 14px;
}
.preview-appeal-box p {
  color: var(--muted);
  line-height: 1.7;
  margin: 8px 0 0;
}
.preview-side-panel {
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--soft);
  padding: 18px;
  align-self: start;
}
.compact-stack .stack-row {
  padding: 10px;
}
.preview-tags {
  margin-top: 12px;
}
@media (max-width: 980px) {
  .preview-shell-grid { grid-template-columns: 1fr; }
  .preview-meta-list { grid-template-columns: 1fr; }
}


/* v0_008_000 permission / contract hardening */
.permission-grid {
  display: grid;
  gap: 18px;
}
.permission-summary .info-grid .info-card strong {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}
.permission-feature-table .route-table td,
.permission-policy-table .route-table td,
.permission-role-table .route-table td {
  vertical-align: top;
}
.permission-guard-modal .full-info {
  grid-column: 1 / -1;
}
.permission-guard-modal code,
.permission-policy-table code {
  word-break: break-all;
}
.btn.is-disabled {
  opacity: .45;
}
.empty-state .btn.outline {
  background: #fff;
  color: var(--primary);
  border: 1px solid var(--primary);
}


/* Public recruitment preview route */
.public-preview-page{min-height:100vh;background:#f4f7fb;color:#1f2937;font-family:"Noto Sans JP",system-ui,sans-serif;padding-bottom:48px}.preview-mode-bar{position:sticky;top:0;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px;background:rgba(255,255,255,.94);border-bottom:1px solid #dbe5ee;padding:14px 32px;box-shadow:0 8px 28px rgba(15,23,42,.08);backdrop-filter:blur(10px)}.preview-mode-bar strong{display:block;font-size:13px}.preview-mode-bar span{font-size:12px;color:#64748b}.preview-mode-status{border-radius:999px;background:#eaf7ff;color:#1d8fc8;font-weight:800;padding:8px 14px;font-size:13px}.public-job-hero{max-width:1100px;margin:34px auto 18px;background:#fff;border-radius:18px;padding:42px 48px;box-shadow:0 24px 70px rgba(15,23,42,.10);border:1px solid #e5edf5}.public-job-company{font-size:18px;font-weight:800;color:#334155;margin-bottom:18px}.public-job-hero h1{font-size:38px;line-height:1.35;margin:0 0 20px;font-weight:900;letter-spacing:-.02em}.public-job-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}.public-job-tag{background:#eef8ff;color:#207ead;border:1px solid #cceeff;border-radius:999px;padding:7px 11px;font-size:13px;font-weight:800}.public-job-summary-grid{display:grid;grid-template-columns:1.1fr 1.7fr .9fr;gap:14px;margin:26px 0}.public-job-summary-grid>div{border-radius:12px;background:#f8fbfd;border:1px solid #e6eef5;padding:15px 16px}.public-job-summary-grid span{display:block;color:#64748b;font-size:12px;font-weight:700;margin-bottom:6px}.public-job-summary-grid strong{font-size:17px}.public-job-image{height:275px;border-radius:16px;background:linear-gradient(135deg,#dff5ff,#eef2ff 52%,#fff7ed);border:1px solid #d7e8f4;display:flex;align-items:center;justify-content:center;color:#64748b;font-size:18px;font-weight:900}.public-preview-anchor-nav{max-width:1100px;margin:0 auto 18px;display:flex;flex-wrap:wrap;gap:8px;background:#fff;padding:18px;border-radius:14px;border:1px solid #e5edf5;box-shadow:0 12px 36px rgba(15,23,42,.06)}.preview-anchor-chip{font-size:13px;text-decoration:none;color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;padding:8px 12px;font-weight:800}.preview-anchor-chip:hover{border-color:#55b8ee;color:#1788bd;background:#ecf8ff}.public-job-layout{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:22px;align-items:start}.public-job-main{display:grid;gap:14px}.public-job-section{display:grid;grid-template-columns:58px 1fr;gap:18px;background:#fff;border:1px solid #e5edf5;border-radius:15px;padding:24px 26px;box-shadow:0 12px 30px rgba(15,23,42,.045)}.public-job-section.tinted{background:#fcfeff}.public-section-label{width:42px;height:42px;border-radius:12px;background:#55b8ee;color:#fff;display:grid;place-items:center;font-weight:900}.public-job-section h2{margin:0 0 10px;font-size:21px}.public-job-section p{margin:0;color:#475569;line-height:1.85}.public-apply-card{position:sticky;top:88px;background:#fff;border:1px solid #e5edf5;border-radius:18px;padding:22px;box-shadow:0 20px 50px rgba(15,23,42,.10)}.apply-card-title{font-size:22px;font-weight:900;margin-bottom:10px}.public-apply-card p{color:#64748b;line-height:1.7;font-size:13px}.public-apply-button{width:100%;height:52px;border:0;border-radius:12px;background:#ff9f43;color:#fff;font-size:17px;font-weight:900;box-shadow:0 14px 28px rgba(255,159,67,.28);cursor:pointer;margin:12px 0}.btn.full{width:100%;justify-content:center}.preview-warning{font-size:12px;color:#64748b;border-top:1px solid #edf2f7;margin-top:16px;padding-top:14px}.public-job-footer{text-align:center;color:#64748b;margin:38px auto 0;font-size:13px}@media(max-width:900px){.public-job-layout{grid-template-columns:1fr}.public-apply-card{position:static}.public-job-summary-grid{grid-template-columns:1fr}.public-job-hero{margin:18px;padding:26px}.public-job-hero h1{font-size:28px}.preview-mode-bar{padding:12px 16px;flex-wrap:wrap}.public-preview-anchor-nav,.public-job-layout{margin-left:14px;margin-right:14px}.public-job-section{grid-template-columns:1fr}.public-section-label{width:36px;height:36px}}


/* ver0_010_000 public application flow */
.application-page{background:linear-gradient(180deg,#f4f9fd 0%,#eef5fb 100%)}
.application-hero{max-width:920px;margin:34px auto 18px;background:#fff;border:1px solid #e5edf5;border-radius:18px;padding:34px 40px;box-shadow:0 24px 70px rgba(15,23,42,.10)}
.application-hero h1{font-size:30px;line-height:1.35;margin:8px 0 12px;font-weight:900;color:#162030}.apply-job-summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.apply-job-summary span{background:#f8fbfd;border:1px solid #e5edf5;border-radius:999px;padding:8px 12px;font-size:13px;color:#475569;font-weight:800}.apply-progress{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}.apply-step{display:flex;align-items:center;gap:10px;border:1px solid #e5edf5;background:#f8fafc;border-radius:14px;padding:14px}.apply-step span{width:32px;height:32px;border-radius:999px;background:#dbeafe;color:#1d75a8;display:grid;place-items:center;font-weight:900}.apply-step strong{font-size:13px;color:#475569}.apply-step.current{border-color:#55b8ee;background:#eef9ff}.apply-step.current span,.apply-step.done span{background:#55b8ee;color:#fff}.application-card{max-width:920px;margin:0 auto;background:#fff;border:1px solid #e5edf5;border-radius:18px;padding:30px 34px;box-shadow:0 18px 54px rgba(15,23,42,.08)}.application-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.application-grid .full{grid-column:1/-1}.field label em{font-style:normal;font-size:11px;color:#fff;background:#ff9f43;border-radius:999px;padding:3px 7px;margin-left:6px}.apply-segment{display:flex;flex-wrap:wrap;gap:8px;min-height:42px;align-items:center}.segment-pill{border:1px solid #dbe5ee;background:#fff;border-radius:999px;padding:9px 14px;font-weight:800;color:#475569;cursor:pointer}.segment-pill.active{background:#55b8ee;color:#fff;border-color:#55b8ee}.privacy-check{display:flex;align-items:center;gap:10px;margin-top:20px;padding:16px;border:1px solid #dbe5ee;border-radius:12px;background:#f8fbfd;font-weight:800}.privacy-check input{width:18px;height:18px}.apply-help-box{margin-top:18px;border-radius:12px;background:#eef9ff;border:1px solid #ceefff;color:#297ca7;padding:14px 16px;font-size:13px;font-weight:700}.application-footer{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;border-top:1px solid #edf2f7;padding-top:20px}.confirm-table{border:1px solid #e5edf5;border-radius:14px;overflow:hidden}.confirm-row{display:grid;grid-template-columns:190px 1fr;border-bottom:1px solid #edf2f7}.confirm-row:last-child{border-bottom:0}.confirm-row span{background:#f8fbfd;padding:14px 16px;color:#64748b;font-weight:800}.confirm-row strong{padding:14px 16px;font-weight:800;color:#1f2937;white-space:pre-wrap}.application-complete-mark{width:72px;height:72px;border-radius:999px;background:#55b8ee;color:#fff;display:grid;place-items:center;font-size:38px;font-weight:900;margin:14px auto 18px}.complete-title{text-align:center;font-size:30px;margin:0 0 12px}.complete-copy{text-align:center;color:#475569;line-height:1.8;max-width:620px;margin:0 auto 24px}.apply-complete-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}@media(max-width:760px){.application-hero,.application-card{margin:16px 14px;padding:24px 20px}.application-grid{grid-template-columns:1fr}.apply-progress{grid-template-columns:1fr}.confirm-row{grid-template-columns:1fr}.application-footer{justify-content:stretch;flex-direction:column}.application-footer .btn{justify-content:center}}


/* v0_011_000 preview device split + AI suggestions */
.preview-device-switch{display:flex;align-items:center;gap:6px;background:#f1f5f9;border:1px solid #dbe5ee;border-radius:999px;padding:4px}.preview-device-button{border:0;border-radius:999px;background:transparent;color:#64748b;font-size:12px;font-weight:900;padding:8px 13px;cursor:pointer}.preview-device-button.active{background:#55b8ee;color:#fff;box-shadow:0 8px 18px rgba(85,184,238,.28)}.mobile-preview-stage{min-height:calc(100vh - 80px);display:flex;justify-content:center;align-items:flex-start;padding:30px 18px 50px;background:linear-gradient(135deg,#eaf7ff,#f7fbff)}.mobile-device-frame{width:min(430px,96vw);height:820px;border-radius:38px;background:#111827;padding:14px;box-shadow:0 30px 80px rgba(15,23,42,.28);position:relative}.mobile-device-top{position:absolute;top:10px;left:50%;transform:translateX(-50%);width:110px;height:24px;border-radius:0 0 18px 18px;background:#111827;z-index:2}.mobile-device-screen{height:100%;overflow:auto;background:#f4f7fb;border-radius:28px}.device-mobile .preview-mode-bar{position:sticky}.device-mobile .public-job-hero,.device-mobile .public-preview-anchor-nav,.device-mobile .public-job-layout{max-width:none;margin:0 12px 14px}.device-mobile .public-job-hero{border-radius:18px;padding:22px;margin-top:18px}.device-mobile .public-job-hero h1{font-size:26px}.device-mobile .public-job-summary-grid{grid-template-columns:1fr}.device-mobile .public-job-image{height:170px}.device-mobile .public-job-layout{display:block}.device-mobile .public-apply-card{position:static;margin-bottom:14px}.device-mobile .public-job-section{grid-template-columns:1fr;padding:20px;border-radius:14px}.device-mobile .public-preview-anchor-nav{display:flex;overflow-x:auto;flex-wrap:nowrap}.device-mobile .preview-anchor-chip{white-space:nowrap}.device-mobile .public-job-footer{padding-bottom:24px}.ai-assist-card{border:1px solid #cceeff;background:linear-gradient(135deg,#f0faff,#fff);border-radius:16px;padding:18px;margin-bottom:18px;box-shadow:0 14px 30px rgba(85,184,238,.12)}.ai-assist-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.ai-assist-head h4{margin:4px 0 6px;font-size:18px}.ai-assist-head p{margin:0;color:#64748b;line-height:1.7}.ai-kicker{display:inline-flex;align-items:center;border-radius:999px;background:#2563eb;color:#fff;font-size:11px;font-weight:900;padding:5px 9px;letter-spacing:.04em}.ai-source-row{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.ai-source-row span{border-radius:999px;background:#fff;border:1px solid #dbeafe;color:#1d4ed8;font-size:12px;font-weight:800;padding:6px 10px}.ai-stale-note{border-radius:10px;background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;font-weight:800;font-size:12px;padding:9px 12px;margin-bottom:12px}.ai-empty-note{border-radius:12px;background:#fff;border:1px dashed #bae6fd;color:#0369a1;padding:18px;text-align:center;font-weight:800}.ai-suggestion-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.ai-suggestion-grid article{background:#fff;border:1px solid #dbeafe;border-radius:13px;padding:14px}.ai-suggestion-grid strong{display:block;margin-bottom:8px;color:#0f172a}.ai-suggestion-grid p{white-space:pre-line;line-height:1.75;color:#334155;margin:0 0 12px;font-size:13px}@media(max-width:900px){.ai-assist-head{flex-direction:column}.ai-suggestion-grid{grid-template-columns:1fr}.preview-device-switch{width:100%;justify-content:center}}

/* v0.012.000: local mock backend / persistence center */
.data-store-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
}
.utility-actions.wrap {
  flex-wrap: wrap;
}
.data-store-json pre {
  max-height: 360px;
  overflow: auto;
  border: 1px solid #d7eaf7;
  border-radius: 10px;
  padding: 16px;
  background: #f7fbfe;
  font-size: 12px;
  line-height: 1.55;
  white-space: pre-wrap;
}
.warning-box {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 10px;
  background: #fff4e8;
  border: 1px solid #ffd2aa;
  color: #8a4b00;
  font-size: 13px;
}


/* ver0_013_000 API / DB contract studio */
.api-studio {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.api-studio-hero {
  background: linear-gradient(135deg, #ffffff, #f3fbff);
}
.api-tab-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0;
}
.api-resource-block {
  margin-top: 18px;
  border: 1px solid #e8edf2;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
}
.api-resource-block h4 {
  margin: 0;
  padding: 12px 14px;
  background: #f6fbff;
  color: #26556e;
}
.method-pill {
  display: inline-flex;
  min-width: 48px;
  justify-content: center;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  color: #fff;
}
.method-pill.get { background: #2a9bd6; }
.method-pill.post { background: #23a36d; }
.method-pill.patch, .method-pill.put { background: #e8992f; }
.method-pill.delete { background: #dc5757; }
.schema-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}
.schema-card {
  border: 1px solid #e8edf2;
  border-radius: 12px;
  padding: 14px;
  background: #fff;
}
.schema-card > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #1b4c62;
}
.schema-card > div span {
  font-size: 12px;
  color: #6f7f89;
}
.schema-card ul {
  margin: 10px 0 0;
  padding-left: 18px;
  color: #344a57;
  line-height: 1.7;
  font-size: 12px;
}
.adapter-flow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}
.adapter-node {
  border: 1px solid #dceff8;
  border-radius: 12px;
  background: #f7fcff;
  padding: 14px;
}
.adapter-node span {
  display: inline-block;
  color: #55B8EE;
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 4px;
}
.adapter-node strong {
  display: block;
  color: #12313e;
}
.adapter-node p {
  color: #637682;
  font-size: 12px;
  line-height: 1.6;
  margin: 8px 0 0;
}
.api-probe {
  border-radius: 12px;
  padding: 12px;
  margin-top: 12px;
  border: 1px solid #e7edf1;
}
.api-probe.pass {
  background: #f2fff8;
  border-color: #bcebcf;
}
.api-probe.fail {
  background: #fff7f7;
  border-color: #f2b8b8;
}
.api-probe > div:first-child {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: #1f5a40;
}
.api-probe-grid {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 8px;
}
.api-probe-item {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  background: #fff;
  border-radius: 10px;
  padding: 10px;
}
.api-probe-item span {
  font-weight: 900;
}
.api-probe-item.ok span {
  color: #18a05e;
}
.api-probe-item.ng span {
  color: #d44d4d;
}
.api-probe-item small {
  display: block;
  color: #6e7d85;
  margin-top: 2px;
}
.warning-box.soft {
  background: #fffdf4;
  border-color: #f1df9b;
  color: #6b5b1f;
}



/* v0_014_000 analytics clarity */
.analysis-wide { grid-column: 1 / -1; }
.chart-legend { display:flex; flex-wrap:wrap; gap:10px; margin: 8px 0 14px; color: var(--muted); font-size: 12px; }
.chart-legend span { display:inline-flex; align-items:center; gap:6px; }
.legend-dot { width:8px; height:8px; border-radius:999px; background: var(--primary); display:inline-block; }
.metric-chart-col { min-width: 76px; }
.chart-value { font-weight:700; color: var(--text); margin-bottom: 6px; }
.mini-chart-note { font-size: 11px; color: var(--muted); line-height: 1.35; }
.hourly-grid { display:grid; gap:12px; }
.hour-row { display:grid; grid-template-columns: 82px 1fr 150px; align-items:center; gap:12px; padding:10px 12px; border:1px solid var(--border); border-radius:10px; background:#fff; }
.hour-label { font-weight:700; color:var(--text); }
.hour-track { height:12px; background:#eaf6fd; border-radius:999px; overflow:hidden; }
.hour-fill { height:100%; background:var(--primary); border-radius:999px; }
.hour-value { display:grid; gap:2px; font-size:12px; color:var(--muted); }
.hour-value strong { color:var(--text); font-size:14px; }
@media (max-width: 760px) { .hour-row { grid-template-columns: 1fr; } .metric-chart-col { min-width: 54px; } }

/* v0_015_000 create flow / salary detail / analytics feasibility */
.salary-detail-card {
  border-left: 4px solid var(--primary);
}
.salary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 14px;
  padding: 14px;
  border-radius: 12px;
  background: #f4f9fc;
}
.salary-grid .field.full {
  grid-column: 1 / -1;
}
.wage-auto-panel {
  grid-column: 1 / -1;
  padding: 16px;
  border: 1px solid rgba(85,184,238,0.28);
  border-radius: 16px;
  background: linear-gradient(135deg, #ffffff, #eef9ff);
  box-shadow: 0 16px 34px rgba(16, 45, 61, 0.08);
}
.wage-auto-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 12px;
}
.wage-auto-head strong {
  display: block;
  color: var(--text);
  font-size: 15px;
}
.wage-auto-head span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}
.wage-status {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid transparent;
}
.wage-status.ok {
  color: #167052;
  background: #e9f9f1;
  border-color: rgba(22,112,82,0.18);
}
.wage-status.warn {
  color: #a15a00;
  background: #fff6e6;
  border-color: rgba(161,90,0,0.18);
}
.wage-auto-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(170px, 1fr));
  gap: 10px;
}
.wage-auto-row {
  display: grid;
  gap: 4px;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 12px;
  background: rgba(255,255,255,0.84);
}
.wage-auto-row span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}
.wage-auto-row strong {
  color: var(--text);
  font-size: 20px;
  letter-spacing: -0.02em;
}
.wage-auto-row small {
  color: var(--muted);
  line-height: 1.5;
}
.wage-auto-note {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.7;
}
.textarea.small {
  min-height: 84px;
}
.salary-warning {
  margin-top: 12px;
}
.analytics-formula-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(170px, 1fr));
  gap: 10px;
  margin: 12px 0;
}
.analytics-formula-grid > div {
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px;
  background: #fff;
  display: grid;
  gap: 4px;
}
.analytics-formula-grid strong {
  color: var(--text);
}
.analytics-formula-grid span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}
.analytics-events-table table {
  width: 100%;
}
.analytics-feasibility .notice-box {
  margin-top: 12px;
}
@media (max-width: 900px) {
  .salary-grid,
  .analytics-formula-grid,
  .wage-auto-grid {
    grid-template-columns: 1fr;
  }
  .wage-auto-head {
    display: grid;
  }
}


/* ver0_015_001: list card more menu */
.job-item { grid-template-columns: 212px 1fr 276px; }
.job-action-row { display: grid; grid-template-columns: 1fr 1fr 42px; gap: 10px; align-items: stretch; width: 100%; position: relative; }
.job-more-wrap { position: relative; display: flex; justify-content: flex-end; }
.job-more-button { width: 42px; min-height: 42px; border-radius: 12px; border: 1px solid var(--line); background: #fff; color: var(--primary); font-size: 24px; line-height: 1; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; }
.job-more-button:hover, .job-more-button[aria-expanded="true"] { border-color: rgba(85,184,238,0.45); box-shadow: 0 0 0 4px rgba(85,184,238,0.12); }
.job-more-menu { position: absolute; right: 0; top: 48px; z-index: 80; width: 164px; border-radius: 12px; border: 1px solid var(--line); background: #fff; box-shadow: 0 18px 38px rgba(15,23,42,.18); padding: 8px; display: grid; gap: 2px; }
.job-more-menu::before { content:""; position:absolute; top:-6px; right:15px; width:10px; height:10px; background:#fff; transform:rotate(45deg); border-left:1px solid var(--line); border-top:1px solid var(--line); }
.job-more-menu button { position: relative; z-index:1; border:0; background:transparent; width:100%; display:flex; align-items:center; gap:10px; padding:11px 10px; border-radius:10px; font-weight:800; color:var(--text); cursor:pointer; text-align:left; }
.job-more-menu button:hover, .job-more-menu button:focus { background:#eef9ff; color:var(--primary-strong); outline:none; }
.job-copied-url { margin-top: 8px; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; border: 1px dashed rgba(85,184,238,0.34); border-radius: 10px; padding: 8px 10px; color: var(--primary-strong); font-size: 11px; background: #f7fcff; }
@media (max-width: 1180px) { .job-item { grid-template-columns: 1fr; } .job-action-row { grid-template-columns: 1fr 1fr 42px; } }
@media (max-width: 680px) { .job-action-row { grid-template-columns: 1fr; } .job-more-button { width:100%; } .job-more-menu { left:0; right:auto; } }

/* v0_016_000 bulk actions */
.bulk-action-band {
  margin-top: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(85, 184, 238, 0.28);
  background: linear-gradient(135deg, rgba(85, 184, 238, 0.10), rgba(255,255,255,0.92));
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}
.bulk-select-all,
.job-select-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  cursor: pointer;
}
.bulk-select-all input,
.job-select-check input {
  width: 16px;
  height: 16px;
  accent-color: var(--primary);
}
.bulk-count { font-size: 13px; color: var(--muted); }
.bulk-count strong { color: var(--primary); font-size: 18px; }
.bulk-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.job-item { position: relative; }
.job-item.is-selected {
  border-color: rgba(85, 184, 238, 0.65);
  box-shadow: 0 16px 34px rgba(85, 184, 238, 0.16);
}
.job-select-check {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(214, 226, 233, 0.95);
  box-shadow: 0 8px 20px rgba(15,23,42,0.08);
}
.job-thumb { padding-top: 42px; }
.bulk-modal .bulk-selected-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
  max-height: 132px;
  overflow: auto;
}
.btn[disabled], .btn[aria-disabled="true"] {
  opacity: .45;
  cursor: not-allowed;
  pointer-events: none;
}


/* v0_017_000: applicant / message / analytics interaction polish */
.applicant-control-band .filter-grid,
.analytics-control-band .filter-grid {
  align-items: end;
}
.field-inline-control {
  justify-content: end;
}
.btn.active-lite,
.local-tab.active-lite {
  border-color: #55b8ee;
  background: #eaf7fe;
  color: #1684c7;
}
.star-button {
  border: 0;
  background: transparent;
  color: #c8c8c8;
  font-size: 18px;
  margin-right: 6px;
  cursor: pointer;
  vertical-align: middle;
}
.star-button.active {
  color: #f2b84b;
}
.table-select {
  min-width: 132px;
  border: 1px solid #d9e3ea;
  border-radius: 6px;
  padding: 8px 10px;
  background: #fff;
  font-weight: 700;
}
.link-count {
  border: 0;
  background: #eaf7fe;
  color: #1684c7;
  border-radius: 999px;
  min-width: 32px;
  padding: 6px 10px;
  font-weight: 800;
  cursor: pointer;
}
.enhanced-applicants-table th:first-child,
.enhanced-applicants-table td:first-child {
  width: 42px;
  text-align: center;
}
.message-tabs {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}
.messages-toolbar.slim-card {
  margin-bottom: 14px;
}
.thread-item.unread strong::after {
  content: " 未読";
  margin-left: 6px;
  color: #fff;
  background: #55b8ee;
  border-radius: 999px;
  font-size: 10px;
  padding: 2px 6px;
}
.message-composer {
  border-top: 1px solid #e6eef4;
  padding-top: 14px;
  margin-top: 18px;
}
.message-composer textarea {
  min-height: 90px;
}
.export-textarea {
  min-height: 260px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  white-space: pre;
}
.upload-drop.compact-upload {
  border: 2px dashed #a7d8f3;
  border-radius: 10px;
  background: #f2f9fd;
  min-height: 140px;
  display: grid;
  place-items: center;
  text-align: center;
  color: #1684c7;
}
.analytics-filter-grid {
  grid-template-columns: 1fr 1fr 2fr;
}
.tiny-empty {
  padding: 18px;
}

/* v0_018_000 dashboard / company / site hardening */
.dashboard-ops-card {
  border-color: rgba(85, 184, 238, 0.24);
}
.task-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 12px;
}
.task-card {
  display: flex;
  min-height: 118px;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid #e6eef5;
  border-radius: 10px;
  background: #fff;
  padding: 14px;
  text-align: left;
  color: var(--text);
  cursor: pointer;
  box-shadow: 0 8px 16px rgba(24, 24, 24, 0.04);
}
.task-card:hover,
.task-card:focus-visible {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 10px 22px rgba(85, 184, 238, 0.18);
}
.task-card span {
  font-size: 12px;
  color: var(--muted);
}
.task-card strong {
  font-size: 28px;
  color: var(--primary-dark);
}
.task-card small {
  color: var(--muted);
  line-height: 1.45;
}
.soft-head {
  margin-top: 14px;
  border-top: 1px solid #eef3f7;
  padding-top: 14px;
}
.company-edit-card .form-grid input,
.company-edit-card .form-grid .input {
  background: #fff;
}
.company-preview-strip {
  margin-top: 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  border-radius: 10px;
  background: #f2f9fd;
  padding: 14px 16px;
  color: var(--text);
}
.company-preview-strip span,
.company-preview-strip small {
  color: var(--muted);
}
.site-map-list .site-map-row {
  align-items: center;
}
.site-preview-modal {
  width: min(1120px, 92vw);
}
.device-switch {
  display: inline-flex;
  gap: 8px;
  border-radius: 999px;
  background: #f0f5f8;
  padding: 6px;
  margin: 4px 0 18px;
}
.device-tab {
  border: 0;
  border-radius: 999px;
  background: transparent;
  padding: 8px 14px;
  cursor: pointer;
  font-weight: 700;
  color: var(--muted);
}
.device-tab.active {
  background: var(--primary);
  color: #fff;
}
.site-preview-frame {
  border-radius: 16px;
  border: 1px solid #dceaf3;
  background: linear-gradient(135deg, #fff 0%, #f7fcff 100%);
  padding: 22px;
  overflow: hidden;
}
.site-preview-frame.mobile {
  max-width: 390px;
  margin: 0 auto;
  border-radius: 28px;
  border-width: 8px;
  padding: 16px;
}
.site-preview-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border-radius: 14px;
  background: #fff;
  padding: 20px;
  box-shadow: 0 10px 22px rgba(24,24,24,0.06);
}
.site-preview-frame.mobile .site-preview-hero {
  flex-direction: column;
  align-items: stretch;
}
.site-preview-hero h3 {
  margin: 8px 0;
  font-size: 24px;
}
.site-preview-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 16px 0;
}
.site-preview-nav span {
  border-radius: 999px;
  background: #eaf6fd;
  padding: 6px 10px;
  color: #147eb5;
  font-size: 12px;
  font-weight: 700;
}
.site-preview-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}
.site-preview-frame.mobile .site-preview-cards {
  grid-template-columns: 1fr;
}
.site-job-card {
  border-radius: 12px;
  border: 1px solid #e6eef5;
  background: #fff;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.site-job-card span {
  color: var(--muted);
  font-size: 12px;
}

/* v0_019_000 roadmap / indeed integration status */
.roadmap-hero .score-bubble,
.score-bubble {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-width:130px;
  min-height:84px;
  border-radius:18px;
  background:linear-gradient(180deg,#eef9ff,#ffffff);
  border:1px solid #b9e7ff;
  box-shadow:0 10px 24px rgba(28,126,184,.08);
  color:#0f3958;
}
.score-bubble strong{font-size:26px;line-height:1.1;color:#25a9e0;}
.score-bubble span{font-size:11px;color:#557;max-width:116px;text-align:center;}
.score-bubble.small{min-width:112px;min-height:72px;margin-bottom:10px;}
.score-bubble.small strong{font-size:22px;}
.roadmap-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:14px;}
.roadmap-kpis>div{border:1px solid #e2edf4;background:#f8fcff;border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:4px;}
.roadmap-kpis strong{font-size:20px;color:#263746;}
.roadmap-kpis span{font-size:12px;color:#789;}
.roadmap-tabs{margin:14px 0;}
.roadmap-timeline{display:grid;grid-template-columns:1fr;gap:12px;}
.roadmap-phase.done{border-left:5px solid #22c55e;}
.roadmap-phase.doing{border-left:5px solid #55b8ee;}
.roadmap-phase.not_started{border-left:5px solid #cbd5e1;}
.progress-track{height:10px;background:#eef3f6;border-radius:999px;overflow:hidden;margin:8px 0 12px;}
.progress-track span{display:block;height:100%;background:linear-gradient(90deg,#55b8ee,#7ed6a6);border-radius:999px;}
.roadmap-readiness-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px;}
.readiness-card{border:1px solid #e4edf3;border-radius:14px;background:#fff;padding:16px;}
.readiness-card ul{margin:8px 0 0;padding-left:18px;color:#52606d;font-size:13px;line-height:1.75;}
.probe-result{margin-top:14px;border-radius:12px;padding:12px 14px;border:1px solid #e4edf3;background:#f7fafc;}
.probe-result.pass{border-color:#9be7b2;background:#f0fff5;}
.probe-result.fail{border-color:#ffc7c7;background:#fff6f6;}
.probe-result ul{margin:8px 0 0;padding-left:18px;line-height:1.7;}
.json-preview{max-height:420px;overflow:auto;border:1px solid #dce7ef;background:#0f172a;color:#e2e8f0;border-radius:12px;padding:16px;font-size:12px;line-height:1.55;white-space:pre-wrap;}
@media (max-width: 920px){.roadmap-kpis,.roadmap-readiness-grid{grid-template-columns:1fr;}}

/* codex v0_001_021: public launch connection console */
.launch-console-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 170px;
  gap:18px;
  align-items:center;
  background:
    radial-gradient(circle at 8% 0%, rgba(36,124,112,.13), transparent 28rem),
    linear-gradient(135deg,#ffffff,#f4faf7);
  border-color:#d7ebe4;
}
.launch-console-hero h3{font-size:28px;line-height:1.25;margin:8px 0;}
.launch-score{
  min-height:142px;
  border-radius:28px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,#183f38,#247c70);
  color:#fff;
  box-shadow:0 20px 38px rgba(36,124,112,.18);
}
.launch-score strong{font-size:38px;line-height:1;letter-spacing:-.04em;}
.launch-score span{font-size:12px;opacity:.82;text-align:center;margin-top:8px;}
.launch-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
  margin:14px 0;
}
.launch-kpi-grid>div{
  border:1px solid #e1ebe7;
  border-radius:18px;
  background:#fff;
  padding:16px;
  min-width:0;
  box-shadow:0 10px 26px rgba(22,35,31,.05);
}
.launch-kpi-grid span,.launch-url-list span{display:block;color:var(--muted);font-size:12px;font-weight:800;margin-bottom:5px;}
.launch-kpi-grid strong{display:block;color:var(--text);font-size:16px;margin-bottom:8px;}
.launch-kpi-grid code,.launch-url-list code{
  display:block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#31554d;
  background:#f2f7f5;
  border:1px solid #e0ebe7;
  border-radius:10px;
  padding:7px 9px;
  font-size:11px;
}
.launch-config-card{
  border-color:#d7ebe4;
  background:linear-gradient(180deg,#fff,#fbfdfb);
}
.launch-config-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.launch-config-grid .field.full{
  grid-column:1 / -1;
}
.launch-config-grid .textarea.small{
  min-height:92px;
}
.launch-url-list.compact{
  margin-top:14px;
  grid-template-columns:1fr;
}
.launch-check-grid,.launch-pattern-grid,.launch-connection-grid,.launch-ad-steps{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.launch-check-card{
  border:1px solid #e4ece8;
  border-left-width:5px;
  border-radius:18px;
  background:#fff;
  padding:16px;
}
.launch-check-card.pass{border-left-color:#22a879;}
.launch-check-card.warn{border-left-color:#d98a36;}
.launch-check-card.fail{border-left-color:#d8584a;}
.launch-check-card.blocked{border-left-color:#24342f;background:#fbfaf6;}
.launch-check-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.launch-check-head span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  border-radius:999px;
  padding:4px 9px;
  background:#eef6f3;
  color:#247c70;
  font-size:11px;
  font-weight:900;
}
.launch-check-card.warn .launch-check-head span{background:#fff2df;color:#b76a18;}
.launch-check-card.fail .launch-check-head span{background:#ffe9e5;color:#c64335;}
.launch-check-card.blocked .launch-check-head span{background:#26342f;color:#fff;}
.launch-check-head strong{font-size:15px;color:var(--text);}
.launch-check-card p{margin:0;color:#52615c;font-size:13px;line-height:1.7;}
.launch-check-card em{display:block;margin-top:10px;color:#798782;font-style:normal;font-size:12px;line-height:1.6;}
.launch-pattern-card{
  border:1px solid #dfeae6;
  border-radius:20px;
  background:#fff;
  padding:18px;
  box-shadow:0 10px 26px rgba(22,35,31,.05);
}
.launch-pattern-card.active{border-color:#247c70;box-shadow:0 16px 34px rgba(36,124,112,.13);}
.launch-pattern-card span{display:inline-flex;border-radius:999px;background:#edf7f3;color:#247c70;padding:4px 9px;font-size:11px;font-weight:900;}
.launch-pattern-card h4{margin:12px 0 8px;font-size:18px;color:var(--text);}
.launch-pattern-card p{min-height:52px;margin:0 0 14px;color:#65736e;font-size:13px;line-height:1.7;}
.launch-connection-grid{align-items:start;margin-top:14px;}
.launch-snippet{
  margin:0 0 14px;
  padding:14px;
  border-radius:14px;
  border:1px solid #dfeae6;
  background:#10201c;
  color:#dff8ee;
  white-space:pre-wrap;
  overflow:auto;
  font-size:12px;
  line-height:1.65;
}
.launch-url-list{display:grid;gap:10px;margin-bottom:14px;}
.launch-ads-gate{border-color:#24342f;background:linear-gradient(135deg,#fff,#f7f4ec);}
.launch-ad-steps>div{border:1px solid #e0e7e3;border-radius:16px;background:#fff;padding:14px;}
.launch-ad-steps strong{display:block;color:#24342f;margin-bottom:4px;}
.launch-ad-steps span{display:block;color:#65736e;font-size:13px;line-height:1.6;}
@media (max-width: 1040px){
  .launch-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .launch-config-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width: 720px){
  .launch-console-hero,.launch-kpi-grid,.launch-config-grid,.launch-check-grid,.launch-pattern-grid,.launch-connection-grid,.launch-ad-steps{grid-template-columns:1fr;}
  .launch-score{min-height:112px;}
  .list-page > .settings-route-tabs,
  .list-page > .route-map-card,
  .list-page > .launch-console-hero,
  .list-page > .launch-kpi-grid,
  .list-page > .section-card,
  .list-page > .launch-connection-grid {
    min-width: 0;
    max-width: 100%;
    width: 100%;
  }
  .settings-route-tabs {
    overflow-x: visible;
    flex-wrap: wrap;
    padding-bottom: 4px;
  }
  .settings-route-tab {
    flex: 0 0 auto;
  }
  .route-map-card,
  .section-head {
    min-width: 0;
  }
  .route-map-card span,
  .launch-snippet,
  .launch-url-list code,
  .launch-kpi-grid code {
    overflow-wrap: anywhere;
    white-space: normal;
  }
}

/* v0_020_000: commercial Nijiya theme, separated from the observed source UI. */
:root {
  --bg-top: #f4f7f5;
  --bg-mid: #eef4f1;
  --bg-shape-1: transparent;
  --bg-shape-2: transparent;
  --bg-shape-3: transparent;
  --primary: #247c70;
  --primary-strong: #176157;
  --primary-soft: #e5f3ef;
  --orange: #d98a36;
  --orange-strong: #b86f22;
  --text: #202927;
  --muted: #66736f;
  --line: #d9e1de;
  --soft-line: #e8eeeb;
  --surface-soft: #f6faf8;
  --shadow: 0 12px 28px rgba(30, 45, 40, 0.10);
  --radius-sm: 8px;
}

html,
body {
  background:
    linear-gradient(90deg, rgba(36,124,112,0.045) 1px, transparent 1px),
    linear-gradient(180deg, rgba(36,124,112,0.035) 1px, transparent 1px),
    linear-gradient(180deg, var(--bg-top), var(--bg-mid));
  background-size: 48px 48px, 48px 48px, auto;
}

.main-card,
.sidebar,
.icon-rail,
.filter-band,
.list-card,
.section-card,
.placeholder-card,
.job-item,
.metric,
.toc,
.modal-card,
.keyword-sidebar,
.group-block,
.asset-drop,
.table-wrap,
.fixed-footer,
.list-footer-bar,
.auth-panel,
.public-card {
  border-radius: 8px;
}

.brand-icon,
.btn.primary,
.keyword-cat.active {
  background: linear-gradient(180deg, var(--primary), var(--primary-strong));
  box-shadow: none;
}

.btn.orange {
  background: linear-gradient(180deg, var(--orange), var(--orange-strong));
}

.nav-item,
.rail-icon,
.local-tab,
.status-pill,
.mini-pill,
.tag,
.readonly-trigger,
.dropdown-menu,
.dropdown-option,
.checkbox-item,
.radio-item,
.asset-card,
.asset-preview,
.job-thumb,
.meta-kv,
.help-button,
.inline-help,
.notice-box,
.publish-note {
  border-radius: 8px;
}

.nav-item.active,
.rail-icon.active,
.local-tab.active,
.toc-item.active {
  background: var(--primary-soft);
  color: var(--primary-strong);
}

.input:focus,
.select:focus,
.textarea:focus {
  border-color: rgba(36,124,112,0.55);
  box-shadow: 0 0 0 3px rgba(36,124,112,0.13);
}

.asset-drop,
.inline-help.open,
.notice-box,
.publish-note,
.flash-banner.info {
  background: #edf7f3;
  border-color: rgba(36,124,112,0.20);
}

.job-thumb {
  background: linear-gradient(160deg, #1f6f64, #3b9789 48%, #d98a36 100%);
}

.public-link-box {
  display: grid;
  gap: 6px;
  margin: 12px 0;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f7fbf9;
}

.public-link-box span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.public-link-box code {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--primary-strong);
  font-size: 12px;
}

/* codex v0.001.001: executive Japanese SaaS direction */
:root {
  --jp-bg: #f4f5f2;
  --jp-bg-2: #ecefeb;
  --jp-surface: #ffffff;
  --jp-surface-2: #f8f9f7;
  --jp-ink: #1f2624;
  --jp-sub: #5d6864;
  --jp-line: #d9ded8;
  --jp-line-strong: #bdc7bf;
  --jp-green: #245f55;
  --jp-green-2: #17483f;
  --jp-green-soft: #e8f1ed;
  --jp-indigo: #40556f;
  --jp-rust: #a7653b;
  --jp-warn: #f3eadf;
  --primary: var(--jp-green);
  --primary-strong: var(--jp-green-2);
  --primary-soft: var(--jp-green-soft);
  --orange: var(--jp-rust);
  --orange-strong: #874d2b;
  --text: var(--jp-ink);
  --muted: var(--jp-sub);
  --line: var(--jp-line);
  --soft-line: #e6ebe5;
  --surface: var(--jp-surface);
  --surface-soft: var(--jp-surface-2);
  --shadow: 0 8px 22px rgba(31, 38, 36, 0.08);
  --radius-sm: 6px;
}

* {
  letter-spacing: 0 !important;
}

html,
body {
  font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
  color: var(--jp-ink);
  background:
    linear-gradient(90deg, rgba(36, 95, 85, 0.035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(36, 95, 85, 0.03) 1px, transparent 1px),
    linear-gradient(180deg, var(--jp-bg), var(--jp-bg-2));
  background-size: 64px 64px, 64px 64px, auto;
}

.sidebar,
.icon-rail {
  background: rgba(249, 250, 247, 0.96);
  border-right: 1px solid var(--jp-line);
  backdrop-filter: none;
}

.brand-box {
  border-bottom: 1px solid var(--jp-line);
  margin-bottom: 14px;
}

.brand-icon {
  width: 38px;
  height: 38px;
  border-radius: 6px;
  background: var(--jp-ink);
  box-shadow: none;
  font-size: 15px;
}

.brand-title {
  font-size: 15px;
  font-weight: 800;
}

.brand-sub,
.page-copy,
.panel-copy,
.section-subcopy,
.modal-copy,
.footer-copy {
  color: var(--jp-sub);
}

.nav-list {
  gap: 4px;
}

.nav-item,
.rail-icon {
  border-radius: 6px;
  padding: 11px 12px;
}

.nav-item.active,
.rail-icon.active,
.local-tab.active,
.toc-item.active,
.thread-item.active {
  background: var(--jp-green-soft);
  color: var(--jp-green-2);
  box-shadow: inset 3px 0 0 var(--jp-green);
}

.nav-dot {
  width: 6px;
  height: 6px;
}

.workspace {
  padding: 18px 22px 96px;
}

.main-card,
.list-card,
.section-card,
.placeholder-card,
.filter-band,
.metric,
.job-item,
.toc,
.modal-card,
.keyword-sidebar,
.group-block,
.asset-card,
.table-wrap,
.detail-header-card,
.message-sidebar,
.fixed-footer,
.list-footer-bar,
.route-map-card,
.auth-panel,
.public-card {
  border-radius: 8px !important;
  box-shadow: none !important;
}

.main-card {
  background: rgba(255, 255, 255, 0.97);
  border: 1px solid var(--jp-line-strong);
}

.utility-bar,
.editor-header {
  padding: 24px 28px 16px;
  border-bottom: 1px solid var(--jp-line);
}

.eyebrow {
  color: var(--jp-green);
  font-size: 11px;
  font-weight: 800;
  text-transform: none;
}

.page-title,
.editor-title {
  font-size: 26px;
  line-height: 1.25;
}

.user-chip,
.mini-pill,
.save-state,
.status-pill,
.tag {
  border-radius: 4px;
  background: var(--jp-surface-2);
  border-color: var(--jp-line);
}

.local-tab,
.btn,
.readonly-trigger,
.input,
.select,
.textarea,
.dropdown-menu,
.dropdown-option,
.checkbox-item,
.radio-item,
.help-button,
.inline-help,
.notice-box,
.publish-note,
.flash-banner,
.meta-kv,
.info-card,
.empty-state {
  border-radius: 6px !important;
}

.btn {
  min-height: 38px;
  font-weight: 700;
  box-shadow: none !important;
}

.btn.primary,
.brand-icon,
.keyword-cat.active,
.preview-device-button.active {
  background: var(--jp-green);
  color: #fff;
}

.btn.orange,
.public-apply-button,
.auth-submit {
  background: var(--jp-rust);
  color: #fff;
}

.btn.ghost {
  background: #fff;
  border-color: var(--jp-line-strong);
}

.btn.linkish,
.link-button {
  color: var(--jp-green);
}

.filter-band,
.placeholder-card,
.section-card,
.list-card {
  background: #fff;
  border-color: var(--jp-line);
}

.summary-grid {
  gap: 10px;
}

.metric {
  padding: 14px;
  background: var(--jp-surface-2);
}

.metric-value {
  font-size: 24px;
}

.job-item {
  grid-template-columns: 168px 1fr 168px;
  background: #fff;
  border-color: var(--jp-line);
}

.job-thumb {
  min-height: 150px;
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(36, 95, 85, 0.88), rgba(64, 85, 111, 0.92)),
    linear-gradient(90deg, transparent 48%, rgba(255,255,255,.16) 48%, rgba(255,255,255,.16) 52%, transparent 52%);
}

.job-thumb-bottom {
  font-size: 18px;
}

.job-name {
  font-size: 19px;
}

.meta-kv {
  background: var(--jp-surface-2);
  border-color: var(--jp-line);
}

.top-tab[aria-current="page"] {
  color: var(--jp-green-2);
  border-bottom-color: var(--jp-green);
}

.tab-strip {
  border-bottom-color: var(--jp-line);
}

.toc {
  background: var(--jp-surface-2);
}

.toc-title,
.minor-title {
  color: var(--jp-green);
  text-transform: none;
  font-size: 11px;
}

.input,
.select,
.textarea,
.readonly-trigger {
  border: 1px solid var(--jp-line-strong);
  background: #fff;
}

.input:focus,
.select:focus,
.textarea:focus {
  border-color: var(--jp-green);
  box-shadow: 0 0 0 3px rgba(36, 95, 85, 0.12);
}

.inline-help.open,
.notice-box,
.publish-note,
.flash-banner.info,
.apply-help-box {
  background: #eef5f1;
  border-color: #cadbd3;
  color: var(--jp-green-2);
}

.flash-banner.success {
  background: #edf6ef;
  border-color: #bfd7c7;
  color: #2f6540;
}

.flash-banner.error,
.save-state.dirty {
  background: var(--jp-warn);
  border-color: #ddc5a9;
  color: #815332;
}

.table th,
.api-resource-block h4 {
  background: var(--jp-surface-2);
}

.modal-backdrop {
  background: rgba(31, 38, 36, 0.42);
  backdrop-filter: blur(2px);
}

.modal-card {
  border-color: var(--jp-line-strong);
}

.ai-assist-card {
  background: #fbfcfa;
  border-color: var(--jp-line-strong);
  box-shadow: none;
}

.ai-kicker {
  background: var(--jp-indigo);
}

.ai-source-row span,
.ai-suggestion-grid article {
  border-color: var(--jp-line);
  color: var(--jp-green-2);
}

/* Public recruitment preview: sober Japanese corporate page */
.public-preview-page {
  min-height: 100vh;
  background:
    linear-gradient(90deg, rgba(36, 95, 85, 0.032) 1px, transparent 1px),
    linear-gradient(180deg, #f6f7f4, #ecefeb);
  background-size: 72px 72px, auto;
  color: var(--jp-ink);
  font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
}

.preview-mode-bar {
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid var(--jp-line-strong);
  box-shadow: none;
  padding: 12px 28px;
}

.preview-mode-status {
  border-radius: 4px;
  background: var(--jp-green-soft);
  color: var(--jp-green-2);
}

.public-job-hero {
  max-width: 1120px;
  margin: 30px auto 16px;
  background: #fff;
  border: 1px solid var(--jp-line-strong);
  border-radius: 8px;
  padding: 34px 40px 38px;
  box-shadow: none;
  position: relative;
}

.public-job-hero::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 5px;
  background: linear-gradient(90deg, var(--jp-green), var(--jp-indigo), var(--jp-rust));
  border-radius: 8px 8px 0 0;
}

.public-job-company {
  display: inline-block;
  margin-bottom: 16px;
  padding: 5px 8px;
  border-left: 3px solid var(--jp-green);
  background: var(--jp-surface-2);
  color: var(--jp-sub);
  font-size: 14px;
}

.public-job-hero h1 {
  max-width: 820px;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  font-size: 34px;
  font-weight: 700;
  line-height: 1.45;
  margin-bottom: 14px;
}

.public-job-subtitle {
  max-width: 760px;
  color: var(--jp-sub);
  line-height: 1.8;
}

.public-job-tag {
  border-radius: 4px;
  background: #f1f4f1;
  color: var(--jp-green-2);
  border-color: var(--jp-line);
  font-weight: 700;
}

.public-job-summary-grid {
  grid-template-columns: 1.1fr 1.7fr .9fr;
  border-top: 1px solid var(--jp-line);
  border-bottom: 1px solid var(--jp-line);
  gap: 0;
  margin: 26px 0 22px;
}

.public-job-summary-grid > div {
  border: 0;
  border-right: 1px solid var(--jp-line);
  border-radius: 0;
  background: transparent;
}

.public-job-summary-grid > div:last-child {
  border-right: 0;
}

.public-job-summary-grid strong {
  font-size: 15px;
}

.public-job-image {
  height: 250px;
  border-radius: 6px;
  background:
    linear-gradient(135deg, rgba(36,95,85,.10), rgba(64,85,111,.08)),
    repeating-linear-gradient(135deg, #f8faf7 0, #f8faf7 10px, #eef2ee 10px, #eef2ee 11px);
  border: 1px solid var(--jp-line);
  color: var(--jp-sub);
}

.public-preview-anchor-nav {
  max-width: 1120px;
  border-radius: 8px;
  border-color: var(--jp-line-strong);
  box-shadow: none;
}

.preview-anchor-chip {
  border-radius: 4px;
  background: #fff;
  color: var(--jp-sub);
}

.preview-anchor-chip:hover {
  border-color: var(--jp-green);
  color: var(--jp-green-2);
  background: var(--jp-green-soft);
}

.public-job-layout {
  max-width: 1120px;
  grid-template-columns: minmax(0, 1fr) 320px;
}

.public-job-section {
  border-radius: 8px;
  border-color: var(--jp-line);
  box-shadow: none;
  background: #fff;
}

.public-job-section.tinted {
  background: #fbfcfa;
}

.public-section-label {
  border-radius: 4px;
  background: var(--jp-green);
}

.public-job-section h2 {
  font-size: 19px;
  border-bottom: 1px solid var(--jp-line);
  padding-bottom: 8px;
}

.public-job-section p {
  color: #3f4845;
}

.public-apply-card {
  border-radius: 8px;
  border-color: var(--jp-line-strong);
  box-shadow: none;
}

.apply-card-title {
  font-size: 19px;
}

.public-apply-button {
  height: 48px;
  border-radius: 6px;
  box-shadow: none;
  background: var(--jp-rust);
}

.preview-warning {
  color: var(--jp-sub);
}

.application-page {
  background: linear-gradient(180deg, #f6f7f4, #ecefeb);
}

.application-hero,
.application-card {
  border-radius: 8px;
  border-color: var(--jp-line-strong);
  box-shadow: none;
}

.application-hero h1,
.complete-title {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  font-weight: 700;
}

.apply-job-summary span,
.apply-step,
.privacy-check,
.confirm-table,
.confirm-row span {
  border-radius: 6px;
  background: var(--jp-surface-2);
  border-color: var(--jp-line);
}

.apply-step span,
.apply-step.current span,
.apply-step.done span,
.application-complete-mark {
  background: var(--jp-green);
}

.apply-step.current {
  border-color: var(--jp-green);
  background: var(--jp-green-soft);
}

.segment-pill {
  border-radius: 4px;
}

.segment-pill.active {
  background: var(--jp-green);
  border-color: var(--jp-green);
}

.field label em {
  border-radius: 4px;
  background: var(--jp-rust);
}

.mobile-device-frame {
  border-radius: 24px;
  background: #202826;
}

.mobile-device-screen {
  background: #f6f7f4;
  border-radius: 18px;
}

@media (max-width: 900px) {
  .public-job-hero h1 {
    font-size: 27px;
  }

  .public-job-summary-grid {
    grid-template-columns: 1fr;
  }

  .public-job-summary-grid > div {
    border-right: 0;
    border-bottom: 1px solid var(--jp-line);
  }

  .public-job-summary-grid > div:last-child {
    border-bottom: 0;
  }
}

/* codex v0.001.001 polish: avoid cramped action buttons and content overlap */
.job-item {
  grid-template-columns: 168px minmax(0, 1fr) 230px;
}

.job-actions {
  align-items: stretch;
}

.job-action-row {
  grid-template-columns: minmax(96px, 1fr) minmax(78px, 1fr) 42px;
}

.job-action-row .btn {
  min-width: 0;
  padding-left: 12px;
  padding-right: 12px;
  white-space: nowrap;
  writing-mode: horizontal-tb;
}

.editor-shell > .fixed-footer {
  position: fixed !important;
  left: 120px;
  right: 28px;
  bottom: 16px;
  margin: 0;
}

@media (max-width: 1180px) {
  .job-item {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .editor-shell > .fixed-footer {
    margin-left: 16px;
    margin-right: 16px;
  }
}

/* codex v0.001.002: UI direction comparison dock */
.design-concept-dock {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 220;
  width: min(344px, calc(100vw - 36px));
  border: 1px solid rgba(20, 43, 39, 0.16);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 42px rgba(31, 38, 36, 0.14);
  padding: 14px;
  color: var(--text);
}

.concept-dock-kicker {
  font-size: 11px;
  font-weight: 800;
  color: var(--primary);
  margin-bottom: 4px;
}

.concept-dock-title {
  font-weight: 900;
  margin-bottom: 5px;
}

.concept-dock-copy,
.concept-dock-note {
  font-size: 12px;
  line-height: 1.7;
  color: var(--muted);
}

.concept-switcher {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin: 12px 0 8px;
}

.concept-button {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  cursor: pointer;
  font-weight: 900;
  font-size: 12px;
  padding: 9px 8px;
}

.concept-button.active {
  border-color: var(--primary);
  background: var(--primary);
  color: #fff;
}

/* Concept A: Japanese business SaaS. This is the default, tuned for clarity and safety. */
body.ui-concept-ops .main-card,
body.ui-concept-ops .section-card,
body.ui-concept-ops .job-item,
body.ui-concept-ops .public-job-hero,
body.ui-concept-ops .public-job-section,
body.ui-concept-ops .application-card {
  transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
}

/* Concept B: executive ledger. Dense, calm, decision-table feel. */
body.ui-concept-ledger {
  --jp-bg: #f3f1eb;
  --jp-bg-2: #e9e5dc;
  --jp-surface: #fffdf8;
  --jp-surface-2: #f7f3eb;
  --jp-ink: #211f1a;
  --jp-sub: #6a6257;
  --jp-line: #d8d0c2;
  --jp-line-strong: #b9ad9c;
  --jp-green: #31443d;
  --jp-green-2: #1f312c;
  --jp-rust: #8d5a2e;
  --primary: var(--jp-green);
  --primary-strong: var(--jp-green-2);
  --orange: var(--jp-rust);
  --surface: var(--jp-surface);
  --surface-soft: var(--jp-surface-2);
  --line: var(--jp-line);
  background:
    linear-gradient(90deg, rgba(49, 68, 61, .042) 1px, transparent 1px),
    linear-gradient(180deg, rgba(49, 68, 61, .032) 1px, transparent 1px),
    linear-gradient(180deg, var(--jp-bg), var(--jp-bg-2));
}

body.ui-concept-ledger .page-title,
body.ui-concept-ledger .editor-title,
body.ui-concept-ledger .public-job-hero h1,
body.ui-concept-ledger .application-hero h1 {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  font-weight: 800;
}

body.ui-concept-ledger .main-card,
body.ui-concept-ledger .section-card,
body.ui-concept-ledger .filter-band,
body.ui-concept-ledger .list-card,
body.ui-concept-ledger .job-item,
body.ui-concept-ledger .public-job-hero,
body.ui-concept-ledger .public-job-section,
body.ui-concept-ledger .application-card {
  border-radius: 4px;
  box-shadow: none;
  background: var(--jp-surface);
}

body.ui-concept-ledger .job-item {
  grid-template-columns: 132px minmax(0, 1fr) 238px;
  border-left: 5px solid var(--primary);
}

body.ui-concept-ledger .job-thumb {
  min-height: 128px;
  background: #394943;
  border-radius: 3px;
}

body.ui-concept-ledger .metric,
body.ui-concept-ledger .meta-kv,
body.ui-concept-ledger .info-card,
body.ui-concept-ledger .public-job-summary-grid > div {
  background: #fbf8f1;
  border-radius: 3px;
}

body.ui-concept-ledger .btn,
body.ui-concept-ledger .local-tab,
body.ui-concept-ledger .top-tab,
body.ui-concept-ledger .input,
body.ui-concept-ledger .textarea,
body.ui-concept-ledger .select,
body.ui-concept-ledger .readonly-trigger {
  border-radius: 3px;
}

body.ui-concept-ledger .public-job-hero {
  border-top-width: 5px;
}

body.ui-concept-ledger .design-concept-dock {
  background: rgba(255, 253, 248, 0.96);
}

/* Concept C: recruiting growth. Slightly more advanced, still B2B-safe. */
body.ui-concept-growth {
  --jp-bg: #eef4f6;
  --jp-bg-2: #e6edf0;
  --jp-surface: #ffffff;
  --jp-surface-2: #f4f8fa;
  --jp-ink: #17212b;
  --jp-sub: #5a6672;
  --jp-line: #d2dde4;
  --jp-line-strong: #afc0cb;
  --jp-green: #17686d;
  --jp-green-2: #0e4d55;
  --jp-indigo: #2d4a7a;
  --jp-rust: #bd6a35;
  --primary: var(--jp-green);
  --primary-strong: var(--jp-green-2);
  --orange: var(--jp-rust);
  --surface-soft: var(--jp-surface-2);
  --line: var(--jp-line);
  background:
    radial-gradient(circle at 8% 14%, rgba(23, 104, 109, .10), transparent 24%),
    linear-gradient(180deg, var(--jp-bg), var(--jp-bg-2));
}

body.ui-concept-growth .sidebar,
body.ui-concept-growth .icon-rail {
  background: linear-gradient(180deg, rgba(12, 48, 55, .96), rgba(22, 69, 76, .94));
  color: #eaf5f4;
  border-right: 0;
}

body.ui-concept-growth .brand-title,
body.ui-concept-growth .brand-sub,
body.ui-concept-growth .nav-item,
body.ui-concept-growth .rail-icon {
  color: #eaf5f4;
}

body.ui-concept-growth .nav-item.active,
body.ui-concept-growth .rail-icon.active {
  background: rgba(255, 255, 255, .14);
  color: #fff;
}

body.ui-concept-growth .main-card,
body.ui-concept-growth .section-card,
body.ui-concept-growth .filter-band,
body.ui-concept-growth .list-card,
body.ui-concept-growth .job-item,
body.ui-concept-growth .application-card {
  border-color: rgba(45, 74, 122, .16);
  box-shadow: 0 18px 38px rgba(23, 33, 43, .08);
}

body.ui-concept-growth .utility-bar,
body.ui-concept-growth .editor-header {
  background:
    linear-gradient(90deg, rgba(23, 104, 109, .08), rgba(45, 74, 122, .06)),
    #fff;
}

body.ui-concept-growth .job-thumb {
  background:
    linear-gradient(135deg, rgba(23,104,109,.90), rgba(45,74,122,.90)),
    repeating-linear-gradient(135deg, rgba(255,255,255,.16) 0 1px, transparent 1px 10px);
}

body.ui-concept-growth .ai-assist-card,
body.ui-concept-growth .notice-box,
body.ui-concept-growth .apply-help-box {
  background: linear-gradient(135deg, rgba(23, 104, 109, .08), rgba(45, 74, 122, .05));
  border-color: rgba(23, 104, 109, .20);
}

body.ui-concept-growth .public-job-hero {
  background:
    linear-gradient(135deg, rgba(23, 104, 109, .07), rgba(45, 74, 122, .055)),
    #fff;
  border-top-color: var(--jp-green);
}

body.ui-concept-growth .public-job-section {
  box-shadow: 0 16px 32px rgba(23, 33, 43, .06);
}

body.ui-concept-growth .design-concept-dock {
  border-color: rgba(23, 104, 109, .22);
}

@media (max-width: 900px) {
  .design-concept-dock {
    position: static;
    width: auto;
    margin: 12px;
  }
}

/* v0_001_003: brand-rich redesign, not a color-only theme. */
:root {
  --nijiya-ink: #102724;
  --nijiya-forest: #123f3a;
  --nijiya-green: #1b6a63;
  --nijiya-mint: #e8efea;
  --nijiya-paper: #f8f5ec;
  --nijiya-paper-2: #f1eadc;
  --nijiya-rust: #c87936;
  --nijiya-rust-2: #a65f2d;
  --nijiya-bluegray: #263f54;
  --primary: var(--nijiya-green);
  --primary-strong: var(--nijiya-forest);
  --primary-soft: #e7f2ef;
  --orange: var(--nijiya-rust);
  --orange-strong: var(--nijiya-rust-2);
  --text: var(--nijiya-ink);
  --muted: #5f6f68;
  --line: #d8ded5;
  --soft-line: #e9e7dc;
  --surface: #fffdfa;
  --surface-soft: #f7f4eb;
  --shadow: 0 18px 46px rgba(20, 34, 31, .12);
}

html,
body {
  font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
  background:
    linear-gradient(90deg, rgba(18, 63, 58, .04), rgba(200, 121, 54, .035)),
    url("assets/background-quiet-grid.svg");
  background-size: auto, 420px 420px;
  color: var(--nijiya-ink);
}

.workspace {
  position: relative;
}

.workspace::before {
  content: "";
  position: fixed;
  right: 2vw;
  bottom: -90px;
  width: 380px;
  height: 380px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(200, 121, 54, .12), transparent 64%);
  pointer-events: none;
}

.main-card,
.public-job-hero,
.public-preview-anchor-nav,
.public-job-section,
.public-apply-card,
.application-card,
.application-hero {
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,253,248,.96)),
    var(--surface);
  border-color: rgba(18, 63, 58, .14);
  box-shadow: var(--shadow);
}

.sidebar {
  background:
    linear-gradient(180deg, rgba(255,253,248,.96), rgba(248,245,236,.94)),
    var(--surface);
  border-right: 1px solid rgba(18, 63, 58, .14);
  box-shadow: 14px 0 40px rgba(18, 63, 58, .06);
}

.brand-box {
  align-items: flex-start;
  border-bottom: 1px solid rgba(18, 63, 58, .12);
  margin-bottom: 18px;
  padding: 10px 4px 22px;
}

.brand-mark {
  width: 48px;
  height: 48px;
  flex: 0 0 auto;
  border-radius: 16px;
  box-shadow: 0 16px 26px rgba(18, 63, 58, .18);
}

.brand-mark.auth-mark {
  width: 52px;
  height: 52px;
}

.brand-mark.rail-mark {
  width: 48px;
  height: 48px;
  margin-bottom: 8px;
}

.brand-icon {
  background: var(--nijiya-forest);
}

.brand-title {
  font-weight: 900;
  letter-spacing: -.02em;
}

.brand-sub {
  color: #68766f;
  line-height: 1.5;
}

.nav-list {
  gap: 10px;
}

.nav-item,
.rail-icon {
  position: relative;
  gap: 12px;
  border: 1px solid transparent;
  border-radius: 18px;
  color: #54665f;
  font-weight: 800;
}

.nav-item:hover,
.rail-icon:hover {
  background: rgba(27, 106, 99, .06);
  border-color: rgba(27, 106, 99, .12);
}

.nav-item.active,
.rail-icon.active {
  background:
    linear-gradient(90deg, rgba(27, 106, 99, .14), rgba(200, 121, 54, .08)),
    #fffdfa;
  border-color: rgba(27, 106, 99, .2);
  color: var(--nijiya-forest);
  box-shadow: 0 12px 22px rgba(18, 63, 58, .08);
}

.nav-icon {
  width: 28px;
  height: 28px;
  border-radius: 11px;
  display: inline-grid;
  place-items: center;
  background: rgba(18, 63, 58, .08);
  color: currentColor;
  flex: 0 0 auto;
}

.nav-icon svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.nav-dot {
  display: none;
}

.icon-rail {
  background:
    linear-gradient(180deg, var(--nijiya-forest), #173c38);
  border-right: 0;
  color: #f8f5ec;
  box-shadow: 14px 0 36px rgba(18, 63, 58, .18);
}

.icon-rail .rail-icon {
  width: 58px;
  height: 58px;
  padding: 0;
  justify-content: center;
  color: rgba(248,245,236,.78);
}

.icon-rail .rail-icon.active {
  background: rgba(255,255,255,.14);
  color: #fff;
  border-color: rgba(255,255,255,.22);
}

.icon-rail .nav-icon {
  background: transparent;
}

.rail-label {
  display: none;
}

.utility-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px) auto;
  align-items: center;
  background:
    radial-gradient(circle at 82% 10%, rgba(200, 121, 54, .13), transparent 34%),
    linear-gradient(135deg, #fffdfa, #f3f4ee);
}

.utility-left {
  max-width: none;
}

.utility-visual {
  min-height: 98px;
  border: 1px solid rgba(18, 63, 58, .12);
  border-radius: 24px;
  padding: 12px 14px;
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 12px;
  align-items: center;
  background:
    linear-gradient(135deg, rgba(232,239,234,.8), rgba(248,245,236,.94));
}

.utility-visual img {
  width: 76px;
  height: 76px;
}

.utility-visual strong,
.utility-visual span {
  display: block;
}

.utility-visual strong {
  font-size: 14px;
  margin-bottom: 4px;
}

.utility-visual span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.55;
}

.eyebrow {
  color: var(--nijiya-green);
}

.page-title,
.editor-title {
  font-size: clamp(28px, 3vw, 38px);
  letter-spacing: -.04em;
}

.editor-header {
  background:
    radial-gradient(circle at 78% 12%, rgba(200, 121, 54, .12), transparent 30%),
    linear-gradient(135deg, #fffdfa, #f3f4ee);
}

.editor-title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px) auto;
  gap: 22px;
  align-items: center;
}

.editor-pipeline-card {
  border: 1px solid rgba(18, 63, 58, .13);
  border-radius: 24px;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(232,239,234,.84), rgba(255,253,248,.96));
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  align-items: center;
}

.editor-pipeline-card img {
  width: 72px;
  height: 72px;
}

.editor-pipeline-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  position: relative;
}

.editor-pipeline-steps::before {
  content: "";
  position: absolute;
  left: 12%;
  right: 12%;
  top: 50%;
  height: 2px;
  transform: translateY(-50%);
  background: rgba(27, 106, 99, .18);
}

.editor-pipeline-steps span {
  position: relative;
  z-index: 1;
  min-height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #fffdfa;
  border: 1px solid rgba(27, 106, 99, .16);
  color: var(--nijiya-forest);
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.editor-save-group {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.filter-band,
.metric,
.meta-kv,
.info-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(248,245,236,.72));
}

.list-card {
  padding: 24px;
}

.job-item {
  grid-template-columns: 268px minmax(0, 1fr) 190px;
  gap: 22px;
  border-radius: 28px;
  padding: 20px;
  background:
    linear-gradient(135deg, #fffdfa, #fbfaf4);
  border-color: rgba(18, 63, 58, .13);
  box-shadow: 0 12px 26px rgba(18, 63, 58, .055);
}

.job-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 20px 44px rgba(18, 63, 58, .11);
}

.job-thumb {
  position: relative;
  min-height: 228px;
  border-radius: 24px;
  padding: 18px;
  isolation: isolate;
  background: var(--nijiya-forest);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
}

.job-thumb::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(9, 34, 31, .08), rgba(9, 34, 31, .54));
}

.job-thumb-art {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -2;
}

.job-thumb-top {
  width: max-content;
  max-width: 100%;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(255,255,255,.86);
  color: var(--nijiya-forest);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .03em;
}

.job-thumb-bottom {
  font-size: 24px;
  text-shadow: 0 2px 10px rgba(0,0,0,.22);
}

.job-thumb-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.job-thumb-strip span {
  border-radius: 999px;
  padding: 5px 8px;
  background: rgba(255,255,255,.16);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  backdrop-filter: blur(8px);
}

.job-name {
  font-size: 25px;
  letter-spacing: -.03em;
}

.status-pill.live {
  background: #def4e9;
  color: #126144;
}

.status-pill.prep {
  background: #fff1dd;
  color: #9d5e1e;
}

.btn {
  border-radius: 14px;
}

.btn.primary,
.concept-button.active,
.preview-device-button.active {
  background: linear-gradient(180deg, var(--nijiya-green), var(--nijiya-forest));
}

.btn.orange,
.public-apply-button {
  background: linear-gradient(180deg, #d88b45, var(--nijiya-rust-2));
}

.auth-logo {
  align-items: center;
}

.public-preview-page {
  background:
    linear-gradient(180deg, rgba(248,245,236,.8), rgba(232,239,234,.78)),
    url("assets/background-quiet-grid.svg");
  background-size: auto, 420px 420px;
}

.preview-mode-bar {
  background: rgba(255,253,248,.95);
  border-bottom-color: rgba(18, 63, 58, .14);
}

.public-job-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) 420px;
  gap: 30px;
  align-items: center;
  max-width: 1180px;
  padding: 48px;
  overflow: hidden;
}

.public-job-hero::before {
  height: 7px;
  background: linear-gradient(90deg, var(--nijiya-green), var(--nijiya-rust));
}

.public-hero-content {
  position: relative;
  z-index: 2;
}

.public-job-company {
  width: max-content;
  max-width: 100%;
  border-left: 4px solid var(--nijiya-green);
  padding: 8px 12px;
  background: rgba(255,255,255,.62);
  color: var(--nijiya-forest);
  font-size: 15px;
}

.public-job-hero h1 {
  max-width: 720px;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  font-size: clamp(34px, 4vw, 50px);
  letter-spacing: -.055em;
}

.public-job-subtitle {
  color: #44564f;
  line-height: 1.8;
}

.public-job-tag {
  background: #fffdfa;
  border-color: rgba(18, 63, 58, .16);
  color: var(--nijiya-green);
}

.public-job-summary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.public-job-summary-grid > div {
  background: rgba(255,255,255,.72);
  border-color: rgba(18, 63, 58, .13);
}

.public-hero-visual {
  position: relative;
  min-height: 360px;
}

.public-hero-visual img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 26px 38px rgba(18,63,58,.16));
}

.public-hero-badge {
  position: absolute;
  border-radius: 999px;
  background: rgba(255,253,248,.92);
  border: 1px solid rgba(18, 63, 58, .12);
  padding: 9px 13px;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 12px 26px rgba(18,63,58,.12);
}

.public-hero-badge.badge-a {
  top: 32px;
  left: 18px;
  color: var(--nijiya-green);
}

.public-hero-badge.badge-b {
  right: 16px;
  bottom: 42px;
  color: var(--nijiya-rust-2);
}

.public-job-image {
  display: none;
}

.public-job-section {
  border-radius: 22px;
  grid-template-columns: 68px 1fr;
}

.public-section-label {
  background: var(--nijiya-green);
  border-radius: 18px;
}

.public-apply-card {
  border-radius: 24px;
}

.application-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 230px;
  gap: 24px;
  align-items: center;
  overflow: hidden;
}

.application-hero-visual {
  border-radius: 26px;
  padding: 18px;
  min-height: 180px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(232,239,234,.9), rgba(248,245,236,.95));
  border: 1px solid rgba(18, 63, 58, .12);
}

.application-hero-visual img {
  width: 130px;
  height: 130px;
}

.application-hero-visual span {
  color: var(--nijiya-forest);
  font-weight: 900;
}

.apply-step.current,
.apply-step.done {
  border-color: rgba(27, 106, 99, .26);
  background: #e8efea;
}

.apply-step.current span,
.apply-step.done span,
.application-complete-mark {
  background: var(--nijiya-green);
}

@media (max-width: 1180px) {
  .utility-bar {
    grid-template-columns: 1fr;
  }

  .editor-title-row {
    grid-template-columns: 1fr;
  }

  .editor-save-group {
    justify-content: flex-start;
  }

  .utility-visual {
    display: none;
  }

  .job-item {
    grid-template-columns: 1fr;
  }

  .job-thumb {
    min-height: 260px;
  }
}

@media (max-width: 980px) {
  .public-job-hero,
  .application-hero {
    grid-template-columns: 1fr;
  }

  .public-hero-visual {
    min-height: 260px;
  }
}

@media (max-width: 760px) {
  .sidebar {
    width: 100%;
  }

  .brand-box {
    padding-inline: 0;
  }

  .public-job-summary-grid {
    grid-template-columns: 1fr;
  }

  .public-job-hero {
    padding: 28px;
  }
}

/* v0_001_004: premium SaaS composition pass. Built from density, hierarchy, and interaction placement. */
:root {
  --premium-bg: #f6f7f8;
  --premium-grid: rgba(16, 24, 40, .035);
  --premium-ink: #111318;
  --premium-sub: #667085;
  --premium-faint: #98a2b3;
  --premium-line: #e4e7ec;
  --premium-line-strong: #cfd4dc;
  --premium-panel: #ffffff;
  --premium-panel-2: #fbfcfd;
  --premium-black: #0b0f14;
  --premium-accent: #12756b;
  --premium-accent-2: #0f5f57;
  --premium-warm: #c57a3a;
  --primary: var(--premium-accent);
  --primary-strong: var(--premium-accent-2);
  --primary-soft: #edf7f5;
  --orange: var(--premium-warm);
  --orange-strong: #9f5b2b;
  --text: var(--premium-ink);
  --muted: var(--premium-sub);
  --line: var(--premium-line);
  --soft-line: #eef0f3;
  --surface: var(--premium-panel);
  --surface-soft: var(--premium-panel-2);
  --shadow: 0 16px 40px rgba(16, 24, 40, .08);
}

html,
body {
  font-family: "Yu Gothic UI", "Yu Gothic", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
  background:
    linear-gradient(90deg, var(--premium-grid) 1px, transparent 1px),
    linear-gradient(180deg, var(--premium-grid) 1px, transparent 1px),
    var(--premium-bg);
  background-size: 32px 32px, 32px 32px, auto;
}

.app-shell {
  min-height: 100vh;
}

.standard-shell .sidebar {
  width: 272px;
  padding: 18px 14px;
  background: #fff;
  border-right: 1px solid var(--premium-line);
  box-shadow: none;
}

.workspace {
  padding: 14px 18px 96px;
}

.workspace::before,
.utility-visual,
.public-hero-visual img,
.application-hero-visual img,
.editor-pipeline-card img {
  display: none !important;
}

.brand-box {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 10px;
  align-items: center;
  padding: 8px 8px 16px;
  margin: 0 0 10px;
  border-bottom: 0;
}

.brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  box-shadow: 0 10px 22px rgba(16, 24, 40, .14);
}

.brand-title {
  font-size: 13px;
  letter-spacing: -.01em;
  line-height: 1.35;
}

.brand-sub {
  margin-top: 2px;
  font-size: 11px;
  color: var(--premium-faint);
}

.workspace-chip {
  margin: 8px 6px 18px;
  padding: 11px 12px;
  border: 1px solid var(--premium-line);
  border-radius: 14px;
  background: linear-gradient(180deg, #fff, #fbfcfd);
}

.workspace-chip span,
.sidebar-footer-card span {
  display: block;
  color: var(--premium-faint);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.workspace-chip strong {
  display: block;
  margin-top: 3px;
  font-size: 13px;
}

.nav-list {
  gap: 3px;
}

.nav-section-label {
  padding: 0 12px 8px;
  color: var(--premium-faint);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .1em;
}

.nav-item {
  height: 40px;
  padding: 0 10px;
  border-radius: 10px;
  color: #4b5563;
  font-size: 13px;
  font-weight: 760;
  background: transparent;
}

.nav-item.active {
  color: var(--premium-ink);
  background: #f1f3f5;
  border-color: transparent;
  box-shadow: none;
}

.nav-item.active::before {
  content: "";
  position: absolute;
  left: -7px;
  width: 3px;
  height: 18px;
  border-radius: 999px;
  background: var(--premium-black);
}

.nav-icon {
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: transparent;
}

.nav-icon svg {
  width: 18px;
  height: 18px;
}

.nav-icon svg path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.sidebar-footer-card {
  margin: 18px 6px 0;
  padding: 13px 12px;
  border: 1px solid var(--premium-line);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(17, 19, 24, .04), rgba(18, 117, 107, .035)),
    #fff;
}

.sidebar-footer-card strong {
  display: block;
  margin: 5px 0 4px;
  font-size: 13px;
}

.sidebar-footer-card small {
  display: block;
  color: var(--premium-sub);
  line-height: 1.55;
}

.premium-command-bar {
  position: sticky;
  top: 0;
  z-index: 45;
  min-height: 58px;
  margin-bottom: 12px;
  padding: 8px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(228, 231, 236, .9);
  border-radius: 16px;
  background: rgba(255, 255, 255, .88);
  backdrop-filter: blur(18px);
  box-shadow: 0 10px 28px rgba(16, 24, 40, .06);
}

.command-left,
.command-right {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.workspace-switcher,
.command-search,
.icon-button {
  border: 1px solid var(--premium-line);
  background: #fff;
  color: var(--premium-ink);
}

.workspace-switcher {
  height: 40px;
  border-radius: 12px;
  padding: 0 12px 0 7px;
  display: flex;
  align-items: center;
  gap: 9px;
}

.command-mark {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  box-shadow: none;
}

.workspace-switcher span {
  color: var(--premium-sub);
  font-size: 12px;
  font-weight: 800;
}

.workspace-switcher strong {
  font-size: 12px;
}

.command-search {
  width: min(44vw, 560px);
  height: 40px;
  border-radius: 12px;
  padding: 0 8px 0 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--premium-sub);
  text-align: left;
}

.command-search-icon {
  color: var(--premium-ink);
  font-size: 17px;
}

.command-search kbd {
  min-width: 38px;
  height: 24px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: #f2f4f7;
  color: #475467;
  font-size: 11px;
  font-weight: 900;
}

.sync-pill {
  height: 32px;
  border: 1px solid var(--premium-line);
  border-radius: 999px;
  padding: 0 11px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: #fff;
  color: var(--premium-sub);
  font-size: 12px;
  font-weight: 760;
}

.sync-pill i {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: #12b76a;
  box-shadow: 0 0 0 4px rgba(18, 183, 106, .12);
}

.icon-button {
  width: 36px;
  height: 36px;
  border-radius: 11px;
  display: grid;
  place-items: center;
}

.icon-button .nav-icon {
  width: 18px;
  height: 18px;
}

.main-card,
.premium-surface {
  border-radius: 18px;
  background: var(--premium-panel);
  border: 1px solid var(--premium-line);
  box-shadow: 0 16px 40px rgba(16, 24, 40, .06);
}

.premium-page-head,
.utility-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px auto;
  gap: 18px;
  align-items: center;
  padding: 24px 28px 20px;
  background:
    linear-gradient(180deg, #fff, #fbfcfd);
  border-bottom: 1px solid var(--premium-line);
}

.eyebrow {
  color: var(--premium-sub);
  letter-spacing: .08em;
  font-size: 11px;
}

.page-title,
.editor-title {
  font-size: clamp(28px, 2.3vw, 36px);
  line-height: 1.05;
  letter-spacing: -.055em;
}

.page-copy,
.section-subcopy,
.panel-copy,
.modal-copy,
.footer-copy {
  color: var(--premium-sub);
}

.premium-signal-panel {
  padding: 10px;
  display: grid;
  gap: 8px;
  border: 1px solid var(--premium-line);
  border-radius: 14px;
  background: #fff;
}

.signal-row {
  display: grid;
  grid-template-columns: 64px 32px 1fr;
  align-items: center;
  gap: 10px;
  font-size: 12px;
}

.signal-row span {
  color: var(--premium-sub);
  font-weight: 760;
}

.signal-row strong {
  font-size: 13px;
}

.signal-bar {
  height: 6px;
  overflow: hidden;
  border-radius: 999px;
  background: #eef2f6;
}

.signal-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--premium-accent);
}

.signal-bar.warn i {
  background: var(--premium-warm);
}

.list-page {
  padding: 0 20px 22px;
}

.local-tabs {
  padding: 14px 0;
  gap: 4px;
}

.local-tab {
  min-height: 34px;
  border-radius: 9px;
  padding: 0 12px;
  background: transparent;
  border-color: transparent;
  color: var(--premium-sub);
  font-size: 13px;
}

.local-tab.active {
  color: var(--premium-ink);
  background: #f2f4f7;
  border-color: transparent;
}

.ops-overview-strip {
  margin: 0 0 12px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--premium-line);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
}

.ops-lane {
  position: relative;
  min-height: 76px;
  padding: 14px 16px 13px 48px;
  border-right: 1px solid var(--premium-line);
}

.ops-lane:last-child {
  border-right: 0;
}

.ops-lane span {
  position: absolute;
  left: 16px;
  top: 16px;
  width: 22px;
  height: 22px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: #f2f4f7;
  color: #475467;
  font-size: 11px;
  font-weight: 900;
}

.ops-lane.active span {
  background: var(--premium-black);
  color: #fff;
}

.ops-lane strong,
.ops-lane small {
  display: block;
}

.ops-lane strong {
  font-size: 13px;
  margin-bottom: 4px;
}

.ops-lane small {
  color: var(--premium-sub);
  line-height: 1.5;
}

.filter-band {
  border-radius: 16px;
  padding: 16px;
  background: #fff;
  border-color: var(--premium-line);
}

.summary-grid {
  gap: 8px;
}

.metric {
  border-radius: 12px;
  padding: 13px 14px;
  background: #fbfcfd;
  border-color: var(--premium-line);
}

.metric-value {
  font-size: 24px;
  letter-spacing: -.04em;
}

.filters {
  gap: 10px;
}

.input,
.select,
.textarea,
.readonly-trigger {
  min-height: 40px;
  border-radius: 10px;
  border: 1px solid var(--premium-line-strong);
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(16, 24, 40, .02);
}

.input:focus,
.select:focus,
.textarea:focus {
  border-color: #111318;
  box-shadow: 0 0 0 3px rgba(17, 19, 24, .08);
}

.bulk-action-band {
  margin-top: 12px;
  border-radius: 12px;
  border-color: var(--premium-line);
  background: #fbfcfd;
}

.list-card,
.section-card,
.placeholder-card {
  border-radius: 16px;
  border-color: var(--premium-line);
  box-shadow: none;
}

.list-card {
  margin-top: 12px;
  padding: 18px;
}

.premium-list-head {
  align-items: center;
}

.density-toggle {
  height: 32px;
  padding: 3px;
  border-radius: 10px;
  display: inline-flex;
  gap: 3px;
  border: 1px solid var(--premium-line);
  background: #f7f8fa;
}

.density-toggle span {
  min-width: 72px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: var(--premium-sub);
  font-size: 12px;
  font-weight: 800;
}

.density-toggle span.active {
  color: var(--premium-ink);
  background: #fff;
  box-shadow: 0 1px 2px rgba(16, 24, 40, .08);
}

.job-table-head {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) 290px;
  gap: 16px;
  padding: 0 16px 9px 96px;
  color: var(--premium-faint);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.card-list {
  gap: 8px;
}

.job-item {
  grid-template-columns: 72px minmax(0, 1fr) 290px !important;
  gap: 16px;
  align-items: center;
  min-height: 124px;
  padding: 14px 16px 14px 96px;
  border-radius: 14px;
  background: #fff;
  border-color: var(--premium-line);
  box-shadow: none;
}

.job-item:hover {
  transform: none;
  border-color: #b9c0ca;
  box-shadow: 0 10px 28px rgba(16, 24, 40, .08);
}

.job-item.is-selected {
  border-color: var(--premium-black);
  box-shadow: 0 0 0 3px rgba(17, 19, 24, .06);
}

.job-select-check {
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
  width: 56px;
  height: 56px;
  padding: 0;
  justify-content: center;
  border-radius: 14px;
  background: #fbfcfd;
  box-shadow: none;
}

.job-select-check span {
  display: none;
}

.job-select-check input {
  width: 18px;
  height: 18px;
  accent-color: #111318;
}

.job-thumb {
  min-height: 68px;
  height: 68px;
  border-radius: 16px;
  padding: 0;
  display: grid;
  place-items: center;
  background: #f2f4f7 !important;
  color: var(--premium-ink);
  box-shadow: inset 0 0 0 1px var(--premium-line);
}

.job-thumb::after {
  display: none;
}

.job-thumb::before {
  content: "支";
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #111318;
  color: #fff;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: -.04em;
}

.job-thumb-manager::before {
  content: "管";
}

.job-thumb-driver::before {
  content: "送";
}

.job-thumb-art,
.job-thumb-top,
.job-thumb-bottom,
.job-thumb-strip {
  display: none;
}

.job-title-row {
  margin-bottom: 6px;
}

.status-pill,
.mini-pill {
  border-radius: 8px;
  padding: 5px 8px;
  font-size: 11px;
}

.status-pill.live {
  background: #ecfdf3;
  color: #067647;
}

.status-pill.prep {
  background: #fffaeb;
  color: #b54708;
}

.status-pill.stop {
  background: #f2f4f7;
  color: #667085;
}

.job-name {
  font-size: 20px;
  line-height: 1.3;
  letter-spacing: -.035em;
}

.job-sub {
  margin-bottom: 9px;
}

.job-flow-line {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
  max-width: 360px;
  margin: 10px 0 0;
}

.job-flow-line span {
  position: relative;
  height: 6px;
  border-radius: 999px;
  overflow: hidden;
  text-indent: -999px;
  background: #eef2f6;
}

.job-flow-line span.done {
  background: #111318;
}

.job-meta-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.meta-kv {
  min-height: 0;
  border-radius: 10px;
  padding: 7px 9px;
  background: #fbfcfd;
  border-color: var(--premium-line);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  max-width: 100%;
}

.meta-k {
  font-size: 10px;
  margin-bottom: 0;
  white-space: nowrap;
}

.meta-v {
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.job-actions {
  height: 100%;
  justify-content: center;
  gap: 10px;
}

.job-action-row {
  grid-template-columns: 1fr 1fr 38px;
  gap: 8px;
}

.job-more-button {
  width: 38px;
  min-height: 38px;
  border-radius: 10px;
  color: var(--premium-ink);
  font-size: 20px;
}

.btn {
  min-height: 38px;
  border-radius: 10px;
  font-weight: 800;
}

.btn.primary {
  background: #111318;
  color: #fff;
}

.btn.orange,
.public-apply-button {
  background: var(--premium-warm);
}

.btn.ghost {
  background: #fff;
  border-color: var(--premium-line-strong);
}

.list-footer-bar,
.fixed-footer {
  border-radius: 14px;
  background: rgba(255,255,255,.92);
}

.editor-shell .icon-rail,
.settings-detail-shell .icon-rail {
  width: 76px;
  padding: 16px 10px;
  background: #0b0f14;
  box-shadow: none;
}

.brand-mark.rail-mark {
  width: 40px;
  height: 40px;
}

.icon-rail .rail-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  color: rgba(255,255,255,.62);
}

.icon-rail .rail-icon.active {
  background: rgba(255,255,255,.12);
  color: #fff;
}

.editor-header {
  padding: 24px 28px;
  background: #fff;
  border-bottom: 1px solid var(--premium-line);
}

.editor-title-row {
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px) auto;
  align-items: center;
}

.editor-pipeline-card {
  min-height: 72px;
  grid-template-columns: 1fr;
  border-radius: 16px;
  background: #fbfcfd;
  border-color: var(--premium-line);
}

.editor-pipeline-steps span {
  min-height: 32px;
  border-radius: 9px;
  color: var(--premium-ink);
}

.tab-strip {
  padding: 0 28px;
  gap: 18px;
  border-bottom: 1px solid var(--premium-line);
}

.top-tab {
  padding: 14px 0;
  color: var(--premium-sub);
}

.top-tab[aria-current="page"] {
  color: var(--premium-ink);
  border-bottom-color: var(--premium-black);
}

.editor-main {
  grid-template-columns: 232px minmax(0, 1fr);
  gap: 20px;
  padding: 20px 24px 0;
}

.toc {
  top: 86px;
  border-radius: 14px;
  background: #fbfcfd;
  border-color: var(--premium-line);
}

.toc-item {
  border-radius: 9px;
}

.toc-item.active {
  color: var(--premium-ink);
  background: #eef2f6;
}

.public-preview-page {
  background:
    linear-gradient(90deg, rgba(16, 24, 40, .035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(16, 24, 40, .035) 1px, transparent 1px),
    #f6f7f8;
  background-size: 32px 32px;
}

.preview-mode-bar {
  background: rgba(255,255,255,.9);
  border-bottom: 1px solid var(--premium-line);
  box-shadow: none;
}

.public-job-hero {
  max-width: 1180px;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 38px;
  border-radius: 22px;
  padding: 54px 58px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(16, 24, 40, .08);
}

.public-job-hero::before {
  height: 4px;
  background: #111318;
}

.public-job-company {
  border-left: 0;
  padding: 0;
  background: transparent;
  color: var(--premium-sub);
  font-size: 13px;
}

.public-job-hero h1 {
  font-family: "Yu Gothic UI", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  max-width: 760px;
  font-size: clamp(40px, 5vw, 62px);
  line-height: 1.08;
  letter-spacing: -.075em;
}

.public-job-tags {
  margin-bottom: 28px;
}

.public-job-tag,
.preview-anchor-chip {
  border-radius: 9px;
  background: #fbfcfd;
  border-color: var(--premium-line);
  color: var(--premium-ink);
}

.public-job-summary-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-top: 1px solid var(--premium-line);
  padding-top: 18px;
}

.public-job-summary-grid > div {
  border-radius: 12px;
  background: #fbfcfd;
}

.public-hero-visual {
  min-height: 340px;
  display: grid;
  gap: 14px;
  align-content: center;
}

.premium-proof-card,
.premium-mini-window {
  border: 1px solid var(--premium-line);
  border-radius: 20px;
  background: #fbfcfd;
  box-shadow: 0 18px 48px rgba(16, 24, 40, .08);
}

.premium-proof-card {
  padding: 22px;
}

.premium-proof-card span {
  color: var(--premium-faint);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.premium-proof-card strong {
  display: block;
  margin: 9px 0 18px;
  font-size: 22px;
  line-height: 1.35;
}

.proof-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.proof-metrics em {
  border: 1px solid var(--premium-line);
  border-radius: 999px;
  padding: 6px 9px;
  background: #fff;
  font-style: normal;
  font-size: 11px;
  font-weight: 900;
}

.proof-line {
  height: 7px;
  margin-top: 18px;
  overflow: hidden;
  border-radius: 999px;
  background: #eef2f6;
}

.proof-line i {
  display: block;
  height: 100%;
  background: #111318;
}

.premium-mini-window {
  padding: 16px;
  display: grid;
  grid-template-columns: 9px 9px 9px 1fr;
  gap: 8px;
  align-items: center;
}

.premium-mini-window span {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #d0d5dd;
}

.premium-mini-window strong {
  justify-self: end;
  font-size: 12px;
  color: var(--premium-sub);
}

.public-job-layout {
  max-width: 1180px;
  grid-template-columns: minmax(0, 1fr) 316px;
}

.public-preview-anchor-nav,
.public-job-section,
.public-apply-card {
  border-radius: 18px;
  border-color: var(--premium-line);
  box-shadow: 0 10px 26px rgba(16, 24, 40, .055);
}

.public-section-label {
  border-radius: 13px;
  background: #111318;
}

.public-apply-card {
  top: 84px;
}

.application-page {
  background: #f6f7f8;
}

.application-hero {
  grid-template-columns: minmax(0, 1fr) 180px;
  border-radius: 22px;
  background: #fff;
}

.application-hero-visual {
  min-height: 150px;
  border-radius: 18px;
  background: #fbfcfd;
}

.apply-flow-card {
  display: grid;
  gap: 8px;
  text-align: center;
}

.apply-flow-card strong {
  font-size: 26px;
  letter-spacing: -.04em;
}

.apply-flow-card span {
  border: 1px solid var(--premium-line);
  border-radius: 999px;
  padding: 6px 12px;
  background: #fff;
  font-size: 12px;
  font-weight: 900;
}

.apply-step.current,
.apply-step.done {
  border-color: #111318;
  background: #f7f8fa;
}

.apply-step.current span,
.apply-step.done span,
.application-complete-mark {
  background: #111318;
}

@media (max-width: 1280px) {
  .premium-page-head,
  .utility-bar,
  .editor-title-row {
    grid-template-columns: 1fr;
  }

  .command-search {
    width: min(60vw, 520px);
  }

  .premium-signal-panel {
    max-width: 440px;
  }

  .job-table-head {
    display: none;
  }

  .job-item {
    grid-template-columns: 64px minmax(0, 1fr) !important;
  }

  .job-actions {
    grid-column: 1 / -1;
    margin-left: 80px;
  }

  .job-meta-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .standard-shell {
    display: block;
  }

  .standard-shell .sidebar {
    width: auto;
    border-right: 0;
    border-bottom: 1px solid var(--premium-line);
  }

  .premium-command-bar,
  .command-left,
  .command-right {
    flex-wrap: wrap;
  }

  .command-search {
    width: 100%;
  }

  .ops-overview-strip,
  .public-job-hero,
  .application-hero {
    grid-template-columns: 1fr;
  }

  .ops-lane {
    border-right: 0;
    border-bottom: 1px solid var(--premium-line);
  }

  .ops-lane:last-child {
    border-bottom: 0;
  }
}

/* codex v0_001_005: public recruitment LP pattern lab */
.public-preview-page.lp-pattern-future,
.public-preview-page.lp-pattern-standard,
.public-preview-page.lp-pattern-trend {
  min-height: 100vh;
  padding-bottom: 0;
  color: #18202f;
  font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
}

.public-preview-page.lp-pattern-future *,
.public-preview-page.lp-pattern-standard *,
.public-preview-page.lp-pattern-trend * {
  box-sizing: border-box;
}

.public-preview-page.lp-pattern-future .preview-mode-bar,
.public-preview-page.lp-pattern-standard .preview-mode-bar,
.public-preview-page.lp-pattern-trend .preview-mode-bar {
  position: sticky;
  top: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px clamp(14px, 3vw, 32px);
  border-bottom: 1px solid rgba(20, 31, 48, .12);
  background: rgba(255, 255, 255, .86);
  box-shadow: 0 16px 42px rgba(20, 31, 48, .08);
  backdrop-filter: blur(18px);
}

.preview-pattern-switch,
.preview-icon-switch {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  max-width: min(100%, 520px);
  padding: 4px;
  overflow-x: auto;
  border: 1px solid rgba(20, 31, 48, .12);
  border-radius: 999px;
  background: rgba(246, 248, 251, .92);
}

.pattern-switch-label {
  flex: 0 0 auto;
  padding: 0 7px 0 10px;
  color: #667085;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .04em;
  white-space: nowrap;
}

.preview-pattern-button,
.preview-icon-button {
  flex: 0 0 auto;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: #475467;
  cursor: pointer;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  padding: 9px 13px;
  transition: transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

.preview-pattern-button:hover,
.preview-icon-button:hover {
  transform: translateY(-1px);
}

.preview-pattern-button.active,
.preview-icon-button.active {
  background: #111827;
  color: #fff;
  box-shadow: 0 10px 24px rgba(17, 24, 39, .18);
}

.public-lp-shell {
  position: relative;
  min-height: calc(100vh - 64px);
  overflow: hidden;
  padding: 38px 20px 54px;
}

.public-preview-page.lp-pattern-future .public-lp-shell {
  background:
    radial-gradient(circle at 78% 10%, rgba(64, 221, 255, .24), transparent 28%),
    radial-gradient(circle at 16% 18%, rgba(132, 92, 255, .2), transparent 32%),
    linear-gradient(135deg, #08111f 0%, #0d1729 48%, #111827 100%);
  color: #f8fbff;
}

.public-preview-page.lp-pattern-standard .public-lp-shell {
  background:
    linear-gradient(90deg, rgba(20, 31, 48, .035) 1px, transparent 1px),
    linear-gradient(180deg, #f7f3e9 0%, #f4f6f4 46%, #eef2f7 100%);
  background-size: 72px 72px, auto;
}

.public-preview-page.lp-pattern-trend .public-lp-shell {
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 199, 205, .52), transparent 28%),
    radial-gradient(circle at 84% 12%, rgba(191, 224, 211, .6), transparent 30%),
    linear-gradient(135deg, #fff8f0 0%, #fff5f7 45%, #f5fbf8 100%);
}

.public-preview-page.lp-pattern-future .public-job-hero,
.public-preview-page.lp-pattern-standard .public-job-hero,
.public-preview-page.lp-pattern-trend .public-job-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: clamp(24px, 4vw, 46px);
  max-width: 1180px;
  margin: 0 auto 18px;
  padding: clamp(32px, 5vw, 58px);
  overflow: hidden;
  border-radius: 34px;
}

.public-preview-page.lp-pattern-future .public-job-hero::before,
.public-preview-page.lp-pattern-standard .public-job-hero::before,
.public-preview-page.lp-pattern-trend .public-job-hero::before {
  display: none;
}

.public-preview-page.lp-pattern-future .public-hero-content,
.public-preview-page.lp-pattern-standard .public-hero-content,
.public-preview-page.lp-pattern-trend .public-hero-content {
  position: relative;
  z-index: 2;
}

.public-preview-page.lp-pattern-future .public-job-company,
.public-preview-page.lp-pattern-standard .public-job-company,
.public-preview-page.lp-pattern-trend .public-job-company {
  margin: 0 0 12px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .02em;
}

.lp-hero-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 16px;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.public-preview-page.lp-pattern-future .public-job-hero h1,
.public-preview-page.lp-pattern-standard .public-job-hero h1,
.public-preview-page.lp-pattern-trend .public-job-hero h1 {
  max-width: 760px;
  margin: 0 0 16px;
  font-size: clamp(31px, 4.4vw, 54px);
  font-weight: 950;
  letter-spacing: -.045em;
  line-height: 1.16;
}

.public-preview-page.lp-pattern-future .public-job-subtitle,
.public-preview-page.lp-pattern-standard .public-job-subtitle,
.public-preview-page.lp-pattern-trend .public-job-subtitle {
  max-width: 720px;
  margin: 0 0 22px;
  font-size: 15px;
  line-height: 1.95;
}

.public-preview-page.lp-pattern-future .public-job-tags,
.public-preview-page.lp-pattern-standard .public-job-tags,
.public-preview-page.lp-pattern-trend .public-job-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 24px;
}

.public-preview-page.lp-pattern-future .public-job-tag,
.public-preview-page.lp-pattern-standard .public-job-tag,
.public-preview-page.lp-pattern-trend .public-job-tag {
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid,
.public-preview-page.lp-pattern-standard .public-job-summary-grid,
.public-preview-page.lp-pattern-trend .public-job-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 0;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid > div,
.public-preview-page.lp-pattern-standard .public-job-summary-grid > div,
.public-preview-page.lp-pattern-trend .public-job-summary-grid > div {
  min-width: 0;
  border-radius: 18px;
  padding: 16px;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid span,
.public-preview-page.lp-pattern-standard .public-job-summary-grid span,
.public-preview-page.lp-pattern-trend .public-job-summary-grid span {
  display: block;
  margin-bottom: 7px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid strong,
.public-preview-page.lp-pattern-standard .public-job-summary-grid strong,
.public-preview-page.lp-pattern-trend .public-job-summary-grid strong {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 15px;
  line-height: 1.55;
}

.public-preview-page.lp-pattern-future .public-hero-visual,
.public-preview-page.lp-pattern-standard .public-hero-visual,
.public-preview-page.lp-pattern-trend .public-hero-visual {
  position: relative;
  z-index: 2;
  min-height: 330px;
  display: grid;
  align-content: center;
  gap: 16px;
}

.public-preview-page.lp-pattern-future .public-preview-anchor-nav,
.public-preview-page.lp-pattern-standard .public-preview-anchor-nav,
.public-preview-page.lp-pattern-trend .public-preview-anchor-nav {
  max-width: 1180px;
  margin: 0 auto 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 14px;
  border-radius: 22px;
}

.public-preview-page.lp-pattern-future .preview-anchor-chip,
.public-preview-page.lp-pattern-standard .preview-anchor-chip,
.public-preview-page.lp-pattern-trend .preview-anchor-chip {
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}

.public-preview-page.lp-pattern-future .public-job-layout,
.public-preview-page.lp-pattern-standard .public-job-layout,
.public-preview-page.lp-pattern-trend .public-job-layout {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 332px;
  gap: 18px;
  align-items: start;
}

.public-preview-page.lp-pattern-future .public-job-main,
.public-preview-page.lp-pattern-standard .public-job-main,
.public-preview-page.lp-pattern-trend .public-job-main {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.public-preview-page.lp-pattern-future .public-job-section,
.public-preview-page.lp-pattern-standard .public-job-section,
.public-preview-page.lp-pattern-trend .public-job-section {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 18px;
  min-width: 0;
  border-radius: 24px;
  padding: 24px;
}

.public-preview-page.lp-pattern-future .public-job-section h2,
.public-preview-page.lp-pattern-standard .public-job-section h2,
.public-preview-page.lp-pattern-trend .public-job-section h2 {
  margin: 0 0 10px;
  font-size: 20px;
  letter-spacing: -.02em;
}

.public-preview-page.lp-pattern-future .public-job-section p,
.public-preview-page.lp-pattern-standard .public-job-section p,
.public-preview-page.lp-pattern-trend .public-job-section p {
  margin: 0;
  line-height: 1.95;
  overflow-wrap: anywhere;
}

.public-preview-page.lp-pattern-future .public-section-label,
.public-preview-page.lp-pattern-standard .public-section-label,
.public-preview-page.lp-pattern-trend .public-section-label {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  font-size: 13px;
  font-weight: 950;
}

.public-preview-page.lp-pattern-future .public-apply-card,
.public-preview-page.lp-pattern-standard .public-apply-card,
.public-preview-page.lp-pattern-trend .public-apply-card {
  position: sticky;
  top: 86px;
  min-width: 0;
  border-radius: 26px;
  padding: 22px;
}

.public-preview-page.lp-pattern-future .apply-card-title,
.public-preview-page.lp-pattern-standard .apply-card-title,
.public-preview-page.lp-pattern-trend .apply-card-title {
  margin-bottom: 10px;
  font-size: 22px;
  font-weight: 950;
  letter-spacing: -.03em;
}

.apply-card-kicker {
  width: fit-content;
  margin-bottom: 8px;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
}

.public-preview-page.lp-pattern-future .public-apply-card p,
.public-preview-page.lp-pattern-standard .public-apply-card p,
.public-preview-page.lp-pattern-trend .public-apply-card p {
  margin: 0 0 14px;
  line-height: 1.75;
  font-size: 13px;
}

.public-apply-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 12px 0 14px;
}

.public-apply-highlights span {
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 11px;
  font-weight: 950;
}

.apply-support-note {
  margin-top: 10px;
  border-radius: 14px;
  padding: 11px 12px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.65;
}

.preview-admin-tools {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid currentColor;
}

.preview-admin-tools summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 950;
  list-style: none;
}

.preview-admin-tools summary::-webkit-details-marker {
  display: none;
}

.preview-admin-tools summary::after {
  content: "＋";
  float: right;
}

.preview-admin-tools[open] summary::after {
  content: "−";
}

.preview-admin-tools .btn {
  margin-top: 8px;
}

.public-preview-page.lp-pattern-future .public-link-box,
.public-preview-page.lp-pattern-standard .public-link-box,
.public-preview-page.lp-pattern-trend .public-link-box {
  min-width: 0;
  margin: 12px 0;
  border-radius: 16px;
  padding: 12px;
}

.public-preview-page.lp-pattern-future .public-link-box span,
.public-preview-page.lp-pattern-standard .public-link-box span,
.public-preview-page.lp-pattern-trend .public-link-box span {
  display: block;
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .05em;
}

.public-preview-page.lp-pattern-future .public-link-box code,
.public-preview-page.lp-pattern-standard .public-link-box code,
.public-preview-page.lp-pattern-trend .public-link-box code {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
  white-space: normal;
  font-size: 11px;
  line-height: 1.5;
}

.public-preview-page.lp-pattern-future .public-apply-button,
.public-preview-page.lp-pattern-standard .public-apply-button,
.public-preview-page.lp-pattern-trend .public-apply-button {
  width: 100%;
  height: 54px;
  border: 0;
  border-radius: 16px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 950;
  transition: transform .18s ease, box-shadow .18s ease;
}

.public-preview-page.lp-pattern-future .public-apply-button:hover,
.public-preview-page.lp-pattern-standard .public-apply-button:hover,
.public-preview-page.lp-pattern-trend .public-apply-button:hover {
  transform: translateY(-2px);
}

.public-preview-page.lp-pattern-future .preview-warning,
.public-preview-page.lp-pattern-standard .preview-warning,
.public-preview-page.lp-pattern-trend .preview-warning {
  margin-top: 14px;
  padding-top: 14px;
  font-size: 12px;
  line-height: 1.7;
}

.public-preview-page.lp-pattern-future .public-job-footer,
.public-preview-page.lp-pattern-standard .public-job-footer,
.public-preview-page.lp-pattern-trend .public-job-footer {
  margin: 38px auto 0;
  text-align: center;
  font-size: 12px;
}

.public-section-stack {
  display: grid;
  gap: 16px;
}

.public-preview-page.lp-pattern-future .lp-flow-section,
.public-preview-page.lp-pattern-standard .lp-flow-section,
.public-preview-page.lp-pattern-trend .lp-flow-section {
  align-items: start;
}

.lp-section-body {
  min-width: 0;
}

.section-eyebrow {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.section-lead {
  max-width: 780px;
  margin: 0 0 18px !important;
  font-size: 14px;
}

.lp-section-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.lp-story-card,
.lp-condition-panel,
.lp-compact-table {
  min-width: 0;
  border-radius: 18px;
  padding: 16px;
}

.lp-story-card h3,
.lp-condition-panel h3 {
  margin: 0 0 8px;
  font-size: 16px;
}

.lp-story-card p,
.condition-panel-head p {
  margin: 0;
  line-height: 1.75;
}

.lp-condition-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.condition-panel-head {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  margin-bottom: 12px;
}

.condition-panel-head > span {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 950;
}

.condition-table,
.lp-compact-table {
  display: grid;
}

.condition-row {
  display: grid;
  grid-template-columns: minmax(108px, 148px) minmax(0, 1fr);
  gap: 12px;
  padding: 11px 0;
  border-top: 1px solid currentColor;
}

.condition-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.condition-row:last-child {
  padding-bottom: 0;
}

.condition-row span {
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .03em;
}

.condition-row strong {
  min-width: 0;
  overflow-wrap: anywhere;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.65;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.lp-section-icon {
  position: relative;
  width: 48px;
  height: 48px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
}

.condition-panel-head .lp-section-icon {
  width: 34px;
  height: 34px;
}

.lp-section-icon svg {
  position: relative;
  z-index: 2;
  width: 74%;
  height: 74%;
  overflow: visible;
}

.lp-section-icon path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.public-preview-page .public-section-label {
  background: transparent;
}

.public-preview-page.icon-style-recruit .lp-section-icon {
  border: 1px solid rgba(0, 112, 243, .18);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(229, 242, 255, .82));
  color: #0969da;
  box-shadow: 0 10px 24px rgba(0, 112, 243, .12);
}

.public-preview-page.icon-style-recruit .condition-panel-head .lp-section-icon {
  border-radius: 11px;
}

.public-preview-page.icon-style-recruit .lp-section-icon::after {
  content: "";
  position: absolute;
  right: -4px;
  top: 8px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #00a3ff;
  box-shadow: 0 0 0 4px rgba(0, 163, 255, .12);
}

.public-preview-page.icon-style-pop .lp-section-icon {
  border: 1px solid rgba(233, 133, 138, .2);
  border-radius: 18px 26px 20px 26px;
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, .95), transparent 24%),
    linear-gradient(135deg, #ffd9de, #cfeadd);
  color: #7b5961;
  box-shadow: 0 14px 28px rgba(128, 74, 86, .12);
}

.public-preview-page.icon-style-pop .condition-panel-head .lp-section-icon {
  border-radius: 14px 18px 15px 18px;
}

.public-preview-page.icon-style-pop .lp-section-icon::before {
  content: "";
  position: absolute;
  left: 5px;
  bottom: 5px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .7);
}

.public-preview-page.icon-style-pop .lp-section-icon path {
  stroke-width: 2.25;
}

.public-preview-page.icon-style-energy .lp-section-icon {
  transform: rotate(-5deg);
  border: 1px solid rgba(255, 138, 60, .28);
  border-radius: 16px;
  background:
    linear-gradient(135deg, #ff8a3c, #ffcf4a 54%, #24d6c9);
  color: #08111f;
  box-shadow: 0 18px 34px rgba(255, 118, 45, .26);
}

.public-preview-page.icon-style-energy .lp-section-icon::before {
  content: "";
  position: absolute;
  inset: -5px;
  z-index: 0;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(255, 138, 60, .16), rgba(36, 214, 201, .18));
  transform: rotate(10deg);
}

.public-preview-page.icon-style-energy .lp-section-icon::after {
  content: "";
  position: absolute;
  right: -6px;
  bottom: 7px;
  width: 16px;
  height: 4px;
  border-radius: 999px;
  background: currentColor;
  transform: rotate(-28deg);
}

.public-preview-page.icon-style-energy .lp-section-icon path {
  stroke-width: 2.75;
}

/* Pattern A: futuristic, restrained premium */
.public-preview-page.lp-pattern-future .preview-mode-bar {
  background: rgba(9, 17, 31, .84);
  border-bottom-color: rgba(135, 220, 255, .18);
  color: #f8fbff;
}

.public-preview-page.lp-pattern-future .preview-mode-bar span,
.public-preview-page.lp-pattern-future .pattern-switch-label {
  color: rgba(230, 244, 255, .68);
}

.public-preview-page.lp-pattern-future .preview-pattern-switch,
.public-preview-page.lp-pattern-future .preview-icon-switch,
.public-preview-page.lp-pattern-future .preview-device-switch {
  border-color: rgba(135, 220, 255, .18);
  background: rgba(255, 255, 255, .08);
}

.public-preview-page.lp-pattern-future .preview-pattern-button,
.public-preview-page.lp-pattern-future .preview-icon-button,
.public-preview-page.lp-pattern-future .preview-device-button {
  color: rgba(238, 248, 255, .78);
}

.public-preview-page.lp-pattern-future .preview-pattern-button.active,
.public-preview-page.lp-pattern-future .preview-icon-button.active,
.public-preview-page.lp-pattern-future .preview-device-button.active {
  background: linear-gradient(135deg, #8be8ff, #a692ff);
  color: #06111f;
  box-shadow: 0 12px 30px rgba(112, 210, 255, .28);
}

.public-preview-page.lp-pattern-future .public-job-hero {
  border: 1px solid rgba(139, 232, 255, .2);
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .055) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 255, 255, .055) 1px, transparent 1px),
    linear-gradient(135deg, rgba(255, 255, 255, .11), rgba(255, 255, 255, .035));
  background-size: 34px 34px, 34px 34px, auto;
  box-shadow: 0 34px 90px rgba(0, 0, 0, .34), inset 0 1px 0 rgba(255, 255, 255, .14);
}

.public-preview-page.lp-pattern-future .public-job-company {
  color: rgba(226, 245, 255, .82);
}

.public-preview-page.lp-pattern-future .lp-hero-kicker {
  border: 1px solid rgba(139, 232, 255, .28);
  background: rgba(139, 232, 255, .1);
  color: #a8eeff;
}

.public-preview-page.lp-pattern-future .public-job-hero h1 {
  color: #fff;
  text-shadow: 0 0 34px rgba(139, 232, 255, .2);
}

.public-preview-page.lp-pattern-future .public-job-subtitle,
.public-preview-page.lp-pattern-future .public-job-section p,
.public-preview-page.lp-pattern-future .public-apply-card p,
.public-preview-page.lp-pattern-future .preview-warning,
.public-preview-page.lp-pattern-future .public-job-footer {
  color: rgba(233, 244, 255, .72);
}

.public-preview-page.lp-pattern-future .public-job-tag {
  border: 1px solid rgba(139, 232, 255, .22);
  background: rgba(139, 232, 255, .09);
  color: #cbf5ff;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid > div,
.public-preview-page.lp-pattern-future .public-preview-anchor-nav,
.public-preview-page.lp-pattern-future .public-job-section,
.public-preview-page.lp-pattern-future .public-apply-card,
.public-preview-page.lp-pattern-future .lp-story-card,
.public-preview-page.lp-pattern-future .lp-condition-panel,
.public-preview-page.lp-pattern-future .lp-compact-table {
  border: 1px solid rgba(139, 232, 255, .16);
  background: rgba(255, 255, 255, .07);
  box-shadow: 0 24px 64px rgba(0, 0, 0, .24), inset 0 1px 0 rgba(255, 255, 255, .08);
  backdrop-filter: blur(16px);
}

.public-preview-page.lp-pattern-future .public-job-summary-grid span,
.public-preview-page.lp-pattern-future .public-link-box span {
  color: #9eeaff;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid strong,
.public-preview-page.lp-pattern-future .public-job-section h2,
.public-preview-page.lp-pattern-future .apply-card-title,
.public-preview-page.lp-pattern-future .lp-story-card h3,
.public-preview-page.lp-pattern-future .lp-condition-panel h3,
.public-preview-page.lp-pattern-future .condition-row strong {
  color: #fff;
}

.public-preview-page.lp-pattern-future .public-section-label {
  color: #07111f;
}

.public-preview-page.lp-pattern-future .section-eyebrow {
  background: rgba(139, 232, 255, .11);
  color: #9eeaff;
}

.public-preview-page.lp-pattern-future .condition-row {
  border-color: rgba(139, 232, 255, .16);
}

.public-preview-page.lp-pattern-future .condition-row span,
.public-preview-page.lp-pattern-future .lp-story-card p,
.public-preview-page.lp-pattern-future .condition-panel-head p {
  color: rgba(233, 244, 255, .7);
}

.public-preview-page.lp-pattern-future .apply-card-kicker,
.public-preview-page.lp-pattern-future .public-apply-highlights span {
  border: 1px solid rgba(139, 232, 255, .18);
  background: rgba(139, 232, 255, .1);
  color: #9eeaff;
}

.public-preview-page.lp-pattern-future .apply-support-note {
  border: 1px solid rgba(139, 232, 255, .14);
  background: rgba(5, 12, 24, .32);
  color: rgba(233, 244, 255, .72);
}

.public-preview-page.lp-pattern-future .preview-admin-tools {
  border-color: rgba(139, 232, 255, .16);
  color: rgba(233, 244, 255, .66);
}

.public-preview-page.lp-pattern-future .preview-anchor-chip {
  border: 1px solid rgba(139, 232, 255, .16);
  background: rgba(255, 255, 255, .07);
  color: rgba(242, 249, 255, .88);
}

.public-preview-page.lp-pattern-future .public-link-box {
  border: 1px solid rgba(139, 232, 255, .18);
  background: rgba(5, 12, 24, .42);
}

.public-preview-page.lp-pattern-future .public-link-box code {
  color: rgba(228, 247, 255, .78);
}

.public-preview-page.lp-pattern-future .public-apply-button {
  background: linear-gradient(135deg, #8be8ff, #a692ff);
  color: #06111f;
  box-shadow: 0 18px 42px rgba(112, 210, 255, .28);
}

.lp-visual-orbit {
  position: relative;
  width: min(330px, 100%);
  aspect-ratio: 1;
  margin: 0 auto;
  border: 1px solid rgba(139, 232, 255, .2);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(139, 232, 255, .24), transparent 34%),
    radial-gradient(circle, rgba(166, 146, 255, .16), transparent 58%);
}

.lp-visual-orbit::before,
.lp-visual-orbit::after {
  content: "";
  position: absolute;
  inset: 36px;
  border: 1px dashed rgba(232, 246, 255, .2);
  border-radius: 50%;
}

.lp-visual-orbit::after {
  inset: 76px;
  border-style: solid;
}

.orbit-core {
  position: absolute;
  inset: 50%;
  width: 122px;
  height: 122px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 34px;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .18);
  box-shadow: 0 0 50px rgba(139, 232, 255, .28);
}

.orbit-core small,
.orbit-core strong {
  display: block;
}

.orbit-core small {
  color: rgba(234, 247, 255, .74);
  font-size: 11px;
  font-weight: 900;
}

.orbit-core strong {
  color: #fff;
  font-size: 25px;
  letter-spacing: -.04em;
}

.orbit-dot {
  position: absolute;
  width: 13px;
  height: 13px;
  border-radius: 999px;
  background: #8be8ff;
  box-shadow: 0 0 24px rgba(139, 232, 255, .72);
}

.dot-a { top: 18%; left: 22%; }
.dot-b { top: 54%; right: 10%; background: #a692ff; }
.dot-c { bottom: 17%; left: 42%; background: #dffb83; }

.lp-signal-card {
  width: min(330px, 100%);
  margin: -48px auto 0;
  border: 1px solid rgba(139, 232, 255, .18);
  border-radius: 22px;
  padding: 18px;
  background: rgba(7, 15, 29, .74);
  box-shadow: 0 24px 64px rgba(0, 0, 0, .32);
}

.lp-signal-card span,
.lp-signal-card em {
  color: rgba(232, 246, 255, .64);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
}

.lp-signal-card strong {
  display: block;
  margin: 7px 0 8px;
  color: #fff;
  font-size: 18px;
  line-height: 1.45;
}

.lp-signal-card em {
  font-style: normal;
}

/* Pattern B: Japanese corporate standard */
.public-preview-page.lp-pattern-standard .public-job-hero {
  border: 1px solid #dad6ca;
  border-top: 7px solid #23415f;
  border-radius: 18px;
  background: #fffefa;
  box-shadow: 0 24px 70px rgba(35, 65, 95, .11);
}

.public-preview-page.lp-pattern-standard .public-job-company,
.public-preview-page.lp-pattern-standard .public-job-subtitle,
.public-preview-page.lp-pattern-standard .public-job-section p,
.public-preview-page.lp-pattern-standard .public-apply-card p,
.public-preview-page.lp-pattern-standard .preview-warning,
.public-preview-page.lp-pattern-standard .public-job-footer {
  color: #5b6470;
}

.public-preview-page.lp-pattern-standard .lp-hero-kicker {
  border: 1px solid #d8c9aa;
  background: #f6efe2;
  color: #6f4e24;
}

.public-preview-page.lp-pattern-standard .public-job-hero h1 {
  color: #1f2f41;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  letter-spacing: -.035em;
}

.public-preview-page.lp-pattern-standard .public-job-tag {
  border: 1px solid #d9e0e7;
  background: #f7fafc;
  color: #31506d;
}

.public-preview-page.lp-pattern-standard .public-job-summary-grid > div,
.public-preview-page.lp-pattern-standard .public-preview-anchor-nav,
.public-preview-page.lp-pattern-standard .public-job-section,
.public-preview-page.lp-pattern-standard .public-apply-card,
.public-preview-page.lp-pattern-standard .lp-story-card,
.public-preview-page.lp-pattern-standard .lp-condition-panel,
.public-preview-page.lp-pattern-standard .lp-compact-table {
  border: 1px solid #dcd8ce;
  background: rgba(255, 254, 250, .96);
  box-shadow: 0 14px 34px rgba(35, 65, 95, .075);
}

.public-preview-page.lp-pattern-standard .public-job-section {
  border-radius: 12px;
}

.public-preview-page.lp-pattern-standard .public-job-summary-grid span,
.public-preview-page.lp-pattern-standard .public-link-box span {
  color: #7a6440;
}

.public-preview-page.lp-pattern-standard .public-job-summary-grid strong,
.public-preview-page.lp-pattern-standard .public-job-section h2,
.public-preview-page.lp-pattern-standard .apply-card-title,
.public-preview-page.lp-pattern-standard .lp-story-card h3,
.public-preview-page.lp-pattern-standard .lp-condition-panel h3,
.public-preview-page.lp-pattern-standard .condition-row strong {
  color: #24364a;
}

.public-preview-page.lp-pattern-standard .public-section-label {
  color: #23415f;
}

.public-preview-page.lp-pattern-standard .section-eyebrow {
  background: #f6efe2;
  color: #7a6440;
}

.public-preview-page.lp-pattern-standard .condition-row {
  border-color: rgba(36, 54, 74, .14);
}

.public-preview-page.lp-pattern-standard .condition-row span,
.public-preview-page.lp-pattern-standard .lp-story-card p,
.public-preview-page.lp-pattern-standard .condition-panel-head p {
  color: #667085;
}

.public-preview-page.lp-pattern-standard .apply-card-kicker,
.public-preview-page.lp-pattern-standard .public-apply-highlights span {
  border: 1px solid #d8c9aa;
  background: #f6efe2;
  color: #7a6440;
}

.public-preview-page.lp-pattern-standard .apply-support-note {
  border: 1px solid #d9e0e7;
  background: #f7fafc;
  color: #4d5d6c;
}

.public-preview-page.lp-pattern-standard .preview-admin-tools {
  border-color: rgba(36, 54, 74, .14);
  color: #667085;
}

.public-preview-page.lp-pattern-standard .preview-anchor-chip {
  border: 1px solid #d9e0e7;
  background: #fff;
  color: #304960;
}

.public-preview-page.lp-pattern-standard .public-link-box {
  border: 1px solid #d9e0e7;
  background: #f7fafc;
}

.public-preview-page.lp-pattern-standard .public-apply-button {
  background: #23415f;
  color: #fff;
  box-shadow: 0 16px 34px rgba(35, 65, 95, .24);
}

.lp-standard-board {
  position: relative;
  border: 1px solid #dcd8ce;
  border-radius: 16px;
  padding: 22px;
  background: #fff;
  box-shadow: 0 24px 54px rgba(35, 65, 95, .12);
}

.board-head {
  display: flex;
  gap: 6px;
  margin-bottom: 22px;
}

.board-head span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #d9e0e7;
}

.lp-standard-board strong {
  display: block;
  color: #24364a;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Noto Serif JP", serif;
  font-size: 31px;
}

.lp-standard-board p {
  color: #667085;
  line-height: 1.8;
}

.board-list {
  display: grid;
  gap: 10px;
  margin-top: 20px;
}

.board-list i {
  display: block;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, #dfe5ec, transparent);
}

.board-list i:nth-child(2) { width: 78%; }
.board-list i:nth-child(3) { width: 58%; }

.lp-standard-stamp {
  justify-self: end;
  width: 116px;
  height: 116px;
  display: grid;
  place-items: center;
  transform: rotate(-8deg);
  border: 2px solid #8c6b39;
  border-radius: 50%;
  color: #8c6b39;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-weight: 900;
}

/* Pattern C: soft editorial for Japanese female applicants */
.public-preview-page.lp-pattern-trend .public-job-hero {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 390px);
  border: 1px solid rgba(190, 151, 138, .22);
  border-radius: 42px;
  background:
    radial-gradient(circle at 0 0, rgba(255, 218, 219, .5), transparent 32%),
    linear-gradient(135deg, rgba(255, 255, 255, .92), rgba(255, 253, 247, .82));
  box-shadow: 0 30px 80px rgba(128, 74, 86, .12);
}

.public-preview-page.lp-pattern-trend .public-job-company {
  color: #80676a;
}

.public-preview-page.lp-pattern-trend .lp-hero-kicker {
  border: 1px solid rgba(210, 143, 137, .24);
  background: #fff0ef;
  color: #a45c5e;
}

.public-preview-page.lp-pattern-trend .public-job-hero h1 {
  color: #2d2930;
  font-family: "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
}

.public-preview-page.lp-pattern-trend .public-job-subtitle,
.public-preview-page.lp-pattern-trend .public-job-section p,
.public-preview-page.lp-pattern-trend .public-apply-card p,
.public-preview-page.lp-pattern-trend .preview-warning,
.public-preview-page.lp-pattern-trend .public-job-footer {
  color: #665f64;
}

.public-preview-page.lp-pattern-trend .public-job-tag {
  border: 1px solid rgba(190, 151, 138, .2);
  background: rgba(255, 255, 255, .78);
  color: #8c5d62;
  box-shadow: 0 8px 18px rgba(128, 74, 86, .06);
}

.public-preview-page.lp-pattern-trend .public-job-summary-grid > div,
.public-preview-page.lp-pattern-trend .public-preview-anchor-nav,
.public-preview-page.lp-pattern-trend .public-job-section,
.public-preview-page.lp-pattern-trend .public-apply-card,
.public-preview-page.lp-pattern-trend .lp-story-card,
.public-preview-page.lp-pattern-trend .lp-condition-panel,
.public-preview-page.lp-pattern-trend .lp-compact-table {
  border: 1px solid rgba(190, 151, 138, .2);
  background: rgba(255, 255, 255, .82);
  box-shadow: 0 20px 54px rgba(128, 74, 86, .09);
  backdrop-filter: blur(14px);
}

.public-preview-page.lp-pattern-trend .public-job-section:nth-child(3n + 1) {
  transform: translateX(6px);
}

.public-preview-page.lp-pattern-trend .public-job-section:nth-child(3n + 2) {
  transform: translateX(-4px);
}

.public-preview-page.lp-pattern-trend .public-job-summary-grid span,
.public-preview-page.lp-pattern-trend .public-link-box span {
  color: #b36e72;
}

.public-preview-page.lp-pattern-trend .public-job-summary-grid strong,
.public-preview-page.lp-pattern-trend .public-job-section h2,
.public-preview-page.lp-pattern-trend .apply-card-title,
.public-preview-page.lp-pattern-trend .lp-story-card h3,
.public-preview-page.lp-pattern-trend .lp-condition-panel h3,
.public-preview-page.lp-pattern-trend .condition-row strong {
  color: #2f2a31;
}

.public-preview-page.lp-pattern-trend .public-section-label {
  color: #4b383b;
}

.public-preview-page.lp-pattern-trend .section-eyebrow {
  background: #fff0ef;
  color: #a45c5e;
}

.public-preview-page.lp-pattern-trend .condition-row {
  border-color: rgba(128, 74, 86, .13);
}

.public-preview-page.lp-pattern-trend .condition-row span,
.public-preview-page.lp-pattern-trend .lp-story-card p,
.public-preview-page.lp-pattern-trend .condition-panel-head p {
  color: #74666b;
}

.public-preview-page.lp-pattern-trend .apply-card-kicker,
.public-preview-page.lp-pattern-trend .public-apply-highlights span {
  border: 1px solid rgba(210, 143, 137, .24);
  background: #fff0ef;
  color: #a45c5e;
}

.public-preview-page.lp-pattern-trend .apply-support-note {
  border: 1px solid rgba(190, 151, 138, .18);
  background: #fff7f3;
  color: #74666b;
}

.public-preview-page.lp-pattern-trend .preview-admin-tools {
  border-color: rgba(128, 74, 86, .13);
  color: #74666b;
}

.public-preview-page.lp-pattern-trend .preview-anchor-chip {
  border: 1px solid rgba(190, 151, 138, .18);
  background: rgba(255, 255, 255, .8);
  color: #7d5a5f;
}

.public-preview-page.lp-pattern-trend .public-link-box {
  border: 1px solid rgba(190, 151, 138, .18);
  background: #fff7f3;
}

.public-preview-page.lp-pattern-trend .public-apply-button {
  background: linear-gradient(135deg, #e9858a, #efb278);
  color: #fff;
  box-shadow: 0 18px 38px rgba(218, 119, 124, .28);
}

.lp-trend-photo-card {
  position: relative;
  border: 1px solid rgba(190, 151, 138, .2);
  border-radius: 34px;
  padding: 24px;
  background: rgba(255, 255, 255, .74);
  box-shadow: 0 26px 62px rgba(128, 74, 86, .14);
}

.trend-face {
  width: 132px;
  height: 132px;
  margin-bottom: 18px;
  border-radius: 36px 70px 52px 70px;
  background:
    radial-gradient(circle at 50% 38%, #5b4b50 0 5px, transparent 6px),
    radial-gradient(circle at 64% 38%, #5b4b50 0 5px, transparent 6px),
    radial-gradient(circle at 56% 62%, rgba(255, 145, 150, .45) 0 18px, transparent 19px),
    linear-gradient(135deg, #ffe0d7, #f2c4c8 55%, #cde8dc);
}

.trend-face span {
  display: block;
  width: 80px;
  height: 26px;
  transform: translate(22px, 72px);
  border-bottom: 5px solid rgba(91, 75, 80, .62);
  border-radius: 0 0 50px 50px;
}

.lp-trend-photo-card strong {
  display: block;
  color: #302a31;
  font-size: 23px;
  line-height: 1.45;
  letter-spacing: -.03em;
}

.lp-trend-photo-card p {
  color: #665f64;
  line-height: 1.8;
}

.lp-trend-stickers {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  transform: rotate(-2deg);
}

.lp-trend-stickers span {
  border: 1px solid rgba(190, 151, 138, .2);
  border-radius: 999px;
  padding: 8px 12px;
  background: #fff;
  color: #8d5a60;
  font-size: 12px;
  font-weight: 900;
  box-shadow: 0 10px 20px rgba(128, 74, 86, .08);
}

/* Mobile preview repair */
.public-preview-page.device-mobile.lp-pattern-future,
.public-preview-page.device-mobile.lp-pattern-standard,
.public-preview-page.device-mobile.lp-pattern-trend {
  overflow-x: hidden;
}

.public-preview-page.device-mobile.lp-pattern-future .mobile-preview-stage,
.public-preview-page.device-mobile.lp-pattern-standard .mobile-preview-stage,
.public-preview-page.device-mobile.lp-pattern-trend .mobile-preview-stage {
  min-height: calc(100vh - 74px);
  display: flex;
  justify-content: center;
  align-items: flex-start;
  padding: 18px 10px 36px;
  overflow-x: hidden;
}

.public-preview-page.device-mobile.lp-pattern-future .mobile-preview-stage {
  background: linear-gradient(135deg, #07111f, #111827);
}

.public-preview-page.device-mobile.lp-pattern-standard .mobile-preview-stage {
  background: #e9ece9;
}

.public-preview-page.device-mobile.lp-pattern-trend .mobile-preview-stage {
  background: #fff5f7;
}

.public-preview-page.device-mobile.lp-pattern-future .mobile-device-frame,
.public-preview-page.device-mobile.lp-pattern-standard .mobile-device-frame,
.public-preview-page.device-mobile.lp-pattern-trend .mobile-device-frame {
  width: min(430px, calc(100vw - 20px));
  height: auto;
  min-height: 0;
  max-height: none;
  border-radius: 34px;
  padding: 10px;
  overflow: visible;
  background: #111827;
  box-shadow: 0 28px 80px rgba(17, 24, 39, .24);
}

.public-preview-page.device-mobile.lp-pattern-standard .mobile-device-frame {
  background: #263245;
}

.public-preview-page.device-mobile.lp-pattern-trend .mobile-device-frame {
  background: #6f5a62;
}

.public-preview-page.device-mobile.lp-pattern-future .mobile-device-top,
.public-preview-page.device-mobile.lp-pattern-standard .mobile-device-top,
.public-preview-page.device-mobile.lp-pattern-trend .mobile-device-top {
  display: none;
}

.public-preview-page.device-mobile.lp-pattern-future .mobile-device-screen,
.public-preview-page.device-mobile.lp-pattern-standard .mobile-device-screen,
.public-preview-page.device-mobile.lp-pattern-trend .mobile-device-screen {
  height: auto;
  max-height: none;
  overflow: visible;
  border-radius: 26px;
}

.public-preview-page.device-mobile.lp-pattern-future .public-lp-shell,
.public-preview-page.device-mobile.lp-pattern-standard .public-lp-shell,
.public-preview-page.device-mobile.lp-pattern-trend .public-lp-shell {
  min-height: auto;
  padding: 12px 0 24px;
}

.public-preview-page.device-mobile.lp-pattern-future .public-job-hero,
.public-preview-page.device-mobile.lp-pattern-standard .public-job-hero,
.public-preview-page.device-mobile.lp-pattern-trend .public-job-hero {
  grid-template-columns: minmax(0, 1fr);
  gap: 20px;
  width: auto;
  max-width: none;
  margin: 0 10px 12px;
  padding: 24px 18px;
  border-radius: 28px;
}

.public-preview-page.device-mobile.lp-pattern-future .public-job-hero h1,
.public-preview-page.device-mobile.lp-pattern-standard .public-job-hero h1,
.public-preview-page.device-mobile.lp-pattern-trend .public-job-hero h1 {
  font-size: 29px;
  line-height: 1.22;
  letter-spacing: -.035em;
}

.public-preview-page.device-mobile.lp-pattern-future .public-job-subtitle,
.public-preview-page.device-mobile.lp-pattern-standard .public-job-subtitle,
.public-preview-page.device-mobile.lp-pattern-trend .public-job-subtitle {
  font-size: 14px;
}

.public-preview-page.device-mobile.lp-pattern-future .public-hero-visual,
.public-preview-page.device-mobile.lp-pattern-standard .public-hero-visual,
.public-preview-page.device-mobile.lp-pattern-trend .public-hero-visual {
  min-height: 0;
}

.public-preview-page.device-mobile.lp-pattern-future .lp-visual-orbit {
  width: 230px;
}

.public-preview-page.device-mobile.lp-pattern-future .lp-signal-card {
  margin-top: -32px;
}

.public-preview-page.device-mobile.lp-pattern-standard .lp-standard-stamp {
  width: 86px;
  height: 86px;
}

.public-preview-page.device-mobile.lp-pattern-trend .public-job-section:nth-child(n) {
  transform: none;
}

.public-preview-page.device-mobile.lp-pattern-future .public-job-summary-grid,
.public-preview-page.device-mobile.lp-pattern-standard .public-job-summary-grid,
.public-preview-page.device-mobile.lp-pattern-trend .public-job-summary-grid {
  grid-template-columns: minmax(0, 1fr);
}

.public-preview-page.device-mobile.lp-pattern-future .public-preview-anchor-nav,
.public-preview-page.device-mobile.lp-pattern-standard .public-preview-anchor-nav,
.public-preview-page.device-mobile.lp-pattern-trend .public-preview-anchor-nav {
  max-width: none;
  margin: 0 10px 12px;
  overflow-x: auto;
  flex-wrap: nowrap;
  scrollbar-width: none;
}

.public-preview-page.device-mobile.lp-pattern-future .public-preview-anchor-nav::-webkit-scrollbar,
.public-preview-page.device-mobile.lp-pattern-standard .public-preview-anchor-nav::-webkit-scrollbar,
.public-preview-page.device-mobile.lp-pattern-trend .public-preview-anchor-nav::-webkit-scrollbar {
  display: none;
}

.public-preview-page.device-mobile.lp-pattern-future .public-job-layout,
.public-preview-page.device-mobile.lp-pattern-standard .public-job-layout,
.public-preview-page.device-mobile.lp-pattern-trend .public-job-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  width: auto;
  max-width: none;
  margin: 0 10px;
}

.public-preview-page.device-mobile.lp-pattern-future .public-job-section,
.public-preview-page.device-mobile.lp-pattern-standard .public-job-section,
.public-preview-page.device-mobile.lp-pattern-trend .public-job-section {
  grid-template-columns: minmax(0, 1fr);
  padding: 20px;
  border-radius: 22px;
}

.public-preview-page.device-mobile.lp-pattern-future .lp-section-card-grid,
.public-preview-page.device-mobile.lp-pattern-standard .lp-section-card-grid,
.public-preview-page.device-mobile.lp-pattern-trend .lp-section-card-grid,
.public-preview-page.device-mobile.lp-pattern-future .lp-condition-grid,
.public-preview-page.device-mobile.lp-pattern-standard .lp-condition-grid,
.public-preview-page.device-mobile.lp-pattern-trend .lp-condition-grid {
  grid-template-columns: minmax(0, 1fr);
}

.public-preview-page.device-mobile.lp-pattern-future .condition-row,
.public-preview-page.device-mobile.lp-pattern-standard .condition-row,
.public-preview-page.device-mobile.lp-pattern-trend .condition-row {
  grid-template-columns: minmax(0, 1fr);
  gap: 4px;
}

.public-preview-page.device-mobile.lp-pattern-future .public-apply-card,
.public-preview-page.device-mobile.lp-pattern-standard .public-apply-card,
.public-preview-page.device-mobile.lp-pattern-trend .public-apply-card {
  position: static;
  order: -1;
}

@media (max-width: 980px) {
  .public-preview-page.lp-pattern-future .preview-mode-bar,
  .public-preview-page.lp-pattern-standard .preview-mode-bar,
  .public-preview-page.lp-pattern-trend .preview-mode-bar {
    align-items: stretch;
    flex-wrap: wrap;
  }

  .preview-pattern-switch {
    order: 3;
    width: 100%;
  }

  .preview-icon-switch {
    order: 4;
    width: 100%;
  }

  .public-preview-page.lp-pattern-future .public-job-hero,
  .public-preview-page.lp-pattern-standard .public-job-hero,
  .public-preview-page.lp-pattern-trend .public-job-hero,
  .public-preview-page.lp-pattern-future .public-job-layout,
  .public-preview-page.lp-pattern-standard .public-job-layout,
  .public-preview-page.lp-pattern-trend .public-job-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .public-preview-page.lp-pattern-future .public-apply-card,
  .public-preview-page.lp-pattern-standard .public-apply-card,
  .public-preview-page.lp-pattern-trend .public-apply-card {
    position: static;
  }
}

@media (max-width: 640px) {
  .public-lp-shell {
    padding: 22px 12px 36px;
  }

  .public-preview-page.lp-pattern-future .public-job-hero,
  .public-preview-page.lp-pattern-standard .public-job-hero,
  .public-preview-page.lp-pattern-trend .public-job-hero {
    padding: 26px 20px;
    border-radius: 28px;
  }

  .public-preview-page.lp-pattern-future .public-job-summary-grid,
  .public-preview-page.lp-pattern-standard .public-job-summary-grid,
  .public-preview-page.lp-pattern-trend .public-job-summary-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .public-preview-page.lp-pattern-future .public-preview-anchor-nav,
  .public-preview-page.lp-pattern-standard .public-preview-anchor-nav,
  .public-preview-page.lp-pattern-trend .public-preview-anchor-nav,
  .public-preview-page.lp-pattern-future .public-job-layout,
  .public-preview-page.lp-pattern-standard .public-job-layout,
  .public-preview-page.lp-pattern-trend .public-job-layout {
    margin-left: 0;
    margin-right: 0;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .public-preview-page.lp-pattern-future .lp-visual-orbit {
    animation: orbitGlow 5.5s ease-in-out infinite alternate;
  }

  .public-preview-page.lp-pattern-trend .lp-trend-stickers {
    animation: softFloat 4.8s ease-in-out infinite alternate;
  }
}

@keyframes orbitGlow {
  from { filter: drop-shadow(0 0 10px rgba(139, 232, 255, .14)); }
  to { filter: drop-shadow(0 0 30px rgba(166, 146, 255, .28)); }
}

@keyframes softFloat {
  from { transform: translateY(0) rotate(-2deg); }
  to { transform: translateY(-8px) rotate(1deg); }
}

/* codex v0_001_006: long-form editor, keyword-aware AI, readable LP patterns */
.job-copy-editor-card {
  border: 1px solid rgba(17, 19, 24, .1);
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(250,252,253,.98)),
    radial-gradient(circle at 8% 0%, rgba(85,184,238,.14), transparent 30%);
}

.job-copy-textareas {
  display: grid;
  gap: 18px;
}

.job-copy-textarea {
  width: 100%;
  border-radius: 18px;
  padding: 18px 20px;
  font-size: 15px;
  line-height: 1.85;
  background: #fff;
}

.description-textarea {
  min-height: 390px;
}

.appeal-textarea {
  min-height: 280px;
}

.field-helper {
  margin-top: 7px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.ai-keyword-lab {
  margin: 16px 0;
  padding: 14px;
  border: 1px solid rgba(85,184,238,.22);
  border-radius: 16px;
  background: rgba(255,255,255,.76);
}

.ai-keyword-lab-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.ai-keyword-lab-head strong {
  display: block;
  color: var(--text);
}

.ai-keyword-lab-head span,
.ai-provider-note {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
}

.ai-coverage-panel {
  margin: 12px 0;
  border: 1px solid rgba(36,181,138,.2);
  border-radius: 15px;
  padding: 12px;
  background: #f3fff9;
}

.ai-coverage-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 9px;
}

.ai-coverage-head strong {
  color: #146b53;
}

.ai-coverage-head span {
  color: #43816d;
  font-size: 12px;
  font-weight: 850;
}

.ai-coverage-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.ai-coverage-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ai-coverage-columns > div {
  border: 1px solid rgba(36,181,138,.14);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255,255,255,.72);
}

.ai-coverage-columns b {
  display: block;
  margin-bottom: 8px;
  color: #146b53;
  font-size: 12px;
}

.ai-coverage-list span {
  border-radius: 999px;
  padding: 6px 9px;
  background: #fff;
  color: #146b53;
  border: 1px solid rgba(36,181,138,.18);
  font-size: 12px;
  font-weight: 850;
}

.ai-keyword-switch-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ai-keyword-switch {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 999px;
  padding: 8px 11px;
  background: #fff;
  color: #475467;
  font-size: 12px;
  font-weight: 850;
}

.ai-keyword-switch span {
  min-width: 32px;
  border-radius: 999px;
  padding: 3px 6px;
  text-align: center;
  font-size: 10px;
  letter-spacing: .04em;
}

.ai-keyword-switch.on {
  border-color: rgba(0,112,243,.22);
  color: #0f4b7d;
  background: #f2fbff;
}

.ai-keyword-switch.on span {
  background: #0969da;
  color: #fff;
}

.ai-keyword-switch.off {
  opacity: .62;
}

.ai-keyword-switch.off span {
  background: #edf2f7;
  color: #667085;
}

.ai-variant-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ai-variant-card {
  display: grid;
  gap: 12px;
  border: 1px solid #dbeafe;
  border-radius: 18px;
  padding: 18px;
  background:
    linear-gradient(180deg, #fff, #fbfdff);
}

.ai-variant-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.ai-variant-head strong {
  margin: 0;
  color: #0f172a;
}

.ai-variant-head span {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 5px 8px;
  background: #eef8ff;
  color: #0f6a9b;
  font-size: 11px;
  font-weight: 850;
}

.ai-variant-card h5 {
  margin: 0;
  color: #162033;
  font-size: 15px;
}

.ai-variant-copy b {
  display: block;
  margin-bottom: 5px;
  color: #475467;
  font-size: 12px;
}

.ai-variant-copy p,
.ai-requirement-card p {
  white-space: pre-line;
  line-height: 1.85;
}

.ai-variant-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.public-preview-page.lp-pattern-future .public-lp-shell {
  background:
    radial-gradient(circle at 78% 10%, rgba(80, 214, 255, .28), transparent 30%),
    radial-gradient(circle at 14% 18%, rgba(255, 205, 104, .26), transparent 34%),
    radial-gradient(circle at 50% 94%, rgba(80, 220, 172, .22), transparent 38%),
    linear-gradient(135deg, #f8fdff 0%, #eef9ff 46%, #fffaf0 100%);
  color: #172033;
}

.public-preview-page.lp-pattern-future .mobile-preview-stage {
  background: linear-gradient(135deg, #eaf8ff, #fff7e7);
}

.public-preview-page.lp-pattern-future .preview-mode-bar {
  background: rgba(255,255,255,.9);
  border-bottom-color: rgba(20,31,48,.1);
  color: #172033;
}

.public-preview-page.lp-pattern-future .preview-mode-bar span,
.public-preview-page.lp-pattern-future .pattern-switch-label {
  color: #667085;
}

.public-preview-page.lp-pattern-future .preview-pattern-switch,
.public-preview-page.lp-pattern-future .preview-icon-switch,
.public-preview-page.lp-pattern-future .preview-device-switch {
  border-color: rgba(20,31,48,.12);
  background: rgba(246,248,251,.9);
}

.public-preview-page.lp-pattern-future .preview-pattern-button,
.public-preview-page.lp-pattern-future .preview-icon-button,
.public-preview-page.lp-pattern-future .preview-device-button {
  color: #475467;
}

.public-preview-page.lp-pattern-future .preview-pattern-button.active,
.public-preview-page.lp-pattern-future .preview-icon-button.active,
.public-preview-page.lp-pattern-future .preview-device-button.active {
  background: linear-gradient(135deg, #1d9bd7, #24b58a);
  color: #fff;
  box-shadow: 0 14px 28px rgba(29,155,215,.2);
}

.public-preview-page.lp-pattern-future .public-job-hero {
  border: 1px solid rgba(20,31,48,.1);
  background:
    linear-gradient(90deg, rgba(29,155,215,.06) 1px, transparent 1px),
    linear-gradient(0deg, rgba(29,155,215,.06) 1px, transparent 1px),
    rgba(255,255,255,.72);
  background-size: 36px 36px, 36px 36px, auto;
  box-shadow: 0 34px 90px rgba(57, 91, 124, .16), inset 0 1px 0 rgba(255,255,255,.86);
}

.public-preview-page.lp-pattern-future .public-job-company,
.public-preview-page.lp-pattern-future .public-job-subtitle,
.public-preview-page.lp-pattern-future .public-job-section p,
.public-preview-page.lp-pattern-future .public-apply-card p,
.public-preview-page.lp-pattern-future .preview-warning,
.public-preview-page.lp-pattern-future .public-job-footer {
  color: #586575;
}

.public-preview-page.lp-pattern-future .lp-hero-kicker {
  border: 1px solid rgba(29,155,215,.18);
  background: #ecf9ff;
  color: #0f6a9b;
}

.public-preview-page.lp-pattern-future .public-job-hero h1,
.public-preview-page.lp-pattern-future .public-job-summary-grid strong,
.public-preview-page.lp-pattern-future .public-job-section h2,
.public-preview-page.lp-pattern-future .apply-card-title,
.public-preview-page.lp-pattern-future .lp-story-card h3,
.public-preview-page.lp-pattern-future .lp-condition-panel h3,
.public-preview-page.lp-pattern-future .condition-row strong {
  color: #172033;
  text-shadow: none;
}

.public-preview-page.lp-pattern-future .public-job-tag {
  border: 1px solid rgba(29,155,215,.16);
  background: rgba(255,255,255,.82);
  color: #0f6a9b;
}

.public-preview-page.lp-pattern-future .public-job-summary-grid > div,
.public-preview-page.lp-pattern-future .public-preview-anchor-nav,
.public-preview-page.lp-pattern-future .public-job-section,
.public-preview-page.lp-pattern-future .public-apply-card,
.public-preview-page.lp-pattern-future .lp-story-card,
.public-preview-page.lp-pattern-future .lp-condition-panel,
.public-preview-page.lp-pattern-future .lp-compact-table {
  border: 1px solid rgba(20,31,48,.1);
  background: rgba(255,255,255,.78);
  box-shadow: 0 22px 58px rgba(57,91,124,.12), inset 0 1px 0 rgba(255,255,255,.82);
  backdrop-filter: blur(18px);
}

.public-preview-page.lp-pattern-future .public-job-summary-grid span,
.public-preview-page.lp-pattern-future .public-link-box span,
.public-preview-page.lp-pattern-future .condition-row span,
.public-preview-page.lp-pattern-future .lp-story-card p,
.public-preview-page.lp-pattern-future .condition-panel-head p {
  color: #667085;
}

.public-preview-page.lp-pattern-future .section-eyebrow,
.public-preview-page.lp-pattern-future .apply-card-kicker,
.public-preview-page.lp-pattern-future .public-apply-highlights span {
  border: 1px solid rgba(36,181,138,.18);
  background: #ecfff7;
  color: #147d62;
}

.public-preview-page.lp-pattern-future .condition-row {
  border-color: rgba(20,31,48,.1);
}

.public-preview-page.lp-pattern-future .public-apply-button {
  background: linear-gradient(135deg, #1d9bd7, #24b58a);
  color: #fff;
  box-shadow: 0 18px 34px rgba(36,181,138,.24);
}

.public-preview-page.lp-pattern-future .apply-support-note,
.public-preview-page.lp-pattern-future .public-link-box {
  border: 1px solid rgba(20,31,48,.1);
  background: rgba(255,255,255,.72);
  color: #586575;
}

.public-preview-page.lp-pattern-future .lp-visual-orbit {
  color: #172033;
}

.public-preview-page.lp-pattern-future .orbit-core {
  background: #fff;
  color: #172033;
  box-shadow: 0 18px 44px rgba(29,155,215,.18);
}

.public-preview-page.lp-pattern-future .lp-signal-card {
  background: rgba(255,255,255,.86);
  color: #172033;
  border-color: rgba(29,155,215,.16);
}

.public-preview-page.lp-pattern-future .lp-signal-card span,
.public-preview-page.lp-pattern-future .lp-signal-card em {
  color: #0f6a9b;
}

.public-preview-page.lp-pattern-future .public-section-label {
  color: #0f6a9b;
}

.public-preview-page.lp-pattern-future .lp-section-icon {
  color: #0f6a9b;
}

.public-preview-page.lp-pattern-future .preview-anchor-chip {
  border-color: rgba(20,31,48,.1);
  background: #fff;
  color: #42526a;
}

.public-preview-page.lp-pattern-future .preview-admin-tools {
  border-color: rgba(20,31,48,.12);
  color: #667085;
}

.public-preview-page.lp-pattern-future .mobile-device-frame {
  background: #dcebf3;
}

.public-preview-page.lp-pattern-future .mobile-device-screen {
  background: #f8fdff;
}

.public-preview-page.lp-pattern-future .mobile-device-top {
  background: #dcebf3;
}

.public-preview-page.lp-pattern-future .lp-hero-kicker::before {
  content: "";
  width: 7px;
  height: 7px;
  margin-right: 7px;
  border-radius: 999px;
  background: #24b58a;
  box-shadow: 0 0 0 5px rgba(36,181,138,.12);
}

.public-preview-page.lp-pattern-future .public-job-hero::after {
  content: "";
  position: absolute;
  right: -80px;
  top: -80px;
  width: 240px;
  height: 240px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,210,97,.35), transparent 64%);
}

.public-preview-page.lp-pattern-future .mobile-device-top {
  display: none;
}

.public-preview-page.lp-pattern-future .public-job-layout,
.public-preview-page.lp-pattern-standard .public-job-layout,
.public-preview-page.lp-pattern-trend .public-job-layout {
  max-width: 1240px;
  grid-template-columns: minmax(0, 1fr) 340px;
}

.public-preview-page.lp-pattern-future .public-job-section,
.public-preview-page.lp-pattern-standard .public-job-section,
.public-preview-page.lp-pattern-trend .public-job-section {
  padding: clamp(24px, 3vw, 34px);
}

.lp-section-card-grid {
  grid-template-columns: minmax(0, 1.28fr) minmax(260px, .86fr);
  gap: 16px;
  align-items: stretch;
}

.lp-story-card.primary {
  grid-row: span 2;
  padding: clamp(20px, 3vw, 28px);
}

.lp-story-card.primary h3 {
  font-size: 20px;
}

.lp-long-paragraph {
  margin: 0 0 14px !important;
  font-size: 14px;
  line-height: 2.05 !important;
  letter-spacing: .01em;
  white-space: pre-wrap;
}

.lp-readable-list {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.lp-readable-list li {
  position: relative;
  padding-left: 18px;
  line-height: 1.9;
  overflow-wrap: anywhere;
}

.lp-readable-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .84em;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: currentColor;
  opacity: .38;
}

.lp-day-flow {
  display: grid;
  gap: 10px;
  margin: 2px 0 0;
  padding: 0;
  list-style: none;
}

.lp-day-flow li {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 11px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(20,31,48,.08);
}

.lp-day-flow time {
  color: #0f6a9b;
  font-size: 12px;
  font-weight: 950;
}

.lp-day-flow span {
  min-width: 0;
  color: inherit;
  line-height: 1.75;
  overflow-wrap: anywhere;
}

.public-preview-page.lp-pattern-trend .public-lp-shell {
  background:
    radial-gradient(circle at 8% 12%, rgba(0, 204, 255, .2), transparent 28%),
    radial-gradient(circle at 88% 14%, rgba(255, 54, 98, .18), transparent 26%),
    linear-gradient(135deg, #fffdfa 0%, #f7fbff 46%, #fff3f6 100%);
}

.public-preview-page.lp-pattern-trend .public-job-hero {
  border: 1px solid rgba(255,54,98,.18);
  background: rgba(255,255,255,.82);
  box-shadow: 0 34px 80px rgba(85, 45, 82, .13);
}

.lp-trend-video-stack {
  position: relative;
  min-height: 330px;
}

.trend-video-card {
  position: absolute;
  display: grid;
  align-content: end;
  gap: 8px;
  border: 1px solid rgba(20,31,48,.08);
  border-radius: 26px;
  padding: 18px;
  background: #fff;
  box-shadow: 0 22px 50px rgba(85,45,82,.16);
}

.trend-video-card span {
  width: fit-content;
  border-radius: 999px;
  padding: 6px 9px;
  background: #111827;
  color: #fff;
  font-size: 11px;
  font-weight: 950;
}

.trend-video-card strong {
  color: #201923;
  font-size: 18px;
}

.trend-video-card em {
  color: #7a6470;
  font-style: normal;
  font-size: 12px;
  font-weight: 850;
}

.trend-video-card.main {
  left: 10%;
  top: 8px;
  width: 190px;
  height: 286px;
  background:
    linear-gradient(160deg, rgba(255,54,98,.12), rgba(0,204,255,.12)),
    #fff;
}

.trend-video-card.sub {
  right: 3%;
  top: 54px;
  width: 166px;
  height: 230px;
  transform: rotate(5deg);
}

.trend-video-card.mini {
  right: 18%;
  bottom: 4px;
  width: 150px;
  height: 150px;
  transform: rotate(-4deg);
}

.public-preview-page.lp-pattern-trend .public-apply-button {
  background: linear-gradient(135deg, #111827, #ff365f 60%, #00c7e5);
}

@media (max-width: 980px) {
  .ai-keyword-lab-head,
  .ai-coverage-columns,
  .ai-variant-head {
    display: grid;
  }

  .ai-variant-grid,
  .lp-section-card-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .lp-story-card.primary {
    grid-row: auto;
  }

  .public-preview-page.lp-pattern-future .public-job-layout,
  .public-preview-page.lp-pattern-standard .public-job-layout,
  .public-preview-page.lp-pattern-trend .public-job-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .lp-trend-video-stack {
    min-height: 260px;
  }

  .trend-video-card.main {
    left: 4%;
    width: 170px;
    height: 238px;
  }

  .trend-video-card.sub {
    right: 2%;
    width: 148px;
    height: 196px;
  }

  .trend-video-card.mini {
    right: 18%;
    width: 130px;
    height: 126px;
  }
}

@media (max-width: 640px) {
  .description-textarea {
    min-height: 330px;
  }

  .appeal-textarea {
    min-height: 240px;
  }

  .ai-keyword-switch-grid {
    max-height: 210px;
    overflow: auto;
    padding-right: 4px;
  }

  .lp-day-flow li {
    grid-template-columns: minmax(0, 1fr);
    gap: 5px;
  }

  .lp-long-paragraph {
    font-size: 13.5px;
    line-height: 1.95 !important;
  }
}

/* codex v0_001_007: separate applicant copy from AI keyword evidence */
.ai-variant-grid {
  grid-template-columns: minmax(0, 1fr);
}

.ai-variant-card {
  gap: 16px;
  border-color: rgba(20, 31, 48, .1);
  box-shadow: 0 14px 34px rgba(29, 76, 112, .08);
}

.ai-variant-body {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, .92fr);
  gap: 14px;
  align-items: start;
}

.ai-variant-copy {
  min-width: 0;
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 16px;
  padding: 16px;
  background: #fff;
}

.ai-variant-copy.appeal-copy {
  background: #f8fbff;
}

.ai-variant-copy b {
  margin-bottom: 9px;
  color: #667085;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ai-variant-copy p,
.ai-requirement-card p {
  margin: 0;
  color: #344054;
  font-family: inherit;
  font-size: 13.5px;
  line-height: 1.9;
}

.public-preview-page.lp-pattern-future .lp-section-card-grid,
.public-preview-page.lp-pattern-standard .lp-section-card-grid,
.public-preview-page.lp-pattern-trend .lp-section-card-grid {
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
}

/* codex v0_001_009: publication gate and Indeed preflight */
.publication-status-card {
  min-width: 180px;
  display: grid;
  gap: 8px;
  justify-items: end;
  padding: 14px 16px;
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 18px;
  background: linear-gradient(180deg, #fff, #f8fbff);
}

.publication-status-card span,
.preflight-summary-grid span,
.feed-review-grid span {
  color: #667085;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.publication-status-card em {
  color: #667085;
  font-size: 12px;
  font-style: normal;
  line-height: 1.5;
  text-align: right;
}

.publication-sync-note {
  margin-top: 14px;
}

.server-save-state {
  background: #eef8ff;
  color: #175cd3;
}

.applicant-sync-metric {
  background: linear-gradient(135deg, #f6fbff 0%, #ffffff 100%);
}

.duplicate-watch-metric {
  background: linear-gradient(135deg, #fff8ed 0%, #ffffff 100%);
}

.duplicate-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  background: #fff6e6;
  color: #9a5b00;
  border: 1px solid rgba(245, 158, 11, .26);
  font-size: 11px;
  font-weight: 900;
  vertical-align: middle;
}

.duplicate-badge.high {
  background: #fff1f1;
  color: #b42318;
  border-color: rgba(244, 63, 94, .26);
}

.applicant-safety-card,
.applicant-history-card {
  border-color: rgba(17, 24, 39, .08);
}

.safe-pill,
.risk-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.safe-pill {
  background: #ecfdf3;
  color: #027a48;
}

.risk-pill {
  background: #fff6e6;
  color: #9a5b00;
}

.risk-pill.high {
  background: #fff1f1;
  color: #b42318;
}

.duplicate-summary-line {
  margin: 4px 0 12px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}

.duplicate-candidate-list,
.status-timeline {
  display: grid;
  gap: 10px;
}

.duplicate-candidate-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 12px;
}

.duplicate-candidate-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.status-timeline-row {
  position: relative;
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 10px;
  padding: 10px 0;
}

.status-timeline-row:not(:last-child)::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 24px;
  bottom: -8px;
  width: 2px;
  background: #d8e2ef;
}

.status-timeline-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 5px;
  background: #175cd3;
  box-shadow: 0 0 0 4px #eef8ff;
}

.followup-task-list,
.interview-draft-list {
  display: grid;
  gap: 10px;
}

.followup-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  margin: 0 0 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fbfdff;
  padding: 12px;
}

.followup-task-row,
.interview-draft-row {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  padding: 14px;
}

.followup-task-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.followup-task-row.urgent {
  border-color: rgba(244, 63, 94, .28);
  background: linear-gradient(135deg, #fff7f7 0%, #ffffff 100%);
}

.followup-task-row p,
.interview-draft-row p {
  margin: 8px 0;
  color: var(--text);
  font-size: 13px;
  line-height: 1.7;
}

.followup-task-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.interview-draft-row {
  background: linear-gradient(135deg, #f8fbff 0%, #ffffff 100%);
}

.interview-approval-box {
  border: 1px solid rgba(23, 92, 211, .14);
  border-radius: 14px;
  background: #fff;
  padding: 12px;
  margin-top: 12px;
}

.applicant-ops-dashboard-card {
  margin-bottom: 16px;
  border-color: rgba(23, 92, 211, .14);
  background:
    radial-gradient(circle at 0% 0%, rgba(23, 92, 211, .10), transparent 30%),
    linear-gradient(135deg, #f7fbff 0%, #ffffff 72%);
}

.applicant-ops-dashboard-card.red {
  border-color: rgba(244, 63, 94, .28);
  background:
    radial-gradient(circle at 0% 0%, rgba(244, 63, 94, .10), transparent 30%),
    linear-gradient(135deg, #fff8f8 0%, #ffffff 72%);
}

.ops-metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.ops-metric {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  padding: 14px;
}

.ops-metric span,
.ops-metric small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.ops-metric strong {
  display: block;
  margin: 5px 0;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
}

.ops-metric.warn {
  border-color: rgba(245, 158, 11, .28);
  background: #fffaf0;
}

.ops-metric.danger {
  border-color: rgba(244, 63, 94, .28);
  background: #fff5f5;
}

.ops-dashboard-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px;
}

.ops-panel-list {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  padding: 12px;
}

.mini-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.ops-task-row,
.ops-risk-row {
  display: grid;
  gap: 4px;
  border-top: 1px solid var(--line);
  padding: 10px 0;
}

.ops-task-row:first-of-type,
.ops-risk-row:first-of-type {
  border-top: 0;
}

.ops-task-row div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.ops-task-row span,
.ops-task-row em,
.ops-risk-row span,
.ops-risk-row small {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.ops-risk-row.high {
  color: #b42318;
}

.sync-status-value {
  font-size: 15px;
  line-height: 1.35;
  color: #175cd3;
}

.sync-error-text {
  display: block;
  margin-top: 6px;
  color: #b42318;
  font-size: 11px;
}

.outbox-summary-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.outbox-summary-strip > div {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #f8fbff;
  padding: 14px 16px;
}

.outbox-summary-strip span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 6px;
}

.outbox-summary-strip strong {
  color: var(--text);
  font-size: 18px;
}

.outbox-list {
  display: grid;
  gap: 12px;
  margin: 0 0 18px;
}

.adapter-boundary-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, auto);
  gap: 14px;
  align-items: center;
  border: 1px solid rgba(23, 92, 211, .14);
  border-radius: 18px;
  background: linear-gradient(135deg, #f5f9ff 0%, #ffffff 100%);
  padding: 16px;
  margin: 0 0 16px;
}

.adapter-boundary-card p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.adapter-status-grid {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.adapter-status-pill {
  display: inline-flex;
  border-radius: 999px;
  background: #eef8ff;
  color: #175cd3;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.outbox-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #fff;
  padding: 16px;
}

.outbox-row.needs-review {
  border-color: #b9dcff;
  background: linear-gradient(135deg, #f3f9ff 0%, #fff 100%);
}

.outbox-main p {
  margin: 10px 0;
  color: var(--text);
  line-height: 1.7;
  font-size: 13px;
}

.outbox-checklist {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fbfdff;
  padding: 12px;
  margin-top: 12px;
}

.checklist-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  font-size: 12px;
  color: var(--muted);
}

.checklist-chip-grid {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.check-chip {
  appearance: none;
  border: 1px solid #d8e2ef;
  background: #fff;
  color: var(--muted);
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.check-chip.checked {
  border-color: rgba(2, 122, 72, .24);
  background: #ecfdf3;
  color: #027a48;
}

.outbox-audit-trail {
  display: grid;
  gap: 6px;
  margin-top: 12px;
}

.audit-line {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: 12px;
}

.audit-line strong {
  color: var(--text);
}

.outbox-status {
  border-radius: 999px;
  background: #eef8ff;
  color: #175cd3;
  font-size: 11px;
  font-weight: 900;
  padding: 5px 9px;
}

.outbox-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

@media (max-width: 760px) {
  .outbox-summary-strip,
  .outbox-row,
  .adapter-boundary-card,
  .followup-toolbar,
  .followup-task-row,
  .ops-dashboard-split,
  .duplicate-candidate-row {
    grid-template-columns: 1fr;
  }

  .outbox-actions,
  .adapter-status-grid,
  .followup-task-actions,
  .duplicate-candidate-meta {
    justify-content: stretch;
  }
}

.publication-gate-card,
.indeed-export-card,
.publication-state-card {
  margin-bottom: 16px;
}

.publication-gate-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 20px;
  align-items: center;
  padding: 20px;
  border-radius: 22px;
  background:
    radial-gradient(circle at 10% 0%, rgba(88, 166, 255, .18), transparent 32%),
    linear-gradient(135deg, #f8fbff, #fffaf1);
  border: 1px solid rgba(20, 31, 48, .08);
}

.publication-gate-hero h3 {
  margin: 4px 0 8px;
  font-size: 24px;
}

.publication-gate-hero p {
  margin: 0;
  color: #475467;
  line-height: 1.8;
}

.preflight-score {
  width: 132px;
  height: 132px;
  display: grid;
  place-items: center;
  justify-self: end;
  border-radius: 34px;
  background: #fff;
  border: 1px solid rgba(20, 31, 48, .08);
  box-shadow: 0 22px 46px rgba(20, 31, 48, .10);
}

.preflight-score span,
.preflight-score em {
  color: #667085;
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.preflight-score strong {
  margin-top: -6px;
  font-size: 42px;
  line-height: 1;
}

.preflight-score.safe strong { color: #12715b; }
.preflight-score.warn strong { color: #b76e00; }
.preflight-score.danger strong { color: #b42318; }

.preflight-summary-grid,
.feed-review-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.preflight-summary-grid > div,
.feed-review-grid > div {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 16px;
  background: #fff;
}

.preflight-summary-grid strong,
.feed-review-grid strong,
.feed-review-grid code {
  min-width: 0;
  color: #182230;
  font-size: 15px;
  overflow-wrap: anywhere;
}

.publication-actions,
.status-action-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.publication-url {
  margin-top: 14px;
}

.preflight-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-bottom: 16px;
}

.preflight-group {
  display: grid;
  gap: 12px;
  padding: 18px;
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 14px 30px rgba(20, 31, 48, .05);
}

.preflight-group h4 {
  margin: 0;
  color: #182230;
}

.preflight-list {
  display: grid;
  gap: 10px;
}

.preflight-row {
  display: grid;
  gap: 10px;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(20, 31, 48, .08);
  background: #fcfcfd;
}

.preflight-row.warn {
  background: #fffaf0;
  border-color: rgba(245, 158, 11, .22);
}

.preflight-row.fail {
  background: #fff6f4;
  border-color: rgba(217, 45, 32, .22);
}

.preflight-row-main {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.preflight-row-main strong {
  display: block;
  margin-bottom: 4px;
  color: #182230;
}

.preflight-row-main p,
.preflight-fix {
  margin: 0;
  color: #667085;
  line-height: 1.65;
  font-size: 13px;
}

.preflight-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
}

.preflight-badge.pass { background: #e8f8f1; color: #12715b; }
.preflight-badge.warn { background: #fff0d1; color: #9a5b00; }
.preflight-badge.fail { background: #fee4df; color: #b42318; }

.preflight-fix {
  padding-left: 52px;
}

.preflight-fix span {
  display: inline-flex;
  margin-right: 8px;
  padding: 2px 7px;
  border-radius: 999px;
  background: #f2f4f7;
  color: #475467;
  font-size: 11px;
  font-weight: 800;
}

.status-action-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.status-action {
  display: grid;
  justify-items: start;
  gap: 10px;
  min-height: 112px;
  padding: 16px;
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 18px;
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.status-action.active {
  border-color: rgba(29, 155, 215, .32);
  background: linear-gradient(180deg, #f2fbff, #fff);
  box-shadow: 0 16px 34px rgba(29, 155, 215, .10);
}

.status-action em {
  color: #667085;
  font-size: 12px;
  font-style: normal;
  line-height: 1.55;
}

.danger-note {
  background: #fff6f4;
  border-color: rgba(217, 45, 32, .18);
  color: #b42318;
}

.feed-score.safe { color: #12715b; }
.feed-score.warn { color: #b76e00; }
.feed-score.danger { color: #b42318; }
.feed-score.idle { color: #667085; }

.feed-validation-list {
  display: grid;
  gap: 10px;
  margin: 12px 0;
}

.feed-check-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(20, 31, 48, .08);
  background: #fcfcfd;
}

.feed-check-row.warn {
  background: #fffaf0;
  border-color: rgba(245, 158, 11, .22);
}

.feed-check-row.error {
  background: #fff6f4;
  border-color: rgba(217, 45, 32, .22);
}

.feed-check-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 48px;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
}

.feed-check-pill.warn {
  background: #fff0d1;
  color: #9a5b00;
}

.feed-check-pill.error {
  background: #fee4df;
  color: #b42318;
}

.feed-check-row strong {
  display: block;
  margin-bottom: 4px;
  color: #182230;
}

.feed-check-row p {
  margin: 0;
  color: #667085;
  line-height: 1.65;
  font-size: 13px;
}

@media (max-width: 980px) {
  .app-shell,
  .workspace,
  .main-card,
  .editor-body {
    min-width: 0;
  }

  .workspace {
    width: 100%;
    padding: 12px 8px 96px;
  }

  .editor-header {
    display: grid;
    padding: 20px 16px 14px;
  }

  .editor-pipeline-card {
    min-width: 0;
    width: 100%;
  }

  .editor-main {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 14px;
    padding: 16px 12px 0;
  }

  .tab-panel,
  .section-card,
  .preflight-grid,
  .preflight-group {
    min-width: 0;
  }

  .toc {
    position: static;
    top: auto;
    max-height: 248px;
    overflow: auto;
  }

  .panel-top {
    display: grid;
  }

  .tab-strip {
    padding-inline: 12px;
    scroll-snap-type: x proximity;
  }

  .top-tab {
    scroll-snap-align: start;
  }

  .media-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .publication-gate-hero,
  .preflight-grid,
  .status-action-grid,
  .preflight-summary-grid,
  .feed-review-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .preflight-score,
  .publication-status-card {
    justify-self: stretch;
  }

  .preflight-score {
    width: 100%;
    height: auto;
    min-height: 120px;
  }

  .preflight-fix {
    padding-left: 0;
  }
}

.lp-story-card.primary {
  grid-row: auto;
}

.lp-story-card {
  padding: clamp(18px, 2.4vw, 26px);
}

.lp-story-card h3 {
  margin-bottom: 12px;
  font-size: 18px;
}

.lp-story-card.primary h3 {
  font-size: 21px;
}

.lp-story-card p,
.lp-readable-list li,
.lp-day-flow span {
  font-family: inherit;
  font-size: 14px;
}

.lp-coverage-note {
  margin-top: 14px;
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, .56);
  color: #667085;
  font-family: inherit;
  font-size: 12px;
}

.lp-coverage-note summary {
  cursor: pointer;
  font-weight: 900;
  letter-spacing: .02em;
}

.lp-coverage-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
}

.lp-coverage-tags span {
  border: 1px solid rgba(20, 31, 48, .08);
  border-radius: 999px;
  padding: 5px 8px;
  background: #fff;
  color: #667085;
  font-size: 11px;
  font-weight: 800;
}

@media (max-width: 980px) {
  .ai-variant-body {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* codex v0_001_008: AI proposal workbench */
.ai-workbench {
  display: grid;
  gap: 14px;
}

.ai-variant-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 4px 2px 8px;
  scrollbar-width: none;
}

.ai-variant-tabs::-webkit-scrollbar {
  display: none;
}

.ai-variant-tab {
  flex: 0 0 auto;
  min-width: 168px;
  border: 1px solid rgba(20,31,48,.1);
  border-radius: 16px;
  padding: 11px 13px;
  background: #fff;
  color: #344054;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 8px 20px rgba(16,24,40,.045);
}

.ai-variant-tab.active {
  border-color: rgba(29,155,215,.28);
  background: linear-gradient(180deg, #f2fbff, #fff);
  box-shadow: 0 14px 30px rgba(29,155,215,.12);
}

.ai-variant-tab span,
.ai-variant-tab em {
  display: block;
}

.ai-variant-tab span {
  font-weight: 900;
}

.ai-variant-tab em {
  margin-top: 5px;
  color: #667085;
  font-size: 11px;
  font-style: normal;
  font-weight: 850;
}

.ai-workbench-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: end;
  margin-bottom: 10px;
}

.ai-workbench-title strong {
  color: #172033;
}

.ai-workbench-title span {
  color: #667085;
  font-size: 12px;
  line-height: 1.5;
}

.ai-comparison-wrap,
.ai-change-preview {
  border: 1px solid rgba(20,31,48,.09);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,.84);
}

.ai-comparison-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  border: 1px solid rgba(20,31,48,.08);
  border-radius: 14px;
}

.ai-comparison-table th,
.ai-comparison-table td {
  padding: 12px;
  border-bottom: 1px solid rgba(20,31,48,.07);
  text-align: left;
  vertical-align: top;
  font-size: 12px;
}

.ai-comparison-table th {
  background: #f8fafc;
  color: #667085;
  font-weight: 900;
}

.ai-comparison-table tbody tr {
  cursor: pointer;
}

.ai-comparison-table tbody tr.active {
  background: #f1fbff;
}

.ai-comparison-table td strong,
.ai-comparison-table td span {
  display: block;
}

.ai-comparison-table td span {
  margin-top: 4px;
  color: #667085;
  line-height: 1.45;
}

.ai-decision-pill {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 5px 9px;
  background: #eef8ff;
  color: #0f6a9b;
  font-size: 11px;
  font-weight: 900;
}

.ai-decision-pill.decision-adopted,
.ai-variant-tab.decision-adopted em {
  color: #147d62;
}

.ai-decision-pill.decision-hold,
.ai-variant-tab.decision-hold em {
  color: #a15c07;
}

.ai-decision-pill.decision-rejected,
.ai-variant-tab.decision-rejected em {
  color: #b42318;
}

.ai-diff-stats,
.ai-impact-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.ai-diff-stat,
.ai-impact-chips span {
  display: inline-flex;
  gap: 6px;
  align-items: center;
  border: 1px solid rgba(20,31,48,.08);
  border-radius: 999px;
  padding: 6px 9px;
  background: #fff;
  color: #475467;
  font-size: 11px;
  font-weight: 850;
}

.ai-impact-chips b {
  color: #0f6a9b;
}

.ai-preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.ai-preview-column {
  min-width: 0;
  border: 1px solid rgba(20,31,48,.08);
  border-radius: 14px;
  padding: 12px;
  background: #f8fafc;
}

.ai-preview-column.proposed {
  background: #fff;
  border-color: rgba(29,155,215,.16);
}

.ai-preview-column b {
  display: block;
  margin-bottom: 7px;
  color: #667085;
  font-size: 11px;
}

.ai-preview-column p {
  margin: 0;
  color: #344054;
  font-size: 12px;
  line-height: 1.7;
}

.danger-lite {
  color: #b42318;
  border-color: rgba(180,35,24,.18);
}

@media (max-width: 760px) {
  .ai-preview-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .ai-comparison-table {
    display: block;
    overflow-x: auto;
  }
}
