@font-face {
  font-family: "Rammetto One";
  src: url("/assets/fonts/RammettoOne-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-display: "Rammetto One", Barlow, Arial, sans-serif;

  --color-ink: #28231f;
  --color-muted: #6f675f;
  --color-page: #fffaf2;
  --color-surface: #ffffff;
  --color-surface-soft: #fffdf9;
  --color-surface-warm: #fff7ea;
  --color-surface-code: #f3eadf;
  --color-line: #e7dbc9;
  --color-line-strong: #d7c9b7;
  --color-line-hover: #d0b995;
  --color-brand: #1d64b7;
  --color-brand-soft: #eef6ff;
  --color-brand-ring: rgba(29, 100, 183, .14);
  --color-match: #1d64b7;
  --color-match-soft: #e8f4ff;
  --color-match-line: #b9d9f6;
  --color-danger: #c72638;
  --color-success: #2f7d54;
  --color-success-soft: #eef8eb;
  --color-success-line: #d8e6d5;
  --color-success-text: #265d36;
  --color-badge-success-bg: #e9f5ee;
  --color-warning: #7a4a00;
  --color-warning-soft: #fff6dd;
  --color-warning-line: #f0cf8a;
  --color-badge-warning: #915f00;
  --color-badge-warning-bg: #fff1c8;
  --color-alert: #b42335;
  --color-alert-soft: #fff8f8;
  --color-badge-danger: #981d2d;
  --color-badge-danger-bg: #ffe2e6;
  --color-release-line: #f1b9b2;
  --color-release-bg: #fff4f2;
  --color-add-line: #b7d8bf;
  --color-add-bg: #f0faf2;
  --color-swatch-line: #c9c0b4;
  --color-overlay: rgba(27, 22, 18, .48);
  --color-footer-bg: rgba(255, 250, 242, .96);
  --color-secondary: #3b4a5f;

  --space-0: 0;
  --space-1: 2px;
  --space-2: 4px;
  --space-3: 6px;
  --space-4: 8px;
  --space-5: 10px;
  --space-6: 12px;
  --space-7: 14px;
  --space-8: 16px;
  --space-9: 18px;
  --space-10: 20px;
  --space-11: 22px;
  --space-12: 24px;
  --space-13: 26px;
  --space-14: 28px;
  --space-16: 32px;
  --space-17: 34px;
  --space-20: 40px;
  --space-24: 48px;
  --space-28: 56px;
  --space-32: 64px;
  --gap-stack: var(--space-7);
  --gap-form-row: var(--space-7);
  --gap-form-column: var(--space-8);
  --gap-actions: var(--space-6);
  --gap-inline-control: var(--space-5);
  --gap-children: var(--space-5);

  --radius-xs: 4px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 10px;
  --radius-round: 999px;
  --radius-circle: 50%;

  --font-size-xs: .78rem;
  --font-size-sm: .82rem;
  --font-size-md: .86rem;
  --font-size-nav: .9rem;
  --font-size-form-label: .86rem;
  --font-size-control: .95rem;
  --font-size-button: .94rem;
  --font-size-card: .92rem;
  --font-size-base: 1rem;
  --font-size-intro-item: 1.02rem;
  --font-size-section: 1.05rem;
  --font-size-copy: 1.08rem;
  --font-size-total: 1.15rem;
  --font-size-tile: 1.3rem;
  --font-size-h3: clamp(1.08rem, 1.4vw, 1.25rem);
  --font-size-h2: clamp(1.28rem, 2vw, 1.65rem);
  --font-size-h1: clamp(1.65rem, 3vw, 2.35rem);
  --font-size-step-total: clamp(1.35rem, 3vw, 2rem);
  --font-size-hero: clamp(2rem, 5vw, 4.4rem);

  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-strong: 600;
  --font-weight-label: 500;
  --font-weight-control: 400;
  --font-weight-button: 600;
  --font-weight-bold: 650;
  --font-weight-heavy: 650;

  --leading-tight: 1;
  --leading-control: 1.05;
  --leading-title: 1.15;
  --leading-copy: 1.55;

  --container-width: 1120px;
  --auth-panel-width: 480px;
  --auth-panel-margin-top: clamp(var(--space-12), 8vh, var(--space-32));
  --auth-panel-gap: var(--space-7);
  --footer-height: 84px;
  --control-height: 44px;
  --control-height-sm: 34px;
  --child-row-padding: var(--space-6);
  --step-actions-margin-top: var(--space-8);
  --qty-height: 42px;
  --avatar-size: 76px;
  --header-logo-size: 46px;
  --cart-thumb-width: 54px;
  --cart-thumb-height: 64px;
  --cart-thumb-width-mobile: 48px;
  --cart-thumb-height-mobile: 58px;

  --shadow-soft: 0 10px 26px rgba(48, 38, 25, .08);
  --shadow-modal: 0 24px 80px rgba(0, 0, 0, .24);
  --ring-selected: inset 0 0 0 2px var(--color-brand-ring);
  --ring-focus: inset 0 0 0 2px var(--color-brand-ring);
  --ring-transparent: 0 0 0 0 rgba(29, 100, 183, 0);
  --ring-danger-soft: inset 0 0 0 2px rgba(199, 38, 56, .08);

  --duration-fast: .16s;

  --red: var(--color-danger);
  --select: var(--color-brand);
  --select-soft: var(--color-brand-soft);
  --select-ring: var(--color-brand-ring);
  --ink: var(--color-ink);
  --muted: var(--color-muted);
  --paper: var(--color-page);
  --line: var(--color-line);
  --gold: #f4b545;
  --green: var(--color-success);
}

* { box-sizing: border-box; }
html { min-height: 100%; }
body { min-height: 100vh; margin: 0; padding-bottom: var(--footer-height); font-family: var(--font-sans); color: var(--color-ink); background: var(--color-page); }
body.admin { overflow-y: scroll; scrollbar-gutter: stable; }
a { color: inherit; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-12); padding: var(--space-7) clamp(var(--space-8), 4vw, var(--space-24)); background: var(--color-surface); border-bottom: 1px solid var(--color-line); position: sticky; top: 0; z-index: 10; }
.brand { display: flex; align-items: center; gap: var(--space-6); text-decoration: none; font-weight: var(--font-weight-bold); }
.brand img { width: var(--header-logo-size); height: var(--header-logo-size); object-fit: contain; }
nav { display: flex; gap: var(--space-8); color: var(--color-muted); font-weight: var(--font-weight-strong); }
.user-menu { align-items: center; flex-wrap: wrap; justify-content: flex-end; gap: var(--space-4); }
.user-menu span { color: var(--color-ink); font-weight: var(--font-weight-heavy); }
.user-menu a { padding: 7px 9px; border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-page); text-decoration: none; font-size: var(--font-size-nav); }
.user-menu a:hover { border-color: var(--color-brand); color: var(--color-brand); }
main { width: min(var(--container-width), calc(100% - var(--space-16))); margin: var(--space-14) auto var(--space-28); }
main:has(.admin-block),
main:has(.admin-search) { width: min(1520px, calc(100% - var(--space-8))); }
.hero { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: var(--space-16); padding: clamp(var(--space-14), 6vw, var(--space-32)); background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md); }
.hero h1 { margin: 0 0 var(--space-7); font-size: var(--font-size-hero); line-height: .98; }
.hero p, .intro p { color: var(--color-muted); font-size: var(--font-size-copy); line-height: var(--leading-copy); }
.hero img { width: 100%; max-height: 440px; object-fit: contain; }
.tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-9); margin-top: var(--space-11); }
.tiles.single { grid-template-columns: minmax(0, 1fr); }
.tile { min-height: 150px; padding: var(--space-12); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); text-decoration: none; display: flex; flex-direction: column; justify-content: space-between; }
.tile strong { font-size: var(--font-size-tile); }
.tile span { color: var(--color-muted); }
.tile.active { border-color: var(--color-danger); box-shadow: var(--ring-danger-soft); }
.tile.disabled { opacity: .55; }
.panel { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: clamp(var(--space-10), 4vw, var(--space-17)); margin-bottom: var(--space-8); }
.narrow { max-width: 520px; margin: var(--space-20) auto; }
.auth-panel { width: min(var(--auth-panel-width), 100%); max-width: var(--auth-panel-width); margin: var(--auth-panel-margin-top) auto; gap: var(--auth-panel-gap); padding: clamp(var(--space-10), 3vw, var(--space-14)); }
.auth-panel h1 { margin-bottom: var(--space-2); }
.auth-panel p { margin: 0; color: var(--color-muted); font-size: var(--font-size-base); line-height: var(--leading-copy); }
.auth-panel .actions { margin: var(--space-3) 0 0; }
.auth-panel > .button, .auth-panel > button { justify-self: start; }
main:has(.auth-panel) > .notice { width: min(var(--auth-panel-width), 100%); margin-left: auto; margin-right: auto; }
h1, h2, h3 { margin-top: 0; line-height: var(--leading-title); font-weight: var(--font-weight-bold); }
h1 { font-size: var(--font-size-h1); }
h2 { font-size: var(--font-size-h2); }
h3 { font-size: var(--font-size-h3); }
.button, button { appearance: none; border: 0; border-radius: var(--radius-sm); background: var(--color-brand); color: var(--color-surface); padding: var(--space-6) var(--space-9); font-family: var(--font-sans); font-size: var(--font-size-button); font-weight: var(--font-weight-button); line-height: var(--leading-control); cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; min-height: var(--control-height); }
.button.secondary, button.secondary { background: var(--color-secondary); }
.button.disabled, button:disabled { background: var(--color-muted); cursor: not-allowed; pointer-events: none; }
.list { display: grid; gap: var(--space-6); }
.perf, .ticket-row { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: var(--space-9); align-items: center; padding: var(--space-10); background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md); }
.purchase-ticket-row { grid-template-columns: minmax(0, 1fr) minmax(420px, max-content); }
.purchase-category-grid { display: grid; grid-template-columns: repeat(2, 190px); gap: var(--space-7); align-items: start; }
.ticket-category-control { display: grid; grid-template-rows: 20px 16px var(--qty-height); gap: var(--space-2); height: auto; min-width: 190px; padding-bottom: 0; }
.ticket-category-control > span { grid-row: 1; font-weight: var(--font-weight-label); line-height: 20px; }
.ticket-category-note { grid-row: 2; display: block; min-height: 16px; line-height: 16px; white-space: nowrap; }
.ticket-category-control .qty-stepper { grid-row: 3; }
.ticket-list { display: grid; gap: var(--space-7); }
.perf h3 { margin-bottom: 4px; }
.perf p, .ticket-row span { margin: 0; color: var(--color-muted); }
.intro-performances { display: grid; gap: var(--space-5); margin: var(--space-10) 0 var(--space-11); padding: var(--space-8) 0; border-top: 1px solid var(--color-line); border-bottom: 1px solid var(--color-line); list-style: none; }
.intro-performances li { display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-4); align-items: baseline; padding: 0; }
.intro-performances strong { font-size: var(--font-size-intro-item); }
.intro-performances span { color: var(--color-muted); }
.performance-meta { display: grid; gap: 7px; align-content: center; }
.performance-meta strong { font-size: clamp(1.18rem, 2vw, 1.55rem); line-height: 1.08; }
.performance-meta span { display: block; color: var(--color-ink); font-size: clamp(1.04rem, 1.7vw, 1.3rem); font-weight: var(--font-weight-bold); }
.performance-meta .availability-note { color: var(--color-muted); font-size: var(--font-size-sm); font-weight: var(--font-weight-strong); }
.ticket-row label > span small { display: block; margin-top: var(--space-1); color: var(--color-muted); font-size: var(--font-size-xs); font-weight: var(--font-weight-strong); }
.badge { white-space: nowrap; border-radius: var(--radius-round); padding: 7px 11px; font-weight: var(--font-weight-strong); font-size: .88rem; }
.badge.ok { color: var(--color-success); background: var(--color-badge-success-bg); }
.badge.warn { color: var(--color-badge-warning); background: var(--color-badge-warning-bg); }
.badge.danger { color: var(--color-badge-danger); background: var(--color-badge-danger-bg); }
.flow, form.panel { display: grid; gap: var(--gap-stack); }
.step-panel { margin-bottom: 0; }
.step-panel.is-hidden { display: none; }
.step-actions { display: flex; justify-content: flex-end; gap: var(--gap-actions); margin-top: var(--step-actions-margin-top); }
.step-summary { position: sticky; bottom: 80px; display: flex; align-items: center; justify-content: space-between; gap: var(--space-9); margin-top: var(--space-9); padding: var(--space-8) var(--space-9); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-warm); box-shadow: var(--shadow-soft); }
.step-summary span { color: var(--color-muted); font-weight: var(--font-weight-strong); }
.step-summary strong { font-size: var(--font-size-step-total); }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--gap-form-row) var(--gap-form-column); align-items: start; }
.form-grid .full { grid-column: 1 / -1; }
label { position: relative; display: grid; align-self: start; gap: var(--space-3); padding-bottom: 0; color: var(--color-ink); font-size: var(--font-size-form-label); font-weight: var(--font-weight-label); }
label:has(> input:not([type="radio"]):not([type="checkbox"])), label:has(> select) { grid-template-rows: 20px var(--control-height); height: calc(20px + var(--space-3) + var(--control-height)); }
label:has(> textarea) { grid-template-rows: 20px 110px; height: calc(20px + var(--space-3) + 110px); }
.form-grid > label { grid-template-rows: 20px var(--control-height); align-self: start; gap: var(--space-3); height: calc(20px + var(--space-3) + var(--control-height)); padding-bottom: 0; }
.form-grid > label > span { min-height: 20px; line-height: 20px; }
fieldset { position: relative; margin: 0; padding: 0 0 var(--space-9); border: 0; }
.class-picker legend { margin-bottom: var(--space-6); font-weight: var(--font-weight-strong); }
.children-editor { display: grid; gap: var(--gap-children); margin-top: var(--space-2); padding: 0; border: 0; border-radius: 0; background: transparent; }
.children-editor h3 { margin: var(--space-2) 0 var(--space-1); font-size: var(--font-size-section); font-weight: var(--font-weight-strong); }
.children-list { display: grid; gap: var(--gap-children); }
.child-row { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(170px, .7fr) auto; gap: var(--gap-form-row); align-items: start; padding: var(--child-row-padding); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-soft); }
.child-row label { padding-bottom: 0; }
.child-remove { min-height: var(--control-height); margin-top: calc(20px + var(--space-3)); padding: var(--space-6) var(--space-8); white-space: nowrap; }
.child-add { justify-self: start; min-height: var(--control-height); padding: var(--space-6) var(--space-8); }
.class-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-6); }
.class-card { position: relative; display: grid; justify-items: center; gap: var(--space-4); padding: var(--space-7) var(--space-4) var(--space-6); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-soft); text-align: center; cursor: pointer; transition: border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease, opacity var(--duration-fast) ease, filter var(--duration-fast) ease; }
.class-card:hover { border-color: var(--color-line-hover); }
.class-card input { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }
.class-card:has(input:checked) { border-color: var(--color-brand); box-shadow: var(--ring-selected); }
.class-grid.has-selection .class-card:not(:has(input:checked)) { opacity: .42; filter: grayscale(.35); }
.class-avatar { width: var(--avatar-size); height: var(--avatar-size); border-radius: var(--radius-circle); overflow: hidden; background: var(--color-surface); }
.class-avatar img { width: 100%; height: 100%; object-fit: cover; display: block; }
.class-card > span:last-child { color: var(--color-ink); font-size: var(--font-size-card); line-height: 1.2; }
input:not([type="checkbox"]):not([type="radio"]), select, textarea { display: block; width: 100%; height: var(--control-height); border: 1px solid var(--color-line-strong); border-radius: var(--radius-sm); padding: var(--space-5) var(--space-9) var(--space-5) var(--space-6); font-family: var(--font-sans); font-size: var(--font-size-control); font-weight: var(--font-weight-control); line-height: var(--leading-control); background: var(--color-surface-soft); outline: 0; box-shadow: var(--ring-transparent); }
input:not([type="checkbox"]):not([type="radio"]):focus, select:focus, textarea:focus { border-color: var(--color-brand); box-shadow: var(--ring-focus); }
input:not([type="checkbox"]):not([type="radio"]).is-invalid, select.is-invalid, textarea.is-invalid { border-color: var(--color-alert); background: var(--color-alert-soft); }
input[type="checkbox"], input[type="radio"] { flex: 0 0 auto; width: 18px; height: 18px; margin: 0; padding: 0; accent-color: var(--color-brand); cursor: pointer; }
.field-error { position: absolute; left: 0; right: 0; top: calc(20px + var(--space-3) + var(--control-height) + var(--space-2)); display: none; color: var(--color-alert); font-size: var(--font-size-sm); font-weight: var(--font-weight-strong); line-height: 1.2; }
label:has(> textarea) > .field-error { top: calc(20px + var(--space-3) + 110px + var(--space-2)); }
.field-error:not(:empty) { display: block; }
textarea { height: 110px; resize: vertical; }
.qty, input.qty { width: var(--cart-thumb-width); height: var(--qty-height); border-left: 0; border-right: 0; border-radius: 0 !important; padding: 0; text-align: center; appearance: textfield; -webkit-appearance: none; -moz-appearance: textfield; background-clip: padding-box; }
.qty::-webkit-outer-spin-button,
.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.qty-stepper { display: inline-grid; grid-template-columns: var(--qty-height) var(--cart-thumb-width) var(--qty-height); align-items: stretch; justify-content: end; width: max-content; }
.qty-stepper:has(.qty-prefix) { grid-template-columns: minmax(38px, auto) var(--qty-height) var(--cart-thumb-width) var(--qty-height); }
.qty-prefix { display: inline-flex; align-items: center; justify-content: flex-end; min-width: 38px; padding-right: var(--space-4); color: var(--color-muted); font-weight: var(--font-weight-strong); white-space: nowrap; }
.qty-btn { min-height: var(--qty-height); width: var(--qty-height); padding: 0; border: 1px solid var(--color-line-strong); background: var(--color-surface-warm); color: var(--color-ink); font-size: var(--font-size-tile); line-height: var(--leading-tight); }
.qty-btn:disabled, .qty:disabled { opacity: .45; cursor: not-allowed; }
.qty-btn.is-disabled { opacity: .45; cursor: not-allowed; }
.qty-btn[data-qty-step="-1"] { border-right: 0; border-radius: var(--radius-sm) 0 0 var(--radius-sm); }
.qty-btn[data-qty-step="1"] { border-left: 0; border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.check, .checkbox { display: flex; align-items: center; gap: var(--gap-inline-control); min-height: 24px; height: auto; padding-bottom: 0; font-weight: var(--font-weight-label); color: var(--color-ink); }
.check input, .checkbox input { width: 18px; }
.check span, .checkbox span { min-height: 0; line-height: var(--leading-title); }
.notice { padding: var(--space-7) var(--space-8); border: 1px solid var(--color-success-line); background: var(--color-success-soft); color: var(--color-success-text); border-radius: var(--radius-md); margin-bottom: var(--space-9); font-weight: var(--font-weight-medium); }
.notice.warning { border-color: var(--color-warning-line); background: var(--color-warning-soft); color: var(--color-warning); }
.sale-phase-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-9); }
.sale-phase-grid article { border: 1px solid var(--color-line); border-radius: var(--radius-sm); padding: var(--space-8); background: var(--color-bg); }
.sale-phase-grid h3 { margin-top: 0; }
.final-summary { margin: var(--space-9) 0; padding: var(--space-8); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-page); }
.final-summary h3 { margin: 0 0 var(--space-5); }
.final-summary ul { display: grid; gap: var(--space-4); margin: 0; padding: 0; list-style: none; }
.final-summary li { display: grid; gap: var(--space-2); padding: var(--space-5) var(--space-6); border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface); }
.final-summary li.release { border-color: var(--color-release-line); background: var(--color-release-bg); }
.final-summary li.add { border-color: var(--color-add-line); background: var(--color-add-bg); }
.final-summary strong { color: var(--color-danger); }
.final-summary li.add strong { color: var(--color-success); }
.actions { display: flex; flex-wrap: wrap; gap: var(--gap-actions); align-items: center; margin-bottom: var(--space-9); }
.account-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-8); align-items: start; }
.account-grid-stacked { grid-template-columns: minmax(0, 1fr); }
.account-side { display: grid; gap: var(--space-8); min-width: 0; }
.account-card { background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: clamp(var(--space-9), 3vw, var(--space-13)); }
.account-card table .button { min-height: var(--control-height-sm); padding: 7px var(--space-5); font-size: .85rem; }
.admin-report-switch { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-6); margin: 0 0 var(--space-9); }
.tabs { display: inline-flex; flex-wrap: wrap; gap: 0; padding: var(--space-2); margin: 0; border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-warm); }
.tabs a { padding: 9px 13px; border-radius: var(--radius-sm); color: var(--color-muted); text-decoration: none; font-weight: var(--font-weight-bold); }
.tabs a.active { background: var(--color-danger); color: var(--color-surface); }
.admin-search { max-width: 520px; margin-bottom: var(--space-5); }
.admin-block { max-width: 100%; margin-top: var(--space-12); overflow-x: auto; }
.admin-block h2 { margin-bottom: 2px; }
.admin-block > p { margin-top: 0; color: var(--color-muted); font-weight: var(--font-weight-bold); }
.class-summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: var(--space-6); margin: 0 0 var(--space-10); }
.class-summary-card { display: grid; justify-items: start; gap: var(--space-2); width: 100%; min-height: 0; padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-soft); color: var(--color-ink); text-align: left; cursor: pointer; }
.class-summary-card:hover { border-color: var(--color-brand); background: var(--color-brand-soft); }
.class-summary-card.active { border-color: var(--color-brand); background: var(--color-brand-soft); box-shadow: var(--ring-selected); }
.class-summary-card strong { font-size: var(--font-size-section); }
.class-summary-card span { color: var(--color-ink); font-weight: var(--font-weight-bold); }
.class-summary-card small { color: var(--color-muted); line-height: 1.35; }
.class-report table { min-width: 860px; }
.class-roster-form { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--space-6); align-items: end; margin: var(--space-8) 0; padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-soft); }
.class-roster-form label:has(> textarea) { grid-template-rows: 20px 140px; height: calc(20px + var(--space-3) + 140px); }
.class-roster-form textarea { height: 140px; min-height: 140px; }
.class-roster-form button { margin-bottom: 0; }
.bank-import-form { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--space-6); align-items: end; margin: var(--space-8) 0; padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-soft); }
.bank-import-form button { margin-bottom: 0; }
.bank-bulk-form { display: flex; flex-wrap: wrap; gap: var(--space-6); align-items: end; margin: 0 0 var(--space-8); padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-warm); }
.bank-bulk-form > div { display: grid; gap: var(--space-1); min-width: 260px; margin-right: auto; }
.bank-bulk-form > div small { color: var(--color-muted); font-weight: var(--font-weight-bold); }
.bank-bulk-form label { width: 160px; }
.bank-bulk-form button { margin-bottom: 0; }
.bank-queue-tabs { display: flex; flex-wrap: wrap; gap: var(--space-3); margin: var(--space-8) 0; }
.bank-queue-tabs a { display: inline-flex; align-items: center; gap: var(--space-3); min-height: 40px; padding: 8px 13px; border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface); color: var(--color-ink); text-decoration: none; font-weight: var(--font-weight-bold); }
.bank-queue-tabs a.active { border-color: var(--color-brand); background: var(--color-brand-soft); box-shadow: var(--ring-selected); }
.bank-queue-tabs strong { color: var(--color-muted); font-variant-numeric: tabular-nums; }
.opos-summary-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: var(--space-6); margin: var(--space-8) 0; }
.opos-summary-grid span { display: grid; gap: var(--space-1); padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-soft); }
.opos-summary-grid strong { font-size: var(--font-size-section); }
.opos-summary-grid small { color: var(--color-muted); font-weight: var(--font-weight-bold); }
.opos-actions { margin: var(--space-7) 0 0; }
.money-cell { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.table-check { display: flex; grid-template-rows: none; align-items: center; gap: var(--space-4); height: auto; padding-bottom: 0; font-weight: var(--font-weight-bold); }
.table-check input { flex: 0 0 auto; }
.class-feedback-summary { margin: var(--space-6) 0 var(--space-8); padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface-warm); }
.missing-child-list { columns: 2; margin: var(--space-5) 0 0; padding-left: var(--space-10); }
.mail-editor-block { display: grid; gap: var(--space-7); padding: var(--space-9) 0; border-top: 1px solid var(--color-line); }
.mail-editor-block h2 { margin-bottom: 0; }
.mail-editor-block textarea { height: 220px; }
.mail-editor-block label:has(> textarea) { grid-template-rows: 20px 220px; height: calc(20px + var(--space-3) + 220px); }
table { width: 100%; border-collapse: collapse; background: var(--color-surface); }
.admin-block table { min-width: 900px; }
th, td { padding: var(--space-6) var(--space-5); border-bottom: 1px solid var(--color-line); text-align: left; vertical-align: top; }
th { color: var(--color-muted); font-size: var(--font-size-nav); }
tfoot th { color: var(--color-ink); font-weight: var(--font-weight-heavy); border-top: 2px solid var(--color-line); background: var(--color-surface-warm); }
.muted { color: var(--color-muted); }
.bank-table-block table { min-width: 1180px; }
.bank-payment-row > td { padding-top: var(--space-5); padding-bottom: var(--space-5); }
.bank-source-cell strong { display: block; margin-bottom: var(--space-2); }
.bank-source-cell small { display: block; max-width: 560px; color: var(--color-muted); line-height: 1.35; }
.bank-amount-cell strong { font-size: 1rem; }
.bank-actions-cell { min-width: 190px; position: sticky; right: 0; background: var(--color-surface); box-shadow: -8px 0 14px rgba(255,255,255,.78); }
.bank-actions-cell form { display: block; margin: 0 0 var(--space-3); }
.bank-actions-cell button { width: 100%; }
.bank-actions-cell button.quiet { background: transparent; color: var(--color-muted); border: 1px solid var(--color-line); }
.bank-review-reason { display: block; margin-bottom: var(--space-3); color: var(--color-muted); font-weight: var(--font-weight-bold); line-height: 1.3; }
.bank-inline-targets { display: grid; gap: var(--space-3); }
.bank-inline-target { display: grid; gap: 2px; padding: var(--space-4); border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface-soft); }
.bank-inline-target small { color: var(--color-muted); line-height: 1.35; }
.bank-row-ignored > td { color: var(--color-muted); background: var(--color-surface-soft); opacity: .62; }
.bank-row-ignored button { opacity: 1; }
.bank-manual-match-dialog { width: min(1180px, calc(100% - var(--space-12))); }
.bank-manual-match-dialog .detail-form { margin-top: var(--space-7); }
.bank-dialog-summary { display: grid; grid-template-columns: minmax(120px, .45fr) minmax(180px, .75fr) minmax(260px, 1.4fr); gap: var(--space-5); margin: var(--space-7) 0; }
.bank-dialog-summary span { display: grid; gap: var(--space-1); padding: var(--space-5); border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface-soft); }
.bank-dialog-summary small { color: var(--color-muted); font-weight: var(--font-weight-bold); }
.bank-dialog-summary strong { overflow-wrap: anywhere; }
.bank-match-form { display: grid; gap: var(--space-7); }
.bank-target-section { display: grid; gap: var(--space-4); }
.bank-target-section h3 { margin: 0; font-size: 1rem; }
.bank-target-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-4); }
.bank-target-card { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: var(--space-3) var(--space-4); align-items: start; min-height: 104px; padding: var(--space-5); border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface); cursor: pointer; }
.bank-target-card:has(input:checked) { border-color: var(--color-brand); background: var(--color-brand-soft); box-shadow: var(--ring-selected); }
.bank-target-card input { margin-top: 4px; }
.bank-target-card span, .bank-target-card small, .bank-target-card b, .bank-target-card > .badge { grid-column: 2; }
.bank-target-card span { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.bank-target-card small { color: var(--color-muted); line-height: 1.35; }
.bank-target-card b { font-variant-numeric: tabular-nums; }
.bank-target-card em { font-style: normal; }
.bank-dialog-actions { display: flex; justify-content: flex-end; }
.bank-action-notice { position: fixed; right: var(--space-7); bottom: var(--space-7); z-index: 50; max-width: min(420px, calc(100vw - var(--space-10))); padding: var(--space-5) var(--space-6); border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-ink); color: var(--color-surface); font-weight: var(--font-weight-bold); box-shadow: var(--shadow-lg); opacity: 0; transform: translateY(10px); pointer-events: none; transition: opacity .18s ease, transform .18s ease; }
.bank-action-notice.is-visible { opacity: 1; transform: translateY(0); }
.mail-preview-dialog { width: min(920px, calc(100vw - 32px)); }
.mail-preview-frame { max-height: 70vh; overflow: auto; padding: var(--space-7); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: #fff; }
.payment-reminder-send { margin-top: var(--space-8); }
td form { display: inline-flex; margin: 0 var(--space-3) var(--space-3) 0; }
td button { min-height: var(--control-height-sm); padding: 7px var(--space-5); font-size: .85rem; }
tr[data-detail-target] { cursor: pointer; }
tr[data-detail-target]:hover > td { background: var(--color-brand-soft); }
.duplicate-family-row > td { background: var(--color-match-soft); border-bottom-color: var(--color-match-line); }
.duplicate-family-row .badge { display: inline-flex; margin-top: var(--space-3); }
.duplicate-family-row .badge.danger { color: var(--color-match); background: var(--color-brand-soft); }
.duplicate-family-details { margin: var(--space-9) 0; padding: var(--space-8); border: 1px solid var(--color-match-line); border-radius: var(--radius-md); background: var(--color-match-soft); }
.duplicate-family-details h3 { margin-bottom: var(--space-3); }
.duplicate-family-details table { margin-top: var(--space-6); background: var(--color-surface); }
.duplicate-family-details td form { display: flex; margin-bottom: var(--space-3); }
.duplicate-family-details .badge:not(.ok):not(.warn):not(.danger) { color: var(--color-muted); background: var(--color-surface-warm); }
.duplicate-summary { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-5); margin-top: var(--space-6); }
.duplicate-summary span { display: grid; gap: var(--space-1); padding: var(--space-5); border: 1px solid rgba(199, 38, 56, .16); border-radius: var(--radius-sm); background: var(--color-surface); }
.duplicate-summary strong { font-size: var(--font-size-section); }
.duplicate-summary small { color: var(--color-muted); }
.duplicate-manual-form { display: flex; flex-wrap: wrap; gap: var(--space-5); align-items: flex-start; margin-top: var(--space-7); }
.duplicate-manual-form label { flex: 1 1 300px; }
.duplicate-manual-form button { margin-top: calc(20px + var(--space-3)); }
.detail-dialog { width: min(1040px, calc(100% - var(--space-16))); border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: var(--space-12); color: var(--color-ink); }
.detail-dialog::backdrop { background: var(--color-overlay); }
.dialog-close { position: absolute; top: var(--space-6); right: var(--space-6); width: var(--control-height-sm); min-height: var(--control-height-sm); padding: 0; border-radius: var(--radius-circle); background: var(--color-secondary); }
.detail-grid { display: grid; grid-template-columns: 150px minmax(0, 1fr); gap: var(--space-4) var(--space-7); margin: 0 0 var(--space-9); }
.detail-grid dt { color: var(--color-muted); font-weight: var(--font-weight-bold); }
.detail-grid dd { margin: 0; }
.detail-actions { display: grid; gap: var(--space-6); margin-top: var(--space-9); padding-top: var(--space-9); border-top: 1px solid var(--color-line); }
.detail-form { display: flex; flex-wrap: wrap; gap: var(--space-5); align-items: flex-start; margin: 0; }
.detail-form label { flex: 1 1 260px; }
.detail-form button { margin-top: calc(20px + var(--space-3)); }
footer { position: fixed; left: 0; right: 0; bottom: 0; display: flex; justify-content: center; gap: var(--space-9); padding: var(--space-9) var(--space-14); color: var(--color-muted); border-top: 1px solid var(--color-line); background: var(--color-footer-bg); backdrop-filter: blur(10px); }
code { background: var(--color-surface-code); padding: var(--space-1) var(--space-2); border-radius: var(--radius-xs); }
.modal-backdrop { position: fixed; inset: 0; z-index: 50; display: grid; place-items: center; padding: var(--space-10); background: var(--color-overlay); }
.modal-backdrop.is-hidden { display: none; }
.modal { width: min(560px, 100%); background: var(--color-surface); border-radius: var(--radius-md); border: 1px solid var(--color-line); box-shadow: var(--shadow-modal); padding: clamp(var(--space-11), 4vw, var(--space-16)); }
.modal h2 { margin-bottom: var(--space-6); }
.modal p { color: var(--color-muted); line-height: var(--leading-copy); }
.modal .modal-note { color: var(--color-danger); font-weight: var(--font-weight-medium); }
.field-hint { margin: calc(-1 * var(--space-3)) 0 var(--space-6); color: var(--color-muted); font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); }
.textile-builder { display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: var(--space-12); align-items: start; }
.textile-controls, .textile-preview-stack { display: grid; gap: var(--space-7); min-width: 0; }
.textile-preview-stack { width: 100%; max-width: 100%; overflow: hidden; }
.product-options { display: grid; gap: var(--space-5); }
.product-option { position: relative; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: var(--space-5); align-items: center; min-height: 58px; padding: var(--space-5) var(--space-6); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); cursor: pointer; transition: border-color var(--duration-fast) ease, background var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.product-option strong, .product-option small { display: block; }
.product-option strong { color: var(--color-ink); line-height: 1.1; }
.product-option small { margin-top: var(--space-1); color: var(--color-muted); font-size: var(--font-size-sm); font-weight: var(--font-weight-bold); line-height: 1.1; }
.product-option b { color: var(--color-ink); font-size: .98rem; white-space: nowrap; }
.swatches { display: flex; flex-wrap: wrap; gap: var(--space-5); }
.swatch { position: relative; display: inline-flex; align-items: center; gap: 7px; min-height: var(--qty-height); padding: var(--space-4) var(--space-5); border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface); cursor: pointer; transition: border-color var(--duration-fast) ease, background var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.product-option input, .swatch input, .size-option input, .print-option input { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }
.swatch span { width: 22px; height: 22px; border: 1px solid var(--color-swatch-line); border-radius: var(--radius-circle); }
.product-option:has(input:checked), .swatch:has(input:checked), .size-option:has(input:checked), .print-option:has(input:checked) { border-color: var(--color-brand); background: var(--color-brand-soft); box-shadow: var(--ring-selected); }
.size-options { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-5); }
.size-option { position: relative; display: grid; grid-template-columns: auto 1fr; gap: var(--space-1) var(--space-5); align-items: center; min-height: 58px; padding: var(--space-5) var(--space-6); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); cursor: pointer; transition: border-color var(--duration-fast) ease, background var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.size-code { grid-row: span 2; display: grid; place-items: center; width: var(--control-height-sm); height: var(--control-height-sm); border-radius: var(--radius-circle); background: var(--color-surface-code); color: var(--color-ink); font-weight: var(--font-weight-heavy); }
.size-body { color: var(--color-ink); font-weight: var(--font-weight-heavy); line-height: var(--leading-control); }
.size-age { color: var(--color-muted); font-size: var(--font-size-md); font-weight: var(--font-weight-strong); line-height: var(--leading-control); }
.size-option:has(input:checked) .size-code { background: var(--color-brand); color: var(--color-surface); }
.size-chart { width: 100%; min-width: 0; max-width: 100%; box-sizing: border-box; border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); overflow: hidden; contain: layout; }
.size-chart summary { cursor: pointer; padding: var(--space-5) var(--space-6); font-weight: var(--font-weight-heavy); }
.size-chart h3 { margin: var(--space-6) var(--space-6) var(--space-3); font-size: var(--font-size-section); }
.size-chart table { margin: 0 0 var(--space-6); width: 100%; min-width: 620px; }
.size-chart th, .size-chart td { text-align: center; white-space: nowrap; }
.size-chart th:first-child, .size-chart td:first-child { text-align: left; }
.size-chart .muted { margin: 0 var(--space-6) var(--space-6); }
.table-scroll { display: block; width: calc(100% - var(--space-12)); max-width: calc(100% - var(--space-12)); margin: 0 var(--space-6); overflow-x: auto; -webkit-overflow-scrolling: touch; }
.print-options { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-5); }
.print-option { position: relative; display: grid; grid-template-columns: auto 1fr; gap: var(--space-5); align-items: center; min-height: 58px; padding: var(--space-5) var(--space-6); border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); cursor: pointer; transition: border-color var(--duration-fast) ease, background var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.print-icon { display: grid; place-items: center; width: var(--control-height-sm); height: var(--control-height-sm); border-radius: var(--radius-circle); background: var(--color-surface-code); color: var(--color-ink); font-family: var(--font-display); font-size: var(--font-size-md); line-height: var(--leading-tight); }
.print-option strong, .print-option small { display: block; }
.print-option strong { color: var(--color-ink); line-height: 1.1; }
.print-option small { margin-top: var(--space-1); color: var(--color-muted); font-size: var(--font-size-md); font-weight: var(--font-weight-strong); line-height: 1.1; }
.print-option:has(input:checked) .print-icon { background: var(--color-brand); color: var(--color-surface); }
.textile-preview { display: grid; place-items: center; min-height: 430px; border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-surface); overflow: hidden; }
.mock-textile { position: relative; width: min(560px, 100%); aspect-ratio: 1920 / 1606; display: grid; place-items: center; }
.textile-base-image { display: block; width: 100%; height: 100%; object-fit: contain; }
.textile-base-image[hidden] { display: none; }
.mock-textile span { position: absolute; top: 43%; left: 30%; width: calc(210px * var(--print-scale)); z-index: 3; text-align: center; font-family: var(--font-display); font-weight: 300; font-synthesis: none; font-size: calc(32px * var(--print-scale)); line-height: .95; color: var(--color-surface); text-transform: uppercase; transform: translateY(calc(-34px * var(--print-scale))) scaleX(.92); }
.mock-textile[data-product-sku="jn745"] span { top: 40%; left: calc(30% + 26px * var(--print-scale)); }
.mock-textile[data-product-sku="f401nk"] span, .mock-textile[data-product-sku="jh001"] span { top: 39%; left: calc(30% + 26px * var(--print-scale)); transform: translateY(calc(-34px * var(--print-scale))) scaleX(.92); }
.mock-textile[data-product-sku="f480nk"] span { top: 24%; }
.cart-panel { margin-top: var(--space-10); padding-top: var(--space-9); border-top: 1px solid var(--color-line); }
.cart-item { display: grid; grid-template-columns: var(--cart-thumb-width) minmax(0, 1fr) auto auto; gap: var(--space-5); align-items: center; padding: var(--space-5) 0; border-bottom: 1px solid var(--color-line); }
.cart-item img, .summary-item img { width: var(--cart-thumb-width); height: var(--cart-thumb-height); object-fit: contain; border: 1px solid var(--color-line); border-radius: var(--radius-sm); background: var(--color-surface); }
.cart-total { display: flex; justify-content: space-between; gap: var(--space-9); margin-top: var(--space-7); font-size: var(--font-size-total); }
.summary-box { padding: var(--space-7) 0; border-bottom: 1px solid var(--color-line); }
.summary-box h3 { margin-bottom: var(--space-5); font-size: var(--font-size-section); }
.summary-item { display: grid; grid-template-columns: var(--cart-thumb-width) minmax(0, 1fr) auto; gap: var(--space-5); align-items: center; padding: var(--space-4) 0; }
.summary-item strong { white-space: nowrap; }
input.mini-input, .mini-input { width: 90px; height: var(--control-height-sm); min-height: var(--control-height-sm); padding: var(--space-3) var(--space-4); }
.is-hidden { display: none !important; }

