/* ─────────────────────────────────── TOKENS */
:root {
  --blue:       #0066FF;
  --blue-light: #3385FF;
  --blue-pale:  #EBF2FF;
  --blue-dark:  #0047CC;
  --ink:        #080C14;
  --ink-soft:   #1A2035;
  --muted:      #6B7A99;
  --border:     #E4EAF4;
  --bg:         #FAFBFE;
  --white:      #FFFFFF;
  --radius:     14px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}

/* Global font safety — prevent any stretching */
h1,h2,h3,h4,h5,h6,p,span,a,button,input,select,textarea,label,li,div{
  font-stretch:normal;
  ;
}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  background:var(--bg);
  color:var(--ink);
  overflow-x:hidden;
  cursor:none;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

/* ─────────────────────────────────── CURSOR */
#cur,#cur-ring{
  position:fixed;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);border-radius:50%;
  transition:opacity .3s;
}
#cur{width:8px;height:8px;background:var(--blue);}
#cur-ring{
  width:32px;height:32px;
  border:1.5px solid var(--blue);
  transition:width .25s,height .25s;
  opacity:.5;
}
body.hovering #cur-ring{width:48px;height:48px;}

/* ─────────────────────────────────── NAV */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0 60px;
  display:flex;align-items:center;justify-content:space-between;
  height:72px;
  transition:background .4s,border-color .4s,box-shadow .4s;
}
header.stuck{
  background:rgba(250,251,254,.96);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  box-shadow:0 2px 20px rgba(0,102,255,.05);
}
.logo{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.35rem;font-weight:800;
  color:var(--ink);text-decoration:none;
  letter-spacing:-.01em;
  display:flex;align-items:center;gap:8px;
}
.logo-dot{
  width:8px;height:8px;background:var(--blue);
  border-radius:50%;display:inline-block;
}
nav ul{display:flex;list-style:none;gap:36px;align-items:center;}
nav a{
  font-size:.8rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;
  transition:color .2s;
}
nav a:hover{color:var(--blue);}
.nav-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue);color:#fff !important;
  padding:10px 22px;border-radius:100px;
  font-size:.75rem !important;letter-spacing:.08em !important;
  transition:background .2s,transform .2s !important;
}
.nav-btn:hover{background:var(--blue-dark) !important;transform:translateY(-1px);}

/* ─────────────────────────────────── HERO */
.hero{
  min-height:100vh;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:140px 80px 100px;
}

/* grid lines bg */
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(0,102,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,102,255,.05) 1px, transparent 1px);
  background-size:60px 60px;
}
/* radial glow */
.hero::after{
  content:'';position:absolute;
  top:-10%;right:-5%;
  width:700px;height:700px;
  background:radial-gradient(circle, rgba(0,102,255,.12) 0%, transparent 65%);
  pointer-events:none;
}

.hero-inner{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}

.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue-pale);color:var(--blue);
  border:1px solid rgba(0,102,255,.2);
  border-radius:100px;padding:6px 16px;
  font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:28px;
  animation:fadeUp .7s ease both;
}
.hero-tag-dot{width:6px;height:6px;background:var(--blue);border-radius:50;animation:pulse 2s infinite;}

@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.7);}}

.hero h1{
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(2.4rem,4.5vw,4.4rem);
  font-weight:700;line-height:1.08;letter-spacing:-.01em;
  margin-bottom:24px;
  animation:fadeUp .7s .1s ease both;
  font-optical-sizing:auto;
}
.hero h1 .accent{color:var(--blue);}
.hero h1 .line2{display:block;color:var(--muted);font-weight:400;font-style:italic;font-family:'Plus Jakarta Sans',sans-serif;font-size:.42em;margin-top:12px;letter-spacing:.01em;line-height:1.5;}

.hero-desc{
  font-size:1.05rem;line-height:1.75;color:var(--muted);
  max-width:440px;margin-bottom:44px;
  animation:fadeUp .7s .2s ease both;
}

.hero-actions{
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  animation:fadeUp .7s .3s ease both;
}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--blue);color:#fff;
  padding:15px 34px;border-radius:100px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.88rem;font-weight:600;letter-spacing:.02em;
  text-decoration:none;
  box-shadow:0 8px 30px rgba(0,102,255,.35);
  transition:background .2s,transform .2s,box-shadow .2s;
  white-space:nowrap;
}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 14px 40px rgba(0,102,255,.4);}
.btn-primary svg{width:16px;height:16px;}

