/* ==========================================================
   DIGILY THEME — DARK PREMIUM SYSTEM
   Accent: #22c55e
   ========================================================== */

/* =========================
   0. Self-hosted fonts
   ========================= */

@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url('../fonts/ibm-plex-sans-var-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* =========================
   1. Design tokens
   ========================= */

:root{
  --container: 1120px;

  /* spacing */
  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 24px;
  --space-5: 32px;
  --space-6: 48px;
  --space-7: 72px;
  --space-8: 96px;

  /* typography */
  --font-sans: 'IBM Plex Sans', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --fs-0: clamp(1rem, 0.3vw + 0.95rem, 1.1rem);
  --fs-1: clamp(1.15rem, 0.8vw + 1rem, 1.35rem);
  --fs-2: clamp(1.6rem, 1.8vw + 1.1rem, 2.2rem);
  --fs-3: clamp(2.2rem, 3.2vw + 1.2rem, 3.4rem);
  --lh: 1.65;

  /* colors */
  --bg: #0b0f14;
  --bg-2: #0f1620;
  --surface: rgba(15,23,42,0.6);

  --text: #e5e7eb;
  --muted: #a3adc2;
  --muted-2: #7f8aa3;

  --border: rgba(255,255,255,0.08);
  --border-strong: rgba(255,255,255,0.14);

  --accent: #22c55e;
  --accent-hover: #34d399;
  --accent-ink: #06110a;

  --radius: 16px;
  --shadow: 0 20px 60px rgba(0,0,0,0.4);

  --grid-opacity: 0.18;
  --noise-opacity: 0.05;
}

/* =========================
   2. Reset + base
   ========================= */

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

html{
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body{
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-0);
  line-height: var(--lh);
  color: var(--text);
  background: var(--bg);
}

/* Background glow */
body::before{
  content:"";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(800px 500px at 20% 0%, rgba(34,197,94,0.18), transparent 60%),
    radial-gradient(600px 400px at 80% 10%, rgba(34,197,94,0.12), transparent 55%);
}

/* Grid overlay */
.grid-overlay{
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 60px 60px;
}

/* Noise */
.noise{
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: var(--noise-opacity);
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
}

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

a{
  color: var(--accent-hover);
  text-decoration: none;
}

a:hover{
  color: var(--accent);
}

.container{
  width: min(var(--container), calc(100% - 2 * var(--space-4)));
  margin-inline: auto;
}

.section{
  padding-block: var(--space-7);
}

@media (max-width: 720px){
  .section{ padding-block: var(--space-6); }
}

/* =========================
   3. Buttons
   ========================= */

.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 999px;
  font-weight: 750;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.15s ease;
}

.btn--primary{
  background: linear-gradient(135deg, var(--accent), var(--accent-hover));
  color: #f8fafc;
}

.btn--primary:hover{
  color: #f8fafc;
  box-shadow: 0 0 0 1px rgba(34,197,94,0.3), 0 0 40px rgba(34,197,94,0.25);
}

.btn--primary:focus-visible{
  color: #f8fafc;
}

.btn--secondary{
  background: transparent;
  border-color: var(--border);
  color: var(--text);
}

.btn--secondary:hover{
  border-color: var(--accent);
}

/* =========================
   4. Navigation
   ========================= */

.skip-link{
  position: absolute;
  left: -9999px;
  top: auto;
}

.skip-link:focus{
  left: 20px;
  top: 20px;
  padding: 10px 14px;
  background: var(--accent);
  color: var(--accent-ink);
  border-radius: 999px;
  font-weight: 700;
  box-shadow: 0 0 0 3px rgba(34,197,94,0.3);
  z-index: 9999;
}

.site-header{
  position: sticky;
  top: 0;
  z-index: 300;
  isolation: isolate;
  overflow: visible;
  backdrop-filter: blur(10px);
  background: rgba(11,15,20,0.72);
  border-bottom: 1px solid var(--border);
  padding-block: var(--space-4);
}

.site-header::before,
.site-header::after{
  content: "";
  position: absolute;
  pointer-events: none;
}

.site-header::before{
  inset: -36px 0 -1px;
  z-index: 0;
  background:
    radial-gradient(900px 220px at 50% 110%, rgba(34,197,94,0.2), transparent 70%),
    linear-gradient(180deg, rgba(11,15,20,0.88), rgba(11,15,20,0.68));
}

.site-header::after{
  inset: 0;
  z-index: 1;
  opacity: 0.05;
  mix-blend-mode: screen;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
}

