/*
Theme Name: CortexDefrag Theme
Theme URI: https://cortexdefrag.com
Author: CortexDefrag
Description: Stable dark theme for cortexdefrag.com
Version: 10.3.2
License: GPLv2 or later
Text Domain: cortexdefrag-theme
*/

:root{
  --bg:#000000;
  --bg-soft:#080B12;
  --card:#0C1018;
  --line:rgba(255,255,255,.08);
  --text:#F1F4FA;
  --muted:#9AA3B8;
  --accent:#00C853;
  --accent2:#FFD600;
  --accent-soft:rgba(0,200,83,.16);
  --radius:22px;
  --shadow:0 22px 70px rgba(0,0,0,.55);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:#000;
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  line-height:1.55;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(0,0,0,.92);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(14px);
}
.nav{
  min-height:72px;
  display:flex;
  align-items:center;
  gap:18px;
  position:relative;
}
.brand{
  font-size:16px;
  font-weight:1000;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.brand .glow{
  color:var(--accent);
}
.menu{
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.menu a{
  padding:8px 10px;
  border-radius:12px;
  font-size:13px;
  font-weight:900;
  letter-spacing:.28px;
  text-transform:uppercase;
  color:rgba(241,244,250,.76);
}
.menu a:hover{
  color:#fff;
  background:rgba(255,255,255,.05);
}
.nav-right{margin-left:auto}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#05070C;
  color:rgba(241,244,250,.72);
  font-size:12px;
  font-weight:800;
}
.badge .dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 8px rgba(18,207,243,.25);
}

/* Mobile menu */
.nav-toggle{
  display:none;
  width:42px;height:42px;
  border-radius:14px;
  border:1px solid var(--line);
  background:#05070C;
  position:relative;
  cursor:pointer;
}
.nav-toggle span{
  position:absolute;left:11px;right:11px;height:2px;border-radius:2px;
  background:#EAF3FF;transition:all .2s ease;
}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:20px}
.nav-toggle span:nth-child(3){top:26px}
body.cdf-nav-open .nav-toggle span:nth-child(1){top:20px;transform:rotate(45deg)}
body.cdf-nav-open .nav-toggle span:nth-child(2){opacity:0}
body.cdf-nav-open .nav-toggle span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* Ticker */
.cdf-ticker{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:#000;
  overflow:hidden;
}
.cdf-ticker .track{
  display:flex;
  gap:28px;
  white-space:nowrap;
  padding:10px 0;
  animation:ticker 22s linear infinite;
  color:rgba(241,244,250,.50);
  font-weight:900;
  font-size:12px;
  letter-spacing:.32px;
  text-transform:uppercase;
}
.cdf-ticker .spark{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 6px rgba(18,207,243,.20);
}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Hero */
.hero{padding:56px 0 20px}
.tagline{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#05070C;
  color:rgba(241,244,250,.80);
  font-size:12px;
  font-weight:900;
  letter-spacing:.28px;
  text-transform:uppercase;
}
.tagline .spark{
  width:10px;height:10px;border-radius:50%;
  background:var(--accent);
}
.h1{
  margin:14px 0 12px;
  font-size:64px;
  line-height:1.01;
  letter-spacing:-1.2px;
  color:#F7FAFF;
}
.lead{
  max-width:84ch;
  color:var(--muted);
  font-size:16px;
}
.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  background:#05070C;
  color:#F7FAFF;
  font-size:14px;
  font-weight:1000;
  box-shadow:0 14px 36px rgba(0,0,0,.40);
  transition:transform .2s ease,border-color .2s ease,background .2s ease;
}
.btn:hover{
  transform:translateY(-2px);
  border-color:rgba(18,207,243,.35);
  background:#0A1118;
}
.btn.ghost{
  background:transparent;
  color:rgba(241,244,250,.85);
}

/* Cards */
.grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:16px;
  margin-top:22px;
}
.card-link{grid-column:span 4;display:block}
.card{
  height:100%;
  min-height:170px;
  border-radius:var(--radius);
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:var(--shadow);
  padding:16px;
  transition:transform .2s ease,border-color .2s ease;
}
.card:hover{
  transform:translateY(-5px);
  border-color:rgba(18,207,243,.20);
}
.card h3{
  margin:10px 0 6px;
  text-transform:uppercase;
  letter-spacing:.25px;
}
.card p{margin:0;color:var(--muted)}

.section{margin-top:38px}
.section-title{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:14px;
}
.section-title h2{
  margin:0;
  font-size:22px;
  text-transform:uppercase;
  letter-spacing:.34px;
}
.section-title .muted{color:var(--muted);font-size:13px}
.sep{
  border:0;
  border-top:1px solid var(--line);
  margin:30px 0;
}

/* Shared shells */
.shell{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:var(--shadow);
}
.sc-frame,.services-shell,.contact-shell{position:relative;overflow:hidden;border-radius:28px;border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow)}

/* Services / contact */
.services-hero,.contact-hero{margin-top:10px;padding:18px 18px 0}
.services-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:16px;
  padding:16px;
}
.contact-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:16px;
  padding:16px;
}
.service-card{
  grid-column:span 4;
  display:flex;
  flex-direction:column;
  min-height:510px;
  padding:16px;
  border-radius:22px;
  border:1px solid var(--line);
  background:#0A0E15;
  box-shadow:var(--shadow);
}
.service-card:hover{border-color:rgba(18,207,243,.20)}
.service-card img,.agenda-thumb{
  width:100%;
  height:190px;
  object-fit:cover;
  border-radius:18px;
  border:1px solid var(--line);
  filter:saturate(.82) brightness(.88);
}
.service-meta{
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
  font-weight:900;
  letter-spacing:.22px;
  text-transform:uppercase;
}
.service-title{
  margin:8px 0 10px;
  min-height:48px;
}
.service-desc{
  margin:0;
  color:var(--muted);
  flex-grow:1;
}
.service-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.service-actions .btn{min-width:120px;text-align:center}

.contact-card{
  border-radius:22px;
  border:1px solid var(--line);
  background:#0A0E15;
  box-shadow:var(--shadow);
  padding:16px;
}
.contact-kpis{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.kpi{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid var(--line);
  background:#05070C;
  color:rgba(241,244,250,.80);
  font-size:13px;
  font-weight:800;
}
.kpi .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}

/* Footer / fab */
.footer{
  margin-top:66px;
  border-top:1px solid var(--line);
  color:var(--muted);
  padding:28px 0;
}
.cdf-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:9999;
}
.cdf-fab a{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:#05070C;
  color:#F7FAFF;
  box-shadow:var(--shadow);
  font-weight:1000;
}
.cdf-fab .dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}

/* Loading bar */
#cdf-topbar{
  position:fixed;
  top:0;left:0;
  height:3px;width:0%;
  background:var(--accent);
  box-shadow:0 0 10px rgba(18,207,243,.20);
  z-index:100000;
  opacity:0;
  transition:width .25s ease, opacity .2s ease;
}
#cdf-topbar.on{opacity:1}
html.cdf-leaving body{opacity:.86;transform:translateY(1px);transition:opacity .18s ease,transform .18s ease}

