/* ============================================
   MOTEKI - Design System
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
    /* Vitrine - Bleu/Rouge/Blanc */
    --v-blue: #1e6abf;
    --v-blue-dark: #164d8a;
    --v-blue-light: #e8f0fe;
    --v-red: #c9303e;
    --v-red-dark: #a02530;
    --v-dark: #1a2332;
    --v-white: #ffffff;
    --v-gray: #f5f7fa;
    --v-text: #333d4d;
    --v-text-light: #6b7a8d;

    /* App - Vert/Blanc */
    --a-green: #1a7a4f;
    --a-green-dark: #145e3d;
    --a-green-light: #f0f9f4;
    --a-green-lighter: #e6f5ec;
    --a-white: #ffffff;
    --a-text: #1a2332;
    --a-text-light: #6b7a8d;
    --a-border: #e2e8f0;
    --a-bg: #f8faf9;

    /* Status colors */
    --status-actif: #22c55e;
    --status-inactif: #94a3b8;
    --status-expire: #f59e0b;
    --status-inexistant: #ef4444;

    --radius: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --shadow: 0 4px 20px rgba(0,0,0,0.08);
    --shadow-lg: 0 10px 40px rgba(0,0,0,0.12);
    --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Dark mode */
[data-theme="dark"] {
    --a-bg: #0f1419;
    --a-white: #1a2332;
    --a-text: #e2e8f0;
    --a-text-light: #94a3b8;
    --a-border: #2d3748;
    --a-green-light: #1a2e25;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    color: var(--v-text);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4,h5,h6 { font-family: 'Space Grotesk', sans-serif; font-weight: 700; }

.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* ===== ANIMATIONS ===== */
@keyframes fadeUp { from { opacity:0; transform:translateY(30px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes slideRight { from { transform:translateX(-30px); opacity:0; } to { transform:translateX(0); opacity:1; } }
@keyframes float { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-15px); } }
@keyframes countUp { from { opacity:0; transform:scale(0.5); } to { opacity:1; transform:scale(1); } }
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.7; } }
@keyframes slideIn { from { transform:translateX(100%); } to { transform:translateX(0); } }

.animate-fade-up { animation: fadeUp 0.6s ease-out forwards; }
.animate-fade-in { animation: fadeIn 0.5s ease-out forwards; }
.animate-slide-right { animation: slideRight 0.5s ease-out forwards; }
.animate-float { animation: float 3s ease-in-out infinite; }

.delay-1 { animation-delay: 0.1s; }
.delay-2 { animation-delay: 0.2s; }
.delay-3 { animation-delay: 0.3s; }
.delay-4 { animation-delay: 0.4s; }
.delay-5 { animation-delay: 0.5s; }

