/* ============================================================
   NORDIC VD LIMITED — nordic-growth.net
   Design system: white + purple, modern retention-marketing studio
   Font: Plus Jakarta Sans
   ============================================================ */

:root{
  --violet:#7C3AED;
  --violet-light:#A78BFA;
  --violet-dark:#5B21B6;
  --violet-50:#F5F3FF;
  --violet-100:#EDE9FE;
  --violet-200:#DDD6FE;
  --grad:linear-gradient(135deg,#7C3AED 0%,#9333EA 50%,#A855F7 100%);
  --ink:#1B1633;
  --ink-700:#3A3556;
  --ink-600:#56506F;
  --ink-500:#736D8C;
  --ink-400:#9A93B0;
  --ink-300:#C4BED6;
  --ink-200:#E6E2F0;
  --ink-100:#F2EFF8;
  --ink-50:#FAF9FD;
  --white:#FFFFFF;
  --radius:20px;
  --radius-lg:28px;
  --shadow-sm:0 2px 10px rgba(27,22,51,0.05);
  --shadow:0 14px 40px rgba(124,58,237,0.10);
  --shadow-lg:0 30px 70px rgba(124,58,237,0.18);
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;}

.container{max-width:1180px;margin:0 auto;padding:0 24px;}
.container-sm{max-width:760px;margin:0 auto;padding:0 24px;}
.section{padding:104px 0;}
.section-tight{padding:72px 0;}

/* ---------- Typography helpers ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:0.72rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--violet);background:var(--violet-50);
  padding:8px 16px;border-radius:100px;border:1px solid var(--violet-100);
}
.eyebrow i{width:14px;height:14px;}
.h-display{
  font-size:clamp(2.4rem,5.2vw,4.1rem);
  font-weight:800;line-height:1.05;letter-spacing:-0.03em;
}
.h-section{
  font-size:clamp(1.9rem,3.6vw,2.8rem);
  font-weight:800;line-height:1.12;letter-spacing:-0.02em;
}
.lede{font-size:1.1rem;color:var(--ink-600);line-height:1.75;}
.text-grad{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.muted{color:var(--ink-500);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:inherit;font-size:0.92rem;font-weight:700;cursor:pointer;
  padding:14px 26px;border-radius:100px;border:1.5px solid transparent;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s,color .25s;
  white-space:nowrap;
}
.btn i{width:17px;height:17px;}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 10px 26px rgba(124,58,237,0.32);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(124,58,237,0.42);}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--ink-200);}
.btn-ghost:hover{border-color:var(--violet);color:var(--violet);transform:translateY(-2px);}
.btn-white{background:#fff;color:var(--violet);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(0,0,0,0.18);}
.btn-lg{padding:17px 34px;font-size:1rem;}

/* ---------- Header ---------- */
#site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,0.82);
  backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--ink-100);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:74px;max-width:1180px;margin:0 auto;padding:0 24px;
}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:1.12rem;letter-spacing:-0.02em;}
.brand img{height:30px;width:auto;}
.nav{display:flex;align-items:center;gap:6px;}
.nav-link{
  font-size:0.92rem;font-weight:600;color:var(--ink-600);
  padding:9px 16px;border-radius:100px;transition:color .2s,background .2s;
}
.nav-link:hover{color:var(--violet);background:var(--violet-50);}
.nav-link.active{color:var(--violet);background:var(--violet-50);}
.header-cta{display:flex;align-items:center;gap:10px;}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;}
.hamburger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-overlay{position:fixed;inset:0;background:rgba(27,22,51,0.45);opacity:0;visibility:hidden;transition:.3s;z-index:55;}
.mobile-overlay.open{opacity:1;visibility:visible;}
.mobile-menu{
  position:fixed;top:0;right:0;height:100vh;width:min(82vw,330px);
  background:#fff;z-index:58;padding:96px 28px 28px;
  transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.8,.2,1);
  box-shadow:-20px 0 60px rgba(27,22,51,0.12);display:flex;flex-direction:column;gap:6px;
}
.mobile-menu.open{transform:translateX(0);}
.mobile-link{font-size:1.05rem;font-weight:700;color:var(--ink);padding:13px 14px;border-radius:14px;transition:.2s;}
.mobile-link:hover{background:var(--violet-50);color:var(--violet);}
.mobile-contact{margin-top:18px;padding-top:18px;border-top:1px solid var(--ink-100);display:flex;flex-direction:column;gap:10px;}
.mobile-contact a{font-size:0.9rem;color:var(--ink-500);font-weight:600;}

