/*
Theme Name: NetDNA Digital
Theme URI: https://netdnaseo.com
Author: NetDNA Digital
Version: 1.0.0
Description: Custom theme for NetDNA Digital
Requires at least: 6.0
Tested up to: 6.9
Requires PHP: 8.0
License: GPL-2.0-or-later
Text Domain: netdna-digital
*/

/* ═══ Base ═══ */
*, *::before, *::after { box-sizing: border-box; }
body { font-family: 'Inter', system-ui, sans-serif; color: #1f2937; -webkit-font-smoothing: antialiased; }

/* Animations */
.hover-lift { transition: transform 0.3s cubic-bezier(.4,0,.2,1), box-shadow 0.3s cubic-bezier(.4,0,.2,1); }
.hover-lift:hover { transform: translateY(-6px); box-shadow: 0 20px 40px -12px rgba(0,0,0,0.15); }
.fade-up { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* Header */
.header-scrolled { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }

/* Dropdown */
.dropdown-menu { opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.25s cubic-bezier(.4,0,.2,1); pointer-events: none; }
.dropdown-parent:hover .dropdown-menu { opacity: 1; visibility: visible; transform: translateY(0); pointer-events: auto; }

/* Pillar accents */
.pillar-it { border-left: 4px solid #0066cc; }
.pillar-ai { border-left: 4px solid #7c3aed; }
.pillar-seo { border-left: 4px solid #059669; }
.pillar-card-it { border-top: 4px solid #0066cc; }
.pillar-card-ai { border-top: 4px solid #7c3aed; }
.pillar-card-seo { border-top: 4px solid #059669; }

/* Hero pattern */
.hero-pattern {
    background-image: radial-gradient(circle at 25% 25%, rgba(0,102,204,0.05) 0%, transparent 50%),
                      radial-gradient(circle at 75% 75%, rgba(5,150,105,0.05) 0%, transparent 50%);
}
.hero-grid {
    background-size: 40px 40px;
    background-image: linear-gradient(to right, rgba(0,102,204,0.04) 1px, transparent 1px),
                      linear-gradient(to bottom, rgba(0,102,204,0.04) 1px, transparent 1px);
}

/* Gradient text */
.text-gradient-brand {
    background: linear-gradient(135deg, #0066cc 0%, #059669 100%);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Stats counter animation */
.stat-card { position: relative; overflow: hidden; }
.stat-card::after {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, #0066cc, #7c3aed, #059669);
}

/* Service card hover */
.service-card { transition: all 0.3s ease; border: 1px solid #e5e7eb; }
.service-card:hover { border-color: transparent; box-shadow: 0 10px 30px -5px rgba(0,0,0,0.1); }

/* Section divider */
.section-divider { height: 1px; background: linear-gradient(90deg, transparent, #e5e7eb 20%, #e5e7eb 80%, transparent); }

/* CTA glow */
.cta-glow { box-shadow: 0 0 30px rgba(0,102,204,0.3); }
.cta-glow:hover { box-shadow: 0 0 40px rgba(0,102,204,0.5); }

/* Testimonial quote */
.quote-mark { font-size: 4rem; line-height: 1; color: #e5e7eb; font-family: Georgia, serif; }

/* Mobile menu animation */
.mobile-menu-enter { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; }
.mobile-menu-enter.open { max-height: 500px; }

/* Smooth scroll */
html { scroll-behavior: smooth; }

/* Line clamp */
.line-clamp-3 { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.line-clamp-4 { display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }

/* ═══ Homepage ═══ */
.font-display { font-family: 'Outfit', sans-serif; }

/* Mesh gradient orbs */
.orb { position:absolute; border-radius:50%; filter:blur(120px); will-change:transform; }
.orb-b { width:600px; height:600px; background:#0066cc; opacity:.30; top:-10%; left:-8%; animation:d1 25s ease-in-out infinite; }
.orb-p { width:450px; height:450px; background:#7c3aed; opacity:.25; top:35%; right:-8%; animation:d2 22s ease-in-out infinite; }
.orb-g { width:350px; height:350px; background:#059669; opacity:.22; bottom:-5%; left:30%; animation:d3 20s ease-in-out infinite; }
@keyframes d1{0%,100%{transform:translate(0,0)}33%{transform:translate(40px,-30px)}66%{transform:translate(-25px,40px)}}
@keyframes d2{0%,100%{transform:translate(0,0)}33%{transform:translate(-50px,25px)}66%{transform:translate(30px,-35px)}}
@keyframes d3{0%,100%{transform:translate(0,0)}33%{transform:translate(25px,30px)}66%{transform:translate(-40px,-20px)}}

/* Fine grid */
.grid-fine{background-size:32px 32px;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px)}

/* Gradient text */
.text-glow{background:linear-gradient(135deg,#60a5fa 0%,#c084fc 40%,#34d399 80%,#60a5fa 100%);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:glow 8s ease infinite}
@keyframes glow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* Glass card */
.glass{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}

/* Float */
@keyframes fa{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes fb{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float-a{animation:fa 7s ease-in-out infinite}
.float-b{animation:fb 5.5s ease-in-out infinite 1.5s}

/* Bento hover glow */
.bento{position:relative;border-radius:1.25rem;transition:transform .4s cubic-bezier(.4,0,.2,1),box-shadow .4s cubic-bezier(.4,0,.2,1)}
.bento::after{content:'';position:absolute;inset:0;border-radius:inherit;border:2px solid transparent;transition:border-color .4s;pointer-events:none}
.bento:hover{transform:translateY(-6px);box-shadow:0 24px 48px -12px rgba(0,0,0,.12)}
.bento:hover::after{border-color:var(--glow,#0066cc33)}

/* Scroll reveal */
.sr{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.sr.vis{opacity:1;transform:none}
.sr-d1{transition-delay:.1s}.sr-d2{transition-delay:.2s}.sr-d3{transition-delay:.3s}

/* Counter tabular */
.counter{font-variant-numeric:tabular-nums}

/* Grain overlay */
.grain::before{content:'';position:absolute;inset:0;opacity:.03;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");pointer-events:none}

/* Review quote accent */
.quote-accent{position:relative}
.quote-accent::before{content:'\201C';position:absolute;top:-8px;left:-4px;font-size:5rem;line-height:1;font-family:Georgia,serif;color:rgba(0,102,204,.08)}

/* Pillar accent lines */
.accent-it{border-top:3px solid #3b82f6}
.accent-ai{border-top:3px solid #8b5cf6}
.accent-seo{border-top:3px solid #10b981}

/* Scrollbar hide */
.scrollbar-hide::-webkit-scrollbar{display:none}
.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}

/* Review featured card */
.review-featured{background:linear-gradient(135deg,#f8fafc,#eff6ff)}
