/* Dashboard-specific (uses design.css tokens) */
:root { --muted: var(--text-muted); --success: var(--moss-700); --danger: var(--ruby-500); --warn: var(--amber-500); --card: var(--surface); --shadow: var(--shadow-sm); }
html, body { min-height: 100vh; background: var(--bg); color: var(--text); }
a { color: inherit; text-decoration: none; }

/* Header */
header { background: color-mix(in oklab, var(--bg) 92%, transparent); backdrop-filter: saturate(140%) blur(10px); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 20; }
header .bar { max-width: 1320px; margin: 0 auto; padding: 1rem 1.6rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
header .brand { font-family: var(--font-display); font-weight: 500; letter-spacing: -.025em; font-size: 1.3rem; font-variation-settings: 'opsz' 100, 'SOFT' 70; color: var(--text); }
header .brand span { color: var(--accent); }
header .resto { font-size: var(--step--1); color: var(--text-muted); flex: 1; text-align: center; letter-spacing: -.005em; }
header .resto strong { color: var(--text); font-weight: 600; }
header .right { display: flex; gap: .75rem; align-items: center; font-size: var(--step--1); }
header .role-badge { font-size: var(--step--2); background: var(--accent-soft); color: var(--accent-strong); padding: .25rem .7rem; border-radius: var(--r-pill); font-weight: 600; letter-spacing: .08em; text-transform: uppercase; border: 1px solid var(--terracotta-100); }
header .role-badge.admin { background: color-mix(in oklab, var(--amber-500) 22%, var(--surface)); color: var(--amber-500); border-color: color-mix(in oklab, var(--amber-500) 40%, transparent); }
header .logout { color: var(--text-muted); cursor: pointer; background: none; border: none; padding: 0; font-size: var(--step--1); transition: color var(--t) var(--ease); }
header .logout:hover { color: var(--accent); }

/* Tabs */
nav.tabs { background: var(--bg); border-bottom: 1px solid var(--border); }
nav.tabs .wrap { max-width: 1320px; margin: 0 auto; padding: 0 1.6rem; }
nav.tabs .section-nav { display: flex; gap: .4rem; padding: .9rem 0; }
nav.tabs .section-nav a { padding: .5rem 1.1rem; border-radius: var(--r-pill); font-size: var(--step--1); font-weight: 500; color: var(--text-soft); background: transparent; border: 1.5px solid transparent; transition: all var(--t) var(--ease); letter-spacing: -.005em; cursor: pointer; }
nav.tabs .section-nav a.active { color: var(--btn-primary-text); background: var(--btn-primary-bg); border-color: var(--btn-primary-bg); }
nav.tabs .section-nav a:not(.active):hover { color: var(--text); background: var(--surface-2); }
nav.tabs .subtabs { display: flex; gap: 0; padding: 0 0 .2rem; overflow-x: auto; border-top: 1px solid var(--border); margin-top: 0; }
nav.tabs .subtabs a { padding: .9rem .25rem; margin-right: 2rem; font-size: var(--step--1); color: var(--text-muted); border-bottom: 2px solid transparent; transition: color var(--t) var(--ease), border-color var(--t) var(--ease); white-space: nowrap; cursor: pointer; font-weight: 500; letter-spacing: -.005em; position: relative; }
nav.tabs .subtabs a.active { color: var(--text); border-bottom-color: var(--accent); }
nav.tabs .subtabs a:hover { color: var(--text); }
nav.tabs > a { padding: 1rem .25rem; margin-right: 2rem; font-size: var(--step--1); color: var(--text-muted); border-bottom: 2px solid transparent; white-space: nowrap; cursor: pointer; display: inline-block; font-weight: 500; }
nav.tabs > a.active { color: var(--text); border-bottom-color: var(--accent); }

main { max-width: 1320px; margin: 0 auto; padding: 2.2rem 1.6rem 4rem; }

/* Stat cards */
.grid { display: grid; gap: 1rem; }
.grid-4 { grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 1.6rem; box-shadow: var(--shadow-sm); transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease); position: relative; overflow: hidden; color: var(--text); }
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.card::before { content: ''; position: absolute; inset: 0 0 auto 0; height: 2px; background: linear-gradient(90deg, var(--accent), var(--moss-500)); opacity: 0; transition: opacity var(--t) var(--ease); }
.card:hover::before { opacity: 1; }
.card .label { font-family: var(--font-body); font-size: var(--step--2); text-transform: uppercase; letter-spacing: .12em; color: var(--text-muted); font-weight: 600; margin-bottom: .6rem; }
.card .big { font-family: var(--font-display); font-size: 2.6rem; font-weight: 400; letter-spacing: -.035em; line-height: 1; font-variation-settings: 'opsz' 144, 'SOFT' 30; font-variant-numeric: tabular-nums; color: var(--text); }
.card .sub { font-size: var(--step--1); color: var(--text-muted); margin-top: .5rem; }

/* Panels */
.panel { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-sm); margin-bottom: 1.8rem; transition: box-shadow var(--t) var(--ease); color: var(--text); }
.panel:hover { box-shadow: var(--shadow-md); }
.panel-head { padding: 1.3rem 1.8rem; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; gap: 1rem; flex-wrap: wrap; background: linear-gradient(180deg, var(--surface-2), var(--surface)); color: var(--text); }
.panel-head h2 { font-family: var(--font-display); font-size: var(--step-2); font-weight: 500; letter-spacing: -.012em; color: var(--text); }
.panel-tools { display: flex; gap: .5rem; align-items: center; flex-wrap: wrap; }
.panel-tools input, .panel-tools select { padding: .55rem .8rem; font-size: var(--step--1); background: var(--input-bg); color: var(--text); border-radius: var(--r-sm); }
.panel-tools input { min-width: 200px; }

