/* ==========================================================================
   Ayushi Gupta — Digital Marketing
   Editorial / bold-confidence theme
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;0,9..144,900;1,9..144,500&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --paper:#f7f4fb;
  --paper-2:#ece4f5;
  --ink:#201c2b;
  --ink-soft:#5d5569;
  --accent:#6b54a2;       /* violet */
  --accent-soft:#e9e1f6;
  --pine:#1f4d3d;         /* deep green */
  --line:#ded3ec;
  --radius:2px;

  --display:'Fraunces', serif;
  --body:'Manrope', sans-serif;

  --container:1180px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  position:relative;
}

/* film-grain overlay */
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:.045;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* soft translucent colour blobs floating behind the content */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  background-image:
    radial-gradient(540px circle at 8% 0%, rgba(107,84,162,.16), transparent 60%),
    radial-gradient(620px circle at 100% 28%, rgba(107,84,162,.12), transparent 55%),
    radial-gradient(480px circle at 18% 92%, rgba(107,84,162,.10), transparent 60%);
}
.site-header,
.marquee,
section,
.site-footer,
.page-hero{
  position:relative;
  z-index:1;
}

img{ max-width:100%; display:block; }

a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  line-height:1.05;
  margin:0;
  letter-spacing:-0.01em;
}

p{ margin:0 0 1em; color:var(--ink-soft); }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 32px;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--body);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
}
.eyebrow::before{
  content:"";
  width:28px;
  height:2px;
  background:var(--accent);
  display:inline-block;
}

/* ---------------- Buttons ---------------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--body);
  font-weight:700;
  font-size:.95rem;
  padding:16px 30px;
  border-radius:999px;
  border:2px solid var(--ink);
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), background .35s, color .35s, box-shadow .35s;
  white-space:nowrap;
}
.btn:hover{
  background:var(--ink);
  color:var(--paper);
  transform:translateY(-3px);
}
.btn-primary{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--paper);
  box-shadow:6px 6px 0 var(--ink);
}
.btn-primary:hover{
  background:var(--ink);
  border-color:var(--ink);
  color:var(--paper);
  box-shadow:6px 6px 0 var(--accent);
  transform:translate(-2px,-2px);
}
.btn-arrow{ transition:transform .35s; }
.btn:hover .btn-arrow{ transform:translateX(4px); }

/* ---------------- Header ---------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 32px;
  max-width:var(--container);
  margin:0 auto;
}
.logo{
  display:inline-flex;
  align-items:center;
}
.logo-img{
  height:34px;
  width:auto;
  display:block;
}

.nav-links{
  display:flex;
  gap:36px;
  list-style:none;
  margin:0;
  padding:0;
}
.nav-links a{
  font-weight:600;
  font-size:.95rem;
  position:relative;
  padding-bottom:4px;
}
.nav-links a::after{
  content:"";
  position:absolute;
  left:0; bottom:0;
  width:0; height:2px;
  background:var(--accent);
  transition:width .3s ease;
}
.nav-links a:hover::after,
.nav-links a.active::after{ width:100%; }
.nav-links a.active{ color:var(--accent); }

.nav-cta{ display:flex; align-items:center; gap:24px; }
.nav-cta .btn{ padding:12px 24px; font-size:.85rem; }

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:8px;
}
.nav-toggle span{
  width:26px; height:2px; background:var(--ink); display:block;
}

/* ---------------- Marquee ---------------- */
.marquee{
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
  white-space:nowrap;
  border-bottom:1px solid var(--line);
}
.marquee-track{
  display:inline-flex;
  animation:marquee 28s linear infinite;
  padding:14px 0;
}
.marquee-track span{
  font-family:var(--display);
  font-style:italic;
  font-size:1.05rem;
  font-weight:500;
  padding:0 28px;
  display:inline-flex;
  align-items:center;
  gap:28px;
  color:var(--paper-2);
}
.marquee-track span::after{ content:"✦"; color:var(--accent); font-style:normal; }