@media (max-width:980px){
  .h1{font-size:44px}
  .card-link,.service-card{grid-column:span 12}
  .service-card{min-height:auto}
  .service-card img,.agenda-thumb{height:220px}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:860px){
  .nav{flex-wrap:nowrap}
  .nav-toggle{display:inline-flex}
  .menu{
    display:none !important;
    position:absolute;
    top:62px;left:16px;right:16px;
    flex-direction:column;
    gap:10px;
    padding:14px;
    border-radius:18px;
    border:1px solid var(--line);
    background:#05070C;
    box-shadow:var(--shadow);
  }
  body.cdf-nav-open .menu{display:flex !important}
  .menu a{width:100%}
  .nav-right .badge{display:none}
}
@media (max-width:520px){
  .hero-actions{gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px}
  .hero-actions .btn{padding:10px 12px;border-radius:14px;font-size:13px;white-space:nowrap}
  .hero-actions::-webkit-scrollbar{height:0}
}

/* v7.1 Brasil Vibration accents */
.brand .glow{
  color: transparent;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  -webkit-background-clip:text;
  background-clip:text;
}
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot,
.cdf-ticker .spark{
  background: linear-gradient(90deg, var(--accent), var(--accent2)) !important;
  box-shadow: 0 0 8px rgba(0,200,83,.24) !important;
}
.btn:hover{
  border-color: rgba(255,214,0,.35);
}


/* v7.2 Brasil Vibration palette (green / blue / yellow / orange accents) */
:root{
  --accent:#00C853;      /* green */
  --accent2:#12CFF3;     /* blue */
  --accent3:#FFD600;     /* yellow */
  --accent4:#FF7A00;     /* orange */
}

/* logo gradient */
.brand .glow{
  background: linear-gradient(90deg, var(--accent), var(--accent2), var(--accent3));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* sparks and dots */
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot,
.cdf-ticker .spark{
  background: linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3));
  box-shadow:0 0 10px rgba(0,200,83,.35);
}

/* ticker highlight */
.cdf-ticker .spark{
  background: linear-gradient(90deg,var(--accent2),var(--accent3),var(--accent4));
}

/* buttons accents */
.btn:hover{
  border-color: var(--accent2);
  box-shadow:0 0 12px rgba(18,207,243,.25);
}

.btn{
  border-color: rgba(255,255,255,.14);
}

.btn.ghost:hover{
  border-color: var(--accent4);
}

/* subtle colored glow for cards */
.card:hover,
.service-card:hover{
  border-color: rgba(0,200,83,.25);
  box-shadow:0 0 18px rgba(18,207,243,.12);
}


/* v7.3 menu titles colored + Brasil spelling */
.menu a{
  background: linear-gradient(90deg, var(--accent), var(--accent2), var(--accent3), var(--accent4));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent !important;
}
.menu a:hover{
  background: linear-gradient(90deg, var(--accent3), var(--accent4), var(--accent), var(--accent2));
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent !important;
}


/* v7.4 faster Brasil colors with red accent */
:root{
  --accent:#00C853;      /* green */
  --accent2:#12CFF3;     /* blue */
  --accent3:#FFD600;     /* yellow */
  --accent4:#FF7A00;     /* orange */
  --accent5:#FF1744;     /* red */
}

/* faster animated gradient for menu titles */
.menu a{
  background: linear-gradient(90deg,var(--accent),var(--accent2),var(--accent3),var(--accent4),var(--accent5));
  background-size:300% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  animation:menuColors 4s linear infinite;
}
.menu a:hover{
  animation:menuColors 2.5s linear infinite;
}

@keyframes menuColors{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

/* ticker sparks faster */
.cdf-ticker .spark{
  background: linear-gradient(90deg,var(--accent2),var(--accent3),var(--accent4),var(--accent5));
  animation:sparkShift 3s linear infinite;
}

@keyframes sparkShift{
  0%{filter:hue-rotate(0deg)}
  100%{filter:hue-rotate(360deg)}
}


/* v7.5 PRO synced title/logo/ticker colors */
:root{
  --pro-blue:#00B7FF;
  --pro-cyan:#00E5FF;
  --pro-orange:#C85A00;
  --pro-orange2:#FF7A00;
}

.brand .glow,
.cdf-title-shift,
.menu a{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue) 0%,
    var(--pro-cyan) 34%,
    var(--pro-orange) 68%,
    var(--pro-orange2) 100%
  );
  background-size: 260% 100%;
  animation: cdfProShift 3.2s linear infinite;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent !important;
}

@keyframes cdfProShift{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

.cdf-title-shift{
  filter: drop-shadow(0 6px 18px rgba(0,183,255,.12));
  letter-spacing:-1.25px;
}
.cdf-title-glow:after{
  background:
    radial-gradient(closest-side, rgba(0,183,255,.10), transparent 68%),
    radial-gradient(closest-side, rgba(0,229,255,.10), transparent 72%),
    radial-gradient(closest-side, rgba(200,90,0,.08), transparent 74%);
  filter: blur(18px);
  opacity:.62;
}

.menu a{
  font-weight:1000;
  transition:opacity .18s ease, transform .18s ease;
}
.menu a:hover{
  opacity:.92;
  transform:translateY(-1px);
  background:none !important;
  animation-duration:1.8s;
}

.cdf-ticker .spark,
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot{
  background: linear-gradient(90deg,var(--pro-blue),var(--pro-cyan),var(--pro-orange),var(--pro-orange2)) !important;
  background-size: 260% 100% !important;
  animation: cdfProShift 2.4s linear infinite;
  box-shadow: 0 0 10px rgba(0,183,255,.18) !important;
}

.btn:hover{
  border-color: rgba(0,183,255,.35) !important;
  box-shadow: 0 0 16px rgba(0,183,255,.10);
}


/* v7.6 dynamic color titles + colored ticker items + neon green hover */
:root{
  --neon-green:#39FF14;
}

/* shared animated gradient */
@keyframes cdfTitleWave{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

/* all major titles animated */
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue) 0%,
    var(--pro-cyan) 28%,
    var(--pro-orange) 64%,
    var(--pro-orange2) 100%
  );
  background-size:260% 100%;
  animation:cdfTitleWave 3.2s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* ticker items in color too */
.cdf-ticker .track,
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue) 0%,
    var(--pro-cyan) 28%,
    var(--pro-orange) 64%,
    var(--pro-orange2) 100%
  );
  background-size:260% 100%;
  animation:cdfTitleWave 2.4s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* neon green hover for menu */
.menu a:hover{
  color:var(--neon-green) !important;
  background:none !important;
  text-shadow:0 0 8px rgba(57,255,20,.35), 0 0 16px rgba(57,255,20,.18);
  animation:none !important;
}

/* keep menu colorful when idle */
.menu a{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue) 0%,
    var(--pro-cyan) 34%,
    var(--pro-orange) 68%,
    var(--pro-orange2) 100%
  );
  background-size:260% 100%;
  animation:cdfProShift 3.2s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}


