/**
Theme Name: Astra
Theme URI: https://wpastra.com/
Author: Brainstorm Force
Author URI: https://wpastra.com/about/?utm_source=theme_preview&utm_medium=author_link&utm_campaign=astra_theme
Description: The Astra WordPress theme is lightning-fast and highly customizable. It has over 1 million downloads and the only theme in the world with 6,000+ five-star reviews! It’s ideal for professional web designers, solopreneurs, small businesses, eCommerce, membership sites and any type of website. It offers special features and templates so it works perfectly with all page builders like Spectra, Elementor, Beaver Builder, etc. Fast performance, clean code, mobile-first design and schema markup are all built-in, making the theme exceptionally SEO-friendly. It’s fully compatible with WooCommerce, SureCart and other eCommerce plugins and comes with lots of store-friendly features and templates. Astra also provides expert support for free users. A dedicated team of fully trained WordPress experts are on hand to help with every aspect of the theme. Try the live demo of Astra: https://zipwp.org/themes/astra/
Version: 4.12.7
Requires at least: 5.3
WC requires at least: 3.0
WC tested up to: 10.6.2
Tested up to: 6.9
Requires PHP: 5.3
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: astra
Domain Path: /languages
Tags: custom-menu, custom-logo, entertainment, one-column, two-columns, left-sidebar, e-commerce, right-sidebar, custom-colors, editor-style, featured-images, full-width-template, microformats, post-formats, rtl-language-support, theme-options, threaded-comments, translation-ready, blog
AMP: true

Astra WordPress Theme, Copyright 2020 WPAstra.
Astra is distributed under the terms of the GNU GPL.

Astra is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of.
Nicolas Gallagher and Jonathan Neal https://necolas.github.com/normalize.css/

Astra icon font is based on IcoMoon-Free vector icon by Keyamoon.
IcoMoon-Free vector icon distributed under terms of CC BY 4.0 or GPL. (https://creativecommons.org/licenses/by/4.0/ or https://www.gnu.org/licenses/gpl.html)
Source: http://keyamoon.com/

Flexibility is a JavaScript polyfill for Flexbox By Jonathan Neal, 10up. (https://github.com/jonathantneal/flexibility)
Licensed under MIT ( https://github.com/jonathantneal/flexibility/blob/master/LICENSE.md )

Screenshot image is a collage of actual sites created using the Astra WordPress Theme.

Icons used in the Screenshot image are all licensed under Creative Commons ( CC BY 4.0 ) License ( https://fontawesome.com/license/free )
https://fontawesome.com/v5.15/icons/store?style=solid
https://fontawesome.com/v5.15/icons/shopping-cart?style=solid
https://fontawesome.com/v5.15/icons/pen-square?style=solid
https://fontawesome.com/v5.15/icons/user-tie?style=solid
https://fontawesome.com/v5.15/icons/user-tie?style=solid

Illustrations used in the Screenshot images are all licensed under Creative Commons ( CC0 ) License ( https://gumroad.com/l/humaaans )
https://websitedemos.net/web-design-agency-08/wp-content/uploads/sites/796/2021/05/standing-24.png
https://websitedemos.net/web-design-agency-08/wp-content/uploads/sites/796/2021/05/sitting-2.png

Hand-drawn illustrations used are created by Brainstorm Force and released under Creative Commons ( CC0 ) License.
https://websitedemos.net/web-design-agency-08/wp-content/uploads/sites/796/2021/05/girl-with-image-container.png
https://websitedemos.net/web-design-agency-08/wp-content/uploads/sites/796/2021/05/boy-with-code-container.png
https://websitedemos.net/web-design-agency-08/wp-content/uploads/sites/796/2021/05/web-browser.png

The same site as screenshot can be imported from here https://websitedemos.net/web-design-agency-08/.

For more information, refer to this document on how to create a page like in the screenshot - https://wpastra.com/docs/replicating-the-screenshot/.

Astra default breadcrumb is based on Breadcrumb Trail by Justin Tadlock. (https://github.com/justintadlock/breadcrumb-trail)
Breadcrumb Trail is distributed under the terms of the GNU GPL v2 or later.

Astra local fonts feature is based on Webfonts Loader by WordPress Themes Team (WPTT). (https://github.com/WPTT/webfont-loader)
Licensed under MIT ( https://github.com/WPTT/webfont-loader/blob/master/LICENSE )

/* Note: The CSS files are loaded from assets/css/ folder. */

