/* Spirea Concept Final Brand Theme
   Inspired by uploaded logo:
   Blue + Yellow + Pink/Red + Orange dots with dark charcoal text.
   Fast, fully responsive, no external framework.
*/

:root{
  --brand-blue:#1268f3;
  --brand-blue-dark:#0a55cc;
  --brand-yellow:#ffc400;
  --brand-orange:#ff9f1c;
  --brand-pink:#f83362;
  --brand-red:#ef315a;

  --charcoal:#26282d;
  --heading:#26282d;
  --text:#424a57;
  --muted:#6d7888;

  --white:#ffffff;
  --offwhite:#fffdf8;
  --light:#f8fafc;

  --blue-soft:#eef6ff;
  --yellow-soft:#fff8dc;
  --pink-soft:#fff1f5;
  --orange-soft:#fff4e5;

  --border:#e8edf3;
  --shadow:0 18px 50px rgba(38,40,45,.10);
  --shadow-sm:0 8px 28px rgba(38,40,45,.07);
  --radius:24px;
  --max:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  background:var(--white);
  color:var(--text);
  line-height:1.65;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{width:min(var(--max), calc(100% - 34px));margin:auto}
.section{padding:88px 0}
.bg-light{
  background:
    radial-gradient(circle at 0% 0%, rgba(18,104,243,.055), transparent 30%),
    radial-gradient(circle at 100% 5%, rgba(255,196,0,.13), transparent 28%),
    #fbfcff;
}
.center{text-align:center}
.center .section-text{margin-left:auto;margin-right:auto}

/* Brand color dots pattern */
.brand-dots{
  display:inline-flex;
  gap:5px;
  align-items:center;
}
.brand-dots span{
  width:10px;height:10px;border-radius:50%;display:block;
}
.brand-dots span:nth-child(1){background:var(--brand-pink)}
.brand-dots span:nth-child(2){background:var(--brand-yellow)}
.brand-dots span:nth-child(3){background:var(--brand-blue)}
.brand-dots span:nth-child(4){background:var(--brand-orange)}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:11px;
  padding:9px 15px;
  border-radius:999px;
  background:#fff;
  color:var(--charcoal);
  border:1px solid var(--border);
  box-shadow:0 8px 22px rgba(38,40,45,.05);
  font-size:13px;
  font-weight:850;
}
.eyebrow::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--brand-pink);
  box-shadow:
    13px 0 0 var(--brand-yellow),
    26px 0 0 var(--brand-blue);
  margin-right:27px;
}

