/*
Theme Name: Flux
Theme URI: https://example.com/flux
Author: Your Studio
Author URI: https://example.com
Description: A neon + liquid-glass Elementor theme for web dev, automation & SEO/SMM studios. Install Elementor, import the bundled template from elementor-templates/flux-page.json, and build freely — no PHP content to edit.
Version: 1.0.0
Requires at least: 6.3
Requires PHP: 7.4
Tested up to: 6.8
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: flux
Tags: one-column, custom-menu, custom-logo, full-site-editing, translation-ready, blog, portfolio, e-commerce
*/

/*
 * This file is loaded on every front-end request.
 * It defines design tokens and base resets that Elementor widgets
 * can reference via CSS variables. Elementor handles all layout
 * and section-level styling through its own engine and the imported template.
 */

/* ===================================================================
   1. DESIGN TOKENS — available as CSS variables everywhere (incl. Elementor Custom CSS fields)
   =================================================================== */
:root {
  --flux-bg-0:   #05060c;
  --flux-bg-1:   #090c18;
  --flux-bg-2:   #0e1226;
  --flux-cyan:   #2ee6d6;
  --flux-violet: #a35cff;
  --flux-pink:   #ff3dae;

  --flux-glass-fill:       rgba(255,255,255,0.055);
  --flux-glass-fill-hover: rgba(255,255,255,0.095);
  --flux-border:           rgba(255,255,255,0.14);
  --flux-border-bright:    rgba(255,255,255,0.40);

  --flux-text-0: #f5f7ff;
  --flux-text-1: #b2b8d4;
  --flux-text-2: #6e7491;

  --flux-radius-lg: 28px;
  --flux-radius-md: 18px;
  --flux-radius-sm: 12px;
  --flux-ease: cubic-bezier(.22,1,.36,1);

  --flux-font-display: 'Space Grotesk', sans-serif;
  --flux-font-body:    'Inter', sans-serif;
  --flux-font-mono:    'JetBrains Mono', monospace;
}

/* ===================================================================
   2. BASE RESET & BODY
   =================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, rgba(163,92,255,0.12), transparent),
    var(--flux-bg-0);
  color: var(--flux-text-1);
  font-family: var(--flux-font-body);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
/* Remove WP default body padding added by the admin bar */
body.admin-bar { padding-top: 32px; }
@media screen and (max-width:782px) { body.admin-bar { padding-top: 46px; } }

a { color: inherit; text-decoration: none; }
ul { list-style: none; }
img, svg { display: block; max-width: 100%; }
button, input { font-family: inherit; }
:focus-visible { outline: 2px solid var(--flux-cyan); outline-offset: 3px; border-radius: 4px; }

/* ===================================================================
   3. AMBIENT ATMOSPHERE — animated neon blobs (rendered by header.php)
   =================================================================== */
.flux-atmosphere {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.flux-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(110px);
  opacity: .35;
  mix-blend-mode: screen;
}
.flux-blob--cyan   { width:560px; height:560px; background:var(--flux-cyan);   top:-12%; left:-8%;  animation:fluxDriftA 28s ease-in-out infinite alternate; }
.flux-blob--violet { width:620px; height:620px; background:var(--flux-violet); top:22%;  right:-14%;animation:fluxDriftB 34s ease-in-out infinite alternate; }
.flux-blob--pink   { width:480px; height:480px; background:var(--flux-pink);   bottom:-12%;left:24%;animation:fluxDriftC 30s ease-in-out infinite alternate; }
@keyframes fluxDriftA { from{transform:translate(0,0) scale(1);}    to{transform:translate(60px,80px)  scale(1.18);} }
@keyframes fluxDriftB { from{transform:translate(0,0) scale(1);}    to{transform:translate(-70px,40px) scale(1.1);}  }
@keyframes fluxDriftC { from{transform:translate(0,0) scale(1);}    to{transform:translate(40px,-60px) scale(1.2);}  }
@media (prefers-reduced-motion: reduce) {
  .flux-blob { animation: none; }
}

/* ===================================================================
   4. GLASS CARD PRIMITIVE
   Elementor HTML widgets can add class="flux-glass" to get the effect.
   =================================================================== */
