/*
Theme Name: mightyLab Co
Theme URI: https://mightylabco.com
Author: mightyLab co
Author URI: https://mightylabco.com
Description: A sleek, dark-themed WordPress theme for mightyLab Co — your outsourced partner that actually gets your business. Fully compatible with Elementor page builder.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mightylab
Tags: dark, elementor, one-page, business, services, responsive, full-width-template

*/

/* ============================================================
   CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
  --ml-bg:           #020617;   /* slate-950 */
  --ml-bg-900:       #0f172a;   /* slate-900 */
  --ml-bg-800:       #1e293b;   /* slate-800 */
  --ml-bg-700:       #334155;   /* slate-700 */
  --ml-text:         #f8fafc;   /* slate-50  */
  --ml-text-300:     #cbd5e1;   /* slate-300 */
  --ml-text-400:     #94a3b8;   /* slate-400 */
  --ml-text-500:     #64748b;   /* slate-500 */
  --ml-orange:       #f97316;   /* orange-500 */
  --ml-orange-400:   #fb923c;   /* orange-400 */
  --ml-pink:         #ec4899;   /* pink-500 */
  --ml-purple:       #a855f7;   /* purple-500 */
  --ml-blue:         #3b82f6;   /* blue-500 */
  --ml-cyan:         #06b6d4;   /* cyan-500 */
  --ml-emerald:      #10b981;   /* emerald-500 */
  --ml-gradient-main: linear-gradient(135deg, var(--ml-orange), var(--ml-pink));
  --ml-gradient-hero: linear-gradient(135deg, var(--ml-orange), var(--ml-pink), var(--ml-purple));
  --ml-gradient-blue: linear-gradient(135deg, var(--ml-blue), var(--ml-cyan));
  --ml-border:       rgba(255,255,255,0.08);
  --ml-radius-card:  1.5rem;
  --ml-radius-pill:  9999px;
  --ml-transition:   0.3s ease;
  --ml-font-display: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background-color: var(--ml-bg);
  color: var(--ml-text);
  font-family: var(--ml-font-display);
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; transition: color var(--ml-transition); }
a:hover { color: var(--ml-orange-400); }

img { max-width: 100%; height: auto; display: block; }

ul, ol { list-style: none; }

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--ml-text);
}

h1 { font-size: clamp(2.5rem, 8vw, 6rem); }
h2 { font-size: clamp(2rem, 5vw, 3.5rem); }
h3 { font-size: 1.25rem; }

p { color: var(--ml-text-400); }

