/*
Theme Name: Nova Ash
Theme URI: https://www.novaash.co.za
Author: L-A Media
Author URI: https://www.novaash.co.za
Description: Custom one-page theme for Nova Ash — Building Brands. Creating Vibes. Marketing, branding, websites, social media and DJ entertainment.
Version: 1.1.0
Requires at least: 6.0
Requires PHP: 7.4
License: Proprietary
Text Domain: novaash
*/

:root{
  --orange:#FF7A3D;
  --coral:#FF5A5F;
  --pink:#FF3D8E;
  --plum:#44204A;
  --charcoal:#1E1E1E;
  --white:#FFFFFF;
  --soft:#FFF9F5;
  --line:#F3E4DC;
  --sunset:linear-gradient(90deg,#FF7A3D 0%,#FF5A5F 50%,#FF3D8E 100%);
  --sunset-v:linear-gradient(160deg,#FF7A3D 0%,#FF5A5F 45%,#FF3D8E 100%);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;background:var(--white);color:var(--charcoal);line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Sora',sans-serif;line-height:1.2;color:var(--charcoal)}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.grad-text{background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- NAV ---------- */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1180px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:52px;width:auto}
.nav-links{display:flex;gap:32px;align-items:center;list-style:none}
.nav-links a{font-size:.86rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(30,30,30,.75);transition:color .2s}
.nav-links a:hover{color:var(--coral)}
.nav-cta{background:var(--sunset);padding:10px 22px;border-radius:100px;color:#fff !important;box-shadow:0 4px 18px rgba(255,90,95,.3)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--charcoal);border-radius:2px}
.mobile-menu{display:none;background:#fff;border-bottom:1px solid var(--line);padding:10px 24px 20px}
.mobile-menu.open{display:block}
.mobile-menu ul{list-style:none}
.mobile-menu li{margin:12px 0}
.mobile-menu a{font-family:'Sora',sans-serif;font-weight:600;font-size:1rem;color:var(--charcoal)}

/* ---------- HERO ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;position:relative;padding:150px 24px 0;background:
  radial-gradient(ellipse 90% 55% at 50% 118%, rgba(255,122,61,.14) 0%, rgba(255,61,142,.07) 45%, transparent 72%),
  #FFFFFF}
.hero-logo{width:min(760px,92vw);margin:0 auto 4px}
.hero .tagline{font-family:'Great Vibes',cursive;font-size:clamp(2.4rem,6vw,4.2rem);background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:24px}
.hero .services-line{font-size:.82rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:rgba(30,30,30,.55);margin-bottom:26px}
.hero .services-line span{color:var(--orange);padding:0 6px}
.hero p.lead{max-width:640px;margin:0 auto 40px;font-size:1.1rem;color:rgba(30,30,30,.72)}
.hero-ctas{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-bottom:80px}
.btn{display:inline-block;padding:16px 36px;border-radius:100px;font-family:'Sora',sans-serif;font-weight:700;font-size:.95rem;letter-spacing:.02em;transition:transform .2s, box-shadow .2s}
.btn:hover{transform:translateY(-2px)}
.btn-sunset{background:var(--sunset);color:#fff;box-shadow:0 8px 28px rgba(255,90,95,.35)}
.btn-sunset:hover{box-shadow:0 12px 36px rgba(255,90,95,.5)}
.btn-outline{border:2px solid var(--pink);color:var(--pink)}
.btn-outline:hover{background:rgba(255,61,142,.07);box-shadow:0 8px 24px rgba(255,61,142,.18)}

/* sunset horizon divider (signature) */
.horizon{position:relative;width:100%;height:120px;overflow:hidden;margin-top:auto}
.horizon .sun{position:absolute;left:50%;transform:translateX(-50%);bottom:38px;width:130px;height:65px;border-radius:130px 130px 0 0;background:linear-gradient(180deg,#FFC26B,#FF7A3D 55%,#FF5A5F);box-shadow:0 0 50px 10px rgba(255,122,61,.35)}
.horizon .line{position:absolute;left:0;right:0;bottom:38px;height:2px;background:var(--sunset)}
.horizon .ripples{position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:340px;height:38px}
.horizon .ripples i{position:absolute;left:50%;transform:translateX(-50%);height:3px;border-radius:3px;background:linear-gradient(90deg,transparent,#FF7A3D,#FF5A5F,transparent);opacity:.85}
.horizon .ripples i:nth-child(1){bottom:28px;width:220px}
.horizon .ripples i:nth-child(2){bottom:19px;width:150px;opacity:.6}
.horizon .ripples i:nth-child(3){bottom:10px;width:90px;opacity:.45}
.horizon .ripples i:nth-child(4){bottom:3px;width:44px;opacity:.3}

/* ---------- SECTION SHARED ---------- */
.na-section{padding:100px 0}
.eyebrow{font-family:'Great Vibes',cursive;font-size:clamp(2.6rem,4.5vw,3.4rem);background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:6px}
h2.sec-title{font-size:clamp(1.9rem,3.6vw,2.7rem);font-weight:800;margin-bottom:18px;letter-spacing:-.01em}
.sec-intro{max-width:640px;color:rgba(30,30,30,.68);font-size:1.05rem}
.center{text-align:center}
.center .sec-intro{margin:0 auto}

/* ---------- ABOUT ---------- */
.about{background:var(--soft)}
.about-grid{display:grid;grid-template-columns:minmax(0,440px) 1fr;gap:70px;align-items:center}
.about-img{position:relative}
.about-img img{border-radius:24px;box-shadow:0 26px 70px rgba(68,32,74,.22)}
.about-img::after{content:"";position:absolute;inset:-14px;border:1px solid rgba(255,90,95,.35);border-radius:32px;pointer-events:none}
.about-text .hi{font-family:'Great Vibes',cursive;font-size:2.6rem;background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;margin-bottom:8px}
.about-text h2{font-size:clamp(1.8rem,3.2vw,2.5rem);margin-bottom:14px}
.about-text p{color:rgba(30,30,30,.75);margin-bottom:16px}
.daynight{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:26px 0}
.dn-card{border-radius:18px;padding:22px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 26px rgba(68,32,74,.06)}
.dn-card h4{font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px}
.dn-card.day h4{color:var(--orange)}
.dn-card.night h4{color:var(--pink)}
.dn-card p{font-size:.92rem;margin:0;color:rgba(30,30,30,.72)}
.quote-line{font-family:'Sora',sans-serif;font-weight:700;font-size:1.15rem;background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- MARKETING ---------- */
.marketing{background:#fff}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.svc-card{background:#fff;border-radius:20px;padding:34px 30px;box-shadow:0 6px 30px rgba(68,32,74,.08);border:1px solid var(--line);transition:transform .25s, box-shadow .25s;position:relative;overflow:hidden;text-align:left}
.svc-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--sunset)}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(68,32,74,.14)}
.svc-icon{width:52px;height:52px;border-radius:14px;background:var(--sunset-v);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:20px;color:#fff}
.svc-card h3{font-size:1.15rem;margin-bottom:8px;color:var(--plum)}
.svc-card>p{font-size:.92rem;color:rgba(30,30,30,.6);margin-bottom:16px}
.svc-card ul{list-style:none}
.svc-card li{font-size:.9rem;padding:5px 0 5px 26px;position:relative;color:rgba(30,30,30,.78)}
.svc-card li::before{content:"\2714";position:absolute;left:0;color:var(--coral);font-size:.8rem;top:7px}

/* ---------- DJ ---------- */
.dj{background:var(--soft);position:relative;overflow:hidden}
.dj::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 55% at 85% 110%, rgba(255,61,142,.08), transparent 65%);pointer-events:none}
.dj-grid{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;position:relative}
.dj-tags{display:flex;flex-wrap:wrap;gap:12px;margin:30px 0}
.tag{border:1.5px solid rgba(255,61,142,.45);color:var(--plum);border-radius:100px;padding:10px 20px;font-size:.9rem;font-weight:600;background:#fff;transition:all .2s}
.tag:hover{background:rgba(255,61,142,.06);border-color:var(--pink)}
.tag span{margin-right:8px}
.dj-art img{border-radius:24px;box-shadow:0 26px 70px rgba(68,32,74,.25);max-width:440px;margin:0 auto}
.journey-note{border-left:3px solid;border-image:linear-gradient(180deg,#FF7A3D,#FF3D8E) 1;padding:6px 0 6px 20px;color:rgba(30,30,30,.68);font-size:.98rem;margin-top:8px}
.dj-follow{margin-top:16px;font-weight:600}

/* ---------- WHY ---------- */
.why{background:#fff;text-align:center}
.why .big-script{font-family:'Great Vibes',cursive;font-size:clamp(2.6rem,5vw,4rem);background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:24px}
.why p{max-width:620px;margin:0 auto 14px;color:rgba(30,30,30,.72);font-size:1.08rem}
.why strong{color:var(--charcoal)}

/* ---------- FEATURED ---------- */
.featured{background:var(--soft)}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:56px}
.feat-card{border-radius:24px;padding:46px 40px;position:relative;overflow:hidden;border:1px solid var(--line);min-height:280px;display:flex;flex-direction:column;background:#fff;box-shadow:0 10px 36px rgba(68,32,74,.08);text-align:left}
.feat-card::before{content:"";position:absolute;top:0;left:0;right:0;height:5px}
.feat-card.mkt::before{background:linear-gradient(90deg,#FF7A3D,#FF5A5F)}
.feat-card.djj::before{background:linear-gradient(90deg,#FF5A5F,#FF3D8E)}
.feat-card h3{font-size:1.5rem;margin-bottom:14px}
.feat-card p{color:rgba(30,30,30,.68);margin-bottom:10px;font-size:.98rem}
.feat-card .btn{margin-top:auto;align-self:flex-start;padding:13px 28px;font-size:.88rem}
.feat-card ul{list-style:none;margin-bottom:24px}
.feat-card li{padding:4px 0 4px 24px;position:relative;color:rgba(30,30,30,.72);font-size:.95rem}
.feat-card li::before{content:"\2192";position:absolute;left:0;color:var(--pink)}

/* ---------- TESTIMONIALS ---------- */
.testi{background:#fff}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:52px}
.t-card{background:#fff;border-radius:20px;padding:32px;box-shadow:0 6px 30px rgba(68,32,74,.08);border:1px solid var(--line);text-align:left}
.t-card .stars{color:var(--orange);letter-spacing:3px;margin-bottom:14px}
.t-card p{font-size:.95rem;color:rgba(30,30,30,.7);margin-bottom:18px;font-style:italic}
.t-card .who{font-family:'Sora',sans-serif;font-weight:700;font-size:.9rem;color:var(--plum)}
.t-card .role{font-size:.8rem;color:rgba(30,30,30,.45)}

/* ---------- FAQ ---------- */
.faq{background:var(--soft)}
.faq-list{max-width:760px;margin:48px auto 0;text-align:left}
.faq-item{border:1px solid var(--line);border-radius:16px;margin-bottom:14px;overflow:hidden;background:#fff;box-shadow:0 4px 18px rgba(68,32,74,.05)}
.faq-item summary{padding:22px 26px;font-family:'Sora',sans-serif;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.4rem;background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:400;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .a{padding:0 26px 22px;color:rgba(30,30,30,.68);font-size:.96rem}

/* ---------- CTA ---------- */
.cta-final{background:var(--sunset-v);text-align:center;position:relative;overflow:hidden}
.cta-final::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 120%, rgba(68,32,74,.35), transparent 70%)}
.cta-final .container{position:relative}
.cta-final .script-big{font-family:'Great Vibes',cursive;font-size:clamp(2.8rem,6vw,4.6rem);color:#fff;margin-bottom:18px;text-shadow:0 2px 24px rgba(68,32,74,.35)}
.cta-final p{max-width:560px;margin:0 auto 40px;color:rgba(255,255,255,.95);font-size:1.08rem}
.btn-white{background:#fff;color:var(--pink);box-shadow:0 8px 28px rgba(68,32,74,.28)}
.btn-white:hover{box-shadow:0 12px 36px rgba(68,32,74,.4)}
.btn-ghost{border:2px solid rgba(255,255,255,.9);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.14)}

/* ---------- FOOTER ---------- */
.site-footer{background:#fff;padding:70px 0 30px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;margin-bottom:50px}
.foot-logo img{height:60px;width:auto;margin-bottom:14px}
.foot-tag{font-family:'Great Vibes',cursive;font-size:1.5rem;background:var(--sunset);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:10px}
.foot-grid p{font-size:.88rem;color:rgba(30,30,30,.5)}
.foot-grid h4{font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:10px}
.foot-grid li a{font-size:.92rem;color:rgba(30,30,30,.6);transition:color .2s}
.foot-grid li a:hover{color:var(--coral)}
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--plum);transition:all .2s}
.socials a:hover{background:var(--sunset);border-color:transparent;color:#fff;transform:translateY(-2px)}
.foot-bottom{border-top:1px solid var(--line);padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem;color:rgba(30,30,30,.4)}

/* ---------- INNER PAGES ---------- */
.page-content{padding:180px 0 100px}
.page-content h1{font-size:clamp(2rem,4vw,3rem);margin-bottom:24px}
.page-content p{margin-bottom:16px;color:rgba(30,30,30,.75)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .about-grid,.dj-grid,.feat-grid{grid-template-columns:1fr;gap:44px}
  .svc-grid,.testi-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .dj-art{order:-1}
}
@media(max-width:640px){
  .nav-links{display:none}
  .burger{display:flex}
  .na-section{padding:70px 0}
  .svc-grid,.testi-grid,.daynight,.foot-grid{grid-template-columns:1fr}
  .hero-ctas .btn{width:100%;text-align:center}
}
@media(prefers-reduced-motion:reduce){*{transition:none !important;animation:none !important}}
/* ============================================
   NOVA ASH — EFFECTS LAYER v1
   ============================================ */

/* ---------- PAGE LOADER: sun rises, site fades in ---------- */
#na-loader{position:fixed;inset:0;z-index:9999;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;transition:opacity .7s ease, visibility .7s}
#na-loader.done{opacity:0;visibility:hidden}
.ld-logo{width:min(340px,70vw);opacity:0;margin-bottom:30px}
.ld-horizon{position:relative;width:300px;height:90px;overflow:hidden}
.ld-sun{position:absolute;left:50%;transform:translate(-50%,70px);bottom:24px;width:84px;height:42px;border-radius:84px 84px 0 0;background:linear-gradient(180deg,#FFC26B,#FF7A3D 55%,#FF5A5F);box-shadow:0 0 40px 8px rgba(255,122,61,.35)}
.ld-line{position:absolute;left:0;right:0;bottom:24px;height:2px;background:linear-gradient(90deg,transparent,#FF7A3D,#FF5A5F,#FF3D8E,transparent)}

/* ---------- HERO: aurora background (very slow, very soft) ---------- */
.hero{position:relative;overflow:hidden}
.aurora{position:absolute;inset:-20%;z-index:0;pointer-events:none;filter:blur(90px);opacity:.5}
.aurora i{position:absolute;border-radius:50%;mix-blend-mode:multiply}
.aurora i:nth-child(1){width:46vw;height:46vw;left:-8%;top:8%;background:radial-gradient(circle,rgba(255,122,61,.16),transparent 65%);animation:aur1 26s ease-in-out infinite alternate}
.aurora i:nth-child(2){width:40vw;height:40vw;right:-6%;top:22%;background:radial-gradient(circle,rgba(255,61,142,.13),transparent 65%);animation:aur2 32s ease-in-out infinite alternate}
.aurora i:nth-child(3){width:36vw;height:36vw;left:28%;bottom:-12%;background:radial-gradient(circle,rgba(255,90,95,.12),transparent 65%);animation:aur3 38s ease-in-out infinite alternate}
@keyframes aur1{from{transform:translate(0,0) scale(1)}to{transform:translate(6vw,4vh) scale(1.15)}}
@keyframes aur2{from{transform:translate(0,0) scale(1.1)}to{transform:translate(-5vw,6vh) scale(.95)}}
@keyframes aur3{from{transform:translate(0,0) scale(.95)}to{transform:translate(4vw,-5vh) scale(1.12)}}
.hero > *{position:relative;z-index:1}

/* hero intro initial states (JS animates in; no-js/reduced-motion stays visible) */
html.fx .hero-logo{opacity:0}
html.fx .hero .services-line, html.fx .hero p.lead, html.fx .hero .hero-ctas .btn{opacity:0;transform:translateY(22px)}

/* ---------- HERO: water shimmer on the sunset ripples ---------- */
.horizon .ripples i{animation:shimmer 7s ease-in-out infinite}
.horizon .ripples i:nth-child(1){animation-delay:0s}
.horizon .ripples i:nth-child(2){animation-delay:1.4s;animation-duration:8s}
.horizon .ripples i:nth-child(3){animation-delay:2.8s;animation-duration:9s}
.horizon .ripples i:nth-child(4){animation-delay:4.2s;animation-duration:10s}
@keyframes shimmer{
  0%,100%{transform:translateX(-50%) scaleX(1)}
  50%{transform:translateX(-50%) scaleX(1.08)}
  25%{opacity:.95}
  75%{opacity:.55}
}
.horizon .sun{animation:sunGlow 9s ease-in-out infinite}
@keyframes sunGlow{0%,100%{box-shadow:0 0 50px 10px rgba(255,122,61,.35)}50%{box-shadow:0 0 64px 16px rgba(255,122,61,.5)}}

/* ---------- BUTTONS: gradient shift + lift (magnetic handled in JS) ---------- */
.btn{transform:translate(var(--mx,0px),var(--my,0px));will-change:transform}
.btn:hover{transform:translate(var(--mx,0px),calc(var(--my,0px) - 3px))}
.btn-sunset{background:linear-gradient(90deg,#FF7A3D 0%,#FF5A5F 40%,#FF3D8E 80%,#FF7A3D 120%);background-size:220% 100%;background-position:0% 0;transition:background-position 1.4s ease, box-shadow .3s ease, transform .25s ease}
.btn-sunset:hover{background-position:95% 0}
.btn-outline,.btn-ghost,.btn-white{transition:box-shadow .3s ease, background .3s ease, transform .25s ease}

/* ---------- SCROLL REVEALS: generic initial state ---------- */
html.fx .rv{opacity:0;transform:translateY(30px);will-change:transform,opacity}

/* ---------- ABOUT: floating portrait + glow behind ---------- */
.about-img{isolation:isolate}
.img-glow{position:absolute;inset:8%;z-index:-1;border-radius:50%;background:radial-gradient(circle,rgba(255,90,95,.4),rgba(255,61,142,.18) 55%,transparent 75%);filter:blur(46px);transform:scale(1.15)}
.float-slow{animation:floaty 7s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}

/* ---------- MARKETING CARDS: richer hover ---------- */
.svc-card{transition:transform .3s ease, box-shadow .3s ease}
.svc-card .svc-icon{transition:transform .35s ease}
.svc-card:hover .svc-icon{transform:rotate(5deg)}
.svc-card::after{content:"";position:absolute;inset:0;border-radius:20px;pointer-events:none;border:1.5px solid transparent;background:linear-gradient(120deg,rgba(255,122,61,.55),rgba(255,61,142,.55)) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .35s ease}
.svc-card:hover::after{opacity:1}
.svc-card:hover{box-shadow:0 18px 44px rgba(68,32,74,.14), 0 0 30px rgba(255,61,142,.12)}

/* ---------- DJ SECTION: tilt + badge pop ---------- */
.dj-art img{will-change:transform;transition:box-shadow .3s ease}
.tag{transition:transform .25s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;cursor:default}
.tag:hover{transform:scale(1.05);box-shadow:0 6px 22px rgba(255,61,142,.25), 0 0 14px rgba(255,61,142,.18);border-color:var(--pink)}

/* ---------- WHY: gradient word glow ---------- */
.gw{background-image:var(--sunset);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:inherit;-webkit-text-fill-color:currentColor;font-weight:700;transition:none}
.gw.on{-webkit-text-fill-color:transparent;color:transparent;text-shadow:0 0 22px rgba(255,90,95,.25)}
.gw{transition:text-shadow .8s ease}

/* ---------- PORTFOLIO: interactive cards ---------- */
.feat-card{transition:transform .35s ease, box-shadow .35s ease;overflow:hidden}
.feat-card:hover{transform:translateY(-6px);box-shadow:0 22px 54px rgba(68,32,74,.16)}
.feat-card::before{background-size:200% 100% !important;transition:background-position 1.2s ease}
.feat-card:hover::before{background-position:100% 0}
.feat-card .btn .arrow{display:inline-block;margin-left:8px;transition:transform .3s ease}
.feat-card .btn:hover .arrow{transform:translateX(6px)}

/* ---------- TESTIMONIALS: carousel ---------- */
.testi-viewport{overflow:hidden;margin-top:52px}
.testi-grid.carousel{display:flex;gap:24px;transition:transform .7s cubic-bezier(.4,0,.2,1);margin-top:0}
.testi-grid.carousel .t-card{flex:0 0 calc((100% - 48px)/3);transition:transform .6s ease, box-shadow .6s ease}
.t-card.t-active{transform:scale(1.03);box-shadow:0 16px 44px rgba(68,32,74,.16);border-color:rgba(255,90,95,.35)}
.testi-dots{display:flex;gap:10px;justify-content:center;margin-top:28px}
.testi-dots button{width:10px;height:10px;border-radius:50%;border:none;background:#F3D9CC;cursor:pointer;transition:all .3s;padding:0}
.testi-dots button.on{background:var(--coral);transform:scale(1.25)}
@media(max-width:900px){.testi-grid.carousel .t-card{flex:0 0 100%}}

/* ---------- FAQ: buttery accordion ---------- */
.faq-item .a{overflow:hidden}
.faq-item summary::after{transition:transform .35s cubic-bezier(.4,0,.2,1)}

/* ---------- CTA: slow moving light ---------- */
.cta-final::after{content:"";position:absolute;width:70%;height:140%;top:-20%;left:-30%;background:radial-gradient(ellipse at center,rgba(255,255,255,.14),transparent 65%);animation:ctaLight 22s ease-in-out infinite alternate;pointer-events:none}
@keyframes ctaLight{from{transform:translateX(0)}to{transform:translateX(120%)}}

/* ---------- FOOTER: social bounce + email underline ---------- */
.socials a{transition:transform .3s cubic-bezier(.34,1.56,.64,1), background .3s, color .3s, box-shadow .3s}
.socials a:hover{transform:translateY(-4px) rotate(-6deg);box-shadow:0 8px 20px rgba(255,90,95,.35)}
.u-anim{background-image:var(--sunset);background-repeat:no-repeat;background-size:0% 2px;background-position:0 100%;transition:background-size .4s ease;padding-bottom:2px}
.u-anim:hover{background-size:100% 2px}

/* ---------- SECTION DIVIDERS: soft gradient transitions ---------- */
.about, .featured, .faq{background-image:linear-gradient(180deg,#FFFFFF 0px,var(--soft) 140px,var(--soft) calc(100% - 140px),#FFFFFF 100%)}

/* ---------- GLOBAL: mouse glow + custom cursor ---------- */
#mouse-glow{position:fixed;top:0;left:0;width:420px;height:420px;margin:-210px 0 0 -210px;border-radius:50%;background:radial-gradient(circle,rgba(255,122,61,.10),rgba(255,61,142,.05) 45%,transparent 70%);pointer-events:none;z-index:5;will-change:transform}
#cursor-dot{position:fixed;top:0;left:0;width:12px;height:12px;margin:-6px 0 0 -6px;border-radius:50%;background:var(--sunset);pointer-events:none;z-index:10000;will-change:transform;box-shadow:0 0 10px rgba(255,90,95,.6)}
@media(hover:none),(max-width:768px){#mouse-glow,#cursor-dot{display:none}}

/* ---------- REDUCED MOTION ---------- */
@media(prefers-reduced-motion:reduce){
  .aurora, #na-loader, #mouse-glow, #cursor-dot{display:none !important}
  html.fx .rv, html.fx .hero-logo, html.fx .tagline .w, html.fx .hero .services-line, html.fx .hero p.lead, html.fx .hero .hero-ctas .btn{opacity:1 !important;transform:none !important}
  .horizon .ripples i,.horizon .sun,.float-slow,.cta-final::after{animation:none !important}
}