.flux-glass {
  position: relative;
  background: linear-gradient(160deg, rgba(255,255,255,0.085), rgba(255,255,255,0.018) 60%);
  border: 1px solid var(--flux-border);
  border-radius: var(--flux-radius-lg);
  backdrop-filter: blur(22px) saturate(160%);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
  box-shadow: 0 24px 60px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.12);
  overflow: hidden;
}
.flux-glass::before {
  content: '';
  position: absolute;
  top: 0; left: 6%; right: 6%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.65), transparent);
}
.flux-glass::after {
  content: '';
  position: absolute;
  top: -45%; left: -15%; width: 55%; height: 60%;
  background: radial-gradient(circle, rgba(255,255,255,.16), transparent 70%);
  transform: rotate(-12deg);
  pointer-events: none;
}

/* ===================================================================
   5. SHARED COMPONENT CLASSES (used by Elementor HTML widgets)
   =================================================================== */

/* Gradient text */
.flux-grad-text {
  background: linear-gradient(120deg, var(--flux-cyan), var(--flux-violet) 50%, var(--flux-pink));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* Eyebrow label */
.flux-eyebrow {
  font-family: var(--flux-font-mono);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .78rem;
  color: var(--flux-cyan);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
}
.flux-eyebrow::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 10px currentColor;
  flex-shrink: 0;
}

/* Buttons */
.flux-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 15px 30px;
  border-radius: 999px;
  font-weight: 600;
  font-size: .95rem;
  cursor: pointer;
  border: none;
  transition: transform .35s var(--flux-ease), box-shadow .35s var(--flux-ease), border-color .35s var(--flux-ease);
}
.flux-btn--primary {
  background: linear-gradient(120deg, var(--flux-cyan), var(--flux-violet) 55%, var(--flux-pink));
  color: #0a0a12;
  box-shadow: 0 0 0 1px rgba(255,255,255,.25) inset, 0 8px 28px rgba(163,92,255,.35);
}
.flux-btn--primary:hover { transform: translateY(-3px); box-shadow: 0 0 0 1px rgba(255,255,255,.3) inset, 0 14px 40px rgba(163,92,255,.5); }
.flux-btn--ghost {
  background: var(--flux-glass-fill);
  border: 1px solid var(--flux-border);
  color: var(--flux-text-0);
  backdrop-filter: blur(14px);
}
.flux-btn--ghost:hover { border-color: var(--flux-border-bright); background: var(--flux-glass-fill-hover); transform: translateY(-3px); }

/* Headings (Elementor typography overrides these per widget, these are fallbacks) */
h1,h2,h3,h4 { font-family: var(--flux-font-display); color: var(--flux-text-0); font-weight: 600; letter-spacing: -.02em; }
p { color: var(--flux-text-1); }

/* ===================================================================
   6. HERO DASHBOARD PANEL (HTML widget)
   =================================================================== */
.flux-browser-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 20px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--flux-border);
}
.flux-dot { width:9px; height:9px; border-radius:50%; }
.flux-dot--c { background:var(--flux-cyan);   box-shadow:0 0 8px var(--flux-cyan);   }
.flux-dot--v { background:var(--flux-violet); box-shadow:0 0 8px var(--flux-violet); }
.flux-dot--p { background:var(--flux-pink);   box-shadow:0 0 8px var(--flux-pink);   }
.flux-url-pill {
  margin-left:auto;
  background:var(--flux-glass-fill);
  border:1px solid var(--flux-border);
  border-radius:999px;
  padding:6px 18px;
  font-family:var(--flux-font-mono);
  font-size:.78rem;
  color:var(--flux-text-2);
}
.flux-panel-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.flux-panel-card {
  background:var(--flux-glass-fill);
  border:1px solid var(--flux-border);
  border-radius:var(--flux-radius-md);
  padding:22px;
}
.flux-panel-label { font-family:var(--flux-font-mono); text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; color:var(--flux-text-2); margin-bottom:10px; }
.flux-panel-value { font-family:var(--flux-font-display); font-size:2.1rem; color:var(--flux-text-0); font-weight:600; }
.flux-panel-value small { font-family:var(--flux-font-body); font-size:.85rem; font-weight:500; color:var(--flux-text-2); margin-left:6px; }
.flux-bars { display:flex; align-items:flex-end; gap:4px; height:36px; margin-top:14px; }
.flux-bars span { flex:1; border-radius:2px; opacity:.85; }
.flux-panel-card--cyan   .flux-bars span { background:var(--flux-cyan);   }
.flux-panel-card--violet .flux-bars span { background:var(--flux-violet); }
.flux-panel-card--pink   .flux-bars span { background:var(--flux-pink);   }
.flux-panel-card--cyan   .flux-panel-value { text-shadow:0 0 18px rgba(46,230,214,.45);  }
.flux-panel-card--violet .flux-panel-value { text-shadow:0 0 18px rgba(163,92,255,.45); }
.flux-panel-card--pink   .flux-panel-value { text-shadow:0 0 18px rgba(255,61,174,.45); }
@media(max-width:680px){ .flux-panel-grid{ grid-template-columns:1fr; } }