/* ---------- Hero ---------- */
.hero{position:relative;padding:110px 0 90px;overflow:hidden;}
.hero-blob{
  position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;pointer-events:none;z-index:0;
}
.blob-1{width:520px;height:520px;background:radial-gradient(circle,#C4B5FD,transparent 70%);top:-160px;right:-120px;}
.blob-2{width:420px;height:420px;background:radial-gradient(circle,#DDD6FE,transparent 70%);bottom:-160px;left:-130px;}
.hero-inner{position:relative;z-index:1;text-align:center;max-width:840px;margin:0 auto;}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:34px;}
.hero-trust{display:flex;gap:28px;justify-content:center;flex-wrap:wrap;margin-top:40px;color:var(--ink-500);font-size:0.86rem;font-weight:600;}
.hero-trust span{display:inline-flex;align-items:center;gap:7px;}
.hero-trust i{width:16px;height:16px;color:var(--violet);}

/* ---------- Logos / stat band ---------- */
.band{background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:50px 40px;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.stat-num{font-size:clamp(2rem,4vw,2.8rem);font-weight:800;letter-spacing:-0.02em;background:linear-gradient(135deg,#C4B5FD,#fff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.stat-label{font-size:0.85rem;color:rgba(255,255,255,0.6);margin-top:6px;font-weight:600;}

/* ---------- Cards / features ---------- */
.card{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--radius);
  padding:32px;transition:transform .3s,box-shadow .3s,border-color .3s;height:100%;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--violet-200);}
.card-icon{
  width:54px;height:54px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:var(--violet-50);color:var(--violet);margin-bottom:20px;
}
.card-icon i{width:25px;height:25px;}
.card h3{font-size:1.18rem;font-weight:800;letter-spacing:-0.01em;margin-bottom:9px;}
.card p{color:var(--ink-600);font-size:0.94rem;line-height:1.7;}

.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}

/* feature row (alternating) */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.feature-visual{
  border-radius:var(--radius-lg);background:var(--violet-50);border:1px solid var(--violet-100);
  min-height:340px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.feature-visual .big-icon{width:120px;height:120px;color:var(--violet);opacity:.9;}
.feature-list{display:flex;flex-direction:column;gap:14px;margin-top:22px;}
.feature-list li{display:flex;gap:12px;align-items:flex-start;font-size:0.96rem;color:var(--ink-700);}
.feature-list i{width:20px;height:20px;color:var(--violet);flex-shrink:0;margin-top:3px;}

/* ---------- Pricing ---------- */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;align-items:stretch;}
.price-card{
  background:#fff;border:1px solid var(--ink-100);border-radius:var(--radius);
  padding:30px;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s;
}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--violet-200);}
.price-card.featured{background:var(--ink);color:#fff;border-color:var(--ink);position:relative;box-shadow:var(--shadow-lg);}
.price-tag{font-size:0.72rem;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-400);margin-bottom:14px;}
.price-card.featured .price-tag{color:var(--violet-light);}
.price-amount{font-size:2.4rem;font-weight:800;letter-spacing:-0.02em;line-height:1;}
.price-amount small{font-size:0.9rem;font-weight:500;color:var(--ink-400);}
.price-card.featured .price-amount small{color:rgba(255,255,255,0.55);}
.price-sub{font-size:0.85rem;color:var(--ink-500);margin:8px 0 22px;}
.price-card.featured .price-sub{color:rgba(255,255,255,0.6);}
.price-hr{height:1px;background:var(--ink-100);margin-bottom:20px;}
.price-card.featured .price-hr{background:rgba(255,255,255,0.16);}
.price-feats{display:flex;flex-direction:column;gap:12px;flex:1;margin-bottom:26px;}
.price-feats li{display:flex;gap:9px;align-items:center;font-size:0.88rem;color:var(--ink-700);}
.price-card.featured .price-feats li{color:rgba(255,255,255,0.9);}
.price-feats i{width:16px;height:16px;color:var(--violet);flex-shrink:0;}
.price-card.featured .price-feats i{color:var(--violet-light);}
.badge-pop{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--grad);color:#fff;font-size:0.64rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;
  padding:6px 16px;border-radius:100px;white-space:nowrap;box-shadow:0 6px 16px rgba(124,58,237,0.4);
}