/* Hero section styles for Astra child theme */
.hero {
  max-width: 1240px;
  margin: 0 auto;
  padding: 96px 32px 64px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 520px);
  gap: 42px;
  align-items: center;
}

.hero-copy {
  position: relative;
  z-index: 1;
}

.hero-kicker {
  display: inline-flex;
  margin-bottom: 18px;
  color: #fb5f29;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.85rem;
}

.hero h1 {
  margin: 0 0 24px;
  font-size: clamp(3rem, 5vw, 4.75rem);
  line-height: 1.02;
  letter-spacing: -0.05em;
}

.hero-lead {
  margin: 0 0 36px;
  max-width: 620px;
  color: #475569;
  font-size: 1.05rem;
  line-height: 1.9;
}

.hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 38px;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 28px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.95rem;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.btn-primary {
  background: #fb5f29;
  color: #ffffff;
  border: 1px solid transparent;
}

.btn-primary:hover,
.btn-primary:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(251,95,41,0.2);
}

.btn-secondary {
  background: rgba(251,95,41,0.08);
  color: #fb5f29;
  border: 1px solid rgba(251,95,41,0.2);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  background: rgba(251,95,41,0.15);
}

.hero-image {
  display: flex;
  justify-content: center;
}

.hero-image img {
  width: 100%;
  border-radius: 32px;
  /* box-shadow: 0 42px 90px rgba(14,30,60,0.12); */
}

.section {
  padding: 80px 32px;
}

.section-heading {
  max-width: 760px;
  margin: 0 auto 48px;
  text-align: center;
}

.section-heading .section-label {
  display: inline-flex;
  margin-bottom: 18px;
  color: #0f172a;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.85rem;
}

.section-heading.center {
  text-align: center;
}

.section-heading h2 {
  margin: 0;
  font-size: clamp(2rem, 3vw, 3.4rem);
  line-height: 1.05;
}

.section-heading p {
  margin: 18px auto 0;
  max-width: 720px;
  color: #6b7280;
  line-height: 1.9;
  font-size: 1rem;
}

.section-services {
  padding-top: 80px;
}

.services-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(360px, 1fr));
  gap: 30px;
  max-width: 1240px;
  margin: 0 auto;
}

.service-card {
    background: #ffffff;
    /* border: 1px solid rgba(226, 232, 240, 0.85); */
    border-radius: 32px;
    padding: 36px 32px;
    min-height: 320px;
    display: grid;
    gap: 24px;
    box-shadow: 0 5px 2px rgba(15, 23, 42, 0.08);
}

.service-icon {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  background: rgba(251,95,41,0.08);
  color: #fb5f29;
  border-radius: 50%;
  border: 1px solid rgba(251,95,41,0.18);
  font-size: 1.6rem;
}

.service-card h3 {
  margin: 0;
  font-size: 1.2rem;
}

.service-card p {
  margin: 0;
  color: #475569;
  line-height: 1.85;
  font-size: 0.98rem;
}

.section-audit {
  background: #f8fafb;
}

.audit-card {
  max-width: 1240px;
  margin: 0 auto;
  background: #ffffff;
  border-radius: 32px;
  padding: 42px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  border: 1px solid rgba(148,163,184,0.16);
  box-shadow: 0 30px 70px rgba(15,23,42,0.08);
}

.audit-card .section-label {
  display: inline-flex;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(251,95,41,0.1);
  color: #fb5f29;
  font-weight: 700;
}

.audit-card h2 {
  margin: 16px 0 0;
  font-size: clamp(2rem, 2.5vw, 2.8rem);
  line-height: 1.05;
}