/* v7.7 Rainbow Spicy Life + more Apple Glass */
:root{
  --spicy-pink:#FF2FB3;
  --spicy-red:#FF3355;
  --spicy-orange:#FF7A00;
  --spicy-yellow:#FFD600;
  --spicy-green:#00D95F;
  --spicy-cyan:#00E5FF;
  --spicy-blue:#2F7BFF;
  --spicy-violet:#8A5CFF;

  --glass: rgba(255,255,255,.10);
  --glass2: rgba(255,255,255,.08);
  --stroke: rgba(255,255,255,.12);
  --stroke2: rgba(255,255,255,.18);
}

/* richer rainbow animated gradient */
@keyframes cdfRainbowFlow{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

.brand .glow,
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3,
.menu a,
.cdf-ticker .track,
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--spicy-pink) 0%,
    var(--spicy-red) 12%,
    var(--spicy-orange) 24%,
    var(--spicy-yellow) 38%,
    var(--spicy-green) 52%,
    var(--spicy-cyan) 66%,
    var(--spicy-blue) 82%,
    var(--spicy-violet) 100%
  );
  background-size: 320% 100%;
  animation: cdfRainbowFlow 2.8s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent !important;
}

/* spicy sparks / dots */
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot,
.cdf-ticker .spark{
  background: linear-gradient(
    90deg,
    var(--spicy-pink),
    var(--spicy-orange),
    var(--spicy-yellow),
    var(--spicy-green),
    var(--spicy-cyan),
    var(--spicy-violet)
  ) !important;
  background-size: 300% 100% !important;
  animation: cdfRainbowFlow 2.2s linear infinite;
  box-shadow:
    0 0 10px rgba(255,47,179,.20),
    0 0 14px rgba(0,229,255,.20),
    0 0 18px rgba(255,122,0,.18) !important;
}

/* more apple glass everywhere */
.header{
  background: rgba(10,14,26,.62) !important;
  backdrop-filter: blur(22px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.35) !important;
  border-bottom: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 10px 34px rgba(0,0,0,.26);
}
.card,
.service-card,
.contact-card,
.sc-frame,
.services-shell,
.contact-shell,
.badge,
.tagline,
.kpi,
.cdf-fab a{
  background: rgba(255,255,255,.10) !important;
  backdrop-filter: blur(24px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(24px) saturate(1.35) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
}
.btn{
  background: rgba(255,255,255,.10) !important;
  backdrop-filter: blur(20px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.3) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
}
.btn.ghost{
  background: rgba(255,255,255,.06) !important;
}

/* deeper colorful ambient lights */
body{
  background:
    radial-gradient(850px 520px at 12% 8%, rgba(255,47,179,.12), transparent 58%),
    radial-gradient(850px 520px at 84% 10%, rgba(255,122,0,.11), transparent 58%),
    radial-gradient(900px 560px at 20% 86%, rgba(0,217,95,.10), transparent 60%),
    radial-gradient(900px 560px at 78% 84%, rgba(0,229,255,.10), transparent 60%),
    linear-gradient(180deg, #070914, #020306 36%, #000000) !important;
}
body:after{
  opacity: .08 !important;
}

/* hover menu stays more playful */
.menu a:hover{
  text-shadow:
    0 0 8px rgba(255,255,255,.14),
    0 0 14px rgba(255,214,0,.20),
    0 0 18px rgba(0,229,255,.18);
  transform: translateY(-1px);
}

/* more premium glow under hero title */
.h1{
  filter: drop-shadow(0 8px 22px rgba(255,255,255,.10));
}
.cdf-title-glow:after{
  background:
    radial-gradient(closest-side, rgba(255,47,179,.10), transparent 70%),
    radial-gradient(closest-side, rgba(255,122,0,.09), transparent 72%),
    radial-gradient(closest-side, rgba(0,229,255,.10), transparent 72%),
    radial-gradient(closest-side, rgba(138,92,255,.10), transparent 76%);
  filter: blur(22px);
  opacity:.72;
}

/* v7.8 Apple Rainbow Maximal polish */
:root{
  --glass: rgba(255,255,255,.14);
  --glass2: rgba(255,255,255,.11);
  --stroke: rgba(255,255,255,.18);
  --stroke2: rgba(255,255,255,.24);
}
.header,
.card,
.service-card,
.contact-card,
.sc-frame,
.services-shell,
.contact-shell,
.badge,
.tagline,
.kpi,
.cdf-fab a,
.btn{
  backdrop-filter: blur(28px) saturate(1.55) !important;
  -webkit-backdrop-filter: blur(28px) saturate(1.55) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.16) !important;
}
.card:before,
.service-card:before,
.contact-card:before,
.sc-frame:before,
.services-shell:before,
.contact-shell:before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    linear-gradient(120deg, rgba(255,255,255,.18), rgba(255,255,255,0) 24%),
    linear-gradient(90deg,
      rgba(255,47,179,.14),
      rgba(255,122,0,.12),
      rgba(255,214,0,.14),
      rgba(0,217,95,.12),
      rgba(0,229,255,.14),
      rgba(47,123,255,.12),
      rgba(138,92,255,.14)
    );
  opacity:.46;
  filter: blur(26px);
  pointer-events:none;
}
.brand .glow,
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3,
.menu a,
.cdf-ticker .track,
.cdf-ticker .track span{
  background-size: 360% 100% !important;
  animation: cdfRainbowFlow 2.2s linear infinite !important;
}
body{
  background:
    radial-gradient(900px 560px at 10% 8%, rgba(255,47,179,.15), transparent 58%),
    radial-gradient(900px 560px at 88% 10%, rgba(255,122,0,.14), transparent 58%),
    radial-gradient(920px 600px at 20% 86%, rgba(0,217,95,.13), transparent 60%),
    radial-gradient(920px 600px at 78% 84%, rgba(0,229,255,.13), transparent 60%),
    radial-gradient(820px 520px at 56% 22%, rgba(138,92,255,.10), transparent 62%),
    linear-gradient(180deg, #0A0D19, #04050A 36%, #000000) !important;
}
.card:hover,
.service-card:hover{
  transform: translateY(-6px) scale(1.01) !important;
  box-shadow:
    0 28px 90px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.18),
    0 0 22px rgba(255,255,255,.06) !important;
}


/* v7.9 Balanced rainbow (less flashy, more pro) */

/* restore smooth ticker scrolling */
.cdf-ticker .track{
  animation: tickerScroll 18s linear infinite !important;
}

@keyframes tickerScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* softer rainbow palette */
:root{
  --pro-blue:#4FC3F7;
  --pro-cyan:#26C6DA;
  --pro-orange:#FB8C00;
  --pro-violet:#7E57C2;
}

/* balanced gradient */
.brand .glow,
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3,
.menu a{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue),
    var(--pro-cyan),
    var(--pro-violet),
    var(--pro-orange)
  );
  background-size:220% 100%;
  animation:cdfBalancedShift 4s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

@keyframes cdfBalancedShift{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

/* ticker text colored but calmer */
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue),
    var(--pro-cyan),
    var(--pro-violet),
    var(--pro-orange)
  );
  background-size:220% 100%;
  animation:cdfBalancedShift 6s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* subtle hover instead of flashy */