/* ===================================================================
   7. SERVICE CARDS (HTML widgets)
   =================================================================== */
.flux-service-card { padding:38px 34px; transition:transform .4s var(--flux-ease), box-shadow .4s var(--flux-ease), border-color .4s var(--flux-ease); }
.flux-service-card:hover { transform:translateY(-8px); border-color:rgba(255,255,255,.3); }
.flux-service-card--cyan:hover   { box-shadow:0 24px 60px rgba(46,230,214,.22), inset 0 1px 0 rgba(255,255,255,.12); }
.flux-service-card--violet:hover { box-shadow:0 24px 60px rgba(163,92,255,.22), inset 0 1px 0 rgba(255,255,255,.12); }
.flux-service-card--pink:hover   { box-shadow:0 24px 60px rgba(255,61,174,.22), inset 0 1px 0 rgba(255,255,255,.12); }
.flux-service-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:26px; }
.flux-service-icon--cyan   { background:rgba(46,230,214,.16);  color:var(--flux-cyan);   }
.flux-service-icon--violet { background:rgba(163,92,255,.16); color:var(--flux-violet); }
.flux-service-icon--pink   { background:rgba(255,61,174,.16); color:var(--flux-pink);   }
.flux-service-icon svg { width:24px; height:24px; }
.flux-service-list { margin-top:24px; }
.flux-service-list li { font-size:.88rem; color:var(--flux-text-1); padding-left:18px; position:relative; margin-bottom:10px; }
.flux-service-list li::before { content:''; position:absolute; left:0; top:.55em; width:7px; height:2px; }
.flux-service-card--cyan   .flux-service-list li::before { background:var(--flux-cyan);   }
.flux-service-card--violet .flux-service-list li::before { background:var(--flux-violet); }
.flux-service-card--pink   .flux-service-list li::before { background:var(--flux-pink);   }

/* ===================================================================
   8. FLOW DIAGRAM / SYSTEM SECTION
   =================================================================== */
.flux-flow-panel { padding:56px 36px 44px; }
.flux-flow-svg   { width:100%; height:auto; }
.flux-flow-nodes { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:36px; }
.flux-flow-node { text-align:center; }
.flux-flow-node__tag { font-family:var(--flux-font-mono); text-transform:uppercase; font-size:.72rem; letter-spacing:.1em; margin-bottom:8px; }
.flux-flow-node__desc { font-size:.86rem; color:var(--flux-text-1); }
.flux-flow-node--cyan   .flux-flow-node__tag { color:var(--flux-cyan);   }
.flux-flow-node--violet .flux-flow-node__tag { color:var(--flux-violet); }
.flux-flow-node--pink   .flux-flow-node__tag { color:var(--flux-pink);   }
@media(max-width:680px){ .flux-flow-nodes{ grid-template-columns:repeat(2,1fr); } }

/* ===================================================================
   9. PROCESS TIMELINE
   =================================================================== */
