body { font-family: -apple-system, sans-serif; margin: 0; background: var(--bg-primary); color: var(--text-primary); display: flex; justify-content: center; min-height: 100vh; padding-bottom: 40px; }
    .main-wrapper { width: 100%; max-width: 600px; min-height: 100vh; background: var(--bg-primary); position: relative; border-left: 1px solid var(--border-primary); border-right: 1px solid var(--border-primary); }
    .page-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 240px; }
    /* Hero */
    .truck-hero { height: 180px; background: var(--bg-tertiary) center/cover no-repeat; position: relative; }
    .truck-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, transparent 60%); }
    .truck-hero-info { position: absolute; bottom: 16px; left: 18px; color: white; }
    .truck-hero-name { font-size: 22px; font-weight: 900; text-shadow: 0 1px 4px rgba(0,0,0,0.5); }
    .truck-hero-badge { display: inline-flex; align-items: center; gap: 4px; background: var(--accent); color: white; font-size: 11px; font-weight: 800; padding: 3px 10px; border-radius: 20px; margin-top: 6px; }
    /* Container */
    .booking-container { padding: 20px; }
    .section-card { background: var(--bg-card); border: 1px solid var(--border-primary); border-radius: 18px; padding: 20px; margin-bottom: 18px; }
    .section-title { font-size: 14px; font-weight: 900; color: var(--accent); text-transform: uppercase; display: flex; align-items: center; gap: 8px; padding-bottom: 12px; border-bottom: 1px solid var(--border-primary); margin-bottom: 16px; letter-spacing: 0.3px; }
    .section-hint { font-size: 12px; color: var(--text-tertiary); margin: -8px 0 16px; line-height: 1.5; }
    /* Form */
    .form-group { margin-bottom: 14px; }
    .form-label { display: block; font-size: 11px; font-weight: 800; color: var(--text-secondary); text-transform: uppercase; margin-bottom: 6px; letter-spacing: 0.3px; }
    .form-label .required { color: var(--accent); }
    .form-input { width: 100%; padding: 13px; border: 1px solid var(--border-secondary); border-radius: 12px; font-size: 15px; box-sizing: border-box; outline: none; background: var(--bg-secondary); color: var(--text-primary); transition: border-color 0.2s; }
    .form-input:focus { border-color: var(--accent); }
    textarea.form-input { resize: vertical; min-height: 80px; }
    .form-row { display: flex; gap: 10px; }
    .form-row .form-group { flex: 1; }
    /* Menu produits */
    .menu-category { font-size: 11px; font-weight: 900; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.5px; padding: 8px 0 4px; }
    .menu-item { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-primary); }
    .menu-item:last-child { border-bottom: none; }
    .menu-item-info { flex: 1; }
    .menu-item-name { font-weight: 700; font-size: 15px; }
    .menu-item-price { font-size: 13px; color: var(--text-secondary); margin-top: 2px; }
    .menu-item-desc { font-size: 12px; color: var(--text-tertiary); margin-top: 2px; }
    .qty-control { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
    .qty-btn { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--border-secondary); background: var(--bg-secondary); color: var(--text-primary); font-size: 18px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: 0.2s; line-height: 1; }
    .qty-btn:active { transform: scale(0.9); }
    .qty-btn.plus { border-color: var(--accent); color: var(--accent); }
    .qty-val { font-size: 16px; font-weight: 900; min-width: 20px; text-align: center; }
    /* Récap */
    .recap-bar { background: var(--accent-light); border: 1px solid var(--accent); border-radius: 14px; padding: 12px 16px; margin-bottom: 16px; }
    .recap-info { font-size: 13px; font-weight: 700; color: var(--accent); }
    /* Submit */
    .submit-btn { background: var(--accent); color: white; width: 100%; padding: 16px; border: none; border-radius: 14px; font-size: 16px; font-weight: 800; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: 0.2s; }
    .submit-btn:disabled { opacity: 0.6; cursor: not-allowed; }
    .submit-btn:active { transform: scale(0.98); }
    /* Loader */
    .loading-spinner { width: 36px; height: 36px; border: 3px solid var(--border-primary); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; margin: 0 auto 12px; }
    @keyframes spin { to { transform: rotate(360deg); } }
    /* Skip link */
    .skip-link { position: absolute; left: -9999px; }
    .skip-link:focus { left: 10px; top: 10px; z-index: 9999; }
