/* ============================================================
   ONE TECHNICIAN — V2 REDESIGN OVERLAY
   Bold, modern, fancy refresh layered on top of style.css
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&display=swap');

:root {
  --v2-accent-2:      #FF5E1A;
  --v2-accent-3:      #FFB347;
  --v2-grad:          linear-gradient(120deg, #FF5E1A 0%, #FF8C00 45%, #FFB347 100%);
  --v2-glass:         rgba(20,20,26,0.55);
  --v2-glass-border:  rgba(255,255,255,0.10);
  --v2-card-radius:   18px;
  --v2-pill-radius:   999px;
  --v2-ease:          cubic-bezier(.2,.7,.2,1);
}
[data-theme="light"] {
  --v2-glass:         rgba(255,255,255,0.65);
  --v2-glass-border:  rgba(0,0,0,0.08);
}

@property --v2-angle {
  syntax: '<angle>';
  inherits: false;
  initial-value: 0deg;
}

/* ----- Smooth theme cross-fade ----- */
html { transition: background-color .35s var(--v2-ease); }
body, .navbar, .footer, .service-card, .testimonial-card,
.process-step, .cta-banner, .mobile-menu, .dashboard-card, .marquee-section,
.btn, .section-tag, .hero-badge {
  transition:
    background-color .35s var(--v2-ease),
    border-color .35s var(--v2-ease),
    color .35s var(--v2-ease),
    box-shadow .35s var(--v2-ease);
}

/* ----- Subtle film grain over the whole page ----- */
body::before {
  content: '';
  position: fixed;
  inset: -50%;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.045 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: .55;
  mix-blend-mode: overlay;
}
[data-theme="light"] body::before { opacity: .35; mix-blend-mode: multiply; }

main, section, footer { position: relative; z-index: 2; }

/* ============================================================
   TYPOGRAPHY — bigger, bolder, gradient sheen
   ============================================================ */
h1, h2 {
  font-family: 'Space Grotesk', var(--font-head);
  letter-spacing: -0.035em;
  font-weight: 700;
}
h1 { font-size: clamp(2.6rem, 6vw, 5.2rem); line-height: 1.02; }
h2 { font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.06; }

.hero-title { font-weight: 700; letter-spacing: -0.04em; }
.hero-title span,
h1 .text-orange, h2 .text-orange, h3 .text-orange {
  background: var(--v2-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  background-size: 200% 200%;
  animation: v2GradShift 8s ease-in-out infinite;
  filter: drop-shadow(0 6px 24px rgba(255,140,0,0.25));
}
@keyframes v2GradShift {
  0%,100% { background-position: 0% 50%; }
  50%     { background-position: 100% 50%; }
}

/* Section tag — glowing pill */
.section-tag {
  padding: 7px 14px 7px 12px;
  border-radius: var(--v2-pill-radius);
  background: linear-gradient(120deg, rgba(255,140,0,0.14), rgba(255,140,0,0.04));
  border: 1px solid rgba(255,140,0,0.35);
  color: var(--orange);
  box-shadow: 0 0 0 4px rgba(255,140,0,0.05);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.section-tag::before {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 0 4px rgba(255,140,0,0.18), 0 0 12px var(--orange);
  animation: v2Pulse 2.4s ease-in-out infinite;
}
@keyframes v2Pulse {
  0%,100% { transform: scale(1); opacity: 1; }
  50%     { transform: scale(1.3); opacity: .7; }
}

/* ============================================================
   NAVBAR — glass + animated underline
   ============================================================ */
.navbar {
  background: transparent !important;
  border-bottom: 1px solid var(--v2-glass-border);
  overflow: visible !important;
}
/* Glass blur via ::before pseudo so dropdown children aren't clipped */
.navbar::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: -1 !important;
  backdrop-filter: blur(18px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(18px) saturate(140%) !important;
  background: var(--v2-glass) !important;
  opacity: 1 !important;
  pointer-events: none !important;
}
.navbar > .container { position: relative; z-index: 1; }
.navbar .nav-inner { position: relative; z-index: 1; }
.navbar.scrolled {
  box-shadow: 0 12px 40px -20px rgba(0,0,0,0.55);
}
/* Dropdown must sit above everything */
.nav-dropdown-menu {
  z-index: 9999 !important;
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  background: var(--dark-2) !important;
  border: 1px solid var(--border-light);
  border-radius: var(--v2-card-radius) !important;
  box-shadow:
    0 24px 64px rgba(0,0,0,0.6),
    0 0 0 1px rgba(255,255,255,0.06);
}
.navbar::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,140,0,0.55) 50%, transparent 100%);
  opacity: .8;
}
.nav-links a { position: relative; transition: color .25s var(--v2-ease); }
.nav-links > li > a::after {
  content: '';
  position: absolute;
  left: 12px; right: 12px; bottom: -6px;
  height: 2px;
  background: var(--v2-grad);
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .35s var(--v2-ease);
}
.nav-links > li > a:hover::after,
.nav-links > li > a.active::after { transform: scaleX(1); }