.flux-timeline { display:grid; grid-template-columns:repeat(5,1fr); gap:18px; position:relative; }
.flux-timeline::before { content:''; position:absolute; top:38px; left:4%; right:4%; height:1px; background:linear-gradient(90deg,var(--flux-cyan),var(--flux-violet),var(--flux-pink)); opacity:.4; }
.flux-stage { padding:26px 20px; }
.flux-stage__index { font-family:var(--flux-font-mono); font-size:.8rem; color:var(--flux-text-2); margin-bottom:30px; display:block; }
.flux-stage h3 { font-size:1.05rem; margin-bottom:10px; }
.flux-stage p  { font-size:.85rem; line-height:1.6; color:var(--flux-text-1); }
@media(max-width:960px){ .flux-timeline{ grid-template-columns:repeat(2,1fr); } .flux-timeline::before{ display:none; } }
@media(max-width:600px){ .flux-timeline{ grid-template-columns:1fr; } }

/* ===================================================================
   10. STATS GRID
   =================================================================== */
.flux-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.flux-stat { padding:32px 28px; }
.flux-stat__value { font-family:var(--flux-font-mono); font-size:2.4rem; color:var(--flux-text-0); font-weight:500; }
.flux-stat:nth-child(1) .flux-stat__value { text-shadow:0 0 20px rgba(46,230,214,.5);  }
.flux-stat:nth-child(2) .flux-stat__value { text-shadow:0 0 20px rgba(163,92,255,.5); }
.flux-stat:nth-child(3) .flux-stat__value { text-shadow:0 0 20px rgba(255,61,174,.5); }
.flux-stat:nth-child(4) .flux-stat__value { text-shadow:0 0 20px rgba(46,230,214,.5);  }
.flux-stat__label { font-family:var(--flux-font-mono); text-transform:uppercase; font-size:.74rem; letter-spacing:.08em; color:var(--flux-text-2); margin-top:10px; }
@media(max-width:900px){ .flux-stats-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:540px){ .flux-stats-grid{ grid-template-columns:1fr; } }

/* ===================================================================
   11. CTA SECTION
   =================================================================== */
.flux-cta-glow { position:absolute; inset:-40px; background:linear-gradient(120deg,var(--flux-cyan),var(--flux-violet),var(--flux-pink)); filter:blur(70px); opacity:.22; border-radius:40px; z-index:-1; }
.flux-cta-form { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:28px; }
.flux-cta-form input {
  background:var(--flux-glass-fill);
  border:1px solid var(--flux-border);
  border-radius:999px;
  padding:15px 24px;
  color:var(--flux-text-0);
  font-size:.95rem;
  min-width:260px;
}
.flux-cta-form input::placeholder { color:var(--flux-text-2); }
.flux-cta-note { font-family:var(--flux-font-mono); font-size:.78rem; color:var(--flux-text-2); margin-top:16px; text-align:center; }

/* ===================================================================
   12. NAV (theme fallback header — overridden by Elementor Pro Theme Builder)
   =================================================================== */
