@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,300;1,9..144,400;1,9..144,600&family=Inter:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=JetBrains+Mono:wght@400;500&display=swap");
/* ============================================================
   ServiaOS — Foundations: Colors & Type
   Editorial. Terroir. Calm density.
   ============================================================ */

/* --- Fonts ------------------------------------------------- */
/* Display serif: Fraunces (soft/supersoft optical cut for warmth).
   USED ONLY FOR DISPLAY — headings H1/H2, pullquotes, eyebrows of
   editorial weight. Never for body, UI labels or app chrome. */
/* UI sans: Inter (pesos 400/500/600). Self-hosted from Google Fonts.
   This is the definitive UI face. Use for everything that isn't
   a display heading: body, buttons, inputs, nav, data, captions. */
:root {
  /* ------------------------------------------------------------
     COLOR — Penedès terroir palette
     One accent per screen. Everything else neutral.
     ------------------------------------------------------------ */

  /* Paper (cream) — primary surface. Sampled from logo background. */
  --paper:        #F8F8F3;   /* canvas */
  --paper-2:      #F1F0E8;   /* raised surface, hover on paper */
  --paper-3:      #E8E6DB;   /* pressed, dividers on paper */

  /* Ink (olive-black) — primary foreground. Sampled from logo wordmark. */
  --ink:          #404329;   /* body + primary text */
  --ink-2:        #595B44;   /* secondary text */
  --ink-3:        #8A8B77;   /* tertiary / captions */
  --ink-4:        #B8B8A8;   /* disabled / placeholder */
  --ink-line:     #D9D8CC;   /* hairlines on paper */

  /* Night — inverse surface (editorial dark pages, modals) */
  --night:        #1E2014;
  --night-2:      #2B2D1E;
  --night-3:      #3B3D2C;

  /* ---- Accents (use ONE per screen) ---- */
  /* Vinya — grape/aubergine, signature accent for primary actions */
  --vinya-50:     #F4EEF1;
  --vinya-100:   #E6D6DF;
  --vinya-300:    #B07898;
  --vinya-500:    #7A3F5F;   /* primary accent */
  --vinya-700:    #5A2B46;
  --vinya-900:    #3A1A2D;

  /* Oliva — olive/moss, secondary accent (info, confirmed reservations) */
  --oliva-50:     #EEF0E4;
  --oliva-100:   #DDE1C7;
  --oliva-300:    #9BA36E;
  --oliva-500:    #6B734A;
  --oliva-700:    #4C5232;

  /* Terra — clay/terracotta, warnings + editorial warmth */
  --terra-50:     #F7EEE6;
  --terra-100:   #EDD7C4;
  --terra-300:    #D39A74;
  --terra-500:    #B06A40;
  --terra-700:    #824829;

  /* Cel — dusty sky, info */
  --cel-50:       #ECEEEF;
  --cel-300:      #8B9FA8;
  --cel-500:      #5E7680;

  /* ---- Semantic ---- */
  --bg:           var(--paper);
  --bg-raised:    var(--paper-2);
  --bg-sunken:    var(--paper-3);
  --fg:           var(--ink);
  --fg-muted:     var(--ink-2);
  --fg-subtle:    var(--ink-3);
  --fg-disabled:  var(--ink-4);
  --line:         var(--ink-line);
  --line-strong:  var(--ink-3);

  --accent:       var(--vinya-500);
  --accent-fg:    #FFFFFF;
  --accent-soft:  var(--vinya-50);

  --success:      var(--oliva-500);
  --success-soft: var(--oliva-50);
  --warning:      var(--terra-500);
  --warning-soft: var(--terra-50);
  --danger:       #9A2B1E;       /* muted brick, not cliché wine */
  --danger-soft:  #F4E4E1;
  --info:         var(--cel-500);
  --info-soft:    var(--cel-50);

  /* ------------------------------------------------------------
     TYPE
     Serif display (Fraunces), Sans UI (Inter Tight).
     Hierarchy by size + weight, never color.
     ------------------------------------------------------------ */
  --font-serif:   "Fraunces", "Fraunces Soft", Georgia, "Times New Roman", serif;
  --font-serif-soft: "Fraunces Soft", "Fraunces", Georgia, serif;
  --font-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Type scale — modest, mobile-first. Don't shout. */
  --fs-xs:   12px;
  --fs-sm:   14px;
  --fs-base: 16px;
  --fs-md:   18px;
  --fs-lg:   22px;
  --fs-xl:   28px;
  --fs-2xl:  36px;
  --fs-3xl:  48px;
  --fs-4xl:  64px;
  --fs-5xl:  88px;

  --lh-tight:  1.08;
  --lh-snug:   1.22;
  --lh-normal: 1.5;
  --lh-relaxed:1.65;

  --tracking-tight:  -0.02em;
  --tracking-snug:   -0.01em;
  --tracking-normal: 0em;
  --tracking-wide:   0.04em;
  --tracking-eyebrow:0.14em;

  /* ------------------------------------------------------------
     SPACING — 4px base. Calm density.
     ------------------------------------------------------------ */
  --space-0:  0;
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  24px;
  --space-6:  32px;
  --space-7:  48px;
  --space-8:  64px;
  --space-9:  96px;
  --space-10: 128px;

  /* ------------------------------------------------------------
     RADII — slight, editorial. Never pill unless intentional.
     ------------------------------------------------------------ */
  --radius-xs: 2px;
  --radius-sm: 4px;
  --radius-md: 8px;   /* default for cards, inputs */
  --radius-lg: 14px;  /* larger surfaces */
  --radius-xl: 24px;
  --radius-full: 999px;

  /* ------------------------------------------------------------
     ELEVATION — soft, low, warm (no bluish drop shadows).
     ------------------------------------------------------------ */
  --shadow-0: none;
  --shadow-1: 0 1px 0 rgba(64,67,41,0.06), 0 1px 2px rgba(64,67,41,0.04);
  --shadow-2: 0 1px 0 rgba(64,67,41,0.05), 0 2px 8px -2px rgba(64,67,41,0.08);
  --shadow-3: 0 2px 1px rgba(64,67,41,0.04), 0 8px 24px -6px rgba(64,67,41,0.12);
  --shadow-4: 0 4px 2px rgba(64,67,41,0.04), 0 24px 48px -12px rgba(64,67,41,0.18);
  --shadow-inset: inset 0 1px 0 rgba(64,67,41,0.04);

  /* Focus ring — accent, not blue. */
  --ring: 0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent);

  /* ------------------------------------------------------------
     MOTION — minimal. Acknowledge only.
     ------------------------------------------------------------ */
  --ease-out:   cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-in-out:cubic-bezier(0.45, 0.05, 0.35, 1);
  --dur-1: 120ms;  /* press */
  --dur-2: 200ms;  /* hover */
  --dur-3: 320ms;  /* panel */

  /* Layout */
  --content-max: 1120px;   /* editorial comfort */
  --content-read: 680px;   /* prose width */
  --touch-min: 44px;       /* never less */
}