.menu a:hover{
  text-shadow:0 0 6px rgba(38,198,218,.25);
  transform:translateY(-1px);
}


/* v8.0 slower rainbow with cyan/orange/red accents */
:root{
  --pro-cyan:#26C6DA;
  --pro-orange:#FB8C00;
  --pro-red:#E53935;
  --pro-blue:#42A5F5;
}

/* slower color shift */
@keyframes cdfBalancedShift{
  0%{background-position:0% 50%}
  100%{background-position:100% 50%}
}

/* apply palette */
.brand .glow,
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3,
.menu a{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue),
    var(--pro-cyan),
    var(--pro-orange),
    var(--pro-red)
  );
  background-size:260% 100%;
  animation:cdfBalancedShift 7s linear infinite; /* slower */
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* ticker colors slower too */
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--pro-blue),
    var(--pro-cyan),
    var(--pro-orange),
    var(--pro-red)
  );
  background-size:260% 100%;
  animation:cdfBalancedShift 9s linear infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* v8.1 fluid pro colors for hero actions */
:root{--flow1:#00E5FF;--flow2:#26C6DA;--flow3:#42A5F5;--flow4:#FB8C00;--flow5:#E53935;--flow6:#FF7A00}
.brand .glow,.h1,.section-title h2,.service-title,.contact-card h2,.card h3,.menu a,.cdf-ticker .track span{
background-image:linear-gradient(90deg,var(--flow1),var(--flow2),var(--flow3),var(--flow4),var(--flow5),var(--flow6)) !important;
background-size:320% 100% !important;animation:cdfFluidRainbow 10s ease-in-out infinite !important;-webkit-background-clip:text;background-clip:text;color:transparent !important}
@keyframes cdfFluidRainbow{0%{background-position:0% 50%;filter:hue-rotate(0deg)}25%{background-position:35% 50%;filter:hue-rotate(35deg)}50%{background-position:70% 50%;filter:hue-rotate(75deg)}75%{background-position:35% 50%;filter:hue-rotate(130deg)}100%{background-position:0% 50%;filter:hue-rotate(180deg)}}
.hero-actions .btn{position:relative;background:rgba(255,255,255,.08) !important;border:1px solid rgba(255,255,255,.16) !important;overflow:hidden}
.hero-actions .btn span{
background-image:linear-gradient(90deg,var(--flow1),var(--flow2),var(--flow3),var(--flow4),var(--flow5),var(--flow6));
background-size:320% 100%;animation:cdfFluidRainbow 8s ease-in-out infinite;-webkit-background-clip:text;background-clip:text;color:transparent !important;position:relative;z-index:2}
.hero-actions .btn:before{
content:"";position:absolute;inset:-1px;background:linear-gradient(90deg,rgba(0,229,255,.18),rgba(38,198,218,.16),rgba(66,165,245,.14),rgba(251,140,0,.14),rgba(229,57,53,.14),rgba(255,122,0,.16));
background-size:320% 100%;animation:cdfFluidRainbow 10s ease-in-out infinite;opacity:.55;filter:blur(18px);z-index:1}
.hero-actions .btn:hover{transform:translateY(-2px) scale(1.01);border-color:rgba(255,255,255,.22) !important;box-shadow:0 14px 34px rgba(0,0,0,.34),0 0 20px rgba(0,229,255,.10)}
.hero-actions .btn.ghost{background:rgba(255,255,255,.05) !important}


/* v8.2 Brasil + Bleu Blanc Rouge, less pink, more classy/pro */
:root{
  --flow1:#00C853;   /* Brasil green */
  --flow2:#FFD600;   /* Brasil yellow */
  --flow3:#26C6DA;   /* cyan */
  --flow4:#1E5BFF;   /* blue */
  --flow5:#F5F7FF;   /* white */
  --flow6:#E53935;   /* red */
  --flow7:#FF7A00;   /* orange */
}

/* stronger but elegant motion */
@keyframes cdfFluidRainbow{
  0%{background-position:0% 50%; filter:hue-rotate(0deg)}
  20%{background-position:28% 50%; filter:hue-rotate(18deg)}
  45%{background-position:68% 50%; filter:hue-rotate(42deg)}
  70%{background-position:34% 50%; filter:hue-rotate(76deg)}
  100%{background-position:0% 50%; filter:hue-rotate(110deg)}
}

/* classy multi-palette: Brasil + FR */
.brand .glow,
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3,
.menu a,
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--flow1) 0%,
    var(--flow2) 16%,
    var(--flow3) 32%,
    var(--flow4) 52%,
    var(--flow5) 70%,
    var(--flow6) 86%,
    var(--flow7) 100%
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfFluidRainbow 6.2s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* Hero buttons more perceptible and premium */
.hero-actions .btn span{
  background-image: linear-gradient(
    90deg,
    var(--flow1) 0%,
    var(--flow2) 16%,
    var(--flow3) 32%,
    var(--flow4) 52%,
    var(--flow5) 70%,
    var(--flow6) 86%,
    var(--flow7) 100%
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfFluidRainbow 5.4s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}
.hero-actions .btn:before{
  background: linear-gradient(
    90deg,
    rgba(0,200,83,.20),
    rgba(255,214,0,.18),
    rgba(38,198,218,.18),
    rgba(30,91,255,.16),
    rgba(245,247,255,.14),
    rgba(229,57,53,.16),
    rgba(255,122,0,.18)
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfFluidRainbow 6.8s ease-in-out infinite !important;
  opacity:.62 !important;
  filter: blur(20px) !important;
}

/* ticker sparks and dots */
.cdf-ticker .spark,
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot{
  background: linear-gradient(
    90deg,
    var(--flow1),
    var(--flow2),
    var(--flow3),
    var(--flow4),
    var(--flow5),
    var(--flow6),
    var(--flow7)
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfFluidRainbow 4.6s ease-in-out infinite !important;
  box-shadow:
    0 0 10px rgba(38,198,218,.18),
    0 0 14px rgba(30,91,255,.14),
    0 0 18px rgba(229,57,53,.12) !important;
}

/* less pink, more elegant hover */
.menu a:hover{
  color: transparent !important;
  background-image: linear-gradient(
    90deg,
    var(--flow2),
    var(--flow3),
    var(--flow4),
    var(--flow5),
    var(--flow6)
  ) !important;
  background-size: 320% 100% !important;
  -webkit-background-clip:text;
  background-clip:text;
  text-shadow:
    0 0 8px rgba(38,198,218,.16),
    0 0 12px rgba(30,91,255,.12);
  transform: translateY(-1px);
  animation: cdfFluidRainbow 3.6s ease-in-out infinite !important;
}

/* title glow cleaner and classier */
.cdf-title-glow:after{
  background:
    radial-gradient(closest-side, rgba(0,200,83,.08), transparent 68%),
    radial-gradient(closest-side, rgba(255,214,0,.08), transparent 70%),
    radial-gradient(closest-side, rgba(38,198,218,.08), transparent 72%),
    radial-gradient(closest-side, rgba(30,91,255,.08), transparent 74%),
    radial-gradient(closest-side, rgba(245,247,255,.07), transparent 76%),
    radial-gradient(closest-side, rgba(229,57,53,.08), transparent 78%),
    radial-gradient(closest-side, rgba(255,122,0,.08), transparent 80%);
  filter: blur(20px);
  opacity:.58;
}


/* v8.3 Brazil Energy palette (green / yellow / blue only) */
:root{
  --flow1:#00C853;   /* Brazil green */
  --flow2:#FFD600;   /* Brazil yellow */
  --flow3:#1E5BFF;   /* Brazil blue */
  --flow4:#26C6DA;   /* cyan energy accent */
}

/* smoother color motion */
@keyframes brasilEnergyShift{
  0%{background-position:0% 50%; filter:hue-rotate(0deg)}
  50%{background-position:50% 50%; filter:hue-rotate(20deg)}
  100%{background-position:100% 50%; filter:hue-rotate(40deg)}
}

/* titles / menu / ticker */
.brand .glow,
.h1,
.section-title h2,
.service-title,
.contact-card h2,
.card h3,
.menu a,
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--flow1),
    var(--flow2),
    var(--flow3),
    var(--flow4)
  ) !important;
  background-size: 300% 100% !important;
  animation: brasilEnergyShift 7s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent !important;
}