/* ===== VITRINE HEADER ===== */
.v-header {
    position: fixed; top:0; left:0; right:0; z-index:100;
    background: rgba(255,255,255,0.95);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(0,0,0,0.05);
    transition: var(--transition);
}
.v-header.scrolled { box-shadow: var(--shadow); }
.v-header .container { display:flex; align-items:center; justify-content:space-between; height:70px; }
.v-logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.v-logo img { width:42px; height:42px; border-radius:50%; object-fit:cover; }
.v-logo span { font-family:'Space Grotesk'; font-weight:700; font-size:1.4rem; color:var(--v-blue); }
.v-nav { display:flex; align-items:center; gap:30px; }
.v-nav a { text-decoration:none; color:var(--v-text-light); font-size:0.9rem; font-weight:500; transition:var(--transition); position:relative; }
.v-nav a:hover { color:var(--v-blue); }
.v-nav a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--v-blue); transition:var(--transition); }
.v-nav a:hover::after { width:100%; }
.v-btn-login { background: linear-gradient(135deg, var(--v-blue), var(--v-blue-dark)); color:#fff !important; padding:10px 24px; border-radius:var(--radius); font-weight:600 !important; }
.v-btn-login::after { display:none !important; }
.v-btn-login:hover { transform:translateY(-2px); box-shadow:0 4px 15px rgba(30,106,191,0.4); }

.v-menu-toggle { display:none; background:none; border:none; cursor:pointer; padding:8px; }
.v-menu-toggle span { display:block; width:24px; height:2px; background:var(--v-text); margin:5px 0; transition:var(--transition); }

/* ===== HERO ===== */
.v-hero {
    min-height: 100vh; display:flex; align-items:center; justify-content:center;
    background: linear-gradient(135deg, var(--v-blue) 0%, var(--v-blue-dark) 100%);
    position:relative; overflow:hidden; padding-top:70px;
}
.v-hero::before {
    content:''; position:absolute; top:-50%; right:-20%; width:600px; height:600px;
    background: radial-gradient(circle, rgba(201,48,62,0.15) 0%, transparent 70%);
    border-radius:50%; animation: float 6s ease-in-out infinite;
}
.v-hero::after {
    content:''; position:absolute; bottom:-30%; left:-10%; width:500px; height:500px;
    background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%);
    border-radius:50%; animation: float 8s ease-in-out infinite reverse;
}
.v-hero-content { position:relative; z-index:2; text-align:center; max-width:800px; padding:40px 20px; }
.v-hero-badge { display:inline-flex; align-items:center; gap:8px; padding:8px 20px; border-radius:30px;
    background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.2);
    color:rgba(255,255,255,0.8); font-size:0.85rem; font-weight:500; margin-bottom:24px; }