.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--ink);border:1.5px solid var(--border);
  padding:14px 28px;border-radius:100px;
  font-size:.82rem;font-weight:500;letter-spacing:.02em;
  text-decoration:none;
  transition:border-color .2s,color .2s,background .2s;
}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-pale);}

.hero-trust{
  display:flex;align-items:center;gap:16px;margin-top:40px;
  animation:fadeUp .7s .4s ease both;
}
.hero-trust-avatars{display:flex;}
.hero-trust-avatars span{
  width:34px;height:34px;border-radius:50%;
  border:2px solid #fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:600;color:#fff;
  margin-left:-10px;
}
.hero-trust-avatars span:first-child{margin-left:0;}
.av1{background:linear-gradient(135deg,#667eea,#764ba2);}
.av2{background:linear-gradient(135deg,#f093fb,#f5576c);}
.av3{background:linear-gradient(135deg,#4facfe,#00f2fe);}
.av4{background:linear-gradient(135deg,#43e97b,#38f9d7);}
.hero-trust-text{font-size:.82rem;color:var(--muted);}
.hero-trust-text strong{color:var(--ink);font-weight:600;}

/* hero right - floating card stack */
.hero-visual{position:relative;height:500px;}

.floating-card{
  position:absolute;background:#fff;
  border:1px solid var(--border);border-radius:20px;
  box-shadow:0 20px 60px rgba(0,0,0,.07);
  padding:24px;
}

.card-main{
  width:340px;top:30px;right:0;
  animation:float 5s ease-in-out infinite,fadeUp .8s .3s ease both;
}
.card-stat{
  width:200px;bottom:60px;left:0;
  animation:float 4s 1s ease-in-out infinite,fadeUp .8s .5s ease both;
}
.card-tag-small{
  width:170px;top:0;left:40px;
  animation:float 6s .5s ease-in-out infinite,fadeUp .8s .7s ease both;
}

@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}

.card-main-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;}
.card-main-top h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:.95rem;font-weight:700;}
.card-badge{
  background:var(--blue-pale);color:var(--blue);
  font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:100px;
}
.bar-wrap{display:flex;flex-direction:column;gap:12px;}
.bar-item label{display:flex;justify-content:space-between;font-size:.72rem;color:var(--muted);margin-bottom:5px;}
.bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.bar-fill{height:100%;border-radius:3px;background:var(--blue);}
.bar-fill.green{background:#22C55E;}
.bar-fill.orange{background:#F59E0B;}

.card-stat h3{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.9rem;font-weight:800;color:var(--blue);letter-spacing:-.02em;line-height:1;}
.card-stat p{font-size:.72rem;color:var(--muted);margin-top:3px;}
.card-stat-icon{
  width:40px;height:40px;background:var(--blue-pale);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;
}
.card-stat-icon svg{width:20px;height:20px;stroke:var(--blue);}

.card-tag-small{
  display:flex;align-items:center;gap:10px;
  padding:14px 18px;
}
.card-tag-small .dot{
  width:10px;height:10px;background:#22C55E;
  border-radius:50%;flex-shrink:0;
  box-shadow:0 0 0 3px rgba(34,197,94,.2);
}
.card-tag-small span{font-size:.78rem;font-weight:500;color:var(--ink);}

/* ─────────────────────────────────── MARQUEE */
.marquee-section{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--white);padding:18px 0;overflow:hidden;
}
.marquee-track{display:flex;white-space:nowrap;animation:marquee 28s linear infinite;}
.marquee-track span{
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);padding:0 36px;
}
.marquee-track .sep{color:var(--blue);font-size:1rem;padding:0 10px;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ─────────────────────────────────── SHARED SECTION STYLES */
section{padding:120px 80px;}
.section-inner{max-width:1280px;margin:0 auto;}

.section-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--blue);font-weight:500;margin-bottom:16px;
}
.section-eyebrow::before{content:'';width:24px;height:1.5px;background:var(--blue);}

h2.section-title{
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(1.8rem,3vw,2.7rem);
  font-weight:700;line-height:1.18;letter-spacing:-.005em;
  margin-bottom:16px;
  font-optical-sizing:auto;
}
h2.section-title .blue{color:var(--blue);}
.section-sub{
  font-size:1rem;color:var(--muted);line-height:1.75;
  max-width:520px;margin-bottom:64px;
}

/* fade-up */
.fu{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.fu.vis{opacity:1;transform:translateY(0);}
.fu.d1{transition-delay:.1s;}
.fu.d2{transition-delay:.2s;}
.fu.d3{transition-delay:.3s;}
.fu.d4{transition-delay:.4s;}
.fu.d5{transition-delay:.5s;}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}

/* ─────────────────────────────────── SERVICES */
.services-section{background:var(--ink-soft);}
.services-section .section-eyebrow{color:rgba(51,133,255,.9);}
.services-section .section-eyebrow::before{background:rgba(51,133,255,.9);}
.services-section .section-title{color:#fff;}
.services-section .section-sub{color:rgba(255,255,255,.45);}

.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.06);
  border-radius:20px;overflow:hidden;
}

.svc-card{
  background:var(--ink-soft);
  padding:44px 40px;
  position:relative;overflow:hidden;
  transition:background .3s;
  cursor:default;
}
.svc-card:hover{background:rgba(0,102,255,.08);}
.svc-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:2px;background:var(--blue);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s;
}
.svc-card:hover::after{transform:scaleX(1);}

.svc-icon{
  width:52px;height:52px;background:rgba(0,102,255,.12);
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;
}
.svc-icon svg{width:24px;height:24px;stroke:var(--blue-light);}

.svc-card h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;font-weight:700;
  color:#fff;margin-bottom:14px;
}
.svc-card p{font-size:.87rem;line-height:1.7;color:rgba(255,255,255,.45);}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;}
.svc-tag{
  font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
  border:1px solid rgba(255,255,255,.1);
  border-radius:100px;padding:4px 12px;
}
.svc-card:hover .svc-tag{border-color:rgba(0,102,255,.3);color:rgba(51,133,255,.8);}