/* ---------- Testimonials ---------- */
.quote{background:#fff;border:1px solid var(--ink-100);border-radius:var(--radius);padding:30px;height:100%;}
.quote .stars{color:#A855F7;letter-spacing:2px;margin-bottom:14px;}
.quote p{color:var(--ink-700);font-size:0.96rem;line-height:1.7;margin-bottom:20px;}
.quote .who{display:flex;align-items:center;gap:12px;}
.quote .who img{width:44px;height:44px;border-radius:50%;object-fit:cover;}
.quote .who b{font-size:0.9rem;font-weight:800;display:block;}
.quote .who span{font-size:0.8rem;color:var(--ink-400);}

/* ---------- FAQ ---------- */
.faq{border:1px solid var(--ink-100);border-radius:16px;margin-bottom:14px;overflow:hidden;background:#fff;}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:22px 26px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;}
.faq-q span{font-size:0.98rem;font-weight:700;color:var(--ink);}
.faq-q i{width:19px;height:19px;color:var(--violet);flex-shrink:0;transition:transform .3s;}
.faq.open .faq-q i{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.faq-a p{padding:0 26px 22px;color:var(--ink-600);font-size:0.92rem;line-height:1.75;}

/* ---------- CTA banner ---------- */
.cta-banner{
  position:relative;overflow:hidden;border-radius:var(--radius-lg);
  background:var(--grad);color:#fff;padding:72px 40px;text-align:center;
}
.cta-banner::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;
  background:rgba(255,255,255,0.12);top:-160px;right:-100px;}
.cta-banner > *{position:relative;z-index:1;}

/* ---------- Soft sections ---------- */
.bg-soft{background:var(--violet-50);}
.bg-ink{background:var(--ink);color:#fff;}

/* ---------- Forms ---------- */
.field{margin-bottom:18px;}
.field label{display:block;font-size:0.8rem;font-weight:700;color:var(--ink-700);margin-bottom:7px;}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:0.95rem;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--ink-200);border-radius:12px;background:#fff;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--violet);box-shadow:0 0 0 4px var(--violet-100);
}
.field textarea{min-height:130px;resize:vertical;}
.form-success{
  display:none;margin-top:18px;padding:16px 18px;border-radius:14px;
  background:var(--violet-50);border:1px solid var(--violet-100);
}
.form-success.show{display:block;}

/* contact info list */
.cinfo{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--ink-100);}
.cinfo .ic{width:46px;height:46px;border-radius:13px;background:var(--violet-50);color:var(--violet);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.cinfo .ic i{width:21px;height:21px;}
.cinfo .lbl{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-400);margin-bottom:3px;}
.cinfo .val{font-size:0.98rem;font-weight:600;color:var(--ink);}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:#fff;padding:72px 0 34px;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:44px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.08);}
.footer-brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:1.1rem;margin-bottom:16px;}
.footer-brand img{height:30px;}
.footer p.desc{color:rgba(255,255,255,0.5);font-size:0.88rem;line-height:1.7;max-width:300px;}
.footer-head{font-size:0.72rem;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:18px;}
.footer-link{display:block;color:rgba(255,255,255,0.62);font-size:0.9rem;padding:6px 0;transition:color .2s;}
.footer-link:hover{color:#fff;}
.footer-addr{color:rgba(255,255,255,0.45);font-size:0.84rem;line-height:1.8;margin-top:12px;}
.footer-bottom{padding-top:26px;}
.footer-bottom p{color:rgba(255,255,255,0.4);font-size:0.82rem;}

/* ---------- Legal pages ---------- */
.legal{padding:80px 0 90px;}
.legal h1{font-size:clamp(2rem,4vw,2.8rem);font-weight:800;letter-spacing:-0.02em;margin-bottom:10px;}
.legal .updated{color:var(--ink-400);font-size:0.9rem;margin-bottom:40px;}
.legal h2{font-size:1.25rem;font-weight:800;margin:34px 0 12px;letter-spacing:-0.01em;}
.legal p{color:var(--ink-600);line-height:1.8;margin-bottom:14px;}
.legal ul.bul{list-style:disc;padding-left:22px;margin-bottom:14px;}
.legal ul.bul li{color:var(--ink-600);line-height:1.8;margin-bottom:8px;}
.legal a{color:var(--violet);font-weight:600;}

/* ---------- Reveal animations ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1);}
.reveal.in{opacity:1;transform:none;}
.delay-1{transition-delay:.08s;}
.delay-2{transition-delay:.16s;}
.delay-3{transition-delay:.24s;}
.delay-4{transition-delay:.32s;}

.page-fade{animation:pageFade .6s ease;}
@keyframes pageFade{from{opacity:0;}to{opacity:1;}}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .feature-row{grid-template-columns:1fr;gap:32px;}
  .feature-row.flip .feature-visual{order:-1;}
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:34px;}
  .price-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:760px){
  .nav,.header-cta .btn{display:none;}
  .hamburger{display:flex;}
  .section{padding:72px 0;}
  .grid-3,.grid-2{grid-template-columns:1fr;}
  .price-grid{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr;gap:30px;}
  .band{padding:38px 26px;}
  .cta-banner{padding:54px 26px;}
}
