/*! =====================================================================
 * BUBOCODE DESIGN SYSTEM v1.0
 * Glassmorphism · Teal & Gold · Artisan WordPress
 * =====================================================================
 * Tous les composants utilisent le prefixe .bubo- pour ne rien casser.
 * --------------------------------------------------------------------- */

@import url('https://fonts.googleapis.com/css2?family=Caveat:wght@600;700&family=Poppins:wght@300;400;500;600;700&display=swap');

/* ===== 1. DESIGN TOKENS ===== */
:root {
  --bubo-teal-deep:#04181a;--bubo-teal-bg:#061f20;--bubo-teal-dark:#114647;--bubo-teal:#186162;
  --bubo-turq:#29A4A6;--bubo-accent:#EDB235;--bubo-accent-2:#DC782E;--bubo-purple:#462A40;
  --bubo-white:#ffffff;--bubo-muted:#a1c1c2;--bubo-soft:#7a9a9b;--bubo-zinc-300:#d4d4d8;--bubo-zinc-500:#71717a;
  --bubo-glass-bg:rgba(255,255,255,0.04);--bubo-glass-bg-hover:rgba(255,255,255,0.06);
  --bubo-glass-border:rgba(255,255,255,0.10);--bubo-glass-border-gold-hover:rgba(237,178,53,0.45);
  --bubo-glass-border-turq-hover:rgba(41,164,166,0.50);--bubo-glass-blur:20px;
  --bubo-glass-halo:radial-gradient(circle,rgba(237,178,53,0.20) 0%,transparent 70%);
  --bubo-font-body:'Poppins',system-ui,-apple-system,sans-serif;
  --bubo-font-script:'Thirsty Script','Caveat',cursive;
  --bubo-text-xs:11px;--bubo-text-sm:13px;--bubo-text-base:15px;--bubo-text-md:17px;--bubo-text-lg:22px;
  --bubo-text-xl:28px;--bubo-text-2xl:clamp(28px,4vw,38px);--bubo-text-3xl:clamp(36px,5vw,54px);
  --bubo-text-display:clamp(40px,7vw,84px);
  --bubo-tracking-tight:-0.025em;--bubo-tracking-normal:0;--bubo-tracking-wide:0.08em;
  --bubo-tracking-wider:0.15em;--bubo-tracking-widest:0.2em;
  --bubo-leading-tight:1.05;--bubo-leading-snug:1.2;--bubo-leading-normal:1.5;--bubo-leading-relaxed:1.7;
  --bubo-space-0:0;--bubo-space-1:4px;--bubo-space-2:8px;--bubo-space-3:12px;--bubo-space-4:16px;
  --bubo-space-5:20px;--bubo-space-6:24px;--bubo-space-8:32px;--bubo-space-10:40px;--bubo-space-12:48px;
  --bubo-space-16:64px;--bubo-space-20:80px;--bubo-space-24:96px;--bubo-space-32:128px;
  --bubo-radius-sm:8px;--bubo-radius-md:16px;--bubo-radius-lg:24px;--bubo-radius-xl:28px;
  --bubo-radius-2xl:32px;--bubo-radius-pill:999px;
  --bubo-shadow-sm:0 4px 12px rgba(0,0,0,0.15);--bubo-shadow-md:0 8px 24px rgba(0,0,0,0.25);
  --bubo-shadow-lg:0 20px 60px rgba(0,0,0,0.3);--bubo-shadow-xl:0 30px 80px rgba(0,0,0,0.45);
  --bubo-shadow-gold:0 8px 32px rgba(237,178,53,0.25);--bubo-shadow-gold-strong:0 12px 40px rgba(237,178,53,0.4);
  --bubo-gradient-gold:linear-gradient(135deg,#EDB235 0%,#DC782E 100%);
  --bubo-gradient-gold-soft:linear-gradient(135deg,#ffffff 0%,#EDB235 60%,#DC782E 100%);
  --bubo-gradient-progress:linear-gradient(90deg,#EDB235 0%,#29A4A6 100%);
  --bubo-gradient-bg:radial-gradient(ellipse 80% 60% at 20% 0%,rgba(41,164,166,0.15),transparent 60%),radial-gradient(ellipse 60% 50% at 90% 30%,rgba(237,178,53,0.08),transparent 60%),radial-gradient(ellipse 70% 50% at 50% 100%,rgba(24,97,98,0.4),transparent 70%),linear-gradient(180deg,#082c2d 0%,#061f20 50%,#04181a 100%);
  --bubo-transition-fast:0.2s ease;--bubo-transition:0.35s ease;--bubo-transition-slow:0.6s ease;
  --bubo-transition-bouncy:0.4s cubic-bezier(0.34,1.56,0.64,1);
}

/* ===== 2. TYPOGRAPHIE ===== */
.bubo-eyebrow{display:inline-block;font-family:var(--bubo-font-body);font-size:var(--bubo-text-xs);font-weight:700;text-transform:uppercase;letter-spacing:var(--bubo-tracking-widest);color:var(--bubo-accent);padding:6px 14px;border-radius:var(--bubo-radius-pill);background:rgba(237,178,53,0.10);border:1px solid rgba(237,178,53,0.25);}
.bubo-script{font-family:var(--bubo-font-script) !important;font-style:italic;font-weight:700;letter-spacing:0.01em;background:var(--bubo-gradient-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:inline-block;line-height:0.95;padding-bottom:0.05em;}
.bubo-grad{font-family:var(--bubo-font-script) !important;font-style:italic;font-weight:700;letter-spacing:0.01em;background:var(--bubo-gradient-gold-soft);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:inline-block;line-height:0.95;padding-bottom:0.05em;}
.bubo-display{font-family:var(--bubo-font-body);font-size:var(--bubo-text-display);font-weight:600;letter-spacing:var(--bubo-tracking-tight);line-height:var(--bubo-leading-tight);color:var(--bubo-white);margin:0;}
.bubo-h2{font-family:var(--bubo-font-body);font-size:var(--bubo-text-3xl);font-weight:600;letter-spacing:var(--bubo-tracking-tight);line-height:var(--bubo-leading-tight);color:var(--bubo-white);margin:0;}
.bubo-lead{font-family:var(--bubo-font-body);font-size:var(--bubo-text-md);line-height:var(--bubo-leading-normal);color:var(--bubo-muted);margin:0;}
.bubo-quote-mark{font-family:var(--bubo-font-script);font-size:120px;line-height:0.7;font-weight:700;background:var(--bubo-gradient-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block;margin-bottom:-30px;font-style:italic;}

/* ===== 3. CARD ===== */
.bubo-card{position:relative;overflow:hidden;background:var(--bubo-glass-bg);border:1px solid var(--bubo-glass-border);border-radius:var(--bubo-radius-xl);padding:var(--bubo-space-8);backdrop-filter:blur(var(--bubo-glass-blur));-webkit-backdrop-filter:blur(var(--bubo-glass-blur));box-shadow:var(--bubo-shadow-lg);transition:transform var(--bubo-transition),border-color var(--bubo-transition),background-color var(--bubo-transition),box-shadow var(--bubo-transition);}
.bubo-card::before{content:"";position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:var(--bubo-glass-halo);pointer-events:none;z-index:0;}
.bubo-card > *{position:relative;z-index:1;}
.bubo-card:hover{transform:translateY(-6px);background:var(--bubo-glass-bg-hover);box-shadow:var(--bubo-shadow-xl);}
.bubo-card--gold:hover{border-color:var(--bubo-glass-border-gold-hover);}
.bubo-card--turq:hover{border-color:var(--bubo-glass-border-turq-hover);}
.bubo-card--static:hover{transform:none;border-color:var(--bubo-glass-border);background:var(--bubo-glass-bg);box-shadow:var(--bubo-shadow-lg);}
.bubo-card .bubo-icon-block,.bubo-card .bubo-icon-circle{transition:transform var(--bubo-transition-bouncy);}
.bubo-card:hover .bubo-icon-block,.bubo-card:hover .bubo-icon-circle{transform:scale(1.12) rotate(-6deg);}

/* ===== 4. BUTTONS ===== */
.bubo-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 28px;border:none;border-radius:var(--bubo-radius-pill);font-family:var(--bubo-font-body);font-size:14px;font-weight:700;letter-spacing:0.01em;cursor:pointer;text-decoration:none;transition:all var(--bubo-transition);line-height:1;}
.bubo-btn--primary{background:var(--bubo-gradient-gold);color:var(--bubo-teal-dark);box-shadow:var(--bubo-shadow-gold);}
.bubo-btn--primary:hover{transform:translateY(-2px);box-shadow:var(--bubo-shadow-gold-strong);color:var(--bubo-white);}
.bubo-btn--ghost{background:var(--bubo-glass-bg);color:var(--bubo-white);border:1px solid var(--bubo-glass-border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.bubo-btn--ghost:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2);}
.bubo-btn--outline{background:transparent;color:var(--bubo-accent);border:2px solid var(--bubo-accent);}
.bubo-btn--outline:hover{background:var(--bubo-accent);color:var(--bubo-teal-dark);}
.bubo-btn--sm{padding:10px 18px;font-size:12px;}
.bubo-btn--lg{padding:18px 36px;font-size:15px;}

/* ===== 5. PILLS ===== */
.bubo-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--bubo-radius-pill);background:rgba(255,255,255,0.05);border:1px solid var(--bubo-glass-border);font-size:var(--bubo-text-xs);font-weight:700;text-transform:uppercase;letter-spacing:var(--bubo-tracking-wide);color:var(--bubo-zinc-300);line-height:1;}
.bubo-pill i{color:var(--bubo-accent);font-size:11px;}
.bubo-pill--gold{background:rgba(237,178,53,0.10);border-color:rgba(237,178,53,0.30);color:var(--bubo-accent);}
.bubo-pill--turq{background:rgba(41,164,166,0.10);border-color:rgba(41,164,166,0.30);color:var(--bubo-turq);}
.bubo-pill-dot{position:relative;width:8px;height:8px;flex-shrink:0;}
.bubo-pill-dot::before,.bubo-pill-dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--bubo-turq);}
.bubo-pill-dot::before{animation:bubo-pulse 2s ease-in-out infinite;}
@keyframes bubo-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.6}}