.btn { padding: .6rem 1.2rem; background: var(--btn-primary-bg); color: var(--btn-primary-text); border: 1.5px solid var(--btn-primary-bg); border-radius: var(--r-pill); font-size: var(--step--1); font-weight: 500; cursor: pointer; transition: all var(--t) var(--ease); display: inline-flex; align-items: center; gap: .5rem; letter-spacing: -.005em; text-decoration: none; }
.btn:hover { background: var(--btn-primary-hover); color: #fff; border-color: var(--btn-primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-accent); }
.btn:active { transform: translateY(0) scale(.98); }
.btn.secondary, .btn.ghost { background: var(--surface); color: var(--text); border-color: var(--border-strong); }
.btn.secondary:hover, .btn.ghost:hover { background: var(--surface-2); color: var(--text); border-color: var(--border-strong); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.btn.danger { background: var(--ruby-500); color: #fff; border-color: var(--ruby-500); }
.btn.danger:hover { background: #7A1E1E; color: #fff; border-color: #7A1E1E; }
.btn.small { padding: .4rem .8rem; font-size: var(--step--2); }

/* Tables */
table { width: 100%; border-collapse: collapse; font-size: var(--step--1); color: var(--text); }
table th, table td { padding: .9rem 1.8rem; text-align: left; border-bottom: 1px solid var(--border); vertical-align: middle; }
table th { background: var(--bg); font-weight: 600; font-size: var(--step--2); text-transform: uppercase; letter-spacing: .12em; color: var(--text-muted); user-select: none; }
th.sortable { cursor: pointer; transition: color var(--t) var(--ease), background var(--t) var(--ease); }
th.sortable:hover { color: var(--text); background: var(--surface-2); }
th.sortable .arrow { display: inline-block; margin-left: .3rem; opacity: .4; font-size: .85em; transition: opacity var(--t) var(--ease); }
th.sortable.asc .arrow, th.sortable.desc .arrow { opacity: 1; color: var(--accent); }
th.sortable .arrow::before { content: '↕'; }
th.sortable.asc .arrow::before { content: '↑'; }
th.sortable.desc .arrow::before { content: '↓'; }
table tr:last-child td { border-bottom: none; }
table tr { transition: background var(--t) var(--ease); }
table tbody tr:hover td { background: var(--surface-2); }
table td input, table td select { padding: .35rem .55rem; font-size: var(--step--1); width: 100%; background: var(--input-bg); color: var(--text); }
table .actions { display: flex; gap: .35rem; }

.badge { display: inline-flex; align-items: center; gap: .3rem; padding: .25rem .7rem; border-radius: var(--r-pill); font-size: var(--step--2); font-weight: 500; cursor: pointer; border: 1px solid transparent; letter-spacing: .02em; }
.badge.confirmed, .badge.active, .badge.trialing, .badge.trial { background: color-mix(in oklab, var(--moss-500) 16%, var(--surface)); color: var(--moss-700); border-color: color-mix(in oklab, var(--moss-500) 35%, transparent); }
.badge.pending { background: color-mix(in oklab, var(--amber-500) 22%, var(--surface)); color: var(--amber-500); border-color: color-mix(in oklab, var(--amber-500) 40%, transparent); }
.badge.cancelled, .badge.no_show, .badge.past_due { background: color-mix(in oklab, var(--ruby-500) 14%, var(--surface)); color: var(--ruby-500); border-color: color-mix(in oklab, var(--ruby-500) 35%, transparent); }
.badge.completed { background: var(--surface-2); color: var(--text-soft); border-color: var(--border-strong); }
.badge.ready { background: color-mix(in oklab, #2563eb 14%, var(--surface)); color: #2563eb; border-color: color-mix(in oklab, #2563eb 35%, transparent); }

.empty { padding: 3.5rem 1.5rem; text-align: center; color: var(--ink-500); font-family: var(--font-display); font-style: italic; font-size: var(--step-1); font-variation-settings: 'SOFT' 80; }

/* No-show risk pill (rendered next to customer name on reservations) */
.risk-pill { display: inline-block; padding: 2px 8px; border-radius: var(--r-pill); font-family: var(--font-mono); font-size: .68rem; font-weight: 600; margin-left: .4rem; vertical-align: middle; cursor: help; letter-spacing: .02em; line-height: 1.5; }
.risk-pill--high { background: var(--terracotta-500); color: var(--cream-50); }
.risk-pill--mid  { background: var(--amber-500);     color: var(--ink-900);  }
.risk-pill--low  { background: var(--moss-500);      color: var(--cream-50); }

/* Happy hour auto (Campagnes tab · Premium cap dynamic_pricing) */
.hh-section { padding: 1.3rem 1.5rem; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); margin-bottom: 1.6rem; box-shadow: var(--shadow-sm); transition: box-shadow var(--t) var(--ease); }
.hh-section:hover { box-shadow: var(--shadow-md); }
.hh-section h2 { font-family: var(--font-display); font-weight: 500; font-size: var(--step-2); letter-spacing: -.015em; margin: 0 0 .2rem; font-variation-settings: 'opsz' 48; }
.hh-section .muted { color: var(--ink-500); font-size: var(--step--1); margin: 0 0 .9rem; }
.hh-toggle-row { display: flex; align-items: center; gap: .9rem; margin: 1rem 0; font-family: var(--font-body); font-size: var(--step--1); color: var(--ink-700); font-weight: 500; }
.hh-toggle-row #hhStatus { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-500); }
.hh-config { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: .9rem; margin: 1rem 0 1.2rem; }
.hh-config label { display: flex; flex-direction: column; font-size: var(--step--2); color: var(--ink-500); gap: .3rem; font-weight: 500; letter-spacing: .02em; text-transform: uppercase; font-family: var(--font-body); margin-bottom: 0; }
.hh-config input { padding: .5rem .7rem; border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--bg); color: var(--ink); font-family: var(--font-mono); font-size: var(--step--1); text-transform: none; transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); }
.hh-config input:focus { border-color: var(--terracotta-500); box-shadow: 0 0 0 3px var(--terracotta-50); outline: none; }
.hh-actions { display: flex; gap: .6rem; flex-wrap: wrap; }
.hh-preview { margin-top: .9rem; padding: .9rem 1.1rem; background: var(--cream-100); border-left: 3px solid var(--terracotta-500); border-radius: var(--r-sm); font-size: var(--step--1); color: var(--ink-700); line-height: 1.55; }
.hh-preview strong { font-family: var(--font-display); font-weight: 500; color: var(--terracotta-700); font-variation-settings: 'opsz' 48, 'tnum' 1; }
/* Switch toggle (reused if future renderers need it) */
.switch { position: relative; display: inline-block; width: 44px; height: 24px; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch span { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: var(--cream-200); transition: background var(--t-fast) var(--ease); border-radius: 24px; }
.switch span::before { content: ''; position: absolute; height: 18px; width: 18px; left: 3px; bottom: 3px; background: var(--cream-50); transition: transform var(--t-fast) var(--ease); border-radius: 50%; box-shadow: var(--shadow-sm); }
.switch input:checked + span { background: var(--moss-500); }
.switch input:checked + span::before { transform: translateX(20px); }
.switch input:focus-visible + span { box-shadow: 0 0 0 3px var(--terracotta-100); }

/* Menu engineering — 4 quadrants Stars/Plowhorses/Puzzles/Dogs (Premium cap menu_engineering) */
.me-header h2 { font-family: var(--font-display); font-weight: 500; font-size: var(--step-3); letter-spacing: -.015em; font-variation-settings: 'opsz' 100; margin: 0 0 .3rem; }
.me-header .muted { color: var(--ink-500); font-size: var(--step--1); margin: 0 0 1.2rem; }
.me-warnings { padding: .9rem 1.2rem; background: var(--cream-100); border-left: 3px solid var(--amber-500); border-radius: var(--r-sm); margin-bottom: 1.2rem; font-size: var(--step--1); color: var(--ink-700); font-family: var(--font-body); }
.me-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem; margin-top: 1rem; }
.me-quadrant { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 1.2rem 1.3rem; border-top: 3px solid var(--line); box-shadow: var(--shadow-sm); transition: box-shadow var(--t) var(--ease), border-color var(--t) var(--ease); }
.me-quadrant:hover { box-shadow: var(--shadow-md); }
.me-quadrant.me-stars      { border-top-color: var(--moss-500);       }
.me-quadrant.me-plowhorses { border-top-color: var(--amber-500);      }
.me-quadrant.me-puzzles    { border-top-color: var(--terracotta-500); }
.me-quadrant.me-dogs       { border-top-color: var(--ruby-500);       }
.me-quadrant h3 { font-family: var(--font-display); margin: 0 0 .3rem; font-size: var(--step-1); font-weight: 500; color: var(--ink); letter-spacing: -.01em; font-variation-settings: 'opsz' 48; }
.me-quadrant-desc { font-size: var(--step--1); color: var(--ink-500); margin: 0 0 .9rem; line-height: 1.45; font-family: var(--font-display); font-style: italic; font-variation-settings: 'SOFT' 60; }
.me-list { list-style: none; padding: 0; margin: 0; }
.me-list li { padding: .55rem 0; border-bottom: 1px solid var(--line); font-size: var(--step--1); }
.me-list li:last-child { border-bottom: none; }
.me-list .me-name { font-weight: 500; color: var(--ink); font-family: var(--font-body); letter-spacing: -.005em; }
.me-list .me-stats { color: var(--ink-500); font-size: var(--step--2); font-family: var(--font-mono); letter-spacing: .01em; margin-top: .15rem; }
.me-list .me-empty { color: var(--ink-500); font-family: var(--font-display); font-style: italic; font-variation-settings: 'SOFT' 80; font-size: var(--step--1); }
@media (max-width: 760px) { .me-grid { grid-template-columns: 1fr; } }

/* AI reply button + variants (ratings tab, Premium cap ai_review_reply) */
.btn-ai-reply { background: transparent; border: 1px solid var(--terracotta-500); color: var(--terracotta-500); padding: .4rem .9rem; border-radius: var(--r-pill); font-family: var(--font-body); font-size: var(--step--1); font-weight: 500; cursor: pointer; transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); letter-spacing: -.005em; }
.btn-ai-reply:hover:not(:disabled) { background: var(--terracotta-500); color: var(--cream-50); transform: translateY(-1px); box-shadow: var(--shadow-accent); }
.btn-ai-reply:disabled { opacity: .55; cursor: wait; }
.rating-ai-variants { margin-top: .9rem; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: .7rem; }
.rating-ai-variant { background: var(--cream-100); border-left: 3px solid var(--terracotta-500); padding: .8rem .9rem; border-radius: var(--r-sm); display: flex; flex-direction: column; gap: .5rem; }
.rating-ai-variant p { margin: 0; font-family: var(--font-display); font-style: italic; font-variation-settings: 'SOFT' 50; font-size: var(--step--1); color: var(--ink-700); line-height: 1.45; }
.rating-ai-variant .btn-variant-copy { align-self: flex-start; background: var(--terracotta-500); color: var(--cream-50); border: none; padding: .3rem .8rem; border-radius: var(--r-pill); font-family: var(--font-body); font-size: var(--step--2); font-weight: 500; cursor: pointer; transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease); letter-spacing: -.005em; }
.rating-ai-variant .btn-variant-copy:hover { background: var(--terracotta-700); transform: translateY(-1px); }

/* Reports — Chart.js cards + benchmark + CSV export */
.reports-charts { display: grid; grid-template-columns: repeat(auto-fit, minmax(340px, 1fr)); gap: 1.2rem; margin: 1rem 0 1.5rem; }
.chart-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 1rem 1.2rem; box-shadow: var(--shadow-sm); transition: box-shadow var(--t) var(--ease), border-color var(--t) var(--ease); }
.chart-card:hover { box-shadow: var(--shadow-md); border-color: var(--line-strong); }
.chart-card h3 { font-family: var(--font-display); font-weight: 500; font-size: var(--step-1); letter-spacing: -.01em; margin: 0 0 .7rem; color: var(--ink); font-variation-settings: 'opsz' 48; }
.chart-wrap { height: 220px; position: relative; }
.chart-card.premium-gated.locked { opacity: .55; pointer-events: none; position: relative; filter: saturate(.6); }
.chart-card.premium-gated.locked::after { content: '★ Pro / Premium'; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background: var(--terracotta-500); color: var(--cream-50); padding: .5rem 1.1rem; border-radius: var(--r-pill); font-family: var(--font-body); font-weight: 600; letter-spacing: .04em; font-size: var(--step--1); box-shadow: var(--shadow-accent); }
.benchmark-widget { margin: 1rem 0 1.5rem; padding: 1.1rem 1.4rem; background: var(--cream-100); border-radius: var(--r-md); border-left: 3px solid var(--terracotta-500); font-family: var(--font-body); color: var(--ink-700); }
.benchmark-widget strong { font-family: var(--font-display); font-size: var(--step-2); color: var(--terracotta-700); font-variation-settings: 'opsz' 48, 'tnum' 1; font-weight: 500; }
.benchmark-widget em { font-family: var(--font-display); font-style: italic; color: var(--terracotta-500); font-variation-settings: 'SOFT' 100, 'WONK' 1; }
.benchmark-widget.empty { color: var(--ink-500); font-family: var(--font-display); font-style: italic; font-variation-settings: 'SOFT' 80; padding: 1.5rem; text-align: left; font-size: var(--step-0); background: transparent; border-left-color: var(--line-strong); }
.export-csv-bar { display: flex; align-items: center; gap: .7rem; padding: .9rem 1.2rem; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); margin: 1rem 0 1.5rem; flex-wrap: wrap; box-shadow: var(--shadow-sm); }
.export-csv-bar .csv-label { font-family: var(--font-display); font-weight: 500; font-size: var(--step-1); color: var(--ink); letter-spacing: -.01em; margin-right: auto; font-variation-settings: 'opsz' 48; }
.export-csv-bar select { width: auto; padding: .5rem .8rem; min-width: 90px; }