@keyframes marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* ---------------- Hero ---------------- */
.hero{
  position:relative;
  padding:90px 0 70px;
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.3fr .9fr;
  gap:60px;
  align-items:end;
}
.hero h1{
  font-size:clamp(3rem, 7vw, 5.6rem);
  margin:18px 0 28px;
}
.hero h1 em{
  font-style:italic;
  color:var(--accent);
  font-weight:500;
}
.hero-sub{
  font-size:1.15rem;
  max-width:46ch;
  margin-bottom:34px;
}
.hero-actions{ display:flex; gap:18px; flex-wrap:wrap; }

.hero-card{
  background:var(--ink);
  color:var(--paper);
  border-radius:18px;
  padding:36px;
  position:relative;
  overflow:hidden;
  align-self:stretch;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  min-height:340px;
  transform:rotate(2deg);
}
.hero-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 20%;
  z-index:0;
}
.hero-card::before{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(245,241,232,.25);
  border-radius:12px;
  pointer-events:none;
  z-index:2;
}
.hero-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(32,28,43,.15) 0%, rgba(32,28,43,.55) 55%, rgba(32,28,43,.92) 100%),
    linear-gradient(100deg, rgba(32,28,43,.85) 0%, rgba(32,28,43,.15) 55%);
  z-index:1;
}
.hero-card > div,
.hero-card > .stat-foot{
  position:relative;
  z-index:2;
}
.hero-card .stat-num{
  font-family:var(--display);
  font-size:4.2rem;
  color:var(--accent);
  line-height:1;
}
.hero-card .stat-label{
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--paper-2);
  margin-top:10px;
}
.hero-card .stat-foot{
  font-family:var(--display);
  font-style:italic;
  font-size:1.2rem;
  color:var(--paper-2);
}

/* ---------------- Sections ---------------- */
section{ padding:100px 0; }
.section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:40px;
  margin-bottom:60px;
}
.section-head h2{ font-size:clamp(2.2rem, 4.5vw, 3.4rem); margin-top:14px; }
.section-head p{ max-width:38ch; }

.bg-alt{ background:var(--paper-2); }
.bg-ink{ background:var(--ink); color:var(--paper); }
.bg-ink h2, .bg-ink h3{ color:var(--paper); }
.bg-ink p{ color:var(--paper-2); }
.bg-ink .eyebrow{ color:var(--accent); }

/* ---------------- Service / Feature cards ---------------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:32px; }

.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:38px 32px;
  position:relative;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s;
}
.card:hover{
  transform:translateY(-8px);
  box-shadow:10px 14px 0 var(--accent);
  border-color:var(--ink);
}
.card .num{
  font-family:var(--display);
  font-size:.95rem;
  font-weight:700;
  color:var(--accent);
  letter-spacing:.1em;
}
.card h3{ font-size:1.5rem; margin:18px 0 12px; }
.card ul{ margin:18px 0 0; padding-left:20px; color:var(--ink-soft); }
.card li{ margin-bottom:6px; }

/* ---------------- Process / numbered steps ---------------- */
.steps{ counter-reset:step; display:flex; flex-direction:column; }
.step{
  display:grid;
  grid-template-columns:120px 1fr;
  gap:30px;
  padding:36px 0;
  border-top:1px solid var(--line);
  align-items:start;
}
.step:last-child{ border-bottom:1px solid var(--line); }
.step .step-num{
  font-family:var(--display);
  font-size:3.2rem;
  color:var(--accent);
  font-weight:600;
}
.step h3{ font-size:1.5rem; margin-bottom:8px; }
.step p{ max-width:60ch; margin-bottom:0; }