/* ===== 6. ICONS ===== */
.bubo-icon-block{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--bubo-radius-md);background:rgba(237,178,53,0.12);border:1px solid rgba(237,178,53,0.25);color:var(--bubo-accent);font-size:24px;}
.bubo-icon-block--turq{background:rgba(41,164,166,0.15);border-color:rgba(41,164,166,0.30);color:var(--bubo-turq);}
.bubo-icon-block--sm{width:40px;height:40px;font-size:18px;border-radius:var(--bubo-radius-sm);}
.bubo-icon-block--lg{width:72px;height:72px;font-size:32px;}
.bubo-icon-circle{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:rgba(237,178,53,0.15);border:1px solid rgba(237,178,53,0.3);color:var(--bubo-accent);font-size:22px;}

/* ===== 7. STATS ===== */
.bubo-stats-head{display:flex;align-items:center;gap:var(--bubo-space-4);margin-bottom:var(--bubo-space-6);}
.bubo-stats-num{font-size:32px;font-weight:700;color:var(--bubo-white);line-height:1;}
.bubo-stats-label{font-size:var(--bubo-text-sm);color:var(--bubo-muted);margin-top:4px;}
.bubo-progress{height:8px;width:100%;border-radius:var(--bubo-radius-pill);background:rgba(255,255,255,0.06);overflow:hidden;}
.bubo-progress__bar{height:100%;border-radius:var(--bubo-radius-pill);background:var(--bubo-gradient-progress);box-shadow:0 0 20px rgba(237,178,53,0.5);}
.bubo-mini-stats{display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;gap:var(--bubo-space-2);align-items:center;text-align:center;padding:var(--bubo-space-5) 0;border-top:1px solid rgba(255,255,255,0.08);}
.bubo-mini-stats__val{font-size:20px;font-weight:700;color:var(--bubo-white);display:block;line-height:1;}
.bubo-mini-stats__lbl{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--bubo-zinc-500);font-weight:700;margin-top:4px;display:block;}
.bubo-mini-stats__sep{width:1px;height:36px;background:rgba(255,255,255,0.1);}