/* hero buttons text */
.hero-actions .btn span{
  background-image: linear-gradient(
    90deg,
    var(--flow1),
    var(--flow2),
    var(--flow3),
    var(--flow4)
  );
  background-size:300% 100%;
  animation: brasilEnergyShift 6s ease-in-out infinite;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* sparks / dots */
.cdf-ticker .spark,
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot{
  background: linear-gradient(
    90deg,
    var(--flow1),
    var(--flow2),
    var(--flow3)
  ) !important;
  box-shadow:0 0 10px rgba(0,200,83,.22) !important;
}


/* v8.4 title faster white/green/blue/red/yellow */
:root{
  --title1:#F5F7FF; /* white */
  --title2:#00C853; /* green */
  --title3:#1E5BFF; /* blue */
  --title4:#E53935; /* red */
  --title5:#FFD600; /* yellow */
}

@keyframes cdfTitleFastShift{
  0%{background-position:0% 50%; filter:hue-rotate(0deg)}
  20%{background-position:25% 50%; filter:hue-rotate(10deg)}
  40%{background-position:55% 50%; filter:hue-rotate(20deg)}
  60%{background-position:80% 50%; filter:hue-rotate(35deg)}
  80%{background-position:45% 50%; filter:hue-rotate(55deg)}
  100%{background-position:0% 50%; filter:hue-rotate(75deg)}
}

.h1{
  background-image: linear-gradient(
    90deg,
    var(--title1) 0%,
    var(--title2) 22%,
    var(--title3) 46%,
    var(--title4) 72%,
    var(--title5) 100%
  ) !important;
  background-size: 340% 100% !important;
  animation: cdfTitleFastShift 4.2s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color: transparent !important;
  text-shadow: none !important;
}


/* v8.5 finale ultra propre: synchronized premium color system */

/* shared palette */
:root{
  --sync-blue:#1E5BFF;
  --sync-green:#00C853;
  --sync-yellow:#FFD600;
  --sync-white:#F5F7FF;
  --sync-cyan:#26C6DA;
  --sync-red:#E53935;
  --sync-orange:#FF7A00;
}

/* one shared premium motion */
@keyframes cdfSyncFlow{
  0%{background-position:0% 50%; filter:hue-rotate(0deg)}
  20%{background-position:24% 50%; filter:hue-rotate(10deg)}
  40%{background-position:54% 50%; filter:hue-rotate(22deg)}
  60%{background-position:82% 50%; filter:hue-rotate(40deg)}
  80%{background-position:46% 50%; filter:hue-rotate(58deg)}
  100%{background-position:0% 50%; filter:hue-rotate(76deg)}
}

/* Logo: blue -> green -> yellow -> white, faster */
.brand .glow{
  background-image: linear-gradient(
    90deg,
    var(--sync-blue) 0%,
    var(--sync-green) 30%,
    var(--sync-yellow) 64%,
    var(--sync-white) 100%
  ) !important;
  background-size: 320% 100% !important;
  animation: cdfSyncFlow 2.2s linear infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  text-shadow:none !important;
  filter: drop-shadow(0 0 8px rgba(30,91,255,.14));
}

/* Main title: white / green / blue / red / yellow */
.h1{
  background-image: linear-gradient(
    90deg,
    var(--sync-white) 0%,
    var(--sync-green) 22%,
    var(--sync-blue) 46%,
    var(--sync-red) 72%,
    var(--sync-yellow) 100%
  ) !important;
  background-size: 340% 100% !important;
  animation: cdfSyncFlow 4.0s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  filter: drop-shadow(0 6px 18px rgba(38,198,218,.10));
}

/* Menu: elegant and readable, slower than logo */
.menu a{
  background-image: linear-gradient(
    90deg,
    var(--sync-green),
    var(--sync-yellow),
    var(--sync-blue),
    var(--sync-white),
    var(--sync-red),
    var(--sync-orange)
  ) !important;
  background-size: 320% 100% !important;
  animation: cdfSyncFlow 6.2s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* Hover stays neon green */
.menu a:hover{
  background:none !important;
  color:#39FF14 !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  animation:none !important;
  text-shadow:
    0 0 6px rgba(57,255,20,.55),
    0 0 12px rgba(57,255,20,.36),
    0 0 18px rgba(57,255,20,.22);
  transform:translateY(-1px);
}

/* Section/card titles */
.section-title h2,
.service-title,
.contact-card h2,
.card h3{
  background-image: linear-gradient(
    90deg,
    var(--sync-green),
    var(--sync-yellow),
    var(--sync-blue),
    var(--sync-cyan)
  ) !important;
  background-size: 300% 100% !important;
  animation: cdfSyncFlow 6.8s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* Ticker items colored and moving */
.cdf-ticker .track{
  animation: tickerScroll 18s linear infinite !important;
}
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--sync-green),
    var(--sync-yellow),
    var(--sync-blue),
    var(--sync-cyan),
    var(--sync-orange)
  ) !important;
  background-size: 320% 100% !important;
  animation: cdfSyncFlow 7.6s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}
@keyframes tickerScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* Hero buttons text also animated, premium and readable */
.hero-actions .btn span{
  background-image: linear-gradient(
    90deg,
    var(--sync-green),
    var(--sync-yellow),
    var(--sync-blue),
    var(--sync-white),
    var(--sync-red),
    var(--sync-orange)
  ) !important;
  background-size: 340% 100% !important;
  animation: cdfSyncFlow 5.6s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  position:relative;
  z-index:2;
}
.hero-actions .btn:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: linear-gradient(
    90deg,
    rgba(0,200,83,.16),
    rgba(255,214,0,.14),
    rgba(30,91,255,.14),
    rgba(245,247,255,.10),
    rgba(229,57,53,.12),
    rgba(255,122,0,.14)
  ) !important;
  background-size: 340% 100% !important;
  animation: cdfSyncFlow 7.2s ease-in-out infinite !important;
  opacity:.56 !important;
  filter:blur(18px) !important;
  z-index:1;
}
.hero-actions .btn:hover{
  box-shadow:
    0 14px 34px rgba(0,0,0,.32),
    0 0 16px rgba(38,198,218,.08);
}