.section-title{
  margin-top:16px;
  color:var(--heading);
  font-size:clamp(30px,4.5vw,54px);
  line-height:1.12;
  letter-spacing:-1.45px;
  font-weight:900;
}
.page-title{
  color:var(--heading);
  font-size:clamp(38px,5.6vw,70px);
  line-height:1.04;
  letter-spacing:-2px;
  font-weight:950;
}
.section-text{
  margin-top:18px;
  color:var(--muted);
  font-size:17px;
  max-width:740px;
}
.gradient-text{
  background:linear-gradient(90deg,var(--brand-blue),var(--brand-pink),var(--brand-orange));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:0;
  cursor:pointer;
  padding:15px 23px;
  border-radius:16px;
  font-size:15px;
  font-weight:850;
  transition:.22s ease;
  white-space:nowrap;
  min-height:52px;
}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg,var(--brand-blue),var(--brand-blue-dark));
  box-shadow:0 16px 35px rgba(18,104,243,.22);
}
.btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 20px 45px rgba(18,104,243,.28);
}
.btn-primary::after{
  content:"";
  width:7px;height:7px;border-radius:50%;
  background:var(--brand-yellow);
  box-shadow:9px 0 0 var(--brand-pink);
}
.btn-outline{
  color:var(--heading);
  background:#fff;
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
}
.btn-outline:hover{
  transform:translateY(-3px);
  border-color:#bfd9ff;
  color:var(--brand-blue);
}
.btn-soft{
  background:linear-gradient(90deg,var(--blue-soft),#fff);
  color:var(--brand-blue);
  border:1px solid #dbeafe;
}
.btn-soft:hover{transform:translateY(-3px);background:#edf5ff}

.grid{display:grid;gap:24px}
.card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.card-hover{transition:.22s ease}
.card-hover:hover{
  transform:translateY(-7px);
  box-shadow:var(--shadow);
  border-color:#bdd8ff;
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:999;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(232,237,243,.95);
}
.nav{
  height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.logo{
  display:flex;
  align-items:center;
  min-width:172px;
}
.logo img{
  height:52px;
  width:auto;
  object-fit:contain;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:25px;
  color:#4b5563;
  font-size:14px;
  font-weight:780;
}
.nav-links a{
  position:relative;
  padding:28px 0;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:18px;
  height:4px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--brand-blue) 0 35%,var(--brand-yellow) 35% 60%,var(--brand-pink) 60% 100%);
  transform:scaleX(0);
  transition:.22s ease;
}
.nav-links a.active,
.nav-links a:hover{color:var(--charcoal)}
.nav-links a.active::after,
.nav-links a:hover::after{transform:scaleX(1)}
.nav-actions{display:flex;align-items:center;gap:12px}
.menu-btn{
  display:none;
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  font-size:26px;
  cursor:pointer;
  color:var(--heading);
  line-height:1;
}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  padding:96px 0 70px;
  background:
    radial-gradient(circle at 7% 8%, rgba(18,104,243,.14), transparent 26%),
    radial-gradient(circle at 88% 12%, rgba(255,196,0,.22), transparent 25%),
    radial-gradient(circle at 50% 105%, rgba(248,51,98,.10), transparent 32%),
    linear-gradient(180deg,#fff 0%,#fffdf8 100%);
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    radial-gradient(circle, rgba(18,104,243,.10) 1.5px, transparent 1.5px);
  background-size:28px 28px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 82%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.04fr .96fr;
  align-items:center;
  gap:44px;
  position:relative;
  z-index:1;
}
.hero h1{
  margin-top:18px;
  color:var(--heading);
  font-size:clamp(42px,6vw,76px);
  line-height:1.02;
  letter-spacing:-2.4px;
  font-weight:950;
}
.hero p{
  margin-top:23px;
  color:var(--muted);
  font-size:18px;
  max-width:690px;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:33px;
}
.hero-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:36px;
  max-width:650px;
}
.stat{
  background:#fff;
  border:1px solid var(--border);
  border-radius:20px;
  padding:18px;
  box-shadow:var(--shadow-sm);
  position:relative;
  overflow:hidden;
}
.stat::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:6px;
  height:100%;
  background:var(--brand-blue);
}
.stat:nth-child(2)::before{background:var(--brand-yellow)}
.stat:nth-child(3)::before{background:var(--brand-pink)}
.stat strong{
  display:block;
  color:var(--heading);
  font-size:26px;
  font-weight:950;
  line-height:1;
}
.stat span{
  display:block;
  margin-top:7px;
  color:var(--muted);
  font-size:13px;
  font-weight:750;
}

/* Page hero */
.page-hero{
  padding:82px 0;
  background:
    radial-gradient(circle at 8% 5%,rgba(18,104,243,.13),transparent 28%),
    radial-gradient(circle at 88% 0%,rgba(255,196,0,.23),transparent 24%),
    radial-gradient(circle at 55% 100%,rgba(248,51,98,.09),transparent 28%),
    #fff;
  border-bottom:1px solid var(--border);
}
.breadcrumb{
  display:flex;
  gap:8px;
  align-items:center;
  color:var(--muted);
  font-weight:750;
  font-size:14px;
  margin-bottom:18px;
  flex-wrap:wrap;
}
.breadcrumb a{color:var(--brand-blue)}