/* Reservations calendar view */
.resa-calendar { padding: 1.2rem 1.6rem 1.6rem; }
.cal-head { display: flex; gap: .5rem; align-items: center; margin-bottom: 1rem; flex-wrap: wrap; }
.cal-head .btn.small { padding: .5rem .9rem; }
.cal-head #calRange { margin-left: auto; font-family: var(--font-display); font-size: var(--step-1); color: var(--ink-700); font-variation-settings: 'opsz' 48, 'SOFT' 40; letter-spacing: -.01em; }
.cal-grid { display: grid; grid-template-columns: 64px repeat(7, 1fr); border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--surface); }
.cal-grid .cal-hour { padding: .35rem .6rem; background: var(--cream-100); font-family: var(--font-mono); font-size: var(--step--2); color: var(--ink-500); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: flex-end; letter-spacing: .02em; }
.cal-grid .cal-day { position: relative; min-height: 44px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--surface); transition: background var(--t-fast) var(--ease); }
.cal-grid .cal-day:hover { background: var(--cream-50); }
.cal-grid .cal-day:nth-child(8n) { border-right: none; }
.cal-grid .cal-day-head { padding: .55rem .4rem; font-family: var(--font-display); font-weight: 500; text-align: center; background: var(--cream-50); font-size: var(--step--1); border-bottom: 1px solid var(--line); border-right: 1px solid var(--line); letter-spacing: -.005em; font-variation-settings: 'opsz' 48; color: var(--ink-700); text-transform: capitalize; }
.cal-grid .cal-day-head:last-child { border-right: none; }
.cal-event { position: absolute; left: 3px; right: 3px; top: 3px; background: var(--terracotta-50); border-left: 3px solid var(--terracotta-500); border-radius: var(--r-xs); padding: .25rem .5rem; font-family: var(--font-body); font-size: var(--step--2); color: var(--ink); cursor: pointer; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease); font-weight: 500; }
.cal-event:hover { background: var(--terracotta-100); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.cal-event + .cal-event { top: 28px; }
.cal-event + .cal-event + .cal-event { top: 53px; }
.cal-event + .cal-event + .cal-event + .cal-event { top: 78px; }
.resa-subnav { display: flex; gap: .3rem; padding: .8rem 1.6rem 0; border-bottom: 1px solid var(--line); margin: 0; }
.resa-subnav a { padding: .55rem 1.1rem; font-family: var(--font-body); font-size: var(--step--1); font-weight: 500; color: var(--ink-500); cursor: pointer; border-bottom: 2px solid transparent; transition: color var(--t) var(--ease), border-color var(--t) var(--ease); letter-spacing: -.005em; }
.resa-subnav a:hover { color: var(--ink); }
.resa-subnav a.active { color: var(--ink); border-bottom-color: var(--terracotta-500); }
@media (max-width: 760px) {
  .resa-calendar .cal-grid { font-size: var(--step--2); grid-template-columns: 40px repeat(7, 1fr); }
  .resa-calendar .cal-event { font-size: 10px; padding: .15rem .3rem; }
}

/* Push notifications card */
.push-card .push-status { margin-top: .55rem; font-size: var(--step--1); color: var(--ink-500); font-family: var(--font-body); }
.push-card .push-status.ok { color: var(--moss-700); font-weight: 500; }
.push-card .push-status.err { color: var(--ruby-500); }

/* Modal */
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; z-index: 100; padding: 1rem; animation: h-fade var(--t) var(--ease); }
.modal { background: var(--surface); color: var(--text); border-radius: var(--r-md); max-width: 560px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: var(--shadow-lg); animation: h-rise var(--t-slow) var(--ease); }
.modal-head { padding: 1.5rem 1.8rem; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }
.modal-head h3 { font-family: var(--font-display); font-size: var(--step-2); font-weight: 500; letter-spacing: -.015em; color: var(--text); }
.modal-head .close { background: none; border: none; font-size: 1.5rem; color: var(--text-muted); cursor: pointer; line-height: 1; padding: 0; transition: color var(--t) var(--ease); }
.modal-head .close:hover { color: var(--accent); }
.modal-body { padding: 1.5rem 1.8rem; }
.modal-body label { margin: 1rem 0 .3rem; }
.modal-body label:first-child { margin-top: 0; }
.modal-foot { padding: 1.1rem 1.8rem; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: .6rem; background: var(--surface-2); }

