/* ============ BUILDER TOOLBAR ============ */
.builder-toolbar {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
    background: var(--panel); border: 1px solid var(--border); border-radius: 12px;
    padding: 0.75rem 1rem; margin-bottom: 1.25rem;
}
.builder-status { font-size: 0.82rem; color: #34d399; display: flex; align-items: center; gap: 0.4rem; transition: color 0.2s; }
.builder-status.unsaved { color: #fbbf24; }
.device-toggle { display: flex; gap: 0.3rem; background: var(--panel-2); border-radius: 8px; padding: 0.25rem; }
.device-toggle button {
    background: none; border: none; color: var(--text-dim); width: 36px; height: 32px; border-radius: 6px; cursor: pointer;
}
.device-toggle button.active { background: var(--gold); color: #000; }
.builder-toolbar-right { display: flex; gap: 0.6rem; align-items: center; }
.builder-toolbar-right .btn-mini { padding: 0.55rem 1rem; text-decoration: none; display: inline-flex; align-items: center; gap: 0.4rem; }
.builder-toolbar-right .btn-gold { padding: 0.6rem 1.1rem; display: inline-flex; align-items: center; gap: 0.4rem; cursor: pointer; border: none; font-family: inherit; font-size: 0.88rem; }

/* ============ HEADER "COMPTE CONNECTÉ" (réplique du vrai header_logged.php + headerV1.css) ============ */
.real-header-logged { display: block; padding: 0; border-bottom: 1px solid var(--site-card-border); }

/* ============ HEADER "PUBLIC / MARKETING" (réplique de welcome.css — pages visiteurs non connectés) ============ */
.real-header-public { display: flex; align-items: center; justify-content: space-between; padding: 0.85rem 1.5rem; border-bottom: 1px solid var(--site-card-border); background: var(--site-bg); }

/* ============ HEADER PROPRE À "Bienvenue" (réplique de welcom.php .welcome-header) ============ */
.real-welcome-header { display: flex; align-items: center; justify-content: space-between; padding: 0.9rem 1.5rem; border-bottom: 1px solid var(--site-card-border); background: var(--site-bg); gap: 1rem; flex-wrap: wrap; }
.real-welcome-header .rwh-logo { display: flex; align-items: center; gap: 0.5rem; font-weight: 900; font-size: 1.1rem; color: var(--site-text); }
.real-welcome-header .rwh-logo .rpl-mark { width: 34px; height: 34px; border-radius: 9px; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 0.8rem; flex-shrink: 0; }
.real-welcome-header .rwh-nav { display: flex; align-items: center; gap: 1.3rem; font-size: 0.82rem; color: var(--site-text-dim); flex-wrap: wrap; }
.rwh-nav .nav-btn-login { color: var(--site-text); font-weight: 600; }
.rwh-nav .nav-btn-register { background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; padding: 0.5rem 1.1rem; border-radius: 50px; font-weight: 700; }
.builder-canvas[data-device="mobile"] .rwh-nav a:not(.nav-btn-login):not(.nav-btn-register) { display: none; }

/* ============ HEADER PROPRE À "À propos" (réplique de about.php .navbar) ============ */
.real-about-navbar { display: flex; align-items: center; justify-content: space-between; padding: 0.9rem 1.5rem; border-bottom: 1px solid var(--site-card-border); background: var(--site-bg); }
.real-about-navbar .ran-logo { display: flex; align-items: center; gap: 0.5rem; font-weight: 900; font-size: 1.1rem; color: var(--site-text); }
.real-about-navbar .ran-links { display: flex; align-items: center; gap: 1.3rem; font-size: 0.82rem; }
.ran-links .nav-link { color: var(--site-text-dim); }
.ran-links .nav-link.active { color: var(--site-primary); font-weight: 700; }
.ran-links .nav-link-primary { background: var(--site-primary); color: #fff; padding: 0.45rem 1rem; border-radius: 8px; font-weight: 700; }
.ran-links .nav-link-secondary { border: 1px solid var(--site-card-border); color: var(--site-text); padding: 0.45rem 1rem; border-radius: 8px; font-weight: 700; }
.builder-canvas[data-device="mobile"] .ran-links .nav-link:not(.nav-link-primary):not(.nav-link-secondary) { display: none; }

/* ============ HEADER PROPRE À "App Android" (réplique de app_android.php .app-navbar) ============ */
.real-app-navbar { display: flex; align-items: center; justify-content: space-between; padding: 0.9rem 1.5rem; background: #0f172a; color: #fff; }
.real-app-navbar .back-btn { color: rgba(255,255,255,0.85); font-size: 0.85rem; font-weight: 600; }
.real-app-navbar .nav-links-right { display: flex; align-items: center; gap: 0.75rem; }
.real-app-navbar .btn-login { background: var(--site-primary); color: #fff; padding: 0.45rem 1rem; border-radius: 8px; font-size: 0.82rem; font-weight: 700; }
.real-app-navbar .nav-links-right a:not(.btn-login) { color: rgba(255,255,255,0.85); font-size: 0.82rem; font-weight: 600; }
.real-public-logo { display: flex; align-items: center; gap: 0.55rem; font-weight: 900; font-size: 1.15rem; color: var(--site-text); }
.real-public-logo .rpl-mark { width: 36px; height: 36px; border-radius: 9px; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 0.85rem; flex-shrink: 0; }
.real-public-nav { display: flex; gap: 1.5rem; font-size: 0.82rem; color: var(--site-text-dim); }
.real-public-nav a.current { color: var(--site-primary); font-weight: 700; }
.builder-canvas[data-device="mobile"] .real-public-nav,
.builder-canvas[data-device="tablet"] .real-public-nav { display: none; }
.real-public-actions { display: flex; align-items: center; gap: 0.75rem; }
.real-public-login { font-size: 0.82rem; font-weight: 700; color: var(--site-primary); }
.real-public-register { background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; padding: 0.5rem 1.1rem; border-radius: 10px; font-size: 0.8rem; font-weight: 700; }
.real-top-bar { display: flex; justify-content: space-between; align-items: center; padding: 0.7rem 1.25rem; }
.real-brand { display: flex; align-items: center; gap: 0.6rem; text-decoration: none; }
.real-brand-logo { width: 38px; height: 38px; border-radius: 10px; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 900; font-size: 0.9rem; flex-shrink: 0; }
.real-brand-copy { display: flex; flex-direction: column; gap: 0.15rem; }
.real-brand-name { font-size: 1.15rem; font-weight: 800; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.real-merchant-chip { display: inline-flex; align-items: center; gap: 0.3rem; width: fit-content; padding: 0.15rem 0.55rem; border-radius: 50px; background: rgba(245,158,11,0.12); color: #b45309; border: 1px solid rgba(245,158,11,0.25); font-size: 0.65rem; font-weight: 700; }
.real-top-actions { display: flex; align-items: center; gap: 0.5rem; }
.real-btn-recharge, .real-wallet-display { display: flex; align-items: center; gap: 0.4rem; color: #fff; padding: 0.45rem 0.8rem; border-radius: 8px; font-weight: 700; font-size: 0.75rem; white-space: nowrap; text-decoration: none; }
.real-btn-recharge { background: linear-gradient(135deg,#f59e0b,#d97706); }
.real-wallet-display { background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); }
.real-menu-icon { color: var(--site-primary); font-size: 1.15rem; padding: 0.5rem; text-decoration: none; }
.builder-canvas[data-device="mobile"] .real-btn-recharge .rt-text,
.builder-canvas[data-device="mobile"] .real-brand-name { display: none; }

.real-nav-bar { display: flex; justify-content: space-around; align-items: center; border-top: 1px solid var(--site-card-border); padding: 0.35rem 0.5rem; }
.real-nav-item { position: relative; display: flex; flex-direction: column; align-items: center; gap: 0.2rem; padding: 0.5rem 0.85rem; color: var(--site-text-dim); font-size: 1.05rem; border-radius: 8px; }
.real-nav-item.current { color: var(--site-primary); }
.real-nav-item.current::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 20px; height: 3px; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); border-radius: 50px; }
.real-nav-item .rn-badge { position: absolute; top: 0.1rem; right: 0.1rem; background: linear-gradient(135deg,#ef4444,#dc2626); color: #fff; font-size: 0.58rem; font-weight: 700; padding: 0.05rem 0.32rem; border-radius: 50px; min-width: 16px; text-align: center; }

/* ============ PAGE TABS (multi-pages du site) ============ */
.page-tabs { display: flex; gap: 0.4rem; margin-bottom: 1rem; flex-wrap: wrap; align-items: center; }
.page-tab {
    display: flex; align-items: center; gap: 0.5rem; background: var(--panel); border: 1px solid var(--border);
    color: var(--text-dim); padding: 0.55rem 1rem; border-radius: 8px; font-size: 0.85rem; font-weight: 600; cursor: pointer;
}
.page-tab.active { border-color: var(--gold); color: var(--gold); background: rgba(240,165,0,0.08); }
.page-tab i { font-size: 0.8rem; }
.page-more-select {
    background: var(--panel); border: 1px solid var(--border); color: var(--text-dim); padding: 0.55rem 1rem;
    border-radius: 8px; font-size: 0.85rem; font-weight: 600; cursor: pointer; font-family: inherit;
}
.page-more-select.on-other-page { border-color: var(--gold); color: var(--gold); background: rgba(240,165,0,0.08); }

/* ============ BUILDER LAYOUT ============ */
.builder-layout { display: grid; grid-template-columns: 260px 1fr 280px; gap: 1.25rem; align-items: start; }
.section-list[data-page], .site-preview[data-page] { display: none; }
.section-list[data-page].active-page, .site-preview[data-page].active-page { display: flex; }
.site-preview[data-page].active-page { display: block; }

.builder-sections-panel, .builder-editor-panel {
    background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 1rem;
    position: sticky; top: 90px;
}
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.9rem; }
.panel-head h3 { margin: 0; font-size: 0.95rem; }

.section-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.4rem; }
.section-item {
    display: flex; align-items: center; gap: 0.5rem;
    background: var(--panel-2); border: 1px solid var(--border); border-radius: 8px; padding: 0.55rem 0.6rem;
    cursor: grab; font-size: 0.82rem; transition: border-color 0.15s, opacity 0.15s;
}
.section-item.dragging { opacity: 0.4; }
.section-item.selected { border-color: var(--gold); }
.section-item.section-hidden { opacity: 0.45; }
.section-item .drag-handle { color: var(--text-dim); cursor: grab; }
.section-item-info { flex: 1; display: flex; align-items: center; gap: 0.5rem; min-width: 0; cursor: pointer; }
.section-item-info i.type-icon { color: var(--gold); width: 16px; text-align: center; flex-shrink: 0; }
.section-item-info span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.section-delete, .section-duplicate { background: none; border: none; color: var(--text-dim); cursor: pointer; padding: 0.2rem; flex-shrink: 0; }
.section-delete:hover { color: #f87171; }
.section-duplicate:hover { color: var(--gold); }
.section-delete:disabled { opacity: 0.25; cursor: not-allowed; }
.section-drop-line { height: 2px; background: var(--gold); border-radius: 2px; margin: -0.2rem 0; display: none; }
.section-drop-line.active { display: block; }

.mini-switch { position: relative; width: 32px; height: 18px; flex-shrink: 0; }
.mini-switch input { opacity: 0; width: 0; height: 0; }
.mini-switch span {
    position: absolute; inset: 0; background: var(--border); border-radius: 20px; cursor: pointer; transition: background 0.2s;
}
.mini-switch span::before {
    content: ''; position: absolute; width: 14px; height: 14px; left: 2px; top: 2px; background: #fff; border-radius: 50%; transition: transform 0.2s;
}
.mini-switch input:checked + span { background: #10b981; }
.mini-switch input:checked + span::before { transform: translateX(14px); }

.add-section-btn {
    width: 100%; margin-top: 0.75rem; padding: 0.6rem; border-radius: 8px; border: 1px dashed var(--border);
    background: transparent; color: var(--text-dim); font-size: 0.82rem; cursor: pointer;
}
.add-section-btn:hover { border-color: var(--gold); color: var(--gold); }

/* ============ CANVAS ============ */
.builder-canvas-wrap { display: flex; justify-content: center; }
.builder-canvas, .theme-scope {
    width: 100%; max-width: 100%; transition: max-width 0.3s ease;
    background: #0e1015; border: 1px solid var(--border); border-radius: 14px; overflow: hidden;
}
.builder-canvas[data-device="tablet"], .preview-frame[data-device="tablet"] { max-width: 720px; }
.builder-canvas[data-device="mobile"], .preview-frame[data-device="mobile"] { max-width: 380px; }
.canvas-browser-bar { display: flex; gap: 0.4rem; padding: 0.6rem 0.8rem; background: #171a21; }
.canvas-browser-bar span { width: 9px; height: 9px; border-radius: 50%; background: #333; }
/* .preview-frame : même scoping de thème que .builder-canvas/.theme-scope, mais sans l'habillage
   "fenêtre de navigateur" (fond sombre, bordure, coins arrondis) — utilisé par preview.html pour un
   rendu plein écran fidèle à ce que verrait un vrai visiteur du site. */
.preview-frame { width: 100%; max-width: 100%; margin: 0 auto; transition: max-width 0.3s ease; }
/* preview.html donne les 2 classes à son wrapper (builder-canvas + preview-frame) pour hériter
   gratuitement de toutes les règles responsives [data-device=...] déjà écrites pour .builder-canvas,
   tout en annulant l'habillage "fenêtre de navigateur" (fond sombre/bordure/coins arrondis). */
.builder-canvas.preview-frame { background: transparent; border: none; border-radius: 0; overflow: visible; }

/* Masque les affordances d'édition (labels de bloc, contours au survol) en mode preview plein écran. */
.preview-mode .site-block:hover { outline: none; }
.preview-mode .site-block-label { display: none; }
/* .site-btn/.rp-buy sont de vrais <a> en mode preview/public (curseur texte + soulignement
   viennent du contenteditable de l'éditeur, à ignorer une fois affiché comme vrai bouton). */
.preview-mode .site-btn, .preview-mode .rp-buy, .preview-mode .real-mini-btn { cursor: pointer; text-decoration: none; }

/* ============ THEMES DE SITE (10 thèmes complets, appliqués via [data-site-theme] sur .builder-canvas) ============ */
.builder-canvas, .theme-scope, .preview-frame {
    --site-primary: #F0A500; --site-secondary: #d97706; --site-accent: #F0A500;
    --site-bg: #ffffff; --site-bg-alt: #f8f9fb;
    --site-card-bg: #ffffff; --site-card-border: #eeeeee;
    --site-text: #1a1a2e; --site-text-dim: #666666;
}
.builder-canvas[data-site-theme="joboost"], .theme-scope[data-site-theme="joboost"], .preview-frame[data-site-theme="joboost"] { --site-primary:#10b981; --site-secondary:#14b8a6; --site-accent:#f59e0b; }
.builder-canvas[data-site-theme="ocean"], .theme-scope[data-site-theme="ocean"], .preview-frame[data-site-theme="ocean"] { --site-primary:#0284c7; --site-secondary:#06b6d4; }
.builder-canvas[data-site-theme="sunset"], .theme-scope[data-site-theme="sunset"], .preview-frame[data-site-theme="sunset"] { --site-primary:#f97316; --site-secondary:#ef4444; }
.builder-canvas[data-site-theme="purple"], .theme-scope[data-site-theme="purple"], .preview-frame[data-site-theme="purple"] { --site-primary:#7c3aed; --site-secondary:#a855f7; }
.builder-canvas[data-site-theme="rose"], .theme-scope[data-site-theme="rose"], .preview-frame[data-site-theme="rose"] { --site-primary:#e11d48; --site-secondary:#fb7185; }
.builder-canvas[data-site-theme="emerald"], .theme-scope[data-site-theme="emerald"], .preview-frame[data-site-theme="emerald"] { --site-primary:#059669; --site-secondary:#34d399; }
.builder-canvas[data-site-theme="minimal"], .theme-scope[data-site-theme="minimal"], .preview-frame[data-site-theme="minimal"] { --site-primary:#111111; --site-secondary:#666666; }
.builder-canvas[data-site-theme="midnight"], .theme-scope[data-site-theme="midnight"], .preview-frame[data-site-theme="midnight"] {
    --site-primary:#0ea5e9; --site-secondary:#38bdf8;
    --site-bg:#0b0f1a; --site-bg-alt:#0f1524;
    --site-card-bg:#131a2b; --site-card-border:rgba(255,255,255,0.08);
    --site-text:#f4f4f5; --site-text-dim:rgba(255,255,255,0.55);
}
.builder-canvas[data-site-theme="neon"], .theme-scope[data-site-theme="neon"], .preview-frame[data-site-theme="neon"] {
    --site-primary:#ff00e5; --site-secondary:#00f0ff;
    --site-bg:#0a0510; --site-bg-alt:#120a1c;
    --site-card-bg:#170f24; --site-card-border:rgba(255,0,229,0.2);
    --site-text:#f4f4f5; --site-text-dim:rgba(255,255,255,0.55);
}

/* ============ SITE PREVIEW (le site client) ============ */
.site-preview { background: var(--site-bg); color: var(--site-text); font-family: 'Inter', sans-serif; transition: background 0.2s, color 0.2s; }
/* Aucun lien du site client (menus, CTA, footer, etc.) ne doit être souligné par défaut —
   une classe plus spécifique peut réintroduire un soulignement au survol si besoin. */
.builder-canvas a, .theme-scope a, .preview-frame a { text-decoration: none; }
.site-preview-header {
    background: var(--site-bg); position: sticky; top: 0; z-index: 5;
}
.site-block { position: relative; padding: 2.5rem 2rem; border-bottom: 1px dashed transparent; transition: outline 0.15s; }
.site-block:hover { outline: 2px dashed rgba(240,165,0,0.4); outline-offset: -2px; }
.site-block.selected { outline: 2px solid var(--gold); outline-offset: -2px; }
.site-block-label {
    position: absolute; top: 0; left: 0; background: var(--gold); color: #000; font-size: 0.65rem; font-weight: 800;
    padding: 0.15rem 0.5rem; border-radius: 0 0 6px 0; opacity: 0; transition: opacity 0.15s; text-transform: uppercase; letter-spacing: 0.04em;
}
.site-block:hover .site-block-label, .site-block.selected .site-block-label { opacity: 1; }

.site-preview [contenteditable="true"] { outline: none; border-radius: 4px; }
.site-preview [contenteditable="true"]:hover { background: rgba(240,165,0,0.08); }
.site-preview [contenteditable="true"]:focus { background: rgba(240,165,0,0.14); box-shadow: 0 0 0 2px var(--gold); }

/* Hero block — structure calquée sur le vrai hero JOboost (badge, titre en dégradé, double CTA, stats, plateformes) */
.site-block[data-block-type="hero"] {
    position: relative; overflow: hidden; text-align: center; padding: 4.5rem 2rem;
    background: linear-gradient(135deg, var(--site-primary), var(--site-secondary)); color: #fff;
}
.site-block[data-block-type="hero"]::before,
.site-block[data-block-type="hero"]::after {
    content: ''; position: absolute; border-radius: 50%; filter: blur(60px); opacity: 0.22; background: #fff; pointer-events: none;
}
.site-block[data-block-type="hero"]::before { width: 260px; height: 260px; top: -70px; left: -50px; }
.site-block[data-block-type="hero"]::after { width: 200px; height: 200px; bottom: -50px; right: -30px; }
.site-block[data-block-type="hero"][data-variant="minimal"]::before,
.site-block[data-block-type="hero"][data-variant="minimal"]::after { display: none; }

.hero-badge-pill {
    position: relative; z-index: 1; display: inline-flex; align-items: center; gap: 0.4rem;
    background: rgba(255,255,255,0.22); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,0.35);
    padding: 0.4rem 1rem; border-radius: 50px; font-size: 0.78rem; font-weight: 700; margin-bottom: 1.25rem;
}
.site-block[data-block-type="hero"] h1 { position: relative; z-index: 1; font-size: 2.3rem; font-weight: 800; margin: 0 0 0.9rem; line-height: 1.18; }
.hero-highlight { background: linear-gradient(135deg, var(--site-accent), #fff7d6); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.site-block[data-block-type="hero"] p { position: relative; z-index: 1; font-size: 1.02rem; opacity: 0.95; max-width: 560px; margin: 0 auto 1.75rem; line-height: 1.6; }
.site-block.block-bg-dark[data-block-type="hero"] { background: var(--site-bg); }
.site-block.block-bg-light[data-block-type="hero"] { background: var(--site-bg-alt); color: var(--site-text); }

.hero-cta-row { position: relative; z-index: 1; display: flex; justify-content: center; gap: 0.85rem; flex-wrap: wrap; margin-bottom: 2rem; }
.hero-btn-primary { background: #fff !important; color: var(--site-primary) !important; }
.hero-btn-secondary { background: rgba(255,255,255,0.16) !important; color: #fff !important; border: 1px solid rgba(255,255,255,0.4); }

.hero-stats-row { position: relative; z-index: 1; display: flex; justify-content: center; gap: 1.5rem; flex-wrap: wrap; margin-bottom: 1.75rem; }
.hero-stat { background: rgba(255,255,255,0.14); border: 1px solid rgba(255,255,255,0.25); border-radius: 12px; padding: 0.9rem 1.5rem; min-width: 120px; }
.hero-stat .hs-num { font-size: 1.4rem; font-weight: 800; }
.hero-stat .hs-lbl { font-size: 0.72rem; opacity: 0.85; }

.hero-platforms-row { position: relative; z-index: 1; display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; font-size: 0.8rem; opacity: 0.85; }
.hero-platforms-row i { font-size: 1.25rem; opacity: 0.9; }

.site-block[data-block-type="hero"] .site-btn { background: rgba(0,0,0,0.35); color: #fff; }

.site-btn { display: inline-block; padding: 0.75rem 1.75rem; border-radius: 8px; font-weight: 700; font-size: 0.9rem; cursor: text; }

/* Hero variant: minimal */
.site-block[data-block-type="hero"][data-variant="minimal"] {
    background: var(--site-bg); color: var(--site-text); padding: 3rem 2rem; text-align: center;
}
.site-block[data-block-type="hero"][data-variant="minimal"] h1 { font-size: 1.8rem; color: var(--site-text); }
.site-block[data-block-type="hero"][data-variant="minimal"] p { color: var(--site-text-dim); opacity: 1; }
.site-block[data-block-type="hero"][data-variant="minimal"] .site-btn { background: var(--site-primary); color: #fff; }
.hero-badge {
    display: inline-block; background: var(--site-bg-alt); border: 1px solid var(--site-card-border); color: var(--site-primary);
    font-size: 0.72rem; font-weight: 700; padding: 0.3rem 0.9rem; border-radius: 50px; margin-bottom: 1rem;
}

/* Hero variant: split (texte + visuel) */
.site-block[data-block-type="hero"][data-variant="split"] {
    display: grid; grid-template-columns: 1.2fr 1fr; gap: 2rem; align-items: center;
    text-align: left; padding: 3.5rem 2rem;
}
.builder-canvas[data-device="mobile"] .site-block[data-block-type="hero"][data-variant="split"] {
    grid-template-columns: 1fr; text-align: center;
}
.hero-visual { background: rgba(255,255,255,0.14); border-radius: 14px; padding: 1.1rem; }
.hero-visual .hv-row {
    display: flex; justify-content: space-between; gap: 0.75rem; background: rgba(255,255,255,0.16);
    border-radius: 8px; padding: 0.6rem 0.9rem; margin-bottom: 0.5rem; font-size: 0.82rem; font-weight: 600;
}
.hero-visual .hv-row:last-child { margin-bottom: 0; }

/* Page header block (pages internes) */
.site-block[data-block-type="page-header"] { text-align: center; padding: 3rem 2rem; background: var(--site-bg-alt); }
.site-block[data-block-type="page-header"] h1 { font-size: 1.8rem; font-weight: 900; margin: 0 0 0.5rem; color: var(--site-primary); }
.site-block[data-block-type="page-header"] p { color: var(--site-text-dim); }

/* Stats block */
.site-block[data-block-type="stats"] { background: var(--site-bg-alt); padding: 2rem; }
.stats-row { display: flex; justify-content: center; gap: 3rem; flex-wrap: wrap; text-align: center; }
.stats-row .stat { min-width: 100px; }
.stats-row .stat .num { font-size: 1.6rem; font-weight: 900; color: var(--site-secondary); }
.stats-row .stat .lbl { font-size: 0.8rem; color: var(--site-text-dim); }

/* Features block (grille de 6 cartes icône — section "Fonctionnalités" du vrai JOboost) */
.site-block[data-block-type="features"] h2 { text-align: center; font-size: 1.6rem; font-weight: 800; margin: 0 0 0.5rem; color: var(--site-text); }
.site-block[data-block-type="features"] .features-subtitle { text-align: center; color: var(--site-text-dim); font-size: 0.9rem; margin: 0 0 1.75rem; }
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; max-width: 960px; margin: 0 auto; }
.builder-canvas[data-device="mobile"] .features-grid,
.builder-canvas[data-device="mobile"] .hero-stats-row { grid-template-columns: 1fr; }
.feature-card {
    background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.5rem;
    text-align: left; transition: transform 0.2s, border-color 0.2s;
}
.feature-card:hover { transform: translateY(-4px); border-color: var(--site-primary); }
.feature-icon {
    width: 52px; height: 52px; border-radius: 12px; display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--site-primary), var(--site-secondary)); color: #fff; font-size: 1.2rem; margin-bottom: 1rem;
}
.feature-card .feature-title { font-weight: 700; font-size: 1rem; margin-bottom: 0.5rem; color: var(--site-text); }
.feature-card .feature-desc { font-size: 0.84rem; color: var(--site-text-dim); line-height: 1.5; }

/* Services block */
.site-block[data-block-type="services"] h2, .site-block[data-block-type="steps"] h2, .site-block[data-block-type="testimonials"] h2,
.site-block[data-block-type="faq"] h2, .site-block[data-block-type="order-tracking"] h2, .site-block[data-block-type="contact-form"] h2 {
    text-align: center; font-size: 1.5rem; font-weight: 800; margin: 0 0 1.75rem; color: var(--site-text);
}
.services-preview-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; max-width: 900px; margin: 0 auto; }
.builder-canvas[data-device="mobile"] .services-preview-grid,
.builder-canvas[data-device="mobile"] .steps-preview-row,
.builder-canvas[data-device="mobile"] .testimonials-preview-grid,
.builder-canvas[data-device="mobile"] .contact-form-layout { grid-template-columns: 1fr; }
.service-preview-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 10px; padding: 1.25rem; text-align: center; }
.service-preview-card .plat { font-size: 0.7rem; color: var(--site-text-dim); margin-bottom: 0.3rem; }
.service-preview-card .name { font-weight: 700; margin-bottom: 0.5rem; color: var(--site-text); }
.service-preview-card .price { color: var(--site-secondary); font-weight: 800; }

/* Steps block */
.steps-preview-row { display: flex; justify-content: center; gap: 2rem; max-width: 900px; margin: 0 auto; flex-wrap: wrap; }
.step-preview { flex: 1; min-width: 180px; text-align: center; }
.step-preview .step-num { width: 40px; height: 40px; border-radius: 50%; background: var(--site-primary); color: #fff; font-weight: 800; display: flex; align-items: center; justify-content: center; margin: 0 auto 0.75rem; }
.step-preview .step-title { font-weight: 700; margin-bottom: 0.4rem; color: var(--site-text); }
.step-preview .step-desc { font-size: 0.85rem; color: var(--site-text-dim); }

/* Testimonials block */
.site-block[data-block-type="testimonials"] { background: var(--site-bg-alt); }
.testimonials-preview-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; max-width: 900px; margin: 0 auto; }
.testimonial-preview-card { background: var(--site-card-bg); border-radius: 10px; padding: 1.25rem; border: 1px solid var(--site-card-border); }
.testimonial-preview-card .stars { color: var(--site-primary); font-size: 0.8rem; margin-bottom: 0.5rem; }
.testimonial-preview-card .quote { font-size: 0.85rem; color: var(--site-text); margin-bottom: 0.75rem; }
.testimonial-preview-card .author { font-weight: 700; font-size: 0.82rem; color: var(--site-text); }

/* FAQ block */
.faq-preview-list { max-width: 700px; margin: 0 auto; display: flex; flex-direction: column; gap: 0.6rem; }
.faq-preview-item { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 8px; padding: 0.9rem 1.1rem; }
.faq-preview-item summary { font-weight: 700; cursor: pointer; font-size: 0.9rem; color: var(--site-text); }
.faq-preview-item p { margin-top: 0.6rem; font-size: 0.85rem; color: var(--site-text-dim); }

/* CTA block */
.site-block[data-block-type="cta"] { background: var(--site-bg); color: var(--site-text); text-align: center; }
.site-block[data-block-type="cta"] h2 { font-size: 1.6rem; margin: 0 0 1rem; color: var(--site-text); }
.site-block[data-block-type="cta"] .site-btn { background: var(--site-primary); color: #fff; }
.site-block.block-bg-light[data-block-type="cta"] { background: var(--site-bg-alt); }
.site-block.block-bg-dark[data-block-type="cta"] { background: var(--site-text); color: var(--site-bg); }

/* Order widget block (typique des sites SMM panel) */
.site-block[data-block-type="order"] { background: var(--site-bg); }
.order-widget, .tracking-widget, .contact-form-widget {
    max-width: 480px; margin: 0 auto; background: var(--site-bg-alt); border: 1px solid var(--site-card-border);
    border-radius: 14px; padding: 1.5rem; text-align: left;
}
.order-widget .ow-row, .tracking-widget .ow-row, .contact-form-widget .ow-row { margin-bottom: 0.9rem; }
.order-widget .ow-row label, .tracking-widget .ow-row label, .contact-form-widget .ow-row label {
    display: block; font-size: 0.75rem; color: var(--site-text-dim); margin-bottom: 0.35rem; text-transform: uppercase; letter-spacing: 0.03em;
}
.order-widget .ow-fake-select, .order-widget .ow-fake-input,
.tracking-widget .ow-fake-input, .contact-form-widget .ow-fake-input, .contact-form-widget .ow-fake-textarea {
    background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 8px; padding: 0.65rem 0.85rem; font-size: 0.88rem; color: var(--site-text);
}
.contact-form-widget .ow-fake-textarea { min-height: 70px; }
.order-widget .ow-total { display: flex; justify-content: space-between; align-items: center; padding-top: 0.75rem; border-top: 1px dashed var(--site-card-border); margin-top: 0.25rem; }
.order-widget .ow-total .ow-price { font-size: 1.3rem; font-weight: 900; color: var(--site-secondary); }
.order-widget .site-btn, .tracking-widget .site-btn, .contact-form-widget .site-btn { width: 100%; text-align: center; margin-top: 1rem; box-sizing: border-box; background: var(--site-primary); color: #fff; }
.platform-icons-row { display: flex; justify-content: center; gap: 1.25rem; margin-top: 1.5rem; flex-wrap: wrap; }
.platform-icons-row i { font-size: 1.4rem; opacity: 0.9; }

/* Order tracking block */
.site-block[data-block-type="order-tracking"] { background: var(--site-bg); }
.tracking-widget .ow-result { margin-top: 1rem; padding: 0.85rem; border-radius: 8px; background: rgba(16,185,129,0.12); color: #10b981; font-size: 0.85rem; font-weight: 600; }

/* Contact form block */
.site-block[data-block-type="contact-form"] { background: var(--site-bg-alt); }
.contact-form-layout { display: grid; grid-template-columns: 1.2fr 1fr; gap: 1.5rem; max-width: 900px; margin: 0 auto; }
.contact-info-side { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 14px; padding: 1.5rem; }
.contact-info-side .ci-row { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 1rem; font-size: 0.85rem; color: var(--site-text); }
.contact-info-side .ci-row i { color: var(--site-primary); width: 18px; }

/* Payment badges block */
.site-block[data-block-type="payment"] { background: var(--site-bg-alt); padding: 2rem; }
.payment-badges-row { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.payment-badge { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 8px; padding: 0.6rem 1.1rem; display: flex; align-items: center; gap: 0.5rem; font-size: 0.8rem; font-weight: 600; color: var(--site-text); }
.payment-badge i { color: var(--site-secondary); }

/* Auth form block (login / inscription / mot de passe oublié) — réplique du vrai login.php JOboost */
.site-block[data-block-type="auth-form"] { background: linear-gradient(135deg, #f9fafb, #e5e7eb); padding: 3rem 1.5rem; }
.real-auth-card { max-width: 440px; margin: 0 auto; background: #fff; border-radius: 1.5rem; box-shadow: 0 20px 25px rgba(0,0,0,0.15); overflow: hidden; text-align: left; }
.real-auth-header { background: linear-gradient(135deg, var(--site-primary), var(--site-secondary)); padding: 2.5rem 2rem; text-align: center; color: #fff; }
.real-auth-header .rah-logo { width: 60px; height: 60px; border-radius: 50%; background: rgba(255,255,255,0.2); display: flex; align-items: center; justify-content: center; font-size: 1.4rem; margin: 0 auto 1rem; }
.real-auth-header h1 { font-size: 1.7rem; font-weight: 800; margin-bottom: 0.4rem; }
.real-auth-header p { opacity: 0.95; font-size: 0.9rem; margin: 0; }
.real-auth-body { padding: 2rem; }
.real-auth-body .form-group { position: relative; margin-bottom: 1.1rem; }
.real-auth-body .form-group label { display: flex; align-items: center; gap: 0.4rem; font-size: 0.85rem; font-weight: 600; color: #374151; margin-bottom: 0.5rem; }
.real-input-wrapper { position: relative; }
.real-input-wrapper i.ri-icon { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: #9ca3af; font-size: 0.9rem; }
.real-auth-body .ow-fake-input { width: 100%; box-sizing: border-box; padding: 0.85rem 1rem 0.85rem 2.75rem; border: 2px solid #e5e7eb; border-radius: 1rem; font-size: 0.92rem; color: #111827; background: #fff; }
.real-auth-body .ow-fake-input.no-icon { padding-left: 1rem; padding-right: 3rem; }
.real-toggle-eye { position: absolute; right: 1rem; top: 50%; transform: translateY(-50%); color: #9ca3af; }
.real-toggle-eye.toggle-password-btn { cursor: pointer; }
.real-form-options { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.25rem; font-size: 0.85rem; flex-wrap: wrap; gap: 0.5rem; }
.real-form-options label { display: flex; align-items: center; gap: 0.4rem; font-weight: 400; color: #374151; margin: 0; }
.real-form-options a { color: var(--site-primary); font-weight: 600; }
.real-auth-body .site-btn.real-submit-btn { display: block; width: 100%; box-sizing: border-box; background: linear-gradient(135deg, var(--site-primary), var(--site-secondary)); color: #fff; text-align: center; padding: 0.9rem; border-radius: 1rem; font-size: 0.95rem; }
.real-divider { display: flex; align-items: center; gap: 0.75rem; margin: 1.25rem 0; color: #9ca3af; font-size: 0.8rem; }
.real-divider::before, .real-divider::after { content: ''; flex: 1; height: 1px; background: #e5e7eb; }
.real-google-btn { width: 100%; box-sizing: border-box; border: 2px solid #e5e7eb; border-radius: 1rem; padding: 0.8rem; display: flex; align-items: center; justify-content: center; gap: 0.6rem; font-weight: 600; font-size: 0.9rem; color: #374151; background: #fff; }
.real-auth-footer-links { text-align: center; margin-top: 1.25rem; font-size: 0.85rem; color: #6b7280; }
.real-auth-footer-links a { color: var(--site-primary); font-weight: 600; }
.real-auth-legal { text-align: center; margin-top: 0.85rem; font-size: 0.76rem; color: #9ca3af; }
.real-auth-legal a { color: #9ca3af; }
.auth-form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }

/* Dashboard summary block (tableau de bord client) */
.site-block[data-block-type="dashboard-summary"] { background: var(--site-bg); text-align: left; }
.ds-greeting { font-size: 1.3rem; font-weight: 800; margin-bottom: 1.25rem; color: var(--site-text); }
.ds-stats-row { display: flex; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.ds-stat-card { flex: 1; min-width: 140px; background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 10px; padding: 1rem; }
.ds-stat-card .ds-val { font-size: 1.3rem; font-weight: 900; color: var(--site-primary); }
.ds-stat-card .ds-lbl { font-size: 0.78rem; color: var(--site-text-dim); }
.ds-table { width: 100%; border-collapse: collapse; font-size: 0.85rem; }
.ds-table th { text-align: left; color: var(--site-text-dim); font-size: 0.72rem; text-transform: uppercase; padding: 0.5rem 0.6rem; border-bottom: 1px solid var(--site-card-border); }
.ds-table td { padding: 0.6rem; border-bottom: 1px solid var(--site-card-border); color: var(--site-text); }
.ds-badge { display: inline-block; padding: 0.15rem 0.6rem; border-radius: 50px; font-size: 0.7rem; font-weight: 700; background: rgba(16,185,129,0.15); color: #10b981; }

/* Wallet widget block */
.site-block[data-block-type="wallet-widget"] { background: var(--site-bg-alt); }
.wallet-balance-card {
    max-width: 420px; margin: 0 auto 1.25rem; background: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%);
    color: #fff; border-radius: 14px; padding: 1.5rem; text-align: center;
}
.wallet-balance-card .wb-label { font-size: 0.78rem; opacity: 0.85; text-transform: uppercase; letter-spacing: 0.04em; }
.wallet-balance-card .wb-amount { font-size: 2rem; font-weight: 900; margin: 0.4rem 0 1rem; }
.wallet-balance-card .site-btn { background: rgba(0,0,0,0.3); color: #fff; }

/* Generic data list block (transactions, notifications, messages, favoris) */
.site-block[data-block-type="data-list"] { background: var(--site-bg); }
.data-list-widget { max-width: 640px; margin: 0 auto; display: flex; flex-direction: column; gap: 0.6rem; }
.data-list-row {
    display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 10px; padding: 0.85rem 1.1rem;
}
.data-list-row .dl-main { font-weight: 700; font-size: 0.88rem; color: var(--site-text); }
.data-list-row .dl-sub { font-size: 0.76rem; color: var(--site-text-dim); }
.data-list-row .dl-side { font-size: 0.82rem; font-weight: 700; color: var(--site-secondary); white-space: nowrap; }

/* Profile form block (gestion du compte) */
.site-block[data-block-type="profile-form"] { background: var(--site-bg-alt); }
.profile-form-widget { max-width: 480px; margin: 0 auto; background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 14px; padding: 1.5rem; text-align: left; }
.profile-form-widget .ow-row { margin-bottom: 0.9rem; }
.profile-form-widget .ow-row label { display: block; font-size: 0.75rem; color: var(--site-text-dim); margin-bottom: 0.35rem; text-transform: uppercase; letter-spacing: 0.03em; }
.profile-form-widget .ow-fake-input { background: var(--site-bg); border: 1px solid var(--site-card-border); border-radius: 8px; padding: 0.65rem 0.85rem; font-size: 0.88rem; color: var(--site-text); }
.profile-form-widget .site-btn { background: var(--site-primary); color: #fff; margin-top: 0.5rem; }

/* Status message block (expiré, échec paiement) */
.site-block[data-block-type="status-message"] { background: var(--site-bg); padding: 3.5rem 2rem; }
.status-icon { width: 72px; height: 72px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.25rem; font-size: 1.8rem; }
.status-icon.status-warning { background: rgba(245,158,11,0.15); color: #f59e0b; }
.status-icon.status-danger { background: rgba(239,68,68,0.15); color: #ef4444; }
.site-block[data-block-type="status-message"] h1 { font-size: 1.5rem; margin-bottom: 0.5rem; color: var(--site-text); }
.site-block[data-block-type="status-message"] p { color: var(--site-text-dim); max-width: 420px; margin: 0 auto 1.5rem; }
.site-block[data-block-type="status-message"] .site-btn { background: var(--site-primary); color: #fff; }

/* Urgency bar block (bandeau d'urgence en haut du vrai JOboost) */
.site-block[data-block-type="urgency-bar"] {
    background: linear-gradient(90deg, #111827, #1e293b, #111827); color: #fff; padding: 0.7rem 1.5rem;
    display: flex; align-items: center; justify-content: center; gap: 0.75rem; flex-wrap: wrap; text-align: center;
}
.urgency-dot { width: 8px; height: 8px; border-radius: 50%; background: #ef4444; flex-shrink: 0; animation: ub-pulse 1.6s infinite; }
@keyframes ub-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.site-block[data-block-type="urgency-bar"] .site-btn { padding: 0.35rem 1rem; font-size: 0.78rem; background: var(--site-primary); color: #fff; }

/* Payment countries block (grille par pays) */
.site-block[data-block-type="payment-countries"] { background: var(--site-bg-alt); }
.countries-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; max-width: 1000px; margin: 0 auto; }
.builder-canvas[data-device="tablet"] .countries-grid { grid-template-columns: repeat(2, 1fr); }
.builder-canvas[data-device="mobile"] .countries-grid { grid-template-columns: 1fr; }
.country-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 10px; padding: 1rem; text-align: center; }
.country-card .cc-flag { font-size: 1.6rem; margin-bottom: 0.4rem; }
.country-card .cc-flag .fi { font-size: 1.1rem; border-radius: 3px; box-shadow: 0 0 0 1px rgba(0,0,0,0.08); }
.t-role .fi { font-size: 0.85rem; border-radius: 2px; vertical-align: -1px; margin-right: 0.15rem; }
.country-card .cc-name { font-weight: 700; font-size: 0.85rem; color: var(--site-text); margin-bottom: 0.3rem; }
.country-card .cc-methods { font-size: 0.72rem; color: var(--site-text-dim); }
.country-card .cc-badge { display: inline-block; margin-top: 0.5rem; font-size: 0.65rem; font-weight: 700; padding: 0.15rem 0.5rem; border-radius: 50px; background: rgba(16,185,129,0.15); color: #10b981; }

/* Top services block (dark) */
.site-block[data-block-type="top-services"] { background: linear-gradient(135deg, #0f172a, #1e293b, #0f172a); }
.site-block[data-block-type="top-services"] h2 { color: #fff; text-align: center; font-size: 1.5rem; font-weight: 800; margin: 0 0 1.75rem; }
.top-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; max-width: 960px; margin: 0 auto; }
.builder-canvas[data-device="mobile"] .top-services-grid,
.builder-canvas[data-device="mobile"] .countries-grid,
.builder-canvas[data-device="mobile"] .contact-cards-grid { grid-template-columns: 1fr; }
.top-service-card { position: relative; background: #fff; border-radius: 12px; padding: 1.25rem; text-align: left; }
.top-service-card .tsc-badge { position: absolute; top: 0.75rem; right: 0.75rem; font-size: 0.62rem; font-weight: 800; padding: 0.15rem 0.5rem; border-radius: 50px; background: rgba(59,130,246,0.15); color: #3b82f6; }
.top-service-card .tsc-cat { display: inline-flex; align-items: center; gap: 0.3rem; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; font-size: 0.65rem; font-weight: 700; padding: 0.2rem 0.6rem; border-radius: 50px; margin-bottom: 0.6rem; }
.top-service-card .tsc-title { font-weight: 700; font-size: 0.95rem; color: #1a1a2e; margin-bottom: 0.3rem; }
.top-service-card .tsc-min { font-size: 0.72rem; color: #777; margin-bottom: 0.75rem; }
.top-service-card .tsc-price { font-size: 1.3rem; font-weight: 900; color: var(--site-secondary); border-top: 1px dashed #eee; padding-top: 0.6rem; }

/* Testimonials carousel chrome */
.testimonials-carousel { max-width: 700px; margin: 0 auto; }
.testimonial-slide { display: none; background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 14px; padding: 2rem; text-align: center; }
.testimonial-slide.active { display: block; }
.testimonial-slide .quote-icon { font-size: 1.5rem; color: var(--site-primary); opacity: 0.4; margin-bottom: 0.75rem; }
.testimonial-slide .quote-text { font-size: 1.05rem; font-style: italic; color: var(--site-text); margin-bottom: 1.25rem; line-height: 1.6; }
.testimonial-slide .t-author-row { display: flex; align-items: center; justify-content: center; gap: 0.75rem; margin-bottom: 0.75rem; }
.testimonial-slide .t-avatar { width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; }
.testimonial-slide .t-name { font-weight: 700; color: var(--site-text); font-size: 0.9rem; text-align: left; }
.testimonial-slide .t-role { font-size: 0.76rem; color: var(--site-text-dim); text-align: left; }
.testimonial-slide .t-stars { color: var(--site-accent); margin-bottom: 0.75rem; }
.testimonial-slide .t-result { display: inline-block; background: var(--site-bg-alt); border-radius: 50px; padding: 0.4rem 1rem; font-size: 0.8rem; font-weight: 700; color: var(--site-primary); }
.carousel-nav { display: flex; justify-content: center; align-items: center; gap: 1rem; margin-top: 1.25rem; }
.carousel-arrow { width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--site-card-border); background: var(--site-card-bg); color: var(--site-text); cursor: pointer; display: flex; align-items: center; justify-content: center; }
.carousel-dots { display: flex; gap: 0.4rem; }
.carousel-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--site-card-border); cursor: pointer; border: none; padding: 0; }
.carousel-dot.active { background: var(--site-primary); width: 20px; border-radius: 4px; }

/* Brand story block (JOMAK) */
.site-block[data-block-type="brand-story"] {
    background: linear-gradient(135deg, var(--site-primary), var(--site-secondary)); color: #fff; text-align: left;
}
.brand-story-layout { display: grid; grid-template-columns: 1fr 1.3fr; gap: 2.5rem; align-items: center; max-width: 980px; margin: 0 auto; }
.builder-canvas[data-device="mobile"] .brand-story-layout { grid-template-columns: 1fr; text-align: center; }
.brand-story-media { width: 100%; aspect-ratio: 1; border-radius: 16px; background: rgba(255,255,255,0.14); border: 1px solid rgba(255,255,255,0.25); display: flex; align-items: center; justify-content: center; font-size: 3rem; }
.site-block[data-block-type="brand-story"] h2 { font-size: 1.9rem; font-weight: 800; margin: 0 0 1rem; }
.site-block[data-block-type="brand-story"] p { opacity: 0.95; margin-bottom: 1.25rem; line-height: 1.6; }
.brand-story-features { list-style: none; padding: 0; margin: 0 0 1.5rem; display: flex; flex-direction: column; gap: 0.6rem; }
.brand-story-features li { display: flex; align-items: center; gap: 0.6rem; font-size: 0.88rem; }
.brand-story-features i { color: #fff; background: rgba(255,255,255,0.2); border-radius: 50%; width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; font-size: 0.65rem; flex-shrink: 0; }
.site-block[data-block-type="brand-story"] .site-btn { background: #fff; color: var(--site-primary); }

/* Final CTA block (fermeture de page façon JOboost) */
.site-block[data-block-type="final-cta"] { background: linear-gradient(135deg, #0f172a, #1e293b, #0f172a); color: #fff; }
.final-cta-badge { display: inline-flex; align-items: center; gap: 0.4rem; background: rgba(16,185,129,0.15); border: 1px solid rgba(16,185,129,0.3); color: #34d399; padding: 0.35rem 1rem; border-radius: 50px; font-size: 0.75rem; font-weight: 700; margin-bottom: 1.25rem; }
.site-block[data-block-type="final-cta"] h2 { font-size: 1.8rem; font-weight: 800; margin: 0 0 0.75rem; }
.site-block[data-block-type="final-cta"] p { opacity: 0.85; max-width: 500px; margin: 0 auto 1.75rem; }
.final-cta-row { display: flex; justify-content: center; gap: 0.85rem; flex-wrap: wrap; margin-bottom: 1.75rem; }
.final-cta-row .fc-btn-primary { background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; }
.final-cta-row .fc-btn-whatsapp { background: #25d366; color: #fff; }
.final-cta-guarantees { display: flex; justify-content: center; gap: 1.75rem; flex-wrap: wrap; font-size: 0.78rem; opacity: 0.75; }
.final-cta-guarantees span i { color: #34d399; margin-right: 0.35rem; }

/* Contact section block (cartes + réseaux sociaux) */
.site-block[data-block-type="contact-section"] { background: var(--site-bg-alt); }
.contact-cards-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; max-width: 800px; margin: 0 auto 2rem; }
.contact-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.5rem; text-align: center; }
.contact-card-icon { width: 52px; height: 52px; border-radius: 50%; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; display: flex; align-items: center; justify-content: center; margin: 0 auto 0.9rem; font-size: 1.1rem; }
.contact-card .cc-title { font-weight: 700; font-size: 0.85rem; color: var(--site-text-dim); margin-bottom: 0.3rem; }
.contact-card .cc-value { font-weight: 700; color: var(--site-text); font-size: 0.95rem; }
.social-icons-row { display: flex; justify-content: center; gap: 0.85rem; flex-wrap: wrap; }
.social-icon-btn { width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-size: 1.1rem; }
.social-icon-btn.si-facebook { background: linear-gradient(135deg,#1877f2,#0c63d4); }
.social-icon-btn.si-instagram { background: linear-gradient(135deg,#e4405f,#c13584); }
.social-icon-btn.si-tiktok { background: linear-gradient(135deg,#000,#1a1a1a); }
.social-icon-btn.si-youtube { background: linear-gradient(135deg,#ff0000,#cc0000); }
.social-icon-btn.si-whatsapp { background: linear-gradient(135deg,#25d366,#20ba5a); }
.social-icon-btn.si-x { background: linear-gradient(135deg,#000,#333); }

/* ============ COMPOSANTS PARTAGÉS "COMPTE CLIENT" (réplique fidèle des vraies pages JOboost) ============ */
.real-section-title { display: flex; align-items: center; gap: 0.6rem; font-size: 1.3rem; font-weight: 800; color: var(--site-text); margin: 0 0 0.3rem; }
.real-section-sub { color: var(--site-text-dim); font-size: 0.88rem; margin: 0 0 1.5rem; }
.real-voir-tout { font-size: 0.8rem; color: var(--site-primary); font-weight: 700; }

.real-stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 1.75rem; }
.builder-canvas[data-device="mobile"] .real-stat-grid,
.builder-canvas[data-device="mobile"] .real-quick-grid,
.builder-canvas[data-device="mobile"] .real-dashboard-cols,
.builder-canvas[data-device="mobile"] .real-fav-grid,
.builder-canvas[data-device="mobile"] .real-info-row-4 { grid-template-columns: 1fr; }
.real-stat-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-left: 4px solid var(--site-primary); border-radius: 10px; padding: 1rem 1.1rem; }
.real-stat-card.rs-blue { border-left-color: #3b82f6; }
.real-stat-card.rs-amber { border-left-color: #f59e0b; }
.real-stat-card.rs-red { border-left-color: #ef4444; }
.real-stat-card .rs-icon { color: var(--site-text-dim); font-size: 0.85rem; margin-bottom: 0.4rem; }
.real-stat-card .rs-val { font-size: 1.3rem; font-weight: 900; color: var(--site-text); }
.real-stat-card .rs-lbl { font-size: 0.76rem; color: var(--site-text-dim); }

.real-dashboard-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-bottom: 1.75rem; }
.real-mini-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.25rem; }
.real-mini-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; font-weight: 700; color: var(--site-text); font-size: 0.92rem; }
.real-empty-state { text-align: center; padding: 1.5rem 0.5rem; color: var(--site-text-dim); font-size: 0.85rem; }
.real-empty-state i { font-size: 1.6rem; margin-bottom: 0.5rem; display: block; opacity: 0.5; }

.real-quick-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.9rem; }
.real-quick-btn { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 10px; padding: 1rem 0.5rem; text-align: center; }
.real-quick-btn i { font-size: 1.2rem; color: var(--site-primary); margin-bottom: 0.5rem; display: block; }
.real-quick-btn span { font-size: 0.78rem; font-weight: 600; color: var(--site-text); }

.real-info-box { border-left: 4px solid var(--site-primary); background: rgba(16,185,129,0.06); border-radius: 8px; padding: 1rem 1.25rem; margin-bottom: 1.25rem; font-size: 0.85rem; color: var(--site-text); }
.real-info-box.amber { border-left-color: #f59e0b; background: rgba(245,158,11,0.08); }
.real-info-box.blue { border-left-color: #3b82f6; background: rgba(59,130,246,0.08); }
.real-info-box.red { border-left-color: #ef4444; background: rgba(239,68,68,0.08); }
.real-info-box h4 { margin: 0 0 0.4rem; font-size: 0.9rem; }
.real-info-box ol, .real-info-box ul { margin: 0.5rem 0 0 1.1rem; padding: 0; }

.real-quick-amounts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.6rem; margin-bottom: 1rem; }
.real-amount-btn { background: var(--site-card-bg); border: 2px solid var(--site-card-border); border-radius: 8px; padding: 0.65rem; text-align: center; font-weight: 700; font-size: 0.88rem; color: var(--site-text); }
.real-amount-btn.selected { border-color: var(--site-primary); color: var(--site-primary); }

.real-filter-row { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.real-filter-btn { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 50px; padding: 0.45rem 1rem; font-size: 0.8rem; font-weight: 600; color: var(--site-text-dim); }
.real-filter-btn.active { background: var(--site-primary); border-color: var(--site-primary); color: #fff; }

.real-order-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.1rem 1.25rem; margin-bottom: 0.85rem; }
.real-order-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.6rem; flex-wrap: wrap; gap: 0.5rem; }
.real-order-head .ro-title { font-weight: 700; color: var(--site-text); font-size: 0.92rem; }
.real-order-meta { display: flex; gap: 1.25rem; flex-wrap: wrap; font-size: 0.78rem; color: var(--site-text-dim); margin-bottom: 0.6rem; }
.real-order-meta span i { margin-right: 0.3rem; color: var(--site-primary); }
.real-order-actions { display: flex; gap: 0.6rem; margin-top: 0.6rem; }
.real-mini-btn { display: inline-block; padding: 0.4rem 0.9rem; border-radius: 8px; border: 1px solid var(--site-card-border); background: transparent; color: var(--site-text); font-weight: 600; font-size: 0.78rem; }
.real-mini-btn.danger { color: #ef4444; border-color: rgba(239,68,68,0.3); }
.real-mini-btn.active { background: var(--site-primary); color: #fff; border-color: var(--site-primary); }

.real-notif-card { display: flex; gap: 0.9rem; background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-left: 4px solid var(--site-card-border); border-radius: 10px; padding: 1rem 1.1rem; margin-bottom: 0.7rem; }
.real-notif-card.unread { border-left-color: var(--site-primary); }
.real-notif-card .rn-icon { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; background: rgba(16,185,129,0.12); color: var(--site-primary); }
.real-notif-card .rn-title { font-weight: 700; font-size: 0.88rem; color: var(--site-text); margin-bottom: 0.2rem; }
.real-notif-card .rn-msg { font-size: 0.82rem; color: var(--site-text-dim); }
.real-notif-card .rn-time { font-size: 0.72rem; color: var(--site-text-dim); margin-top: 0.3rem; }

.real-post-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem; }
.real-post-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.1rem 1.25rem; }
.real-post-card .rp-head { display: flex; align-items: center; gap: 0.7rem; margin-bottom: 0.7rem; }
.real-post-card .rp-avatar { width: 38px; height: 38px; border-radius: 50%; background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.82rem; flex-shrink: 0; }
.real-post-card .rp-author { font-weight: 700; font-size: 0.86rem; color: var(--site-text); }
.real-post-card .rp-time { font-size: 0.72rem; color: var(--site-text-dim); }
.real-post-card .rp-content { font-size: 0.85rem; color: var(--site-text); margin-bottom: 0.85rem; }
.real-post-card .rp-actions { display: flex; gap: 1.25rem; font-size: 0.78rem; color: var(--site-text-dim); border-top: 1px solid var(--site-card-border); padding-top: 0.7rem; }
.real-post-card .rp-actions i { margin-right: 0.35rem; }

/* Catalogue de services (réplique de public_html/index.php, état connecté) */
.real-search-bar { display: flex; gap: 0.6rem; max-width: 600px; margin: 0 auto 1.5rem; }
.real-search-bar .ow-fake-input { flex: 1; margin: 0; }
.real-filter-pills-row { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 1rem; }
.real-catalog-selects-row { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.25rem; }
.real-catalog-selects-row .ow-fake-input { min-width: 180px; margin: 0; }
.real-catalog-actions-row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.75rem; margin-bottom: 1.5rem; }
.real-product-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.real-product-card { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.1rem; }
.real-product-card .rp-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 0.7rem; gap: 0.5rem; }
.real-product-card .rp-badges { display: flex; gap: 0.35rem; flex-wrap: wrap; }
.real-product-card .rp-platform-badge { background: rgba(16,185,129,0.12); color: var(--site-primary); font-size: 0.65rem; font-weight: 700; padding: 0.2rem 0.55rem; border-radius: 50px; }
.real-product-card .rp-code-badge { background: var(--site-bg-alt); color: var(--site-text-dim); font-size: 0.65rem; padding: 0.2rem 0.5rem; border-radius: 50px; }
.real-product-card .rp-fav { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--site-card-border); display: flex; align-items: center; justify-content: center; color: #9ca3af; flex-shrink: 0; font-size: 0.85rem; }
.real-product-card .rp-title { font-weight: 700; color: var(--site-text); margin-bottom: 0.35rem; font-size: 0.95rem; }
.real-product-card .rp-desc { font-size: 0.78rem; color: var(--site-text-dim); margin-bottom: 0.5rem; }
.real-product-card .rp-stats { font-size: 0.72rem; margin-bottom: 0.65rem; color: var(--site-text-dim); }
.real-product-card .rp-price { font-weight: 800; color: var(--site-text); margin-bottom: 0.8rem; }
.real-product-card .rp-buy { display: block; text-align: center; background: var(--site-primary); color: #fff; border-radius: 8px; padding: 0.6rem; font-size: 0.82rem; font-weight: 700; text-decoration: none; }
.builder-canvas[data-device="mobile"] .real-product-grid,
.preview-frame[data-device="mobile"] .real-product-grid { grid-template-columns: 1fr; }
.builder-canvas[data-device="tablet"] .real-product-grid,
.preview-frame[data-device="tablet"] .real-product-grid { grid-template-columns: repeat(2, 1fr); }

.real-fav-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.real-fav-card { position: relative; background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.25rem; }
.real-fav-card .fc-remove { position: absolute; top: 0.75rem; right: 0.75rem; width: 26px; height: 26px; border-radius: 50%; background: rgba(239,68,68,0.1); color: #ef4444; display: flex; align-items: center; justify-content: center; font-size: 0.75rem; }
.real-fav-card .fc-platform { display: inline-block; background: linear-gradient(135deg,#3b82f6,#2563eb); color: #fff; font-size: 0.65rem; font-weight: 700; padding: 0.2rem 0.6rem; border-radius: 50px; margin-bottom: 0.6rem; }
.real-fav-card .fc-title { font-weight: 700; color: var(--site-text); margin-bottom: 0.4rem; }
.real-fav-card .fc-stats { font-size: 0.75rem; color: var(--site-text-dim); margin-bottom: 0.6rem; }
.real-fav-card .fc-price { font-size: 1.1rem; font-weight: 900; color: var(--site-secondary); margin-bottom: 0.75rem; }
.real-fav-card .site-btn { width: 100%; box-sizing: border-box; text-align: center; background: var(--site-primary); color: #fff; }

.real-form-section { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 12px; padding: 1.5rem; margin-bottom: 1.25rem; text-align: left; }
.real-form-section h3 { display: flex; align-items: center; gap: 0.5rem; font-size: 1rem; margin: 0 0 1.1rem; color: var(--site-text); }

.real-info-row-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; background: var(--site-bg-alt); border-radius: 10px; padding: 1rem 1.25rem; margin-bottom: 1.25rem; }
.real-info-row-4 .ri-lbl { font-size: 0.72rem; color: var(--site-text-dim); text-transform: uppercase; margin-bottom: 0.25rem; }
.real-info-row-4 .ri-val { font-weight: 700; color: var(--site-text); font-size: 0.85rem; }

.real-price-display { text-align: center; background: var(--site-bg-alt); border-radius: 10px; padding: 1rem; margin: 1rem 0; }
.real-price-display .pd-lbl { font-size: 0.78rem; color: var(--site-text-dim); }
.real-price-display .pd-val { font-size: 1.5rem; font-weight: 900; color: var(--site-secondary); }

.real-wallet-balance-row { display: flex; justify-content: space-between; align-items: center; background: var(--site-bg-alt); border-radius: 8px; padding: 0.85rem 1.1rem; margin-bottom: 1.25rem; font-size: 0.85rem; }
.real-wallet-balance-row strong { color: var(--site-primary); font-size: 1rem; }

.real-status-icon-lg { width: 90px; height: 90px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.25rem; font-size: 2.2rem; }
.real-status-icon-lg.amber { background: rgba(245,158,11,0.14); color: #f59e0b; }
.real-status-icon-lg.red { background: rgba(239,68,68,0.14); color: #ef4444; }
.real-status-icon-lg.blue { background: rgba(59,130,246,0.14); color: #3b82f6; }
.real-owner-box { background: var(--site-bg-alt); border-radius: 10px; padding: 1rem 1.25rem; margin: 1.25rem auto; max-width: 480px; text-align: left; font-size: 0.85rem; color: var(--site-text-dim); }
.real-owner-box strong { color: var(--site-text); }

.real-msg-template { background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 10px; padding: 1rem 1.25rem; margin-bottom: 0.75rem; text-align: left; }
.real-msg-template .mt-head { display: flex; align-items: center; gap: 0.5rem; font-weight: 700; color: var(--site-text); margin-bottom: 0.4rem; font-size: 0.88rem; }
.real-msg-template .mt-head i { color: #10b981; }
.real-msg-template .mt-body { font-size: 0.8rem; color: var(--site-text-dim); font-style: italic; }

/* États de chargement des pages (fetch dashboard/includes/pages/*.html) */
.page-loading, .page-load-error {
    padding: 4rem 2rem; text-align: center; font-size: 0.9rem; color: var(--site-text-dim); background: var(--site-bg);
}
.page-loading i { color: var(--site-primary); margin-right: 0.5rem; }
.page-load-error { color: #dc2626; max-width: 480px; margin: 0 auto; line-height: 1.6; }
.page-load-error i { margin-right: 0.5rem; }

/* Footer block */
.site-block[data-block-type="footer"] { background: #0e1015; color: rgba(255,255,255,0.6); text-align: center; font-size: 0.82rem; padding: 1.5rem 2rem; }
.footer-brand-row { display: flex; align-items: center; justify-content: center; gap: 0.5rem; font-weight: 800; font-size: 1.1rem; color: #fff; margin-bottom: 0.5rem; }
.footer-links-row { display: flex; justify-content: center; gap: 1.25rem; flex-wrap: wrap; margin-top: 0.6rem; font-size: 0.8rem; }
.footer-links-row a { color: rgba(255,255,255,0.6); }

.block-align-left .site-block-inner, .site-block.block-align-left { text-align: left !important; }

/* ============ EDITOR PANEL ============ */
.editor-empty { text-align: center; color: var(--text-dim); font-size: 0.85rem; padding: 2rem 0.5rem; }
.editor-empty i { font-size: 1.5rem; margin-bottom: 0.6rem; display: block; }
.editor-form-head { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1rem; font-weight: 700; font-size: 0.9rem; }
.editor-form-head i { color: var(--gold); }
.editor-group { margin-bottom: 1.1rem; }
.editor-group label { display: block; font-size: 0.78rem; color: var(--text-dim); margin-bottom: 0.5rem; }
.swatch-row { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.swatch-btn {
    flex: 1; min-width: 60px; padding: 0.5rem 0.4rem; border-radius: 8px; border: 1px solid var(--border);
    background: var(--panel-2); color: var(--text); font-size: 0.72rem; cursor: pointer; text-align: center;
}
.swatch-btn.active { border-color: var(--gold); color: var(--gold); }
.editor-hint { font-size: 0.75rem; color: var(--text-dim); line-height: 1.5; }
.editor-select, .editor-text-input {
    width: 100%; padding: 0.55rem 0.7rem; border-radius: 8px; border: 1px solid var(--border);
    background: var(--panel-2); color: var(--text); font-size: 0.8rem; font-family: inherit;
}
.editor-select:focus, .editor-text-input:focus { outline: none; border-color: var(--gold); }

/* ============ BLOCK LIBRARY MODAL ============ */
.modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.6); display: none;
    align-items: center; justify-content: center; z-index: 100; padding: 1.5rem;
}
.modal-overlay.open { display: flex; }
.modal-box { background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 1.5rem; max-width: 560px; width: 100%; max-height: 80vh; overflow-y: auto; }
.modal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1.25rem; }
.modal-head h3 { margin: 0; }
.modal-close { background: none; border: none; color: var(--text-dim); font-size: 1.1rem; cursor: pointer; }
.block-library-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }
.block-library-card {
    border: 1px solid var(--border); border-radius: 10px; padding: 1rem; text-align: center; cursor: pointer; background: var(--panel-2);
}
.block-library-card:hover { border-color: var(--gold); }
.block-library-card i { font-size: 1.3rem; color: var(--gold); margin-bottom: 0.5rem; display: block; }
.block-library-card .bl-name { font-weight: 700; font-size: 0.85rem; }
.block-library-card .bl-desc { font-size: 0.72rem; color: var(--text-dim); margin-top: 0.25rem; }
.block-library-group-label {
    grid-column: 1 / -1; font-size: 0.7rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--text-dim); margin-top: 0.5rem; padding-top: 0.75rem; border-top: 1px solid var(--border);
}
.block-library-group-label:first-child { border-top: none; padding-top: 0; margin-top: 0; }

/* ============ ÉLÉMENTS SIMPLES (briques individuelles : titre, texte, bouton, lien, image, icône, séparateur, espacement) ============ */
.element-center { text-align: center; }
.element-heading { font-size: 1.6rem; font-weight: 800; color: var(--site-text); text-align: center; margin: 0; }
.element-text { font-size: 0.95rem; color: var(--site-text-dim); line-height: 1.7; max-width: 640px; margin: 0 auto; text-align: center; }
.element-btn { display: inline-block; background: var(--site-primary); color: #fff; }
.element-link { color: var(--site-primary); font-weight: 700; text-decoration: none; display: inline-flex; align-items: center; gap: 0.45rem; }
.element-link:hover { text-decoration: underline; }
.element-icon-display { font-size: 2.5rem; color: var(--site-primary); display: block; }
.element-divider { border: none; border-top: 1px solid var(--site-card-border); max-width: 90%; margin: 0 auto; }
.element-spacer { height: 48px; }
.element-image-box {
    position: relative; max-width: 480px; margin: 0 auto; border-radius: 12px; overflow: hidden;
    background: var(--site-bg-alt); border: 1px dashed var(--site-card-border); min-height: 180px;
    display: flex; align-items: center; justify-content: center;
}
.element-image-placeholder { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; color: var(--site-text-dim); font-size: 0.85rem; padding: 2rem; }
.element-image-placeholder i { font-size: 2.2rem; }
.element-image-img { width: 100%; height: auto; display: block; }
.element-image-upload-btn {
    position: absolute; bottom: 0.75rem; right: 0.75rem; background: rgba(0,0,0,0.65); color: #fff;
    padding: 0.45rem 0.8rem; border-radius: 8px; font-size: 0.75rem; font-weight: 600; cursor: pointer;
    display: inline-flex; align-items: center; gap: 0.4rem;
}
.element-image-upload-btn:hover { background: rgba(0,0,0,0.8); }
.preview-mode .element-image-upload-btn { display: none; }

.element-quote { border-left: 4px solid var(--site-primary); padding: 0.5rem 0 0.5rem 1.25rem; max-width: 640px; margin: 0 auto; text-align: left; }
.element-quote i { color: var(--site-primary); font-size: 1.3rem; margin-bottom: 0.5rem; display: block; }
.element-quote p { font-size: 1.05rem; font-style: italic; color: var(--site-text); margin: 0 0 0.5rem; line-height: 1.6; }
.element-quote-author { font-size: 0.82rem; color: var(--site-text-dim); font-weight: 700; }
.element-list { max-width: 560px; margin: 0 auto; padding-left: 1.3rem; color: var(--site-text); font-size: 0.92rem; line-height: 2; text-align: left; }

/* ============ TAILLE & COULEUR — génériques, s'appliquent à n'importe quel élément ou titre de section ============ */
/* La taille de police elle-même est appliquée en JS (inline style, calculée à partir de la taille
   naturelle réelle de l'élément) — voir applySizeToTarget() dans site-builder.js. Les classes ci-dessous
   ne gèrent que le padding du bouton, qui ne dépend pas du font-size. */
.element-btn.el-size-sm { padding: 0.5rem 1rem; }
.element-btn.el-size-lg { padding: 0.9rem 1.8rem; }
.element-btn.el-size-xl { padding: 1.1rem 2.2rem; }

/* ============ ESPACEMENT (padding) — générique, s'applique à n'importe quelle section ============ */
.site-block.block-padding-compact { padding: 1.1rem 1rem; }
.site-block.block-padding-spacious { padding: 4.5rem 2.5rem; }

/* ============ BORDURE / OMBRE / COINS ARRONDIS — génériques ============ */
/* .builder-canvas a "overflow:hidden" (nécessaire pour ses propres coins arrondis) : sans marge,
   une bordure/ombre/coin arrondi posé sur une section pleine largeur serait coupé net sur les bords
   du canevas et donc invisible. La marge donne l'espace nécessaire pour que l'effet se voie vraiment. */
.site-block.block-border-thin, .site-block.block-border-thick,
.site-block.block-shadow-soft, .site-block.block-shadow-medium, .site-block.block-shadow-strong,
.site-block.block-radius-md, .site-block.block-radius-lg {
    margin: 0.6rem 1rem;
}
.site-block.block-border-thin { border: 1px solid var(--site-primary); }
.site-block.block-border-thick { border: 4px solid var(--site-primary); }
.site-block.block-shadow-soft { box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
.site-block.block-shadow-medium { box-shadow: 0 8px 24px rgba(0,0,0,0.18); }
.site-block.block-shadow-strong { box-shadow: 0 16px 40px rgba(0,0,0,0.28); }
/* Sans bordure ni fond propre, un coin arrondi n'a aucune arête visible à courber : on ajoute
   toujours une bordure fine par défaut pour que l'arrondi se voie, même seul. */
.site-block.block-radius-md { border-radius: 16px; overflow: hidden; border: 1px solid var(--site-card-border); }
.site-block.block-radius-lg { border-radius: 32px; overflow: hidden; border: 1px solid var(--site-card-border); }
.site-block.block-radius-md.block-border-thin, .site-block.block-radius-lg.block-border-thin { border-color: var(--site-primary); }
.site-block.block-radius-md.block-border-thick, .site-block.block-radius-lg.block-border-thick { border-width: 4px; border-color: var(--site-primary); }

/* ============ ANIMATIONS D'ENTRÉE — se jouent quand la section entre dans le viewport ============ */
@keyframes animFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes animSlideUp { from { opacity: 0; transform: translateY(40px); } to { opacity: 1; transform: translateY(0); } }
@keyframes animSlideLeft { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
@keyframes animZoomIn { from { opacity: 0; transform: scale(0.85); } to { opacity: 1; transform: scale(1); } }
@keyframes animBounceIn { 0% { opacity: 0; transform: scale(0.3); } 50% { transform: scale(1.05); } 70% { transform: scale(0.95); } 100% { opacity: 1; transform: scale(1); } }
.site-block.anim-fade-in, .site-block.anim-slide-up, .site-block.anim-slide-left, .site-block.anim-zoom-in, .site-block.anim-bounce-in { opacity: 0; }
.site-block.anim-fade-in.in-view { animation: animFadeIn 0.6s ease forwards; }
.site-block.anim-slide-up.in-view { animation: animSlideUp 0.6s ease forwards; }
.site-block.anim-slide-left.in-view { animation: animSlideLeft 0.6s ease forwards; }
.site-block.anim-zoom-in.in-view { animation: animZoomIn 0.6s ease forwards; }
.site-block.anim-bounce-in.in-view { animation: animBounceIn 0.7s ease forwards; }

/* ============ CODE PERSONNALISÉ (CSS/JS/HTML) ============ */
.editor-textarea {
    width: 100%; padding: 0.6rem 0.7rem; border-radius: 8px; border: 1px solid var(--border);
    background: var(--panel-2); color: var(--text); font-size: 0.78rem; font-family: 'Courier New', monospace;
    resize: vertical; min-height: 80px;
}
.editor-textarea:focus { outline: none; border-color: var(--gold); }
.element-html-preview { min-height: 40px; }

.color-swatch-row { display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap; }
.color-swatch-btn { width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--border); cursor: pointer; padding: 0; }
.color-swatch-btn.active { border-color: var(--gold); }
.color-custom-picker { width: 32px; height: 32px; border: none; border-radius: 50%; padding: 0; cursor: pointer; background: none; }
.color-custom-picker::-webkit-color-swatch-wrapper { padding: 0; border-radius: 50%; }
.color-custom-picker::-webkit-color-swatch { border: 2px solid var(--border); border-radius: 50%; }

.icon-picker-grid {
    display: grid; grid-template-columns: repeat(6, 1fr); gap: 0.4rem; max-height: 220px; overflow-y: auto;
    padding: 0.5rem; border: 1px solid var(--border); border-radius: 10px; background: var(--panel-2);
}
.icon-picker-btn {
    width: 100%; aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
    border-radius: 8px; border: 1px solid transparent; background: transparent; color: var(--text-dim);
    cursor: pointer; font-size: 0.95rem;
}
.icon-picker-btn:hover { background: var(--panel); color: var(--text); }
.icon-picker-btn.active { background: var(--gold); color: #000; border-color: var(--gold); }

.social-links-list { display: flex; flex-direction: column; gap: 0.6rem; }
.social-link-row { display: flex; align-items: center; gap: 0.6rem; }
.social-link-row i { width: 20px; text-align: center; color: var(--text-dim); }
.social-link-row input { flex: 1; }

/* ============ TOAST ============ */
.toast {
    position: fixed; bottom: 1.5rem; left: 50%; transform: translateX(-50%) translateY(120%);
    background: #10b981; color: #fff; padding: 0.75rem 1.5rem; border-radius: 50px; font-size: 0.85rem; font-weight: 600;
    box-shadow: 0 8px 24px rgba(0,0,0,0.3); transition: transform 0.3s ease; z-index: 200; display: flex; align-items: center; gap: 0.5rem;
}
.toast.show { transform: translateX(-50%) translateY(0); }

@media (max-width: 1100px) {
    .builder-layout { grid-template-columns: 1fr; }
    .builder-sections-panel, .builder-editor-panel { position: static; }
}

/* ============ GALERIE DE THÈMES (dashboard/site-themes.php) ============ */
.theme-gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.25rem; }
.theme-card { background: var(--panel); border: 1px solid var(--border); border-radius: 14px; overflow: hidden; transition: border-color 0.2s, transform 0.2s; }
.theme-card:hover { border-color: var(--gold); transform: translateY(-3px); }
.theme-card.current { border-color: #10b981; }
.theme-mini-preview { border-radius: 0; overflow: hidden; }
.theme-mini-hero { background: linear-gradient(135deg,var(--site-primary),var(--site-secondary)); padding: 1.5rem 1.25rem; text-align: center; }
.theme-mini-hero .tmh-line1 { height: 10px; width: 70%; background: rgba(255,255,255,0.9); border-radius: 4px; margin: 0 auto 0.5rem; }
.theme-mini-hero .tmh-line2 { height: 6px; width: 45%; background: rgba(255,255,255,0.5); border-radius: 4px; margin: 0 auto 0.75rem; }
.theme-mini-hero .tmh-btn { display: inline-block; background: rgba(0,0,0,0.35); color: #fff; font-size: 0.65rem; font-weight: 700; padding: 0.3rem 0.9rem; border-radius: 20px; }
.theme-mini-body { background: var(--site-bg); padding: 0.9rem 1.25rem; display: flex; gap: 0.5rem; }
.theme-mini-body .tmb-card { flex: 1; background: var(--site-card-bg); border: 1px solid var(--site-card-border); border-radius: 6px; height: 28px; }
.theme-card-info { padding: 1rem 1.25rem 1.25rem; }
.theme-card-info .tc-name { font-weight: 800; font-size: 0.95rem; margin-bottom: 0.25rem; display: flex; align-items: center; gap: 0.5rem; }
.theme-card-info .tc-vibe { font-size: 0.78rem; color: var(--text-dim); margin-bottom: 0.9rem; }
.theme-card-info .tc-btn {
    display: block; text-align: center; width: 100%; padding: 0.6rem; border-radius: 8px; border: none;
    background: var(--panel-2); color: var(--text); font-weight: 700; font-size: 0.82rem; cursor: pointer; text-decoration: none;
}
.theme-card.current .tc-btn { background: rgba(16,185,129,0.14); color: #34d399; cursor: default; }
.theme-card:not(.current) .tc-btn:hover { background: var(--gold); color: #000; }
.current-badge { display: inline-block; background: #10b981; color: #fff; font-size: 0.62rem; font-weight: 800; padding: 0.15rem 0.5rem; border-radius: 4px; text-transform: uppercase; }

/* ============ VRAIE RESPONSIVITÉ (media queries réelles) ============
   Jusqu'ici, toute l'adaptation mobile/tablette passait UNIQUEMENT par l'attribut
   [data-device] posé à la main via le bouton de bascule de l'éditeur/aperçu — donc sur un vrai
   téléphone (ou un simple redimensionnement de fenêtre), rien ne s'adaptait automatiquement.
   Ce bloc reprend les mêmes règles mais via de vraies @media, pour que le site s'adapte réellement,
   peu importe comment il est consulté (device-toggle, ou vraie largeur d'écran). */
@media (max-width: 900px) {
    .real-public-nav { display: none; }
    .countries-grid { grid-template-columns: repeat(2, 1fr); }
    .real-product-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
    .rwh-nav a:not(.nav-btn-login):not(.nav-btn-register) { display: none; }
    .ran-links .nav-link:not(.nav-link-primary):not(.nav-link-secondary) { display: none; }
    .real-btn-recharge .rt-text { display: none; }
    .real-brand-name { display: none; }
    .site-block[data-block-type="hero"][data-variant="split"] { grid-template-columns: 1fr; text-align: center; }
    .features-grid, .hero-stats-row, .services-preview-grid, .steps-preview-row,
    .testimonials-preview-grid, .contact-form-layout, .countries-grid, .top-services-grid,
    .contact-cards-grid, .real-stat-grid, .real-quick-grid, .real-dashboard-cols,
    .real-fav-grid, .real-info-row-4, .real-product-grid {
        grid-template-columns: 1fr;
    }
    .brand-story-layout { grid-template-columns: 1fr; text-align: center; }

    /* Typographie et espacements resserrés pour éviter tout débordement horizontal sur mobile */
    .site-block { padding: 2rem 1.25rem; }
    .site-block[data-block-type="hero"] h1 { font-size: 1.7rem; }
    .site-block[data-block-type="page-header"] h1 { font-size: 1.4rem; }
    .element-heading { font-size: 1.3rem; }
    body, html { overflow-x: hidden; }
}