/* ===== 8. MARQUEE ===== */
.bubo-marquee{position:relative;overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(to right,transparent,#000 15%,#000 85%,transparent);mask-image:linear-gradient(to right,transparent,#000 15%,#000 85%,transparent);}
.bubo-marquee__track{display:inline-flex;gap:48px;white-space:nowrap;animation:bubo-marquee 30s linear infinite;padding:8px 0;}
.bubo-marquee__item{display:inline-flex;align-items:center;gap:8px;font-size:var(--bubo-text-base);font-weight:600;color:var(--bubo-white);opacity:.5;flex-shrink:0;transition:opacity var(--bubo-transition);}
.bubo-marquee__item:hover{opacity:1;}
.bubo-marquee__item i{color:var(--bubo-accent);font-size:18px;}
@keyframes bubo-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== 9. STEP NUMBERS ===== */
.bubo-step-num{font-family:var(--bubo-font-script);font-size:64px;line-height:1;font-weight:700;background:var(--bubo-gradient-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block;margin-bottom:var(--bubo-space-3);font-style:italic;}

/* ===== 10. CTA CHECKS ===== */
.bubo-checks{display:flex;gap:var(--bubo-space-5);flex-wrap:wrap;justify-content:center;font-size:var(--bubo-text-sm);color:var(--bubo-soft);}
.bubo-checks span{display:inline-flex;align-items:center;gap:6px;}
.bubo-checks i{color:var(--bubo-turq);}

/* ===== 11. LAYOUT ===== */
.bubo-container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--bubo-space-6);box-sizing:border-box;}
.bubo-section{padding:var(--bubo-space-20) 0;position:relative;}
@media (min-width:768px){.bubo-section{padding:var(--bubo-space-24) 0;}}
.bubo-grid{display:grid;gap:var(--bubo-space-6);}
.bubo-grid--2,.bubo-grid--3,.bubo-grid--4{grid-template-columns:minmax(0,1fr);}
@media (min-width:640px){.bubo-grid--2{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (min-width:1024px){.bubo-grid--3{grid-template-columns:repeat(3,minmax(0,1fr));}.bubo-grid--4{grid-template-columns:repeat(4,minmax(0,1fr));}}
.bubo-stack{display:flex;flex-direction:column;gap:var(--bubo-space-6);}
.bubo-stack--sm{gap:var(--bubo-space-3);}
.bubo-stack--lg{gap:var(--bubo-space-10);}
.bubo-cluster{display:flex;flex-wrap:wrap;gap:var(--bubo-space-3);align-items:center;}

/* ===== 12. BACKGROUND HELPERS ===== */
.bubo-bg-dark{background:var(--bubo-teal-bg);color:var(--bubo-white);}
.bubo-bg-atmospheric{position:relative;background:var(--bubo-gradient-bg);color:var(--bubo-white);min-height:100vh;}

/* ===== 13. UTILITIES ===== */
.bubo-text-white{color:var(--bubo-white) !important;}
.bubo-text-muted{color:var(--bubo-muted) !important;}
.bubo-text-soft{color:var(--bubo-soft) !important;}
.bubo-text-accent{color:var(--bubo-accent) !important;}
.bubo-text-turq{color:var(--bubo-turq) !important;}
.bubo-text-center{text-align:center;}
.bubo-text-left{text-align:left;}
.bubo-text-right{text-align:right;}
.bubo-r-sm{border-radius:var(--bubo-radius-sm);}
.bubo-r-md{border-radius:var(--bubo-radius-md);}
.bubo-r-lg{border-radius:var(--bubo-radius-lg);}
.bubo-r-xl{border-radius:var(--bubo-radius-xl);}
.bubo-r-pill{border-radius:var(--bubo-radius-pill);}
.bubo-mt-2{margin-top:var(--bubo-space-2);}.bubo-mt-4{margin-top:var(--bubo-space-4);}.bubo-mt-6{margin-top:var(--bubo-space-6);}.bubo-mt-8{margin-top:var(--bubo-space-8);}.bubo-mt-12{margin-top:var(--bubo-space-12);}
.bubo-mb-2{margin-bottom:var(--bubo-space-2);}.bubo-mb-4{margin-bottom:var(--bubo-space-4);}.bubo-mb-6{margin-bottom:var(--bubo-space-6);}.bubo-mb-8{margin-bottom:var(--bubo-space-8);}.bubo-mb-12{margin-bottom:var(--bubo-space-12);}
.bubo-glow-gold{filter:drop-shadow(0 0 20px rgba(237,178,53,0.4));}
.bubo-blur-bg{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);}
@keyframes bubo-fade-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.bubo-fade-in{animation:bubo-fade-in 0.8s ease-out forwards;opacity:0;}
.bubo-delay-1{animation-delay:0.1s;}.bubo-delay-2{animation-delay:0.2s;}.bubo-delay-3{animation-delay:0.3s;}.bubo-delay-4{animation-delay:0.4s;}.bubo-delay-5{animation-delay:0.5s;}
@media (max-width:767px){.bubo-hide-mobile{display:none !important;}}
@media (min-width:768px){.bubo-hide-desktop{display:none !important;}}