/* Toasts */
#toasts { position: fixed; top: 1.2rem; right: 1.2rem; z-index: 200; display: flex; flex-direction: column; gap: .6rem; pointer-events: none; }
.toast { background: var(--btn-primary-bg); color: var(--btn-primary-text); padding: 1rem 1.4rem; border-radius: var(--r-md); font-size: var(--step--1); box-shadow: var(--shadow-lg); pointer-events: auto; max-width: 360px; animation: toastIn var(--t-slow) var(--ease); display: flex; align-items: center; gap: .7rem; font-weight: 500; }
.toast.ok { background: var(--moss-700); color: #fff; }
.toast.err { background: var(--ruby-500); color: #fff; }
.toast.fade { animation: toastOut var(--t) var(--ease) forwards; }
@keyframes toastIn { from { transform: translateX(24px); opacity: 0 } to { transform: translateX(0); opacity: 1 } }
@keyframes toastOut { to { transform: translateX(24px); opacity: 0 } }

/* Section transitions */
main > section, #tabContainer { animation: sectionIn var(--t-slow) var(--ease); }
@keyframes sectionIn { from { opacity: 0; transform: translateY(6px) } to { opacity: 1; transform: translateY(0) } }

/* Skeletons */
.skel { background: linear-gradient(90deg, var(--cream-100) 0, var(--cream-200) 50%, var(--cream-100) 100%); background-size: 200% 100%; animation: shimmer 1.4s infinite; border-radius: 8px; height: 1em; margin: .3rem 0; }
@keyframes shimmer { 0% { background-position: 200% 0 } 100% { background-position: -200% 0 } }

/* Login — editorial */
.login-box { max-width: 440px; margin: 6rem auto; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 3rem 2.5rem; box-shadow: var(--shadow-lg); position: relative; overflow: hidden; color: var(--text); }
.login-box::before { content: ''; position: absolute; top: -40px; right: -40px; width: 180px; height: 180px; border-radius: 50%; background: radial-gradient(closest-side, var(--accent-soft), transparent 70%); }
.login-box h1 { font-family: var(--font-display); font-size: var(--step-3); font-weight: 400; letter-spacing: -.02em; margin-bottom: .4rem; position: relative; font-variation-settings: 'opsz' 100; }
.login-box h1 em { color: var(--accent); font-style: italic; font-weight: 400; font-variation-settings: 'SOFT' 100; }
.login-box .sub { color: var(--text-muted); margin-bottom: 2rem; font-size: var(--step-0); position: relative; }
.login-box label { margin-top: 1rem; }
.login-box label:first-of-type { margin-top: 0; }
.login-box button { margin-top: 1.6rem; width: 100%; padding: 1rem; background: var(--btn-primary-bg); color: var(--btn-primary-text); border: none; border-radius: var(--r-pill); font-size: var(--step-0); font-weight: 500; cursor: pointer; transition: all var(--t) var(--ease); letter-spacing: -.005em; }
.login-box button:hover { background: var(--btn-primary-hover); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow-accent); }
.login-box button:disabled { opacity: .5; cursor: wait; }
.login-box .notice { margin-top: 1rem; padding: .85rem 1rem; background: var(--err-bg); color: var(--err-text); border-radius: var(--r-sm); font-size: var(--step--1); display: none; border: 1px solid var(--terracotta-100); }
.login-box .notice.show { display: block; }
.login-box .foot { margin-top: 2rem; text-align: center; font-size: var(--step--1); color: var(--text-muted); position: relative; }
.login-box .foot a { color: var(--accent-strong); font-weight: 500; }

/* QR card */
.qr-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 1rem; text-align: center; transition: all var(--t) var(--ease); color: var(--text); }
.qr-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.qr-card-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: .8rem; padding-bottom: .6rem; border-bottom: 1px solid var(--border); }
.qr-card-label { font-family: var(--font-display); font-size: var(--step-1); font-weight: 500; letter-spacing: -.01em; color: var(--text); }
.qr-card-meta { font-family: var(--font-mono); font-size: var(--step--2); color: var(--text-muted); letter-spacing: .04em; }
/* QR frame must stay light in both modes for scan contrast */
.qr-frame { width: 100%; aspect-ratio: 1; background: #ffffff; border-radius: var(--r-sm); display: grid; place-items: center; margin-bottom: .7rem; overflow: hidden; }
.qr-frame img { width: 100%; height: 100%; object-fit: contain; padding: 10px; }
.qr-frame.empty { background: var(--surface-2); border: 1.5px dashed var(--border-strong); font-size: 2.5rem; color: var(--text-muted); }
.qr-url { font-family: var(--font-mono); font-size: .65rem; color: var(--text-subtle); word-break: break-all; margin-bottom: .6rem; letter-spacing: .02em; line-height: 1.3; }

/* Gamified customer tags (inspired by the reference image) */
.gtag { display: inline-flex; align-items: center; gap: .35rem; padding: .4rem .85rem; border-radius: var(--r-pill); font-size: .82rem; font-weight: 600; letter-spacing: -.005em; font-family: var(--font-body); }
.gtag .gi { font-size: .72rem; font-weight: 700; }
.gtag-gold { background: linear-gradient(135deg,#FDE68A,#F7C85B); color: #78350F; }
.gtag-pink { background: linear-gradient(135deg,#FBCFE8,#F9A8D4); color: #831843; }
.gtag-rose { background: linear-gradient(135deg,#FEE2E2,#FCA5A5); color: #991B1B; }
.gtag-teal { background: linear-gradient(135deg,#A7F3D0,#6EE7B7); color: #065F46; }
.gtag-blue { background: linear-gradient(135deg,#DBEAFE,#93C5FD); color: #1E3A8A; }
.gtag-peach { background: linear-gradient(135deg,#FED7AA,#FDBA74); color: #7C2D12; }
.gtag-amber { background: linear-gradient(135deg,#FEF3C7,#FCD34D); color: #78350F; }
.gtag-neutral { background: var(--cream-100); color: var(--ink-700); border: 1px solid var(--line); }

/* Pill/chip for capability hints in tabs */
.hint { display: inline-flex; align-items: center; gap: .3rem; padding: .2rem .55rem; background: var(--cream-100); border: 1px solid var(--line); border-radius: var(--r-pill); font-size: var(--step--2); color: var(--ink-500); font-weight: 500; margin-left: .4rem; }

/* Locked subtabs */
nav.tabs .subtabs a.locked { color: var(--ink-500); }
nav.tabs .subtabs a.locked:hover { color: var(--terracotta-500); }
nav.tabs .subtabs a .tier-icon { display: inline-block; margin-left: .35rem; font-size: .78em; vertical-align: 1px; font-weight: 700; letter-spacing: 0; transition: opacity var(--t) var(--ease), filter var(--t) var(--ease); }
nav.tabs .subtabs a .tier-icon.pro { color: var(--amber-500); text-shadow: 0 0 10px rgba(200,150,52,.35); }
nav.tabs .subtabs a .tier-icon.premium { background: linear-gradient(135deg,#c3dafd,#7b91e7,#3730a3); -webkit-background-clip: text; background-clip: text; color: transparent; }
nav.tabs .subtabs a .tier-icon.addon { width: 1.15em; height: 1.15em; line-height: 1.05em; border-radius: 50%; background: var(--terracotta-50); color: var(--terracotta-700); text-align: center; font-size: .72em; border: 1px solid var(--terracotta-100); }
/* When locked, icon is dimmed slightly but still visible */
nav.tabs .subtabs a .tier-icon.is-locked { filter: grayscale(.25) brightness(.9); }

/* T4 — Mobile-view button hover */
.mobile-view-btn:hover { background: var(--cream-100, #f5efe2) !important; color: var(--ink-700, #2a2018) !important; }
@media (max-width: 768px) { .mobile-view-btn { display: none !important; } }

/* T3 — Floor tab notification badge (count of tables with active alert).
   Lives next to the label, ruby pill so it pops without competing with the
   active-tab terracotta underline. */
nav.tabs .subtabs a .tab-badge {
  display: inline-block;
  margin-left: .4rem;
  min-width: 1.2em;
  height: 1.2em;
  padding: 0 .35em;
  border-radius: var(--r-pill);
  background: var(--ruby-500, #c4574a);
  color: #fff;
  font-family: var(--font-mono);
  font-size: .68em;
  font-weight: 600;
  line-height: 1.2em;
  text-align: center;
  vertical-align: 1px;
  box-shadow: 0 1px 4px rgba(196, 87, 74, .35);
  animation: tab-badge-pop var(--t) var(--ease-spring) both;
}
@keyframes tab-badge-pop {
  0% { transform: scale(.6); opacity: 0; }
  60% { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  nav.tabs .subtabs a .tab-badge { animation: none; }
}

/* T3 — Bell injected into floor table cards. The card itself is positioned
   absolutely on the canvas, so the bell sits in its top-right corner with an
   inner offset so it doesn't get clipped by the rounded edge.
   Uses ruby for call_waiter, moss for ready (kind=ready). */
.floor-table .table-notif-bell {
  position: absolute;
  top: -10px;
  right: -10px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--ruby-500, #c4574a);
  color: #fff;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(196, 87, 74, .45), 0 0 0 2px var(--cream-50, #fff);
  pointer-events: none;
  animation: table-bell-pulse 1.6s var(--ease) infinite;
  z-index: 2;
}
.floor-table .table-notif-bell[data-kind="ready"] {
  background: var(--moss-700, #5a7d68);
  box-shadow: 0 2px 8px rgba(90, 125, 104, .45), 0 0 0 2px var(--cream-50, #fff);
  animation: none;
}
@keyframes table-bell-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}
@media (prefers-reduced-motion: reduce) {
  .floor-table .table-notif-bell { animation: none; }
}

/* ------ Mobile responsive ------ */
@media (max-width: 768px) {
  /* Header : 2-row layout, brand left + right cluster, resto name on row 2 */
  header .bar { padding: .7rem .8rem; gap: .4rem; flex-wrap: wrap; }
  header .brand { font-size: 1.1rem; }
  header .resto { font-size: var(--step--2); flex-basis: 100%; text-align: left; order: 3; padding-top: .2rem; }
  header .right {
    flex-wrap: nowrap;
    gap: .25rem;
    justify-content: flex-end;
    margin-left: auto;
    align-items: center;
  }
  header .right .role-badge { display: none; }
  /* All header buttons get the same compact icon-button shape on mobile */
  header .right > button,
  header .right > a,
  header .right > select {
    padding: .35rem .45rem !important;
    font-size: .8rem !important;
    margin-right: 0 !important;
    line-height: 1;
    height: 32px;
    min-height: 32px;
  }
  header .right > a span { display: none; } /* hide "Aide" word, keep only 💬 */
  header .right .logout {
    padding: .35rem .55rem !important;
    border: 1px solid var(--line);
    border-radius: 8px;
    height: 32px;
  }
  /* Hide flag emojis in lang picker, keep only code (saves width) */
  #uiLangPicker { font-size: .72rem !important; padding: .2rem .25rem !important; min-width: 56px; }

  /* Tabs : horizontal scroll with snap + edge fade hint */
  nav.tabs .wrap { padding: 0 .8rem; }
  nav.tabs .section-nav {
    overflow-x: auto; scrollbar-width: none;
    padding: .55rem 0;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x proximity;
    -webkit-mask-image: linear-gradient(90deg, #000 calc(100% - 28px), transparent);
    mask-image: linear-gradient(90deg, #000 calc(100% - 28px), transparent);
  }
  nav.tabs .section-nav::-webkit-scrollbar { display: none; }
  nav.tabs .section-nav a { scroll-snap-align: start; flex-shrink: 0; }
  nav.tabs .subtabs {
    padding: 0 0 .2rem; gap: 0;
    overflow-x: auto; scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    scroll-snap-type: x proximity;
    -webkit-mask-image: linear-gradient(90deg, #000 calc(100% - 28px), transparent);
    mask-image: linear-gradient(90deg, #000 calc(100% - 28px), transparent);
  }
  nav.tabs .subtabs::-webkit-scrollbar { display: none; }
  nav.tabs .subtabs a {
    white-space: nowrap; flex-shrink: 0;
    scroll-snap-align: start;
    margin-right: 1.2rem;
    padding: .8rem .2rem;
  }
  nav.tabs .subtabs a:last-child { margin-right: 1rem; }

  /* Main content : tighter gutters but keep some breathing */
  main { padding: 1.1rem .8rem 5rem; }

  /* Tables : reduce vertical padding, prevent over-cramped fonts */
  table { font-size: var(--step--2); }
  table th, table td { padding: .6rem .7rem; }
  table th { font-size: .68rem; padding: .55rem .7rem; }

  /* Panels */
  .panel { border-radius: var(--r-sm); margin-bottom: 1.1rem; }
  .panel-head { padding: .85rem 1rem; flex-wrap: wrap; gap: .45rem; }
  .panel-head h2 { font-size: var(--step-1); }
  .panel-tools { flex-wrap: wrap; gap: .35rem; width: 100%; }
  .panel-tools input,
  .panel-tools select { min-width: 0; flex: 1 1 140px; padding: .5rem .65rem; font-size: var(--step--1); }
  .panel-tools .btn { flex: 0 0 auto; }

  /* Stat cards grid — 2 cols on phone */
  .grid-4 { grid-template-columns: repeat(2, 1fr); gap: .6rem; }
  .card { padding: 1rem; border-radius: var(--r-sm); }
  .card .big { font-size: 1.7rem; }
  .card .label { font-size: .68rem; margin-bottom: .35rem; }
  .card .sub { font-size: .78rem; }

  /* Tables : robust horizontal scroll wrapper. Catches:
     - <div> wrapping a table (most renderers)
     - direct .panel > table
     The scroll fade is added by design.css universal rule. */
  .panel > .table-wrap,
  .panel > div:has(> table),
  .panel > table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Force tables to hold a min-width so important columns don't squeeze
     into illegibility — user scrolls horizontally instead. */
  .panel table { min-width: 560px; }

  /* Floor canvas : disable drag behavior cues, just scroll inside the wrap */
  .floor-canvas-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .floor-canvas { min-width: 700px; }

  /* Plan grid 1 col is set elsewhere; ensure addon cards too */
  .addon-grid { grid-template-columns: 1fr !important; gap: 1rem; }

  /* Login box plein écran */
  .login-box { margin: 1.5rem auto; padding: 2rem 1.4rem; max-width: calc(100% - 1.6rem); border-radius: var(--r-lg); }

  /* QR cards : smaller sizing, 2 per row */
  .qr-card { padding: .8rem; }
  .qr-frame { aspect-ratio: 1; }

  /* Reports charts : 1 per row + reduce height */
  .reports-charts { grid-template-columns: 1fr !important; gap: .8rem; }
  .chart-wrap { height: 200px !important; }

  /* Rating / AI variants : 1 col */
  .rating-ai-variants { grid-template-columns: 1fr !important; }

  /* Snippet box : let copy button drop below + URL break */
  .snippet-box { flex-wrap: wrap; padding: .6rem .7rem; }
  .snippet-box code { width: 100%; word-break: break-all; white-space: normal; font-size: .75rem; }
  .snippet-box button { width: 100%; }
}

/* Très petit écran (iPhone SE, anciens Android) */
@media (max-width: 420px) {
  header .bar { padding: .55rem .6rem; }
  header .brand { font-size: 1rem; }
  /* Hide brand on very narrow when resto name + chips eat the row */
  header .right > a[href*="wa.me"] { display: none; } /* hide "Aide" link entirely */

  .grid-4 { grid-template-columns: 1fr 1fr; }
  .card .big { font-size: 1.55rem; }
  .panel-head h2 { font-size: var(--step-0); }
  main { padding: .9rem .65rem 5rem; }
  .panel-tools .btn { flex: 1 1 auto; min-height: 44px; }
  /* Snippets avec horizontal scroll sur les longs URL */
  .snippet-box { flex-wrap: wrap; }
  .snippet-box code { width: 100%; word-break: break-all; font-size: .72rem; }

  /* Calendar grid : minimum 60px per day on phones */
  .resa-calendar .cal-grid { grid-template-columns: 32px repeat(7, minmax(48px, 1fr)); }
  .resa-calendar { padding: .8rem .7rem; overflow-x: auto; }
}

/* ----- Mobile typography polish (2026-05-02) -----
   Display fonts with negative letter-spacing read as "stretched" on small
   screens. Tighten the heroes, the .me-header, the upgrade card title,
   the panel titles, and a few oversized numbers. */
@media (max-width: 768px) {
  .me-header h2 { font-size: var(--step-1); letter-spacing: -.005em; line-height: 1.2; }
  .me-header .muted { font-size: var(--step--1); margin-bottom: .9rem; }
  .me-quadrant h3 { font-size: var(--step-0); }
  .me-quadrant-desc { font-size: var(--step--2); margin-bottom: .6rem; }
  .upgrade { padding: 1.8rem 1.2rem; margin: 1.5rem auto; }
  .upgrade h2 { font-size: var(--step-2); letter-spacing: 0; line-height: 1.2; }
  .upgrade::before { width: 160px; height: 160px; top: -60px; right: -60px; }
  .panel-head h2 { line-height: 1.25; letter-spacing: 0; }
  .hh-section h2 { font-size: var(--step-1); letter-spacing: 0; line-height: 1.25; }
  .plan-card h4 { font-size: var(--step-1); }
  .plan-card .price-mono { font-size: var(--step-0); }
  /* Stat cards .big — keep readable but never wider than the card */
  .card .big { font-size: clamp(1.3rem, 6vw, 1.7rem); letter-spacing: -.01em; }
}
@media (max-width: 420px) {
  .me-header h2 { font-size: var(--step-0); }
  .upgrade h2 { font-size: var(--step-1); }
  .panel-head h2 { font-size: var(--step--1); }
}

/* Upgrade card (shown when user clicks a locked tab) */
.upgrade { background: var(--surface); color: var(--text); border: 1px solid var(--border); border-radius: var(--r-lg); padding: clamp(2rem, 5vw, 4rem); text-align: center; max-width: 640px; margin: 3rem auto; position: relative; overflow: hidden; box-shadow: var(--shadow-md); }
.upgrade::before { content: ''; position: absolute; top: -80px; right: -80px; width: 260px; height: 260px; border-radius: 50%; background: radial-gradient(closest-side, var(--accent-soft), transparent 70%); }
.upgrade .lock-badge { font-family: var(--font-mono); font-size: var(--step--1); color: var(--accent-strong); background: var(--accent-soft); border: 1px solid var(--terracotta-100); padding: .4rem 1rem; border-radius: var(--r-pill); display: inline-flex; align-items: center; gap: .4rem; margin-bottom: 1.5rem; letter-spacing: .05em; font-weight: 500; position: relative; }
.upgrade h2 { font-family: var(--font-display); font-size: var(--step-4); font-weight: 400; letter-spacing: -.02em; margin-bottom: 1rem; position: relative; font-variation-settings: 'opsz' 100; color: var(--text); }
.upgrade h2 em { color: var(--accent); font-style: italic; font-variation-settings: 'SOFT' 100; }
.upgrade p.lead { margin: 0 auto 2rem; position: relative; color: var(--text-soft); }
.upgrade .cta-row { display: flex; gap: .6rem; justify-content: center; flex-wrap: wrap; position: relative; }

/* Plan picker (settings) */
.plan-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .9rem; margin: 1rem 0; }
@media (max-width: 780px) { .plan-grid { grid-template-columns: 1fr; } }
.plan-card { padding: 1.4rem; border: 1.5px solid var(--border); border-radius: var(--r-md); background: var(--surface); color: var(--text); cursor: pointer; transition: all var(--t) var(--ease); position: relative; display: flex; flex-direction: column; }
.plan-card:hover { border-color: var(--border-strong); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.plan-card.current { border-color: var(--moss-700); background: color-mix(in oklab, var(--moss-500) 10%, var(--surface)); }
.plan-card.current::after { content: 'ACTUEL'; position: absolute; top: .7rem; right: .7rem; font-family: var(--font-mono); font-size: var(--step--2); color: var(--moss-700); letter-spacing: .08em; font-weight: 500; }
.plan-card.featured { background: var(--accent); color: #fff; border-color: var(--accent); }
.plan-card.featured:hover { box-shadow: var(--shadow-lg); }
.plan-card h4 { font-family: var(--font-display); font-size: var(--step-2); font-weight: 500; letter-spacing: -.015em; margin-bottom: .2rem; }
.plan-card .price-mono { font-family: var(--font-mono); font-weight: 500; font-size: var(--step-1); margin-bottom: .8rem; }
.plan-card .price-mono small { font-size: var(--step--1); color: var(--text-muted); font-weight: 400; }
.plan-card.featured .price-mono small { color: rgba(255,255,255,.75); }
.plan-card ul { list-style: none; padding: 0; margin: 0 0 1rem; font-size: var(--step--1); flex: 1; }
.plan-card li { padding: .3rem 0; color: var(--text-soft); }
.plan-card.featured li { color: rgba(255,255,255,.92); }
.plan-card button { margin-top: auto; }

/* --- Addon grid + cards (Paramètres > Options payantes) --- */
.addon-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1rem; }
.addon-card { position: relative; padding: 1.4rem; border: 1.5px solid var(--line); border-radius: var(--r-md); background: var(--surface); display: flex; flex-direction: column; transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease); }
.addon-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: var(--line-strong); }
.addon-card.is-active { border-color: var(--moss-500); background: linear-gradient(180deg, color-mix(in oklab, var(--moss-500) 10%, var(--cream-50)), var(--surface) 40%); }
.addon-card.is-active::after { content: '● ACTIF'; position: absolute; top: .7rem; right: .8rem; font-family: var(--font-mono); font-size: var(--step--2); color: var(--moss-700); letter-spacing: .08em; font-weight: 600; }
.addon-card .addon-price { font-family: var(--font-display); font-size: var(--step-2); font-weight: 500; letter-spacing: -.015em; margin: .4rem 0; }
.addon-card .addon-price small { font-family: var(--font-body); font-size: var(--step--1); color: var(--ink-500); font-weight: 400; }
.addon-card .addon-desc { color: var(--ink-muted); font-size: var(--step--1); min-height: 4.5em; margin-bottom: 1rem; line-height: 1.5; }
.addon-card button { margin-top: auto; }

/* --- Snippet box (widget embed + referral link) --- */
.snippet-box { display: flex; gap: .6rem; align-items: center; padding: .7rem .8rem; background: var(--btn-primary-bg); color: var(--btn-primary-text); border-radius: var(--r-sm); font-family: var(--font-mono); font-size: var(--step--1); overflow: hidden; }
.snippet-box code { flex: 1; word-break: break-all; white-space: nowrap; overflow-x: auto; scrollbar-width: none; }
.snippet-box code::-webkit-scrollbar { display: none; }
.snippet-box button { background: var(--terracotta-500); color: var(--cream-50); border: none; padding: .45rem .9rem; border-radius: var(--r-pill); cursor: pointer; font-family: var(--font-body); font-size: var(--step--1); font-weight: 500; letter-spacing: -.005em; white-space: nowrap; transition: background var(--t) var(--ease), transform var(--t-fast) var(--ease); }
.snippet-box button:hover { background: var(--terracotta-700); transform: translateY(-1px); }

/* --- Referral block --- */
.referral-code-row { display: grid; grid-template-columns: auto 1fr; gap: 1.4rem; margin: .8rem 0; align-items: end; }
@media (max-width: 640px) { .referral-code-row { grid-template-columns: 1fr; } }
.referral-code { font-family: var(--font-mono); font-size: var(--step-2); font-weight: 600; color: var(--terracotta-500); letter-spacing: .14em; padding: .55rem 1rem; background: var(--cream-100); border: 1.5px solid var(--terracotta-100); border-radius: var(--r-sm); text-align: center; }
.referral-earnings { padding: .8rem 1rem; background: var(--cream-100); border-left: 3px solid var(--moss-500); border-radius: var(--r-sm); margin: 1rem 0; font-size: var(--step-0); color: var(--ink-700); }
.referral-earnings strong { font-family: var(--font-mono); color: var(--moss-700); }
.referral-list { list-style: none; padding: 0; margin: 0; }
.referral-list li { padding: .7rem 0; border-bottom: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; font-size: var(--step--1); }
.referral-list li:last-child { border-bottom: 0; }
.referral-list .ok { color: var(--moss-700); font-weight: 500; font-family: var(--font-mono); letter-spacing: .04em; }
.referral-list .pending { color: var(--ink-500); font-family: var(--font-mono); letter-spacing: .04em; font-size: var(--step--2); }
.referral-empty { color: var(--ink-muted); font-family: var(--font-display); font-style: italic; font-variation-settings: 'SOFT' 100, 'WONK' 1; border: 0 !important; }

/* --- Team block --- */
.team-invite-row { display: grid; grid-template-columns: 1fr auto auto; gap: .6rem; margin: 1rem 0 1.4rem; }
.team-invite-row input, .team-invite-row select { margin: 0; }
@media (max-width: 700px) { .team-invite-row { grid-template-columns: 1fr; } }
.team-list { list-style: none; padding: 0; margin: 0; }
.team-list li { padding: .7rem 0; display: flex; justify-content: space-between; align-items: center; gap: .8rem; border-bottom: 1px solid var(--line); }
.team-list li:last-child { border-bottom: 0; }
.team-list .team-meta { display: flex; gap: .7rem; align-items: center; flex-wrap: wrap; min-width: 0; }
.team-list .team-email { font-family: var(--font-body); color: var(--ink); font-weight: 500; }
.team-list .team-role { font-family: var(--font-mono); font-size: var(--step--2); padding: .15rem .55rem; background: var(--cream-100); color: var(--ink-700); border-radius: var(--r-pill); letter-spacing: .06em; text-transform: uppercase; }
.team-list .team-status { font-family: var(--font-mono); font-size: var(--step--2); letter-spacing: .06em; text-transform: uppercase; }
.team-list .team-status.active { color: var(--moss-700); }
.team-list .team-status.pending { color: var(--amber-500); }
.team-list button.danger { background: transparent; border: 1px solid var(--ruby-500); color: var(--ruby-500); padding: .4rem .9rem; border-radius: var(--r-pill); cursor: pointer; font-family: var(--font-body); font-size: var(--step--1); transition: all var(--t) var(--ease); }
.team-list button.danger:hover { background: var(--ruby-500); color: var(--cream-50); }
.team-empty { color: var(--ink-muted); font-family: var(--font-display); font-style: italic; font-variation-settings: 'SOFT' 100, 'WONK' 1; border: 0 !important; padding: .8rem 0; }

/* ============================================================
   Dark mode — long-tail patches for inline-style hex islands.
   Most surfaces now flip automatically via semantic tokens
   (--surface, --bg, --text, --border, --btn-primary-*) defined
   in design.css :root and overridden in [data-theme="dark"].
   This block only handles the renderers that still hardcode
   pastel hex colors inline (floor plan states, banner gradients).
   ============================================================ */

/* Banner gradients (menu disclaimer, trial countdown, setup checklist) ---
   These use linear-gradient with two known cream/yellow stops. Substring
   match on the hex code catches both bg and gradient stops. */
[data-theme="dark"] [style*="#fef3c7"],
[data-theme="dark"] [style*="#fef9e7"],
[data-theme="dark"] [style*="#FEF3C7"] { background: linear-gradient(135deg, var(--surface-2), var(--surface)) !important; }
[data-theme="dark"] [style*="#fef3c7"] *,
[data-theme="dark"] [style*="#fef9e7"] *,
[data-theme="dark"] [style*="#FEF3C7"] * { color: var(--text) !important; }
[data-theme="dark"] [style*="#fef3c7"] strong,
[data-theme="dark"] [style*="#fef9e7"] strong,
[data-theme="dark"] [style*="#FEF3C7"] strong { color: var(--amber-500) !important; }

/* Floor plan tables (pastel-bg + dark-text combos) — desaturate. */
[data-theme="dark"] [style*="#d1fae5"] { background-color: #1f352a !important; }
[data-theme="dark"] [style*="#fde68a"] { background-color: #3a2e1a !important; }
[data-theme="dark"] [style*="#fecaca"] { background-color: #3a2020 !important; }
[data-theme="dark"] [style*="color:#064e3b"] { color: #86efac !important; }
[data-theme="dark"] [style*="color:#78350f"] { color: #fcd34d !important; }
[data-theme="dark"] [style*="color:#7f1d1d"] { color: #fca5a5 !important; }
[data-theme="dark"] [style*="color:#0f766e"] { color: #6ee7b7 !important; }
[data-theme="dark"] [style*="color:#b45309"] { color: #fbbf24 !important; }
[data-theme="dark"] [style*="color:#b91c1c"] { color: #fca5a5 !important; }

/* Mirror under [data-theme="auto"] when OS prefers dark. */
@media (prefers-color-scheme: dark) {
  [data-theme="auto"] [style*="#fef3c7"],
  [data-theme="auto"] [style*="#fef9e7"],
  [data-theme="auto"] [style*="#FEF3C7"] { background: linear-gradient(135deg, var(--surface-2), var(--surface)) !important; }
  [data-theme="auto"] [style*="#fef3c7"] *,
  [data-theme="auto"] [style*="#fef9e7"] *,
  [data-theme="auto"] [style*="#FEF3C7"] * { color: var(--text) !important; }
  [data-theme="auto"] [style*="#d1fae5"] { background-color: #1f352a !important; }
  [data-theme="auto"] [style*="#fde68a"] { background-color: #3a2e1a !important; }
  [data-theme="auto"] [style*="#fecaca"] { background-color: #3a2020 !important; }
  [data-theme="auto"] [style*="color:#064e3b"] { color: #86efac !important; }
  [data-theme="auto"] [style*="color:#78350f"] { color: #fcd34d !important; }
  [data-theme="auto"] [style*="color:#7f1d1d"] { color: #fca5a5 !important; }
}