.nav-logo-img {
  border-radius: 10px;
  box-shadow: 0 0 0 1px rgba(255,140,0,0.35), 0 8px 24px -8px rgba(255,140,0,0.55);
  transition: transform .4s var(--v2-ease);
}
.nav-logo:hover .nav-logo-img { transform: rotate(-4deg) scale(1.05); }

/* ============================================================
   BUTTONS — gradient primary, sheen, glow
   ============================================================ */
.btn {
  font-weight: 800;
  letter-spacing: 0.06em;
  padding: 16px 34px;
  font-size: 0.86rem;
}
.btn-primary {
  background: var(--v2-grad) !important;
  color: #111 !important;
  box-shadow:
    0 10px 30px -10px rgba(255,140,0,0.65),
    inset 0 1px 0 rgba(255,255,255,0.45);
}
.btn-primary:hover {
  filter: brightness(1.08) saturate(1.05);
  transform: translateY(-3px);
  box-shadow:
    0 18px 40px -12px rgba(255,140,0,0.75),
    inset 0 1px 0 rgba(255,255,255,0.55);
}
.btn-outline {
  border: 1.5px solid rgba(255,140,0,0.45);
  background: linear-gradient(120deg, rgba(255,140,0,0.05), rgba(255,140,0,0.01));
  color: var(--white);
}
.btn-outline:hover {
  border-color: var(--orange);
  background: linear-gradient(120deg, rgba(255,140,0,0.18), rgba(255,140,0,0.06));
  color: var(--white);
  transform: translateY(-3px);
}
[data-theme="light"] .btn-outline,
[data-theme="light"] .btn-outline:hover { color: #111; }

/* ============================================================
   CARDS — animated conic border, lift + sheen
   ============================================================ */
.service-card,
.testimonial-card,
.process-step,
.dashboard-card {
  position: relative;
  border-radius: var(--v2-card-radius) !important;
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)),
              var(--card-bg) !important;
  border: 1px solid var(--v2-glass-border) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.04) inset,
    0 22px 60px -28px rgba(0,0,0,0.65);
  overflow: hidden;
  isolation: isolate;
}
[data-theme="light"] .service-card,
[data-theme="light"] .testimonial-card,
[data-theme="light"] .process-step,
[data-theme="light"] .dashboard-card {
  background: linear-gradient(180deg, rgba(255,255,255,0.85), rgba(255,255,255,0.65)) !important;
  border-color: rgba(0,0,0,0.08) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.6) inset,
    0 18px 50px -28px rgba(0,0,0,0.18);
}

.service-card::before,
.testimonial-card::before,
.process-step::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(from var(--v2-angle, 0deg),
              transparent 0deg, transparent 220deg,
              #FF5E1A 280deg, #FFB347 320deg, transparent 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0;
  transition: opacity .4s var(--v2-ease);
  animation: v2Spin 6s linear infinite;
  pointer-events: none;
  z-index: 1;
}
@keyframes v2Spin { to { --v2-angle: 360deg; } }

