env('BILLING_ENFORCE_BOOKING', false), /* |-------------------------------------------------------------------------- | Hybride Rechnungskreise |-------------------------------------------------------------------------- | | Alle neuen Abschlüsse laufen über Stripe und erhalten fortlaufende | Nummern im STR-Kreis. Laufende Legacy-Zahlungen werden ab Relaunch im | eigenen MAN-Kreis weiter per Rechnung abgerechnet (Fälligkeitsprüfung | via `billing:generate-manual-invoices`). Die Alt-Rechnungen aus den | Ursprungsportalen bleiben unverändert in `legacy_invoices`. | */ 'invoice_number_padding' => 5, // Zahlungsziel für Rechnungen des manuellen Kreises (Tage). 'manual_due_days' => env('BILLING_MANUAL_DUE_DAYS', 14), /* |-------------------------------------------------------------------------- | Einzel-Pressemitteilung (Pay-per-Release) |-------------------------------------------------------------------------- | | Netto-Preis laut Decision-Update. Die Stripe-Price-ID wird einmalig | von `billing:sync-stripe-plans` angelegt und hier per ENV verdrahtet — | ohne sie ist der Einzel-PM-Checkout deaktiviert. | */ 'single_pm_price_cents' => 1900, 'single_pm_stripe_price_id' => env('STRIPE_PRICE_SINGLE_PM'), /* |-------------------------------------------------------------------------- | USt-Behandlung (Entscheidung 12.06.2026) |-------------------------------------------------------------------------- | | Alle neuen Preise sind NETTO. Die Steuer wird zur Rechnungsstellung | anhand der Rechnungsadresse bestimmt (VatResolver): Deutschland immer | mit Steuer, EU-Ausland nur mit gültiger USt-ID befreit (Reverse | Charge), Drittländer grundsätzlich befreit. | */ 'vat_rate' => env('BILLING_VAT_RATE', 0.19), // Eigene deutsche USt-ID des Betreibers — Pflichtangabe für die // eVatR-Online-Bestätigung ausländischer EU-USt-IDs (BZSt-REST-API). // Ohne sie bleibt die USt-ID-Prüfung eine reine Formatprüfung. 'own_vat_id' => env('BILLING_OWN_VAT_ID'), // EU-Mitgliedstaaten (ISO 3166-1 alpha-2), Stand 2026 — ohne DE, // das im VatResolver als Inland behandelt wird. 'eu_country_codes' => [ 'AT', 'BE', 'BG', 'CY', 'CZ', 'DK', 'EE', 'ES', 'FI', 'FR', 'GR', 'HR', 'HU', 'IE', 'IT', 'LT', 'LU', 'LV', 'MT', 'NL', 'PL', 'PT', 'RO', 'SE', 'SI', 'SK', ], ];