.audit-card p {
  margin: 16px 0 0;
  max-width: 620px;
  color: #475569;
  line-height: 1.9;
}

.section-about {
  padding: 80px 32px;
  background: #f8fafc;
}

.section-about.split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 44px;
  align-items: center;
  max-width: 1240px;
  margin: 0 auto;
}

.about-image-panel {
  display: flex;
  justify-content: center;
  align-items: center;
}

.about-image-panel img {
  width: 100%;
  border-radius: 32px;
  box-shadow: 0 40px 90px rgba(15,23,42,0.08);
}

.about-copy-panel {
  max-width: 620px;
}

.about-copy-panel .section-label {
  display: inline-flex;
  margin-bottom: 18px;
  color: #0f172a;
  letter-spacing: 0.12em;
  font-size: 0.85rem;
  text-transform: uppercase;
}

.about-copy-panel h2 {
  margin: 0 0 24px;
  font-size: clamp(2.4rem, 3vw, 3.4rem);
}

.about-copy-panel p {
  margin: 0;
  color: #475569;
  line-height: 1.9;
  font-size: 1.05rem;
}

.section-stats {
  padding: 60px 32px;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 20px;
  max-width: 1240px;
  margin: 0 auto;
}

.stat-card {
  background: #ffffff;
  padding: 32px 32px 28px 24px;
  border-radius: 24px;
  border-left: 4px solid #fb5f29;
  text-align: left;
  box-shadow: 0 30px 70px rgba(15, 23, 42, 0.06);
}

.stat-card strong {
  display: block;
  font-size: clamp(2.4rem, 3vw, 3.4rem);
  margin-bottom: 8px;
  color: #111827;
  line-height: 1;
}

.stat-card p {
  margin: 0;
  color: #475569;
  line-height: 1.7;
}

.section-brands {
  padding: 60px 32px;
}

.brand-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 24px;
  max-width: 1120px;
  margin: 0 auto;
  align-items: center;
}

.brand-item {
  background: #ffffff;
  border-radius: 20px;
  border: 1px solid rgba(148,163,184,0.14);
  min-height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #475569;
  font-weight: 700;
}

.section-process {
  padding: 80px 32px;
}

.process-flow {
  display: grid;
  gap: 24px;
  max-width: 1240px;
  margin: 0 auto;
}

.process-step {
  background: #ffffff;
  border: 1px solid rgba(148,163,184,0.16);
  border-radius: 28px;
  padding: 28px 30px;
}

.step-number {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(251,95,41,0.12);
  color: #fb5f29;
  font-weight: 700;
  margin-bottom: 18px;
}

.process-step h3 {
  margin: 0 0 12px;
  font-size: 1.25rem;
}

.process-step p {
  margin: 0;
  color: #475569;
  line-height: 1.8;
}

.section-portfolio {
  padding: 80px 32px;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1240px;
  margin: 0 auto;
}

.portfolio-card {
  background: #ffffff;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid rgba(148,163,184,0.16);
}

.portfolio-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.portfolio-copy {
  padding: 24px;
}

.portfolio-copy span {
  display: inline-block;
  margin-bottom: 12px;
  color: #fb5f29;
  font-weight: 700;
}

.portfolio-copy h3 {
  margin: 0;
  font-size: 1.3rem;
  line-height: 1.4;
}

.section-testimonials {
  padding: 80px 32px;
}

.testimonial-layout {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 460px);
  gap: 32px;
}

.testimonial-intro {
  padding-right: 24px;
}

.testimonial-intro .section-label {
  display: inline-flex;
  margin-bottom: 18px;
}

.testimonial-intro h2 {
  margin: 0 0 18px;
  font-size: clamp(2.4rem, 3vw, 3rem);
}

.testimonial-intro p {
  margin: 0;
  color: #475569;
  line-height: 1.9;
}

.testimonial-slides {
  display: grid;
  gap: 24px;
}

.testimonial-card {
  background: #ffffff;
  border-radius: 28px;
  padding: 28px;
  border: 1px solid rgba(148,163,184,0.16);
}

