{% extends 'base.html.twig' %} {% block title %}{{ (system_setting is defined and system_setting and system_setting.seoHomeTitle) ? system_setting.seoHomeTitle : 'CARTECADEAU — Cartes-cadeaux & recharges, livrées en un éclair' }}{% endblock %} {% block body %} {# ============================================================ Mapping marque → couleurs (utilisé partout : floating stack, product cards, marquee, category rail). Si une catégorie n'est pas listée, fallback or/aurore via .product-emblem (sans .branded). ============================================================ #} {% set brandMap = { 'PlayStation': {'primary': '#0070D1', 'secondary': '#003791', 'initials': 'PS'}, 'Xbox': {'primary': '#107C10', 'secondary': '#0E5E0E', 'initials': 'XB'}, 'Steam': {'primary': '#1B2838', 'secondary': '#66C0F4', 'initials': 'ST'}, 'Netflix': {'primary': '#E50914', 'secondary': '#831010', 'initials': 'N'}, 'Spotify': {'primary': '#1DB954', 'secondary': '#0E6B2F', 'initials': 'SP'}, 'Amazon': {'primary': '#FF9900', 'secondary': '#232F3E', 'initials': 'AZ'}, 'Apple': {'primary': '#A2AAAD', 'secondary': '#1C1C1E', 'initials': 'iT'}, 'iTunes': {'primary': '#A2AAAD', 'secondary': '#1C1C1E', 'initials': 'iT'}, 'Google Play': {'primary': '#34A853', 'secondary': '#FBBC04', 'initials': 'GP'}, 'Free Fire': {'primary': '#FF6A00', 'secondary': '#E2231A', 'initials': 'FF'}, 'Mobile Legends': {'primary': '#22D3EE', 'secondary': '#1E1B4B', 'initials': 'ML'}, 'PUBG Mobile': {'primary': '#F2A900', 'secondary': '#1A1A1A', 'initials': 'PG'}, 'Genshin Impact': {'primary': '#FFB347', 'secondary': '#5B3E91', 'initials': 'GI'}, 'Valorant': {'primary': '#FF4655', 'secondary': '#0F1923', 'initials': 'VA'}, 'Riot': {'primary': '#FF4655', 'secondary': '#0F1923', 'initials': 'RT'}, 'Fortnite': {'primary': '#9F4DEA', 'secondary': '#00FFFF', 'initials': 'FN'}, 'Roblox': {'primary': '#E2231A', 'secondary': '#393B3F', 'initials': 'RB'}, 'Nintendo': {'primary': '#E60012', 'secondary': '#1F1F1F', 'initials': 'NS'}, 'Twitch': {'primary': '#9146FF', 'secondary': '#392E5C', 'initials': 'TV'}, } %} {# Helper: récupère le brand d'une catégorie (ou un fallback or). #} {% macro brandOf(cat, map) %} {%- if cat and map[cat] is defined -%} {{- map[cat]|json_encode|raw -}} {%- else -%} {"primary":"#f4c77b","secondary":"#e0a93f","initials":"{{ (cat ?: 'GC')|slice(0,2)|upper }}"} {%- endif -%} {% endmacro %} {# ---------- BARRE CATÉGORIES ---------- #}
Toutes les catégories Cartes-cadeaux Recharges de jeux {% for cat in platforms %} {{ cat }} {% endfor %}
{# ---------- HERO PROMO (avec FloatingStack autour du phone) ---------- #}

Wupex × CinetPay · Mobile Money

{% if system_setting is defined and system_setting and system_setting.seoPromoBannerText %}

{{ system_setting.seoPromoBannerText }}

{% endif %}
Reçois tes cartes-cadeaux
en quelques minutes
Recharge tes jeux préférés
sans complications
Paie en Mobile Money
code livré instantanément
💳
Paiement Mobile MoneyWave · Orange · MTN · Moov
🔒
Transactions sécuriséesPaiement vérifié via CinetPay
🎧
Support disponibleOn t'accompagne en cas de souci
Acheter maintenant {% if not app.user %}Créer un compte{% endif %}
{# Stats de confiance — remplace les dots #}
+200marques
38 slivraison moyenne
24/7support
{# FloatingStack — 4 cartes de marque flottant autour du phone #}
{# ---------- RAIL CATÉGORIES (orbes colorées) ---------- #} {% if platforms is not empty %}

Explore par catégorie

Tout voir →
{% for cat in platforms %} {% set b = brandMap[cat] ?? null %} {% set tile = b ? b.primary : '#f4c77b' %} {{ b ? b.initials : cat|slice(0,2)|upper }} {{ cat }} {% endfor %}
{% endif %} {# ---------- SÉLECTION DU MOMENT (product cards brandées) ---------- #} {% if carouselItems is not empty %}

La sélection du moment

Tout le catalogue →
{% endif %} {# ---------- MARQUEE DES MARQUES (deux lignes opposées) ---------- #} {% if platforms is not empty %}

Les marques qu'ils adorent

{% set brandList = platforms %} {% set halfA = brandList|slice(0, (brandList|length / 2)|round(0, 'ceil')) %} {% set halfB = brandList|slice((brandList|length / 2)|round(0, 'ceil')) %}
{% for repeat in 1..3 %} {% for cat in halfA %} {% set b = brandMap[cat] ?? {'primary': '#f4c77b', 'secondary': '#e0a93f', 'initials': cat|slice(0,2)|upper} %} {{ b.initials }} {{ cat }} {% endfor %} {% endfor %}
{% if halfB|length > 0 %}
{% for repeat in 1..3 %} {% for cat in halfB %} {% set b = brandMap[cat] ?? {'primary': '#f4c77b', 'secondary': '#e0a93f', 'initials': cat|slice(0,2)|upper} %} {{ b.initials }} {{ cat }} {% endfor %} {% endfor %}
{% endif %}
{% endif %} {# ---------- COMMENT ÇA MARCHE ---------- #}

Comment ça marche

01

Choisis

Parcours le catalogue et ajoute tes cartes-cadeaux ou recharges au panier.

02

Paie en Mobile Money

Wave, Orange, MTN ou Moov via CinetPay, en quelques secondes.

03

Reçois ton code

Ton code/PIN s'affiche aussitôt et t'est envoyé par email. Instantané.

{% endblock %}