/**
 * Theme Name: hello-elementor-custom
 * Template:   hello-elementor
 */

 /* ============================================
   CRYSTAL OF NA'AMIA — CORE DESIGN SYSTEM
   Paste: Elementor → Site Settings → Custom CSS
   All values reference :root variables only
   ============================================ */

:root {
  --c-accent:    #00D4FF;
  --c-secondary: #7B5CE7;
  --c-text:      #FFFFFF;
  --c-bg:        #060B1E;
  --c-surface:   #0E1332;
  --c-border:    #1A2048;
  --c-muted:     #6B7199;

  --c-gold:      #FFAD55;

  --grad-primary: linear-gradient(135deg, #00D4FF, #7B5CE7);
  --grad-subtle:  linear-gradient(135deg, #00D4FF0A, #7B5CE708);
  --grad-edge:    linear-gradient(90deg, transparent, #00D4FF40, transparent);

  --glow-sm:        0 0 12px #00D4FF30;
  --glow-md:        0 0 20px #00D4FF40;
  --glow-lg:        0 0 35px #00D4FF50;
  --glow-violet:    0 0 20px #7B5CE740;
  --glow-violet-lg: 0 0 35px #7B5CE750;
  --shadow-lift:    0 8px 32px #00000040;

  --space-xs:  10px;
  --space-sm:  16px;
  --space-md:  24px;
  --space-lg:  40px;
  --space-xl:  60px;
  --space-sec: 110px;

  --radius-sm:   10px;
  --radius-md:   14px;
  --radius-pill: 50px;
  --radius-full: 50%;
}

/* ============================================
   GLOBAL BACKGROUND — Dark + Circuit Pattern
   Applied to the entire website body
   ============================================ */
body,
html {
  background-color: var(--c-bg) !important;
}

/* ============================================
   CIRCUIT BOARD — SVG background layer
   Injected via functions.php wp_body_open
   ============================================ */
#circuit-bg {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  pointer-events: none !important;
  z-index: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  display: block !important;
  line-height: 0 !important;
  font-size: 0 !important;
}

#circuit-bg svg {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}

/* --- Elementor content above circuit --- */
.elementor {
  position: relative;
  z-index: 1;
}

/* --- Transparent sections reveal global bg --- */
.core-bg-dark {
  background: transparent !important;
}

/* --- Opaque sections block global bg --- */
.core-bg-solid {
  background: var(--c-bg) !important;
}

.core-bg-panel {
  background: var(--c-surface) !important;
}

/* --- Transparent sections reveal global bg --- */
.core-bg-dark {
  background: transparent !important;
}

/* --- Opaque sections block global bg --- */
.core-bg-solid {
  background: #060B1E !important;
}

.core-bg-panel {
  background: #0E1332 !important;
}

/* ========================
   BACKGROUNDS
   ======================== */
   
.core-bg-dark {
  background: var(--c-bg);
  position: relative;
}

.core-bg-dark > .elementor-container,
.core-bg-dark > .e-con-inner {
  position: relative;
  z-index: 1;
}

.core-bg-solid {
  background: var(--c-bg);
}

.core-bg-panel {
  background: var(--c-surface);
}


/* ========================
   LAYOUT
   ======================== */
.core-layout-split {
  display: flex;
  flex-direction: row;
  gap: var(--space-xl);
  align-items: center;
}

.core-layout-split-reverse {
  display: flex;
  flex-direction: row-reverse;
  gap: var(--space-xl);
  align-items: center;
}

.core-header-center {
  text-align: center;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: var(--space-xl);
}


/* ========================
   TYPOGRAPHY
   ======================== */

.core-text-grad {
  background: var(--grad-primary);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.core-bg-dark p,
.core-bg-solid p,
.core-bg-panel p {
  color: var(--c-text);
}

.core-bg-dark strong,
.core-bg-solid strong,
.core-bg-panel strong {
  color: var(--c-text);
  font-weight: 500;
}

.core-bg-dark em,
.core-bg-solid em,
.core-bg-panel em {
  color: var(--c-accent);
  font-style: normal;
  font-weight: 400;
}


/* ========================
   BADGE
   ======================== */

.core-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 7px 18px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-pill);
  color: var(--c-accent);
  box-shadow: var(--glow-md);
}

.core-badge::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: var(--radius-full);
  background: var(--c-accent);
  box-shadow: 0 0 8px var(--c-accent), 0 0 18px var(--c-accent);
  animation: core-dot-pulse 2.5s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes core-dot-pulse {
  0%, 100% { transform: scale(1); box-shadow: 0 0 8px var(--c-accent), 0 0 18px var(--c-accent); }
  50% { transform: scale(1.25); box-shadow: 0 0 14px var(--c-accent), 0 0 32px var(--c-accent); }
}


/* ========================
   LABELS
   ======================== */

.core-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  color: var(--c-accent);
}

.core-label::before,
.core-label::after {
  content: '';
  width: 28px;
  height: 2px;
  background: var(--c-accent);
  border-radius: 2px;
  box-shadow: 0 0 8px var(--c-accent);
}

.core-label-left {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  color: var(--c-accent);
}

.core-label-left::before {
  content: '';
  width: 28px;
  height: 2px;
  background: var(--c-accent);
  border-radius: 2px;
  box-shadow: 0 0 8px var(--c-accent);
}