.testimonial-card p {
  margin: 0 0 18px;
  color: #475569;
  line-height: 1.9;
}

.testimonial-card h3 {
  margin: 0 0 8px;
}

.testimonial-card span {
  color: #6b7280;
}

.section-contact {
  padding: 80px 32px;
}

.contact-grid {
  display: grid;
  gap: 32px;
  max-width: 1240px;
  margin: 0 auto;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 500px);
}

.contact-details {
  display: grid;
  gap: 20px;
}

.contact-details h2 {
  margin: 0;
  font-size: clamp(2.4rem, 3vw, 3.2rem);
}

.contact-details p {
  margin: 0;
  color: #475569;
  max-width: 560px;
  line-height: 1.9;
}

.contact-info p {
  margin: 0 0 10px;
  color: #475569;
  font-weight: 600;
}

.contact-form-card {
  background: #ffffff;
  border-radius: 32px;
  padding: 34px;
  border: 1px solid rgba(148,163,184,0.16);
  box-shadow: 0 24px 60px rgba(15,23,42,0.08);
}

.contact-form {
  display: grid;
  gap: 18px;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(148,163,184,0.24);
  border-radius: 16px;
  padding: 16px 18px;
  color: #111827;
  background: #f8fafc;
}

.contact-form textarea {
  resize: vertical;
}

.contact-form button {
  width: 100%;
}

.bg-light {
  background: #f8fafb;
}

@media (max-width: 1180px) {
  .services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1024px) {
  .hero,
  .section-about.split,
  .testimonial-layout,
  .contact-grid,
  .audit-card {
    grid-template-columns: 1fr;
  }

  .hero {
    padding-top: 80px;
  }

  .audit-card {
    padding: 32px;
  }
}

@media (max-width: 760px) {
  .site-branding {
    flex-direction: column;
    align-items: flex-start;
    padding: 18px 20px;
  }

  .site-nav-wrap {
    flex-direction: column;
    gap: 16px;
    width: 100%;
  }

  .main-navigation ul {
    flex-wrap: wrap;
    gap: 16px;
  }

  .hero {
    padding: 72px 20px 52px;
  }

  .section {
    padding: 60px 20px;
  }

  .services-grid,
  .stats-grid,
  .brand-grid,
  .portfolio-grid,
  .process-flow,
  .testimonial-slides {
    grid-template-columns: 1fr;
  }

  .section-heading {
    margin-bottom: 36px;
  }

  .contact-form button {
    min-height: 52px;
  }
}

.services-section {
  background: #f5f5f5;
  padding: 80px 20px;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
}

.services-header {
  margin-bottom: 50px;
}

.subtitle {
  font-size: 14px;
  letter-spacing: 1px;
  font-weight: 600;
  color: #777;
  display: block;
  margin-bottom: 10px;
}

.services-header h2 {
  font-size: 42px;
  font-weight: 600;
  margin-bottom: 15px;
  color: #222;
}

.services-header p {
  font-size: 16px;
  color: #555;
  max-width: 600px;
  line-height: 1.6;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
}

.stat-item {
  position: relative;
}

.stat-item .divider {
  display: inline-block;
  width: 3px;
  height: 20px;
  background: #ff4d4d;
  margin-bottom: 10px;
}

.stat-item h3 {
  font-size: 36px;
  font-weight: 600;
  margin: 5px 0;
}

.stat-item p {
  font-size: 14px;
  color: #555;
}