.site-header .container{
  position: relative;
  z-index: 2;
}

.site-header__inner{
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-4);
}

.site-logo{
  font-weight: 800;
  text-decoration: none;
  color: var(--text);
}

.site-logo:hover{
  color: var(--text);
}

.site-nav{
  position: relative;
  z-index: 310;
  justify-self: center;
}

.site-header__cta{
  justify-self: end;
  padding: 9px 16px;
  font-size: 0.95rem;
  font-weight: 650;
  background: transparent;
  color: var(--accent-hover);
  border-color: rgba(34,197,94,0.45);
  box-shadow: none;
}

.site-header__cta:hover{
  background: rgba(34,197,94,0.08);
  color: var(--accent-hover);
  border-color: rgba(34,197,94,0.75);
  box-shadow: none;
}

.site-nav__cta{
  display: none;
  margin-top: 8px;
}

.menu-toggle{
  display: none;
  border: 1px solid var(--border);
  background: rgba(10,16,26,0.7);
  color: var(--text);
  border-radius: 10px;
  width: 44px;
  height: 40px;
  padding: 0;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
}

.menu-toggle__line{
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: var(--text);
}

.menu{
  list-style: none;
  display: flex;
  gap: 14px;
  padding: 0;
  margin: 0;
  align-items: center;
}

.menu > .menu-item{
  position: relative;
}

.menu > .has-mega{
  position: static;
}

.menu a{
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  color: var(--muted);
}

.menu a:hover{
  background: rgba(255,255,255,0.05);
  color: var(--text);
}

.menu .current-menu-item > a,
.menu .current-menu-parent > a,
.menu .current-menu-ancestor > a{
  color: var(--accent-hover);
  background: rgba(34,197,94,0.08);
  box-shadow: inset 0 0 0 1px rgba(34,197,94,0.28);
}

.menu .menu-item-has-children > a::after,
.menu .has-mega > a::after{
  content: "";
  width: 7px;
  height: 7px;
  margin-left: 8px;
  border-right: 1.8px solid currentColor;
  border-bottom: 1.8px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  opacity: 0.78;
  transition: transform 0.15s ease, opacity 0.15s ease;
}

.menu .sub-menu{
  list-style: none;
  margin: 0;
  padding: 8px;
  min-width: 220px;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 350;
  background: rgba(10,16,26,0.96);
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  box-shadow: 0 18px 30px rgba(0,0,0,0.35);
  display: grid;
  gap: 2px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  transition: opacity 0.15s ease, transform 0.15s ease, visibility 0.15s ease;
}

.menu .sub-menu a{
  border-radius: 10px;
  width: 100%;
  padding: 9px 12px;
}

.menu .menu-item-has-children:hover > .sub-menu,
.menu .menu-item-has-children:focus-within > .sub-menu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.menu > .has-mega > .sub-menu{
  display: none;
}

.menu .menu-item-has-children:hover > a::after,
.menu .menu-item-has-children:focus-within > a::after,
.menu .has-mega:hover > a::after,
.menu .has-mega:focus-within > a::after{
  transform: rotate(-135deg) translateY(-1px);
  opacity: 1;
}

.mega-menu{
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  width: min(1080px, calc(100vw - 2 * var(--space-4)));
  padding: 14px;
  margin-top: 8px;
  border-radius: 14px;
  border: 1px solid var(--border-strong);
  background: rgba(8,14,24,0.97);
  box-shadow: 0 26px 42px rgba(0,0,0,0.48);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.16s ease, transform 0.16s ease, visibility 0.16s ease;
}

.mega-menu::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -10px;
  height: 10px;
}