.flux-nav { position:fixed; top:0; left:0; right:0; z-index:200; padding:20px 0; transition:background .4s, padding .4s, border-color .4s; border-bottom:1px solid transparent; }
.flux-nav.is-scrolled { background:rgba(7,9,18,.72); backdrop-filter:blur(18px) saturate(160%); -webkit-backdrop-filter:blur(18px) saturate(160%); padding:14px 0; border-color:var(--flux-border); }
.flux-nav__inner { max-width:1240px; margin:0 auto; padding:0 32px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.flux-logo { font-family:var(--flux-font-display); font-weight:700; font-size:1.35rem; color:var(--flux-text-0); letter-spacing:-.02em; }
.flux-logo-dot { color:var(--flux-cyan); text-shadow:0 0 14px var(--flux-cyan); }
.flux-nav__links { display:flex; gap:34px; }
.flux-nav__links a { font-size:.93rem; color:var(--flux-text-1); position:relative; padding-bottom:4px; transition:color .3s; }
.flux-nav__links a::after { content:''; position:absolute; left:0; bottom:0; height:2px; width:0; background:linear-gradient(90deg,var(--flux-cyan),var(--flux-violet)); transition:width .35s var(--flux-ease); }
.flux-nav__links a:hover, .flux-nav__links a.is-active { color:var(--flux-text-0); }
.flux-nav__links a:hover::after, .flux-nav__links a.is-active::after { width:100%; }
.flux-nav__toggle { display:none; width:40px; height:40px; border-radius:10px; background:var(--flux-glass-fill); border:1px solid var(--flux-border); align-items:center; justify-content:center; flex-direction:column; gap:5px; cursor:pointer; }
.flux-nav__toggle span { display:block; width:18px; height:2px; background:var(--flux-text-0); border-radius:2px; }
@media(max-width:880px){
  .flux-nav__links { position:fixed; top:70px; left:16px; right:16px; flex-direction:column; gap:0; background:rgba(10,12,24,.92); border:1px solid var(--flux-border); border-radius:var(--flux-radius-md); backdrop-filter:blur(20px); padding:8px; transform:translateY(-12px); opacity:0; pointer-events:none; transition:transform .35s var(--flux-ease),opacity .35s var(--flux-ease); }
  .flux-nav__links.is-open { transform:translateY(0); opacity:1; pointer-events:auto; }
  .flux-nav__links a { padding:14px 16px; border-radius:10px; }
  .flux-nav__links a:hover { background:rgba(255,255,255,.05); }
  .flux-nav__links a::after { display:none; }
  .flux-nav__toggle { display:flex; }
}

/* ===================================================================
   13. FOOTER (theme fallback — overridden by Elementor Pro Theme Builder)
   =================================================================== */
.flux-footer { padding:64px 0 36px; border-top:1px solid var(--flux-border); position:relative; z-index:1; }
.flux-footer__inner { max-width:1240px; margin:0 auto; padding:0 32px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:36px; margin-bottom:44px; }
.flux-footer__brand p { font-size:.9rem; color:var(--flux-text-2); margin-top:10px; max-width:260px; }
.flux-footer__links { display:flex; gap:48px; flex-wrap:wrap; }
.flux-footer__col h4 { font-family:var(--flux-font-mono); text-transform:uppercase; font-size:.72rem; letter-spacing:.1em; color:var(--flux-text-2); margin-bottom:16px; }
.flux-footer__col a { display:block; font-size:.9rem; color:var(--flux-text-1); margin-bottom:10px; transition:color .3s; }
.flux-footer__col a:hover { color:var(--flux-text-0); }
.flux-social-row { display:flex; gap:12px; }
.flux-social-btn { width:38px; height:38px; border-radius:50%; background:var(--flux-glass-fill); border:1px solid var(--flux-border); display:flex; align-items:center; justify-content:center; font-family:var(--flux-font-mono); font-size:.72rem; color:var(--flux-text-1); transition:border-color .3s, color .3s; }
.flux-social-btn:hover { border-color:var(--flux-cyan); color:var(--flux-text-0); }
.flux-footer__bottom { max-width:1240px; margin:0 auto; padding:24px 32px 0; border-top:1px solid var(--flux-border); display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-family:var(--flux-font-mono); font-size:.78rem; color:var(--flux-text-2); }

/* ===================================================================
   14. SCROLL REVEAL UTILITY
   =================================================================== */
[data-flux-reveal] { opacity:0; transform:translateY(26px); transition:opacity .8s var(--flux-ease), transform .8s var(--flux-ease); }
[data-flux-reveal].is-visible { opacity:1; transform:translateY(0); }
@media(prefers-reduced-motion:reduce){ [data-flux-reveal]{ transition:none; opacity:1; transform:none; } }

/* ===================================================================
   15. ELEMENTOR OVERRIDES
   Make Elementor sections / containers transparent so the dark body
   gradient shows through (prevents the white/grey default backgrounds).
   =================================================================== */
.elementor-section,
.elementor-container,
.e-container {
  position: relative;
  z-index: 1;
}
/* Prevent Elementor from clipping the atmosphere blobs */
body > .elementor { position: relative; z-index: 1; }

/* ===================================================================
   16. CUSTOM LOGO (if set via Appearance › Customize)
   =================================================================== */
.site-logo-wrap { display:flex; align-items:center; }
.site-logo-wrap img { max-height:40px; width:auto; }

/* ===================================================================
   17. WP CORE — pagination, comments, accessibility
   =================================================================== */
.nav-links { font-family:var(--flux-font-mono); font-size:.85rem; }
.screen-reader-text { position:absolute; left:-9999em; }