@media (max-width: 760px) {
  .topbar, nav { align-items: flex-start; }
  .topbar { flex-direction: column; }
  body { padding-bottom: 0; }
  .hero, .tiles, .perf, .ticket-row, .purchase-ticket-row, .purchase-category-grid, .form-grid, .textile-builder, .account-grid, .sale-phase-grid { grid-template-columns: 1fr; }
  .children-editor { padding: 0; }
  .child-row { grid-template-columns: 1fr; align-items: stretch; }
  .child-remove { margin-top: 0; }
  .class-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .cart-item { grid-template-columns: 48px minmax(0, 1fr); }
  .cart-item img, .summary-item img { width: var(--cart-thumb-width-mobile); height: var(--cart-thumb-height-mobile); }
  .cart-item strong, .cart-item button { grid-column: 2; justify-self: start; }
  .summary-item { grid-template-columns: 48px minmax(0, 1fr); }
  .summary-item strong { grid-column: 2; }
  .hero { padding: var(--space-12); }
  .qty-stepper { justify-content: start; }
  .step-actions { flex-direction: column-reverse; align-items: stretch; }
  .auth-panel .actions { align-items: stretch; }
  .auth-panel > .button, .auth-panel > button, .auth-panel .actions .button, .auth-panel .actions button { width: 100%; }
  .step-summary { position: static; }
  table { display: block; overflow-x: auto; white-space: nowrap; }
  .detail-dialog table { display: table; white-space: normal; }
  .detail-grid { grid-template-columns: 1fr; }
  footer { position: static; flex-wrap: wrap; }
}