/* ============================================================
   SEMANTIC TYPE CLASSES
   Use these; don't roll your own.
   ============================================================ */

.t-eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-subtle);
}

.t-display-xl, h1.display {
  font-family: var(--font-serif-soft);
  font-size: clamp(var(--fs-3xl), 8vw, var(--fs-5xl));
  font-weight: 400;        /* serif display is regular or light, never bold */
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--fg);
  text-wrap: balance;
}

.t-display, h1 {
  font-family: var(--font-serif);
  font-size: clamp(var(--fs-2xl), 6vw, var(--fs-4xl));
  font-weight: 400;
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--fg);
  text-wrap: balance;
}

.t-h1, h2 {
  font-family: var(--font-serif);
  font-size: var(--fs-2xl);
  font-weight: 400;
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-snug);
  color: var(--fg);
  text-wrap: balance;
}

.t-h2, h3 {
  font-family: var(--font-serif);
  font-size: var(--fs-xl);
  font-weight: 500;
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-snug);
  color: var(--fg);
}

.t-h3, h4 {
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  font-weight: 600;
  line-height: var(--lh-snug);
  color: var(--fg);
}

.t-body, p {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: 400;
  line-height: var(--lh-relaxed);
  color: var(--fg);
  text-wrap: pretty;
}

.t-body-lg {
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  line-height: var(--lh-relaxed);
  color: var(--fg-muted);
  text-wrap: pretty;
}

.t-lede {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-lg);
  line-height: var(--lh-normal);
  color: var(--fg-muted);
}

.t-caption, small {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
  color: var(--fg-subtle);
}

.t-label {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: 500;
  line-height: 1.3;
  color: var(--fg);
}

.t-mono, code, kbd {
  font-family: var(--font-mono);
  font-size: 0.92em;
  letter-spacing: 0;
  color: var(--fg-muted);
}