.service-card:hover,
.testimonial-card:hover,
.process-step:hover {
  transform: translateY(-6px);
  border-color: rgba(255,140,0,0.35) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.06) inset,
    0 30px 70px -28px rgba(255,140,0,0.45),
    0 22px 60px -28px rgba(0,0,0,0.65);
}
.service-card:hover::before,
.testimonial-card:hover::before,
.process-step:hover::before { opacity: 1; }

.service-card::after,
.testimonial-card::after {
  content: '';
  position: absolute;
  top: 0; left: -60%;
  width: 50%; height: 100%;
  background: linear-gradient(115deg, transparent 0%, rgba(255,255,255,0.10) 50%, transparent 100%);
  transform: skewX(-18deg);
  transition: left .9s var(--v2-ease);
  pointer-events: none;
  z-index: 1;
}
.service-card:hover::after,
.testimonial-card:hover::after { left: 130%; }

.service-card-icon {
  position: relative;
  width: 64px; height: 64px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(160deg, rgba(255,140,0,0.18), rgba(255,140,0,0.04));
  border: 1px solid rgba(255,140,0,0.35);
  color: var(--orange);
  font-size: 1.5rem;
  box-shadow: 0 12px 28px -14px rgba(255,140,0,0.55);
  margin-bottom: 18px;
}
.service-card-icon::after {
  content: '';
  position: absolute;
  inset: -6px;
  border-radius: 22px;
  border: 1px dashed rgba(255,140,0,0.30);
  animation: v2SlowSpin 18s linear infinite;
  pointer-events: none;
}
@keyframes v2SlowSpin { to { transform: rotate(360deg); } }

.process-step .step-num {
  font-family: 'Space Grotesk', var(--font-head);
  font-size: 3.4rem;
  font-weight: 700;
  background: var(--v2-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 8px 24px rgba(255,140,0,0.35));
  line-height: 1;
}

.testimonial-card .stars {
  font-size: 1.15rem;
  filter: drop-shadow(0 4px 12px rgba(255,140,0,0.45));
}
.author-avatar {
  background: var(--v2-grad) !important;
  color: #111 !important;
  font-weight: 800;
  box-shadow: 0 8px 24px -10px rgba(255,140,0,0.65);
}

/* ============================================================
   HERO — bigger statement, glow, divider lines
   ============================================================ */
.hero { padding-top: 160px; padding-bottom: 120px; }
.hero-badge {
  background: linear-gradient(120deg, rgba(255,140,0,0.18), rgba(255,140,0,0.05)) !important;
  border: 1px solid rgba(255,140,0,0.45) !important;
  border-radius: var(--v2-pill-radius) !important;
  padding: 8px 16px 8px 14px !important;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 10px 30px -15px rgba(255,140,0,0.55);
}
.hero-stat-num {
  font-family: 'Space Grotesk', var(--font-head);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  background: var(--v2-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
.hero-stats > div { position: relative; padding-left: 18px; }
.hero-stats > div + div::before {
  content: '';
  position: absolute;
  left: 0; top: 12%;
  height: 76%;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,140,0,0.55), transparent);
}

.hero-float-card {
  background: var(--v2-glass) !important;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid var(--v2-glass-border) !important;
  border-radius: 14px !important;
  box-shadow: 0 18px 50px -22px rgba(0,0,0,0.6);
}
.fc-icon {
  background: var(--v2-grad) !important;
  color: #111 !important;
  box-shadow: 0 10px 24px -10px rgba(255,140,0,0.65);
}

/* ============================================================
   SECTIONS — alt background + edge dividers
   ============================================================ */
.section { position: relative; }
.section-alt {
  background-color: var(--dark) !important;
  background-image:
    radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,140,0,0.08) 0%, transparent 65%),
    radial-gradient(ellipse 50% 40% at 100% 100%, rgba(255,140,0,0.05) 0%, transparent 60%) !important;
}
.section-alt::before,
.section-alt::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,140,0,0.5), transparent);
}
.section-alt::before { top: 0; }
.section-alt::after  { bottom: 0; }