/* Dots / sparks synchronized */
.cdf-ticker .spark,
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot{
  background: linear-gradient(
    90deg,
    var(--sync-green),
    var(--sync-yellow),
    var(--sync-blue),
    var(--sync-cyan)
  ) !important;
  background-size: 320% 100% !important;
  animation: cdfSyncFlow 4.8s ease-in-out infinite !important;
  box-shadow:
    0 0 8px rgba(0,200,83,.18),
    0 0 12px rgba(30,91,255,.14) !important;
}

/* Cleaner, classier title glow */
.cdf-title-glow:after{
  background:
    radial-gradient(closest-side, rgba(245,247,255,.08), transparent 68%),
    radial-gradient(closest-side, rgba(0,200,83,.07), transparent 72%),
    radial-gradient(closest-side, rgba(30,91,255,.07), transparent 76%),
    radial-gradient(closest-side, rgba(255,214,0,.07), transparent 80%);
  filter: blur(18px);
  opacity:.54;
}


/* v9.0 Festival Mode */
:root{
  --festival-pink:#FF3DB8;
  --festival-orange:#FF7A00;
  --festival-yellow:#FFD600;
  --festival-green:#00D95F;
  --festival-cyan:#00E5FF;
  --festival-blue:#2F7BFF;
  --festival-violet:#8A5CFF;
}