.ml-gradient-text {
  background: var(--ml-gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.ml-gradient-text-blue {
  background: var(--ml-gradient-blue);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.ml-gradient-text-orange {
  background: linear-gradient(135deg, var(--ml-orange-400), var(--ml-pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ============================================================
   LAYOUT
   ============================================================ */
.ml-container {
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: 1.5rem;
}

.ml-section {
  padding-block: 5rem;
  padding-inline: 1.5rem;
  position: relative;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.ml-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  border-radius: var(--ml-radius-pill);
  font-size: 1.05rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--ml-transition);
  border: none;
  text-decoration: none;
}

.ml-btn-primary {
  background: var(--ml-gradient-main);
  color: #fff;
  box-shadow: 0 10px 30px rgba(249,115,22,0.25);
}
.ml-btn-primary:hover {
  background: linear-gradient(135deg, #ea6c0e, #db2777);
  box-shadow: 0 14px 40px rgba(249,115,22,0.35);
  color: #fff;
  transform: translateY(-2px);
}

.ml-btn-outline {
  background: transparent;
  color: var(--ml-text-300);
  border: 1px solid var(--ml-bg-700);
}
.ml-btn-outline:hover {
  background: rgba(255,255,255,0.05);
  color: var(--ml-text);
}

/* ============================================================
   HEADER / NAV
   ============================================================ */
#masthead,
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  padding: 1rem 1.5rem;
  transition: background var(--ml-transition), backdrop-filter var(--ml-transition);
}
#masthead.scrolled,
.site-header.scrolled {
  background: rgba(2,6,23,0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--ml-border);
}

.site-header-inner {
  max-width: 1280px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.site-logo a {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.03em;
}
.site-logo .logo-mighty { color: var(--ml-text); }
.site-logo .logo-lab { background: var(--ml-gradient-main); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.site-logo .logo-co { color: var(--ml-text-300); }

.main-navigation ul {
  display: flex;
  align-items: center;
  gap: 2rem;
}
.main-navigation ul li a {
  color: var(--ml-text-400);
  font-size: 0.9rem;
  font-weight: 500;
  transition: color var(--ml-transition);
}
.main-navigation ul li a:hover { color: var(--ml-text); }

.nav-cta { margin-left: 1rem; }

/* Mobile Nav */
.menu-toggle {
  display: none;
  background: none;
  border: none;
  color: var(--ml-text);
  cursor: pointer;
  padding: 0.5rem;
}
.menu-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: currentColor;
  margin: 5px 0;
  transition: all var(--ml-transition);
}

@media (max-width: 768px) {
  .menu-toggle { display: block; }
  .main-navigation {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(2,6,23,0.97);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--ml-border);
    padding: 1.5rem;
  }
  .main-navigation.open { display: block; }
  .main-navigation ul { flex-direction: column; align-items: flex-start; gap: 1rem; }
  .nav-cta { margin-left: 0; margin-top: 1rem; }
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero-section {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 6rem 1.5rem 4rem;
  position: relative;
  overflow: hidden;
}

.hero-bg-orb-1 {
  position: absolute;
  top: -25%;
  right: -25%;
  width: 800px;
  height: 800px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,115,22,0.18) 0%, rgba(236,72,153,0.08) 50%, transparent 70%);
  filter: blur(60px);
  animation: orbFloat1 20s ease-in-out infinite;
}
.hero-bg-orb-2 {
  position: absolute;
  bottom: -25%;
  left: -25%;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(59,130,246,0.18) 0%, rgba(6,182,212,0.08) 50%, transparent 70%);
  filter: blur(60px);
  animation: orbFloat2 18s ease-in-out infinite;
}

.hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

@keyframes orbFloat1 {
  0%, 100% { transform: scale(1) rotate(0deg); }
  33% { transform: scale(1.1) rotate(60deg); }
  66% { transform: scale(0.95) rotate(120deg); }
}
@keyframes orbFloat2 {
  0%, 100% { transform: rotate(0deg); }
  50% { transform: rotate(-20deg) scale(1.05); }
}

.hero-inner {
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin-inline: auto;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  border-radius: var(--ml-radius-pill);
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  backdrop-filter: blur(8px);
  font-size: 0.875rem;
  color: var(--ml-text-300);
  margin-bottom: 2rem;
  animation: fadeInDown 0.6s ease both;
}
.hero-badge svg { color: var(--ml-orange-400); }

.hero-title {
  font-size: clamp(3rem, 9vw, 7rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  margin-bottom: 1.5rem;
  animation: fadeInUp 0.7s ease 0.1s both;
}
.hero-title .word-mighty { color: var(--ml-text); }
.hero-title .word-lab {
  background: var(--ml-gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.hero-title .word-co { color: var(--ml-text-300); }

.hero-tagline {
  font-size: clamp(1.1rem, 2.5vw, 1.5rem);
  color: var(--ml-text-400);
  max-width: 700px;
  margin-inline: auto;
  margin-bottom: 1rem;
  animation: fadeInUp 0.7s ease 0.2s both;
}
.hero-tagline strong { color: var(--ml-text); font-weight: 600; }

.hero-sub {
  font-size: 1.1rem;
  color: var(--ml-text-500);
  max-width: 550px;
  margin-inline: auto;
  margin-bottom: 3rem;
  animation: fadeInUp 0.7s ease 0.3s both;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  animation: fadeInUp 0.7s ease 0.4s both;
}

/* Floating shapes */
.hero-shape-1 {
  position: absolute;
  top: 20%;
  left: 5%;
  width: 80px;
  height: 80px;
  border: 1.5px solid rgba(249,115,22,0.3);
  border-radius: 1rem;
  animation: shapeRotate 12s linear infinite;
}
.hero-shape-2 {
  position: absolute;
  bottom: 30%;
  right: 8%;
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, rgba(59,130,246,0.15), rgba(168,85,247,0.15));
  border-radius: 50%;
  animation: shapeFloat 8s ease-in-out infinite;
}
.hero-shape-3 {
  position: absolute;
  top: 35%;
  right: 6%;
  width: 32px;
  height: 32px;
  border: 2px solid rgba(236,72,153,0.4);
  animation: shapeRotate 8s linear infinite reverse;
}

@keyframes shapeRotate { to { transform: rotate(360deg); } }
@keyframes shapeFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}
@keyframes fadeInDown {
  from { opacity: 0; transform: translateY(-20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.ml-section-label {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ml-orange-400);
  margin-bottom: 1rem;
}

.ml-section-title {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 800;
  margin-bottom: 1.25rem;
}

.ml-section-desc {
  font-size: 1.1rem;
  color: var(--ml-text-400);
  max-width: 600px;
  margin-inline: auto;
}

.ml-text-center { text-align: center; }

/* ============================================================
   SERVICES SECTION
   ============================================================ */
.services-section {
  background: linear-gradient(180deg, var(--ml-bg) 0%, rgba(15,23,42,0.5) 50%, var(--ml-bg) 100%);
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1.5rem;
  margin-top: 4rem;
}

.service-card {
  position: relative;
  height: 100%;
  padding: 2rem;
  border-radius: var(--ml-radius-card);
  background: rgba(15,23,42,0.5);
  border: 1px solid var(--ml-bg-800);
  overflow: hidden;
  transition: border-color var(--ml-transition), transform var(--ml-transition);
}
.service-card:hover {
  border-color: var(--ml-bg-700);
  transform: translateY(-4px);
}

.service-card-bg-glow {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity var(--ml-transition);
}
.service-card:hover .service-card-bg-glow { opacity: 0.05; }

.service-card-glow-corner {
  position: absolute;
  bottom: -2.5rem;
  right: -2.5rem;
  width: 8rem;
  height: 8rem;
  border-radius: 50%;
  opacity: 0;
  filter: blur(2rem);
  transition: opacity var(--ml-transition);
}
.service-card:hover .service-card-glow-corner { opacity: 0.1; }

.service-icon {
  display: inline-flex;
  padding: 0.75rem;
  border-radius: 0.875rem;
  margin-bottom: 1.5rem;
}
.service-icon svg { width: 24px; height: 24px; color: #fff; }

.service-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--ml-text);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.service-title-arrow {
  margin-left: auto;
  color: var(--ml-text-500);
  transition: all var(--ml-transition);
  flex-shrink: 0;
}
.service-card:hover .service-title-arrow {
  color: var(--ml-text);
  transform: translate(3px, -3px);
}

.service-desc { font-size: 0.95rem; line-height: 1.7; }

/* Service colour variants */
.sc-orange .service-icon { background: linear-gradient(135deg, var(--ml-orange), var(--ml-pink)); }
.sc-orange .service-card-bg-glow { background: linear-gradient(135deg, var(--ml-orange), var(--ml-pink)); }
.sc-orange .service-card-glow-corner { background: linear-gradient(135deg, var(--ml-orange), var(--ml-pink)); }

.sc-blue .service-icon { background: var(--ml-gradient-blue); }
.sc-blue .service-card-bg-glow { background: var(--ml-gradient-blue); }
.sc-blue .service-card-glow-corner { background: var(--ml-gradient-blue); }

.sc-purple .service-icon { background: linear-gradient(135deg, var(--ml-purple), var(--ml-pink)); }
.sc-purple .service-card-bg-glow { background: linear-gradient(135deg, var(--ml-purple), var(--ml-pink)); }
.sc-purple .service-card-glow-corner { background: linear-gradient(135deg, var(--ml-purple), var(--ml-pink)); }

.sc-emerald .service-icon { background: linear-gradient(135deg, var(--ml-emerald), #14b8a6); }
.sc-emerald .service-card-bg-glow { background: linear-gradient(135deg, var(--ml-emerald), #14b8a6); }
.sc-emerald .service-card-glow-corner { background: linear-gradient(135deg, var(--ml-emerald), #14b8a6); }

.sc-amber .service-icon { background: linear-gradient(135deg, #f59e0b, var(--ml-orange)); }
.sc-amber .service-card-bg-glow { background: linear-gradient(135deg, #f59e0b, var(--ml-orange)); }
.sc-amber .service-card-glow-corner { background: linear-gradient(135deg, #f59e0b, var(--ml-orange)); }

.sc-rose .service-icon { background: linear-gradient(135deg, #f43f5e, #ef4444); }
.sc-rose .service-card-bg-glow { background: linear-gradient(135deg, #f43f5e, #ef4444); }
.sc-rose .service-card-glow-corner { background: linear-gradient(135deg, #f43f5e, #ef4444); }

/* ============================================================
   WHY US / ABOUT SECTION
   ============================================================ */
.about-section {
  overflow: hidden;
}
.about-section .about-orb {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 800px;
  height: 800px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(249,115,22,0.04) 0%, rgba(236,72,153,0.04) 50%, transparent 70%);
  filter: blur(80px);
  pointer-events: none;
}

.about-grid {
  display: grid;
  gap: 4rem;
  align-items: center;
}
@media (min-width: 1024px) { .about-grid { grid-template-columns: 1fr 1fr; } }

.about-headline {
  font-size: clamp(2.2rem, 5vw, 4rem);
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 2rem;
}

.about-lead { font-size: 1.1rem; line-height: 1.8; margin-bottom: 2.5rem; }

.stats-row {
  display: flex;
  gap: 2.5rem;
  flex-wrap: wrap;
}

.stat-item { text-align: center; }
.stat-number {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  font-weight: 800;
  line-height: 1;
  margin-bottom: 0.25rem;
}
.stat-label { font-size: 0.85rem; color: var(--ml-text-500); }
.stat-sub { font-size: 0.75rem; color: var(--ml-bg-700); }

.feature-list { display: flex; flex-direction: column; gap: 1rem; }

.feature-item {
  display: flex;
  gap: 1.25rem;
  padding: 1.25rem 1.5rem;
  border-radius: 1rem;
  background: rgba(15,23,42,0.3);
  border: 1px solid var(--ml-bg-800);
  transition: all var(--ml-transition);
}
.feature-item:hover {
  border-color: var(--ml-bg-700);
  background: rgba(15,23,42,0.5);
}

.feature-icon-wrap {
  flex-shrink: 0;
  padding: 0.75rem;
  border-radius: 0.75rem;
  background: linear-gradient(135deg, var(--ml-bg-800), var(--ml-bg-900, #060f21));
  transition: background var(--ml-transition);
}
.feature-item:hover .feature-icon-wrap {
  background: linear-gradient(135deg, rgba(249,115,22,0.15), rgba(236,72,153,0.15));
}
.feature-icon-wrap svg { width: 20px; height: 20px; color: var(--ml-orange-400); }

.feature-name { font-size: 1rem; font-weight: 700; color: var(--ml-text); margin-bottom: 0.25rem; }
.feature-desc { font-size: 0.875rem; line-height: 1.6; }

/* ============================================================
   TESTIMONIALS SECTION
   ============================================================ */
.testimonials-section {
  background: linear-gradient(180deg, var(--ml-bg) 0%, rgba(15,23,42,0.3) 50%, var(--ml-bg) 100%);
}

.testimonials-grid {
  display: grid;
  gap: 1.5rem;
  margin-top: 4rem;
}
@media (min-width: 768px) { .testimonials-grid { grid-template-columns: repeat(3, 1fr); } }

.testimonial-card {
  position: relative;
  padding: 2rem;
  border-radius: var(--ml-radius-card);
  background: rgba(15,23,42,0.5);
  border: 1px solid var(--ml-bg-800);
  transition: border-color var(--ml-transition);
}
.testimonial-card:hover { border-color: var(--ml-bg-700); }

.testimonial-quote-icon {
  position: absolute;
  top: -1rem;
  left: 2rem;
  padding: 0.5rem;
  border-radius: 50%;
  background: var(--ml-gradient-main);
}
.testimonial-quote-icon svg { width: 16px; height: 16px; color: #fff; }

.testimonial-text {
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--ml-text-300);
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

.testimonial-author { display: flex; align-items: center; gap: 0.75rem; }
.testimonial-avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(249,115,22,0.2), rgba(236,72,153,0.2));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--ml-orange-400);
  flex-shrink: 0;
}
.testimonial-name { font-weight: 600; color: var(--ml-text); font-size: 0.95rem; }

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section { padding-block: 3rem; }

.cta-card {
  position: relative;
  border-radius: 2.5rem;
  overflow: hidden;
  padding: 3rem 2rem;
  text-align: center;
}
.cta-card::before {
  content: '';
  position: absolute;
  inset: 0;
  padding: 1px;
  border-radius: 2.5rem;
  background: var(--ml-gradient-hero);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}
.cta-card-bg {
  position: absolute;
  inset: 0;
  background: var(--ml-bg);
  border-radius: 2.5rem;
  z-index: 0;
}
.cta-card-glow {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(249,115,22,0.08), rgba(236,72,153,0.08), rgba(168,85,247,0.08));
  filter: blur(60px);
  z-index: 0;
}

.cta-inner { position: relative; z-index: 2; max-width: 700px; margin-inline: auto; }

.cta-icon-wrap {
  display: inline-flex;
  padding: 1rem;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(249,115,22,0.15), rgba(236,72,153,0.15));
  margin-bottom: 2rem;
}
.cta-icon {
  padding: 0.75rem;
  border-radius: 50%;
  background: var(--ml-gradient-main);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cta-icon svg { width: 24px; height: 24px; color: #fff; }

.cta-title {
  font-size: clamp(1.5rem, 4vw, 2.5rem);
  font-weight: 800;
  margin-bottom: 1.25rem;
  line-height: 1.2;
}

.cta-text { font-size: 1.05rem; color: var(--ml-text-400); margin-bottom: 2.5rem; }

.cta-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  border-top: 1px solid var(--ml-bg-800);
  padding-block: 4rem;
  padding-inline: 1.5rem;
}

.footer-inner {
  max-width: 1280px;
  margin-inline: auto;
}

.footer-grid {
  display: grid;
  gap: 3rem;
  margin-bottom: 3rem;
}
@media (min-width: 768px) { .footer-grid { grid-template-columns: 2fr 1fr 1.5fr; } }

.footer-brand-name {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 1rem;
}
.footer-brand-desc { font-size: 0.9rem; color: var(--ml-text-400); max-width: 300px; }

.footer-col-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ml-text);
  margin-bottom: 1rem;
}

.footer-links { display: flex; flex-direction: column; gap: 0.75rem; }
.footer-links a { font-size: 0.9rem; color: var(--ml-text-400); }
.footer-links a:hover { color: var(--ml-orange-400); }

.footer-contact-list { display: flex; flex-direction: column; gap: 0.75rem; }
.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--ml-text-400);
}
.footer-contact-item svg { width: 16px; height: 16px; color: var(--ml-orange-400); flex-shrink: 0; margin-top: 2px; }
.footer-contact-item a { color: var(--ml-text-400); }
.footer-contact-item a:hover { color: var(--ml-orange-400); }
.footer-country { color: var(--ml-text-500); font-size: 0.8rem; margin-right: 0.25rem; }

.footer-bottom {
  padding-top: 2rem;
  border-top: 1px solid var(--ml-bg-800);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  font-size: 0.85rem;
  color: var(--ml-text-500);
}
.footer-legal { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer-legal a { color: var(--ml-text-500); }
.footer-legal a:hover { color: var(--ml-text); }

/* ============================================================
   ELEMENTOR OVERRIDES
   ============================================================ */
.elementor-section,
.elementor-container { max-width: 100% !important; }

.elementor-page .hero-section,
.elementor-page .services-section,
.elementor-page .about-section,
.elementor-page .testimonials-section,
.elementor-page .cta-section { padding: 0; }

/* Make Elementor sections inherit dark bg */
.elementor-section.elementor-section-boxed > .elementor-container {
  max-width: 1280px;
}

/* Ensure Elementor widgets respect dark theme */
.elementor-widget-text-editor p,
.elementor-widget-text-editor li { color: var(--ml-text-400); }

.elementor-widget-heading h1,
.elementor-widget-heading h2,
.elementor-widget-heading h3 { color: var(--ml-text); }

/* ============================================================
   WORDPRESS CORE CLASSES
   ============================================================ */
.screen-reader-text {
  border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
  height: 1px; overflow: hidden; padding: 0; position: absolute;
  width: 1px; word-wrap: normal !important;
}
.alignnone, .alignleft, .alignright, .aligncenter { margin: 0.5rem 0; }
.alignleft { float: left; margin-right: 1.5rem; }
.alignright { float: right; margin-left: 1.5rem; }
.aligncenter { display: block; margin-inline: auto; }
.wp-block-image { margin-bottom: 1.5rem; }

/* ============================================================
   PAGE / POST CONTENT
   ============================================================ */
.entry-content {
  max-width: 760px;
  margin-inline: auto;
  padding: 5rem 1.5rem;
}
.entry-content h1, .entry-content h2, .entry-content h3 { margin-bottom: 1rem; margin-top: 2rem; }
.entry-content p { margin-bottom: 1.25rem; color: var(--ml-text-400); }
.entry-content ul, .entry-content ol { padding-left: 1.5rem; margin-bottom: 1.25rem; color: var(--ml-text-400); }
.entry-content ul { list-style: disc; }
.entry-content ol { list-style: decimal; }
.entry-content a { color: var(--ml-orange-400); text-decoration: underline; }

/* ============================================================
   UTILITIES
   ============================================================ */
.mt-4 { margin-top: 1rem; }
.mb-4 { margin-bottom: 1rem; }
.sr-only { @extend .screen-reader-text; }

/*
Theme Name: mightyLab Co
Theme URI: https://mightylabco.com
Author: mightyLab co
Author URI: https://mightylabco.com
Description: Dark-themed WordPress theme for mightyLab Co. Fully compatible with Elementor Free and Pro, with Theme Builder support for Header, Footer, Single Page, and all custom templates.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mightylab
Tags: dark, elementor, one-page, business, services, responsive, full-width-template, custom-header, custom-footer, theme-builder
*/

/* ═══════════════════════════════════════════
   CSS CUSTOM PROPERTIES
═══════════════════════════════════════════ */
:root {
  --ml-bg:          #020617;
  --ml-bg-900:      #0f172a;
  --ml-bg-800:      #1e293b;
  --ml-bg-700:      #334155;
  --ml-text:        #f8fafc;
  --ml-text-300:    #cbd5e1;
  --ml-text-400:    #94a3b8;
  --ml-text-500:    #64748b;
  --ml-orange:      #f97316;
  --ml-orange-400:  #fb923c;
  --ml-pink:        #ec4899;
  --ml-purple:      #a855f7;
  --ml-blue:        #3b82f6;
  --ml-cyan:        #06b6d4;
  --ml-emerald:     #10b981;
  --ml-grad-main:   linear-gradient(135deg,#f97316,#ec4899);
  --ml-grad-hero:   linear-gradient(135deg,#f97316,#ec4899,#a855f7);
  --ml-grad-blue:   linear-gradient(135deg,#3b82f6,#06b6d4);
  --ml-border:      rgba(255,255,255,0.08);
  --ml-card-r:      1.5rem;
  --ml-pill:        9999px;
  --ml-t:           0.3s ease;
  --ml-font:        'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

/* ═══════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ml-bg);color:var(--ml-text);
  font-family:var(--ml-font);font-size:16px;line-height:1.6;
  overflow-x:hidden;-webkit-font-smoothing:antialiased
}
a{color:inherit;text-decoration:none;transition:color var(--ml-t)}
a:hover{color:var(--ml-orange-400)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}

/* ═══════════════════════════════════════════
   TYPOGRAPHY
═══════════════════════════════════════════ */
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.15;letter-spacing:-.02em;color:var(--ml-text)}
h1{font-size:clamp(2.5rem,8vw,6rem)}
h2{font-size:clamp(2rem,5vw,3.5rem)}
h3{font-size:1.25rem}
p{color:var(--ml-text-400)}

.ml-grad-text{background:var(--ml-grad-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ml-grad-orange{background:linear-gradient(135deg,#fb923c,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ml-grad-blue{background:var(--ml-grad-blue);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ═══════════════════════════════════════════
   LAYOUT HELPERS
═══════════════════════════════════════════ */
.ml-container{max-width:1280px;margin-inline:auto;padding-inline:1.5rem}
.ml-section{padding-block:5rem;padding-inline:1.5rem;position:relative}
.ml-center{text-align:center}

/* ═══════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.ml-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1rem 2rem;border-radius:var(--ml-pill);
  font-size:1.05rem;font-weight:600;cursor:pointer;
  transition:all var(--ml-t);border:none;text-decoration:none
}
.ml-btn-primary{
  background:var(--ml-grad-main);color:#fff;
  box-shadow:0 10px 30px rgba(249,115,22,.25)
}
.ml-btn-primary:hover{
  background:linear-gradient(135deg,#ea6c0e,#db2777);color:#fff;
  box-shadow:0 14px 40px rgba(249,115,22,.35);transform:translateY(-2px)
}
.ml-btn-outline{
  background:transparent;color:var(--ml-text-300);
  border:1px solid var(--ml-bg-700)
}
.ml-btn-outline:hover{background:rgba(255,255,255,.05);color:var(--ml-text)}

/* ═══════════════════════════════════════════
   HEADER (native fallback)
═══════════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:999;
  padding:1rem 1.5rem;transition:background var(--ml-t),backdrop-filter var(--ml-t)
}
.site-header.scrolled{
  background:rgba(2,6,23,.88);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--ml-border)
}
.site-header-inner{
  max-width:1280px;margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between
}
.site-logo a{font-size:1.5rem;font-weight:800;letter-spacing:-.03em}
.site-logo .lm{color:var(--ml-text)}
.site-logo .ll{background:var(--ml-grad-main);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.site-logo .lc{color:var(--ml-text-300)}

.main-navigation ul{display:flex;align-items:center;gap:2rem}
.main-navigation ul li a{color:var(--ml-text-400);font-size:.9rem;font-weight:500}
.main-navigation ul li a:hover{color:var(--ml-text)}
.nav-cta{margin-left:1rem}

.menu-toggle{
  display:none;background:none;border:none;
  color:var(--ml-text);cursor:pointer;padding:.5rem
}
.menu-toggle span{
  display:block;width:24px;height:2px;
  background:currentColor;margin:5px 0;transition:all var(--ml-t)
}
@media(max-width:768px){
  .menu-toggle{display:block}
  .main-navigation{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:rgba(2,6,23,.97);backdrop-filter:blur(14px);
    border-bottom:1px solid var(--ml-border);padding:1.5rem
  }
  .main-navigation.open{display:block}
  .main-navigation ul{flex-direction:column;align-items:flex-start;gap:1rem}
  .nav-cta{margin-left:0;margin-top:1rem}
}

/* ═══════════════════════════════════════════
   HERO SECTION
═══════════════════════════════════════════ */
.hero-section{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;text-align:center;
  padding:6rem 1.5rem 4rem;position:relative;overflow:hidden
}
.h-orb-1{
  position:absolute;top:-25%;right:-25%;
  width:800px;height:800px;border-radius:50%;
  background:radial-gradient(circle,rgba(249,115,22,.18) 0%,rgba(236,72,153,.08) 50%,transparent 70%);
  filter:blur(60px);animation:orbA 20s ease-in-out infinite
}
.h-orb-2{
  position:absolute;bottom:-25%;left:-25%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.18) 0%,rgba(6,182,212,.08) 50%,transparent 70%);
  filter:blur(60px);animation:orbB 18s ease-in-out infinite
}
.h-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);
  background-size:60px 60px
}
@keyframes orbA{0%,100%{transform:scale(1) rotate(0deg)}33%{transform:scale(1.1) rotate(60deg)}66%{transform:scale(.95) rotate(120deg)}}
@keyframes orbB{0%,100%{transform:rotate(0deg)}50%{transform:rotate(-20deg) scale(1.05)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}

.hero-inner{position:relative;z-index:2;max-width:900px;margin-inline:auto}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.5rem 1rem;border-radius:var(--ml-pill);
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  backdrop-filter:blur(8px);font-size:.875rem;color:var(--ml-text-300);
  margin-bottom:2rem;animation:fadeDown .6s ease both
}
.hero-badge svg{color:var(--ml-orange-400)}
.hero-title{
  font-size:clamp(3rem,9vw,7rem);font-weight:800;letter-spacing:-.04em;
  margin-bottom:1.5rem;animation:fadeUp .7s ease .1s both
}
.hero-title .w-mighty{color:var(--ml-text)}
.hero-title .w-lab{background:var(--ml-grad-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-title .w-co{color:var(--ml-text-300)}
.hero-tagline{
  font-size:clamp(1.1rem,2.5vw,1.5rem);color:var(--ml-text-400);
  max-width:700px;margin-inline:auto;margin-bottom:1rem;
  animation:fadeUp .7s ease .2s both
}
.hero-tagline strong{color:var(--ml-text);font-weight:600}
.hero-sub{
  font-size:1.1rem;color:var(--ml-text-500);
  max-width:550px;margin-inline:auto;margin-bottom:3rem;
  animation:fadeUp .7s ease .3s both
}
.hero-actions{
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;
  animation:fadeUp .7s ease .4s both
}
.h-shape-1{position:absolute;top:20%;left:5%;width:80px;height:80px;border:1.5px solid rgba(249,115,22,.3);border-radius:1rem;animation:spin 12s linear infinite}
.h-shape-2{position:absolute;bottom:30%;right:8%;width:64px;height:64px;background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(168,85,247,.15));border-radius:50%;animation:float 8s ease-in-out infinite}
.h-shape-3{position:absolute;top:35%;right:6%;width:32px;height:32px;border:2px solid rgba(236,72,153,.4);animation:spin 8s linear infinite reverse}

/* ═══════════════════════════════════════════
   SECTION LABELS & TITLES
═══════════════════════════════════════════ */
.ml-label{
  display:block;text-transform:uppercase;letter-spacing:.15em;
  font-size:.8rem;font-weight:600;color:var(--ml-orange-400);margin-bottom:1rem
}
.ml-title{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;margin-bottom:1.25rem}
.ml-desc{font-size:1.1rem;color:var(--ml-text-400);max-width:600px;margin-inline:auto}

/* ═══════════════════════════════════════════
   SERVICE CARDS
═══════════════════════════════════════════ */
.services-bg{background:linear-gradient(180deg,var(--ml-bg) 0%,rgba(15,23,42,.5) 50%,var(--ml-bg) 100%)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:4rem}
.scard{
  position:relative;height:100%;padding:2rem;
  border-radius:var(--ml-card-r);
  background:rgba(15,23,42,.5);border:1px solid var(--ml-bg-800);
  overflow:hidden;transition:border-color var(--ml-t),transform var(--ml-t)
}
.scard:hover{border-color:var(--ml-bg-700);transform:translateY(-4px)}
.scard-glow{position:absolute;inset:0;opacity:0;transition:opacity var(--ml-t)}
.scard:hover .scard-glow{opacity:.05}
.scard-corner{position:absolute;bottom:-2.5rem;right:-2.5rem;width:8rem;height:8rem;border-radius:50%;opacity:0;filter:blur(2rem);transition:opacity var(--ml-t)}
.scard:hover .scard-corner{opacity:.1}
.scard-icon{display:inline-flex;padding:.75rem;border-radius:.875rem;margin-bottom:1.5rem}
.scard-icon svg{width:24px;height:24px;color:#fff}
.scard-title{font-size:1.15rem;font-weight:700;color:var(--ml-text);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}
.scard-arrow{margin-left:auto;color:var(--ml-text-500);transition:all var(--ml-t);flex-shrink:0}
.scard:hover .scard-arrow{color:var(--ml-text);transform:translate(3px,-3px)}
.scard-desc{font-size:.95rem;line-height:1.7}

.sc-orange .scard-icon,.sc-orange .scard-glow,.sc-orange .scard-corner{background:linear-gradient(135deg,var(--ml-orange),var(--ml-pink))}
.sc-blue   .scard-icon,.sc-blue   .scard-glow,.sc-blue   .scard-corner{background:var(--ml-grad-blue)}
.sc-purple .scard-icon,.sc-purple .scard-glow,.sc-purple .scard-corner{background:linear-gradient(135deg,var(--ml-purple),var(--ml-pink))}
.sc-emerald.scard-icon,.sc-emerald.scard-glow,.sc-emerald.scard-corner{background:linear-gradient(135deg,var(--ml-emerald),#14b8a6)}
.sc-amber  .scard-icon,.sc-amber  .scard-glow,.sc-amber  .scard-corner{background:linear-gradient(135deg,#f59e0b,var(--ml-orange))}
.sc-rose   .scard-icon,.sc-rose   .scard-glow,.sc-rose   .scard-corner{background:linear-gradient(135deg,#f43f5e,#ef4444)}

/* ═══════════════════════════════════════════
   ABOUT / WHY US
═══════════════════════════════════════════ */
.about-orb{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:800px;border-radius:50%;
  background:radial-gradient(circle,rgba(249,115,22,.04) 0%,rgba(236,72,153,.04) 50%,transparent 70%);
  filter:blur(80px);pointer-events:none
}
.about-grid{display:grid;gap:4rem;align-items:center}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1fr}}
.about-headline{font-size:clamp(2.2rem,5vw,4rem);font-weight:800;line-height:1.1;margin-bottom:2rem}
.about-lead{font-size:1.1rem;line-height:1.8;margin-bottom:2.5rem}
.stats-row{display:flex;gap:2.5rem;flex-wrap:wrap}
.stat-num{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;line-height:1;margin-bottom:.25rem}
.stat-lbl{font-size:.85rem;color:var(--ml-text-500)}
.stat-sub{font-size:.75rem;color:var(--ml-bg-700)}

.feature-list{display:flex;flex-direction:column;gap:1rem}
.fitem{
  display:flex;gap:1.25rem;padding:1.25rem 1.5rem;
  border-radius:1rem;background:rgba(15,23,42,.3);
  border:1px solid var(--ml-bg-800);transition:all var(--ml-t)
}
.fitem:hover{border-color:var(--ml-bg-700);background:rgba(15,23,42,.5)}
.ficon{
  flex-shrink:0;padding:.75rem;border-radius:.75rem;
  background:linear-gradient(135deg,var(--ml-bg-800),#060f21);
  transition:background var(--ml-t)
}
.fitem:hover .ficon{background:linear-gradient(135deg,rgba(249,115,22,.15),rgba(236,72,153,.15))}
.ficon svg{width:20px;height:20px;color:var(--ml-orange-400)}
.fname{font-size:1rem;font-weight:700;color:var(--ml-text);margin-bottom:.25rem}
.fdesc{font-size:.875rem;line-height:1.6}

/* ═══════════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════════ */
.testimonials-bg{background:linear-gradient(180deg,var(--ml-bg) 0%,rgba(15,23,42,.3) 50%,var(--ml-bg) 100%)}
.tgrid{display:grid;gap:1.5rem;margin-top:4rem}
@media(min-width:768px){.tgrid{grid-template-columns:repeat(3,1fr)}}
.tcard{
  position:relative;padding:2rem;border-radius:var(--ml-card-r);
  background:rgba(15,23,42,.5);border:1px solid var(--ml-bg-800);
  transition:border-color var(--ml-t)
}
.tcard:hover{border-color:var(--ml-bg-700)}
.tquote{
  position:absolute;top:-1rem;left:2rem;padding:.5rem;
  border-radius:50%;background:var(--ml-grad-main)
}
.tquote svg{width:16px;height:16px;color:#fff}
.ttext{font-size:.95rem;line-height:1.75;color:var(--ml-text-300);margin-top:1rem;margin-bottom:1.5rem}
.tauthor{display:flex;align-items:center;gap:.75rem}
.tavatar{
  width:2.5rem;height:2.5rem;border-radius:50%;
  background:linear-gradient(135deg,rgba(249,115,22,.2),rgba(236,72,153,.2));
  display:flex;align-items:center;justify-content:center;
  font-size:.875rem;font-weight:700;color:var(--ml-orange-400);flex-shrink:0
}
.tname{font-weight:600;color:var(--ml-text);font-size:.95rem}

/* ═══════════════════════════════════════════
   CTA BOX
═══════════════════════════════════════════ */
.cta-card{
  position:relative;border-radius:2.5rem;overflow:hidden;
  padding:3rem 2rem;text-align:center
}
.cta-card::before{
  content:'';position:absolute;inset:0;padding:1px;
  border-radius:2.5rem;background:var(--ml-grad-hero);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude
}
.cta-bg{position:absolute;inset:0;background:var(--ml-bg);border-radius:2.5rem;z-index:0}
.cta-glow{position:absolute;inset:0;background:linear-gradient(135deg,rgba(249,115,22,.08),rgba(236,72,153,.08),rgba(168,85,247,.08));filter:blur(60px);z-index:0}
.cta-inner{position:relative;z-index:2;max-width:700px;margin-inline:auto}
.cta-icon-wrap{display:inline-flex;padding:1rem;border-radius:50%;background:linear-gradient(135deg,rgba(249,115,22,.15),rgba(236,72,153,.15));margin-bottom:2rem}
.cta-icon{padding:.75rem;border-radius:50%;background:var(--ml-grad-main);display:flex;align-items:center;justify-content:center}
.cta-icon svg{width:24px;height:24px;color:#fff}
.cta-title{font-size:clamp(1.5rem,4vw,2.5rem);font-weight:800;margin-bottom:1.25rem;line-height:1.2}
.cta-text{font-size:1.05rem;color:var(--ml-text-400);margin-bottom:2.5rem}
.cta-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}

/* ═══════════════════════════════════════════
   FOOTER (native)
═══════════════════════════════════════════ */
.site-footer{border-top:1px solid var(--ml-bg-800);padding-block:4rem;padding-inline:1.5rem}
.footer-inner{max-width:1280px;margin-inline:auto}
.footer-grid{display:grid;gap:3rem;margin-bottom:3rem}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1.5fr}}
.footer-brand-name{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;margin-bottom:1rem}
.footer-brand-desc{font-size:.9rem;color:var(--ml-text-400);max-width:300px}
.footer-col-title{font-size:.95rem;font-weight:700;color:var(--ml-text);margin-bottom:1rem}
.footer-links{display:flex;flex-direction:column;gap:.75rem}
.footer-links a{font-size:.9rem;color:var(--ml-text-400)}
.footer-links a:hover{color:var(--ml-orange-400)}
.footer-contact-list{display:flex;flex-direction:column;gap:.75rem}
.fci{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem;color:var(--ml-text-400)}
.fci svg{width:16px;height:16px;color:var(--ml-orange-400);flex-shrink:0;margin-top:2px}
.fci a{color:var(--ml-text-400)}
.fci a:hover{color:var(--ml-orange-400)}
.fcountry{color:var(--ml-text-500);font-size:.8rem;margin-right:.25rem}
.footer-bottom{padding-top:2rem;border-top:1px solid var(--ml-bg-800);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;font-size:.85rem;color:var(--ml-text-500)}
.footer-legal{display:flex;gap:1.5rem;flex-wrap:wrap}
.footer-legal a{color:var(--ml-text-500)}
.footer-legal a:hover{color:var(--ml-text)}

/* ═══════════════════════════════════════════
   POLICY PAGES (Privacy / Terms)
═══════════════════════════════════════════ */
.policy-page{padding:8rem 1.5rem 5rem;max-width:820px;margin-inline:auto}
.policy-date{color:var(--ml-text-500);font-size:.9rem;margin-bottom:3rem}
.policy-body h2{font-size:1.4rem;font-weight:700;color:var(--ml-text);margin-top:2.5rem;margin-bottom:.75rem}
.policy-body h3{font-size:1.1rem;font-weight:600;color:var(--ml-text);margin-top:1.5rem;margin-bottom:.5rem}
.policy-body p{color:var(--ml-text-400);line-height:1.8;margin-bottom:1rem}
.policy-body ul{padding-left:1.25rem;margin-bottom:1rem}
.policy-body ul li{color:var(--ml-text-400);list-style:disc;line-height:1.8;margin-bottom:.25rem}
.policy-body ul li ul{margin-top:.25rem}
.policy-body a{color:var(--ml-orange-400);text-decoration:underline}
.policy-body strong{color:var(--ml-text-300)}

/* ═══════════════════════════════════════════
   SIGN-UP PAGE
═══════════════════════════════════════════ */
.signup-page{padding:8rem 1.5rem 5rem}
.signup-wrap{max-width:720px;margin-inline:auto}
.signup-header{text-align:center;margin-bottom:3rem}
.signup-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:.75rem}

/* Form card wrapper */
.ml-card{
  background:rgba(15,23,42,.5);border:1px solid var(--ml-bg-800);
  border-radius:1.25rem;padding:1.75rem;margin-bottom:1.5rem
}
.ml-card-title{font-size:1.1rem;font-weight:700;color:var(--ml-text);margin-bottom:1.25rem}

/* Grid helpers */
.form-row{display:grid;gap:1rem}
@media(min-width:600px){.form-row.cols-2{grid-template-columns:1fr 1fr}}
.form-row.template-grid{grid-template-columns:repeat(2,1fr)}
@media(min-width:500px){.form-row.template-grid{grid-template-columns:repeat(3,1fr)}}

/* Fields */
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-size:.875rem;font-weight:500;color:var(--ml-text-300)}
.form-label .req{color:var(--ml-orange-400);margin-left:.2rem}
.form-input,
.form-textarea,
.form-select{
  width:100%;background:var(--ml-bg-900);border:1px solid var(--ml-bg-700);
  border-radius:.75rem;padding:.875rem 1rem;color:var(--ml-text);
  font-family:var(--ml-font);font-size:.9rem;transition:border-color var(--ml-t)
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--ml-text-500)}
.form-input:focus,.form-textarea:focus,.form-select:focus{
  outline:none;border-color:var(--ml-orange)
}
.form-textarea{resize:vertical;min-height:90px}
.form-select option{background:var(--ml-bg-900)}

/* Template picker */
.tpl-btn{
  position:relative;width:100%;border-radius:.75rem;overflow:hidden;
  border:2px solid var(--ml-bg-700);cursor:pointer;
  background:none;transition:border-color var(--ml-t);padding:0
}
.tpl-btn:hover{border-color:var(--ml-bg-700)}
.tpl-btn.selected{border-color:var(--ml-orange)}
.tpl-btn img{width:100%;height:9rem;object-fit:cover;object-position:top;display:block}
.tpl-btn-label{
  padding:.375rem .5rem;font-size:.75rem;font-weight:600;text-align:center;
  background:rgba(15,23,42,.85);color:var(--ml-text-300);transition:color var(--ml-t)
}
.tpl-btn.selected .tpl-btn-label{color:var(--ml-orange-400)}
.tpl-check-wrap{grid-column:1/-1;margin-top:.25rem}
.tpl-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer}
.tpl-checkbox input{width:1rem;height:1rem;accent-color:var(--ml-orange);cursor:pointer}
.tpl-checkbox span{font-size:.875rem;color:var(--ml-text-300);transition:color var(--ml-t)}
.tpl-checkbox:hover span{color:var(--ml-text)}

/* Terms scroll box */
.terms-scroll{
  height:18rem;overflow-y:auto;background:var(--ml-bg);
  border:1px solid var(--ml-bg-700);border-radius:.75rem;
  padding:1.25rem;color:var(--ml-text-300);font-size:.875rem;line-height:1.7;
  scrollbar-width:thin;scrollbar-color:var(--ml-bg-700) transparent
}
.terms-scroll::-webkit-scrollbar{width:6px}
.terms-scroll::-webkit-scrollbar-track{background:transparent}
.terms-scroll::-webkit-scrollbar-thumb{background:var(--ml-bg-700);border-radius:3px}
.terms-block{margin-bottom:1.5rem}
.terms-block h4{
  font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.1em;color:var(--ml-orange-400);margin-bottom:.5rem
}
.terms-block p{color:var(--ml-text-300);white-space:pre-line}
.terms-hint{font-size:.75rem;color:var(--ml-text-500);font-style:italic;margin-top:.5rem}

/* Submit */
.ml-submit{
  width:100%;padding:1.1rem;border-radius:1rem;
  background:var(--ml-grad-main);color:#fff;
  font-size:1.1rem;font-weight:700;border:none;cursor:pointer;
  transition:all var(--ml-t);box-shadow:0 8px 24px rgba(249,115,22,.2)
}
.ml-submit:hover{background:linear-gradient(135deg,#ea6c0e,#db2777);transform:translateY(-2px);box-shadow:0 12px 30px rgba(249,115,22,.3)}
.ml-submit:disabled{opacity:.45;cursor:not-allowed;transform:none}

/* ═══════════════════════════════════════════
   THANK-YOU / SIGNED-UP PAGE
═══════════════════════════════════════════ */
.thankyou-page{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;text-align:center;
  padding:5rem 1.5rem;position:relative;overflow:hidden
}
.ty-orb{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(249,115,22,.1) 0%,rgba(236,72,153,.06) 50%,transparent 70%);
  filter:blur(80px);pointer-events:none
}
.ty-inner{position:relative;z-index:2;max-width:680px;margin-inline:auto}
.ty-check{
  display:inline-flex;align-items:center;justify-content:center;
  width:6rem;height:6rem;border-radius:50%;
  background:var(--ml-grad-main);margin-bottom:2rem;
  animation:fadeDown .6s ease both;
  box-shadow:0 0 60px rgba(249,115,22,.3)
}
.ty-check svg{width:2.5rem;height:2.5rem;color:#fff}
.ty-title{font-size:clamp(2rem,5vw,3.5rem);font-weight:800;margin-bottom:1.25rem;animation:fadeUp .7s ease .1s both}
.ty-text{font-size:1.1rem;color:var(--ml-text-400);line-height:1.8;margin-bottom:2.5rem;animation:fadeUp .7s ease .2s both}
.ty-details{
  display:grid;gap:1rem;text-align:left;
  background:rgba(15,23,42,.5);border:1px solid var(--ml-bg-800);
  border-radius:1.25rem;padding:1.5rem;margin-bottom:2.5rem;
  animation:fadeUp .7s ease .3s both
}
@media(min-width:500px){.ty-details{grid-template-columns:1fr 1fr}}
.ty-detail-item{display:flex;flex-direction:column;gap:.25rem}
.ty-detail-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--ml-text-500)}
.ty-detail-val{font-size:.95rem;color:var(--ml-text-300)}
.ty-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;animation:fadeUp .7s ease .4s both}

/* ═══════════════════════════════════════════
   WORDPRESS UTILITY CLASSES
═══════════════════════════════════════════ */
.screen-reader-text{border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}
.alignnone,.alignleft,.alignright,.aligncenter{margin:.5rem 0}
.alignleft{float:left;margin-right:1.5rem}
.alignright{float:right;margin-left:1.5rem}
.aligncenter{display:block;margin-inline:auto}

/* ═══════════════════════════════════════════
   ELEMENTOR OVERRIDES
═══════════════════════════════════════════ */
.elementor-section.elementor-section-boxed>.elementor-container{max-width:1280px}
.elementor-widget-text-editor p{color:var(--ml-text-400)}
.elementor-widget-heading h1,.elementor-widget-heading h2,.elementor-widget-heading h3{color:var(--ml-text)}

/* ═══════════════════════════════════════════
   GENERIC ENTRY CONTENT (fallback pages)
═══════════════════════════════════════════ */
.entry-content{max-width:760px;margin-inline:auto;padding:5rem 1.5rem}
.entry-content h1,.entry-content h2,.entry-content h3{margin-bottom:1rem;margin-top:2rem}
.entry-content p{margin-bottom:1.25rem}
.entry-content ul,.entry-content ol{padding-left:1.5rem;margin-bottom:1.25rem;color:var(--ml-text-400)}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content a{color:var(--ml-orange-400);text-decoration:underline}

/* ═══════════════════════════════════════════
   SCROLL-REVEAL via JS
═══════════════════════════════════════════ */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .55s ease,transform .55s ease}
[data-reveal].revealed{opacity:1;transform:translateY(0)}