/* ─────────────────────────────────── ABOUT */
.about-section{background:var(--bg);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}

.about-visual{position:relative;}
.about-img-box{
  background:linear-gradient(135deg,var(--blue-pale) 0%,rgba(0,102,255,.08) 100%);
  border-radius:24px;
  height:480px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  border:1px solid rgba(0,102,255,.12);
}
.about-img-box::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(0,102,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,102,255,.06) 1px,transparent 1px);
  background-size:30px 30px;
}
.about-big-num{
  font-family:'Fraunces',Georgia,serif;font-size:8rem;font-weight:700;font-style:italic;
  color:rgba(0,102,255,.07);line-height:1;user-select:none;position:relative;z-index:1;
  letter-spacing:0;font-optical-sizing:auto;
}
.about-chip{
  position:absolute;bottom:30px;left:30px;
  background:#fff;border:1px solid var(--border);
  border-radius:14px;padding:16px 20px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  display:flex;align-items:center;gap:14px;
}
.about-chip-icon{
  width:40px;height:40px;background:var(--blue-pale);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.about-chip-icon svg{width:20px;height:20px;stroke:var(--blue);}
.about-chip-text strong{display:block;font-size:.88rem;font-weight:600;}
.about-chip-text span{font-size:.75rem;color:var(--muted);}

.about-content .section-sub{margin-bottom:40px;}
.feature-list{display:flex;flex-direction:column;gap:20px;}
.feature-item{
  display:flex;align-items:flex-start;gap:16px;
  padding:20px;border-radius:14px;border:1px solid var(--border);
  background:#fff;transition:border-color .2s,box-shadow .2s;
}
.feature-item:hover{border-color:var(--blue);box-shadow:0 6px 24px rgba(0,102,255,.08);}
.feature-icon{
  width:42px;height:42px;background:var(--blue-pale);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.feature-icon svg{width:20px;height:20px;stroke:var(--blue);}
.feature-text h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:.92rem;font-weight:700;margin-bottom:4px;}
.feature-text p{font-size:.82rem;color:var(--muted);line-height:1.6;}

/* ─────────────────────────────────── PORTFOLIO */
.portfolio-section{background:var(--white);}
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:20px;
}
.port-card{
  border-radius:20px;overflow:hidden;
  border:1px solid var(--border);
  position:relative;
  transition:transform .3s,box-shadow .3s;
  cursor:default;
}
.port-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.1);}
.port-card.wide{grid-column:span 2;}