.menu > .has-mega:hover > .mega-menu,
.menu > .has-mega:focus-within > .mega-menu{
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.mega-menu__all{
  color: var(--accent-hover);
  font-size: 0.92rem;
  font-weight: 700;
}

.mega-menu__grid{
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mega-menu__card{
  margin: 0;
}

.mega-menu__link{
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
  color: var(--text);
  text-decoration: none;
}

.mega-menu__media{
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 10px;
  border: 1px solid var(--border);
  aspect-ratio: 16 / 9.5;
  background: linear-gradient(160deg, rgba(20,34,56,0.95), rgba(10,16,26,0.98));
}

.mega-menu__image{
  width: 100%;
  display: block;
  height: 100%;
  object-fit: cover;
  transform: scale(1.01);
  transition: transform 0.25s ease;
}

.mega-menu__content{
  display: grid;
  width: 100%;
  gap: 8px;
  padding-inline: 2px;
}

.mega-menu__title{
  margin: 0;
  color: #f8fafc;
  font-size: 1.12rem;
  font-weight: 600;
  line-height: 1.3;
}

.mega-menu__excerpt{
  color: rgba(233,239,250,0.88);
  font-size: 0.95rem;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mega-menu__link:hover .mega-menu__image{
  transform: scale(1.04);
}

.mega-menu__empty{
  margin: 0;
  color: var(--muted);
}

.mega-menu__footer{
  margin-top: 14px;
  display: flex;
  justify-content: flex-start;
}

.submenu-toggle{
  display: none;
}

@media (max-width: 920px){
  .site-header__inner{
    grid-template-columns: 1fr auto;
  }

  .menu-toggle{
    display: inline-flex;
  }

  .site-header__cta{
    display: none;
  }

  .site-nav{
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    width: min(360px, calc(100vw - 2 * var(--space-4)));
    max-height: calc(100vh - 120px);
    overflow: auto;
    padding: 10px;
    border-radius: 14px;
    border: 1px solid var(--border-strong);
    background: rgba(10,16,26,0.98);
    box-shadow: 0 24px 40px rgba(0,0,0,0.45);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    pointer-events: none;
    transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
  }

  body.nav-open .site-nav{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  .menu{
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
  }

  .menu > .menu-item{
    width: 100%;
  }

  .menu a{
    width: 100%;
    justify-content: flex-start;
    border-radius: 10px;
  }

  .menu .menu-item-has-children > a::after,
  .menu .has-mega > a::after,
  .mega-menu{
    display: none;
  }

  .menu > .has-mega > .sub-menu{
    display: grid;
  }

  .menu .menu-item-has-children{
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
  }

  .submenu-toggle{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-left: 4px;
    border: 0;
    background: transparent;
    color: var(--muted);
    border-radius: 8px;
  }

  .submenu-toggle::before{
    content: "";
    width: 8px;
    height: 8px;
    border-right: 1.8px solid currentColor;
    border-bottom: 1.8px solid currentColor;
    transform: rotate(45deg);
    transition: transform 0.15s ease;
  }

  .menu .menu-item-has-children.is-open > .submenu-toggle::before{
    transform: rotate(-135deg);
  }

  .submenu-toggle:focus-visible{
    outline: 2px solid rgba(34,197,94,0.5);
    outline-offset: 2px;
  }

  .menu .sub-menu{
    grid-column: 1 / -1;
    position: static;
    min-width: 0;
    margin-top: 4px;
    padding: 4px 0 0 10px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    gap: 3px;
    max-height: 0;
    overflow: hidden;
    padding-top: 0;
    transition: max-height 0.2s ease;
  }

  .menu .menu-item-has-children.is-open > .sub-menu{
    max-height: 480px;
    padding-top: 4px;
  }

  .menu .sub-menu a{
    padding: 7px 10px;
    border-radius: 8px;
    font-size: 0.96rem;
  }

  .site-nav__cta{
    display: inline-flex;
    width: 100%;
    margin-top: 10px;
  }
}

/* =========================
   5. Hero
   ========================= */

.hero{
  position: relative;
  isolation: isolate;
  overflow: clip;
  padding-block: 0;
  border-bottom: 1px solid var(--border);
}

.hero::before,
.hero::after{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero::before{
  z-index: 0;
  background:
    radial-gradient(900px 420px at 50% 0%, rgba(34,197,94,0.16), transparent 60%),
    linear-gradient(180deg, rgba(11,15,20,0.92) 0%, rgba(11,15,20,0.84) 48%, rgba(11,15,20,0.96) 100%);
}

.hero::after{
  z-index: -1;
  opacity: 0;
  transform: scale(1.08);
  filter: blur(10px);
  background-image: var(--hero-bg-image);
  background-size: cover;
  background-position: center;
  transition: opacity 0.3s ease;
}

.hero.has-bg::after{
  opacity: 0.3;
}

.hero .container{
  position: relative;
  z-index: 2;
  padding-top: clamp(22px, 4vw, 48px);
  padding-bottom: clamp(38px, 6.2vw, 82px);
}

.hero__inner{
  display: grid;
  gap: clamp(24px, 3vw, 42px);
}

.hero__content{
  max-width: 820px;
  margin-inline: auto;
  text-align: center;
}

.hero__title{
  font-size: var(--fs-3);
  line-height: 1.08;
  margin-bottom: var(--space-3);
}

.hero__subtitle{
  font-size: var(--fs-1);
  margin-bottom: var(--space-4);
  max-width: 56ch;
  margin-inline: auto;
  color: var(--muted);
}

.hero__buttons{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
}

.hero__media{
  position: relative;
  margin: 0;
  border-radius: calc(var(--radius) + 10px);
  overflow: hidden;
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow);
}

.hero__media::before{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(11,15,20,0.1), rgba(11,15,20,0.3));
}

.hero__image{
  width: 100%;
  display: block;
  min-height: clamp(300px, 44vw, 560px);
  max-height: 66vh;
  object-fit: cover;
  object-position: center;
}

@media (min-width: 1200px){
  .hero__media{
    margin-inline: calc(-1 * var(--space-4));
  }
}

@media (max-width: 719px){
  .hero__buttons{
    flex-direction: column;
    align-items: stretch;
  }

  .hero__buttons .btn{
    width: 100%;
  }
}

/* =========================
   6. Typography
   ========================= */

.h2{
  font-size: var(--fs-2);
  margin-bottom: var(--space-3);
}

.eyebrow{
  color: var(--muted-2);
  text-transform: uppercase;
  font-weight: 800;
  font-size: 0.8rem;
  margin-bottom: var(--space-2);
  letter-spacing: 0.08em;
}

.muted{ color: var(--muted); }

.prose{
  max-width: 70ch;
}
.prose p{ margin-bottom: var(--space-3); }

/* =========================
   7. Content Block
   ========================= */

.content-block__grid{
  display: grid;
  gap: var(--space-4);
  align-items: center;
}

.content-block__text{
  order: 1;
}

.content-block__media{
  order: 2;
  margin: 0;
  border-radius: calc(var(--radius) + 4px);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.content-block__media img{
  width: 100%;
  display: block;
  height: auto;
}

@media (min-width: 900px){
  .content-block__grid{
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--space-5);
  }

  .content-block__grid .content-block__text{
    order: 1;
  }

  .content-block__grid .content-block__media{
    order: 2;
  }

  .content-block__grid.is-reversed .content-block__media{
    order: 1;
  }

  .content-block__grid.is-reversed .content-block__text{
    order: 2;
  }

  .content-block__grid.is-centered{
    grid-template-columns: 1fr;
    max-width: 720px;
    margin-inline: auto;
  }
}

/* =========================
   8. Cards / Features
   ========================= */

.features__grid{
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

@media (min-width: 720px){
  .features__grid.cols-2{ grid-template-columns: repeat(2, 1fr); }
  .features__grid.cols-3{ grid-template-columns: repeat(3, 1fr); }
  .features__grid.cols-4{ grid-template-columns: repeat(4, 1fr); }
}

.card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4);
  transition: 0.2s ease;
}

.card:hover{
  border-color: rgba(34,197,94,0.3);
  box-shadow: var(--shadow);
}

.card__media-link{
  display: block;
  margin-bottom: var(--space-3);
  border-radius: calc(var(--radius) - 4px);
  overflow: hidden;
}

.card__media-image{
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

.card__title{
  margin-bottom: var(--space-2);
}

.card__title-link{
  color: var(--text);
}

.card__title-link:hover{
  color: var(--accent-hover);
}

.card__text{
  color: var(--muted);
}

/* =========================
   8b. Pricing Packages
   ========================= */

.pricing-packages__intro{
  max-width: 64ch;
}

.pricing-packages__grid{
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

@media (min-width: 900px){
  .pricing-packages__grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.pricing-package-card{
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 2px);
  padding: clamp(20px, 2.2vw, 32px);
  min-height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}

.pricing-package-card.is-popular{
  border-color: rgba(34,197,94,0.65);
  box-shadow: 0 0 0 1px rgba(34,197,94,0.26), 0 20px 40px rgba(0,0,0,0.25);
}

@media (min-width: 900px){
  .pricing-package-card.is-popular{
    transform: translateY(-6px);
  }
}

.pricing-package-card__badge{
  margin: 0 0 var(--space-2);
  align-self: center;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(34,197,94,0.42);
  background: rgba(34,197,94,0.13);
  color: #d1fae5;
  font-size: 0.82rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.pricing-package-card__label{
  margin: 0;
  text-align: center;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  line-height: 1;
}

.pricing-package-card__fit{
  margin: var(--space-3) 0;
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.45;
}

.pricing-package-card__prices{
  margin-bottom: var(--space-3);
  border-top: 1px solid rgba(255,255,255,0.08);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding-block: 10px;
}

.pricing-package-card__price-line{
  margin: 0;
  display: grid;
  grid-template-columns: 8.5rem minmax(0, 1fr);
  align-items: baseline;
  column-gap: 10px;
  line-height: 1.25;
}

.pricing-package-card__price-line + .pricing-package-card__price-line{
  margin-top: 10px;
}

.pricing-package-card__price-key{
  color: var(--muted);
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.pricing-package-card__price-value{
  color: var(--text);
  font-size: clamp(1.4rem, 1.55vw, 1.95rem);
  font-weight: 740;
  white-space: nowrap;
  justify-self: end;
  font-variant-numeric: tabular-nums;
}

.pricing-package-card__features{
  margin: 0;
  padding-left: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.pricing-package-card__features li{
  color: var(--muted);
  line-height: 1.45;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.pricing-package-card__features li::before{
  content: "";
  width: 7px;
  height: 7px;
  margin-top: 0.6em;
  flex: 0 0 7px;
  border-radius: 999px;
  background: rgba(34,197,94,0.65);
}

.pricing-package-card__cta{
  margin-top: auto;
  padding-top: var(--space-4);
}

.pricing-package-card__cta .btn{
  width: 100%;
}

@media (max-width: 720px){
  .pricing-package-card{
    padding: 18px;
  }

  .pricing-package-card__label{
    font-size: clamp(1.9rem, 9vw, 2.5rem);
  }

  .pricing-package-card__fit{
    font-size: 0.92rem;
    line-height: 1.4;
  }

  .pricing-package-card__price-line{
    grid-template-columns: 6.2rem minmax(0, 1fr);
    column-gap: 8px;
  }

  .pricing-package-card__price-key{
    font-size: 0.8rem;
  }

  .pricing-package-card__price-value{
    font-size: clamp(1.18rem, 6.4vw, 1.55rem);
    white-space: normal;
  }

  .pricing-package-card__features{
    gap: 8px;
  }

  .pricing-package-card__cta{
    padding-top: var(--space-3);
  }
}

/* =========================
   9. CTA
   ========================= */

.cta__box{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: calc(var(--radius) + 6px);
  padding: var(--space-5);
  display: grid;
  gap: var(--space-4);
}

@media (min-width: 900px){
  .cta__box{
    grid-template-columns: 1fr auto;
    align-items: center;
  }
}

/* =========================
   10. FAQ
   ========================= */

.faq__list{
  display: grid;
  gap: var(--space-2);
}

.faq__item{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-3);
}

.faq__q{
  font-weight: 700;
  cursor: pointer;
}

.faq__a{
  padding-top: var(--space-2);
  color: var(--muted);
}

/* =========================
   11. Logos
   ========================= */

.logos__row{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin-top: var(--space-4);
}

@media (min-width: 720px){
  .logos__row{ grid-template-columns: repeat(6, 1fr); }
}

.logos__item{
  background: linear-gradient(180deg, rgba(19,30,48,0.86), rgba(13,21,35,0.92));
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  padding: var(--space-3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.logos__item img{
  max-height: 38px;
  width: auto;
  margin-inline: auto;
  opacity: 0.88;
  filter: grayscale(100%) brightness(0) invert(92%) contrast(115%);
  transition: opacity 0.2s ease, filter 0.2s ease;
}

.logos__item:hover{
  border-color: rgba(34,197,94,0.45);
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(0,0,0,0.28);
}

.logos__item:hover img{
  opacity: 1;
  filter: grayscale(0%) brightness(1.08) contrast(1.05);
}

/* =========================
   11b. Logo Wall
   ========================= */

.logo-wall__intro{
  max-width: 64ch;
}

.logo-wall__grid{
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

@media (min-width: 720px){
  .logo-wall__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1100px){
  .logo-wall__grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.logo-wall__card{
  background: linear-gradient(180deg, rgba(19,30,48,0.86), rgba(13,21,35,0.92));
  border: 1px solid var(--border-strong);
  border-radius: calc(var(--radius) + 2px);
  overflow: hidden;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.logo-wall__card:hover{
  border-color: rgba(34,197,94,0.42);
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.3);
}

.logo-wall__card-link{
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
  color: inherit;
}

.logo-wall__logo-wrap{
  min-height: 66px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-wall__logo{
  max-height: 44px;
  width: auto;
  max-width: 100%;
  display: block;
  margin-inline: auto;
  object-fit: contain;
  filter: grayscale(100%) brightness(0) invert(92%) contrast(112%);
  opacity: 0.95;
}

.logo-wall__name{
  margin: 0;
  font-size: 1.1rem;
  line-height: 1.25;
}

.logo-wall__facts{
  display: grid;
  gap: 8px;
}

.logo-wall__fact{
  margin: 0;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 8px;
}

.logo-wall__fact span{
  color: var(--muted-2);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.logo-wall__fact strong{
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 650;
  text-align: right;
}

@media (max-width: 719px){
  .logo-wall__card-link{
    gap: var(--space-2);
    padding: 18px;
  }

  .logo-wall__logo-wrap{
    min-height: 54px;
  }

  .logo-wall__logo{
    max-height: 36px;
    width: 100%;
    max-width: 220px;
    filter: grayscale(100%) brightness(0) invert(94%) contrast(115%) !important;
    opacity: 1;
  }

  .logo-wall__name{
    text-align: center;
    font-size: 1rem;
  }

  .logo-wall__facts{
    gap: 10px;
  }

  .logo-wall__fact{
    display: grid;
    grid-template-columns: 1fr;
    gap: 2px;
    justify-content: start;
    align-items: start;
  }

  .logo-wall__fact strong{
    text-align: left;
    font-size: 0.92rem;
  }
}

/* =========================
   12. Testimonials
   ========================= */

.testimonials__grid{
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

@media (min-width: 900px){
  .testimonials__grid{
    grid-template-columns: repeat(3, 1fr);
  }
}

.quote-card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4);
  display: grid;
  gap: var(--space-4);
}

.quote-card__meta{
  color: var(--muted);
  font-size: 0.9rem;
}

/* =========================
   13. Single
   ========================= */

.single-entry{
  border-bottom: 1px solid var(--border);
}

.single-hero{
  padding-block: clamp(36px, 6vw, 72px) clamp(18px, 3.2vw, 36px);
}

.single-hero__inner{
  max-width: none;
}

.single-hero__kicker{
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  font-size: 0.78rem;
  color: var(--muted-2);
  margin-bottom: var(--space-2);
  max-width: 70ch;
}

.single-hero__kicker a{
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
}

.single-hero__kicker a:hover{
  color: var(--text);
  border-bottom-color: rgba(255,255,255,0.24);
}

.single-hero__title{
  font-size: clamp(2rem, 3.2vw, 3.3rem);
  line-height: 1.08;
  margin: 0 0 var(--space-3);
  max-width: 30ch;
}

.single-hero__excerpt{
  margin: 0 0 var(--space-3);
  font-size: var(--fs-1);
  color: var(--muted);
  max-width: 64ch;
}

.single-hero__meta{
  display: inline-flex;
  gap: 10px;
  align-items: center;
  color: var(--muted-2);
  font-size: 0.95rem;
  margin-bottom: var(--space-4);
  max-width: 70ch;
}

.single-hero__media{
  margin: 0;
  border-radius: calc(var(--radius) + 6px);
  overflow: hidden;
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow);
}

.single-hero__media img{
  width: 100%;
  display: block;
  aspect-ratio: 16 / 8.2;
  object-fit: cover;
}

.single-body{
  padding-top: clamp(20px, 3.5vw, 44px);
}

.single-toc-mobile-wrap{
  display: none;
  margin-bottom: var(--space-4);
}

.single-toc-mobile-card{
  background: var(--surface);
}

.single-body__grid{
  display: grid;
  gap: var(--space-5);
}

.single-body__content{
  max-width: 70ch;
}

.single-body__content h2,
.single-body__content h3{
  scroll-margin-top: 120px;
}

.single-body__aside{
  align-self: start;
}

.single-service-cta{
  margin-top: var(--space-6);
  margin-bottom: var(--space-6);
}

.single-service-cta__title{
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 1.8vw, 1.85rem);
  line-height: 1.2;
}

.single-service-cta__body{
  margin: 0;
  color: var(--muted);
}

.single-author{
  margin-top: 0;
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: start;
}

.single-author__avatar img{
  width: 128px;
  aspect-ratio: 4 / 5;
  height: auto;
  object-fit: cover;
  border-radius: calc(var(--radius) + 4px);
  border: 1px solid var(--border-strong);
}

.single-author__label{
  margin: 0 0 4px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  font-size: 0.75rem;
  color: var(--muted-2);
}

.single-author__name{
  margin: 0 0 8px;
  font-size: 1.2rem;
}

.single-author__bio{
  margin: 0;
  color: var(--muted);
}

.single-aside__card{
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-4);
}

.single-aside__title{
  margin: 0 0 var(--space-2);
}

.single-aside__text{
  margin: 0 0 var(--space-3);
  color: var(--muted);
}

.single-toc{
  position: sticky;
  top: 110px;
}

.single-toc__list{
  list-style: none;
  margin: 0;
  padding: var(--space-2) 0 0;
  display: grid;
  gap: 8px;
}

.single-toc__details{
  display: block;
}

.single-toc__summary{
  list-style: none;
  cursor: pointer;
  margin: 0;
}

.single-toc__summary::-webkit-details-marker{
  display: none;
}

.single-toc__summary::after{
  content: "";
  display: inline-block;
  flex: 0 0 auto;
  margin-left: 8px;
  width: 8px;
  height: 8px;
  border-right: 1.8px solid currentColor;
  border-bottom: 1.8px solid currentColor;
  transform: rotate(45deg);
  opacity: 0.78;
  transition: transform 0.15s ease, opacity 0.15s ease;
  color: var(--muted-2);
}

.single-toc__details[open] .single-toc__summary::after{
  transform: rotate(-135deg);
  opacity: 1;
}

.single-toc__item{
  margin: 0;
}

.single-toc__sublist{
  list-style: none;
  margin: 0;
  padding: 0;
  display: none;
}

.single-toc__item--h2.is-expanded > .single-toc__sublist{
  display: grid;
  gap: 6px;
  padding-top: 6px;
}

.single-toc__item--h3{
  padding-left: 14px;
}

.single-toc__link{
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.35;
  display: inline-block;
  border-left: 2px solid transparent;
  padding-left: 10px;
}

.single-toc__link:hover{
  color: var(--text);
}

.single-toc__link.is-active{
  color: var(--accent-hover);
  border-left-color: var(--accent-hover);
}

.single-related{
  padding-top: 0;
}

.single-related__title{
  margin-bottom: var(--space-4);
}

.single-related__card{
  height: 100%;
}

/* =========================
   14. Category Archive
   ========================= */

.category-archive__hero{
  padding-bottom: var(--space-4);
}

.category-archive__title{
  margin-bottom: var(--space-2);
}

.category-archive__description{
  max-width: 70ch;
}

.category-archive__list{
  padding-top: 0;
}

.category-archive__grid{
  margin-top: 0;
}

.category-archive__meta{
  margin: 0 0 var(--space-2);
  font-size: 0.9rem;
  display: inline-flex;
  gap: 8px;
  align-items: center;
}

.category-archive__pagination{
  margin-top: var(--space-5);
}

.category-archive__pagination .nav-links{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.category-archive__pagination .page-numbers{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 38px;
  height: 38px;
  padding-inline: 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
}

.category-archive__pagination .page-numbers.current{
  border-color: var(--accent);
  color: var(--text);
}

/* =========================
   15. Footer
   ========================= */

.site-footer{
  border-top: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(10,16,26,0.72), rgba(8,12,18,0.9));
  padding-block: var(--space-6) var(--space-4);
}

.site-footer__grid{
  display: grid;
  gap: var(--space-5);
}

.site-footer__logo{
  display: inline-block;
  color: var(--text);
  font-weight: 800;
  font-size: 1.4rem;
  margin-bottom: var(--space-2);
}

.site-footer__logo:hover{
  color: var(--text);
}

.site-footer__desc{
  margin: 0;
  color: var(--muted);
  max-width: 48ch;
}

.footer-menu{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.footer-menu a{
  color: var(--muted);
}

.footer-menu a:hover{
  color: var(--text);
}

.site-footer__bottom{
  margin-top: var(--space-5);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.site-footer__copy{
  margin: 0;
  color: var(--muted-2);
  font-size: 0.9rem;
}

@media (min-width: 860px){
  .site-footer__grid{
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
    align-items: start;
  }

  .site-footer__nav{
    justify-self: end;
  }

  .footer-menu{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
  }
}

@media (min-width: 980px){
  .single-body__grid{
    grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
  }
}

@media (max-width: 560px){
  .single-hero__meta{
    display: grid;
    gap: 6px;
  }

  .single-hero__meta span[aria-hidden="true"]{
    display: none;
  }

  .single-author{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px){
  .single-toc{ display: none; }
  .single-toc-mobile-wrap{ display: block; }
}

/* =========================
   16. Gravity Forms — dark override
   ========================= */

.gform_wrapper.gform-theme,
.gform_wrapper.gform-theme[data-form-index="0"]{
  --gf-color-primary: var(--accent) !important;
  --gf-color-primary-rgb: 34, 197, 94 !important;
  --gf-color-primary-contrast: #fff !important;
  --gf-color-secondary: transparent !important;
  --gf-color-secondary-contrast: var(--text) !important;
  --gf-color-in-ctrl: rgba(255,255,255,0.06) !important;
  --gf-color-in-ctrl-rgb: 255, 255, 255 !important;
  --gf-color-in-ctrl-contrast: var(--text) !important;
  --gf-color-in-ctrl-contrast-rgb: 229, 231, 235 !important;
  --gf-color-in-ctrl-darker: rgba(255,255,255,0.04) !important;
  --gf-color-in-ctrl-lighter: rgba(255,255,255,0.08) !important;
  --gf-color-in-ctrl-primary: var(--accent) !important;
  --gf-color-in-ctrl-primary-rgb: 34, 197, 94 !important;
  --gf-color-in-ctrl-dark: var(--muted) !important;
  --gf-color-in-ctrl-dark-rgb: 163, 173, 194 !important;
  --gf-color-in-ctrl-dark-darker: var(--text) !important;
  --gf-color-in-ctrl-dark-lighter: var(--muted-2) !important;
  --gf-color-in-ctrl-light: rgba(255,255,255,0.14) !important;
  --gf-color-in-ctrl-light-rgb: 255, 255, 255 !important;
  --gf-color-in-ctrl-light-darker: rgba(255,255,255,0.22) !important;
  --gf-color-in-ctrl-light-lighter: rgba(255,255,255,0.06) !important;
  --gf-color-out-ctrl-dark: var(--muted) !important;
  --gf-color-out-ctrl-dark-rgb: 163, 173, 194 !important;
  --gf-color-out-ctrl-dark-darker: var(--text) !important;
  --gf-color-out-ctrl-dark-lighter: var(--muted-2) !important;
  --gf-color-out-ctrl-light: rgba(255,255,255,0.1) !important;
  --gf-color-out-ctrl-light-rgb: 255, 255, 255 !important;
  --gf-color-out-ctrl-light-darker: rgba(255,255,255,0.2) !important;
  --gf-color-out-ctrl-light-lighter: rgba(255,255,255,0.06) !important;
  --gf-ctrl-border-color: rgba(255,255,255,0.14) !important;
  --gf-ctrl-label-color-primary: var(--text) !important;
  --gf-ctrl-label-color-secondary: var(--muted) !important;
  --gf-ctrl-btn-border-color-secondary: rgba(255,255,255,0.14) !important;
}

.gform_wrapper .gfield_label,
.gform_wrapper .gform-field-label{
  color: var(--text) !important;
}

.gform_wrapper .gfield_description{
  color: var(--muted) !important;
}

.gform_wrapper .gfield_required_text{
  color: var(--accent) !important;
}

.gform_wrapper input:not([type="submit"]):not([type="hidden"]):not([type="checkbox"]):not([type="radio"]),
.gform_wrapper textarea,
.gform_wrapper select{
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  border-radius: var(--radius) !important;
  color: var(--text) !important;
  padding: 10px 14px;
}

.gform_wrapper input:not([type="submit"]):focus,
.gform_wrapper textarea:focus,
.gform_wrapper select:focus{
  border-color: var(--accent) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(34,197,94,0.25) !important;
}

.gform_wrapper .gform_footer input[type="submit"],
.gform_wrapper .gform_button{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px !important;
  border: none !important;
  border-radius: 999px !important;
  font-weight: 750;
  font-family: inherit;
  font-size: inherit;
  cursor: pointer;
  background: linear-gradient(135deg, var(--accent), var(--accent-hover)) !important;
  color: #f8fafc !important;
  transition: box-shadow 0.15s ease;
}

.gform_wrapper .gform_footer input[type="submit"]:hover,
.gform_wrapper .gform_button:hover{
  box-shadow: 0 0 0 1px rgba(34,197,94,0.3), 0 0 40px rgba(34,197,94,0.25) !important;
}

.gform_wrapper .gfield-choice-input[type="checkbox"],
.gform_wrapper .gfield-choice-input[type="radio"]{
  accent-color: var(--accent);
}

.gform_wrapper .gform-field-label--type-inline{
  color: var(--text) !important;
}