/* ============================================================
   MARQUEE — fade edges + gradient icons
   ============================================================ */
.marquee-section {
  border-top: 1px solid var(--v2-glass-border) !important;
  border-bottom: 1px solid var(--v2-glass-border) !important;
  background:
    radial-gradient(ellipse 60% 200% at 50% 50%, rgba(255,140,0,0.08), transparent 60%),
    var(--dark-2) !important;
  position: relative;
}
.marquee-section::before,
.marquee-section::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0; width: 120px;
  z-index: 2;
  pointer-events: none;
}
.marquee-section::before { left: 0;  background: linear-gradient(90deg, var(--dark-2), transparent); }
.marquee-section::after  { right: 0; background: linear-gradient(-90deg, var(--dark-2), transparent); }
.marquee-item {
  font-family: 'Space Grotesk', var(--font-head);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.marquee-item i {
  background: var(--v2-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

/* ============================================================
   CTA BANNER — bold gradient panel with grid mask
   ============================================================ */
.cta-banner {
  position: relative;
  border-radius: 24px !important;
  background:
    radial-gradient(ellipse 80% 120% at 0% 0%, rgba(255,140,0,0.18), transparent 55%),
    radial-gradient(ellipse 80% 120% at 100% 100%, rgba(255,94,26,0.14), transparent 55%),
    linear-gradient(160deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)),
    var(--card-bg) !important;
  border: 1px solid rgba(255,140,0,0.35) !important;
  overflow: hidden;
  box-shadow: 0 30px 80px -30px rgba(255,140,0,0.4);
}
.cta-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,140,0,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,140,0,0.06) 1px, transparent 1px);
  background-size: 36px 36px;
  -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 30%, transparent 70%);
          mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, #000 30%, transparent 70%);
  pointer-events: none;
}

/* ============================================================
   THEME TOGGLE — animated, glowing
   ============================================================ */
.theme-toggle {
  width: 44px !important;
  height: 44px !important;
  border-radius: 12px !important;
  background: linear-gradient(160deg, rgba(255,140,0,0.18), rgba(255,140,0,0.04)) !important;
  border: 1px solid rgba(255,140,0,0.35) !important;
  color: var(--orange) !important;
  box-shadow: 0 8px 24px -10px rgba(255,140,0,0.55);
  position: relative;
  overflow: hidden;
}
.theme-toggle::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--v2-grad);
  opacity: 0;
  transition: opacity .35s var(--v2-ease);
}
.theme-toggle:hover { transform: translateY(-2px) rotate(-8deg); color: #111 !important; }
.theme-toggle:hover::before { opacity: 1; }
.theme-toggle i { position: relative; z-index: 1; transition: transform .5s var(--v2-ease); }
.theme-toggle:hover i { transform: rotate(360deg) scale(1.1); }
[data-theme="light"] .theme-toggle {
  background: linear-gradient(160deg, rgba(255,140,0,0.18), rgba(255,140,0,0.04)) !important;
  border-color: rgba(255,140,0,0.45) !important;
  color: var(--orange-dark) !important;
}

/* ============================================================
   FOOTER — glowing top edge
   ============================================================ */
.footer {
  position: relative;
  background:
    radial-gradient(ellipse 80% 80% at 50% 0%, rgba(255,140,0,0.06), transparent 60%),
    var(--dark) !important;
  border-top: 1px solid var(--v2-glass-border) !important;
}
.footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,140,0,0.55), transparent);
}
.social-link { transition: all .35s var(--v2-ease); }
.social-link:hover {
  transform: translateY(-3px) scale(1.08);
  background: var(--v2-grad) !important;
  color: #111 !important;
  box-shadow: 0 10px 26px -10px rgba(255,140,0,0.65);
}

/* ============================================================
   PAGE HERO (interior pages)
   ============================================================ */
.page-hero h1, .page-hero-title {
  font-family: 'Space Grotesk', var(--font-head);
  font-weight: 700;
  letter-spacing: -0.04em;
}
.page-hero { border-bottom: 1px solid var(--v2-glass-border); }