/* ---------------- Testimonials ---------------- */
.testimonial{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:40px;
  position:relative;
}
.testimonial .quote-mark{
  font-family:var(--display);
  font-size:4rem;
  color:var(--accent);
  line-height:.4;
  margin-bottom:20px;
  display:block;
}
.testimonial p{ font-size:1.1rem; color:var(--ink); font-family:var(--display); font-weight:400; }
.testimonial .author{
  margin-top:24px;
  display:flex;
  align-items:center;
  gap:14px;
}
.author-avatar{
  width:46px; height:46px; border-radius:50%;
  background:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display);
  font-weight:700;
  color:var(--paper);
}
.author-name{ font-weight:700; font-size:.95rem; }
.author-role{ font-size:.82rem; color:var(--ink-soft); }

/* ---------------- CTA Banner ---------------- */
.cta-banner{
  background:var(--accent);
  color:var(--paper);
  border-radius:24px;
  padding:70px 60px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-banner h2{ color:var(--paper); font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:22px; }
.cta-banner p{ color:#e8e0f7; max-width:50ch; margin:0 auto 34px; }
.cta-banner .btn{
  border-color:var(--paper);
  color:var(--paper);
}
.cta-banner .btn:hover{
  background:var(--paper);
  color:var(--accent);
}
.cta-banner::before,
.cta-banner::after{
  content:"";
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(245,241,232,.25);
}
.cta-banner::before{ width:340px; height:340px; right:-120px; top:-140px; }
.cta-banner::after{ width:220px; height:220px; left:-80px; bottom:-100px; }

/* ---------------- FAQ Accordion ---------------- */
.faq-list{ max-width:820px; margin:0 auto; }
.faq-item{
  border-bottom:1px solid var(--line);
}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  background:none;
  border:none;
  text-align:left;
  font-family:var(--display);
  font-size:1.25rem;
  font-weight:600;
  padding:28px 0;
  cursor:pointer;
  color:var(--ink);
}
.faq-icon{
  flex-shrink:0;
  width:34px; height:34px;
  border-radius:50%;
  border:2px solid var(--ink);
  display:flex; align-items:center; justify-content:center;
  position:relative;
  transition:transform .35s, background .35s, border-color .35s;
}
.faq-icon::before, .faq-icon::after{
  content:"";
  position:absolute;
  background:var(--ink);
  transition:transform .3s, background .3s;
}
.faq-icon::before{ width:12px; height:2px; }
.faq-icon::after{ width:2px; height:12px; }
.faq-item.open .faq-icon{ background:var(--accent); border-color:var(--accent); transform:rotate(180deg); }
.faq-item.open .faq-icon::before, .faq-item.open .faq-icon::after{ background:var(--paper); }
.faq-item.open .faq-icon::after{ transform:scaleY(0); }

.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .4s ease, padding .4s ease;
}
.faq-answer p{ padding-bottom:28px; max-width:65ch; margin:0; }
.faq-item.open .faq-answer{ max-height:400px; }

/* ---------------- Contact ---------------- */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:60px;
}
.contact-info-card{
  background:var(--ink);
  color:var(--paper);
  border-radius:18px;
  padding:42px;
}
.contact-info-card h3{ color:var(--paper); font-size:1.6rem; margin-bottom:6px;}
.contact-info-card .eyebrow{ color:var(--accent); margin-bottom: 18px; }
.contact-detail{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:20px 0;
  border-top:1px solid rgba(245,241,232,.15);
}
.contact-detail:first-of-type{ border-top:none; margin-top: 28px;}
.contact-detail .label{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--accent);
}
.contact-detail .value{
  font-family:var(--display);
  font-size:1.25rem;
}
.social-row{ display:flex; gap:14px; margin-top:30px; }
.social-row a{
  width:42px; height:42px;
  border:1px solid rgba(245,241,232,.3);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem;
  font-weight:700;
  transition:background .3s, border-color .3s;
}
.social-row a:hover{ background:var(--accent); border-color:var(--accent); }