/* Hero visual */
.visual{min-height:560px;position:relative}
.dashboard-card{
  position:absolute;
  right:0;
  top:30px;
  width:440px;
  overflow:hidden;
  border-radius:32px;
  background:#fff;
  border:1px solid var(--border);
  box-shadow:0 26px 70px rgba(38,40,45,.16);
}
.dash-top{
  padding:18px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.dot-row{display:flex;gap:7px}
.dot{width:11px;height:11px;border-radius:50%;background:#cbd5e1}
.dot:nth-child(1){background:var(--brand-pink)}
.dot:nth-child(2){background:var(--brand-yellow)}
.dot:nth-child(3){background:var(--brand-blue)}
.dash-body{padding:22px}
.chart-box{
  height:190px;
  border-radius:24px;
  background:
    radial-gradient(circle at 12% 18%,rgba(255,196,0,.95),transparent 18%),
    radial-gradient(circle at 88% 20%,rgba(248,51,98,.8),transparent 20%),
    linear-gradient(135deg,var(--brand-blue),#3b8cff);
  padding:22px;
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
  overflow:hidden;
}
.chart-box::after{
  content:"";
  position:absolute;
  left:24px;
  right:24px;
  bottom:29px;
  height:3px;
  background:rgba(255,255,255,.42);
  border-radius:999px;
}
.chart-box strong{
  font-size:34px;
  font-weight:950;
  position:relative;
}
.chart-box span{position:relative}
.mini-grid{
  margin-top:18px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.mini-card{
  padding:18px;
  border:1px solid var(--border);
  border-radius:18px;
  background:#f8fafc;
}
.mini-card:nth-child(1){background:var(--blue-soft)}
.mini-card:nth-child(2){background:var(--yellow-soft)}
.mini-card small{color:var(--muted);font-weight:750}
.mini-card strong{
  display:block;
  margin-top:5px;
  color:var(--heading);
  font-size:22px;
  font-weight:950;
}
.floating{
  position:absolute;
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  padding:18px;
  box-shadow:0 22px 55px rgba(38,40,45,.13);
}
.float-a{left:0;top:95px;width:215px}
.float-b{left:34px;bottom:68px;width:260px}
.float-c{right:44px;bottom:18px;width:210px}
.floating b{display:block;color:var(--heading);font-size:15px}
.floating small{color:var(--muted);font-weight:650}
.progress{
  height:9px;
  background:#e2e8f0;
  overflow:hidden;
  border-radius:999px;
  margin-top:13px;
}
.progress span{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--brand-blue),var(--brand-yellow),var(--brand-pink));
}

/* Strip */
.strip{
  padding:24px 0;
  background:#fff;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.strip-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  color:#667085;
  font-size:14px;
  font-weight:900;
  letter-spacing:.3px;
}
.strip-row span::before{
  content:"";
  display:inline-block;
  width:8px;height:8px;border-radius:50%;
  margin-right:8px;
  background:var(--brand-blue);
}
.strip-row span:nth-child(2n)::before{background:var(--brand-yellow)}
.strip-row span:nth-child(3n)::before{background:var(--brand-pink)}
.strip-row span:nth-child(4n)::before{background:var(--brand-orange)}

/* Services */
.services-grid{
  margin-top:38px;
  grid-template-columns:repeat(3,1fr);
}
.service-card{
  padding:28px;
  position:relative;
  overflow:hidden;
}
.service-card::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:5px;
  background:var(--brand-blue);
}
.service-card:nth-child(2)::before,
.service-card:nth-child(6)::before{background:var(--brand-yellow)}
.service-card:nth-child(3)::before,
.service-card:nth-child(5)::before{background:var(--brand-pink)}
.service-card:nth-child(4)::before{background:var(--brand-orange)}
.icon{
  width:58px;
  height:58px;
  border-radius:20px;
  display:grid;
  place-items:center;
  margin-bottom:20px;
  font-size:25px;
  background:var(--blue-soft);
  color:var(--brand-blue);
  border:1px solid #dbeafe;
}
.service-card:nth-child(2n) .icon{
  background:var(--yellow-soft);
  color:#b77900;
}
.service-card:nth-child(3n) .icon{
  background:var(--pink-soft);
  color:var(--brand-pink);
}
.service-card h3,
.process-card h3,
.portfolio-content h3,
.price-card h3,
.team-card h3,
.feature-card h3{
  color:var(--heading);
  font-weight:900;
  line-height:1.3;
}
.service-card h3{font-size:21px}
.service-card p{color:var(--muted);margin-top:12px}
.clean-list{
  list-style:none;
  margin-top:18px;
  display:grid;
  gap:9px;
}
.clean-list li{
  color:#475569;
  font-size:14px;
  font-weight:650;
}
.clean-list li::before{
  content:"✓";
  color:var(--green);
  font-weight:950;
  margin-right:9px;
}

/* About */
.about-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:42px;
  align-items:center;
}
.mock-image{position:relative;min-height:500px}
.mock-main{
  position:absolute;
  inset:0 60px 75px 0;
  border-radius:32px;
  background:
    radial-gradient(circle at 18% 20%,rgba(255,196,0,.95),transparent 21%),
    radial-gradient(circle at 82% 16%,rgba(248,51,98,.82),transparent 22%),
    radial-gradient(circle at 78% 82%,rgba(255,159,28,.80),transparent 24%),
    linear-gradient(135deg,var(--brand-blue),#45a3ff);
  box-shadow:var(--shadow);
  border:8px solid #fff;
  overflow:hidden;
}
.mock-main::before{
  content:"";
  position:absolute;
  inset:35px;
  border:2px dashed rgba(255,255,255,.46);
  border-radius:24px;
}
.mock-main::after{
  content:"Image Placeholder";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  color:#fff;
  font-weight:900;
  font-size:22px;
  text-align:center;
}
.mock-small{
  position:absolute;
  right:0;
  bottom:0;
  width:58%;
  height:235px;
  border-radius:30px;
  background:linear-gradient(135deg,var(--brand-orange),var(--brand-pink));
  box-shadow:var(--shadow);
  border:8px solid #fff;
}
.about-list{
  display:grid;
  gap:15px;
  margin-top:28px;
}
.about-item{
  display:flex;
  gap:15px;
  padding:18px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  box-shadow:0 8px 22px rgba(38,40,45,.05);
}
.check{
  width:30px;
  height:30px;
  min-width:30px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#dcfce7;
  color:#15803d;
  font-weight:950;
}
.about-item strong{color:var(--heading);font-weight:900}
.about-item p{color:var(--muted);margin-top:4px;font-size:14px}

/* Process */
.process-grid{
  margin-top:38px;
  grid-template-columns:repeat(4,1fr);
  counter-reset:step;
}
.process-card{
  padding:26px;
  position:relative;
  overflow:hidden;
}
.process-card::after{
  counter-increment:step;
  content:"0" counter(step);
  position:absolute;
  top:10px;
  right:18px;
  color:#eef5ff;
  font-size:54px;
  font-weight:950;
  z-index:0;
}
.process-card:nth-child(2)::after{color:#fff6d7}
.process-card:nth-child(3)::after{color:#fff0f5}
.process-card:nth-child(4)::after{color:#fff2df}
.process-card>*{position:relative;z-index:1}
.process-card h3{font-size:20px;margin-top:18px}
.process-card p{color:var(--muted);margin-top:10px;font-size:14px}

/* Portfolio */
.portfolio-grid{
  margin-top:38px;
  grid-template-columns:repeat(3,1fr);
}
.portfolio-card{overflow:hidden}
.portfolio-img{
  height:255px;
  background:
    radial-gradient(circle at 18% 24%,rgba(255,196,0,.9),transparent 19%),
    linear-gradient(135deg,var(--brand-blue),#46a3ff);
  position:relative;
  overflow:hidden;
}
.portfolio-img.alt{
  background:
    radial-gradient(circle at 80% 20%,rgba(18,104,243,.85),transparent 20%),
    linear-gradient(135deg,var(--brand-yellow),var(--brand-orange));
}
.portfolio-img.alt2{
  background:
    radial-gradient(circle at 20% 22%,rgba(255,196,0,.9),transparent 19%),
    linear-gradient(135deg,var(--brand-pink),var(--charcoal));
}
.portfolio-img::after{
  content:"Replace Image";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  color:#fff;
  font-weight:900;
  border:2px dashed rgba(255,255,255,.50);
  border-radius:18px;
  padding:30px 38px;
  white-space:nowrap;
}
.portfolio-content{padding:24px}
.portfolio-content h3{font-size:20px}
.portfolio-content p{color:var(--muted);margin-top:9px}
.tags{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:16px;
}
.tag{
  padding:7px 11px;
  border-radius:999px;
  background:var(--blue-soft);
  color:var(--brand-blue);
  font-size:12px;
  font-weight:850;
}
.tag:nth-child(2n){background:var(--yellow-soft);color:#a16207}
.tag:nth-child(3n){background:var(--pink-soft);color:var(--brand-pink)}

/* Pricing */
.pricing-grid{
  margin-top:38px;
  grid-template-columns:repeat(3,1fr);
}
.price-card{
  padding:30px;
  position:relative;
  overflow:hidden;
}
.price-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:5px;
  background:var(--brand-blue);
}
.price-card:nth-child(1)::before{background:var(--brand-yellow)}
.price-card:nth-child(3)::before{background:var(--brand-pink)}
.price-card.popular{
  border:2px solid var(--brand-blue);
  box-shadow:0 22px 60px rgba(18,104,243,.15);
  transform:scale(1.03);
}
.popular-label{
  position:absolute;
  top:20px;
  right:20px;
  color:#fff;
  background:linear-gradient(135deg,var(--brand-blue),var(--brand-pink));
  font-size:12px;
  font-weight:950;
  border-radius:999px;
  padding:7px 11px;
}
.price-card h3{font-size:24px}
.price-card p{color:var(--muted);margin-top:10px}
.price{
  margin-top:18px;
  color:var(--heading);
  font-size:42px;
  line-height:1;
  font-weight:950;
  letter-spacing:-1.5px;
}
.price span{
  font-size:14px;
  color:var(--muted);
  font-weight:750;
}
.features{
  list-style:none;
  margin:26px 0;
  display:grid;
  gap:12px;
}
.features li{
  color:#475569;
  font-weight:650;
}
.features li::before{
  content:"✓";
  color:var(--green);
  margin-right:9px;
  font-weight:950;
}

/* Testimonials / Team */
.testimonial-grid,
.team-grid,
.feature-grid{
  margin-top:38px;
  grid-template-columns:repeat(3,1fr);
}
.testimonial,
.team-card,
.feature-card{padding:27px}
.stars{
  color:var(--brand-orange);
  letter-spacing:2px;
  font-weight:950;
}
.testimonial p{
  margin-top:16px;
  color:#475569;
}
.client{
  display:flex;
  gap:13px;
  align-items:center;
  margin-top:23px;
}
.client-avatar,
.team-avatar{
  width:48px;
  height:48px;
  border-radius:50%;
  background:
    radial-gradient(circle at 25% 25%,var(--brand-yellow),transparent 34%),
    linear-gradient(135deg,var(--brand-blue),var(--brand-pink));
}
.client strong,
.team-card strong{
  display:block;
  color:var(--heading);
  font-weight:900;
}
.client small,
.team-card small{
  color:var(--muted);
  font-weight:650;
}
.team-avatar{
  width:78px;
  height:78px;
  margin-bottom:16px;
}

/* FAQ */
.faq-list{
  display:grid;
  gap:14px;
  margin-top:38px;
}
.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 22px rgba(38,40,45,.05);
}
.faq-question{
  width:100%;
  border:0;
  background:#fff;
  display:flex;
  justify-content:space-between;
  gap:15px;
  text-align:left;
  padding:20px 22px;
  color:var(--heading);
  font-size:16px;
  font-weight:900;
  cursor:pointer;
}
.faq-question span{color:var(--brand-blue)}
.faq-answer{
  display:none;
  color:var(--muted);
  padding:0 22px 20px;
}
.faq-item.active .faq-answer{display:block}

/* Contact */
.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:28px;
  align-items:start;
}
.contact-info,
.contact-form{padding:30px}
.contact-list{
  display:grid;
  gap:16px;
  margin-top:28px;
}
.contact-row{
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.contact-icon{
  width:43px;
  height:43px;
  min-width:43px;
  display:grid;
  place-items:center;
  border-radius:15px;
  background:var(--blue-soft);
  color:var(--brand-blue);
  font-size:20px;
}
.contact-row:nth-child(2) .contact-icon{background:var(--yellow-soft);color:#a16207}
.contact-row:nth-child(3) .contact-icon{background:var(--pink-soft);color:var(--brand-pink)}
.contact-row:nth-child(4) .contact-icon{background:var(--orange-soft);color:#c2410c}
.contact-row strong{
  color:var(--heading);
  font-weight:900;
}
.contact-row p{
  color:var(--muted);
  margin-top:3px;
}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.field{
  display:grid;
  gap:8px;
}
label{
  color:var(--heading);
  font-weight:850;
  font-size:14px;
}
input,
select,
textarea{
  width:100%;
  padding:15px 16px;
  border:1px solid var(--border);
  border-radius:15px;
  background:#fff;
  color:var(--heading);
  outline:0;
  transition:.2s ease;
}
input:focus,
select:focus,
textarea:focus{
  border-color:var(--brand-blue);
  box-shadow:0 0 0 4px rgba(18,104,243,.12);
}
textarea{
  min-height:145px;
  resize:vertical;
}
.full{grid-column:1/-1}

/* CTA */
.cta-box{
  padding:56px;
  border-radius:34px;
  background:
    radial-gradient(circle at 14% 18%,rgba(255,196,0,.92),transparent 18%),
    radial-gradient(circle at 86% 18%,rgba(248,51,98,.72),transparent 20%),
    linear-gradient(135deg,var(--brand-blue),#3287ff);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:26px;
  box-shadow:0 26px 70px rgba(18,104,243,.22);
}
.cta-box h2{
  font-size:clamp(28px,4vw,46px);
  line-height:1.1;
  font-weight:950;
  letter-spacing:-1.3px;
}
.cta-box p{
  color:#f8fbff;
  margin-top:13px;
  max-width:640px;
}
.cta-box .btn{
  background:#fff;
  color:var(--brand-blue);
}

/* Content pages */
.content-card{padding:34px}
.content-card h2{
  color:var(--heading);
  font-size:28px;
  margin-top:26px;
}
.content-card h2:first-child{margin-top:0}
.content-card p,
.content-card li{
  color:#475569;
  margin-top:12px;
}
.content-card ul{
  margin-left:20px;
  margin-top:12px;
}

/* Footer */
footer{
  padding:60px 0 28px;
  background:var(--charcoal);
  color:#d4dae3;
  position:relative;
  overflow:hidden;
}
footer::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:6px;
  background:linear-gradient(90deg,var(--brand-blue),var(--brand-yellow),var(--brand-pink),var(--brand-orange));
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr .8fr .8fr .9fr;
  gap:28px;
  position:relative;
}
.footer-logo img{
  height:58px;
  width:auto;
  background:#fff;
  border-radius:12px;
  padding:7px;
}
.footer-text{
  margin-top:17px;
  color:#aab3c2;
  max-width:400px;
}
.footer-title{
  color:#fff;
  font-weight:950;
  margin-bottom:16px;
}
.footer-links{
  display:grid;
  gap:10px;
  color:#aab3c2;
  font-size:14px;
}
.footer-links a:hover{color:#fff}
.socials{
  display:flex;
  gap:10px;
  margin-top:20px;
}
.socials a{
  width:39px;
  height:39px;
  display:grid;
  place-items:center;
  border-radius:13px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:950;
}
.socials a:nth-child(1){background:var(--brand-pink)}
.socials a:nth-child(2){background:var(--brand-blue)}
.socials a:nth-child(3){background:var(--brand-yellow);color:var(--charcoal)}
.socials a:nth-child(4){background:var(--brand-orange)}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:22px;
  margin-top:40px;
  color:#aab3c2;
  font-size:14px;
}

/* Floating WhatsApp */
.whatsapp-float{
  position:fixed;
  right:20px;
  bottom:20px;
  width:62px;
  height:62px;
  border-radius:50%;
  display:grid;
  place-items:center;
  color:#fff;
  background:#20b15a;
  font-size:0;
  font-weight:950;
  box-shadow:0 18px 40px rgba(32,177,90,.35);
  z-index:998;
  transition:.22s ease;
}
.whatsapp-float::before{
  content:"WA";
  font-size:18px;
}
.whatsapp-float:hover{
  transform:translateY(-4px) scale(1.03);
}

/* Responsive */
@media(max-width:1080px){
  .nav-links{gap:18px}
  .nav-actions .btn{padding:13px 18px}
}

@media(max-width:1020px){
  .nav-links,
  .nav-actions{display:none}
  .menu-btn{display:grid;place-items:center}
  .site-header.mobile-open .nav-links{
    display:flex;
    position:absolute;
    top:78px;
    left:17px;
    right:17px;
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    background:#fff;
    border:1px solid var(--border);
    border-radius:20px;
    padding:10px;
    box-shadow:var(--shadow);
    max-height:calc(100vh - 96px);
    overflow:auto;
  }
  .site-header.mobile-open .nav-links a{
    width:100%;
    padding:14px 12px;
    border-radius:12px;
  }
  .site-header.mobile-open .nav-links a:hover,
  .site-header.mobile-open .nav-links a.active{
    background:var(--blue-soft);
  }
  .site-header.mobile-open .nav-links a::after{display:none}
  .hero-grid,
  .about-grid,
  .contact-grid{grid-template-columns:1fr}
  .visual{min-height:520px}
  .dashboard-card{width:min(440px,92%)}
  .services-grid,
  .portfolio-grid,
  .pricing-grid,
  .testimonial-grid,
  .team-grid,
  .feature-grid{grid-template-columns:1fr 1fr}
  .process-grid{grid-template-columns:1fr 1fr}
  .price-card.popular{transform:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-box{flex-direction:column;align-items:flex-start}
}

@media(max-width:760px){
  .container{width:min(100% - 28px,var(--max))}
  .section{padding:66px 0}
  .hero{padding:58px 0 52px}
  .page-hero{padding:58px 0}
  .hero h1{letter-spacing:-1.7px}
  .hero-actions{width:100%}
  .hero-actions .btn{flex:1 1 100%}
  .hero-stats,
  .services-grid,
  .portfolio-grid,
  .pricing-grid,
  .testimonial-grid,
  .process-grid,
  .form-grid,
  .team-grid,
  .feature-grid{grid-template-columns:1fr}
  .visual{min-height:500px}
  .dashboard-card{
    right:0;
    left:auto;
    width:92%;
    top:28px;
    border-radius:26px;
  }
  .float-a{top:62px;left:0;width:188px}
  .float-b{left:0;bottom:82px;width:218px}
  .float-c{right:0;bottom:8px;width:176px}
  .mock-image{min-height:410px}
  .mock-main{inset:0 25px 75px 0}
  .mock-small{width:72%;height:185px}
  .portfolio-img{height:220px}
  .portfolio-img::after{padding:24px 26px}
  .strip-row{justify-content:center;text-align:center}
  .cta-box{padding:34px 24px;border-radius:26px}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
  .whatsapp-float{width:56px;height:56px;right:15px;bottom:15px}
  .logo{min-width:auto}
  .logo img{height:46px}
  .btn{width:100%}
  .contact-info,
  .contact-form,
  .content-card{padding:24px}
}

@media(max-width:430px){
  .container{width:min(100% - 22px,var(--max))}
  .section-title{letter-spacing:-1px}
  .page-title{letter-spacing:-1.2px}
  .hero h1{font-size:40px}
  .section-title{font-size:30px}
  .visual{min-height:470px}
  .dashboard-card{width:94%}
  .chart-box{height:165px}
  .floating{padding:14px;border-radius:18px}
  .float-a{width:165px}
  .float-b{width:190px}
  .float-c{width:155px}
  .footer-logo img{height:52px}
}