/* richer ambient lights */
body{
  background:
    radial-gradient(900px 560px at 8% 8%, rgba(255,61,184,.14), transparent 58%),
    radial-gradient(900px 560px at 88% 10%, rgba(255,122,0,.14), transparent 58%),
    radial-gradient(920px 600px at 18% 86%, rgba(0,217,95,.13), transparent 60%),
    radial-gradient(920px 600px at 78% 84%, rgba(0,229,255,.14), transparent 60%),
    radial-gradient(820px 520px at 56% 22%, rgba(138,92,255,.12), transparent 62%),
    linear-gradient(180deg, #0A0D19, #04050A 36%, #000000) !important;
}

/* cinematic beams */
body::before{
  background:
    radial-gradient(1000px 680px at 16% 8%, rgba(255,61,184,.16), transparent 52%),
    radial-gradient(1000px 680px at 84% 10%, rgba(0,229,255,.16), transparent 52%),
    radial-gradient(1200px 740px at 50% 100%, rgba(0,0,0,.52), transparent 60%) !important;
  filter: blur(34px);
  opacity:.96;
}

/* particle shimmer overlay */
body::after{
  content:"";
  position:fixed; inset:0;
  background-image:
    radial-gradient(circle at 10% 20%, rgba(255,255,255,.12) 0 1px, transparent 1.5px),
    radial-gradient(circle at 30% 80%, rgba(255,255,255,.10) 0 1px, transparent 1.5px),
    radial-gradient(circle at 70% 30%, rgba(255,255,255,.12) 0 1px, transparent 1.5px),
    radial-gradient(circle at 90% 70%, rgba(255,255,255,.10) 0 1px, transparent 1.5px);
  background-size: 220px 220px, 300px 300px, 260px 260px, 340px 340px;
  mix-blend-mode: screen;
  opacity:.10 !important;
  animation: cdfParticles 16s linear infinite;
}
@keyframes cdfParticles{
  0%{transform:translateY(0)}
  100%{transform:translateY(-20px)}
}

/* hero title stronger */
.h1{
  background-image: linear-gradient(
    90deg,
    var(--festival-pink),
    var(--festival-orange),
    var(--festival-yellow),
    var(--festival-green),
    var(--festival-cyan),
    var(--festival-blue),
    var(--festival-violet)
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfSyncFlow 3.6s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  filter: drop-shadow(0 8px 22px rgba(255,255,255,.10));
}

/* cards more festival/glossy */
.card,
.service-card,
.contact-card,
.sc-frame,
.services-shell,
.contact-shell{
  background: rgba(255,255,255,.11) !important;
  backdrop-filter: blur(26px) saturate(1.45) !important;
  -webkit-backdrop-filter: blur(26px) saturate(1.45) !important;
  border:1px solid rgba(255,255,255,.16) !important;
  box-shadow:
    0 26px 80px rgba(0,0,0,.38),
    inset 0 1px 0 rgba(255,255,255,.18) !important;
}

/* stage-light border glow */
.card:hover,
.service-card:hover{
  box-shadow:
    0 30px 96px rgba(0,0,0,.42),
    inset 0 1px 0 rgba(255,255,255,.20),
    0 0 26px rgba(0,229,255,.08),
    0 0 34px rgba(255,61,184,.08) !important;
  transform: translateY(-7px) scale(1.012) !important;
}

/* buttons more alive */
.hero-actions .btn,
.btn{
  background: rgba(255,255,255,.10) !important;
  backdrop-filter: blur(22px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.4) !important;
}
.hero-actions .btn:before,
.btn:before{
  background: linear-gradient(
    90deg,
    rgba(255,61,184,.18),
    rgba(255,122,0,.18),
    rgba(255,214,0,.16),
    rgba(0,217,95,.16),
    rgba(0,229,255,.18),
    rgba(47,123,255,.16),
    rgba(138,92,255,.18)
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfSyncFlow 6.4s ease-in-out infinite !important;
  opacity:.68 !important;
  filter: blur(20px) !important;
}
.hero-actions .btn:hover,
.btn:hover{
  box-shadow:
    0 18px 40px rgba(0,0,0,.34),
    0 0 22px rgba(0,229,255,.10),
    0 0 28px rgba(255,61,184,.10) !important;
}

/* ticker more festival */
.cdf-ticker{
  background: rgba(6,10,18,.82) !important;
  backdrop-filter: blur(18px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.35) !important;
}
.cdf-ticker .track span{
  background-image: linear-gradient(
    90deg,
    var(--festival-yellow),
    var(--festival-green),
    var(--festival-cyan),
    var(--festival-blue),
    var(--festival-violet),
    var(--festival-pink),
    var(--festival-orange)
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfSyncFlow 5.8s linear infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}
.cdf-ticker .spark,
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot{
  background: linear-gradient(
    90deg,
    var(--festival-pink),
    var(--festival-orange),
    var(--festival-yellow),
    var(--festival-green),
    var(--festival-cyan),
    var(--festival-blue),
    var(--festival-violet)
  ) !important;
  background-size: 360% 100% !important;
  animation: cdfSyncFlow 4.2s ease-in-out infinite !important;
  box-shadow:
    0 0 10px rgba(255,61,184,.16),
    0 0 14px rgba(0,229,255,.16),
    0 0 18px rgba(255,214,0,.14) !important;
}

/* active glow under menu hover remains green */
.menu a:hover{
  text-shadow:
    0 0 8px rgba(57,255,20,.56),
    0 0 14px rgba(57,255,20,.34),
    0 0 20px rgba(57,255,20,.20) !important;
}

/* home cards stage labels */
.badge,
.tagline,
.kpi{
  background: rgba(255,255,255,.10) !important;
  backdrop-filter: blur(18px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(18px) saturate(1.35) !important;
}

/* mobile still readable */
@media (max-width: 860px){
  .menu{
    background: rgba(10,14,24,.94) !important;
    backdrop-filter: blur(24px) saturate(1.35) !important;
    -webkit-backdrop-filter: blur(24px) saturate(1.35) !important;
  }
}


/* v9.1 logo bigger + slower color shift */
.brand{
  font-size: 20px !important;
  letter-spacing: .7px;
}
.brand .glow{
  font-size: inherit;
  background-size: 320% 100% !important;
  animation: cdfSyncFlow 4.8s linear infinite !important;
}
@media (max-width: 860px){
  .brand{font-size:18px !important;}
}


/* v9.2 solar hero refinement */
.h1{
  font-size:56px !important;
  line-height:1.02;
  letter-spacing:-1px;
  text-shadow:0 0 12px rgba(255,255,255,.12);
}

.hero{
  position:relative;
  overflow:visible;
}
.hero:before{
  content:"";
  position:absolute;
  left:50%;
  top:8px;
  width:520px;
  height:240px;
  transform:translateX(-50%);
  background:
    radial-gradient(closest-side, rgba(255,214,0,.10), transparent 68%),
    radial-gradient(closest-side, rgba(0,229,255,.08), transparent 72%),
    radial-gradient(closest-side, rgba(255,122,0,.07), transparent 76%);
  filter:blur(24px);
  opacity:.72;
  pointer-events:none;
  z-index:0;
}
.hero > *{
  position:relative;
  z-index:1;
}
.lead{
  max-width:760px;
}
@media (max-width:980px){
  .h1{font-size:44px !important;}
  .hero:before{width:360px;height:180px;top:18px;}
}


/* v9.5 stable pro fix: clickable home cards + keep agenda/services intact */
.grid,
.section,
.sc-frame,
.hero-actions,
.hero{
  position:relative;
  z-index:3;
}

.card-link{
  display:block !important;
  text-decoration:none;
  position:relative;
  z-index:4;
  pointer-events:auto !important;
}
.card-link .card{
  cursor:pointer;
}
.card-link .card > *{
  pointer-events:none !important;
}

.hero-actions .btn,
.hero-actions .btn *{
  pointer-events:auto !important;
}

.sc-frame{
  position:relative;
  z-index:2;
}
.sc-frame iframe{
  position:relative;
  z-index:1;
}
.sc-frame .btn,
.sc-frame a.btn,
.sc-frame a[href*="/mixes"],
.sc-frame a[href*="soundcloud.com"]{
  position:relative !important;
  z-index:5 !important;
  pointer-events:auto !important;
}

.card:hover,
.card-link:hover .card{
  transform: translateY(-6px) scale(1.01);
}

@media (max-width:980px){
  .card-link{grid-column:span 12;}
}


/* v10.0 stable festival final */
:root{
  --v10-green:#00C853;
  --v10-yellow:#FFD600;
  --v10-blue:#1E5BFF;
  --v10-cyan:#26C6DA;
  --v10-white:#F5F7FF;
  --v10-orange:#FF7A00;
  --v10-red:#E53935;
}

@keyframes v10ColorFlow{
  0%{background-position:0% 50%; filter:hue-rotate(0deg)}
  25%{background-position:28% 50%; filter:hue-rotate(12deg)}
  50%{background-position:62% 50%; filter:hue-rotate(24deg)}
  75%{background-position:36% 50%; filter:hue-rotate(40deg)}
  100%{background-position:0% 50%; filter:hue-rotate(58deg)}
}

/* polished typography color system */
.brand .glow{
  background-image: linear-gradient(90deg, var(--v10-blue), var(--v10-green), var(--v10-yellow), var(--v10-white));
  background-size: 320% 100% !important;
  animation: v10ColorFlow 4.8s linear infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

.h1{
  background-image: linear-gradient(
    90deg,
    var(--v10-white),
    var(--v10-green),
    var(--v10-blue),
    var(--v10-cyan),
    var(--v10-yellow),
    var(--v10-orange),
    var(--v10-red)
  ) !important;
  background-size: 360% 100% !important;
  animation: v10ColorFlow 4.6s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

.section-title h2,
.service-title,
.contact-card h2,
.card h3{
  background-image: linear-gradient(90deg, var(--v10-green), var(--v10-yellow), var(--v10-blue), var(--v10-cyan));
  background-size: 300% 100% !important;
  animation: v10ColorFlow 6.8s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

.menu a{
  background-image: linear-gradient(90deg, var(--v10-green), var(--v10-yellow), var(--v10-blue), var(--v10-white), var(--v10-orange));
  background-size: 320% 100% !important;
  animation: v10ColorFlow 6s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}
.menu a:hover{
  background:none !important;
  color:#39FF14 !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
  animation:none !important;
  text-shadow:0 0 6px rgba(57,255,20,.55),0 0 12px rgba(57,255,20,.36),0 0 18px rgba(57,255,20,.22);
}

.cdf-ticker .track{
  animation: tickerScroll 18s linear infinite !important;
}
@keyframes tickerScroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.cdf-ticker .track span{
  background-image: linear-gradient(90deg, var(--v10-yellow), var(--v10-green), var(--v10-cyan), var(--v10-blue), var(--v10-orange));
  background-size: 320% 100% !important;
  animation: v10ColorFlow 7.4s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
}

/* dots / sparks / pills */
.cdf-ticker .spark,
.badge .dot,
.tagline .spark,
.kpi .dot,
.cdf-fab .dot{
  background: linear-gradient(90deg, var(--v10-green), var(--v10-yellow), var(--v10-blue), var(--v10-cyan)) !important;
  background-size: 320% 100% !important;
  animation: v10ColorFlow 4.8s ease-in-out infinite !important;
  box-shadow:0 0 8px rgba(0,200,83,.18),0 0 12px rgba(30,91,255,.14) !important;
}

.hero-actions .btn span{
  background-image: linear-gradient(90deg, var(--v10-green), var(--v10-yellow), var(--v10-blue), var(--v10-white), var(--v10-orange), var(--v10-red)) !important;
  background-size: 340% 100% !important;
  animation: v10ColorFlow 5.8s ease-in-out infinite !important;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  position:relative;
  z-index:2;
}
.hero-actions .btn:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: linear-gradient(90deg, rgba(0,200,83,.16), rgba(255,214,0,.14), rgba(30,91,255,.14), rgba(245,247,255,.10), rgba(255,122,0,.14), rgba(229,57,53,.12)) !important;
  background-size: 340% 100% !important;
  animation: v10ColorFlow 7.2s ease-in-out infinite !important;
  opacity:.56 !important;
  filter:blur(18px) !important;
  z-index:1;
}

.hero{
  position:relative;
  overflow:visible;
}
.hero:before{
  content:"";
  position:absolute;
  left:50%;
  top:8px;
  width:520px;
  height:240px;
  transform:translateX(-50%);
  background:
    radial-gradient(closest-side, rgba(255,214,0,.10), transparent 68%),
    radial-gradient(closest-side, rgba(0,229,255,.08), transparent 72%),
    radial-gradient(closest-side, rgba(255,122,0,.07), transparent 76%);
  filter:blur(24px);
  opacity:.72;
  pointer-events:none;
  z-index:0;
}
.hero > *{position:relative;z-index:1}

/* home cards click stability */
.grid,.section,.sc-frame,.hero-actions,.hero{position:relative;z-index:3}
.card-link{
  display:block !important;
  text-decoration:none;
  position:relative;
  z-index:4;
  pointer-events:auto !important;
}
.card-link .card{cursor:pointer}
.card-link .card > *{pointer-events:none !important}
.hero-actions .btn,.hero-actions .btn *{pointer-events:auto !important}
.sc-frame{position:relative;z-index:2}
.sc-frame iframe{position:relative;z-index:1}
.sc-frame .btn,
.sc-frame a.btn,
.sc-frame a[href*="/mixes"],
.sc-frame a[href*="soundcloud.com"]{
  position:relative !important;
  z-index:5 !important;
  pointer-events:auto !important;
}

/* premium festival glass without breaking layout */
.header{
  background: rgba(10,14,26,.72) !important;
  backdrop-filter: blur(20px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.3) !important;
  border-bottom:1px solid rgba(255,255,255,.14) !important;
}
.card,.service-card,.contact-card,.sc-frame,.services-shell,.contact-shell,.badge,.tagline,.kpi,.cdf-fab a,.btn{
  background: rgba(255,255,255,.10) !important;
  backdrop-filter: blur(22px) saturate(1.32) !important;
  -webkit-backdrop-filter: blur(22px) saturate(1.32) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:0 24px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.14) !important;
}
.card:hover,.service-card:hover{
  transform: translateY(-6px) scale(1.01) !important;
  box-shadow:0 28px 90px rgba(0,0,0,.40), inset 0 1px 0 rgba(255,255,255,.18), 0 0 22px rgba(255,255,255,.05) !important;
}

.lead{
  max-width:760px;
}

@media (max-width:980px){
  .card-link{grid-column:span 12;}
  .hero:before{width:360px;height:180px;top:18px;}
}


/* v10.1 contact form styles */
.cdf-contact-form{display:block}
.cdf-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.cdf-field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.cdf-field label{color:rgba(245,247,255,.82);font-size:13px;font-weight:800;letter-spacing:.2px}
.cdf-field input,.cdf-field textarea{
  width:100%;border-radius:16px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);color:#F5F7FF;padding:14px 16px;outline:none;
  backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2)
}
.cdf-field input:focus,.cdf-field textarea:focus{
  border-color:rgba(57,255,20,.35);box-shadow:0 0 0 3px rgba(57,255,20,.08)
}
.cdf-form-actions{margin-top:8px}
.contact-notice{margin:0 0 14px;padding:12px 14px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08)}
.contact-success{color:#b7ffcf;border-color:rgba(0,200,83,.24)}
.contact-error{color:#ffd0d0;border-color:rgba(229,57,53,.24)}
@media (max-width:720px){.cdf-form-grid{grid-template-columns:1fr}}


/* v10.3 stable fixes: contact form clickability + service CTA clickability */
.contact-shell,
.contact-grid,
.contact-card,
.cdf-contact-form,
.cdf-contact-form *,
.service-card,
.service-card *,
.service-actions,
.service-actions * {
  pointer-events: auto !important;
}

.contact-shell,
.contact-grid,
.contact-card,
.service-card,
.service-actions {
  position: relative;
  z-index: 10;
}

.cdf-contact-form{
  position: relative;
  z-index: 20;
}

.cdf-contact-form input,
.cdf-contact-form textarea,
.cdf-contact-form button{
  position: relative;
  z-index: 21;
}

.service-actions .btn,
.service-actions a.btn,
.service-actions a{
  position: relative;
  z-index: 20 !important;
  pointer-events: auto !important;
  display: inline-flex !important;
}

/* avoid overlays stealing clicks only inside cards text area */
.service-card img,
.service-card .service-meta,
.service-card .service-title,
.service-card .service-desc{
  pointer-events: none !important;
}

.cdf-contact-form .btn{
  cursor: pointer;
}

.cdf-contact-form button.btn{
  border: 1px solid rgba(255,255,255,.18) !important;
  background: rgba(255,255,255,.10) !important;
}

/* keep same visuals */
.contact-notice{
  position: relative;
  z-index: 22;
}


/* v10.3.1 agenda details click fix */
.services-shell,
.services-grid,
.service-card{
  position: relative;
}

.service-card::before,
.service-card::after,
.services-shell::before,
.services-shell::after{
  pointer-events: none !important;
}

.service-card .agenda-thumb,
.service-card .service-meta,
.service-card .service-title,
.service-card .service-desc{
  pointer-events: none !important;
}

.service-card .service-actions{
  position: relative;
  z-index: 60 !important;
  pointer-events: auto !important;
}

.service-card .service-actions a,
.service-card .service-actions .btn,
.service-card .service-actions .btn span{
  pointer-events: auto !important;
}

.service-card .service-actions a{
  position: relative !important;
  z-index: 61 !important;
  display: inline-flex !important;
  cursor: pointer !important;
}

.service-card .service-actions .btn{
  position: relative !important;
  z-index: 62 !important;
}

.service-card .service-actions .btn::before,
.service-card .service-actions .btn::after{
  pointer-events: none !important;
}


/* v10.3.2 agenda + services click fix
   The links are present in HTML, so force overlays and decorative layers
   to stop stealing pointer events, and lift CTA layers above card effects.
*/
.services-shell,
.services-grid,
.service-card,
.service-actions{
  position: relative;
}

.services-shell::before,
.services-shell::after,
.service-card::before,
.service-card::after,
.service-actions::before,
.service-actions::after,
.service-actions .btn::before,
.service-actions .btn::after{
  pointer-events: none !important;
}

.service-card img,
.service-card .service-meta,
.service-card .service-title,
.service-card .service-desc,
.service-card .agenda-thumb{
  pointer-events: none !important;
}

.service-actions{
  z-index: 80 !important;
  pointer-events: auto !important;
}

.service-actions a,
.service-actions .btn,
.service-actions .btn span{
  pointer-events: auto !important;
}

.service-actions a{
  position: relative !important;
  z-index: 81 !important;
  display: inline-flex !important;
  cursor: pointer !important;
  text-decoration: none !important;
}

.service-actions .btn{
  position: relative !important;
  z-index: 82 !important;
}

.service-actions .btn span{
  position: relative !important;
  z-index: 83 !important;
}

/* keep contact untouched, but ensure CTA area wins over any shell overlay */
.services-shell{
  z-index: 10 !important;
}