/* Form */
.form-card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  padding:42px;
}
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.field{ margin-bottom:22px; display:flex; flex-direction:column; gap:8px; }
.field label{
  font-size:.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--ink-soft);
}
.field input,
.field select,
.field textarea{
  font-family:var(--body);
  font-size:1rem;
  padding:14px 16px;
  border:1px solid var(--line);
  border-radius:10px;
  background:var(--paper-2);
  color:var(--ink);
  outline:none;
  transition:border-color .25s, background .25s;
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color:var(--accent);
  background:var(--paper);
}
.field textarea{ resize:vertical; min-height:130px; }

/* ---------------- Footer ---------------- */
.site-footer{
  background:var(--ink);
  color:var(--paper-2);
  padding:70px 0 30px;
}
.footer-top{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:50px;
  padding-bottom:50px;
  border-bottom:1px solid rgba(245,241,232,.12);
}
.footer-logo{
  display:inline-flex;
  align-items:center;
  margin-bottom:14px;
}
.footer-logo .logo-img{
  height:38px;
}
.footer-col h4{
  color:var(--paper);
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.18em;
  margin-bottom:18px;
  font-family:var(--body);
  font-weight:700;
}
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.footer-col a{ color:var(--paper-2); transition:color .25s; }
.footer-col a:hover{ color:var(--accent); }
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:28px;
  font-size:.85rem;
  color:rgba(245,241,232,.5);
  flex-wrap:wrap;
  gap:16px;
}

/* ---------------- Reveal animation ---------------- */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.in{ opacity:1; transform:translateY(0); }

/* ---------------- Page header (inner pages) ---------------- */
.page-hero{
  padding:70px 0 60px;
  border-bottom:1px solid var(--line);
}
.page-hero h1{ font-size:clamp(2.6rem,6vw,4.4rem); margin-top:16px; }
.page-hero p{ max-width:55ch; font-size:1.1rem; margin-top:18px; }
.breadcrumb{
  font-size:.85rem;
  color:var(--ink-soft);
  margin-bottom: 4px;
}
.breadcrumb .accent{ color:var(--accent); font-weight:700; }

/* ---------------- Blog grid ---------------- */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.blog-card{
  display:flex;
  flex-direction:column;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s, border-color .35s;
}
.blog-card:hover{
  transform:translateY(-8px);
  box-shadow:10px 14px 0 var(--accent);
  border-color:var(--ink);
}
.blog-card-img{
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--paper-2);
}
.blog-card-img img{ width:100%; height:100%; object-fit:cover; display:block; }
.blog-card-body{ padding:26px 28px 32px; flex:1; display:flex; flex-direction:column; }
.blog-meta{
  font-family:var(--body);
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
}
.blog-card-body h3{ font-size:1.3rem; margin:14px 0 10px; }
.blog-card-body p{ color:var(--ink-soft); flex:1; }
.blog-readmore{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  margin-top:16px;
}
.blog-card:hover .blog-readmore .btn-arrow{ transform:translateX(4px); }

/* ---------------- Pagination ---------------- */
.pagination{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin-top:60px;
}
.pagination span,
.pagination a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:46px;
  height:46px;
  padding:0 16px;
  border-radius:999px;
  border:2px solid var(--line);
  font-weight:700;
  font-family:var(--body);
  font-size:.9rem;
}
.pagination a:hover{
  border-color:var(--ink);
  background:var(--ink);
  color:var(--paper);
}
.pagination span.current{
  background:var(--accent);
  border-color:var(--accent);
  color:var(--paper);
}