.v-hero h1 { font-size:3.2rem; color:#fff; margin-bottom:20px; line-height:1.15; }
.v-hero p { font-size:1.15rem; color:rgba(255,255,255,0.8); margin-bottom:36px; line-height:1.7; max-width:600px; margin-left:auto; margin-right:auto; }
.v-hero-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.v-btn-primary { display:inline-flex; align-items:center; gap:8px; padding:16px 32px; border-radius:var(--radius);
    background:#fff; color:var(--v-blue); font-weight:700; text-decoration:none; font-size:1rem;
    transition:var(--transition); border:none; cursor:pointer; }
.v-btn-primary:hover { transform:translateY(-3px); box-shadow:0 10px 30px rgba(0,0,0,0.2); }
.v-btn-secondary { display:inline-flex; align-items:center; gap:8px; padding:16px 32px; border-radius:var(--radius);
    background:transparent; color:#fff; font-weight:600; text-decoration:none; font-size:1rem;
    border:2px solid rgba(255,255,255,0.3); transition:var(--transition); cursor:pointer; }
.v-btn-secondary:hover { background:rgba(255,255,255,0.1); border-color:rgba(255,255,255,0.5); }

/* Slider dots */
.v-hero-dots { display:flex; justify-content:center; gap:8px; margin-top:40px; }
.v-hero-dots .dot { width:12px; height:12px; border-radius:50%; background:rgba(255,255,255,0.3); border:none; cursor:pointer; transition:var(--transition); }
.v-hero-dots .dot.active { background:#fff; width:32px; border-radius:6px; }

/* ===== SECTIONS ===== */
.v-section { padding:100px 0; }
.v-section-alt { background:var(--v-gray); }
.v-section-title { text-align:center; margin-bottom:60px; }
.v-section-title .badge { display:inline-block; padding:6px 18px; border-radius:20px; font-size:0.8rem; font-weight:600; margin-bottom:12px; }
.v-section-title .badge-blue { background:var(--v-blue-light); color:var(--v-blue); }
.v-section-title .badge-red { background:rgba(201,48,62,0.1); color:var(--v-red); }
.v-section-title h2 { font-size:2.4rem; color:var(--v-dark); margin-bottom:12px; }
.v-section-title p { color:var(--v-text-light); max-width:600px; margin:0 auto; font-size:1.05rem; }

/* ===== CARDS ===== */
.v-card { background:#fff; border-radius:var(--radius-lg); padding:32px; border:1px solid rgba(0,0,0,0.06);
    transition:var(--transition); }
.v-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-lg); }
.v-card-icon { width:56px; height:56px; border-radius:var(--radius); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.v-card-icon.blue { background:linear-gradient(135deg, var(--v-blue), var(--v-blue-dark)); }
.v-card-icon.red { background:linear-gradient(135deg, var(--v-red), var(--v-red-dark)); }
.v-card-icon svg, .v-card-icon i { color:#fff; font-size:1.4rem; }
.v-card h3 { font-size:1.1rem; margin-bottom:8px; color:var(--v-dark); }
.v-card p { font-size:0.9rem; color:var(--v-text-light); line-height:1.6; }

.v-grid-2 { display:grid; grid-template-columns:repeat(2, 1fr); gap:24px; }
.v-grid-3 { display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; }
.v-grid-4 { display:grid; grid-template-columns:repeat(4, 1fr); gap:24px; }

/* ===== STATS ===== */
.v-stats { background:linear-gradient(135deg, var(--v-blue), var(--v-blue-dark)); padding:80px 0; }
.v-stats h2 { color:#fff; text-align:center; margin-bottom:50px; font-size:2rem; }
.v-stat-item { text-align:center; }
.v-stat-number { font-family:'Space Grotesk'; font-size:3rem; font-weight:700; color:#fff; }
.v-stat-label { color:rgba(255,255,255,0.7); font-size:0.9rem; margin-top:4px; }

/* ===== CONTACT ===== */
.v-contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; max-width:1000px; margin:0 auto; }
.v-form-group { margin-bottom:16px; }
.v-input { width:100%; padding:14px 18px; border-radius:var(--radius); border:1px solid var(--a-border);
    font-family:'Plus Jakarta Sans'; font-size:0.9rem; outline:none; transition:var(--transition); background:#fff; }
.v-input:focus { border-color:var(--v-blue); box-shadow:0 0 0 3px rgba(30,106,191,0.1); }
textarea.v-input { resize:vertical; min-height:120px; }
.v-btn-submit { display:inline-flex; align-items:center; gap:8px; padding:14px 32px; border-radius:var(--radius);
    background:linear-gradient(135deg, var(--v-blue), var(--v-blue-dark)); color:#fff; font-weight:600; border:none;
    cursor:pointer; font-size:0.95rem; transition:var(--transition); font-family:'Plus Jakarta Sans'; }
.v-btn-submit:hover { transform:translateY(-2px); box-shadow:0 4px 15px rgba(30,106,191,0.4); }

.v-contact-info { display:flex; flex-direction:column; gap:16px; }
.v-info-card { background:#fff; border-radius:var(--radius); padding:20px; border:1px solid rgba(0,0,0,0.06);
    display:flex; align-items:flex-start; gap:14px; }
.v-info-icon { width:40px; height:40px; border-radius:10px; background:var(--v-blue-light);
    display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--v-blue); }

/* ===== FOOTER ===== */
.v-footer { background:var(--v-dark); color:#fff; padding:60px 0 30px; }
.v-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; margin-bottom:40px; }
.v-footer h4 { font-size:1rem; margin-bottom:16px; }
.v-footer p, .v-footer a { font-size:0.85rem; color:rgba(255,255,255,0.6); text-decoration:none; line-height:2; }
.v-footer a:hover { color:#fff; }
.v-footer-bottom { border-top:1px solid rgba(255,255,255,0.1); padding-top:24px; text-align:center; }
.v-footer-bottom p { font-size:0.8rem; color:rgba(255,255,255,0.4); }

/* ===== APP STYLES ===== */
.app-container { min-height:100vh; background:var(--a-bg); font-family:'Plus Jakarta Sans', sans-serif; }

.app-header { background:var(--a-green); color:#fff; padding:14px 20px; display:flex; align-items:center; gap:12px;
    position:sticky; top:0; z-index:50; }
.app-header img { width:36px; height:36px; border-radius:50%; object-fit:cover; }
.app-header h1 { font-family:'Space Grotesk'; font-size:1.2rem; font-weight:700; }
.app-header .label { font-size:0.7rem; opacity:0.7; margin-left:4px; }

.app-content { padding:16px; padding-bottom:80px; }

/* Bottom navigation */
.app-nav { position:fixed; bottom:0; left:0; right:0; background:var(--a-white); border-top:1px solid var(--a-border);
    display:flex; justify-content:space-around; padding:8px 0 12px; z-index:50; }
.app-nav a { display:flex; flex-direction:column; align-items:center; gap:2px; text-decoration:none;
    color:var(--a-text-light); font-size:0.65rem; font-weight:500; transition:var(--transition); padding:4px 8px; }
.app-nav a.active { color:var(--a-green); }
.app-nav a svg { width:22px; height:22px; }

/* App cards */
.app-card { background:var(--a-white); border-radius:var(--radius-lg); padding:20px; border:1px solid var(--a-border);
    transition:var(--transition); }
.app-card:hover { box-shadow:var(--shadow); }
.app-welcome { background:linear-gradient(135deg, var(--a-green), var(--a-green-dark)); border-radius:var(--radius-xl);
    padding:28px; color:#fff; margin-bottom:20px; }
.app-welcome h2 { font-size:1.5rem; margin-bottom:4px; }
.app-welcome p { opacity:0.8; font-size:0.9rem; }

.app-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.app-grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }

.app-action-card { text-decoration:none; display:block; }
.app-action-card .icon { width:44px; height:44px; border-radius:var(--radius); display:flex; align-items:center;
    justify-content:center; margin-bottom:10px; transition:var(--transition); }
.app-action-card:hover .icon { transform:scale(1.1); }
.app-action-card .icon.green { background:var(--a-green); }
.app-action-card .icon.red { background:var(--v-red); }
.app-action-card .icon.blue { background:var(--v-blue); }
.app-action-card .icon.gray { background:#6b7a8d; }
.app-action-card .icon.dark { background:var(--a-green-dark); }
.app-action-card .icon svg { color:#fff; width:20px; height:20px; }
.app-action-card h3 { font-size:0.85rem; color:var(--a-text); margin-bottom:4px; }
.app-action-card p { font-size:0.75rem; color:var(--a-text-light); }

/* App forms */
.app-input { width:100%; padding:14px 16px; border-radius:var(--radius); border:1px solid var(--a-border);
    font-family:'Plus Jakarta Sans'; font-size:0.9rem; outline:none; transition:var(--transition);
    background:var(--a-white); color:var(--a-text); }
.app-input:focus { border-color:var(--a-green); box-shadow:0 0 0 3px rgba(26,122,79,0.1); }
.app-input::placeholder { color:var(--a-text-light); }

.app-select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7a8d' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 16px center; padding-right:40px; }

.app-btn { display:inline-flex; align-items:center; justify-content:center; gap:8px; width:100%;
    padding:14px 24px; border-radius:var(--radius); font-family:'Plus Jakarta Sans'; font-size:0.95rem;
    font-weight:600; border:none; cursor:pointer; transition:var(--transition); }
.app-btn-green { background:linear-gradient(135deg, var(--a-green), var(--a-green-dark)); color:#fff; }
.app-btn-green:hover { transform:translateY(-2px); box-shadow:0 4px 15px rgba(26,122,79,0.4); }
.app-btn-outline { background:transparent; color:var(--a-text); border:1px solid var(--a-border); }

/* Status badges */
.badge-status { display:inline-flex; align-items:center; gap:4px; padding:4px 12px; border-radius:20px;
    font-size:0.75rem; font-weight:600; }
.badge-actif { background:rgba(34,197,94,0.1); color:var(--status-actif); }
.badge-inactif { background:rgba(148,163,184,0.1); color:var(--status-inactif); }
.badge-expire { background:rgba(245,158,11,0.1); color:var(--status-expire); }
.badge-inexistant { background:rgba(239,68,68,0.1); color:var(--status-inexistant); }

/* Result cards */
.result-card { text-align:center; padding:32px; border-radius:var(--radius-lg); }
.result-card.success { background:var(--a-green-lighter); border:2px solid var(--a-green); }
.result-card .code { font-family:'Space Grotesk'; font-size:2.5rem; font-weight:700; color:var(--a-green);
    letter-spacing:6px; margin:16px 0; }

/* Settings items */
.setting-item { display:flex; align-items:center; justify-content:space-between; padding:16px; }
.setting-item .left { display:flex; align-items:center; gap:12px; }
.setting-item .left svg { color:var(--a-green); width:20px; height:20px; }
.setting-item span { font-size:0.9rem; font-weight:500; color:var(--a-text); }

/* Toggle switch */
.toggle { width:48px; height:26px; border-radius:13px; background:var(--a-border); position:relative;
    cursor:pointer; transition:var(--transition); border:none; }
.toggle.active { background:var(--a-green); }
.toggle::after { content:''; width:22px; height:22px; border-radius:50%; background:#fff; position:absolute;
    top:2px; left:2px; transition:var(--transition); box-shadow:0 2px 4px rgba(0,0,0,0.1); }
.toggle.active::after { left:24px; }

/* Photo upload */
.photo-upload { width:96px; height:96px; border-radius:50%; border:2px dashed var(--a-border);
    display:flex; align-items:center; justify-content:center; cursor:pointer; overflow:hidden;
    margin:0 auto 20px; transition:var(--transition); background:var(--a-bg); }
.photo-upload:hover { border-color:var(--a-green); }
.photo-upload img { width:100%; height:100%; object-fit:cover; }

/* Profile */
.profile-header { text-align:center; }
.profile-avatar { width:80px; height:80px; border-radius:50%; background:var(--a-bg); overflow:hidden;
    margin:0 auto 12px; border:3px solid var(--a-green); }
.profile-avatar img { width:100%; height:100%; object-fit:cover; }
.profile-name { font-size:1.1rem; font-weight:700; color:var(--a-text); }
.profile-code { font-family:'Space Grotesk'; font-weight:700; color:var(--a-green); font-size:1.1rem; letter-spacing:3px; }

/* Chasuble print */
.chasuble-preview { border:3px solid var(--a-green); border-radius:var(--radius-lg); padding:32px;
    text-align:center; background:#fff; max-width:400px; margin:0 auto; }
.chasuble-preview .logo { width:60px; height:60px; border-radius:50%; object-fit:cover; margin:0 auto 8px; }
.chasuble-preview .vendor-photo { width:80px; height:80px; border-radius:50%; border:2px solid var(--a-green);
    object-fit:cover; margin:0 auto 12px; }

/* Toast notifications */
.toast-container { position:fixed; top:20px; right:20px; z-index:10000; display:flex; flex-direction:column; gap:8px; }
.toast { padding:14px 20px; border-radius:var(--radius); color:#fff; font-size:0.9rem; font-weight:500;
    animation:slideIn 0.3s ease-out; min-width:280px; display:flex; align-items:center; gap:8px;
    box-shadow:var(--shadow-lg); }
.toast-success { background:var(--a-green); }
.toast-error { background:var(--status-inexistant); }
.toast-info { background:var(--v-blue); }

/* Loader */
.loader { width:32px; height:32px; border:3px solid var(--a-border); border-top-color:var(--a-green);
    border-radius:50%; animation:spin 0.8s linear infinite; margin:40px auto; }
@keyframes spin { to { transform:rotate(360deg); } }

/* Login page */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center;
    background:var(--a-bg); padding:20px; }
.login-card { background:var(--a-white); border-radius:var(--radius-xl); padding:40px;
    max-width:400px; width:100%; text-align:center; box-shadow:var(--shadow); }
.login-card img { width:64px; height:64px; border-radius:50%; object-fit:cover; margin:0 auto 16px; }
.login-card h1 { font-size:1.5rem; margin-bottom:4px; color:var(--a-text); }
.login-card .subtitle { color:var(--a-text-light); font-size:0.9rem; margin-bottom:24px; }
.login-card form { text-align:left; }
.login-card .form-group { margin-bottom:12px; }
.login-link { color:var(--a-green); font-weight:600; text-decoration:none; font-size:0.9rem;
    display:inline-block; margin-top:16px; }
.login-link:hover { text-decoration:underline; }

/* Payment summary */
.payment-summary { background:var(--a-green-lighter); border-radius:var(--radius); padding:16px; }
.payment-row { display:flex; justify-content:space-between; font-size:0.9rem; margin-bottom:4px; }
.payment-row .label { color:var(--a-text-light); }
.payment-row .value { font-weight:600; color:var(--a-text); }

/* Verification result */
.verification-result { text-align:center; padding:32px; border-radius:var(--radius-lg); border:2px solid; }
.verification-result.actif { border-color:var(--status-actif); background:rgba(34,197,94,0.05); color:var(--status-actif); }
.verification-result.inactif { border-color:var(--status-inactif); background:rgba(148,163,184,0.05); color:var(--status-inactif); }
.verification-result.expire { border-color:var(--status-expire); background:rgba(245,158,11,0.05); color:var(--status-expire); }
.verification-result.inexistant { border-color:var(--status-inexistant); background:rgba(239,68,68,0.05); color:var(--status-inexistant); }
.verification-result .status-text { font-family:'Space Grotesk'; font-size:2rem; font-weight:700; margin-top:8px; }

/* History list */
.history-item { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; }

/* Responsive */
@media (max-width: 768px) {
    .v-nav { display:none; position:fixed; top:70px; left:0; right:0; background:#fff; flex-direction:column;
        padding:20px; gap:16px; box-shadow:var(--shadow-lg); }
    .v-nav.open { display:flex; }
    .v-menu-toggle { display:block; }
    .v-hero h1 { font-size:2rem; }
    .v-hero p { font-size:1rem; }
    .v-hero-actions { flex-direction:column; align-items:center; }
    .v-grid-2, .v-grid-3, .v-grid-4 { grid-template-columns:1fr; }
    .v-stat-number { font-size:2rem; }
    .v-grid-4 { grid-template-columns:1fr 1fr; }
    .v-contact-grid { grid-template-columns:1fr; }
    .v-footer-grid { grid-template-columns:1fr 1fr; gap:24px; }
    .v-section { padding:60px 0; }
    .v-section-title h2 { font-size:1.8rem; }
}
@media (max-width: 480px) {
    .v-footer-grid { grid-template-columns:1fr; }
}

/* Print styles for chasuble */
@media print {
    body * { visibility:hidden; }
    .chasuble-preview, .chasuble-preview * { visibility:visible; }
    .chasuble-preview { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
        border:3px solid #1a7a4f; width:350px; }
}


/* ===== PAYMENT FLOW V2 ===== */
.payment-shell { max-width:560px; margin:0 auto; display:grid; gap:16px; }
.payment-hero { background:linear-gradient(135deg, var(--a-green), var(--a-green-dark)); border-radius:var(--radius-xl); padding:24px; color:#fff; box-shadow:var(--shadow); }
.payment-hero h2 { font-size:1.35rem; margin-bottom:8px; }
.payment-hero p { font-size:0.92rem; opacity:0.88; line-height:1.7; }
.payment-hero-badge { display:inline-flex; align-items:center; gap:8px; padding:8px 14px; border-radius:999px; background:rgba(255,255,255,0.14); color:#fff; font-size:0.74rem; font-weight:700; letter-spacing:0.02em; margin-bottom:14px; }
.payment-hero-badge-light { background:rgba(26,122,79,0.08); color:var(--a-green); }
.payment-card { padding:20px; }
.payment-field { margin-bottom:14px; }
.payment-field label { display:block; font-size:0.82rem; font-weight:700; color:var(--a-text); margin-bottom:8px; }
.payment-field .field-help { display:block; margin-top:6px; color:var(--a-text-light); font-size:0.76rem; }
.field-error { display:none; margin-top:6px; color:var(--status-inexistant); font-size:0.76rem; font-weight:600; }
.field-error.visible { display:block; }
.input-error { border-color:var(--status-inexistant) !important; box-shadow:0 0 0 3px rgba(239,68,68,0.08) !important; }
.payment-summary-card { margin:18px 0 12px; }
.payment-note { background:rgba(26,122,79,0.06); border:1px solid rgba(26,122,79,0.12); border-radius:var(--radius); padding:14px 16px; font-size:0.82rem; line-height:1.65; color:var(--a-text-light); margin-bottom:16px; }
.payment-note strong { color:var(--a-text); }
.payment-success-extra { color:var(--a-text-light); font-size:0.85rem; }
.button-spinner { width:16px; height:16px; border:2px solid rgba(255,255,255,0.32); border-top-color:#fff; border-radius:50%; animation:spin 0.8s linear infinite; display:inline-block; vertical-align:middle; margin-right:8px; }
.payment-modal { position:fixed; inset:0; background:rgba(15,23,32,0.56); backdrop-filter:blur(4px); display:none; align-items:center; justify-content:center; padding:20px; z-index:120; }
.payment-modal.active { display:flex; }
.payment-modal-card { width:min(100%, 420px); background:var(--a-white); border-radius:24px; padding:24px; box-shadow:var(--shadow-lg); }
.payment-modal-top h3 { font-size:1.2rem; color:var(--a-text); margin-bottom:6px; }
.payment-modal-top p { color:var(--a-text-light); font-size:0.86rem; line-height:1.6; margin-bottom:18px; }
.payment-spinner { width:54px; height:54px; margin:0 auto 16px; border:4px solid rgba(26,122,79,0.12); border-top-color:var(--a-green); border-radius:50%; animation:spin 0.8s linear infinite; }
.payment-modal-status { text-align:center; font-weight:700; color:var(--a-text); margin-bottom:6px; }
.payment-modal-countdown { text-align:center; color:var(--a-text-light); font-size:0.86rem; }
.payment-result-icon { width:72px; height:72px; border-radius:50%; display:grid; place-items:center; margin:0 auto 16px; }
.payment-result-icon.success { background:rgba(34,197,94,0.12); color:var(--status-actif); }
.payment-result-icon.error { background:rgba(239,68,68,0.1); color:var(--status-inexistant); }
.payment-result-icon svg { width:34px; height:34px; }
.payment-result-message { text-align:center; font-size:1rem; font-weight:700; color:var(--a-text); margin-bottom:16px; }
.payment-details { background:var(--a-bg); border:1px solid var(--a-border); border-radius:18px; padding:10px 16px; margin-bottom:16px; }
.payment-details div { display:flex; justify-content:space-between; gap:16px; padding:10px 0; border-bottom:1px solid var(--a-border); }
.payment-details div:last-child { border-bottom:none; }
.payment-details span { color:var(--a-text-light); font-size:0.8rem; }
.payment-details strong { color:var(--a-text); font-size:0.86rem; text-align:right; }
@media (max-width: 480px) {
  .payment-hero { padding:20px; }
  .payment-modal-card { padding:20px; }
  .payment-details div { flex-direction:column; gap:4px; align-items:flex-start; }
}

/* ===== QR SCANNER MODAL ===== */
.modal-overlay {
    position:fixed;top:0;left:0;right:0;bottom:0;z-index:200;
    background:rgba(0,0,0,0.6);backdrop-filter:blur(8px);
    display:flex;align-items:center;justify-content:center;padding:16px;
}
.modal-content {
    background:var(--a-white);border-radius:var(--radius-xl);
    width:100%;max-width:420px;max-height:90vh;overflow-y:auto;
    padding:20px;box-shadow:var(--shadow-lg);
    animation:fadeUp 0.3s ease-out;
}
.modal-header {
    display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;
}
.modal-header h3 {
    display:flex;align-items:center;gap:8px;font-size:1rem;color:var(--a-text);
}
.modal-close {
    width:32px;height:32px;border-radius:50%;border:none;cursor:pointer;
    background:var(--a-bg);color:var(--a-text);font-size:1.3rem;
    display:flex;align-items:center;justify-content:center;transition:var(--transition);
}
.modal-close:hover { background:rgba(239,68,68,0.1);color:#ef4444; }