.t-pullquote {
  font-family: var(--font-serif-soft);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(var(--fs-xl), 4vw, var(--fs-3xl));
  line-height: var(--lh-snug);
  color: var(--fg);
}

/* Base reset-ish */
html { color: var(--fg); background: var(--bg); }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-relaxed);
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
::selection { background: color-mix(in oklab, var(--accent) 30%, transparent); color: var(--fg); }
  html, body { min-height: 100%; }
  body { margin: 0; background: var(--paper); color: var(--ink); }
  .srv-shell { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
  @media (max-width: 900px) { .srv-shell { grid-template-columns: 1fr; } }

  /* Sidebar (desktop) */
  .srv-side {
    background: var(--paper-2); border-right: 1px solid var(--line);
    padding: 28px 18px 18px; display: flex; flex-direction: column; gap: 14px;
    position: sticky; top: 0; height: 100vh;
  }
  @media (max-width: 900px) { .srv-side { display: none; } }
  .srv-brand-mark { font: 600 18px/1 var(--font-sans); letter-spacing: 0.02em; color: var(--ink); }
  .srv-brand-sub { margin-top: 4px; display: flex; flex-direction: column; gap: var(--space-1, 4px); }
  .srv-brand-tag { opacity: 0.7; }
  .srv-nav { display: flex; flex-direction: column; gap: 2px; margin-top: 16px; }
  .srv-nav-item {
    display: flex; align-items: center; gap: 12px; padding: 10px 12px;
    background: transparent; border: none; font: 500 14px/1 var(--font-sans);
    color: var(--ink-2); cursor: pointer; border-radius: 8px; text-align: left;
  }
  .srv-nav-item i { font-size: 18px; color: var(--ink-3); }
  .srv-nav-item:hover { background: var(--paper-3); color: var(--ink); }
  .srv-nav-item.on { background: var(--ink); color: var(--paper); }
  .srv-nav-item.on i { color: var(--paper); }
  .srv-side-foot { margin-top: auto; display: flex; justify-content: space-between; align-items: center; gap: 8px; padding-top: 16px; border-top: 1px solid var(--line); }
  .srv-logout { background: transparent; border: none; color: var(--ink-3); font: 500 12px/1 var(--font-sans); cursor: pointer; display: inline-flex; align-items: center; gap: 6px; }
  .srv-logout i { font-size: 16px; }

  .lang-tog { display: inline-flex; border: 1px solid var(--line); border-radius: 999px; overflow: hidden; background: var(--paper); }
  .lang-tog button { font: 500 11px/1 var(--font-sans); border: none; background: transparent; color: var(--ink-3); padding: 6px 10px; cursor: pointer; }
  .lang-tog .on { background: var(--ink); color: var(--paper); }

  /* Main */
  .srv-main { padding: 40px clamp(20px, 5vw, 64px) 120px; max-width: var(--content-max, 1120px); width: 100%; }
  @media (max-width: 900px) { .srv-main { padding: 24px 20px 100px; } }

  .srv-page-head { margin-bottom: 28px; display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
  .srv-page-head h1 { margin: 6px 0 0; font-size: clamp(32px, 5vw, 52px); line-height: 1.05; }
  .srv-greet { font-size: clamp(36px, 6vw, 64px); }
  .eyebrow { font: 600 11px/1 var(--font-sans); letter-spacing: var(--tracking-eyebrow, 0.14em); text-transform: uppercase; color: var(--fg-subtle, var(--ink-3)); }

  /* Mobile bottom tabbar */
  .srv-tabbar {
    position: fixed; bottom: 0; left: 0; right: 0; display: none;
    justify-content: space-around; background: color-mix(in oklab, var(--paper) 95%, transparent);
    backdrop-filter: blur(10px); border-top: 1px solid var(--line);
    padding: 8px 4px calc(8px + env(safe-area-inset-bottom)); z-index: 40;
  }
  @media (max-width: 900px) { .srv-tabbar { display: flex; } }
  .srv-tabbar button {
    flex: 1; background: transparent; border: none; cursor: pointer;
    font: 500 10px/1 var(--font-sans); color: var(--ink-3);
    display: flex; flex-direction: column; align-items: center; gap: 3px;
    min-height: 48px; padding: 4px; letter-spacing: 0.04em;
  }
  .srv-tabbar button i { font-size: 20px; }
  .srv-tabbar .on { color: var(--vinya-500); }

  /* Buttons */
  .btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 12px 18px; border-radius: 8px; font: 500 14px/1 var(--font-sans);
    border: none; cursor: pointer; min-height: 44px; text-decoration: none;
    transition: background var(--dur-2) var(--ease-out);
  }
  .btn i { font-size: 18px; }
  .btn.primary { background: var(--vinya-500); color: #fff; }
  .btn.primary:hover { background: var(--vinya-700); }
  .btn.ghost { background: var(--paper-2); color: var(--ink); }
  .btn.ghost:hover { background: var(--paper-3); }
  .btn.small { padding: 8px 12px; min-height: 34px; font-size: 12px; }
  .link-btn { background: transparent; border: none; color: var(--vinya-500); font: 500 13px/1 var(--font-sans); cursor: pointer; padding: 4px 0; text-decoration: none; }
  .link-btn:hover { color: var(--vinya-700); }

  /* ── Auth (login + expired) ─────────────── */
  .srv-auth { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 20px; background: var(--paper); position: relative; }
  .srv-auth-lang { position: absolute; top: 24px; right: 24px; }
  .srv-auth-card { width: 100%; max-width: 440px; background: var(--paper); border: 1px solid var(--line); border-radius: 16px; padding: 48px 40px 40px; box-shadow: var(--shadow-3); }
  .srv-auth-card.expired { max-width: 520px; }
  .srv-auth-mark { font: 600 13px/1 var(--font-sans); letter-spacing: 0.08em; text-transform: uppercase; color: var(--vinya-500); }
  .srv-auth-title { font-size: 36px; margin: 16px 0 10px; line-height: 1.1; }
  .srv-auth-sub { margin: 0 0 28px; font-size: 16px; color: var(--ink-2); }
  .srv-auth-form { display: flex; flex-direction: column; gap: 16px; }
  .srv-field { display: flex; flex-direction: column; gap: 6px; }
  .srv-field input {
    font: 400 15px/1.4 var(--font-sans); padding: 12px 14px; border: 1px solid var(--line);
    border-radius: 8px; background: var(--paper); color: var(--ink); outline: none;
    transition: border-color var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
  }
  .srv-field input:focus { border-color: var(--vinya-500); box-shadow: var(--ring); }
  .srv-auth-btn { margin-top: 8px; width: 100%; }
  .srv-auth-link { margin-top: 4px; text-align: center; font: 500 13px/1 var(--font-sans); color: var(--ink-3); text-decoration: none; }
  .srv-auth-link:hover { color: var(--vinya-500); }
  .srv-auth-foot { margin-top: 28px; text-align: center; font-style: italic; }
  .exp-cta-row { display: flex; gap: 8px; margin: 24px 0 16px; flex-wrap: wrap; }
  .exp-cta-row .btn { flex: 1; min-width: 180px; }
  .exp-facts { display: flex; flex-direction: column; gap: 0; margin: 20px 0 0; padding: 16px 0 0; border-top: 1px solid var(--line); }
  .exp-facts > div { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; }
  .exp-facts dt { font: 500 12px/1 var(--font-sans); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); margin: 0; }
  .exp-facts dd { margin: 0; color: var(--ink); font-variant-numeric: tabular-nums; }

  /* ── KPI cards (dashboard) ──────────────── */
  .kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 32px; }
  .kpi-card {
    background: var(--paper); border: 1px solid var(--line); border-radius: 12px;
    padding: 20px 22px; display: flex; flex-direction: column; gap: 6px; min-height: 148px;
  }
  .kpi-card.accent { background: var(--vinya-50); border-color: var(--vinya-100); }
  .kpi-card.ok { background: var(--oliva-50); border-color: color-mix(in oklab, var(--oliva-500) 18%, var(--line)); }
  .kpi-big { font: 400 54px/1 var(--font-serif); color: var(--ink); letter-spacing: -0.02em; margin-top: 6px; display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
  .kpi-big-serif { font: 500 22px/1.15 var(--font-serif); color: var(--ink); letter-spacing: -0.01em; margin-top: 10px; flex: 1; }
  .kpi-big-muted { font: 400 54px/1 var(--font-serif); color: var(--ink-4); margin-top: 6px; }
  .kpi-delta { font: 500 13px/1 var(--font-sans); color: var(--oliva-700); background: var(--oliva-50); padding: 3px 8px; border-radius: 999px; letter-spacing: -0.01em; }
  .kpi-delta.up { color: var(--oliva-700); }
  .kpi-status { font: 500 18px/1 var(--font-sans); color: var(--ink); display: inline-flex; align-items: center; gap: 10px; margin-top: 10px; }
  .status-dot { width: 10px; height: 10px; border-radius: 999px; background: var(--oliva-500); box-shadow: 0 0 0 4px color-mix(in oklab, var(--oliva-500) 25%, transparent); }

  .srv-cta { margin-bottom: 40px; }

  /* ── Sections / reservation rows ─────────── */
  .srv-sec { margin-bottom: 36px; }
  .srv-sec-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 14px; }
  .srv-sec-head h2 { margin: 0; font-size: 22px; font-weight: 500; }
  .res-rows { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
  .res-row {
    display: grid; grid-template-columns: 72px 1fr auto; gap: 16px; align-items: center;
    background: var(--paper); border: 1px solid var(--line); border-radius: 10px;
    padding: 14px 16px; position: relative;
    transition: border-color var(--dur-2) var(--ease-out), background var(--dur-2) var(--ease-out);
  }
  .res-row:hover { border-color: var(--ink-3); }
  .res-row.highlight { background: var(--vinya-50); border-color: var(--vinya-100); }
  .res-row-hour { font: 500 20px/1 var(--font-serif); letter-spacing: -0.01em; color: var(--ink); }
  .res-row-name { font: 600 15px/1.2 var(--font-sans); color: var(--ink); }
  .res-row-meta { font: 400 13px/1.4 var(--font-sans); color: var(--ink-2); margin-top: 3px; font-variant-numeric: tabular-nums; }
  .res-row-note { font: italic 400 13px/1.4 var(--font-serif); color: var(--ink-2); margin-top: 4px; }
  .src-badge {
    display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 999px;
    font: 500 11px/1 var(--font-sans); letter-spacing: 0.02em;
  }
  .src-badge.src-bot    { background: var(--oliva-50); color: var(--oliva-700); }
  .src-badge.src-manual { background: var(--cel-50); color: #3F525A; }
  .src-badge.src-web    { background: var(--paper-3); color: var(--ink-2); }

  .res-row-actions { display: none; gap: 4px; align-items: center; flex-shrink: 0; }
  .res-row:hover .res-row-actions { display: flex; }

  .swipe-hint { display: none; font-style: italic; color: var(--ink-3); }
  @media (max-width: 600px) {
    .res-row { grid-template-columns: 58px 1fr auto; padding: 12px 14px; }
    .res-row-hour { font-size: 17px; }
    .swipeable .swipe-hint { display: block; position: absolute; right: 12px; bottom: 6px; font-size: 10px; opacity: 0.5; }
    .res-row:hover .res-row-actions { display: none; }
  }

  @keyframes res-slide-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
  .res-enter { animation: res-slide-in 0.3s ease; }

  .filter-row { display: flex; gap: 6px; margin-bottom: 20px; flex-wrap: wrap; }
  .chip {
    font: 500 12px/1 var(--font-sans); padding: 7px 12px; border-radius: 999px;
    border: 1px solid var(--line); background: var(--paper); color: var(--ink-2); cursor: pointer; min-height: 32px;
  }
  .chip.on { background: var(--ink); color: var(--paper); border-color: var(--ink); }

  /* Fab */
  .fab {
    position: fixed; right: 24px; bottom: 24px; background: var(--vinya-500); color: #fff;
    border: none; border-radius: 999px; padding: 14px 20px; cursor: pointer;
    font: 500 14px/1 var(--font-sans); display: inline-flex; align-items: center; gap: 8px;
    box-shadow: var(--shadow-4); z-index: 30;
  }
  .fab:hover { background: var(--vinya-700); }
  .fab i { font-size: 20px; }
  @media (max-width: 900px) { .fab { right: 16px; bottom: 80px; } }

  .empty-hint { padding: 16px 0; text-align: center; font-style: italic; }

  /* ── Carta table ────────────── */
  .srv-table { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; background: var(--paper); }
  .srv-table-head, .srv-table-row {
    display: grid; grid-template-columns: 28px 2fr 100px 1.2fr 60px; gap: 12px; align-items: center;
    padding: 12px 16px;
  }
  .srv-table-head { background: var(--paper-2); font: 500 11px/1 var(--font-sans); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
  .srv-table-row { border-top: 1px solid var(--line); transition: background var(--dur-2) var(--ease-out); }
  .srv-table-row:hover { background: var(--paper-2); }
  .srv-table-row.off { opacity: 0.55; }
  .col-grip { color: var(--ink-4); cursor: grab; display: flex; align-items: center; justify-content: center; }
  .col-grip i { font-size: 16px; }
  .dish-name { font: 600 14px/1.3 var(--font-sans); color: var(--ink); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
  .dish-sub { font-size: 12px; margin-top: 2px; font-style: italic; font-family: var(--font-serif); color: var(--ink-2); }
  .chip-xs { font: 500 9px/1 var(--font-sans); letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 6px; border-radius: 999px; background: var(--terra-50); color: var(--terra-700); }
  .col-price { text-align: right; font: 500 15px/1 var(--font-serif); color: var(--ink); font-variant-numeric: tabular-nums; }
  .price-suffix { font: 500 11px/1 var(--font-sans); color: var(--ink-3); }
  .col-alg { display: flex; gap: 4px; flex-wrap: wrap; }
  .alg-chip { font: 500 10px/1 var(--font-sans); padding: 3px 7px; background: var(--paper-3); color: var(--ink-2); border-radius: 999px; letter-spacing: 0.02em; }
  .col-on { display: flex; justify-content: flex-end; }

  .toggle { position: relative; width: 40px; height: 22px; border-radius: 999px; border: none; background: var(--ink-4); cursor: pointer; padding: 0; transition: background var(--dur-2) var(--ease-out); flex-shrink: 0; }
  .toggle .thumb { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 999px; background: #fff; box-shadow: var(--shadow-1); transition: transform var(--dur-2) var(--ease-out); }
  .toggle.on { background: var(--oliva-500); }
  .toggle.on .thumb { transform: translateX(18px); }

  @media (max-width: 720px) {
    .srv-table-head { display: none; }
    .srv-table-row {
      grid-template-columns: 28px 1fr auto; grid-template-areas: "grip name price" "grip alg on"; gap: 4px 12px;
    }
    .col-grip { grid-area: grip; }
    .col-name { grid-area: name; }
    .col-price { grid-area: price; }
    .col-alg { grid-area: alg; padding-left: 4px; }
    .col-on { grid-area: on; }
  }

  /* ── Experiences ────────────── */
  .exp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }
  .exp-card { background: var(--paper); border: 1px solid var(--line); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; transition: box-shadow var(--dur-2) var(--ease-out); }
  .exp-card:hover { box-shadow: var(--shadow-3); }
  .exp-card.paused .exp-img { filter: saturate(0.3) brightness(1.05); }
  .exp-img {
    aspect-ratio: 16/10; position: relative; padding: 16px;
    display: flex; justify-content: space-between; align-items: flex-start;
    color: #fff;
  }
  .exp-state { display: inline-flex; align-items: center; gap: 6px; background: rgba(0,0,0,0.35); padding: 4px 10px; border-radius: 999px; font: 500 11px/1 var(--font-sans); backdrop-filter: blur(4px); }
  .exp-state .dot { width: 6px; height: 6px; border-radius: 999px; }
  .exp-state.on .dot { background: #BFD54A; box-shadow: 0 0 0 4px rgba(191,213,74,0.3); }
  .exp-state.off .dot { background: #D39A74; }
  .exp-price { font: 500 18px/1 var(--font-serif); background: rgba(0,0,0,0.4); padding: 6px 10px; border-radius: 8px; backdrop-filter: blur(4px); }
  .exp-body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 10px; }
  .exp-name { margin: 0; font-size: 22px; font-weight: 500; }
  .exp-desc { margin: 0; font: 400 14px/1.5 var(--font-sans); color: var(--ink-2); }
  .exp-meta { display: flex; justify-content: space-between; gap: 12px; padding: 8px 0; border-top: 1px dotted var(--line); border-bottom: 1px dotted var(--line); font-size: 10px; }
  .exp-actions { display: flex; align-items: center; gap: 12px; margin-top: 4px; flex-wrap: wrap; }
  .exp-actions .btn.small { margin-left: auto; }

  /* ── Settings ──────────────── */
  .set-list { display: flex; flex-direction: column; gap: 10px; }
  .set-sec { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
  .set-sec-head { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 18px 22px; background: transparent; border: none; font: inherit; cursor: pointer; color: var(--ink); text-align: left; }
  .set-sec-head .t-h2 { margin: 0; font-size: 20px; font-weight: 500; font-family: var(--font-serif); }
  .set-sec-head i { font-size: 18px; color: var(--ink-3); transition: transform var(--dur-2) var(--ease-out); }
  .set-sec.open .set-sec-head i { transform: rotate(180deg); }
  .set-sec-body { padding: 6px 22px 22px; display: flex; flex-direction: column; gap: 14px; border-top: 1px solid var(--line); }
  .set-row { display: grid; grid-template-columns: 200px 1fr; gap: 16px; align-items: center; padding: 6px 0; }
  @media (max-width: 600px) { .set-row { grid-template-columns: 1fr; gap: 4px; padding: 6px 0; } }
  .set-row .eyebrow { font-size: 11px; }
  .set-val { font: 400 15px/1.4 var(--font-sans); color: var(--ink); }
  .set-input { font: 400 15px/1.4 var(--font-sans); padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px; background: var(--paper); color: var(--ink); outline: none; width: 100%; }
  .set-input:focus { border-color: var(--vinya-500); box-shadow: var(--ring); }
  .hours { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
  .hours li { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px dotted var(--line); font: 400 14px/1.4 var(--font-sans); }
  .hours li em { font-style: normal; font-family: var(--font-serif); color: var(--ink); font-variant-numeric: tabular-nums; }
  .hours li .closed { color: var(--terra-700); font-style: italic; }
  .brand-preview { background: var(--ink); color: var(--paper); padding: 28px 24px; border-radius: 12px; text-align: center; margin-bottom: 8px; }
  .brand-mark-big { font: 500 32px/1 var(--font-serif); letter-spacing: -0.01em; }
  .sub-card { background: var(--vinya-50); padding: 20px; border-radius: 10px; border: 1px solid var(--vinya-100); }
  .sub-card .t-h2 { margin: 6px 0; font-size: 22px; }

  /* ── Demo nav (not real UI) ── */
  .demo-bar { position: fixed; bottom: 20px; left: 20px; z-index: 100; }
  @media (max-width: 900px) { .demo-bar { bottom: 76px; left: 12px; } }
  .demo-tog { background: var(--ink); color: var(--paper); border: none; width: 40px; height: 40px; border-radius: 999px; cursor: pointer; box-shadow: var(--shadow-3); display: inline-flex; align-items: center; justify-content: center; }
  .demo-tog i { font-size: 18px; }
  .demo-bar.open .demo-links {
    position: absolute; bottom: 48px; left: 0; background: var(--ink); color: var(--paper);
    border-radius: 10px; padding: 10px; display: flex; flex-direction: column; gap: 2px;
    min-width: 160px; box-shadow: var(--shadow-4);
  }
  .demo-bar .demo-links .eyebrow { color: var(--ink-4); padding: 4px 10px 6px; }
  .demo-bar .demo-links button {
    background: transparent; border: none; color: var(--paper); padding: 6px 10px;
    font: 400 13px/1 var(--font-sans); text-align: left; cursor: pointer; border-radius: 6px;
  }
  .demo-bar .demo-links button:hover { background: rgba(255,255,255,0.08); }

  /* ── Cell feedback (Carta inline edit) ── */
  .cell-saving { opacity: 0.55; pointer-events: none; }
  .cell-saved  { animation: cell-saved-flash 0.6s ease forwards; }
  .cell-error  { animation: cell-error-flash 1.2s ease forwards; }
  @keyframes cell-saved-flash {
    0%   { background: var(--oliva-50, #F0FDF4); }
    100% { background: transparent; }
  }
  @keyframes cell-error-flash {
    0%   { background: var(--terra-50, #FEF2F2); }
    100% { background: transparent; }
  }

  /* ── Status badges (cancelled / noshow) ── */
  .status-badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px; border-radius: var(--radius-full, 999px);
    font: 500 11px/1 var(--font-sans); letter-spacing: 0.02em;
  }
  .status-badge.status-cancelled { background: var(--danger-soft); color: var(--danger); }
  .status-badge.status-noshow    { background: var(--warning-soft); color: var(--warning); }

  /* ── Cancelled row visual treatment ── */
  .res-row.is-cancelled { opacity: 0.6; }
  .res-row.is-cancelled .res-row-hour,
  .res-row.is-cancelled .res-row-name { text-decoration: line-through; opacity: 0.7; }

  /* ── Reservation groups ── */
  .res-group { margin-top: var(--space-8, 64px); }
  .res-group:first-child { margin-top: 0; }

  .res-group-heading {
    font-family: var(--font-sans);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: var(--tracking-eyebrow, 0.14em);
    text-transform: uppercase;
    color: var(--fg-subtle, var(--ink-3));
    margin: 0 0 var(--space-4, 16px) 0;
    padding-bottom: var(--space-3, 12px);
    border-bottom: 1px solid var(--line);
  }

  /* ── Cancellation reason ── */
  .cancel-reason {
    display: block;
    margin-top: var(--space-1, 4px);
    font-size: 11px;
    color: var(--fg-subtle, var(--ink-3));
    font-style: italic;
  }

  /* ── Confirm modal helpers ── */
  .btn.primary:disabled { opacity: 0.4; cursor: not-allowed; }

  /* ── Dish edit modal ── */
  .dish-edit-modal {
    background: var(--paper); border-radius: 12px; padding: 24px;
    width: 90%; max-width: 560px; max-height: 90vh; overflow-y: auto;
    box-shadow: 0 8px 30px rgba(0,0,0,0.12);
  }

  /* ── Allergen grid (inside edit modal) ── */
  .allergen-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2, 8px);
  }
  .allergen-grid-item {
    display: flex; align-items: center; gap: var(--space-2, 8px);
    cursor: pointer; font: 400 13px/1 var(--font-sans); color: var(--ink); padding: 2px 0;
  }
  .allergen-grid-item input[type="checkbox"] { accent-color: var(--oliva-500); }

  /* ── Allergen badges (in table row) ── */
  .allergen-badge {
    display: inline-flex; align-items: center;
    padding: 2px 6px; border-radius: var(--radius-sm, 4px);
    background: var(--paper-2); color: var(--fg-muted, var(--ink-2));
    font-size: 10px; font-weight: 600; letter-spacing: 0.04em; margin-right: 2px;
  }

  /* ── Tag badge ── */
  .tag-badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px; border-radius: var(--radius-full, 999px);
    background: var(--oliva-50); color: var(--oliva-700);
    font-size: 10px; font-weight: 500; letter-spacing: 0.04em;
    margin-left: var(--space-2, 8px);
  }

  /* ── Section head actions ── */
  .section-head {
    display: flex; align-items: center; gap: var(--space-3, 12px); margin-bottom: var(--space-4, 16px);
  }
  .section-head-actions {
    display: inline-flex; gap: var(--space-1, 4px);
    opacity: 0; transition: opacity var(--dur-2, 200ms) var(--ease-out);
  }
  .section-head:hover .section-head-actions { opacity: 1; }
  .section-action-btn {
    background: none; border: none; color: var(--fg-subtle, var(--ink-3));
    cursor: pointer; padding: var(--space-1, 4px); border-radius: var(--radius-sm, 4px); font-size: 16px;
  }
  .section-action-btn:hover { background: var(--paper-2); color: var(--fg, var(--ink)); }

  /* ── Section drag handle ── */
  .section-drag-handle {
    cursor: grab; color: var(--fg-subtle, var(--ink-3));
    opacity: 0; transition: opacity var(--dur-2, 200ms) var(--ease-out);
    padding: 4px; display: inline-flex; align-items: center; font-size: 18px;
  }
  .section-head:hover .section-drag-handle { opacity: 0.6; }
  .section-drag-handle:hover { opacity: 1 !important; }
  .section-drag-handle:active { cursor: grabbing; }
  .section-ghost { opacity: 0.4; background: var(--paper-2); border-radius: var(--radius-md, 8px); }

  /* ── Dish drag ── */
  .dish-ghost { opacity: 0.35; background: var(--paper-2); }
  .dish-dragging { cursor: grabbing; }
  .srv-table-row .col-grip { opacity: 0.3; transition: opacity var(--dur-2, 200ms) var(--ease-out); }
  .srv-table-row:hover .col-grip { opacity: 0.7; }
  .srv-table-row .col-grip:active { cursor: grabbing; }

  /* ── New section button ── */
  .new-section-btn {
    display: flex; align-items: center; gap: var(--space-2, 8px);
    padding: var(--space-4, 16px); margin-top: var(--space-6, 32px);
    border: 1px dashed var(--line); border-radius: var(--radius-md, 8px);
    background: transparent; color: var(--fg-subtle, var(--ink-3));
    font: 500 13px/1 var(--font-sans); cursor: pointer; width: 100%; justify-content: center;
  }
  .new-section-btn:hover { border-color: var(--accent, var(--vinya-500)); color: var(--accent, var(--vinya-500)); }