/* ============================================================
   FORMS
   ============================================================ */
input[type="text"], input[type="email"], input[type="tel"],
textarea, select {
  border-radius: 12px !important;
  border: 1px solid var(--v2-glass-border) !important;
  background: rgba(255,255,255,0.03) !important;
  transition: all .3s var(--v2-ease);
}
input:focus, textarea:focus, select:focus {
  border-color: var(--orange) !important;
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(255,140,0,0.15) !important;
}
[data-theme="light"] input,
[data-theme="light"] textarea,
[data-theme="light"] select { background: rgba(0,0,0,0.03) !important; }

/* ============================================================
   LIGHT MODE — extra polish
   ============================================================ */
[data-theme="light"] .navbar { background: rgba(255,255,255,0.7) !important; }
[data-theme="light"] .navbar.scrolled { background: rgba(255,255,255,0.85) !important; }
[data-theme="light"] .section-alt {
  background-color: #F4F4F4 !important;
  background-image:
    radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,140,0,0.08), transparent 65%) !important;
}
[data-theme="light"] .marquee-section {
  background:
    radial-gradient(ellipse 60% 200% at 50% 50%, rgba(255,140,0,0.08), transparent 60%),
    #EFEFEF !important;
}
[data-theme="light"] .marquee-section::before { background: linear-gradient(90deg, #EFEFEF, transparent) !important; }
[data-theme="light"] .marquee-section::after  { background: linear-gradient(-90deg, #EFEFEF, transparent) !important; }
[data-theme="light"] .footer {
  background:
    radial-gradient(ellipse 80% 80% at 50% 0%, rgba(255,140,0,0.08), transparent 60%),
    #ECECEC !important;
  color: #333;
}
[data-theme="light"] .footer p,
[data-theme="light"] .footer a { color: #333; }
[data-theme="light"] .footer a:hover { color: var(--orange-dark); }
[data-theme="light"] .cta-banner {
  background:
    radial-gradient(ellipse 80% 120% at 0% 0%, rgba(255,140,0,0.18), transparent 55%),
    radial-gradient(ellipse 80% 120% at 100% 100%, rgba(255,94,26,0.12), transparent 55%),
    #FFFFFF !important;
}
[data-theme="light"] .hero-float-card { background: rgba(255,255,255,0.85) !important; }
[data-theme="light"] .hero-float-card div { color: #111 !important; }

/* ============================================================
   MICRO-INTERACTIONS
   ============================================================ */
.service-card-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  font-weight: 700;
  color: var(--orange);
  font-family: 'Space Grotesk', var(--font-head);
  letter-spacing: 0.02em;
}
.service-card-arrow i { transition: transform .35s var(--v2-ease); }
.service-card:hover .service-card-arrow i { transform: translateX(6px); }

.checklist li i {
  background: var(--v2-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 4px 10px rgba(255,140,0,0.35));
}

/* ============================================================
   REVEAL ANIMATIONS — snappier
   ============================================================ */
.reveal, .reveal-left, .reveal-right {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s var(--v2-ease), transform .7s var(--v2-ease);
}
.reveal-left  { transform: translateX(-32px); }
.reveal-right { transform: translateX(32px); }
.reveal.visible, .reveal-left.visible, .reveal-right.visible {
  opacity: 1;
  transform: none;
}
.reveal-d1 { transition-delay: .08s; }
.reveal-d2 { transition-delay: .16s; }
.reveal-d3 { transition-delay: .24s; }
.reveal-d4 { transition-delay: .32s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .hero { padding-top: 130px; padding-bottom: 90px; }
  .cta-banner { padding: 32px !important; }
}
@media (max-width: 640px) {
  h1 { font-size: clamp(2.2rem, 8vw, 3rem); }
  .hero-stats > div { padding-left: 0; }
  .hero-stats > div + div::before { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .service-card-icon::after,
  .service-card::before,
  .testimonial-card::before,
  .process-step::before,
  .hero-title span,
  h1 .text-orange, h2 .text-orange, h3 .text-orange { animation: none !important; }
}