/* ---------------- Single blog post ---------------- */
.single-featured-image{
  width:100%;
  max-height:520px;
  overflow:hidden;
}
.single-featured-image img{ width:100%; height:100%; object-fit:cover; display:block; }
.single-post-content{
  max-width:760px;
  margin:0 auto;
}
.single-post-content h2,
.single-post-content h3,
.single-post-content h4{ margin-top:1.6em; margin-bottom:.6em; }
.single-post-content p{ margin-bottom:1.4em; line-height:1.8; color:var(--ink-soft); }
.single-post-content img{ border-radius:14px; margin:30px 0; max-width:100%; height:auto; }
.single-post-content blockquote{
  border-left:4px solid var(--accent);
  padding-left:24px;
  font-style:italic;
  color:var(--ink);
  margin:30px 0;
}
.single-post-content ul,
.single-post-content ol{ padding-left:24px; color:var(--ink-soft); margin-bottom:1.4em; }
.single-post-content a{ color:var(--accent); text-decoration:underline; }
.single-post-back{ max-width:760px; margin:50px auto 0; }

/* ---------------- About page specific ---------------- */
.about-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:60px;
  align-items:center;
}
.portrait{
  background:var(--ink);
  border-radius:24px;
  aspect-ratio:4/5;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding:30px;
}
.portrait::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,77,46,.35), transparent 45%),
    radial-gradient(circle at 80% 80%, rgba(31,77,61,.45), transparent 50%),
    linear-gradient(0deg, rgba(32,28,43,.85) 0%, rgba(32,28,43,0) 45%);
  z-index:1;
}
.portrait img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
}
.portrait .portrait-tag{
  position:relative;
  z-index:2;
  font-family:var(--display);
  font-style:italic;
  color:var(--paper);
  font-size:1.4rem;
}
.values-list{ display:flex; flex-direction:column; gap:0; margin-top:20px; }
.value-item{
  display:flex; gap:20px;
  padding:22px 0;
  border-top:1px solid var(--line);
}
.value-item:last-child{ border-bottom:1px solid var(--line); }
.value-item .v-mark{
  font-family:var(--display);
  font-size:1.6rem;
  color:var(--accent);
}

/* ---------------- Stats strip ---------------- */
.stats-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  padding:60px 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.stat{ text-align:center; }
.stat .num{
  font-family:var(--display);
  font-size:clamp(2.4rem,5vw,3.6rem);
  color:var(--accent);
}
.stat .label{
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--ink-soft);
  margin-top:8px;
}

/* ---------------- Responsive ---------------- */
@media (max-width: 980px){
  .hero-grid, .about-grid, .contact-grid{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .stats-strip{ grid-template-columns:repeat(2,1fr); }
  .hero-card{ transform:rotate(0); }
}

@media (max-width: 760px){
  .nav-links, .nav-cta .btn{ display:none; }
  .nav-toggle{ display:flex; }
  .logo-img{ height:28px; }
  .nav.open .nav-links{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:100%; left:0; right:0;
    background:var(--paper);
    padding:24px 32px;
    border-bottom:1px solid var(--line);
    gap:18px;
  }
  .nav.open .nav-cta{ display:none; }
  .grid-3, .grid-2, .form-row, .blog-grid{ grid-template-columns:1fr; }
  .section-head{ flex-direction:column; align-items:flex-start; }
  .step{ grid-template-columns:1fr; gap:10px; }
  .footer-top{ grid-template-columns:1fr; }
  .cta-banner{ padding:50px 28px; }
  section{ padding:70px 0; }
}

/* ---------------- Elementor structural reset ----------------
   Each design block is wrapped in its own Elementor section/column/
   HTML widget so it can be moved, duplicated or removed. These rules
   strip Elementor's default wrapper spacing so the inner markup keeps
   its original look. */
.elementor-section.elementor-section{ padding:0 !important; margin:0 !important; }
.elementor-section.elementor-section.elementor-section-boxed > .elementor-container,
.elementor-section.elementor-section .elementor-container.elementor-container{ max-width:none !important; width:100% !important; padding:0 !important; margin:0 !important; }
.elementor-column.elementor-column > .elementor-widget-wrap{ padding:0 !important; }
.elementor-widget-html.elementor-widget-html .elementor-widget-container{ margin:0 !important; }
.elementor-widget-wrap.elementor-widget-wrap{ max-width:none !important; }
.elementor *{ box-sizing:border-box; }
