body { font-family: -apple-system, sans-serif; margin: 0; background-color: var(--bg-primary); color: var(--text-primary); padding-bottom: calc(100px + env(safe-area-inset-bottom, 0px)); display: flex; justify-content: center; min-height: 100vh; }
    .app-name { font-size: 22px; font-weight: 900; font-style: italic; letter-spacing: -1px; color: var(--text-primary); }
    .app-name span { color: var(--accent); }
    .main-wrapper { width: 100%; max-width: 600px; border-left: 1px solid var(--border-primary); border-right: 1px solid var(--border-primary); min-height: 100vh; position: relative; display: flex; flex-direction: column; }
    .truck-header { height: 240px; background-size: cover; background-position: center; position: relative; background-color: #1c1c1c; }
    .header-content { position: absolute; bottom: 0; left: 0; width: 100%; background: linear-gradient(to top, rgba(0,0,0,0.8), transparent); padding: 20px; color: white; box-sizing: border-box; }
    .cat-nav { display: flex; overflow-x: auto; gap: 10px; padding: 15px; position: sticky; top: var(--header-h, 0px); background: var(--bg-primary); z-index: 50; border-bottom: 1px solid var(--border-primary); scrollbar-width: none; }
    .cat-pill { padding: 8px 16px; background: var(--bg-secondary); border-radius: 20px; font-size: 13px; font-weight: bold; white-space: nowrap; color: var(--text-tertiary); cursor: pointer; transition: 0.2s; border: 1px solid transparent; }
    .cat-pill.active { background: var(--text-primary); color: var(--text-inverse); }
    .menu-grid { padding: 15px; display: grid; grid-template-columns: 1fr; gap: 15px; }
    @media (min-width: 600px) { .menu-grid { grid-template-columns: 1fr 1fr; } }
    @media (min-width: 768px) {
        .main-wrapper { max-width: 900px; }
        .bottom-nav { max-width: 900px; }
        .menu-grid { gap: 18px; }
        .reviews-section { max-width: 700px; margin-left: auto; margin-right: auto; }
    }
    @media (min-width: 1024px) {
        .header { display: none !important; }
        .header-top-btns { display: flex !important; }
        .main-wrapper { max-width: 1200px !important; margin: 0 auto; border: none !important; }
        /* Wrapper desktop : profil (flex:1) | calendrier (300px fixe) */
        .truck-detail-row { display: flex; flex-direction: row; border-bottom: 1px solid var(--border-primary); background: var(--bg-secondary); }
        .truck-profile-block { flex: 1; min-width: 0; display: flex; flex-direction: row; border-bottom: none; padding: 20px; gap: 20px; }
        /* Photo : rectangle arrondi, pas edge-to-edge */
        .truck-header { width: 280px !important; height: 210px !important; border-radius: 16px !important; flex-shrink: 0; border-right: none; }
        .truck-header .header-content { display: none !important; }
        .truck-actions-bar { flex: 1 !important; flex-direction: column !important; justify-content: flex-start !important; align-items: stretch !important; padding: 0 !important; border: none !important; height: auto; box-sizing: border-box; gap: 10px !important; overflow-y: auto; background: transparent !important; }
        .desktop-truck-header { display: block !important; flex: 0 0 auto; }
        .truck-meta-actions-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
        .truck-meta-row { flex: 1 !important; }
        .truck-action-btns { flex-shrink: 0; }
        .action-btn-round { flex: none !important; }
        .action-btn-pill { flex: none !important; }
        /* Calendrier via bottom sheet — plus de colonne inline */
        .menu-grid { grid-template-columns: 1fr 1fr; gap: 20px; padding: 20px 30px; max-width: 1100px; margin: 0 auto; }
        .cat-nav { position: sticky !important; top: 0 !important; z-index: 50; padding: 15px 30px; }
        .reviews-section { max-width: 800px; margin-left: auto; margin-right: auto; padding: 30px; }
        .cart-float { max-width: 500px; bottom: 30px; }
        .modal-content { max-width: 650px !important; height: 80vh !important; border-radius: var(--radius-xl) !important; margin: auto; }
        .modal-overlay { align-items: center !important; }
        .product-card { padding: 16px; }
        .p-img { width: 100px !important; height: 100px !important; border-radius: 14px !important; }
    }
    @media (min-width: 1400px) {
        .menu-grid { grid-template-columns: 1fr 1fr 1fr; }
    }

    .product-card { background: var(--bg-card); padding: 12px; border-radius: 16px; display: flex; gap: 12px; border: 1px solid var(--border-primary); cursor: pointer; transition: transform 0.1s; position: relative; }
    .product-card:active { transform: scale(0.98); }
    .product-card.out-of-stock { opacity: 0.6; filter: grayscale(1); pointer-events: none; }
    .badge-out { position: absolute; top: 10px; right: 10px; background: var(--text-primary); color: var(--text-inverse); padding: 2px 6px; border-radius: 4px; font-size: 9px; font-weight: 900; z-index: 2; }

    .p-img { width: 90px; height: 90px; border-radius: 12px; background: var(--bg-tertiary); object-fit: cover; }
    .p-info { flex: 1; display: flex; flex-direction: column; justify-content: center; }
    .p-name { font-weight: bold; font-size: 15px; margin-bottom: 4px; }
    .p-desc { font-size: 11px; color: var(--text-tertiary); margin-bottom: 8px; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
    .p-price { font-weight: 900; color: var(--accent); }
    .qty-badge { font-weight: 900; font-size: 14px; min-width: 20px; text-align: center; color: var(--text-primary); }
    .btn-qty-minus:hover, .btn-qty-plus:hover { opacity: 0.7; }

    /* Menu/formula card special style */
    .badge-formula { position: absolute; top: 10px; right: 10px; background: var(--accent); color: white; padding: 3px 8px; border-radius: 6px; font-size: 10px; font-weight: 900; display: flex; align-items: center; gap: 3px; }
    .formula-steps-hint { display: flex; gap: 4px; margin-top: 4px; flex-wrap: wrap; }
    .formula-step-chip { background: var(--bg-tertiary); padding: 2px 7px; border-radius: 8px; font-size: 9px; font-weight: 700; color: var(--text-tertiary); }

    .cart-float { position: fixed; bottom: 95px; left: 50%; transform: translateX(-50%); width: 90%; max-width: 400px; background: var(--text-primary); color: var(--text-inverse); padding: 15px 25px; border-radius: 50px; display: none; justify-content: space-between; align-items: center; box-shadow: 0 10px 25px rgba(0,0,0,0.3); z-index: 100; cursor: pointer; }
    
    /* Configurateur modal amélioré style McDonald's */
    .modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.6); z-index: 2000; display: none; align-items: flex-end; justify-content: center; backdrop-filter: blur(5px); }
    .modal-content { background: var(--bg-primary); width: 100%; max-width: 600px; height: 90vh; border-radius: 20px 20px 0 0; display: flex; flex-direction: column; overflow: hidden; animation: slideUp 0.3s ease-out; }
    @keyframes slideUp { from { transform: translateY(100%); } to { transform: translateY(0); } }
    .modal-header { padding: 20px; border-bottom: 1px solid var(--border-primary); display: flex; justify-content: space-between; align-items: center; }
    .modal-header-info { flex: 1; }
    .modal-header-info h3 { margin: 0; font-size: 18px; }
    .modal-header-info p { margin: 4px 0 0; font-size: 12px; color: var(--text-tertiary); }
    .modal-body { flex: 1; overflow-y: auto; padding: 0; }
    .modal-footer { padding: 15px 20px; border-top: 1px solid var(--border-primary); background: var(--bg-secondary); }

    /* Steps navigation dans le modal */
    .modal-steps-nav { display: flex; padding: 12px 20px; gap: 8px; overflow-x: auto; background: var(--bg-secondary); border-bottom: 1px solid var(--border-primary); scrollbar-width: none; }
    .modal-step-pill { padding: 6px 14px; border-radius: 20px; font-size: 12px; font-weight: 700; white-space: nowrap; background: var(--bg-tertiary); color: var(--text-tertiary); border: 2px solid transparent; cursor: pointer; display: flex; align-items: center; gap: 4px; transition: 0.2s; }
    .modal-step-pill.active { border-color: var(--accent); color: var(--accent); background: rgba(255,59,48,0.08); }
    .modal-step-pill.done { background: var(--accent); color: white; border-color: var(--accent); }
    .modal-step-pill .pill-num { width: 20px; height: 20px; border-radius: 50%; background: var(--border-primary); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 900; }
    .modal-step-pill.active .pill-num { background: var(--accent); color: white; }
    .modal-step-pill.done .pill-num { background: rgba(255,255,255,0.3); }

    .step-section { padding: 20px; }
    .step-title { font-size: 16px; font-weight: 900; margin-bottom: 5px; display: flex; align-items: center; gap: 8px; }
    .step-subtitle { font-size: 12px; color: var(--text-tertiary); margin-bottom: 15px; }

    /* Option cards avec images (style McDonald's) */
    .option-item { display: flex; align-items: center; gap: 12px; padding: 12px; border: 2px solid var(--border-primary); border-radius: 14px; margin-bottom: 10px; cursor: pointer; transition: 0.2s; background: var(--bg-card); }
    .option-item:hover { border-color: var(--text-tertiary); }
    .option-item.selected { border-color: var(--accent); background: rgba(255,59,48,0.05); box-shadow: 0 0 0 1px var(--accent); }
    .option-img { width: 60px; height: 60px; border-radius: 10px; object-fit: cover; background: var(--bg-tertiary); flex-shrink: 0; }
    .option-info { flex: 1; }
    .option-name { font-weight: 700; font-size: 14px; }
    .option-desc { font-size: 11px; color: var(--text-tertiary); margin-top: 2px; line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
    .option-price { font-size: 12px; color: var(--accent); font-weight: 700; margin-top: 2px; }
    .radio-circle { width: 22px; height: 22px; border: 2px solid var(--border-secondary); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .option-item.selected .radio-circle { border-color: var(--accent); background: var(--accent); }
    .radio-inner { width: 10px; height: 10px; background: white; border-radius: 50%; display: none; }
    .option-item.selected .radio-inner { display: block; }

    .btn-add-cart { width: 100%; padding: 15px; background: var(--text-primary); color: var(--text-inverse); border: none; border-radius: 14px; font-weight: 900; font-size: 16px; cursor: pointer; opacity: 1; transition: 0.3s; }
    .btn-add-cart:disabled { opacity: 0.5; cursor: not-allowed; }
    .btn-add-cart.pulse-ready { animation: pulseReady 0.5s ease; background: var(--accent); color: #fff; }
    @keyframes pulseReady { 0% { transform: scale(1); } 50% { transform: scale(1.04); } 100% { transform: scale(1); } }

    /* Personnalisation ingrédients */
    .customize-chip { display:inline-flex; align-items:center; gap:6px; padding:8px 14px; border-radius:20px; font-size:13px; font-weight:600; cursor:pointer; transition:0.2s; user-select:none; border:1.5px solid var(--border-primary); background:var(--bg-secondary); color:var(--text-primary); }
    .customize-chip.active { background:var(--text-primary); color:var(--text-inverse); border-color:var(--text-primary); }
    .customize-chip.disabled { opacity:0.5; cursor:default; background:var(--bg-tertiary); border-color:var(--border-primary); }
    .customize-chip .material-icons { font-size:16px; }
    .customize-removed-label { font-size:11px; color:var(--text-tertiary); margin-top:3px; }

    .bottom-nav { position: fixed; bottom: 0; left: 50%; transform: translateX(-50%); width: 100%; max-width: 600px; height: 80px; background: var(--bg-nav); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-top: 1px solid var(--border-primary); display: flex; justify-content: space-around; align-items: center; z-index: 9999; padding-bottom: env(safe-area-inset-bottom); }
    .nav-btn { color: var(--text-placeholder); cursor: pointer; width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 2px; transition: 0.3s; border-radius: 12px; }
    .nav-btn .material-icons { font-size: 24px; }
    .nav-btn.active { color: var(--accent); }

    .reviews-section { padding: 20px; margin-top: 20px; border-top: 1px solid var(--border-primary); }
    .review-card { background: var(--bg-card); padding: 12px; border-radius: 12px; margin-bottom: 10px; border: 1px solid var(--border-primary); }
    .stars-input { display: flex; gap: 5px; margin-bottom: 10px; }
    .stars-input .material-icons { font-size: 30px; cursor: pointer; color: var(--border-secondary); }
    .stars-input .material-icons.active { color: orange; }

    /* ── Header redesigné ── */
    .header-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,0.25) 0%, transparent 40%); pointer-events: none; z-index: 1; }
    .header-top-btns { position: absolute; top: 16px; left: 16px; right: 16px; display: none; justify-content: space-between; align-items: center; z-index: 10; }
    .header-icon-btn { width: 42px; height: 42px; border-radius: 50%; background: rgba(0,0,0,0.45); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); display: flex; align-items: center; justify-content: center; cursor: pointer; color: white; transition: background 0.2s; border: 1px solid rgba(255,255,255,0.12); }
    .header-icon-btn:hover { background: rgba(0,0,0,0.65); }
    .header-icon-btn .material-icons { font-size: 22px; }
    .header-theme-toggle-inner { background: rgba(0,0,0,0.45) !important; backdrop-filter: blur(12px) !important; -webkit-backdrop-filter: blur(12px) !important; border: 1px solid rgba(255,255,255,0.12) !important; }
    .truck-header .header-content { background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.55) 50%, transparent 100%); padding: 36px 20px 18px; }
    .truck-header .header-content #truck-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
    .truck-header .header-content h1 { margin: 0 0 4px; font-size: 24px; font-weight: 900; color: #fff; line-height: 1.2; letter-spacing: -0.3px; }
    .truck-header .header-content p { margin: 0; font-size: 13px; color: rgba(255,255,255,0.80); line-height: 1.4; }

    /* ── Barre actions ── */
    .truck-actions-bar { padding: 14px 20px; background: var(--bg-secondary); border-bottom: 1px solid var(--border-primary); display: flex; flex-direction: column; gap: 12px; }
    .truck-meta-actions-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
    .truck-meta-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; flex: 1; min-width: 0; }
    .meta-pill { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 700; background: var(--bg-tertiary); color: var(--text-secondary); padding: 5px 12px; border-radius: 20px; border: 1px solid var(--border-primary); white-space: nowrap; }
    .meta-pill .material-icons { font-size: 13px; color: var(--text-tertiary); }
    .meta-pill.open { background: rgba(76,175,80,0.12); color: #4caf50; border-color: rgba(76,175,80,0.28); }
    .meta-pill.open .status-dot { background: #4caf50; }
    .meta-pill.open .material-icons { color: #4caf50; }
    .meta-pill.closed { background: rgba(255,59,48,0.10); color: var(--accent); border-color: rgba(255,59,48,0.25); }
    .meta-pill.closed .status-dot { background: var(--accent); }
    .status-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
    .truck-action-btns { display: flex; gap: 6px; align-items: center; flex-shrink: 0; }
    .action-btn-round { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--border-secondary); background: var(--bg-secondary); color: var(--text-secondary); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: 0.2s; padding: 0; }
    .action-btn-round:hover { background: var(--bg-tertiary); border-color: var(--text-primary); color: var(--text-primary); }
    .action-btn-round .material-icons { font-size: 17px; }
    .action-btn-pill { display: flex; align-items: center; justify-content: center; gap: 5px; padding: 6px 12px; border-radius: var(--radius-md); border: 1px solid var(--border-secondary); background: var(--bg-secondary); color: var(--text-primary); font-size: 12px; font-weight: 700; cursor: pointer; transition: 0.2s; white-space: nowrap; }
    .action-btn-pill:hover { background: var(--bg-tertiary); border-color: var(--text-primary); }
    .action-btn-pill .material-icons { font-size: 18px; color: var(--text-secondary); }
    .action-btn-pill.event-btn { background: var(--accent); border-color: var(--accent); color: white; }
    .action-btn-pill.event-btn .material-icons { color: white; }
    .action-btn-pill.event-btn:hover { opacity: 0.88; }

    /* ── Panel info desktop (côté droit de la carte) ── */
    .desktop-truck-header { display: none; margin-bottom: 4px; }
    .desktop-truck-name { font-size: 24px; font-weight: 900; color: var(--text-primary); margin: 0 0 6px; line-height: 1.2; letter-spacing: -0.3px; }
    .desktop-truck-desc { font-size: 13px; color: var(--text-secondary); line-height: 1.5; margin: 0; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
    .desktop-truck-badges { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 10px; }
    .desktop-truck-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 20px; background: var(--bg-tertiary); color: var(--text-secondary); border: 1px solid var(--border-primary); white-space: nowrap; }

    /* ── Prochaines présences ── */
    .upcoming-date-card { flex-shrink: 0; background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 12px; padding: 10px 14px; min-width: 155px; max-width: 200px; }
    .upcoming-date-day { font-weight: 800; font-size: 13px; color: var(--accent); margin-bottom: 5px; text-transform: capitalize; }
    .upcoming-date-meta { font-size: 11px; color: var(--text-secondary); display: flex; align-items: center; gap: 3px; margin-top: 3px; line-height: 1.3; }
    .upcoming-date-meta .material-icons { font-size: 12px; color: var(--text-tertiary); flex-shrink: 0; }

    /* ── Carte non configurée ── */
    .no-menu-state { text-align: center; padding: 60px 24px; color: var(--text-tertiary); grid-column: 1 / -1; }
    .no-menu-state .material-icons { font-size: 64px; opacity: 0.35; display: block; margin-bottom: 16px; }
    .no-menu-title { font-size: 18px; font-weight: 800; color: var(--text-secondary); margin: 0 0 8px; }
    .no-menu-sub { font-size: 14px; margin: 0; line-height: 1.5; }

    /* ── Placeholder photo manquante ── */
    /* Quand aucune image n'est configurée pour le truck */
    .truck-header.no-photo { background-color: var(--bg-tertiary) !important; }
    .truck-header.no-photo .header-overlay { display: none; }
    .truck-header.no-photo .header-content { background: none; }
    .truck-header.no-photo .header-content h1 { color: var(--text-primary); }
    .truck-header.no-photo .header-content p { color: var(--text-secondary); }
    /* z-index: 0 → peint avant header-content (z-index:auto) qui apparaît par-dessus en bas */
    .header-no-photo { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; z-index: 0; pointer-events: none; padding-bottom: 40px; }
    .header-no-photo .material-icons { font-size: 44px; color: var(--text-tertiary); opacity: 0.3; }
    .no-photo-label { font-size: 11px; font-weight: 700; color: var(--text-tertiary); opacity: 0.45; text-transform: uppercase; letter-spacing: 0.5px; }

    /* ── Placeholder "aucune date" dans le calendrier ── */
    .no-dates-placeholder { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: var(--bg-card); border: 1px dashed var(--border-secondary); border-radius: 12px; color: var(--text-tertiary); font-size: 12px; font-weight: 600; font-style: italic; white-space: nowrap; }
    .no-dates-placeholder .material-icons { font-size: 16px; flex-shrink: 0; opacity: 0.55; }

    /* ── Panneau calendrier — désormais via bottom sheet ── */

    /* ── Tabs Présences / Événements ── */
    .dates-tab { display: flex; align-items: center; gap: 5px; padding: 8px 14px; border: 1.5px solid var(--border-secondary); border-radius: 20px; background: transparent; color: var(--text-secondary); font-size: 13px; font-weight: 700; cursor: pointer; transition: 0.2s; }
    .dates-tab .material-icons { font-size: 15px; }
    .dates-tab.active { background: var(--text-primary); color: var(--text-inverse); border-color: var(--text-primary); }

    /* ── Cards dates (design gérant) ── */
    .cal-date-card { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--bg-tertiary); border-radius: 10px; margin-bottom: 8px; border: 1px solid var(--border-primary); }
    .cal-date-card.past { opacity: 0.5; }
    .cal-date-icon { color: var(--accent); flex-shrink: 0; font-size: 20px; }
    .cal-date-card.past .cal-date-icon { color: var(--text-tertiary); }
    .cal-date-info { flex: 1; min-width: 0; }
    .cal-date-day { font-weight: 700; font-size: 13px; color: var(--text-primary); text-transform: capitalize; }
    .cal-date-card.past .cal-date-day { color: var(--text-tertiary); }
    .cal-date-meta { font-size: 11px; color: var(--text-tertiary); margin-top: 2px; display: flex; align-items: center; gap: 3px; }
    .cal-date-meta .material-icons { font-size: 12px; flex-shrink: 0; }
    .cal-empty { text-align: center; padding: 14px 12px; color: var(--text-tertiary); font-size: 13px; font-style: italic; }

    /* ── Séparateur section calendrier ── */
    .cal-section-label { display: none; align-items: center; gap: 6px; font-size: 11px; font-weight: 800; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.5px; margin: 10px 0 6px; padding-bottom: 6px; border-bottom: 1px solid var(--border-primary); }
    .cal-section-label .material-icons { font-size: 13px; }

    /* ── CTA événements ── */
    .events-cta-block { display: flex; align-items: center; gap: 12px; padding: 14px; background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 14px; }
    .events-cta-btn { display: flex; align-items: center; gap: 5px; padding: 9px 14px; background: var(--accent); color: white; border: none; border-radius: 10px; font-size: 13px; font-weight: 700; cursor: pointer; white-space: nowrap; flex-shrink: 0; }

    /* ── Grille semaine read-only (Tab "Habituel") ── */
    .usual-week-ro { display: grid; grid-template-columns: 34px repeat(7, 1fr); gap: 4px; margin-top: 4px; }
    .uwg-ro-header { text-align: center; font-size: 10px; font-weight: 800; color: var(--text-secondary); padding: 3px 0; }
    .uwg-ro-label { font-size: 9px; font-weight: 800; color: var(--text-secondary); text-transform: uppercase; display: flex; align-items: center; letter-spacing: 0.3px; }
    .uwg-ro-cell { height: 28px; border-radius: 6px; background: var(--bg-tertiary); border: 1.5px solid var(--border-secondary); }
    .uwg-ro-cell.active { background: var(--accent); border-color: var(--accent); }

    /* ── Calendrier mensuel "À venir" ── */
    .cal-wrapper { padding-bottom: 8px; }
    .cal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
    .cal-month-title { font-size: 13px; font-weight: 800; color: var(--text-primary); text-transform: capitalize; text-align: center; flex: 1; }
    .cal-nav-btn { background: var(--bg-tertiary); border: 1px solid var(--border-primary); border-radius: 8px; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text-secondary); flex-shrink: 0; }
    .cal-nav-btn .material-icons { font-size: 18px; }
    .cal-weekdays { display: grid; grid-template-columns: repeat(7, 1fr); margin-bottom: 4px; }
    .cal-weekday { text-align: center; font-size: 10px; font-weight: 800; color: var(--text-tertiary); padding: 3px 0; }
    .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; }
    .menu-cal-day { min-height: 36px; border-radius: 7px; background: var(--bg-card); border: 1px solid var(--border-secondary); padding: 4px 3px 3px; display: flex; flex-direction: column; overflow: hidden; position: relative; }
    .menu-cal-day.other-month { background: transparent; border-color: transparent; }
    .menu-cal-day.today { border-color: var(--accent) !important; border-width: 2px; }
    .menu-cal-day.has-event { background: rgba(255,59,48,0.10); border-color: rgba(255,59,48,0.45); }
    .menu-cal-day.past-event { opacity: 0.55; }
    .menu-cal-day-num { font-size: 11px; font-weight: 700; color: var(--text-primary); line-height: 1; }
    .menu-cal-note { font-size: 8px; color: var(--accent); font-weight: 700; margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; line-height: 1.2; }

    /* ── Bottom sheet Emplacements ── */
    .schedule-sheet-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.45); z-index: 1500; display: flex; align-items: flex-end; justify-content: center; }
    .schedule-sheet { background: var(--bg-secondary); border-radius: 20px 20px 0 0; width: 100%; max-width: 600px; max-height: 75vh; overflow-y: auto; padding: 0 0 env(safe-area-inset-bottom, 16px); animation: sheetUp 0.28s ease-out; }
    @keyframes sheetUp { from { transform: translateY(100%); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
    .schedule-sheet-handle { width: 36px; height: 4px; border-radius: 4px; background: var(--border-secondary); margin: 10px auto 6px; }
    .schedule-sheet-tabs { display: flex; gap: 6px; padding: 6px 20px 12px; border-bottom: 1px solid var(--border-primary); }
    .schedule-sheet-tabs .dates-tab { flex: 1; justify-content: center; }
    .schedule-sheet-body { padding: 16px 20px 20px; }
    .schedule-btn { background: var(--bg-secondary) !important; border: 1.5px solid var(--accent) !important; color: var(--accent) !important; }
    @media (min-width: 768px) {
        .schedule-sheet-backdrop { align-items: center; }
        .schedule-sheet { border-radius: 20px; max-width: 500px; max-height: 70vh; animation: sheetFade 0.2s ease-out; }
        @keyframes sheetFade { from { transform: scale(0.95); opacity: 0; } to { transform: scale(1); opacity: 1; } }
    }