/* ========================
   SEPARATOR
   ======================== */

.core-sep,
.core-sep .elementor-divider-separator {
  background: var(--grad-primary) !important;
  border: none !important;
  height: 2px !important;
  border-radius: 2px;
  box-shadow: var(--glow-sm);
}


/* ========================
   BUTTONS
   ======================== */

.core-btn-fill .elementor-button {
  background: var(--grad-primary) !important;
  color: var(--c-text) !important;
  border: none !important;
  border-radius: var(--radius-pill) !important;
  padding: var(--space-sm) 34px !important;
  box-shadow: var(--glow-md);
  transition: all 0.35s ease;
  position: relative;
  overflow: hidden;
}

.core-btn-fill .elementor-button:hover {
  transform: translateY(-3px);
  box-shadow: var(--glow-lg);
}

.core-btn-fill .elementor-button::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, #FFFFFF14, transparent);
  transition: left 0.6s;
}

.core-btn-fill .elementor-button:hover::after {
  left: 100%;
}

.core-btn-ghost .elementor-button {
  background: transparent !important;
  color: var(--c-accent) !important;
  border: 1.5px solid var(--c-accent) !important;
  border-radius: var(--radius-pill) !important;
  padding: var(--space-sm) 34px !important;
  box-shadow: var(--glow-sm);
  transition: all 0.35s ease;
}

.core-btn-ghost .elementor-button:hover {
  background: #00D4FF10 !important;
  box-shadow: var(--glow-md);
  transform: translateY(-3px);
}


/* ========================
   CARDS
   ======================== */

.core-card {
  background: var(--c-surface);
  border: 1px solid #00D4FF30;
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
  transition: all 0.4s ease;
  box-shadow: var(--glow-md);
}

.core-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--grad-edge);
  z-index: 2;
}

.core-card:hover {
  border-color: #00D4FF60;
  box-shadow: var(--glow-lg);
  transform: translateY(-4px);
}

.core-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.core-card-alt {
  background: var(--c-surface);
  border: 1px solid #7B5CE730;
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
  transition: all 0.4s ease;
  box-shadow: var(--glow-violet);
}

.core-card-alt::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, #7B5CE740, transparent);
  z-index: 2;
}

.core-card-alt:hover {
  border-color: #7B5CE760;
  box-shadow: var(--glow-violet-lg);
  transform: translateY(-4px);
}

.core-card-alt img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* ========================
   NUMBERED STEPS
   ======================== */

.core-row-step {
  display: flex;
  gap: var(--space-md);
  align-items: flex-start;
  padding: var(--space-md) 0;
  border-bottom: 1px solid var(--c-border);
}

.core-row-step:last-child {
  border-bottom: none;
}

.core-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  min-width: 42px;
  border-radius: var(--radius-sm);
  background: var(--c-surface);
  border: 1px solid #00D4FF45;
  color: var(--c-accent);
  box-shadow: var(--glow-sm);
  text-shadow: 0 0 8px #00D4FF4D;
  flex-shrink: 0;
}


/* ========================
   CALLOUT
   ======================== */

.core-callout {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-left: 3px solid var(--c-accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: var(--space-md) var(--space-md);
}


/* ========================
   HIGHLIGHT BOX
   ======================== */

.core-highlight {
  background: var(--grad-subtle);
  border: 1px solid #00D4FF24;
  border-radius: var(--radius-md);
  padding: var(--space-md);
  position: relative;
  box-shadow: 0 0 20px #00D4FF08;
}

.core-highlight::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  background: var(--grad-edge);
}


/* ========================
   ASIDE / NOTE
   ======================== */

.core-aside {
  border-top: 1px solid var(--c-border);
  padding: var(--space-md) 0 0 22px;
  margin-top: var(--space-md);
  position: relative;
}

.core-aside::before {
  content: '';
  position: absolute;
  left: 0;
  top: var(--space-md);
  width: 3px;
  height: calc(100% - var(--space-md));
  border-radius: 3px;
  background: var(--grad-primary);
  box-shadow: var(--glow-sm);
}

.core-aside p {
  color: var(--c-muted) !important;
}

.core-aside strong {
  color: var(--c-text) !important;
}

.core-aside em {
  color: var(--c-accent) !important;
}


/* ========================
   VERIFIED / CHECK BOX
   ======================== */

.core-box-check {
  display: flex;
  gap: 22px;
  align-items: flex-start;
  background: var(--grad-subtle);
  border: 1px solid #00D4FF24;
  border-radius: var(--radius-md);
  padding: var(--space-md);
  position: relative;
  overflow: hidden;
}

.core-box-check::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--grad-edge);
}


/* ========================
   RESPONSIVE
   ======================== */

@media (max-width: 1100px) {
  .core-layout-split,
  .core-layout-split-reverse {
    flex-direction: column !important;
    gap: var(--space-lg) !important;
  }
}

@media (max-width: 768px) {
  .core-badge {
    font-size: 11px;
    letter-spacing: 2px;
    padding: 6px var(--space-sm);
  }

  .core-num {
    width: 36px;
    height: 36px;
    min-width: 36px;
  }

  .core-row-step {
    gap: var(--space-sm);
  }
}