/* Responsive */
@media (max-width: 768px) {
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.section-process {
  background: #f5f5f5;
  padding: 100px 20px;
  text-align: center;
}

.process-wrapper {
  position: relative;
  margin-top: 80px;
}

.process-line {
  width: 100%;
  height: 200px;
}

.process-steps {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.process-step {
  position: absolute;
  text-align: center;
  width: 150px;
}

/* Position each step manually across the curve */
.process-step:nth-child(1) { left: 5%; }
.process-step:nth-child(2) { left: 25%; }
.process-step:nth-child(3) { left: 45%; }
.process-step:nth-child(4) { left: 65%; }
.process-step:nth-child(5) { left: 85%; }

.process-step.top {
  top: -20px;
}

.process-step.bottom {
  top: 120px;
}

/* Icon circle */
.process-step .icon {
  width: 60px;
  height: 60px;
  border: 2px solid #f26a2e;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 10px;
  background: #fff;
  font-size: 22px;
}

/* Text */
.process-step h4 {
  font-size: 16px;
  font-weight: 500;
}

/* Responsive */
@media (max-width: 768px) {
  .process-line {
    display: none;
  }

  .process-step {
    position: static;
    margin-bottom: 30px;
  }
}

.agile-section {
  padding: 80px 0;
  background: #f5f5f5;
}

.agile-wrapper {
  display: flex;
  gap: 40px;
  align-items: flex-start;
}

.container {
  max-width: 1200px;
  margin: auto;
  padding: 0 20px;
}

/* LEFT */
.agile-left {
  flex: 1;
}

.agile-left h2 {
  font-size: 36px;
  margin-bottom: 20px;
}

.agile-left p {
  color: #666;
  line-height: 1.6;
  margin-bottom: 25px;
}

.agile-steps {
  display: flex;
  gap: 60px;
  margin-bottom: 30px;
}

.agile-steps ul {
  list-style: none;
  padding: 0;
}

.agile-steps li {
  margin-bottom: 10px;
  font-size: 16px;
}

/* BUTTON */
.btn-primary {
  background: #ff5a3c;
  color: #fff;
  padding: 12px 28px;
  border-radius: 6px;
  text-decoration: none;
  display: inline-block;
}

/* RIGHT */
.agile-right {
  flex: 1;
  background: #eee;
  padding: 30px;
  border-radius: 10px;
}

/* ACCORDION */
.accordion-item {
  background: #fff;
  border-radius: 6px;
  margin-bottom: 15px;
  overflow: hidden;
}

.accordion-header {
  padding: 15px 20px;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 15px;
}

.accordion-header span {
  font-size: 20px;
}

.accordion-content {
  display: none;
  padding: 15px 20px;
  border-top: 1px solid #eee;
  color: #666;
}

/* ACTIVE */
.accordion-item.active .accordion-content {
  display: block;
}

/* RESPONSIVE */
@media (max-width: 992px) {
  .agile-wrapper {
    flex-direction: column;
  }
}

.section-testimonials {
  padding: 80px 0;
  background: #f5f5f5;
}

.testimonial-layout {
  display: flex;
  gap: 50px;
  align-items: flex-start;
}

/* LEFT */
.testimonial-intro {
  flex: 1;
}

.testimonial-intro h2 {
  font-size: 36px;
  margin-bottom: 20px;
}

.testimonial-intro p {
  color: #666;
  margin-bottom: 30px;
}

/* NAV BUTTONS */
.testimonial-nav {
  display: flex;
  gap: 15px;
}

.nav-btn {
  width: 45px;
  height: 45px;
  border-radius: 50%;
  border: 1px solid #ddd;
  background: #fff;
  cursor: pointer;
  font-size: 18px;
}

/* RIGHT */
.testimonial-slides {
  flex: 2;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 25px;
}

/* CARD */
.testimonial-card {
  background: #fff;
  padding: 30px;
  border-radius: 8px;
  position: relative;
  border: 1px solid #eee;
}

.quote {
  font-size: 50px;
  color: #333;
  margin-bottom: 10px;
}

.testimonial-card p {
  color: #444;
  line-height: 1.6;
  margin-bottom: 30px;
}

/* CLIENT */
.client-info h4 {
  margin: 0;
  font-size: 16px;
}

.client-info span {
  color: #888;
  font-size: 14px;
}

/* RESPONSIVE */
@media (max-width: 992px) {
  .testimonial-layout {
    flex-direction: column;
  }

  .testimonial-slides {
    grid-template-columns: 1fr;
  }
}