  *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

  :root {
    /* === OPERATIONAL DESIGN SYSTEM (Phase 1) === */
    /* Brand */
    --primary:        #1C2E51;
    --accent:         #786F67;
    --page-bg:        #FAFAF7;
    --card-bg:        #FFFFFF;
    --border:         #E8E5DF;
    --text-primary:   #2C2B28;
    --text-secondary: #8A8780;
    --text-muted:     #B0ADA6;

    /* Semantic status */
    --green: #1D9E75;  --green-bg: #E1F5EE;
    --amber: #BA7517;  --amber-bg: #FAEEDA;
    --blue:  #185FA5;  --blue-bg:  #E6F1FB;
    --red:   #A32D2D;  --red-bg:   #FCEBEB;

    /* Operational chrome */
    --surface-sunken: #F4F1EB;
    --surface-hover:  #F0EDE6;
    --surface-active: #E8E5DF;

    /* === LEGACY ALIASES (to be retired in Phase 2) === */
    --cream:       var(--page-bg);
    --parchment:   var(--surface-sunken);
    --ink:         var(--text-primary);
    --ink-light:   var(--text-primary);
    --rust:        var(--primary);
    --rust-light:  var(--primary);
    --sage:        var(--green);
    --sage-light:  var(--green);
    --gold:        var(--accent);
    --gold-light:  var(--accent);
    --warm-gray:   var(--text-secondary);
    --overdue:     var(--red);
    --due-soon:    var(--amber);
    --due-mid:     var(--amber);
    --on-track:    var(--green);

    /* Restaurant pill colors — preserved for Phase 1, restyled in Phase 2 */
    --r0: #7B3F2E;
    --r1: #3A5C6B;
    --r2: #5C4A2E;
    --r3: #3B5241;
    --r4: #4A3A6B;
    --r5: #6B4A2E;
    --r6: #2E4A5C;
    --r7: #5C3A4A;
  }

  body {
    font-family: 'DM Sans', system-ui, sans-serif;
    background: var(--page-bg);
    color: var(--text-primary);
    min-height: 100vh;
    overflow-x: hidden;
    font-variant-numeric: tabular-nums;
    -webkit-font-smoothing: antialiased;
  }

  /* HEADER */
  header {
    background: var(--card-bg);
    color: var(--text-primary);
    padding: 12px 24px;
    display: flex;
    align-items: center;
    gap: 20px;
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 100;
  }
  .header-logos {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
  }
  .header-logos img {
    height: 32px;
    width: auto;
    object-fit: contain;
    opacity: 1;
  }
  .header-logos img:first-child {
    height: 38px;
  }
  .header-logos .logo-divider {
    width: 1px;
    height: 26px;
    background: var(--border);
  }
  header h1 {
    font-family: 'DM Sans', sans-serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: var(--text-primary);
  }
  header h1 em {
    font-style: normal;
    color: var(--text-secondary);
  }
  .header-sub {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--warm-gray);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-left: auto;
  }
  .header-actions { display: flex; gap: 12px; align-items: center; }
  .btn-primary {
    background: var(--primary);
    color: #fff;
    border: 1px solid var(--primary);
    min-height: 36px;
    padding: 0 18px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: none;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease, filter 120ms ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
  }
  .btn-primary:hover { filter: brightness(0.92); }
  .btn-primary:active { filter: brightness(0.84); transform: translateY(1px); }
  .btn-primary:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
  .btn-ghost {
    background: var(--card-bg);
    color: var(--text-primary);
    border: 1px solid var(--border);
    min-height: 36px;
    padding: 0 16px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    text-transform: none;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease, color 120ms ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
  }
  .btn-ghost:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .btn-ghost:active { background: var(--surface-active); transform: translateY(1px); }
  .btn-ghost:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }

  /* DASHBOARD SUMMARY */
  .summary-bar {
    background: var(--parchment);
    border-bottom: 1px solid var(--border);
    padding: 16px 40px;
    display: flex;
    gap: 32px;
    align-items: center;
    flex-wrap: wrap;
  }
  .summary-stat {
    display: flex;
    flex-direction: column;
    gap: 2px;
  }
  .summary-stat.clickable {
    cursor: pointer;
    padding: 4px 8px;
    margin: -4px -8px;
    border-radius: 0;
    transition: background 0.15s;
  }
  .summary-stat.clickable:hover {
    background: rgba(0,0,0,0.05);
  }
  .summary-stat .label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--warm-gray);
  }
  .summary-stat .value {
    font-family: 'DM Sans', sans-serif;
    font-size: 28px;
    font-weight: 600;
    line-height: 1;
  }
  .value.red { color: var(--red); }
  .value.orange { color: var(--amber); }
  .value.green { color: var(--green); }
  .divider { width: 1px; height: 36px; background: var(--border); }

  /* TABS */
  .tabs-container {
    background: var(--card-bg);
    border-bottom: 1px solid var(--border);
    position: relative;
  }
  .tabs-container::before,
  .tabs-container::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 40px;
    pointer-events: none;
    z-index: 2;
    opacity: 0;
    transition: opacity 0.2s;
  }
  .tabs-container::before {
    left: 0;
    background: linear-gradient(to right, var(--card-bg), transparent);
  }
  .tabs-container::after {
    right: 0;
    background: linear-gradient(to left, var(--card-bg), transparent);
  }
  .tabs-container.scroll-left::before { opacity: 1; }
  .tabs-container.scroll-right::after { opacity: 1; }
  .tabs-wrapper {
    background: var(--card-bg);
    display: flex;
    padding: 0 40px;
    gap: 0;
    overflow-x: auto;
    scrollbar-width: none;
  }
  .tabs-wrapper::-webkit-scrollbar { display: none; }
  .tabs-utility {
    background: var(--card-bg);
    display: flex;
    padding: 0 40px;
    gap: 0;
    border-top: 1px solid var(--border);
  }
  .tabs-utility .tab {
    padding: 0 16px;
    height: 38px;
    font-size: 12px;
  }
  .tab {
    padding: 0 18px;
    height: 42px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: none;
    color: var(--text-secondary);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    transition: background 120ms ease, color 120ms ease, border-color 120ms ease, transform 80ms ease;
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: none;
    border-top: none;
    border-left: none;
    border-right: none;
    font-variant-numeric: tabular-nums;
  }
  .tab:hover { color: var(--text-primary); background: var(--surface-hover); }
  .tab:active { background: var(--surface-active); transform: translateY(1px); }
  .tab.active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }
  .tab .badge {
    background: var(--surface-sunken);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 0;
    min-width: 18px;
    text-align: center;
    letter-spacing: 0.02em;
    font-variant-numeric: tabular-nums;
  }
  .tab.active .badge { background: var(--primary); color: #fff; }

  /* MAIN CONTENT */
  main { padding: 32px 40px; }

  /* FILTER BAR */
  .filter-bar-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
  }
  .filter-toggle {
    background: var(--card-bg);
    border: 1px solid var(--border);
    height: 36px;
    padding: 0 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--text-primary);
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
    display: inline-flex;
    align-items: center;
    gap: 6px;
  }
  .filter-toggle:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .filter-toggle:active { background: var(--surface-active); transform: translateY(1px); }
  .filter-toggle.active { border-color: var(--primary); color: var(--primary); background: var(--card-bg); }
  .filter-toggle .arrow { transition: transform 0.2s; display: inline-block; font-size: 10px; }
  .filter-toggle.active .arrow { transform: rotate(180deg); }
  .filter-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, margin 0.3s ease;
    margin-bottom: 0;
  }
  .filter-content.open {
    max-height: 200px;
    margin-bottom: 24px;
  }
  .filter-bar {
    display: flex;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
  }
  .filter-select {
    background: white;
    border: 1px solid var(--border);
    padding: 7px 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    color: var(--ink-light);
    letter-spacing: 0.06em;
    cursor: pointer;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238C8278' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 28px;
  }
  .filter-select:focus { border-color: var(--rust); }
  .filter-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--warm-gray);
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }
  .search-input {
    background: white;
    border: 1px solid var(--border);
    padding: 7px 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    color: var(--ink);
    outline: none;
    width: 200px;
  }
  .search-input:focus { border-color: var(--rust); }
  .search-input::placeholder { color: var(--warm-gray); }

  /* PROJECT TABLE */
  .projects-container { overflow-x: auto; }
  table {
    width: 100%;
    border-collapse: collapse;
    background: var(--card-bg);
    border: 1px solid var(--border);
    font-variant-numeric: tabular-nums;
  }
  thead tr {
    background: var(--surface-sunken);
  }
  thead th {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    padding: 10px 14px;
    text-align: left;
    white-space: nowrap;
    font-weight: 600;
    border-bottom: 1px solid var(--border);
  }
  tbody tr {
    border-bottom: 1px solid var(--border);
    transition: background 120ms ease;
    cursor: pointer;
  }
  tbody tr:last-child { border-bottom: none; }
  tbody tr:nth-child(even) { background: rgba(244, 241, 235, 0.5); }
  tbody tr:hover { background: var(--surface-hover); }
  tbody td {
    padding: 12px 14px;
    font-size: 14px;
    vertical-align: top;
    color: var(--text-primary);
  }
  .project-name {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 500;
    color: var(--text-primary);
    display: block;
    line-height: 1.35;
  }
  .project-desc {
    font-family: 'Source Serif 4', Georgia, serif;
    font-size: 13px;
    color: var(--text-secondary);
    margin-top: 3px;
    font-style: normal;
    max-width: 320px;
    line-height: 1.5;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  .category-tag {
    display: inline-block;
    padding: 2px 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    border: 1px solid var(--border);
    color: var(--text-secondary);
    background: var(--surface-sunken);
  }
  /* Per-category modifier classes retained as no-ops; the operational
     system uses neutral chips so categories are read by label, not color. */
  .category-tag.beverage,
  .category-tag.culinary,
  .category-tag.administrative,
  .category-tag.collateral,
  .category-tag.dining {
    color: var(--text-secondary);
    border-color: var(--border);
    background: var(--surface-sunken);
  }

  .owner-cell {
    font-size: 14px;
    color: var(--ink-light);
    white-space: nowrap;
  }
  .due-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    padding: 3px 8px;
    white-space: nowrap;
  }
  .due-badge.overdue { background: var(--red-bg); color: var(--red); font-weight: 600; }
  .due-badge.soon { background: var(--amber-bg); color: var(--amber); font-weight: 600; }
  .due-badge.mid { background: var(--surface-sunken); color: var(--text-secondary); font-weight: 600; }
  .due-badge.track { background: var(--green-bg); color: var(--green); font-weight: 600; }
  .due-badge::before {
    content: '●';
    font-size: 11px;
  }
  .priority-badge {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 2px 6px;
  }
  .priority-badge.high { background: var(--red-bg); color: var(--red); font-weight: 600; }
  .priority-badge.medium { background: var(--amber-bg); color: var(--amber); font-weight: 600; }
  .priority-badge.low { background: var(--surface-sunken); color: var(--text-secondary); font-weight: 600; }

  .complete-toggle {
    width: 18px; height: 18px;
    border: 2px solid var(--border);
    background: white;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.2s;
    flex-shrink: 0;
  }
  .complete-toggle.done { background: var(--sage); border-color: var(--sage); }
  .complete-toggle.done::after { content: '✓'; color: white; font-size: 12px; font-weight: bold; }

  .at-risk-flag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px; height: 18px;
    border: 1px solid var(--border);
    border-radius: 50%;
    background: white;
    color: var(--warm-gray);
    font-size: 10px;
    cursor: pointer;
    user-select: none;
    transition: all 0.15s;
    flex-shrink: 0;
  }
  .at-risk-flag:hover { border-color: var(--rust); color: var(--rust); }
  .at-risk-flag.on { background: var(--rust); border-color: var(--rust); color: #fff; }

  .update-preview {
    font-family: 'Source Serif 4', Georgia, serif;
    font-size: 13px;
    color: var(--text-secondary);
    max-width: 200px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    line-height: 1.5;
  }

  /* TOAST NOTIFICATIONS */
  .toast-container {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
  }
  .toast {
    background: var(--card-bg);
    color: var(--text-primary);
    border: 1px solid var(--border);
    padding: 10px 16px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    letter-spacing: 0.02em;
    border-left: 3px solid var(--green);
    box-shadow: 0 4px 16px rgba(44,43,40,0.1);
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.3s ease, transform 0.3s ease;
    pointer-events: auto;
  }
  .toast.show { opacity: 1; transform: translateY(0); }
  .toast.error { border-left-color: var(--red); }
  .toast.info { border-left-color: var(--gold); }

  /* EMPTY STATE */
  .empty-state {
    padding: 60px 40px;
    text-align: center;
    color: var(--warm-gray);
  }
  .empty-state h3 {
    font-family: 'DM Sans', sans-serif;
    font-size: 26px;
    font-weight: 300;
    margin-bottom: 8px;
    color: var(--ink-light);
  }
  .empty-state p { font-size: 15px; }

  /* MODAL */
  .modal-overlay {
    position: fixed; inset: 0;
    background: rgba(44,43,40,0.4);
    z-index: 200;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
  }
  .modal-overlay.open { display: flex; }
  /* Opening panel mode: right-side slide-out instead of centered overlay */
  .modal-overlay.opening-panel { background: none; pointer-events: none; align-items: stretch; justify-content: flex-end; padding: 0; }
  .modal-overlay.opening-panel .modal { pointer-events: auto; max-width: 460px; max-height: 100vh; height: 100vh; border-left: 1px solid var(--border); animation: slideInRight 0.3s ease; position: relative; transition: max-width 0.25s ease; }
  .modal-overlay.opening-panel.collapsed .modal { max-width: 0; overflow: hidden; }
  .opening-panel-toggle { pointer-events: auto; position: fixed; right: 460px; top: 50%; transform: translateY(-50%); width: 28px; height: 56px; background: var(--primary); color: #fff; border: none; border-radius: 0; cursor: pointer; display: none; align-items: center; justify-content: center; font-size: 14px; z-index: 201; transition: right 0.25s ease, filter 0.15s; }
  .opening-panel-toggle:hover { filter: brightness(0.92); }
  .modal-overlay.opening-panel.open .opening-panel-toggle { display: flex; }
  .modal-overlay.opening-panel.collapsed .opening-panel-toggle { right: 0; }
  @keyframes slideInRight { from { transform: translateX(100%); } to { transform: translateX(0); } }
  .modal {
    background: var(--card-bg);
    border: 1px solid var(--border);
    width: 100%;
    max-width: 680px;
    max-height: 90vh;
    overflow-y: auto;
  }
  .modal-header {
    background: var(--card-bg);
    color: var(--text-primary);
    border-bottom: 1px solid var(--border);
    padding: 16px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .modal-header h2 {
    font-family: 'DM Sans', sans-serif;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.02em;
  }
  .modal-header h2 em { color: var(--text-secondary); font-style: normal; font-weight: 400; }
  .modal-close {
    background: none; border: none;
    color: var(--text-secondary); font-size: 22px;
    cursor: pointer; padding: 4px 8px; line-height: 1;
    transition: color 120ms ease, background 120ms ease;
  }
  .modal-close:hover { color: var(--text-primary); background: var(--surface-hover); }
  .modal-body { padding: 24px; }
  .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
  .form-group { display: flex; flex-direction: column; gap: 6px; }
  .form-group.full { grid-column: 1 / -1; }
  .form-group label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
  }
  .form-group label span.required { color: var(--red); }
  .form-input, .form-select, .form-textarea {
    background: var(--card-bg);
    border: 1px solid var(--border);
    height: 36px;
    padding: 0 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    color: var(--text-primary);
    outline: none;
    transition: border-color 120ms ease, background 120ms ease;
    width: 100%;
    font-variant-numeric: tabular-nums;
  }
  .form-input:hover, .form-select:hover, .form-textarea:hover { border-color: var(--text-muted); }
  .form-input:focus, .form-select:focus, .form-textarea:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238A8780' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
    cursor: pointer;
  }
  .form-textarea { resize: vertical; min-height: 80px; height: auto; padding: 10px 12px; font-family: 'DM Sans', sans-serif; }
  .new-option-input {
    margin-top: 6px;
    display: none;
  }
  .note-entry { border: 1px solid var(--border); background: var(--card-bg); }
  .note-entry textarea {
    width: 100%; padding: 12px; border: none; outline: none;
    font-family: 'DM Sans', sans-serif; font-size: 14px;
    color: var(--text-primary); resize: none; min-height: 80px;
  }
  .note-entry-footer {
    padding: 8px 12px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .note-entry-footer span {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--warm-gray);
  }
  .notes-log { display: flex; flex-direction: column; gap: 12px; margin-top: 12px; }
  .note-item {
    border-left: 2px solid var(--border);
    padding: 8px 14px;
    position: relative;
    transition: border-color 0.2s;
  }
  .note-item:hover { border-left-color: var(--primary); }
  .note-item.is-pending { opacity: 0.6; }
  .note-item .note-date { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--text-secondary); margin-bottom: 4px; }
  .note-item .note-text { font-family: 'Source Serif 4', Georgia, serif; font-size: 14px; color: var(--text-primary); line-height: 1.55; }
  .note-pending-tag { font-size: 10px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-muted); margin-left: 4px; font-style: normal; }
  .note-actions {
    display: none;
    gap: 6px;
    margin-top: 8px;
  }
  .note-item:hover .note-actions { display: flex; }
  .note-action-btn {
    background: none;
    border: 1px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--warm-gray);
    padding: 3px 8px;
    cursor: pointer;
    transition: all 0.15s;
  }
  .note-action-btn:hover { border-color: var(--ink); color: var(--ink); }
  .note-action-btn.delete:hover { border-color: var(--red); color: var(--red); }
  .note-edit-area {
    display: none;
    margin-top: 8px;
    flex-direction: column;
    gap: 6px;
  }
  .note-edit-area.open { display: flex; }
  .note-edit-area textarea {
    width: 100%;
    border: 1px solid var(--border);
    padding: 8px 10px;
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    color: var(--text-primary);
    resize: none;
    min-height: 64px;
    outline: none;
    transition: border-color 120ms ease;
    line-height: 1.5;
  }
  .note-edit-area textarea:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .note-edit-actions { display: flex; gap: 6px; }
  .btn-note-save {
    background: var(--primary);
    color: #fff;
    border: 1px solid var(--primary);
    padding: 6px 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: filter 120ms ease, transform 80ms ease;
  }
  .btn-note-save:hover { filter: brightness(0.92); }
  .btn-note-save:active { filter: brightness(0.84); transform: translateY(1px); }
  .btn-note-cancel {
    background: var(--card-bg);
    border: 1px solid var(--border);
    padding: 6px 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--text-primary);
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
  }
  .btn-note-cancel:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .btn-note-cancel:active { background: var(--surface-active); transform: translateY(1px); }

  .modal-footer {
    padding: 12px 24px;
    display: flex;
    gap: 8px;
    justify-content: flex-end;
    border-top: 1px solid var(--border);
    background: var(--surface-sunken);
    margin-top: 0;
  }
  .btn-cancel {
    background: var(--card-bg);
    border: 1px solid var(--border);
    min-height: 36px;
    padding: 0 18px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    color: var(--text-primary);
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .btn-cancel:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .btn-cancel:active { background: var(--surface-active); transform: translateY(1px); }
  .section-divider {
    grid-column: 1 / -1;
    border: none;
    border-top: 1px solid var(--border);
    margin: 4px 0;
  }
  .section-label {
    grid-column: 1 / -1;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: -8px;
  }

  /* DETAIL PANEL */
  .detail-overlay {
    position: fixed; inset: 0;
    background: rgba(44,43,40,0.4);
    z-index: 200;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
  }
  .detail-overlay.open { opacity: 1; pointer-events: auto; }
  .detail-panel {
    position: fixed;
    top: 0; right: 0;
    width: 480px;
    height: 100vh;
    background: var(--card-bg);
    border-left: 1px solid var(--border);
    z-index: 201;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
  }
  .detail-panel.open { transform: translateX(0); }
  .detail-panel-header {
    background: var(--card-bg);
    color: var(--text-primary);
    border-bottom: 1px solid var(--border);
    padding: 16px 20px;
    flex-shrink: 0;
  }
  .detail-panel-header .restaurant-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 4px;
  }
  .detail-panel-header h3 {
    font-family: 'DM Sans', sans-serif;
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.005em;
    color: var(--text-primary);
    line-height: 1.3;
  }
  .detail-panel-header .meta {
    display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap;
  }
  .detail-body { flex: 1; overflow-y: auto; padding: 20px; }
  .detail-section { margin-bottom: 24px; }
  .detail-section-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
  }
  .detail-row {
    display: flex; justify-content: space-between;
    padding: 8px 0; font-size: 14px; border-bottom: 1px solid var(--border);
  }
  .detail-row:last-child { border-bottom: none; }
  .detail-row .key { color: var(--text-secondary); font-size: 13px; }
  .detail-row .val { color: var(--text-primary); font-weight: 500; text-align: right; max-width: 60%; font-variant-numeric: tabular-nums; }
  .detail-description { font-family: 'Source Serif 4', Georgia, serif; font-size: 14px; color: var(--text-secondary); line-height: 1.6; font-style: normal; }
  .detail-panel-footer { padding: 12px 20px; border-top: 1px solid var(--border); background: var(--surface-sunken); display: flex; flex-direction: column; align-items: center; gap: 8px; flex-shrink: 0; }
  .detail-panel-footer-row { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; }
  .btn-sm {
    padding: 6px 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    border: 1px solid var(--border);
    background: var(--card-bg);
    color: var(--text-primary);
    transition: background 120ms ease, border-color 120ms ease, color 120ms ease, transform 80ms ease;
  }
  .btn-sm:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .btn-sm:active { background: var(--surface-active); transform: translateY(1px); }
  .btn-sm.danger { color: var(--red); border-color: var(--red); }
  .btn-sm.danger:hover { background: var(--red); color: #fff; }
  .btn-sm.success { color: var(--green); border-color: var(--green); }
  .btn-sm.success:hover { background: var(--green); color: #fff; }

  /* ADD RESTAURANT MODAL */
  .restaurant-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
  .restaurant-chip {
    padding: 6px 14px;
    border: 1px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    letter-spacing: 0.08em;
    display: flex; align-items: center; gap: 8px;
    cursor: default;
    color: var(--ink-light);
  }
  .restaurant-chip .remove-chip {
    cursor: pointer; color: var(--warm-gray); font-size: 15px; line-height: 1; transition: color 0.2s;
  }
  .restaurant-chip .remove-chip:hover { color: var(--red); }

  /* PAGE INDICATOR */
  .page-header {
    display: flex; align-items: flex-start;
    justify-content: space-between; margin-bottom: 24px;
    flex-wrap: wrap; gap: 12px;
  }
  .page-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0;
    color: var(--text-primary);
  }
  .page-title span { color: var(--text-secondary); font-size: 16px; font-weight: 400; }

  .weeks-display {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--warm-gray);
    margin-top: 2px;
  }

  /* RESTAURANT COLOR PILLS */
  .restaurant-pill {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-primary);
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-left: 3px solid var(--text-secondary);
    white-space: nowrap;
    font-weight: 600;
    border-radius: 0;
  }
  .restaurant-pill[data-r="0"] { border-left-color: #7B3F2E; }
  .restaurant-pill[data-r="1"] { border-left-color: #3A5C6B; }
  .restaurant-pill[data-r="2"] { border-left-color: #5C4A2E; }
  .restaurant-pill[data-r="3"] { border-left-color: #3B5241; }
  .restaurant-pill[data-r="4"] { border-left-color: #4A3A6B; }
  .restaurant-pill[data-r="5"] { border-left-color: #6B4A2E; }
  .restaurant-pill[data-r="6"] { border-left-color: #2E4A5C; }
  .restaurant-pill[data-r="7"] { border-left-color: #5C3A4A; }

  /* FILTER BAR — operational */
  .filter-bar {
    background: var(--surface-sunken);
    border: 1px solid var(--border);
    padding: 12px 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  .filter-row {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
  }
  .filter-group {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .filter-group-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    white-space: nowrap;
  }
  .filter-select {
    height: 36px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    padding: 0 28px 0 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    color: var(--text-primary);
    letter-spacing: 0;
    cursor: pointer;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%238A8780' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    transition: border-color 120ms ease, background-color 120ms ease;
  }
  .filter-select:hover { border-color: var(--text-muted); }
  .filter-select:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .filter-select.active { border-color: var(--primary); color: var(--primary); }
  .search-input {
    height: 36px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    padding: 0 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    color: var(--text-primary);
    outline: none;
    width: 240px;
    transition: border-color 120ms ease, background-color 120ms ease;
  }
  .search-input:hover { border-color: var(--text-muted); }
  .search-input:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .search-input::placeholder { color: var(--text-muted); }

  /* DUE DATE TOGGLES — operational toggle group */
  .due-toggles {
    display: inline-flex;
    border: 1px solid var(--border);
    background: var(--card-bg);
    align-items: stretch;
  }
  .due-toggle {
    position: relative;
    border-right: 1px solid var(--border);
  }
  .due-toggle:last-child { border-right: none; }
  .due-toggle input[type="checkbox"] {
    position: absolute;
    opacity: 0; width: 0; height: 0;
  }
  .due-toggle label {
    display: inline-flex;
    align-items: center;
    height: 36px;
    padding: 0 14px;
    background: var(--card-bg);
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: background 120ms ease, color 120ms ease, transform 80ms ease;
    color: var(--text-primary);
    user-select: none;
    font-variant-numeric: tabular-nums;
  }
  .due-toggle label:hover { background: var(--surface-hover); }
  .due-toggle label:active { background: var(--surface-active); transform: translateY(1px); }
  .due-toggle input:checked + label {
    background: var(--primary);
    color: #fff;
  }

  .filter-clear {
    background: none;
    border: none;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 0 8px;
    height: 36px;
    transition: color 120ms ease, background 120ms ease;
  }
  .filter-clear:hover { color: var(--red); }

  .filter-clear[style*="display:none"] { display: none !important; }

  /* INLINE NOTE COMPOSER */
  .note-composer {
    border: 1px solid var(--border);
    background: white;
    transition: border-color 0.2s, box-shadow 0.2s;
    margin-top: 14px;
  }
  .note-composer:focus-within {
    border-color: var(--rust);
    box-shadow: 0 0 0 3px rgba(139,58,30,0.08);
  }
  .note-composer textarea {
    width: 100%;
    border: none;
    outline: none;
    padding: 12px 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 15px;
    color: var(--ink);
    resize: none;
    min-height: 72px;
    line-height: 1.55;
    background: transparent;
  }
  .note-composer textarea::placeholder { color: var(--warm-gray); font-style: italic; }
  .note-composer-footer {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-top: 1px solid var(--border);
    background: var(--parchment);
    flex-wrap: wrap;
  }
  .note-composer-footer select {
    flex: 1;
    border: 1px solid var(--border);
    background: white;
    padding: 5px 28px 5px 10px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--ink-light);
    letter-spacing: 0.06em;
    outline: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath fill='%238C8278' d='M0 0l4 5 4-5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    cursor: pointer;
    transition: border-color 0.2s;
  }
  .note-composer-footer select:focus { border-color: var(--rust); }
  .note-composer-footer input[type="text"] {
    flex: 1;
    border: 1px solid var(--border);
    background: white;
    padding: 5px 10px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--ink);
    outline: none;
    transition: border-color 0.2s;
  }
  .note-composer-footer input[type="text"]:focus { border-color: var(--rust); }
  .note-composer-footer .note-date-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    color: var(--warm-gray);
    letter-spacing: 0.1em;
    white-space: nowrap;
  }
  .btn-add-note {
    background: var(--rust);
    color: white;
    border: none;
    padding: 5px 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s;
    white-space: nowrap;
  }
  .btn-add-note:hover { background: var(--rust-light); }
  .btn-add-note:disabled { background: var(--border); color: var(--warm-gray); cursor: default; }
  .note-composer-new-name {
    display: none;
  }
  .note-composer-new-name.visible {
    display: flex;
    flex: 1;
  }

  /* ADMIN TAB */
  /* GANTT */
  .gantt-controls { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
  .gantt-window-btn { background: var(--card-bg); border: 1px solid var(--border); color: var(--text-primary); font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; height: 36px; padding: 0 14px; border-radius: 0; cursor: pointer; transition: background 120ms ease, border-color 120ms ease, transform 80ms ease; }
  .gantt-window-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .gantt-window-btn:active { background: var(--surface-active); transform: translateY(1px); }
  .gantt-window-btn.active { background: var(--primary); color: #fff; border-color: var(--primary); }
  .gantt-group-select { background: var(--card-bg); border: 1px solid var(--border); color: var(--text-primary); font-family: 'DM Sans', sans-serif; font-size: 13px; height: 36px; padding: 0 12px; border-radius: 0; cursor: pointer; transition: border-color 120ms ease; }
  .gantt-group-select:hover { border-color: var(--text-muted); }
  .gantt-group-select:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .gantt-show-complete { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-secondary); cursor: pointer; margin-left: auto; }
  .gantt-scroll-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 0; background: var(--card-bg); }
  .gantt-table { width: 100%; border-collapse: collapse; min-width: 700px; font-variant-numeric: tabular-nums; }
  .gantt-header-row th { background: var(--surface-sunken); color: var(--text-secondary); font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; padding: 10px 8px; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); white-space: nowrap; text-align: center; position: sticky; top: 0; z-index: 2; }
  .gantt-header-row th.label-col { text-align: left; min-width: 200px; max-width: 260px; position: sticky; left: 0; background: var(--surface-sunken); z-index: 3; }
  .gantt-group-row td { background: var(--surface-sunken); font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 600; color: var(--text-secondary); padding: 8px 12px; border-top: 1px solid var(--border); letter-spacing: 0.06em; text-transform: uppercase; }
  .gantt-row td { border-bottom: 1px solid var(--border); padding: 0; vertical-align: middle; }
  .gantt-row:hover td { background: var(--surface-hover); }
  .gantt-label-cell { min-width: 200px; max-width: 260px; padding: 9px 12px; font-size: 13px; color: var(--text-primary); line-height: 1.3; position: sticky; left: 0; background: var(--card-bg); z-index: 1; border-right: 1px solid var(--border); }
  .gantt-row:hover .gantt-label-cell { background: var(--surface-hover); }
  .gantt-label-cell.complete { color: var(--text-muted); text-decoration: line-through; opacity: 0.6; }
  .gantt-label-name { font-size: 13px; white-space: normal; word-break: break-word; max-width: 230px; line-height: 1.3; }
  .gantt-label-meta { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--warm-gray); margin-top: 2px; }
  .gantt-bar-cell { padding: 5px 0; position: relative; height: 42px; }
  .gantt-bar { height: 20px; border-radius: 0; position: absolute; top: 50%; transform: translateY(-50%); min-width: 6px; cursor: pointer; transition: opacity 0.15s; display: flex; align-items: center; padding: 0 7px; overflow: hidden; }
  .gantt-bar:hover { opacity: 0.8; }
  .gantt-bar-label { font-size: 10px; color: white; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-family: 'DM Sans', sans-serif; }
  .gantt-bar.complete { opacity: 0.35; }
  .gantt-bar.overdue { box-shadow: 0 0 0 2px var(--red); }
  .gantt-today-line { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--red); opacity: 0.85; pointer-events: none; z-index: 5; }
  .gantt-today-line::before {
    content: 'TODAY';
    position: absolute;
    top: 4px;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'DM Sans', sans-serif;
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.06em;
    color: #fff;
    background: var(--red);
    padding: 1px 5px;
    border-radius: 0;
    white-space: nowrap;
  }
  .gantt-day-cell { min-width: 28px; border-right: 1px solid var(--border); }
  .gantt-day-cell.today-col { background: var(--red-bg); border-left: 1px solid var(--red); border-right: 1px solid var(--red); }
  .gantt-day-cell.opening-target-col { background: var(--amber-bg); border-left: 1px solid var(--amber); border-right: 1px solid var(--amber); }
  .gantt-day-cell.weekend { background: rgba(0,0,0,0.015); }
  .gantt-no-date { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--warm-gray); padding: 9px 12px; text-align: center; }
  .gantt-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 16px; }
  .gantt-legend-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ink-light); }
  .gantt-legend-dot { width: 12px; height: 12px; border-radius: 0; flex-shrink: 0; }
  .gantt-mobile-notice { display: none; }

  /* ============================================================
     OPENINGS VIEW
     ============================================================ */
  .openings-view { padding: 32px 40px; }

  /* Opening selector cards */
  .opening-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; margin-top: 8px; }
  .opening-card { background: var(--card-bg); border: 1px solid var(--border); padding: 16px 20px; cursor: pointer; transition: background 120ms ease, border-color 120ms ease; }
  .opening-card:hover { border-color: var(--text-muted); background: var(--surface-hover); }
  .opening-card-name { font-family: 'DM Sans', sans-serif; font-size: 18px; font-weight: 600; letter-spacing: -0.005em; color: var(--text-primary); margin-bottom: 4px; }
  .opening-card-restaurant { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); margin-bottom: 12px; }
  .opening-card-date { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--text-secondary); margin-bottom: 12px; font-variant-numeric: tabular-nums; }
  .opening-card-progress-bar { height: 4px; background: var(--surface-sunken); border-radius: 0; overflow: hidden; }
  .opening-card-progress-fill { height: 100%; background: var(--green); border-radius: 0; transition: width 0.3s; }
  .opening-card-stats { display: flex; gap: 16px; margin-top: 8px; font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
  .opening-card-stats .stat-red { color: var(--red); }

  /* Opening detail header */
  .opening-back { background: none; border: none; font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 500; letter-spacing: 0.02em; color: var(--text-secondary); cursor: pointer; padding: 4px 0; margin-bottom: 12px; transition: color 120ms ease; display: inline-flex; align-items: center; gap: 6px; }
  .opening-back:hover { color: var(--primary); }
  .opening-header { margin-bottom: 16px; }
  .opening-header-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
  .opening-title { font-family: 'DM Sans', sans-serif; font-size: 22px; font-weight: 600; letter-spacing: -0.005em; color: var(--text-primary); }
  .opening-meta { display: flex; gap: 24px; margin-top: 8px; flex-wrap: wrap; }
  .opening-meta-item { font-family: 'DM Sans', sans-serif; font-size: 12px; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
  .opening-meta-item strong { color: var(--text-primary); font-weight: 600; }

  /* Opening summary bar */
  .opening-summary { background: var(--surface-sunken); border: 1px solid var(--border); padding: 12px 16px; display: flex; gap: 24px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }

  /* Sub-tabs within an opening */
  .opening-tabs-row { display: flex; align-items: flex-end; gap: 16px; margin-bottom: 16px; }
  .opening-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--border); flex: 1; }
  .opening-tab { padding: 0 16px; height: 38px; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 0.02em; color: var(--text-secondary); cursor: pointer; border: none; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: background 120ms ease, color 120ms ease, border-color 120ms ease; background: none; display: inline-flex; align-items: center; }
  .opening-tab:hover { color: var(--text-primary); background: var(--surface-hover); }
  .opening-tab.active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }
  .opening-search-wrap { position: relative; flex-shrink: 0; margin-bottom: 2px; }
  .opening-search { width: 220px; height: 36px; padding: 0 28px 0 12px; font-family: 'DM Sans', sans-serif; font-size: 13px; border: 1px solid var(--border); border-radius: 0; background: var(--card-bg); color: var(--text-primary); outline: none; transition: border-color 120ms ease; }
  .opening-search:hover { border-color: var(--text-muted); }
  .opening-search:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .opening-search::placeholder { color: var(--text-muted); }
  .opening-search-clear { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; font-size: 14px; color: var(--text-secondary); padding: 2px 4px; line-height: 1; }
  .opening-search-clear:hover { color: var(--text-primary); }

  /* This Week / Phases section headers */
  .opening-section { margin-bottom: 24px; }
  .opening-section-header { display: flex; align-items: center; gap: 12px; margin-bottom: 8px; }
  .opening-section-title { font-family: 'DM Sans', sans-serif; font-size: 16px; font-weight: 600; color: var(--text-primary); }
  .opening-section-count { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; color: var(--text-secondary); background: var(--surface-sunken); border: 1px solid var(--border); padding: 2px 8px; border-radius: 0; font-variant-numeric: tabular-nums; }
  .opening-section-title.overdue { color: var(--red); }

  /* Task rows (shared by This Week + Phases) */
  .opening-task-list { border: 1px solid var(--border); background: var(--card-bg); }
  .opening-task-row { display: flex; align-items: center; gap: 12px; padding: 10px 14px; border-bottom: 1px solid var(--border); cursor: pointer; transition: background 120ms ease; }
  .opening-task-row:last-child { border-bottom: none; }
  .opening-task-row:hover { background: var(--surface-hover); }
  .opening-task-row.done { opacity: 0.55; }
  .opening-task-info { flex: 1; min-width: 0; }
  .opening-task-title { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 500; color: var(--text-primary); line-height: 1.35; }
  .opening-task-meta { display: flex; gap: 8px; margin-top: 3px; align-items: center; flex-wrap: wrap; }
  .opening-task-category { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); }
  .opening-task-owner { font-size: 13px; color: var(--text-secondary); }
  .opening-task-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
  .opening-inline-select { font-family: 'DM Sans', sans-serif; font-size: 12px; padding: 4px 8px; border: 1px solid var(--border); border-radius: 0; background: var(--card-bg); color: var(--text-primary); cursor: pointer; max-width: 160px; appearance: auto; transition: border-color 120ms ease; }
  .opening-inline-select:hover { border-color: var(--text-muted); }
  .opening-inline-select:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .opening-inline-select.unassigned { color: var(--text-muted); font-style: normal; }
  .opening-subcat-bulk { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 500; padding: 2px 6px; border: 1px solid var(--border); border-radius: 0; background: var(--card-bg); color: var(--text-secondary); cursor: pointer; max-width: 130px; margin-left: 8px; transition: background 120ms ease, border-color 120ms ease, color 120ms ease; }
  .opening-subcat-bulk:hover { background: var(--surface-hover); border-color: var(--text-muted); color: var(--text-primary); }
  .opening-subcat-bulk:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }

  /* Phase accordion sections */
  .opening-phase { margin-bottom: 8px; border: 1px solid var(--border); background: var(--card-bg); }
  .opening-phase-header { display: flex; align-items: center; gap: 12px; padding: 12px 16px; cursor: pointer; transition: background 120ms ease; user-select: none; }
  .opening-phase-header:hover { background: var(--surface-hover); }
  .opening-phase-dot { width: 10px; height: 10px; border-radius: 0; flex-shrink: 0; }
  .opening-phase-name { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 600; color: var(--text-primary); flex: 1; position: relative; }
  .phase-info-icon { display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; border-radius: 0; background: var(--surface-sunken); border: 1px solid var(--border); font-family: 'DM Sans', sans-serif; font-size: 11px; font-style: normal; font-weight: 600; color: var(--text-secondary); cursor: pointer; margin-left: 6px; vertical-align: middle; transition: background 120ms ease, color 120ms ease, border-color 120ms ease; line-height: 1; }
  .phase-info-icon:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
  .phase-info-tooltip { display: none; position: absolute; top: calc(100% + 8px); left: 0; z-index: 100; background: var(--card-bg); border: 1px solid var(--border); border-radius: 0; padding: 12px 16px; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 400; line-height: 1.5; color: var(--text-primary); max-width: 480px; min-width: 300px; }
  .phase-info-tooltip.show { display: block; }
  .opening-phase-stats { display: flex; align-items: center; gap: 12px; }
  .opening-phase-progress { font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 500; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
  .opening-phase-progress-bar { width: 80px; height: 4px; background: var(--surface-sunken); border-radius: 0; overflow: hidden; }
  .opening-phase-progress-fill { height: 100%; border-radius: 0; transition: width 0.3s; }
  .opening-phase-arrow { color: var(--text-secondary); font-size: 12px; transition: transform 0.2s; }
  .opening-phase.open .opening-phase-arrow { transform: rotate(180deg); }
  .opening-phase-body { display: none; border-top: 1px solid var(--border); }
  .opening-phase.open .opening-phase-body { display: block; }
  .opening-subcat { border-bottom: 1px solid var(--border); }
  .opening-subcat-header { padding: 8px 16px; font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); background: var(--surface-sunken); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 8px; cursor: pointer; user-select: none; transition: background 120ms ease; }
  .opening-subcat-header:hover { background: var(--surface-hover); }
  .opening-subcat-count { font-size: 11px; font-weight: 600; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
  .opening-subcat-arrow { font-size: 9px; color: var(--text-secondary); margin-left: auto; transition: transform 0.2s; }
  .opening-subcat.open .opening-subcat-arrow { transform: rotate(180deg); }
  .opening-expand-btn { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 0.02em; background: var(--card-bg); border: 1px solid var(--border); color: var(--text-primary); padding: 6px 12px; border-radius: 0; cursor: pointer; transition: background 120ms ease, border-color 120ms ease, transform 80ms ease; }
  .opening-expand-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .opening-expand-btn:active { background: var(--surface-active); transform: translateY(1px); }
  .opening-date-edit { cursor: pointer; border-bottom: 1px dashed var(--text-muted); transition: color 120ms ease, border-color 120ms ease; }
  .opening-date-edit:hover { color: var(--primary); border-color: var(--primary); }
  .opening-subcat .opening-task-list { display: none; }
  .opening-subcat.open .opening-task-list { display: block; }

  /* By Owner view */
  .opening-owner-group { margin-bottom: 12px; background: var(--card-bg); border: 1px solid var(--border); border-radius: 0; overflow: hidden; }
  .opening-owner-header { padding: 12px 16px; display: flex; align-items: center; gap: 12px; cursor: pointer; user-select: none; transition: background 120ms ease; }
  .opening-owner-header:hover { background: var(--surface-hover); }
  .opening-owner-name { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 600; color: var(--text-primary); }
  .opening-owner-stats { display: flex; gap: 12px; margin-left: auto; align-items: center; font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; color: var(--text-secondary); font-variant-numeric: tabular-nums; }
  .opening-owner-stat { display: flex; align-items: center; gap: 4px; }
  .opening-owner-stat .red { color: var(--red); font-weight: 600; }
  .opening-owner-stat .green { color: var(--green); font-weight: 600; }
  .opening-owner-arrow { font-size: 10px; color: var(--text-secondary); transition: transform 0.2s; }
  .opening-owner-group.open .opening-owner-arrow { transform: rotate(180deg); }
  .opening-owner-body { display: none; border-top: 1px solid var(--border); }
  .opening-owner-group.open .opening-owner-body { display: block; }

  /* Opening Gantt */
  .opening-gantt-legend { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 16px; }
  .opening-gantt-legend-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-secondary); }
  .opening-gantt-legend-dot { width: 12px; height: 12px; border-radius: 0; flex-shrink: 0; }
  .opening-gantt-milestone { position: absolute; top: 0; bottom: 0; width: 2px; background: var(--amber); z-index: 4; pointer-events: none; }
  .opening-gantt-milestone::before { content: 'OPENING DAY'; position: absolute; top: -18px; left: 4px; font-family: 'DM Sans', sans-serif; font-size: 9px; font-weight: 600; letter-spacing: 0.06em; color: var(--amber); white-space: nowrap; }

  /* No tasks empty state */
  .opening-empty { padding: 32px; text-align: center; color: var(--text-secondary); font-size: 14px; }
  .opening-empty strong { display: block; font-family: 'DM Sans', sans-serif; font-size: 16px; color: var(--text-primary); margin-bottom: 4px; font-weight: 600; }

  /* Opening Notes tab */
  .opening-notes-wrap { max-width: 720px; }
  .opening-notes-input { margin-bottom: 24px; }
  .opening-note-textarea { width: 100%; font-family: 'DM Sans', sans-serif; font-size: 14px; line-height: 1.5; padding: 12px; border: 1px solid var(--border); background: var(--card-bg); color: var(--text-primary); resize: vertical; box-sizing: border-box; transition: border-color 120ms ease; }
  .opening-note-textarea:hover { border-color: var(--text-muted); }
  .opening-note-textarea:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .opening-notes-input-actions { display: flex; justify-content: flex-end; margin-top: 8px; }
  .opening-notes-list { display: flex; flex-direction: column; gap: 8px; }
  .opening-notes-list.archived { padding: 16px; }
  .opening-note-card { background: var(--card-bg); border: 1px solid var(--border); padding: 12px 16px; }
  .opening-note-card.archived { opacity: 0.6; }
  .opening-note-timestamp { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-secondary); margin-bottom: 6px; font-variant-numeric: tabular-nums; }
  .opening-note-content { font-family: 'Source Serif 4', Georgia, serif; font-size: 14px; line-height: 1.6; color: var(--text-primary); margin-bottom: 10px; }
  .opening-note-actions { display: flex; gap: 6px; }
  .opening-note-btn { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 500; letter-spacing: 0.02em; padding: 4px 10px; border: 1px solid var(--border); background: var(--card-bg); color: var(--text-primary); cursor: pointer; transition: background 120ms ease, border-color 120ms ease, color 120ms ease; }
  .opening-note-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .opening-note-btn.danger { color: var(--red); border-color: var(--red); }
  .opening-note-btn.danger:hover { background: var(--red); color: #fff; }
  .opening-note-btn.primary { color: var(--primary); border-color: var(--primary); }
  .opening-note-btn.primary:hover { background: var(--primary); color: #fff; }

  .admin-view { display: none; padding: 32px 40px; }
  .admin-view.active { display: block; }
  .projects-view { display: block; }
  .projects-view.hidden { display: none; }

  .admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
    margin-bottom: 40px;
  }
  .admin-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
  }
  .admin-card-header {
    background: var(--surface-sunken);
    color: var(--text-primary);
    border-bottom: 1px solid var(--border);
    padding: 12px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .admin-card-header h3 {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
  }
  .admin-card-header .card-count {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    color: var(--text-secondary);
    font-variant-numeric: tabular-nums;
  }
  .admin-card-body { padding: 12px 16px; }
  .admin-list { list-style: none; display: flex; flex-direction: column; gap: 2px; margin-bottom: 12px; }
  .admin-list-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    border: 1px solid transparent;
    transition: border-color 120ms ease, background 120ms ease;
  }
  .admin-list-item:hover { border-color: var(--border); background: var(--surface-hover); }
  .admin-list-item .item-label {
    flex: 1;
    font-size: 14px;
    color: var(--text-primary);
    outline: none;
    background: transparent;
    border: none;
    font-family: 'DM Sans', sans-serif;
    cursor: default;
  }
  .admin-list-item .item-label.editing {
    background: var(--card-bg);
    border: 1px solid var(--primary);
    padding: 2px 6px;
    cursor: text;
  }
  .admin-item-actions {
    display: none;
    gap: 4px;
    flex-shrink: 0;
  }
  .admin-list-item:hover .admin-item-actions { display: flex; }
  .admin-list-item.editing .item-label { display: none; }
  .admin-list-item.editing .admin-item-actions { display: none !important; }
  .admin-save-row {
    display: none;
    gap: 4px;
    flex: 1;
    align-items: center;
  }
  .admin-list-item.editing .admin-save-row { display: flex; }
  .admin-item-btn {
    background: var(--card-bg);
    border: 1px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: var(--text-primary);
    padding: 4px 8px;
    cursor: pointer;
    transition: background 120ms ease, border-color 120ms ease, color 120ms ease, transform 80ms ease;
    line-height: 1.6;
  }
  .admin-item-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .admin-item-btn:active { background: var(--surface-active); transform: translateY(1px); }
  .admin-item-btn.del:hover { border-color: var(--red); color: var(--red); background: var(--red-bg); }
  .admin-item-btn.save { border-color: var(--green); color: var(--green); }
  .admin-item-btn.save:hover { background: var(--green); color: #fff; }
  .admin-add-row {
    display: flex;
    gap: 8px;
  }
  .admin-add-input {
    flex: 1;
    border: 1px solid var(--border);
    height: 36px;
    padding: 0 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    color: var(--text-primary);
    background: var(--card-bg);
    outline: none;
    transition: border-color 120ms ease;
  }
  .admin-add-input:hover { border-color: var(--text-muted); }
  .admin-add-input:focus { outline: 2px solid var(--primary); outline-offset: -1px; border-color: var(--primary); }
  .admin-add-input::placeholder { color: var(--text-muted); font-style: normal; }
  .admin-add-btn {
    background: var(--primary);
    color: #fff;
    border: 1px solid var(--primary);
    height: 36px;
    padding: 0 16px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    transition: filter 120ms ease, transform 80ms ease;
    white-space: nowrap;
  }
  .admin-add-btn:hover { filter: brightness(0.92); }
  .admin-add-btn:active { filter: brightness(0.84); transform: translateY(1px); }

  .admin-section-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 22px;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 4px;
  }
  .admin-section-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
    margin-bottom: 24px;
  }
  .admin-divider {
    border: none;
    border-top: 1px solid var(--border);
    margin: 32px 0;
  }
  .admin-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
    margin-bottom: 32px;
  }
  .admin-stat-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    padding: 12px 16px;
  }
  .admin-stat-card .stat-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    margin-bottom: 4px;
  }
  .admin-stat-card .stat-value {
    font-family: 'DM Sans', sans-serif;
    font-size: 28px;
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: -0.01em;
    color: var(--primary);
    font-variant-numeric: tabular-nums;
  }
  .admin-stat-card .stat-sub {
    font-size: 12px;
    color: var(--text-secondary);
    margin-top: 4px;
  }
  .admin-restaurant-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
  }
  .admin-restaurant-row:last-child { border-bottom: none; }
  .admin-restaurant-color {
    width: 10px; height: 10px; border-radius: 0; flex-shrink: 0;
  }
  .admin-restaurant-name { flex: 1; font-size: 15px; color: var(--ink-light); }
  .admin-restaurant-count {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--warm-gray);
  }
  .admin-restaurant-actions { display: flex; gap: 4px; }
  .danger-zone {
    border: 1px solid var(--red);
    padding: 16px 20px;
    background: var(--red-bg);
  }
  .danger-zone h4 {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--red);
    margin-bottom: 8px;
  }
  .danger-zone p { font-size: 13px; color: var(--text-primary); margin-bottom: 12px; line-height: 1.5; }
  .btn-danger {
    background: transparent;
    border: 1px solid var(--red);
    color: var(--red);
    padding: 8px 16px;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.2s;
  }
  .btn-danger:hover { background: var(--red); color: white; }




  /* ============================================================
     OVERDUE BADGE
     ============================================================ */
  .overdue-badge { display: inline-flex; align-items: center; background: var(--red-bg); color: var(--red); border: 1px solid var(--red); font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 600; border-radius: 0; padding: 3px 10px; letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; cursor: pointer; transition: background 120ms ease, color 120ms ease; }
  .overdue-badge:hover { background: var(--red); color: #fff; }

  /* ============================================================
     PRINT / PDF REPORT
     ============================================================ */
  #print-view { position: absolute; left: -9999px; top: 0; width: 800px; visibility: hidden; }
  @media print {
    body > *:not(#print-view) { display: none !important; }
    #print-view { display: block !important; position: static !important; left: auto !important; top: auto !important; width: auto !important; visibility: visible !important; font-family: 'DM Sans', Georgia, serif; color: #1a1612; font-size: 12pt; line-height: 1.5; padding: 0; margin: 0; }
    .pr-header { display: flex; align-items: center; justify-content: space-between; border-bottom: 3px solid #8b3a1e; padding-bottom: 14pt; margin-bottom: 10pt; }
    .pr-header-left { display: flex; align-items: center; gap: 8pt; }
    .pr-header-left h1 { font-size: 14pt; font-weight: 700; margin: 0; line-height: 1.2; color: #1a1612; }
    .pr-header-left p { font-size: 9pt; color: #6b6055; margin: 2pt 0 0; }
    .pr-header-logos { display: flex; align-items: center; gap: 10pt; }
    .pr-header-logos img { height: 36pt; object-fit: contain; }
    .pr-header-logos .pr-logo-divider { width: 1px; height: 28pt; background: #d4cbb8; }
    .pr-summary-bar { display: flex; gap: 0; margin-bottom: 20pt; border: 1px solid #d4cbb8; border-radius: 0; overflow: hidden; }
    .pr-summary-stat { flex: 1; text-align: center; padding: 10pt 6pt; border-right: 1px solid #d4cbb8; }
    .pr-summary-stat:last-child { border-right: none; }
    .pr-summary-stat .pr-stat-value { font-size: 18pt; font-weight: 700; color: #1a1612; display: block; line-height: 1.2; }
    .pr-summary-stat .pr-stat-label { font-size: 7pt; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #6b6055; }
    .pr-summary-stat.pr-stat-green .pr-stat-value { color: #4a7c59; }
    .pr-summary-stat.pr-stat-rust .pr-stat-value { color: #8b3a1e; }
    .pr-summary-stat.pr-stat-blue .pr-stat-value { color: #4a7c9e; }
    /* Force real table layout — the global mobile-cards rules below try to
       turn every table into a stacked block at narrow widths, which breaks
       print rendering on small windows. Override explicitly. */
    .pr-table { display: table !important; width: 100%; border-collapse: collapse; font-size: 10pt; margin-top: 4pt; }
    .pr-table thead { display: table-header-group !important; }
    .pr-table tbody { display: table-row-group !important; gap: 0 !important; }
    .pr-table tr { display: table-row !important; background: transparent !important; border: none !important; padding: 0 !important; grid-template-columns: none !important; }
    .pr-table th, .pr-table td { display: table-cell !important; }
    .pr-table th { text-align: left; font-size: 8pt; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: #6b6055; border-bottom: 1.5pt solid #1a1612; padding: 4pt 8pt; background: #f7f4ef; }
    .pr-table td { padding: 6pt 8pt; border-bottom: 1px solid #ede8df; vertical-align: top; }
    .pr-table tr:last-child td { border-bottom: none; }
    .pr-table tbody tr:nth-child(even) td { background: #fafaf7; }
    .pr-pri-high { display: inline-block; background: #8b3a1e; color: #fff; font-size: 7pt; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 1pt 5pt; border-radius: 0; }
    .pr-pri-medium { display: inline-block; background: #c9a84c; color: #fff; font-size: 7pt; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 1pt 5pt; border-radius: 0; }
    .pr-pri-low { display: inline-block; background: #a09585; color: #fff; font-size: 7pt; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 1pt 5pt; border-radius: 0; }
    .pr-overdue { color: #8b3a1e; font-weight: 600; }
    .pr-due-soon { color: #c9a84c; font-weight: 600; }
    .pr-complete { color: #4a7c59; }
    .pr-status-badge { display: inline-block; font-size: 7pt; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; padding: 1pt 5pt; border-radius: 0; }
    .pr-status-active { background: rgba(74,124,158,0.12); color: #4a7c9e; }
    .pr-status-new { background: rgba(74,124,89,0.12); color: #4a7c59; }
    .pr-page-break { page-break-before: always; padding-top: 8pt; }
    .pr-footer { border-top: 2px solid #8b3a1e; padding-top: 8pt; margin-top: 20pt; font-size: 8pt; color: #a09585; display: flex; justify-content: space-between; }
    .pr-restaurant-section { margin-bottom: 0; }
    .pr-restaurant-header { font-size: 14pt; font-weight: 700; color: #1a1612; border-bottom: 2px solid #8b3a1e; padding-bottom: 6pt; margin-bottom: 16pt; }
    .pr-subsection { margin-bottom: 20pt; page-break-inside: avoid; }
    .pr-subsection-title { font-size: 11pt; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #1a1612; margin: 0 0 8pt; padding-bottom: 4pt; border-bottom: 2pt solid #8b3a1e; }
    .pr-no-activity { font-size: 10pt; color: #a09585; font-style: italic; margin: 4pt 0 0; }
    .pr-notes-block { background: #f7f4ef; border-left: 4pt solid #8b3a1e; padding: 12pt 16pt; margin-bottom: 20pt; white-space: pre-wrap; font-size: 11pt; line-height: 1.6; color: #1a1612; }
    .pr-notes-label { font-size: 8pt; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: #6b6055; margin-bottom: 4pt; }
    .pr-section-title { font-size: 12pt; font-weight: 700; color: #1a1612; border-bottom: 2px solid #8b3a1e; padding-bottom: 6pt; margin: 20pt 0 12pt; }
    .pr-update-group { margin-bottom: 12pt; page-break-inside: avoid; }
    .pr-update-task-name { font-size: 10pt; font-weight: 700; color: #1a1612; margin-bottom: 4pt; }
    .pr-update-note { font-size: 10pt; color: #3a3530; margin: 2pt 0 2pt 12pt; }
    .pr-update-note-date { font-size: 9pt; color: #6b6055; font-weight: 600; }
    .pr-progress-bar-track { width: 100%; height: 8pt; background: #ede8df; border-radius: 0; overflow: hidden; margin-top: 4pt; }
    .pr-progress-bar-fill { height: 100%; background: #4a7c59; border-radius: 0; }
    /* Weekly Report v2 safety hook — not currently emitted, available for future renderers */
    .pr-section-break { page-break-before: always; }
  }
  /* ============================================================
     LOGIN SCREEN
     ============================================================ */
  #login-screen { display: none; position: fixed; inset: 0; background: var(--cream); z-index: 9999; align-items: center; justify-content: center; padding: 24px; }
  .login-card { background: white; border: 1px solid var(--border); border-radius: 0; padding: 40px; width: 100%; max-width: 400px; box-shadow: 0 8px 32px rgba(0,0,0,0.08); }
  .login-logo-wrap { text-align: center; margin-bottom: 24px; }
  .login-logo-wrap img { height: 48px; }
  .login-title { font-family: 'Cinzel', serif; font-size: 22px; font-weight: 400; letter-spacing: 0.04em; color: var(--ink); text-align: center; margin: 0 0 4px; }
  .login-sub { font-family: 'EB Garamond', serif; font-style: italic; font-size: 14px; color: var(--warm-gray); text-align: center; margin: 0 0 28px; }
  .login-form { display: flex; flex-direction: column; gap: 16px; }
  .login-label { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 500; color: var(--ink-light); letter-spacing: 0.06em; text-transform: uppercase; display: block; margin-bottom: 6px; }
  .login-select, .login-input { width: 100%; }
  .login-error { background: var(--red-bg); border: 1px solid var(--red); color: var(--red); border-radius: 0; padding: 10px 12px; font-size: 13px; }
  .login-btn { width: 100%; padding: 12px; font-size: 14px; justify-content: center; margin-top: 4px; }
  /* ============================================================
     SUBTASKS
     ============================================================ */
  .subtask-badge { display: inline-block; font-family: 'DM Sans', sans-serif; font-size: 10px; background: var(--parchment); border: 1px solid var(--border); color: var(--ink-light); border-radius: 0; padding: 1px 8px; margin-top: 4px; }
  .subtask-badge.all-done { background: rgba(74,124,89,0.12); border-color: rgba(74,124,89,0.3); color: #3a7a52; }
  .subtask-item { display: flex; align-items: flex-start; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); }
  .subtask-item:last-child { border-bottom: none; }
  .subtask-check { width: 16px; height: 16px; border: 2px solid var(--border); border-radius: 0; flex-shrink: 0; cursor: pointer; margin-top: 2px; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
  .subtask-check.done { background: var(--sage); border-color: var(--sage); }
  .subtask-check.done::after { content: '✓'; color: white; font-size: 10px; font-weight: 700; }
  .subtask-body { flex: 1; min-width: 0; }
  .subtask-name { font-size: 13px; color: var(--ink); line-height: 1.3; }
  .subtask-name.done { text-decoration: line-through; color: var(--warm-gray); }
  .subtask-desc { font-size: 11px; color: var(--warm-gray); margin-top: 2px; }
  .subtask-meta { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--warm-gray); margin-top: 3px; }
  .subtask-actions { display: flex; gap: 6px; opacity: 0; transition: opacity 0.15s; }
  .subtask-item:hover .subtask-actions { opacity: 1; }
  .subtask-action-btn { font-size: 11px; color: var(--warm-gray); background: none; border: none; cursor: pointer; padding: 0; font-family: 'DM Sans', sans-serif; }
  .subtask-action-btn:hover { color: var(--rust); }
  .subtask-add-btn { margin-top: 10px; font-size: 12px; color: var(--rust); background: none; border: 1px dashed var(--border); border-radius: 0; padding: 6px 12px; cursor: pointer; width: 100%; text-align: center; transition: all 0.15s; font-family: 'DM Sans', sans-serif; }
  .subtask-add-btn:hover { border-color: var(--rust); background: rgba(139,58,30,0.04); }
  .subtask-form { background: var(--parchment); border: 1px solid var(--border); border-radius: 0; padding: 12px; margin-top: 10px; display: flex; flex-direction: column; gap: 8px; }
  .subtask-form .form-input, .subtask-form .form-textarea, .subtask-form .form-select { font-size: 12px; padding: 6px 8px; }
  .subtask-form .form-textarea { min-height: 48px; resize: vertical; }
  .subtask-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
  .subtask-form-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 4px; }
  .subtask-form-actions .btn-primary { font-size: 12px; padding: 6px 14px; }
  .subtask-form-actions .btn-cancel { font-size: 12px; padding: 6px 14px; }
  .subtask-rollup-toast { background: rgba(74,124,89,0.12); border: 1px solid rgba(74,124,89,0.3); color: #2d6b42; border-radius: 0; padding: 8px 12px; font-size: 12px; margin-bottom: 10px; display: none; }
  .complex-toggle-row { display: flex; align-items: center; padding: 4px 0 8px; }
  .complex-toggle-row label { display: flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; color: var(--ink); }
  .complex-toggle-row input[type=checkbox] { width: 15px; height: 15px; cursor: pointer; accent-color: var(--rust); }
  .complex-toggle-hint { font-size: 11px; color: var(--warm-gray); font-style: italic; margin-left: 4px; }

  /* ============================================================
     SORTABLE COLUMN HEADERS
     ============================================================ */
  .sortable-th { cursor: pointer; user-select: none; white-space: nowrap; }
  .sortable-th:hover { background: rgba(255,255,255,0.08); }
  .sort-icon { font-size: 10px; opacity: 0.8; }

  /* ============================================================
     RESTAURANT CARD VIEW
     ============================================================ */
  #restaurant-cards { padding: 0 40px 40px; }
  .rc-section-label { font-family: 'DM Sans', sans-serif; font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--warm-gray); margin: 24px 0 12px; }
  .rc-section-done { opacity: 0.6; }
  .rc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
  .rc-card { background: white; border: 1px solid var(--border); border-radius: 0; padding: 18px; cursor: pointer; transition: box-shadow 0.15s, transform 0.15s; }
  .rc-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.08); transform: translateY(-1px); }
  .rc-card-done { opacity: 0.55; }
  .rc-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
  .rc-badge { font-family: 'DM Sans', sans-serif; font-size: 10px; border-radius: 0; padding: 2px 8px; font-weight: 500; }
  .rc-badge.rc-overdue { background: var(--red-bg); color: var(--red); }
  .rc-badge.rc-soon { background: rgba(210,140,40,0.12); color: #a07020; }
  .rc-badge.rc-upcoming { background: var(--parchment); color: var(--ink-light); border: 1px solid var(--border); }
  .rc-badge.rc-complete { background: rgba(74,124,89,0.12); color: #3a7a52; }
  .rc-badge.rc-pri-high { background: var(--red-bg); color: var(--red); }
  .rc-badge.rc-pri-medium { background: var(--parchment); color: var(--ink-light); border: 1px solid var(--border); }
  .rc-badge.rc-pri-low { background: var(--parchment); color: var(--warm-gray); }
  .rc-subtasks { font-family: 'DM Sans', sans-serif; font-size: 10px; color: var(--warm-gray); background: var(--parchment); border-radius: 0; padding: 2px 8px; }
  .rc-title { font-size: 15px; font-weight: 600; color: var(--ink); margin-bottom: 4px; line-height: 1.3; }
  .rc-desc { font-size: 12px; color: var(--ink-light); margin-bottom: 8px; line-height: 1.4; }
  .rc-owner { font-size: 12px; color: var(--warm-gray); margin-top: 8px; }
  .rc-note { font-size: 11px; color: var(--warm-gray); margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border); line-height: 1.4; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  /* ============================================================
     MOBILE NAV DRAWER
     ============================================================ */
  .mobile-menu-btn {
    display: none;
    background: var(--card-bg);
    border: 1px solid var(--border);
    color: var(--text-primary);
    width: 44px;
    height: 44px;
    border-radius: 0;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: background 120ms ease, border-color 120ms ease;
  }
  .mobile-menu-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .mobile-menu-btn svg { width: 20px; height: 20px; }

  .mobile-nav-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(44,43,40,0.4);
    z-index: 999;
    opacity: 0;
    transition: opacity 0.25s;
  }
  .mobile-nav-overlay.open { opacity: 1; }

  .mobile-nav-drawer {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    background: var(--card-bg);
    border-left: 1px solid var(--border);
    z-index: 1000;
    transform: translateX(100%);
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .mobile-nav-drawer.open { transform: translateX(0); }

  .mobile-nav-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
  }
  .mobile-nav-header span {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
  }
  .mobile-nav-close {
    background: none;
    border: none;
    color: var(--text-secondary);
    width: 44px;
    height: 44px;
    cursor: pointer;
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 120ms ease, background 120ms ease;
  }
  .mobile-nav-close:hover { color: var(--text-primary); background: var(--surface-hover); }

  .mobile-nav-section {
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
  }
  .mobile-nav-section-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
    padding: 4px 16px 8px;
  }
  .mobile-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 12px 16px;
    min-height: 44px;
    background: none;
    border: none;
    color: var(--text-primary);
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    text-align: left;
    transition: background 120ms ease, color 120ms ease;
  }
  .mobile-nav-item:hover,
  .mobile-nav-item:active { background: var(--surface-hover); }
  .mobile-nav-item.active { color: var(--primary); background: var(--surface-sunken); font-weight: 600; }
  .mobile-nav-item .badge {
    background: var(--surface-sunken);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 0;
    min-width: 18px;
    text-align: center;
    margin-left: auto;
    font-variant-numeric: tabular-nums;
  }
  .mobile-nav-item.active .badge { background: var(--primary); color: #fff; }

  /* ============================================================
     MOBILE RESPONSIVE
     ============================================================ */
  @media (max-width: 768px) {

    /* HAMBURGER VISIBLE */
    .mobile-menu-btn { display: flex; }

    /* HEADER — slimmed down */
    header { padding: 10px 16px; flex-wrap: nowrap; gap: 10px; }
    .header-logos img { height: 24px; }
    .header-logos img:first-child { height: 30px; }
    .header-logos .logo-divider { display: none; }
    .header-logos img:nth-child(3) { display: none; }
    header h1 { font-size: 18px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
    .header-sub { display: none; }
    .header-actions { margin-left: auto; gap: 6px; flex-shrink: 0; }
    /* Hide text buttons in header; keep + New Task and hamburger */
    #btn-add-restaurant, #btn-print-report, #btn-export-tasks { display: none; }
    .header-actions .btn-ghost[onclick*="logout"] { display: none; }
    .btn-primary, .btn-ghost { min-height: 44px; min-width: 44px; padding: 8px 14px; font-size: 11px; }

    /* HIDE DESKTOP TABS — replaced by mobile nav drawer */
    .tabs-container { display: none; }

    /* SUMMARY BAR */
    .summary-bar { padding: 12px 16px; gap: 12px; }
    .summary-stat .value { font-size: 22px; }
    .divider { display: none; }

    /* MAIN */
    main { padding: 16px; }

    /* FILTER BAR */
    .filter-bar { flex-direction: column; align-items: stretch; gap: 8px; }
    .filter-row { flex-direction: column; align-items: stretch; gap: 8px; }
    .filter-group { width: 100%; }
    .filter-group-label { min-width: 70px; }
    .search-input { width: 100%; min-height: 44px; font-size: 16px; }
    .filter-select { width: 100%; min-height: 44px; font-size: 16px; }
    .filter-toggle { min-height: 44px; }

    /* TABLE → MOBILE CARD LAYOUT */
    .projects-container { overflow-x: visible; }
    table { display: block; width: 100%; }
    thead { display: none; }
    tbody { display: flex; flex-direction: column; gap: 10px; }
    tbody tr {
      display: grid;
      grid-template-columns: auto 1fr;
      gap: 4px 10px;
      background: white;
      border: 1px solid var(--border);
      border-radius: 0;
      padding: 14px 16px;
      border-bottom: none;
    }
    tbody tr:nth-child(even) { background: white; }
    tbody tr:hover { background: rgba(196,154,60,0.06); }

    /* All cells reset */
    tbody td { padding: 0; font-size: 14px; }

    /* Row 1: checkbox + project title */
    tbody td:first-child {
      grid-row: 1;
      grid-column: 1;
      align-self: start;
      padding-top: 2px;
    }
    /* Project name cell — spans right column, rows 1-2 */
    tbody td:nth-child(2) {
      grid-row: 1 / 3;
      grid-column: 2;
      min-width: 0;
    }
    /* When restaurant column is shown, it takes nth-child(2) and pushes project to nth-child(3) */
    tbody td:nth-child(3) {
      grid-column: 1 / -1;
      min-width: 0;
    }

    /* Show project description on mobile cards */
    .project-name { font-size: 16px; }
    .project-desc { display: block; font-size: 12px; margin-top: 2px; }

    /* Metadata row — all badges on one wrapping line */
    tbody td:nth-child(4),
    tbody td:nth-child(5),
    tbody td:nth-child(6),
    tbody td:nth-child(7),
    tbody td:nth-child(8) {
      grid-column: 1 / -1;
    }
    /* Owner cell: show inline, smaller */
    tbody td:nth-child(5) { display: block; }
    .owner-cell { font-size: 13px; color: var(--warm-gray); }
    /* Hide latest update on cards — too long */
    tbody td:nth-child(8) { display: none; }

    /* DETAIL PANEL → BOTTOM SHEET */
    .detail-panel {
      width: 100% !important;
      max-width: 100% !important;
      height: auto !important;
      max-height: 92vh;
      top: auto !important;
      bottom: 0;
      left: 0;
      right: 0;
      border-radius: 0;
      transform: translateY(100%);
      box-shadow: 0 -8px 32px rgba(0,0,0,0.25);
    }
    .detail-panel.open { transform: translateY(0); }
    .detail-panel-header { padding: 20px 20px 16px; position: relative; }
    .detail-panel-header::before {
      content: '';
      display: block;
      width: 36px;
      height: 4px;
      background: rgba(255,255,255,0.3);
      border-radius: 0;
      margin: 0 auto 12px;
    }
    .detail-body { padding: 20px; }

    /* MODALS → BOTTOM SHEET STYLE */
    .modal {
      width: 100% !important;
      max-width: 100% !important;
      max-height: 92vh;
      overflow-y: auto;
      border-radius: 0;
      margin: 0;
    }
    .modal-overlay { padding: 0; align-items: flex-end; }
    .modal-body { padding: 16px; }
    .modal-header { padding: 16px; position: relative; }
    .modal-header::before {
      content: '';
      display: block;
      width: 36px;
      height: 4px;
      background: var(--border);
      border-radius: 0;
      margin: 0 auto 12px;
    }
    .form-grid { grid-template-columns: 1fr !important; }
    .modal .btn-primary, .modal .btn-ghost { width: 100%; }

    /* ADMIN */
    .admin-view { padding: 16px; }
    .admin-grid { grid-template-columns: 1fr; }
    .admin-stats-grid { grid-template-columns: 1fr 1fr; }

    #restaurant-cards { padding: 0 16px 24px; }
    .rc-grid { grid-template-columns: 1fr; }

    /* GANTT — improved mobile scroll UX */
    .gantt-controls { gap: 8px; flex-wrap: wrap; }
    .gantt-controls > * { flex-shrink: 0; }
    .gantt-window-btn { padding: 8px 12px; font-size: 11px; min-height: 44px; }
    .gantt-group-select { min-height: 44px; font-size: 14px; }
    .gantt-show-complete { margin-left: 0; width: 100%; justify-content: flex-start; min-height: 44px; }
    .gantt-scroll-wrap {
      -webkit-overflow-scrolling: touch;
      scroll-snap-type: x proximity;
      overscroll-behavior-x: contain;
    }
    .gantt-label-cell { min-width: 140px; max-width: 160px; font-size: 12px; }
    .gantt-label-name { max-width: 140px; font-size: 12px; }
    .gantt-header-row th.label-col { min-width: 140px; max-width: 160px; }
    .gantt-mobile-notice { display: block; background: #fff8e7; border: 1px solid #e8d9a0; border-radius: 0; padding: 10px 14px; font-size: 13px; color: #7a6a3a; margin-bottom: 16px; }

    /* RECENT VIEW */
    #recent-view { padding: 16px !important; }

    /* TOUCH TARGETS — ensure 44px minimums */
    .tab { min-height: 44px; padding: 10px 14px; font-size: 11px; }
    .inbox-submit-btn { min-height: 44px; }
    .btn-ghost, .btn-primary { min-height: 44px; }
  }

  @media (max-width: 480px) {
    header h1 { font-size: 16px; }
    .header-logos { gap: 8px; }
    .header-logos img { height: 20px; }
    .header-logos img:first-child { height: 26px; }
    .summary-stat .value { font-size: 20px; }
    tbody tr { padding: 12px 12px; }
    .project-name { font-size: 15px; }
    .project-desc { font-size: 11px; }
  }

  /* ============================================================
     ANALYTICS VIEW
     ============================================================ */
  .analytics-view { display: none; padding: 32px 40px; }
  .analytics-section-title { font-family: 'DM Sans', sans-serif; font-size: 28px; font-weight: 300; color: var(--ink); margin: 0 0 4px; }
  .analytics-section-subtitle { font-size: 13px; color: var(--warm-gray); letter-spacing: 0.06em; margin-bottom: 28px; }
  .analytics-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 32px; }
  .analytics-stat-card { background: white; border: 1px solid var(--border); border-radius: 0; padding: 20px 16px; text-align: center; }
  .analytics-stat-value { font-family: 'DM Sans', sans-serif; font-size: 40px; font-weight: 600; color: var(--ink); line-height: 1; }
  .analytics-stat-value.danger { color: var(--red); }
  .analytics-stat-value.success { color: #4a7c59; }
  .analytics-stat-label { font-size: 11px; color: var(--warm-gray); letter-spacing: 0.08em; text-transform: uppercase; margin-top: 6px; }
  .analytics-charts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
  .analytics-chart-card { background: white; border: 1px solid var(--border); border-radius: 0; padding: 24px; }
  .analytics-chart-title { font-size: 12px; font-weight: 600; color: var(--ink-light); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 16px; }
  @media (max-width: 900px) {
    .analytics-stats-grid { grid-template-columns: 1fr 1fr; }
    .analytics-charts-grid { grid-template-columns: 1fr; }
    .analytics-view { padding: 16px; }
  }
  @media (max-width: 480px) {
    .analytics-stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
    .analytics-stat-card { padding: 14px 10px; }
    .analytics-stat-value { font-size: 32px; }
    .analytics-stat-label { font-size: 10px; }
    .analytics-chart-card { padding: 16px 12px; }
    .analytics-section-title { font-size: 22px; }
  }

  /* ============================================================
     TRAVEL CALENDAR
     ============================================================ */
  .travel-view { display: none; padding: 32px 40px; }
  .travel-view.active { display: block; }

  /* Travel header */
  .travel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 12px;
  }
  .travel-header-left { display: flex; align-items: center; gap: 16px; }
  .travel-month-nav {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  .travel-month-nav h2 {
    font-family: 'DM Sans', sans-serif;
    font-size: 28px;
    font-weight: 300;
    min-width: 220px;
    text-align: center;
    color: var(--ink);
  }
  .travel-nav-btn {
    background: var(--card-bg);
    border: 1px solid var(--border);
    color: var(--text-primary);
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
    flex-shrink: 0;
  }
  .travel-nav-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .travel-nav-btn:active { background: var(--surface-active); transform: translateY(1px); }
  .travel-header-actions { display: flex; align-items: center; gap: 8px; }
  .travel-view-toggle {
    display: inline-flex;
    border: 1px solid var(--border);
    background: var(--card-bg);
    overflow: hidden;
  }
  .travel-view-btn {
    background: var(--card-bg);
    border: none;
    height: 36px;
    padding: 0 14px;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.02em;
    cursor: pointer;
    color: var(--text-primary);
    transition: background 120ms ease, color 120ms ease, transform 80ms ease;
    border-right: 1px solid var(--border);
  }
  .travel-view-btn:last-child { border-right: none; }
  .travel-view-btn.active { background: var(--primary); color: #fff; }
  .travel-view-btn:not(.active):hover { background: var(--surface-hover); }
  .travel-view-btn:not(.active):active { background: var(--surface-active); transform: translateY(1px); }
  .travel-people-btn {
    background: var(--card-bg);
    border: 1px solid var(--border);
    color: var(--text-primary);
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    transition: background 120ms ease, border-color 120ms ease, transform 80ms ease;
  }
  .travel-people-btn:hover { background: var(--surface-hover); border-color: var(--text-muted); }
  .travel-people-btn:active { background: var(--surface-active); transform: translateY(1px); }

  /* Quarterly visit tracking widget */
  .quarterly-widget {
    background: white;
    border: 1px solid var(--border);
    border-radius: 0;
    margin-bottom: 24px;
    overflow: hidden;
  }
  .qv-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    cursor: pointer;
    background: var(--parchment);
    border-bottom: 1px solid var(--border);
    user-select: none;
  }
  .qv-header h3 {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
    margin: 0;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }
  .qv-toggle { font-size: 11px; color: var(--warm-gray); }
  .qv-body { padding: 16px 20px; }
  .qv-table {
    width: 100%;
    border-collapse: collapse;
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
  }
  .qv-table th {
    text-align: left;
    padding: 8px 12px;
    border-bottom: 2px solid var(--border);
    color: var(--warm-gray);
    font-weight: 500;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .qv-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    color: var(--ink);
  }
  .qv-table tr:last-child td { border-bottom: none; }
  .qv-restaurant { font-weight: 600; }
  .qv-metric { white-space: nowrap; }
  .qv-value {
    font-family: 'DM Sans', sans-serif;
    font-weight: 600;
    font-size: 15px;
    margin-right: 4px;
  }
  .qv-up { color: var(--on-track); font-size: 11px; margin-left: 6px; }
  .qv-down { color: var(--overdue); font-size: 11px; margin-left: 6px; }
  .qv-flat { color: var(--warm-gray); font-size: 11px; margin-left: 6px; }
  .qv-last-visit { color: var(--ink-light); }
  .qv-days-since { color: var(--warm-gray); font-size: 11px; }
  .qv-note {
    margin-top: 12px;
    font-size: 11px;
    color: var(--warm-gray);
    text-align: right;
    font-style: italic;
  }

  /* Restaurant context card */
  .trip-context-card {
    background: var(--parchment);
    border: 1px solid var(--border);
    border-radius: 0;
    padding: 16px 20px;
    margin-bottom: 20px;
  }
  .trip-context-title {
    font-weight: 600;
    font-size: 14px;
    color: var(--ink);
    margin-bottom: 12px;
  }
  .trip-context-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
  }
  .trip-context-stat { text-align: center; }
  .trip-context-value {
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: var(--ink);
  }
  .trip-context-value.danger { color: var(--overdue); }
  .trip-context-label {
    font-size: 11px;
    color: var(--warm-gray);
    margin-top: 2px;
  }

  /* Agenda blocks */
  .agenda-blocks-list { display: flex; flex-direction: column; gap: 12px; }
  .ab-date-group { }
  .ab-date-header {
    font-weight: 600;
    font-size: 12px;
    color: var(--warm-gray);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 8px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--border);
  }
  .agenda-block-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    background: white;
    border: 1px solid var(--border);
    border-radius: 0;
    margin-bottom: 6px;
  }
  .agenda-block-item.done { opacity: 0.55; }
  .ab-check {
    width: 18px;
    height: 18px;
    border-radius: 0;
    border: 2px solid var(--border);
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 2px;
    transition: all 0.15s;
  }
  .ab-check.done { background: var(--sage); border-color: var(--sage); }
  .ab-check:hover { border-color: var(--sage); }
  .ab-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
  .ab-body { flex: 1; min-width: 0; }
  .ab-title { font-weight: 600; font-size: 14px; color: var(--ink); }
  .ab-title.done { text-decoration: line-through; color: var(--warm-gray); }
  .ab-meta { font-size: 12px; color: var(--warm-gray); margin-top: 2px; display: flex; gap: 8px; align-items: center; }
  .ab-time { font-family: 'DM Sans', sans-serif; font-size: 11px; }
  .ab-type-badge {
    background: var(--parchment);
    padding: 1px 6px;
    border-radius: 0;
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--ink-light);
  }
  .ab-notes { font-size: 12px; color: var(--ink-light); margin-top: 4px; line-height: 1.5; }
  .ab-linked-task { font-size: 11px; color: var(--sage); margin-top: 4px; font-style: italic; }
  .ab-actions { display: flex; gap: 4px; flex-shrink: 0; }
  .ab-template-row {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
  }

  /* Pre-trip checklist */
  .checklist-list { display: flex; flex-direction: column; gap: 6px; }
  .checklist-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: white;
    border: 1px solid var(--border);
    border-radius: 0;
  }
  .checklist-body { flex: 1; min-width: 0; }
  .checklist-title { font-weight: 600; font-size: 13px; color: var(--ink); }
  .checklist-meta { display: flex; gap: 8px; margin-top: 4px; flex-wrap: wrap; }
  .checklist-cat, .checklist-owner {
    font-size: 11px;
    background: var(--parchment);
    padding: 1px 6px;
    border-radius: 0;
    color: var(--ink-light);
  }
  .checklist-due { font-size: 11px; color: var(--warm-gray); }
  .checklist-due.overdue { color: var(--overdue); font-weight: 600; }
  .checklist-actions { flex-shrink: 0; }
  .checklist-add-btn {
    font-size: 11px !important;
    padding: 4px 10px !important;
    white-space: nowrap;
  }
  .checklist-on-agenda {
    font-size: 11px;
    color: var(--sage);
    font-weight: 600;
    white-space: nowrap;
  }

  /* Recap modal styles */
  .recap-header-card {
    background: var(--parchment);
    border: 1px solid var(--border);
    border-radius: 0;
    padding: 16px 20px;
    margin-bottom: 20px;
  }
  .recap-header-title { font-family: 'DM Sans', sans-serif; font-size: 22px; font-weight: 400; color: var(--ink); margin-bottom: 8px; }
  .recap-header-meta { font-size: 13px; color: var(--ink-light); line-height: 1.6; }
  .recap-header-meta strong { color: var(--ink); }

  .recap-section { margin-bottom: 20px; }
  .recap-section-title {
    font-weight: 600;
    font-size: 13px;
    color: var(--ink);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 10px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
  }

  .recap-obs-tabs { display: flex; gap: 0; margin-bottom: 12px; border-bottom: 2px solid var(--border); }
  .recap-obs-tab {
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    border: none;
    background: none;
    color: var(--warm-gray);
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all 0.15s;
  }
  .recap-obs-tab.active { color: var(--rust); border-bottom-color: var(--rust); }
  .recap-obs-tab:hover { color: var(--ink); }

  .recap-obs-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px;
    background: white;
    border: 1px solid var(--border);
    border-radius: 0;
    margin-bottom: 6px;
  }
  .recap-obs-text { flex: 1; font-size: 14px; line-height: 1.5; color: var(--ink); }
  .recap-obs-text.converted { text-decoration: line-through; color: var(--warm-gray); }
  .recap-obs-actions { display: flex; gap: 4px; flex-shrink: 0; }

  .recap-action-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: white;
    border: 1px solid var(--border);
    border-radius: 0;
    margin-bottom: 4px;
    font-size: 13px;
  }
  .recap-action-title { flex: 1; font-weight: 500; color: var(--ink); }
  .recap-action-meta { font-size: 11px; color: var(--warm-gray); }

  .recap-status-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 0;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .recap-status-badge.draft { background: #FFF3CD; color: #856404; }
  .recap-status-badge.final { background: #D4EDDA; color: #155724; }

  /* Recap history list */
  .recap-history-list { display: flex; flex-direction: column; gap: 8px; }
  .recap-history-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: white;
    border: 1px solid var(--border);
    border-radius: 0;
    cursor: pointer;
    transition: border-color 0.15s;
  }
  .recap-history-item:hover { border-color: var(--rust); }
  .recap-history-info { flex: 1; }
  .recap-history-title { font-weight: 600; font-size: 14px; color: var(--ink); }
  .recap-history-meta { font-size: 12px; color: var(--warm-gray); margin-top: 2px; }

  /* Calendar grid */
  .travel-calendar-grid {
    background: white;
    border: 1px solid var(--border);
    overflow: hidden;
  }
  .travel-cal-days-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--surface-sunken);
    border-bottom: 1px solid var(--border);
  }
  .travel-cal-day-label {
    padding: 8px 0;
    text-align: center;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-secondary);
  }
  .travel-cal-body {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
  }
  .travel-cal-cell {
    min-height: 120px;
    border-right: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 6px 4px 4px;
    vertical-align: top;
    position: relative;
    background: white;
  }
  .travel-cal-cell:nth-child(7n) { border-right: none; }
  .travel-cal-cell.other-month { background: #faf8f5; }
  .travel-cal-cell.today { background: rgba(196,154,60,0.05); }
  .travel-cal-date-num {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--warm-gray);
    margin-bottom: 4px;
    padding-left: 2px;
    line-height: 1;
  }
  .travel-cal-cell.today .travel-cal-date-num {
    color: var(--rust);
    font-weight: 700;
  }
  .travel-cal-cell.other-month .travel-cal-date-num { opacity: 0.4; }

  /* Trip bars */
  .trip-bar {
    display: flex;
    align-items: center;
    height: 22px;
    margin-bottom: 2px;
    padding: 0 6px;
    cursor: pointer;
    overflow: hidden;
    border-radius: 0;
    transition: opacity 0.15s;
    position: relative;
  }
  .trip-bar:hover { opacity: 0.85; }
  .trip-bar-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    color: white;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 500;
    letter-spacing: 0.04em;
  }
  .trip-bar-initials {
    font-family: 'DM Sans', sans-serif;
    font-size: 9px;
    color: rgba(255,255,255,0.85);
    flex-shrink: 0;
    margin-left: 4px;
  }
  /* First day of trip: left-rounded */
  .trip-bar.trip-start { border-radius: 0; }
  /* Last day of trip: right-rounded */
  .trip-bar.trip-end   { border-radius: 0; }
  /* Both start and end */
  .trip-bar.trip-start.trip-end { border-radius: 0; }
  /* Mid days: no rounding */
  .trip-bar.trip-mid   { border-radius: 0; }

  /* List view */
  .travel-list { display: flex; flex-direction: column; gap: 12px; }
  .trip-card {
    background: white;
    border: 1px solid var(--border);
    padding: 18px 20px;
    cursor: pointer;
    transition: box-shadow 0.15s, border-color 0.15s;
    display: flex;
    gap: 16px;
    align-items: flex-start;
  }
  .trip-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.07); border-color: var(--ink-light); }
  .trip-card.trip-past { opacity: 0.55; }
  .trip-card-travelers { display: flex; flex-direction: column; gap: 3px; flex-shrink: 0; padding-top: 2px; }
  .trip-traveler-dot {
    width: 10px;
    height: 10px;
    border-radius: 0;
    flex-shrink: 0;
  }
  .trip-card-body { flex: 1; min-width: 0; }
  .trip-card-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 20px;
    font-weight: 300;
    color: var(--ink);
    line-height: 1.2;
    margin-bottom: 4px;
  }
  .trip-card-dest {
    font-size: 14px;
    color: var(--warm-gray);
    margin-bottom: 6px;
  }
  .trip-card-meta {
    display: flex;
    gap: 14px;
    align-items: center;
    flex-wrap: wrap;
  }
  .trip-card-dates {
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    color: var(--ink-light);
    letter-spacing: 0.04em;
  }
  .trip-card-restaurant {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    color: var(--rust);
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .trip-card-traveler-pills { display: flex; gap: 4px; flex-wrap: wrap; }
  .trip-traveler-pill {
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    padding: 2px 7px;
    border-radius: 0;
    color: white;
    font-weight: 500;
    letter-spacing: 0.04em;
  }

  /* Trip detail modal (wide) */
  .trip-modal .modal { max-width: 780px; }
  .trip-modal-body { padding: 0; }
  .trip-modal-section {
    padding: 24px 32px;
    border-bottom: 1px solid var(--border);
  }
  .trip-modal-section:last-child { border-bottom: none; }
  .trip-modal-section-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--warm-gray);
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border);
  }
  .traveler-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 8px;
  }
  .traveler-checkbox-row {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    padding: 6px 10px;
    border: 1px solid transparent;
    transition: border-color 0.15s, background 0.15s;
    user-select: none;
  }
  .traveler-checkbox-row:hover { border-color: var(--border); background: var(--parchment); }
  .traveler-checkbox-row.selected { border-color: var(--border); background: var(--parchment); }
  .traveler-color-swatch {
    width: 14px;
    height: 14px;
    border-radius: 0;
    flex-shrink: 0;
  }
  .traveler-checkbox-row input[type="checkbox"] {
    width: 15px;
    height: 15px;
    accent-color: var(--rust);
    cursor: pointer;
    flex-shrink: 0;
  }
  .traveler-checkbox-label { font-size: 15px; color: var(--ink); }

  /* Itinerary */
  .itinerary-list { display: flex; flex-direction: column; gap: 0; }
  .itinerary-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
  }
  .itinerary-item:last-child { border-bottom: none; }
  .itinerary-item-check {
    width: 16px;
    height: 16px;
    border: 2px solid var(--border);
    border-radius: 0;
    flex-shrink: 0;
    cursor: pointer;
    margin-top: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
  }
  .itinerary-item-check.done { background: var(--sage); border-color: var(--sage); }
  .itinerary-item-check.done::after { content: '✓'; color: white; font-size: 10px; font-weight: 700; }
  .itinerary-item-type { font-size: 16px; flex-shrink: 0; line-height: 1.2; }
  .itinerary-item-body { flex: 1; min-width: 0; }
  .itinerary-item-title {
    font-size: 15px;
    color: var(--ink);
    line-height: 1.3;
    font-weight: 500;
  }
  .itinerary-item-title.done { text-decoration: line-through; color: var(--warm-gray); font-weight: 400; }
  .itinerary-item-meta {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    color: var(--warm-gray);
    margin-top: 2px;
  }
  .itinerary-item-desc {
    font-size: 13px;
    color: var(--ink-light);
    margin-top: 3px;
    line-height: 1.4;
    font-style: italic;
  }
  .itinerary-item-project {
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    color: var(--rust);
    margin-top: 2px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
  .itinerary-item-actions {
    display: none;
    gap: 4px;
    flex-shrink: 0;
  }
  .itinerary-item:hover .itinerary-item-actions { display: flex; }
  .itin-action-btn {
    background: none;
    border: 1px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: 10px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--warm-gray);
    padding: 2px 7px;
    cursor: pointer;
    transition: all 0.15s;
    line-height: 1.6;
  }
  .itin-action-btn:hover { border-color: var(--ink); color: var(--ink); }
  .itin-action-btn.del:hover { border-color: var(--red); color: var(--red); }

  /* Itinerary add form */
  .itin-add-form {
    background: var(--parchment);
    border: 1px solid var(--border);
    padding: 16px;
    margin-top: 12px;
    display: none;
  }
  .itin-add-form.open { display: block; }
  .itin-add-form .form-grid { grid-template-columns: 1fr 1fr; }
  .itin-form-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 12px; }

  /* People manager modal */
  .people-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
  .people-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    border: 1px solid var(--border);
    background: white;
    transition: border-color 0.15s;
  }
  .people-item:hover { border-color: var(--ink-light); }
  .people-color-dot {
    width: 14px;
    height: 14px;
    border-radius: 0;
    flex-shrink: 0;
  }
  .people-initials-badge {
    width: 32px;
    height: 32px;
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    color: white;
    font-weight: 500;
    flex-shrink: 0;
    letter-spacing: 0.04em;
  }
  .people-name { flex: 1; font-size: 15px; color: var(--ink); }
  .people-active-toggle {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    color: var(--warm-gray);
    cursor: pointer;
    border: 1px solid var(--border);
    padding: 2px 8px;
    transition: all 0.15s;
  }
  .people-active-toggle:hover { border-color: var(--ink); color: var(--ink); }
  .people-active-toggle.active { border-color: var(--sage); color: var(--sage); }
  .people-delete-btn {
    background: none;
    border: 1px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--warm-gray);
    padding: 2px 7px;
    cursor: pointer;
    transition: all 0.15s;
    line-height: 1.6;
  }
  .people-delete-btn:hover { border-color: var(--red); color: var(--red); }
  .people-section-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--ink-light);
    margin-bottom: 10px;
    font-weight: 600;
  }
  .people-unlinked {
    border-style: dashed;
    background: var(--parchment);
  }

  /* Color picker palette */
  .color-palette {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-top: 6px;
  }
  .color-swatch-btn {
    width: 28px;
    height: 28px;
    border-radius: 0;
    border: 3px solid transparent;
    cursor: pointer;
    transition: border-color 0.15s, transform 0.1s;
  }
  .color-swatch-btn:hover { transform: scale(1.1); }
  .color-swatch-btn.selected { border-color: var(--ink); }

  @media (max-width: 768px) {
    .travel-view { padding: 16px; }
    .travel-header { flex-direction: column; align-items: stretch; gap: 12px; }
    .travel-header-left { justify-content: center; }
    .travel-month-nav h2 { font-size: 22px; min-width: 180px; }
    .travel-nav-btn { width: 44px; height: 44px; }
    .travel-header-actions { justify-content: center; }
    .travel-view-btn { min-height: 44px; padding: 10px 14px; }
    .travel-people-btn { width: 44px; height: 44px; }
    /* Compact calendar cells */
    .travel-cal-cell { min-height: 56px; padding: 4px 2px 2px; }
    .travel-cal-date-num { font-size: 10px; }
    .travel-cal-day-label { font-size: 9px; padding: 6px 0; }
    /* Trip bars — smaller on mobile */
    .trip-bar { height: 18px; padding: 0 3px; margin-bottom: 1px; }
    .trip-bar-label { font-size: 8px; }
    .trip-bar-initials { display: none; }
    .trip-modal .modal { max-width: 100%; }
  }

  /* ============================================================
     INBOX FEATURE
     ============================================================ */
  .inbox-view { padding: 32px 40px; max-width: 820px; }
  .inbox-section { margin-bottom: 36px; }
  .inbox-section-title { font-family: 'DM Sans', sans-serif; font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--warm-gray); margin-bottom: 14px; }
  .inbox-form-card { background: white; border: 1px solid var(--border); border-radius: 0; padding: 24px; margin-bottom: 0; }
  .inbox-submit-btn { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 0.02em; background: var(--primary); color: #fff; border: 1px solid var(--primary); height: 36px; padding: 0 18px; border-radius: 0; cursor: pointer; margin-top: 4px; transition: filter 120ms ease, transform 80ms ease; }
  .inbox-submit-btn:hover { filter: brightness(0.92); }
  .inbox-submit-btn:active { filter: brightness(0.84); transform: translateY(1px); }
  .inbox-submit-btn:hover { opacity: 0.85; }
  .inbox-item { background: white; border: 1px solid var(--border); border-radius: 0; padding: 14px 18px; margin-bottom: 8px; display: flex; align-items: flex-start; gap: 14px; }
  .inbox-item-body { flex: 1; min-width: 0; }
  .inbox-item-title { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
  .inbox-item-meta { font-family: 'DM Sans', sans-serif; font-size: 11px; color: var(--warm-gray); letter-spacing: 0.03em; margin-top: 4px; }
  .inbox-item-desc { font-size: 13px; color: #6b6055; margin-top: 4px; line-height: 1.5; }
  .inbox-item-actions { display: flex; gap: 8px; flex-shrink: 0; align-items: flex-start; padding-top: 2px; }
  .inbox-status { font-family: 'DM Sans', sans-serif; font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 9px; border-radius: 0; font-weight: 600; white-space: nowrap; flex-shrink: 0; }
  .inbox-status.submitted { background: #e5e0db; color: #6b6055; }
  .inbox-status.added    { background: #d1ead8; color: #2d6a3f; }
  .inbox-status.agenda   { background: #dbeafe; color: #1e40af; }
  .inbox-status.archived { background: #e5e0db; color: #6b6055; }
  .inbox-action-btn { font-family: 'DM Sans', sans-serif; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; padding: 5px 12px; border-radius: 0; cursor: pointer; border: 1px solid var(--border); background: white; color: var(--ink); white-space: nowrap; }
  .inbox-action-btn:hover { background: var(--parchment); }
  .inbox-action-btn.primary { background: var(--primary); color: #fff; border-color: var(--primary); }
  .inbox-action-btn.primary:hover { filter: brightness(0.92); }
  .inbox-action-btn.primary:hover { opacity: 0.85; }
  .inbox-action-btn.danger { color: var(--red); border-color: var(--red); background: white; }
  .inbox-action-btn.danger:hover { background: var(--red); color: white; }
  .inbox-empty { font-family: 'DM Sans', sans-serif; font-size: 13px; color: var(--warm-gray); padding: 20px; text-align: center; background: var(--parchment); border-radius: 0; border: 1px dashed var(--border); }
  .inbox-category-pill { font-family: 'DM Sans', sans-serif; font-size: 10px; letter-spacing: 0.05em; text-transform: uppercase; background: var(--parchment); border: 1px solid var(--border); color: var(--warm-gray); padding: 1px 7px; border-radius: 0; white-space: nowrap; }

  /* INBOX MOBILE */
  @media (max-width: 768px) {
    .inbox-view { padding: 16px; }
    .inbox-form-card { padding: 16px; }
    .inbox-item { padding: 14px; gap: 10px; flex-wrap: wrap; }
    .inbox-item-actions { width: 100%; justify-content: flex-start; padding-top: 8px; border-top: 1px solid var(--border); margin-top: 4px; }
    .inbox-action-btn { min-height: 44px; display: flex; align-items: center; padding: 8px 14px; }
    .inbox-submit-btn { width: 100%; min-height: 44px; }
  }

  /* ============================================================
     WAVE 5: FINISHING TOUCHES
     ============================================================ */
  /* Safe area support for notched devices */
  @supports (padding: env(safe-area-inset-bottom)) {
    header { padding-top: max(10px, env(safe-area-inset-top)); }
    .mobile-nav-drawer { padding-bottom: env(safe-area-inset-bottom); }
    .detail-panel { padding-bottom: env(safe-area-inset-bottom); }
    .modal-overlay { padding-bottom: env(safe-area-inset-bottom); }
  }

  /* Use dvh for mobile browser chrome handling */
  @supports (height: 100dvh) {
    .detail-panel { height: 100dvh; }
    .mobile-nav-drawer { height: 100dvh; }
    @media (max-width: 768px) {
      .detail-panel { height: auto; max-height: 92dvh; }
    }
  }

  /* Smooth view transitions */
  main > div,
  .analytics-view,
  .travel-view,
  .inbox-view,
  #admin-view,
  #gantt-view,
  #recent-view {
    animation: fadeInView 0.2s ease-out;
  }
  @keyframes fadeInView {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
  }

  /* ============================================================
     LTH PLATFORM DESIGN — Brandon's Personal Workspace
     ============================================================ */

  body.workspace-brandon {
    --navy: #1C2E51;
    --copper: #786F67;
    --warm-bg: #FAFAF7;
    --card-bg: #FFFFFF;
    --border: #E8E5DF;
    --text-primary: #2C2B28;
    --text-secondary: #8A8780;
    --text-muted: #B0ADA6;
    --green: #1D9E75;
    --green-bg: #E1F5EE;
    --amber: #BA7517;
    --amber-bg: #FAEEDA;
    --blue: #185FA5;
    --blue-bg: #E6F1FB;
    --red: #A32D2D;
    --red-bg: #FCEBEB;
    --cream: var(--warm-bg);
    --parchment: #F0EFEC;
    --ink: var(--navy);
    --ink-light: #3A4A66;
    --rust: var(--navy);
    --rust-light: #2A4068;
    --warm-gray: var(--text-secondary);
    --gold: var(--copper);
    --gold-light: var(--copper);
    background-color: var(--warm-bg);
    font-family: 'DM Sans', sans-serif;
    color: var(--text-primary);
  }

  /* Page titles — Cinzel */
  body.workspace-brandon .page-title,
  body.workspace-brandon h1 {
    font-family: 'Cinzel', serif;
    font-size: 22px;
    font-weight: 400;
    letter-spacing: 0.02em;
    color: var(--navy);
  }

  /* Summary bar stat values — Cinzel */
  body.workspace-brandon .summary-stat .value,
  body.workspace-brandon .admin-stat-card .stat-value,
  body.workspace-brandon .analytics-stat-value {
    font-family: 'Cinzel', serif;
    font-size: 26px;
    font-weight: 400;
    color: var(--navy);
  }

  /* Summary bar stat labels — DM Sans uppercase */
  body.workspace-brandon .summary-stat .label,
  body.workspace-brandon .admin-stat-card .stat-label,
  body.workspace-brandon .analytics-stat-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.06em;
    color: var(--text-secondary);
    text-transform: uppercase;
  }

  /* Admin stat sub notes — EB Garamond italic */
  body.workspace-brandon .admin-stat-card .stat-sub {
    font-family: 'EB Garamond', serif;
    font-style: italic;
    font-size: 13px;
    color: var(--copper);
  }

  /* Section labels — copper with hairline */
  body.workspace-brandon .section-label,
  body.workspace-brandon .rc-section-label,
  body.workspace-brandon .people-section-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.08em;
    color: var(--copper);
    text-transform: uppercase;
  }

  /* Cards — no border-radius, hairline border, no shadow */
  body.workspace-brandon .admin-stat-card,
  body.workspace-brandon .analytics-stat-card,
  body.workspace-brandon .inbox-form-card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 0;
    box-shadow: none;
  }

  /* Tables */
  body.workspace-brandon table {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 0;
  }

  body.workspace-brandon th {
    font-family: 'DM Sans', sans-serif;
    font-size: 11px;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    text-transform: uppercase;
    font-weight: 500;
    background: var(--warm-bg);
    border-bottom: 1px solid var(--border);
  }

  body.workspace-brandon td {
    font-family: 'DM Sans', sans-serif;
    font-size: 13px;
    border-bottom: 1px solid var(--border);
  }

  /* Buttons — navy, no border-radius */
  body.workspace-brandon .btn-primary {
    background: var(--navy);
    color: #fff;
    border: none;
    border-radius: 0;
    font-family: 'DM Sans', sans-serif;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.03em;
  }
  body.workspace-brandon .btn-primary:hover {
    background: #2A4068;
  }

  /* Inputs — no border-radius */
  body.workspace-brandon input,
  body.workspace-brandon select,
  body.workspace-brandon textarea {
    border-radius: 0;
    border: 1px solid var(--border);
    font-family: 'DM Sans', sans-serif;
    font-size: 14px;
  }

  body.workspace-brandon input:focus,
  body.workspace-brandon select:focus,
  body.workspace-brandon textarea:focus {
    border-color: var(--navy);
    outline: none;
  }

  /* Nav wordmark — show LT HOSPITALITY instead of SC logo */
  body.workspace-brandon .header-logos img {
    display: none;
  }

  body.workspace-brandon .header-logos::before {
    content: 'LT HOSPITALITY';
    font-family: 'Cinzel', serif;
    font-size: 15px;
    letter-spacing: 0.12em;
    color: var(--warm-bg);
  }

  /* Header title override */
  body.workspace-brandon header h1 {
    font-family: 'Cinzel', serif;
    font-size: 22px;
    color: var(--warm-bg);
  }
  body.workspace-brandon header h1 em {
    color: var(--copper);
  }

  /* Badges — no border-radius */
  body.workspace-brandon .badge,
  body.workspace-brandon .overdue-badge,
  body.workspace-brandon .inbox-category-pill {
    border-radius: 0;
  }

  /* Modal — no border-radius, no shadow */
  body.workspace-brandon .modal {
    border-radius: 0;
    box-shadow: none;
    border: 1px solid var(--border);
  }

  body.workspace-brandon .detail-panel {
    border-radius: 0;
    box-shadow: none;
    border-left: 1px solid var(--border);
  }

  /* Empty states — EB Garamond */
  body.workspace-brandon .empty-state {
    font-family: 'EB Garamond', serif;
    font-style: italic;
    font-size: 16px;
    color: var(--copper);
  }
  body.workspace-brandon .empty-state h3 {
    font-family: 'Cinzel', serif;
    font-style: normal;
    color: var(--navy);
  }

  /* Summary bar */
  body.workspace-brandon .summary-bar {
    background: var(--parchment);
    border-bottom: 1px solid var(--border);
  }

  /* Login card — no border-radius */
  body.workspace-brandon .login-card {
    border-radius: 0;
    box-shadow: none;
    border: 1px solid var(--border);
  }