.port-visual{
  height:220px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.port-card.wide .port-visual{height:260px;}

.pv1{background:linear-gradient(135deg,#0066FF 0%,#0033AA 100%);}
.pv2{background:linear-gradient(135deg,#1A2035 0%,#0D47A1 100%);}
.pv3{background:linear-gradient(135deg,#111827 0%,#1e3a5f 100%);}
.pv4{background:linear-gradient(135deg,#0a1628 0%,#0066FF 100%);}
.pv5{background:linear-gradient(135deg,#003380 0%,#0066FF 100%);}

.port-mockup{
  width:75%;background:rgba(255,255,255,.1);border-radius:10px;
  padding:16px;border:1px solid rgba(255,255,255,.15);
  backdrop-filter:blur(8px);position:relative;z-index:1;
}
.port-mockup-bar{
  display:flex;align-items:center;gap:6px;margin-bottom:12px;
}
.port-mockup-bar span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);}
.port-mockup-bar span:first-child{background:rgba(255,100,100,.6);}
.port-mockup-bar span:nth-child(2){background:rgba(255,200,0,.6);}
.port-mockup-bar span:nth-child(3){background:rgba(0,200,100,.6);}
.port-mockup-content{
  display:flex;flex-direction:column;gap:8px;
}
.port-mock-line{
  height:8px;border-radius:4px;background:rgba(255,255,255,.15);
}
.port-mock-line.w60{width:60%;}
.port-mock-line.w40{width:40%;}
.port-mock-line.w80{width:80%;}
.port-mock-line.w30{width:30%;}
.port-mock-line.accent{background:rgba(51,133,255,.5);}

.port-label{
  font-family:'Fraunces',Georgia,serif;font-size:3.5rem;font-weight:700;font-style:italic;
  color:rgba(255,255,255,.07);position:absolute;
  bottom:-10px;right:14px;user-select:none;line-height:1;letter-spacing:0;
}

.port-info{padding:22px 24px;background:#fff;}
.port-info-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.port-info-top h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:.95rem;font-weight:700;}
.port-cat{
  font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue);background:var(--blue-pale);
  padding:4px 10px;border-radius:100px;
}
.port-info p{font-size:.82rem;color:var(--muted);}

/* ─────────────────────────────────── WHY US */
.why-section{background:var(--bg);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}

.why-left h2{margin-bottom:20px;}
.why-left .section-sub{max-width:420px;}

.stats-block{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:40px;
}
.stat-card{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:28px 24px;text-align:center;
  transition:border-color .2s,box-shadow .2s;
}
.stat-card:hover{border-color:var(--blue);box-shadow:0 8px 30px rgba(0,102,255,.1);}
.stat-card .num{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:2.2rem;font-weight:800;
  color:var(--blue);display:block;
}
.stat-card .lbl{font-size:.75rem;color:var(--muted);margin-top:4px;letter-spacing:.05em;}

.why-right{
  display:flex;flex-direction:column;gap:16px;
}
.why-item{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:28px 30px;display:flex;align-items:flex-start;gap:20px;
  transition:border-color .2s,box-shadow .2s;
}
.why-item:hover{border-color:var(--blue);box-shadow:0 8px 30px rgba(0,102,255,.08);}
.why-num{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.5rem;font-weight:800;
  color:rgba(0,102,255,.15);min-width:36px;line-height:1;
}
.why-item-text h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:6px;}
.why-item-text p{font-size:.83rem;color:var(--muted);line-height:1.65;}

/* ─────────────────────────────────── TESTIMONIALS */
.testimonials-section{background:var(--ink-soft);}
.testimonials-section .section-title{color:#fff;}
.testimonials-section .section-eyebrow{color:rgba(51,133,255,.9);}
.testimonials-section .section-eyebrow::before{background:rgba(51,133,255,.9);}
.testimonials-section .section-sub{color:rgba(255,255,255,.4);margin-bottom:0;}

.testi-header{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:50px;
}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}

.testi-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:20px;padding:36px;
  position:relative;overflow:hidden;
  transition:background .3s,border-color .3s;
}
.testi-card:hover{background:rgba(0,102,255,.07);border-color:rgba(0,102,255,.25);}

.testi-stars{display:flex;gap:4px;margin-bottom:18px;}
.testi-stars span{color:var(--blue);font-size:.9rem;}
.testi-text{
  font-family:'Plus Jakarta Sans',sans-serif;font-style:italic;
  font-size:.92rem;line-height:1.75;color:rgba(255,255,255,.65);
  margin-bottom:24px;
}
.testi-author{display:flex;align-items:center;gap:14px;}
.testi-avatar{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.82rem;font-weight:700;color:#fff;flex-shrink:0;
}
.tav1{background:linear-gradient(135deg,#0066FF,#0033AA);}
.tav2{background:linear-gradient(135deg,#7C3AED,#4F46E5);}
.tav3{background:linear-gradient(135deg,#059669,#0D9488);}
.testi-author-text strong{display:block;font-size:.85rem;font-weight:600;color:#fff;}
.testi-author-text span{font-size:.75rem;color:rgba(255,255,255,.4);}

.testi-quote{
  position:absolute;top:24px;right:24px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:5rem;font-weight:800;
  color:rgba(0,102,255,.08);line-height:1;user-select:none;
}

/* ─────────────────────────────────── PRICING */
.pricing-section{background:var(--bg);}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}

.price-card{
  background:#fff;border:1px solid var(--border);border-radius:20px;
  padding:40px 36px;position:relative;
  transition:transform .3s,box-shadow .3s;
  cursor:default;
}
.price-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.08);}
.price-card.featured{
  background:var(--blue);border-color:var(--blue);
  transform:translateY(-8px);
  box-shadow:0 24px 60px rgba(0,102,255,.35);
}
.price-card.featured:hover{transform:translateY(-12px);}

.price-badge{
  position:absolute;top:20px;right:20px;
  background:rgba(255,255,255,.2);color:#fff;
  font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 12px;border-radius:100px;
}

.price-name{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.75rem;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px;
}
.price-card.featured .price-name{color:rgba(255,255,255,.7);}

.price-amount{
  display:flex;align-items:baseline;gap:4px;margin-bottom:6px;
}
.price-currency{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.3rem;font-weight:700;color:var(--ink);}
.price-card.featured .price-currency,.price-card.featured .price-num,.price-card.featured .price-per{color:#fff;}
.price-num{font-family:'Plus Jakarta Sans',sans-serif;font-size:3rem;font-weight:800;color:var(--ink);line-height:1;}
.price-per{font-size:.82rem;color:var(--muted);align-self:flex-end;padding-bottom:4px;}

.price-desc{font-size:.82rem;color:var(--muted);margin-bottom:28px;line-height:1.5;}
.price-card.featured .price-desc{color:rgba(255,255,255,.65);}

.price-divider{height:1px;background:var(--border);margin-bottom:24px;}
.price-card.featured .price-divider{background:rgba(255,255,255,.15);}

.price-features{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:32px;}
.price-features li{
  display:flex;align-items:center;gap:10px;
  font-size:.84rem;color:var(--ink);
}
.price-card.featured .price-features li{color:rgba(255,255,255,.9);}
.price-features li svg{width:16px;height:16px;stroke:var(--blue);flex-shrink:0;}
.price-card.featured .price-features li svg{stroke:rgba(255,255,255,.9);}

.price-btn{
  display:block;text-align:center;
  padding:14px 20px;border-radius:100px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.06em;
  text-decoration:none;
  border:2px solid var(--blue);color:var(--blue);
  transition:background .2s,color .2s;
}
.price-btn:hover{background:var(--blue);color:#fff;}
.price-card.featured .price-btn{background:#fff;color:var(--blue);border-color:#fff;}
.price-card.featured .price-btn:hover{background:rgba(255,255,255,.85);}

/* ─────────────────────────────────── FAQ */
.faq-section{background:var(--white);}
.faq-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start;}
.faq-left .section-sub{margin-bottom:0;}

.faq-list{display:flex;flex-direction:column;gap:0;}
.faq-item{border-bottom:1px solid var(--border);}
.faq-btn{
  width:100%;background:none;border:none;
  text-align:left;padding:22px 0;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.95rem;font-weight:600;
  color:var(--ink);cursor:pointer;
  transition:color .2s;
}
.faq-btn:hover{color:var(--blue);}
.faq-icon{
  width:26px;height:26px;background:var(--border);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .2s,transform .3s;
  font-size:.75rem;
}
.faq-item.open .faq-icon{background:var(--blue);color:#fff;transform:rotate(45deg);}
.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height .4s ease,padding .3s;
  font-size:.88rem;color:var(--muted);line-height:1.75;
}
.faq-item.open .faq-answer{max-height:300px;padding-bottom:20px;}

/* ─────────────────────────────────── LEAD MAGNET */
.lead-magnet-section{
  background:var(--blue);
  padding:100px 80px;position:relative;overflow:hidden;
}
.lead-magnet-section::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:50px 50px;
}
.lead-magnet-section::after{
  content:'';position:absolute;
  bottom:-100px;right:-100px;
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(0,0,0,.15) 0%,transparent 65%);
}
.lm-inner{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
  position:relative;z-index:1;
}
.lm-left h2{
  font-family:'Fraunces',Georgia,serif;
  font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:700;
  color:#fff;line-height:1.18;letter-spacing:0;margin-bottom:16px;
  font-optical-sizing:auto;
}
.lm-left p{
  font-size:1rem;line-height:1.75;
  color:rgba(255,255,255,.7);margin-bottom:28px;
}
.lm-perks{list-style:none;display:flex;flex-direction:column;gap:12px;}
.lm-perks li{
  display:flex;align-items:center;gap:10px;
  font-size:.88rem;color:rgba(255,255,255,.85);
}
.lm-perks li svg{width:18px;height:18px;stroke:rgba(255,255,255,.9);flex-shrink:0;}

.lm-form-box{
  background:#fff;border-radius:24px;
  padding:44px 40px;
  box-shadow:0 30px 70px rgba(0,0,0,.2);
}
.lm-form-box h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.3rem;font-weight:800;
  margin-bottom:6px;
}
.lm-form-box > p{
  font-size:.85rem;color:var(--muted);margin-bottom:28px;line-height:1.5;
}

.form-group{margin-bottom:18px;}
label.flabel{
  display:block;font-size:.7rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:7px;
}
input[type=text],input[type=email],input[type=tel],select,textarea{
  width:100%;padding:13px 16px;
  border:1.5px solid var(--border);border-radius:12px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.9rem;
  color:var(--ink);background:var(--bg);
  outline:none;transition:border-color .2s,box-shadow .2s;appearance:none;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(0,102,255,.12);
  background:#fff;
}
textarea{resize:vertical;min-height:80px;}
select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7A99' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;
  padding-right:38px;cursor:pointer;
}

.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

.submit-btn{
  width:100%;padding:15px 20px;
  background:var(--blue);color:#fff;border:none;border-radius:100px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:.88rem;font-weight:700;letter-spacing:.02em;
  cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s;
  display:flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 8px 28px rgba(0,102,255,.3);
}
.submit-btn:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 14px 36px rgba(0,102,255,.4);}
.submit-btn svg{width:16px;height:16px;}

.form-note{font-size:.72rem;color:var(--muted);text-align:center;margin-top:12px;line-height:1.5;}

.form-success{
  display:none;text-align:center;padding:40px 20px;
}
.success-icon{
  width:64px;height:64px;background:var(--blue-pale);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto 20px;
}
.success-icon svg{width:30px;height:30px;stroke:var(--blue);}
.form-success h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:1.3rem;font-weight:800;margin-bottom:8px;}
.form-success p{font-size:.88rem;color:var(--muted);line-height:1.65;}

/* ─────────────────────────────────── CONTACT */
.contact-section{background:var(--bg);}
.contact-grid-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start;}

.contact-info-cards{display:flex;flex-direction:column;gap:16px;margin-bottom:36px;}
.cinfo{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:20px 22px;display:flex;align-items:center;gap:16px;
  transition:border-color .2s;
}
.cinfo:hover{border-color:var(--blue);}
.cinfo-icon{
  width:44px;height:44px;background:var(--blue-pale);border-radius:12px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cinfo-icon svg{width:20px;height:20px;stroke:var(--blue);}
.cinfo-text strong{display:block;font-size:.82rem;font-weight:600;margin-bottom:2px;}
.cinfo-text a,.cinfo-text span{font-size:.82rem;color:var(--muted);text-decoration:none;}
.cinfo-text a:hover{color:var(--blue);}

.contact-form-box{
  background:#fff;border:1px solid var(--border);border-radius:24px;
  padding:44px 40px;
  box-shadow:0 10px 40px rgba(0,0,0,.05);
}
.contact-form-box h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.4rem;font-weight:800;margin-bottom:24px;
}

/* ─────────────────────────────────── FOOTER */
footer{
  background:var(--ink);color:#fff;
  padding:70px 80px 36px;
}
.footer-top{
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:50px;
  padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-logo{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.4rem;font-weight:800;
  color:#fff;display:flex;align-items:center;gap:8px;margin-bottom:14px;
}
.footer-logo .dot{width:8px;height:8px;background:var(--blue);border-radius:50%;}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.4);line-height:1.7;max-width:250px;margin-bottom:24px;}
.footer-social{display:flex;gap:10px;}
.fsoc{
  width:36px;height:36px;border:1px solid rgba(255,255,255,.12);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.5);font-size:.75rem;font-weight:600;
  text-decoration:none;transition:border-color .2s,color .2s;
}
.fsoc:hover{border-color:var(--blue);color:var(--blue);}

.footer-col h4{
  font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:18px;font-weight:500;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col ul li a{
  font-size:.85rem;color:rgba(255,255,255,.5);text-decoration:none;
  transition:color .2s;
}
.footer-col ul li a:hover{color:var(--blue-light);}

.footer-bottom{
  padding-top:28px;display:flex;justify-content:space-between;align-items:center;
  font-size:.75rem;color:rgba(255,255,255,.25);
}
.footer-bottom a{color:rgba(255,255,255,.35);text-decoration:none;}
.footer-bottom a:hover{color:var(--blue-light);}

/* ─────────────────────────────────── RESPONSIVE */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .pricing-grid{grid-template-columns:1fr;}
  .price-card.featured{transform:none;}
}
@media(max-width:960px){
  header{padding:0 30px;}
  nav ul li:not(:last-child){display:none;}
  section{padding:80px 30px;}
  .hero{padding:120px 30px 80px;}
  .hero-inner{grid-template-columns:1fr;}
  .hero-visual{display:none;}
  .about-grid,.why-grid,.faq-layout,.contact-grid-layout{grid-template-columns:1fr;}
  .lm-inner{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr;}
  .port-card.wide{grid-column:span 1;}
  .services-grid{grid-template-columns:1fr;}
}
@media(max-width:640px){
  .footer-top{grid-template-columns:1fr;}
  .form-row-2{grid-template-columns:1fr;}
  .stats-block{grid-template-columns:1fr 1fr;}
  .lm-form-box{padding:30px 24px;}
  .contact-form-box{padding:30px 24px;}
}

#chat-icon{
position:fixed;
bottom:20px;
right:20px;
width:60px;
height:60px;
background:#007bff;
color:#fff;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
font-size:26px;
cursor:pointer;
box-shadow:0 4px 10px rgba(0,0,0,0.2);
z-index:9999;
}

#chatbox{
position:fixed;
bottom:90px;
right:20px;
width:320px;
height:420px;
background:#fff;
border-radius:10px;
box-shadow:0 5px 20px rgba(0,0,0,0.2);
display:none;
flex-direction:column;
overflow:hidden;
z-index:9999;
}

#chat-header{
background:#007bff;
color:#fff;
padding:10px;
font-weight:bold;
display:flex;
justify-content:space-between;
}

#chat-messages{
flex:1;
padding:10px;
overflow-y:auto;
font-size:14px;
}

#chat-input-area{
display:flex;
border-top:1px solid #eee;
}

#chat-input{
flex:1;
border:none;
padding:10px;
}

#chat-send{
background:#007bff;
color:#fff;
border:none;
padding:10px 15px;
cursor:pointer;
}