/*-----------------------------------*\
  #style.css
\*-----------------------------------*/

/*-----------------------------------*\
  #CUSTOM PROPERTY
\*-----------------------------------*/

:root {

  /**
   * colors
   */

  --primary-blue: hsl(205, 78%, 45%);
  --primary-blue-dark: hsl(220, 46%, 15%);
  --primary-blue-light: hsl(202, 86%, 64%);
  --accent-sage: hsl(214, 58%, 34%);
  --accent-sage-light: hsl(206, 78%, 96%);
  --accent-clay: hsl(198, 82%, 58%);
  --lavender-gray: hsl(216, 18%, 72%);
  --eerie-black: hsl(220, 18%, 12%);
  --light-gray: hsl(210, 20%, 84%);
  --cultured-2: hsl(210, 44%, 97%);
  --platinum: hsl(213, 22%, 88%);
  --gray-web: hsl(218, 9%, 40%);
  --cultured: hsl(212, 26%, 92%);
  --black_10: hsla(0, 0%, 0%, 0.1);
  --black_5: hsla(0, 0%, 0%, 0.05);
  --white-1: hsl(0, 0%, 100%);
  --white-2: hsl(210, 55%, 98%);
  --black: hsl(0, 0%, 0%);

  /**
   * gradient color
   */

  --gradient: linear-gradient(135deg, var(--primary-blue-dark) 0%, var(--primary-blue) 58%, var(--primary-blue-light) 100%);

  /**
   * typography
   */

  --ff-roboto: 'Roboto', sans-serif;
  --ff-league-spartan: 'League Spartan', sans-serif;

  --fs-1: 3.5rem;
  --fs-2: 3rem;
  --fs-3: 2.1rem;
  --fs-4: 1.7rem;
  --fs-5: 1.4rem;
  --fs-6: 1.3rem;

  --fw-700: 700;
  --fw-500: 500;

  /**
   * spacing
   */

  --section-padding: 60px;

  /**
   * shadow
   */

  --shadow-1: 0 6px 24px var(--black_5);
  --shadow-2: 0 2px 28px var(--black_10);

  /**
   * border radius
   */

  --radius-2: 2px;
  --radius-5: 5px;
  --radius-8: 8px;

  /**
   * transition
   */

  --transition-1: 0.25s ease;
  --transition-2: 0.5s ease;
  --cubic-out: cubic-bezier(0.33, 0.85, 0.4, 0.96);

}





/*-----------------------------------*\
  #RESET
\*-----------------------------------*/

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

li { list-style: none; }

a {
  text-decoration: none;
  color: inherit;
}

a,
img,
span,
time,
label,
input,
button,
textarea,
ion-icon { display: block; }

img { height: auto; }

input,
button,
textarea {
  background: none;
  border: none;
  font: inherit;
}

input,
textarea { width: 100%; }

button { cursor: pointer; }

ion-icon { pointer-events: none; }

address { font-style: normal; }

html {
  font-family: var(--ff-roboto);
  font-size: 10px;
  scroll-behavior: smooth;
}

body {
  background-color: var(--white-2);
  color: var(--gray-web);
  font-size: 1.6rem;
  line-height: 1.8;
  overflow-x: hidden;
}

body.modal-open { overflow: hidden; }

::-webkit-scrollbar { width: 10px; }

::-webkit-scrollbar-track { background-color: hsl(0, 0%, 98%); }

::-webkit-scrollbar-thumb { background-color: hsl(0, 0%, 80%); }

::-webkit-scrollbar-thumb:hover { background-color: hsl(0, 0%, 70%); }

:focus-visible { outline-offset: 4px; }





/*-----------------------------------*\
  #REUSED STYLE
\*-----------------------------------*/

.container { padding-inline: 15px; }

.btn {
  max-width: max-content;
  color: var(--white-1);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  padding: 10px 30px;
  border-radius: var(--radius-5);
  text-align: center;
  transition: var(--transition-1);
}

.btn-primary {
  background-image: var(--gradient);
  background-size: 160%;
  box-shadow: 0 12px 26px hsla(205, 78%, 45%, 0.18);
}

.btn-primary:is(:hover, :focus) { background-position: bottom right; }

.btn-secondary {
  background-color: var(--white-1);
  color: var(--eerie-black);
}

.btn-secondary:is(:hover, :focus) {
  background-color: var(--eerie-black);
  color: var(--white-1);
}

.section { padding-block: var(--section-padding); }

.h1,
.h2,
.h3 {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  line-height: 1.2;
}

.h1 { font-size: var(--fs-1); }

.h2 { font-size: var(--fs-2); }

.h3 { font-size: var(--fs-3); }

.w-100 { width: 100%; }

.section-title,
.section-text { text-align: center; }

.section-text { font-size: var(--fs-6); }

.grid-list {
  display: grid;
  gap: 30px;
}

.img-holder {
  aspect-ratio: var(--width) / var(--height);
  background-color: var(--light-gray);
}

.img-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
}





/*-----------------------------------*\
  #HEADER
\*-----------------------------------*/

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background-color: hsla(210, 55%, 98%, 0.92);
  padding-block: 6px;
  border-block-end: 1px solid hsla(220, 18%, 12%, 0.08);
  z-index: 4;
  transition: var(--transition-1);
  backdrop-filter: blur(12px);
}

.header.active { filter: drop-shadow(var(--shadow-2)); }

.header > .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  min-height: 52px;
  position: relative;
}

.logo {
  width: 192px;
  height: 46px;
  max-width: calc(100% - 64px);
  flex-shrink: 1;
  overflow: visible;
  position: relative;
  z-index: 1;
}

.logo img {
  width: 100%;
  height: 58px;
  object-fit: contain;
  object-position: left center;
  pointer-events: none;
  transform: translateY(-4px) scale(1.13);
  transform-origin: left center;
}

.nav-toggle-btn {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  color: var(--primary-blue-dark);
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  flex-shrink: 0;
  font-size: 40px;
  position: relative;
  z-index: 3;
}

.nav-toggle-btn.active .open,
.nav-toggle-btn .close { display: none; }

.nav-toggle-btn .open,
.nav-toggle-btn.active .close { display: block; }

.navbar {
  background-color: hsla(44, 40%, 97%, 0.98);
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  max-width: calc(100% - 30px);
  width: 100%;
  padding-inline: 0;
  border: 1px solid var(--cultured);
  transition: 0.3s var(--cubic-out);
  max-height: 0;
  visibility: hidden;
  overflow: hidden;
  z-index: 5;
}

.navbar.active {
  max-height: 320px;
  visibility: visible;
  transition-duration: 0.5s;
}

.navbar-list {
  padding: 20px 15px;
  padding-block-start: 10px;
  opacity: 0;
  transition: var(--transition-1);
}

.navbar.active .navbar-list { opacity: 1; }

.navbar-link {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: var(--fs-4);
  line-height: 1.2;
  padding-block: 8px;
  transition: var(--transition-1);
}

.navbar-link:is(:hover, :focus) { color: var(--primary-blue); }

.header .btn { margin-block-start: 10px; }





/*-----------------------------------*\
  #HEO
\*-----------------------------------*/

.hero {
  background:
    radial-gradient(circle at 12% 10%, hsla(205, 78%, 45%, 0.09), transparent 30%),
    radial-gradient(circle at 88% 8%, hsla(202, 86%, 64%, 0.12), transparent 28%),
    linear-gradient(180deg, var(--white-1), var(--white-2));
  padding-block-start: calc(var(--section-padding) + 50px);
  text-align: center;
}

.hero-content { margin-block-end: 30px; }

.hero-subtitle {
  color: var(--eerie-black);
  font-size: var(--fs-5);
  font-weight: var(--fw-500);
}

.hero-title { margin-block: 12px 8px; }

.hero-text { font-size: var(--fs-5); }

.hero .btn {
  margin-inline: auto;
  margin-block-start: 20px;
}





/*-----------------------------------*\
  #SERVICE
\*-----------------------------------*/

.category-showcase {
  display: grid;
  background-color: var(--primary-blue-dark);
}

.category-showcase-card {
  position: relative;
  min-height: 170px;
  overflow: hidden;
  isolation: isolate;
}

.category-showcase-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.22) saturate(0.96) contrast(0.98);
  transition: var(--transition-2);
}

.category-showcase-card:nth-child(2) img {
  object-position: top center;
}

.category-showcase-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, transparent 38%, hsla(220, 18%, 12%, 0.5)),
    linear-gradient(135deg, hsla(205, 78%, 45%, 0.24), transparent 48%);
  z-index: 0;
}

.category-showcase-card:is(:hover, :focus) img {
  transform: scale(1.04);
}

.category-showcase-btn {
  position: absolute;
  right: 16px;
  bottom: 16px;
  z-index: 1;
  width: max-content;
  color: var(--eerie-black);
  background-color: hsla(0, 0%, 100%, 0.92);
  border: 1px solid hsla(0, 0%, 100%, 0.62);
  border-radius: var(--radius-5);
  font-size: 1.25rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 9px 12px;
  transition: var(--transition-1);
}

.category-showcase-card:is(:hover, :focus) .category-showcase-btn {
  color: var(--white-1);
  background-color: var(--primary-blue);
  border-color: var(--primary-blue);
}

@media (min-width: 768px) {
  .category-showcase { grid-template-columns: repeat(3, 1fr); }

  .category-showcase-card { min-height: 210px; }
}

@media (min-width: 1200px) {
  .category-showcase-card { min-height: 250px; }
}

.service {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, var(--white-1) 0%, var(--white-2) 44%, var(--accent-sage-light) 100%);
}

.service::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 10% 10%, hsla(205, 78%, 45%, 0.08), transparent 28%),
    radial-gradient(circle at 88% 18%, hsla(202, 86%, 64%, 0.11), transparent 30%);
  pointer-events: none;
}

.service > .container {
  position: relative;
  z-index: 1;
}

.service-head {
  max-width: 820px;
  margin-inline: auto;
  margin-block-end: 36px;
  text-align: center;
}

.service-kicker {
  width: max-content;
  margin-inline: auto;
  margin-block-end: 12px;
  color: var(--primary-blue);
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: 999px;
  box-shadow: var(--shadow-1);
  font-size: 1.22rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 8px 12px;
  text-transform: uppercase;
}

.service .section-text {
  margin-block: 8px 0;
}

.service-highlights {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-block-start: 22px;
}

.service-highlights li {
  color: var(--eerie-black);
  background-color: hsla(0, 0%, 100%, 0.76);
  border: 1px solid var(--platinum);
  border-radius: 999px;
  box-shadow: var(--shadow-1);
  font-size: 1.25rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 9px 12px;
}

.service .grid-list {
  align-items: stretch;
  gap: 18px;
}

.service-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 380px;
  height: 100%;
  background:
    linear-gradient(180deg, hsla(0, 0%, 100%, 0.98), hsla(210, 44%, 97%, 0.94));
  padding: 26px;
  border: 1px solid hsla(213, 25%, 78%, 0.72);
  border-radius: var(--radius-8);
  text-align: left;
  box-shadow: 0 16px 36px hsla(220, 18%, 12%, 0.08);
  transition: var(--transition-2);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.service-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, var(--primary-blue), var(--accent-clay));
  opacity: 0.82;
  z-index: -1;
}

.service-card::after {
  content: "";
  position: absolute;
  right: -46px;
  bottom: -46px;
  width: 140px;
  height: 140px;
  background:
    linear-gradient(135deg, hsla(205, 78%, 45%, 0.11), hsla(202, 86%, 64%, 0.1));
  border-radius: 32px;
  transform: rotate(18deg);
  z-index: -1;
}

.service-card:is(:hover, :focus-within) {
  border-color: hsla(205, 78%, 45%, 0.42);
  box-shadow: 0 24px 54px hsla(220, 18%, 12%, 0.12);
  transform: translateY(-8px);
}

.service-card .card-icon {
  color: var(--white-1);
  width: 68px;
  height: 68px;
  border: 6px solid hsla(0, 0%, 100%, 0.72);
  border-radius: 20px;
  box-shadow: 0 14px 28px hsla(220, 18%, 12%, 0.14);
  display: grid;
  flex-shrink: 0;
  overflow: hidden;
  place-items: center;
  transform: rotate(-2deg);
}

.service-card .card-icon img {
  width: 42px;
  height: 42px;
  object-fit: contain;
}

.service-card .card-title {
  margin-block: 22px 10px;
  transition: var(--transition-1);
}

.service-card .card-title:is(:hover, :focus) {
  color: var(--primary-blue);
}

.service-card .card-text {
  font-size: var(--fs-6);
  line-height: 1.65;
}

.service-more-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  color: var(--eerie-black);
  background-color: var(--white-1);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  line-height: 1;
  margin-block-start: auto;
  padding: 10px 14px;
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  box-shadow: var(--shadow-1);
  transition: var(--transition-1);
}

.service-more-link::after {
  content: "->";
  line-height: 1;
  transition: var(--transition-1);
}

.service-more-link:is(:hover, :focus) {
  color: var(--white-1);
  background-color: var(--primary-blue-dark);
  border-color: var(--primary-blue);
}

.service-more-link:is(:hover, :focus)::after {
  transform: translateX(3px);
}





/*-----------------------------------*\
  #SERVICE DETAIL
\*-----------------------------------*/

.service-detail-hero {
  background-color: var(--white-2);
  padding-block: calc(var(--section-padding) + 55px) 55px;
}

.service-detail-back {
  color: var(--primary-blue);
  display: inline-block;
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  margin-block-end: 28px;
}

.service-detail-back:is(:hover, :focus) { text-decoration: underline; }

.service-detail-head {
  display: grid;
  gap: 22px;
}

.service-detail-icon {
  display: grid;
  place-items: center;
  width: 92px;
  height: 92px;
  border-radius: 50%;
}

.service-detail-icon img {
  width: 56px;
  height: 56px;
  object-fit: contain;
}

.service-detail-kicker {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  text-transform: uppercase;
}

.service-detail-title {
  margin-block: 8px 12px;
}

.service-detail-summary {
  max-width: 62ch;
  color: var(--gray-web);
  font-size: var(--fs-5);
}

.service-detail-content {
  padding-block: 60px;
}

.service-detail-grid {
  display: grid;
  gap: 28px;
}

.service-detail-main,
.service-detail-panel {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 24px;
}

.service-detail-main .h2,
.service-detail-main .h3,
.service-detail-panel .h3 {
  margin-block-end: 12px;
}

.service-detail-main .h3 {
  margin-block-start: 28px;
}

.service-detail-main p {
  font-size: var(--fs-6);
}

.service-detail-list {
  display: grid;
  gap: 10px;
}

.service-detail-list li {
  position: relative;
  padding-inline-start: 20px;
  font-size: var(--fs-6);
}

.service-detail-list li::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 7px;
  height: 7px;
  background-color: var(--primary-blue);
  border-radius: 50%;
}

.service-detail-list.compact {
  margin-block-end: 24px;
}





/*-----------------------------------*\
  #CATEGORY PAGES
\*-----------------------------------*/

.category-page-hero {
  background:
    radial-gradient(circle at 14% 0%, hsla(205, 78%, 45%, 0.1), transparent 28%),
    radial-gradient(circle at 84% 14%, hsla(202, 86%, 64%, 0.12), transparent 30%),
    linear-gradient(135deg, var(--white-2) 0%, var(--accent-sage-light) 100%);
  padding-block-start: 58px;
}

.category-page-hero-media {
  width: 100%;
  height: clamp(230px, 44vw, 470px);
  overflow: hidden;
}

.category-page-hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.2) saturate(0.96) contrast(0.98);
}

.category-page-hero.programador .category-page-hero-media img {
  object-position: top center;
}

.category-page-intro {
  padding-block: 44px 58px;
}

.category-page-kicker {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  line-height: 1;
  text-transform: uppercase;
}

.category-page-title {
  max-width: 13ch;
  margin-block: 10px 14px;
}

.category-page-text {
  max-width: 68ch;
  color: var(--gray-web);
  font-size: var(--fs-5);
}

.category-page-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-block-start: 24px;
}

.category-page-actions .btn-secondary {
  border: 1px solid var(--platinum);
}

.category-hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-block-start: 26px;
}

.category-hero-proof span {
  width: max-content;
  color: var(--eerie-black);
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: 999px;
  box-shadow: var(--shadow-1);
  font-size: 1.25rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 9px 12px;
}

.category-impact-section,
.category-before-after-section,
.category-gallery-section,
.category-results-section {
  padding-block: 60px;
  background-color: var(--white-1);
}

.category-impact-section.dark,
.category-results-section.dark {
  color: var(--white-1);
  background:
    radial-gradient(circle at 12% 8%, hsla(205, 78%, 45%, 0.22), transparent 30%),
    radial-gradient(circle at 88% 12%, hsla(202, 86%, 64%, 0.16), transparent 32%),
    linear-gradient(135deg, hsl(220, 46%, 12%), hsl(215, 44%, 18%));
}

.category-impact-grid {
  display: grid;
  gap: 30px;
  align-items: center;
}

.category-impact-copy .h2,
.category-impact-copy .h3 {
  margin-block-end: 12px;
}

.category-impact-copy p {
  max-width: 62ch;
  font-size: var(--fs-6);
}

.category-impact-section.dark .h2,
.category-impact-section.dark .h3,
.category-results-section.dark .h2 {
  color: var(--white-1);
}

.category-impact-section.dark p,
.category-results-section.dark p {
  color: hsl(218, 14%, 78%);
}

.category-impact-media {
  position: relative;
  min-height: 320px;
  overflow: hidden;
  border-radius: var(--radius-8);
  background-color: var(--white-2);
}

.category-impact-media img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  filter: grayscale(0.18) saturate(0.96) contrast(0.98);
}

.category-floating-stat {
  position: absolute;
  left: 16px;
  bottom: 16px;
  display: grid;
  gap: 4px;
  width: min(230px, calc(100% - 32px));
  color: var(--eerie-black);
  background-color: hsla(0, 0%, 100%, 0.92);
  border: 1px solid hsla(0, 0%, 100%, 0.72);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
  padding: 14px;
  backdrop-filter: blur(8px);
}

.category-floating-stat strong {
  font-family: var(--ff-league-spartan);
  font-size: 2.8rem;
  line-height: 1;
}

.category-floating-stat span {
  font-size: 1.25rem;
  font-weight: var(--fw-700);
  line-height: 1.35;
}

.category-metric-grid {
  display: grid;
  gap: 16px;
  margin-block-start: 28px;
}

.category-metric-card {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.category-results-section.dark .category-metric-card {
  background-color: hsl(220, 18%, 16%);
  border-color: hsla(202, 86%, 64%, 0.24);
}

.category-metric-card strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 3rem;
  line-height: 1;
}

.category-results-section.dark .category-metric-card strong {
  color: var(--white-1);
}

.category-metric-card p {
  margin-block: 8px 12px;
  font-size: 1.34rem;
  line-height: 1.45;
}

.category-meter {
  height: 8px;
  overflow: hidden;
  background-color: hsl(0, 0%, 88%);
  border-radius: 999px;
}

.category-results-section.dark .category-meter {
  background-color: hsl(220, 12%, 26%);
}

.category-meter span {
  height: 100%;
  background-image: var(--gradient);
  border-radius: inherit;
}

.category-impact-dashboard {
  display: grid;
  gap: 18px;
}

.category-impact-score {
  display: grid;
  align-content: center;
  min-height: 260px;
  color: var(--white-1);
  background:
    radial-gradient(circle at 80% 14%, hsla(202, 86%, 64%, 0.2), transparent 32%),
    radial-gradient(circle at 20% 84%, hsla(205, 78%, 45%, 0.22), transparent 34%),
    linear-gradient(135deg, hsl(220, 46%, 13%), hsl(215, 44%, 18%));
  border: 1px solid hsla(202, 86%, 64%, 0.22);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
  padding: 28px;
}

.category-impact-score > span {
  width: max-content;
  color: var(--eerie-black);
  background-color: var(--white-1);
  border-radius: 999px;
  font-size: 1.15rem;
  font-weight: var(--fw-700);
  line-height: 1;
  margin-block-end: 18px;
  padding: 7px 10px;
  text-transform: uppercase;
}

.category-impact-score strong {
  color: var(--white-1);
  font-family: var(--ff-league-spartan);
  font-size: clamp(5rem, 12vw, 8.8rem);
  line-height: 0.82;
}

.category-impact-score p {
  max-width: 34ch;
  color: var(--lavender-gray);
  font-size: var(--fs-6);
  line-height: 1.55;
  margin-block-start: 18px;
}

.category-impact-levers {
  display: grid;
  gap: 14px;
}

.category-impact-levers article {
  display: grid;
  gap: 14px;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 20px;
}

.category-impact-levers strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.4rem;
  line-height: 1;
}

.category-impact-levers span {
  color: var(--gray-web);
  font-size: var(--fs-6);
  line-height: 1.45;
  margin-block-start: 6px;
}

.category-impact-bar {
  height: 12px;
  overflow: hidden;
  background-color: hsl(210, 10%, 90%);
  border-radius: 999px;
}

.category-impact-bar span {
  width: var(--level);
  height: 100%;
  background-image: var(--gradient);
  border-radius: inherit;
}

.category-impact-flow {
  display: grid;
  gap: 10px;
}

.category-impact-flow span {
  position: relative;
  color: var(--eerie-black);
  background-color: hsla(0, 0%, 100%, 0.86);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  font-size: 1.32rem;
  font-weight: var(--fw-700);
  line-height: 1.2;
  padding: 13px 14px;
  text-align: center;
}

.category-impact-flow span:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -10px;
  width: 2px;
  height: 10px;
  background-color: var(--primary-blue);
  transform: translateX(-50%);
}

.category-before-after-grid {
  display: grid;
  gap: 18px;
}

.category-before-after-section {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(180deg, var(--white-1), var(--white-2));
}

.category-before-after-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 8% 8%, hsla(205, 78%, 45%, 0.08), transparent 28%),
    radial-gradient(circle at 92% 12%, hsla(202, 86%, 64%, 0.11), transparent 26%);
  pointer-events: none;
}

.category-before-after-section > .container {
  position: relative;
  z-index: 1;
}

.category-before-after-showcase {
  display: grid;
  gap: 18px;
  align-items: stretch;
}

.category-before-after-panel {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: 0 18px 44px hsla(220, 18%, 12%, 0.08);
  padding: 24px;
}

.category-before-after-panel::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
}

.category-before-after-panel.is-before {
  background:
    linear-gradient(180deg, hsl(0, 0%, 100%), hsl(210, 44%, 97%));
}

.category-before-after-panel.is-before::before {
  background-color: var(--accent-clay);
}

.category-before-after-panel.is-after {
  background:
    linear-gradient(180deg, hsl(206, 78%, 98%), hsl(206, 70%, 94%));
  border-color: hsla(205, 78%, 45%, 0.34);
}

.category-before-after-panel.is-after::before {
  background-image: var(--gradient);
}

.category-before-after-panel-head {
  display: grid;
  gap: 10px;
  margin-block-end: 20px;
}

.category-before-after-panel-head span {
  width: max-content;
  color: var(--white-1);
  background-color: var(--eerie-black);
  border-radius: 999px;
  font-size: 1.12rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 7px 10px;
  text-transform: uppercase;
}

.category-before-after-panel.is-before .category-before-after-panel-head span {
  background-color: var(--accent-clay);
}

.category-before-after-panel.is-after .category-before-after-panel-head span {
  background-color: var(--primary-blue);
}

.category-before-after-panel-head strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.6rem;
  line-height: 1.05;
}

.category-snapshot {
  display: grid;
  gap: 10px;
  margin-block-end: 22px;
  padding: 18px;
  background-color: hsla(0, 0%, 100%, 0.72);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
}

.category-snapshot span {
  height: 12px;
  border-radius: 999px;
}

.category-snapshot.is-chaos span {
  background-color: hsl(210, 8%, 74%);
}

.category-snapshot.is-chaos span:nth-child(2),
.category-snapshot.is-chaos span:nth-child(4) {
  transform: translateX(12px);
  opacity: 0.62;
}

.category-snapshot.is-organized span {
  background-image: var(--gradient);
}

.category-snapshot.is-organized span:nth-child(2),
.category-snapshot.is-organized span:nth-child(4) {
  background-color: var(--accent-sage);
  background-image: none;
  opacity: 0.72;
}

.category-pain-list,
.category-result-list {
  display: grid;
  gap: 12px;
}

.category-pain-list li,
.category-result-list li {
  position: relative;
  padding-inline-start: 28px;
  color: var(--gray-web);
  font-size: var(--fs-6);
  line-height: 1.5;
}

.category-pain-list li::before,
.category-result-list li::before {
  position: absolute;
  top: 0;
  left: 0;
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  color: var(--white-1);
  font-size: 1.1rem;
  font-weight: var(--fw-700);
  line-height: 1;
}

.category-pain-list li::before {
  content: "!";
  background-color: var(--accent-clay);
}

.category-result-list li::before {
  content: "";
  background-color: var(--primary-blue);
}

.category-result-list li::after {
  content: "";
  position: absolute;
  top: 6px;
  left: 6px;
  width: 8px;
  height: 5px;
  border-inline-start: 2px solid var(--white-1);
  border-block-end: 2px solid var(--white-1);
  transform: rotate(-45deg);
}

.category-transform-marker {
  display: grid;
  place-items: center;
}

.category-transform-marker span {
  display: grid;
  place-items: center;
  width: 74px;
  height: 74px;
  color: var(--white-1);
  background-image: var(--gradient);
  border: 8px solid var(--white-1);
  border-radius: 50%;
  box-shadow: var(--shadow-2);
  font-size: 1.25rem;
  font-weight: var(--fw-700);
  line-height: 1;
  text-transform: uppercase;
}

.category-before-after-proof {
  display: grid;
  gap: 14px;
  margin-block-start: 22px;
}

.category-before-after-proof article {
  background-color: hsla(0, 0%, 100%, 0.86);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 18px;
}

.category-before-after-proof strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.2rem;
  line-height: 1;
}

.category-before-after-proof span {
  color: var(--gray-web);
  font-size: var(--fs-6);
  line-height: 1.45;
  margin-block-start: 7px;
}

.category-before-after-card {
  display: grid;
  gap: 18px;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 22px;
}

.category-before-after-side {
  display: grid;
  gap: 10px;
}

.category-before-after-label {
  width: max-content;
  color: var(--white-1);
  background-color: var(--accent-sage);
  border-radius: 999px;
  font-size: 1.15rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 7px 9px;
}

.category-before-after-card p {
  color: var(--gray-web);
  font-size: var(--fs-6);
}

.category-before-after-card strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.15rem;
  line-height: 1.1;
}

.category-gallery-grid {
  display: grid;
  gap: 20px;
}

.category-gallery-card {
  overflow: hidden;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
}

.category-gallery-card img {
  width: 100%;
  height: 230px;
  object-fit: cover;
  filter: grayscale(0.18) saturate(0.96) contrast(0.98);
}

.category-gallery-card div {
  padding: 20px;
}

.category-gallery-card .h3 {
  margin-block-end: 7px;
}

.category-gallery-card p {
  font-size: var(--fs-6);
}

.category-diagnostic-section {
  position: relative;
  isolation: isolate;
  padding-block: 78px;
  color: var(--eerie-black);
  background:
    linear-gradient(90deg, hsla(220, 18%, 12%, 0.035) 1px, transparent 1px),
    radial-gradient(circle at 86% 12%, hsla(202, 86%, 64%, 0.12), transparent 30%),
    linear-gradient(180deg, var(--white-2), hsl(206, 78%, 96%));
  background-size: 46px 46px, auto, auto;
  border-block: 1px solid hsla(220, 18%, 12%, 0.08);
}

.category-diagnostic-layout {
  display: grid;
  gap: 34px;
  align-items: center;
}

.category-diagnostic-copy .h2 {
  color: var(--eerie-black);
  margin-block-end: 12px;
}

.category-diagnostic-copy p {
  color: var(--gray-web);
  font-size: var(--fs-6);
}

.category-diagnostic-list {
  display: grid;
  gap: 10px;
  margin-block-start: 22px;
}

.category-diagnostic-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: var(--eerie-black);
  background-color: hsla(0, 0%, 100%, 0.78);
  border: 1px solid hsla(220, 18%, 12%, 0.08);
  border-radius: var(--radius-8);
  box-shadow: 0 10px 28px hsla(220, 18%, 12%, 0.06);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  padding: 12px 14px;
}

.category-diagnostic-list ion-icon {
  color: var(--primary-blue);
  flex-shrink: 0;
  margin-block-start: 4px;
}

.category-scoreboard {
  display: grid;
  gap: 16px;
}

.category-score-column {
  background-color: var(--white-1);
  border: 1px solid hsla(220, 18%, 12%, 0.1);
  border-radius: var(--radius-8);
  box-shadow: 0 18px 45px hsla(220, 18%, 12%, 0.08);
  padding: 20px;
}

.category-score-column strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.3rem;
  line-height: 1;
}

.category-score-column > p {
  color: var(--gray-web);
  font-size: 1.32rem;
  margin-block: 6px 18px;
}

.category-score-row {
  display: grid;
  gap: 7px;
}

.category-score-row:not(:last-child) {
  margin-block-end: 15px;
}

.category-score-row span:first-child {
  color: var(--eerie-black);
  font-size: 1.32rem;
  font-weight: var(--fw-700);
}

.category-score-track {
  height: 9px;
  overflow: hidden;
  background-color: hsl(210, 10%, 89%);
  border-radius: 999px;
}

.category-score-track span {
  height: 100%;
  background-color: var(--accent-sage);
  border-radius: inherit;
}

.category-score-column.is-after .category-score-track span {
  background-color: var(--primary-blue);
}

.category-diagnostic-graphs {
  display: grid;
  gap: 20px;
}

.category-graph-card {
  background:
    linear-gradient(180deg, hsla(0, 0%, 100%, 0.98), hsla(210, 44%, 97%, 0.96));
  border: 1px solid hsla(213, 25%, 78%, 0.76);
  border-radius: var(--radius-8);
  box-shadow: 0 24px 70px hsla(220, 18%, 12%, 0.1);
  padding: clamp(20px, 3vw, 28px);
}

.category-graph-card-wide {
  min-height: 100%;
}

.category-graph-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  margin-block-end: 20px;
}

.category-graph-head span {
  width: max-content;
  color: var(--primary-blue-dark);
  background-color: var(--accent-sage-light);
  border: 1px solid hsla(205, 78%, 45%, 0.18);
  border-radius: 999px;
  font-size: 1.12rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 7px 9px;
  text-transform: uppercase;
}

.category-graph-head strong {
  color: var(--eerie-black);
  max-width: 18ch;
  font-family: var(--ff-league-spartan);
  font-size: 2.55rem;
  line-height: 1.05;
}

.category-graph-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-block-end: 18px;
}

.category-graph-legend span {
  position: relative;
  color: var(--gray-web);
  font-size: 1.22rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding-inline-start: 18px;
}

.category-graph-legend span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  transform: translateY(-50%);
}

.category-graph-legend .is-before::before {
  background-color: hsl(218, 9%, 58%);
}

.category-graph-legend .is-after::before {
  background-color: var(--primary-blue);
}

.category-comparison-graph {
  display: grid;
  gap: 18px;
}

.category-comparison-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px 12px;
}

.category-comparison-row > span {
  color: var(--eerie-black);
  font-size: 1.36rem;
  font-weight: var(--fw-700);
  line-height: 1.2;
}

.category-comparison-row > strong {
  color: var(--primary-blue);
  font-family: var(--ff-league-spartan);
  font-size: 2rem;
  line-height: 1;
  text-align: end;
}

.category-comparison-track {
  position: relative;
  grid-column: 1 / -1;
  height: 48px;
  overflow: hidden;
  background:
    linear-gradient(90deg, hsla(220, 18%, 12%, 0.06) 1px, transparent 1px),
    hsl(210, 44%, 97%);
  background-size: 25% 100%, auto;
  border: 1px solid hsla(220, 18%, 12%, 0.09);
  border-radius: 999px;
  box-shadow: inset 0 1px 4px hsla(220, 18%, 12%, 0.06);
}

.category-comparison-track span {
  position: absolute;
  left: 10px;
  min-width: 28px;
  height: 11px;
  border-radius: 999px;
  max-width: calc(100% - 20px);
}

.category-comparison-track .is-before {
  top: 10px;
  width: calc(var(--before) - 10px);
  background-color: hsl(218, 9%, 58%);
}

.category-comparison-track .is-after {
  bottom: 10px;
  width: calc(var(--after) - 10px);
  background-color: var(--primary-blue);
  box-shadow: 0 8px 18px hsla(205, 78%, 45%, 0.2);
}

.category-diagnostic-summary {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 18px;
  text-align: center;
}

.category-diagnostic-summary .h3 {
  color: var(--eerie-black);
}

.category-diagnostic-summary p {
  color: var(--gray-web);
  font-size: var(--fs-6);
}

.category-donut {
  display: grid;
  align-content: center;
  justify-items: center;
  place-items: center;
  width: min(220px, 100%);
  aspect-ratio: 1;
  background:
    radial-gradient(circle, var(--white-1) 0 58%, transparent 59%),
    conic-gradient(var(--primary-blue) var(--value), hsl(213, 22%, 88%) 0);
  border: 1px solid hsla(220, 18%, 12%, 0.09);
  border-radius: 50%;
  box-shadow:
    inset 0 0 0 12px hsla(210, 44%, 97%, 0.9),
    0 18px 42px hsla(220, 18%, 12%, 0.1);
}

.category-donut strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 5rem;
  line-height: 0.85;
}

.category-donut span {
  color: var(--gray-web);
  font-size: 1.2rem;
  font-weight: var(--fw-700);
  line-height: 1;
  margin-block-start: 6px;
  text-transform: uppercase;
}

.category-offer-section {
  padding-block: 70px;
  background:
    radial-gradient(circle at 10% 0%, hsla(205, 78%, 45%, 0.08), transparent 26%),
    linear-gradient(180deg, var(--white-2), var(--accent-sage-light));
}

.category-offer-grid {
  display: grid;
  gap: 20px;
}

.category-offer-card {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 26px;
}

.category-offer-card.is-featured {
  color: var(--white-1);
  background:
    radial-gradient(circle at 80% 12%, hsla(202, 86%, 64%, 0.2), transparent 30%),
    radial-gradient(circle at 14% 86%, hsla(205, 78%, 45%, 0.2), transparent 32%),
    hsl(220, 46%, 13%);
  border-color: hsl(220, 46%, 13%);
  box-shadow: var(--shadow-2);
}

.category-offer-eyebrow {
  width: max-content;
  color: var(--primary-blue);
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: 999px;
  font-size: 1.15rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 7px 9px;
}

.category-offer-card.is-featured .category-offer-eyebrow {
  color: var(--eerie-black);
  background-color: var(--white-1);
}

.category-offer-card .h3 {
  margin-block: 18px 8px;
}

.category-offer-card.is-featured .h3 {
  color: var(--white-1);
}

.category-offer-card p,
.category-offer-card li {
  font-size: var(--fs-6);
}

.category-offer-card.is-featured p,
.category-offer-card.is-featured li {
  color: var(--lavender-gray);
}

.category-offer-card ul {
  display: grid;
  gap: 9px;
  margin-block: 18px 24px;
}

.category-offer-card li {
  position: relative;
  padding-inline-start: 20px;
}

.category-offer-card li::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 7px;
  height: 7px;
  background-color: var(--primary-blue);
  border-radius: 50%;
}

.category-offer-card.is-featured li::before {
  background-color: var(--white-1);
}

.category-offer-card .btn {
  margin-block-start: auto;
}

.category-case-section {
  padding-block: 70px;
  background-color: var(--white-1);
}

.category-case-layout {
  display: grid;
  gap: 28px;
  align-items: center;
}

.category-case-media {
  overflow: hidden;
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
}

.category-case-media img {
  width: 100%;
  height: 100%;
  max-height: 520px;
  object-fit: cover;
  filter: grayscale(0.18) saturate(0.96) contrast(0.98);
}

.category-case-copy .h2 {
  margin-block-end: 12px;
}

.category-case-copy p {
  font-size: var(--fs-6);
}

.category-case-result {
  display: grid;
  gap: 12px;
  margin-block-start: 24px;
}

.category-case-result li {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  color: var(--eerie-black);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
}

.category-case-result span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  color: var(--white-1);
  background-image: var(--gradient);
  border-radius: 50%;
  font-family: var(--ff-league-spartan);
  font-size: 2rem;
  line-height: 1;
}

.category-objection-section {
  padding-block: 70px;
  background:
    radial-gradient(circle at 90% 8%, hsla(202, 86%, 64%, 0.11), transparent 28%),
    var(--accent-sage-light);
}

.category-objection-grid {
  display: grid;
  gap: 16px;
}

.category-objection-card {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 22px;
}

.category-objection-card .h3 {
  margin-block-end: 8px;
}

.category-objection-card p {
  font-size: var(--fs-6);
}

.category-page-content {
  padding-block: 60px;
  background-color: var(--white-1);
}

.category-section-head {
  max-width: 760px;
  margin-inline: auto;
  margin-block-end: 34px;
  text-align: center;
}

.category-section-head .h2 {
  margin-block-end: 10px;
}

.category-section-head p {
  font-size: var(--fs-6);
}

.category-feature-grid {
  display: grid;
  gap: 20px;
}

.category-feature-card {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 24px;
}

.category-feature-icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  margin-block-end: 16px;
  color: var(--white-1);
  background-image: var(--gradient);
  border-radius: 50%;
  font-size: 23px;
}

.category-feature-card .h3 {
  margin-block-end: 8px;
}

.category-feature-card p,
.category-process-copy p {
  font-size: var(--fs-6);
}

.category-feature-card ul,
.category-example-card ul,
.category-help-list {
  display: grid;
  gap: 9px;
  margin-block-start: 14px;
}

.category-feature-card li,
.category-example-card li,
.category-help-list li {
  position: relative;
  padding-inline-start: 18px;
  font-size: var(--fs-6);
}

.category-feature-card li::before,
.category-example-card li::before,
.category-help-list li::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 0;
  width: 6px;
  height: 6px;
  background-color: var(--primary-blue);
  border-radius: 50%;
}

.category-page-band {
  padding-block: 60px;
  background-color: var(--white-2);
}

.category-band-grid {
  display: grid;
  gap: 30px;
}

.category-process-copy .h2 {
  margin-block-end: 10px;
}

.category-process-list {
  display: grid;
  gap: 14px;
  counter-reset: category-step;
}

.category-process-list li {
  position: relative;
  min-height: 56px;
  padding: 16px 16px 16px 64px;
  color: var(--eerie-black);
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
}

.category-process-list li::before {
  counter-increment: category-step;
  content: counter(category-step);
  position: absolute;
  top: 14px;
  left: 16px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  color: var(--white-1);
  background-color: var(--primary-blue);
  border-radius: 50%;
}

.category-example-section,
.category-faq-section {
  padding-block: 60px;
  background-color: var(--white-1);
}

.category-example-grid {
  display: grid;
  gap: 20px;
}

.category-example-card {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 24px;
}

.category-example-card .h3 {
  margin-block-end: 8px;
}

.category-help-section {
  padding-block: 60px;
  background-color: var(--white-2);
}

.category-help-panel {
  display: grid;
  gap: 24px;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 26px;
}

.category-help-panel .h2 {
  margin-block-end: 10px;
}

.category-help-panel p {
  font-size: var(--fs-6);
}

.category-faq-list {
  display: grid;
  gap: 12px;
  max-width: 900px;
  margin-inline: auto;
}

.category-faq-item {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 18px 20px;
}

.category-faq-item summary {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2rem;
  font-weight: var(--fw-700);
  line-height: 1.15;
  cursor: pointer;
}

.category-faq-item p {
  margin-block-start: 10px;
  font-size: var(--fs-6);
}

.category-page-cta {
  padding-block: 60px;
  color: var(--white-1);
  background:
    radial-gradient(circle at 20% 20%, hsla(0, 0%, 100%, 0.14), transparent 28%),
    var(--gradient);
  text-align: center;
}

.category-page-cta .h2 {
  color: var(--white-1);
  margin-block-end: 10px;
}

.category-page-cta p {
  max-width: 60ch;
  margin-inline: auto;
  font-size: var(--fs-6);
}

.category-page-cta .btn {
  margin-inline: auto;
  margin-block-start: 22px;
}

@media (min-width: 768px) {
  .category-feature-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-example-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .category-help-panel {
    grid-template-columns: 0.85fr 1fr;
    align-items: start;
    padding: 34px;
  }

  .category-metric-grid,
  .category-gallery-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-impact-dashboard {
    grid-template-columns: 0.82fr 1fr;
    align-items: stretch;
  }

  .category-impact-score {
    grid-row: span 2;
  }

  .category-impact-levers article {
    grid-template-columns: minmax(0, 0.75fr) minmax(180px, 1fr);
    align-items: center;
  }

  .category-impact-flow {
    grid-column: 2;
    grid-template-columns: repeat(4, 1fr);
  }

  .category-impact-flow span:not(:last-child)::after {
    top: 50%;
    right: -10px;
    bottom: auto;
    left: auto;
    width: 10px;
    height: 2px;
    transform: translateY(-50%);
  }

  .category-scoreboard,
  .category-offer-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-diagnostic-graphs {
    grid-template-columns: minmax(0, 1fr) 260px;
  }

  .category-comparison-row {
    grid-template-columns: 126px minmax(0, 1fr) 56px;
    align-items: center;
  }

  .category-comparison-track {
    grid-column: auto;
  }

  .category-before-after-showcase {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: 0;
  }

  .category-before-after-panel.is-before {
    border-radius: var(--radius-8) 0 0 var(--radius-8);
  }

  .category-before-after-panel.is-after {
    border-radius: 0 var(--radius-8) var(--radius-8) 0;
  }

  .category-transform-marker {
    width: 0;
    z-index: 2;
  }

  .category-transform-marker span {
    transform: translateX(-50%);
  }

  .category-before-after-proof {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-before-after-card {
    grid-template-columns: 1fr 1fr;
  }

  .category-objection-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 992px) {
  .category-page-hero { padding-block-start: 65px; }

  .category-impact-grid {
    grid-template-columns: 0.85fr 1fr;
  }

  .category-case-layout {
    grid-template-columns: 0.85fr 1fr;
  }

  .category-diagnostic-layout {
    grid-template-columns: 0.68fr 1.32fr;
  }

  .category-impact-grid.reverse {
    grid-template-columns: 1fr 0.85fr;
  }

  .category-impact-grid.reverse .category-impact-media {
    order: -1;
  }

  .category-band-grid {
    grid-template-columns: 0.75fr 1fr;
    align-items: start;
  }
}



/*-----------------------------------*\
  #ABOUT
\*-----------------------------------*/

.about { background-color: var(--white-2); }

.about-banner {
  position: relative;
  border-radius: var(--radius-5);
  overflow: hidden;
  margin-block-end: 25px;
}

.play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--white-1);
  color: var(--primary-blue);
  font-size: 32px;
  padding: 16px;
  border-radius: 50%;
  animation: pulse 1.5s ease-out infinite;
}

@keyframes pulse {
  0% { box-shadow: 0 0 0 1px var(--white-1); }
  100% { box-shadow: 0 0 0 25px transparent; }
}

.about :is(.section-title, .section-text) { text-align: left; }

.about .section-title { margin-block-end: 5px; }

.about .section-text:not(:last-child) { margin-block-end: 18px; }

.about .h3 { margin-block-end: 8px; }

.about-list { margin-block: 15px 18px; }

.about-item {
  display: flex;
  align-items: flex-start;
  gap: 5px;
}

.about-item ion-icon {
  color: var(--primary-blue);
  flex-shrink: 0;
  margin-block-start: 2px;
}

.about-item:not(:last-child) { margin-block-end: 12px; }





/*-----------------------------------*\
  #CTA
\*-----------------------------------*/

.cta {
  position: relative;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  z-index: 1;
}

.cta::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: var(--gradient);
  opacity: 0.95;
  z-index: -1;
}

.cta-subtitle,
.cta .section-title { color: var(--white-1); }

.cta-subtitle {
  font-size: var(--fs-6);
  font-weight: var(--fw-500);
  text-align: center;
}

.cta .section-title { margin-block: 12px 18px; }

.cta .btn { margin-inline: auto; }





/*-----------------------------------*\
  #BLOG
\*-----------------------------------*/

.blog .section-text { margin-block: 5px 35px; }

.blog-card { background-color: var(--white-2); }

.blog-card .card-banner { overflow: hidden; }

.blog-card .card-banner img { transition: var(--transition-2); }

.blog-card:is(:hover, :focus-within) .card-banner img { transform: scale(1.05); }

.blog-card .card-content { padding: 15px; }

.blog-card .time {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  line-height: 1;
  margin-block-end: 10px;
}

.blog-card .card-title { transition: var(--transition-1); }

.blog-card .card-title:is(:hover, :focus) { color: var(--primary-blue); }





/*-----------------------------------*\
  #CONTACT
\*-----------------------------------*/

.contact { background-color: var(--white-2); }

.contact .section-text { margin-block: 5px 35px; }

.contact-form {
  background-color: var(--white-1);
  padding: 20px;
  border-radius: var(--radius-2);
  margin-block-end: 30px;
  box-shadow: var(--shadow-1);
}

.input-field {
  background-color: var(--white-2);
  color: var(--eerie-black);
  font-size: var(--fs-5);
  padding: 15px;
  border-radius: var(--radius-2);
  outline: 1px solid transparent;
  outline-offset: 0;
  margin-block-end: 15px;
}

.input-field::-webkit-inner-spin-button { display: none; }

.input-field:focus { outline-color: var(--primary-blue); }

.input-field::placeholder { transition: var(--transition-1); }

.input-field:focus::placeholder { opacity: 0; }

textarea.input-field {
  resize: vertical;
  min-height: 80px;
  height: 100px;
  max-height: 200px;
  overscroll-behavior: contain;
}

.checkbox {
  width: max-content;
  margin-block-start: 5px;
  accent-color: var(--primary-blue);
}

.label-link {
  display: inline-block;
  color: var(--primary-blue);
}

.label-link:is(:hover, :focus) { text-decoration: underline; }

.checkbox-wrapper {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-block-end: 15px;
}

.checkbox-wrapper .label { font-size: var(--fs-6); }

.contact-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px 25px;
}

.contact-item { min-width: 100%; }

.contact-card {
  background-color: var(--white-1);
  padding: 20px;
  border-radius: var(--radius-2);
  box-shadow: var(--shadow-1);
  display: flex;
  align-items: flex-start;
  gap: 15px;
}

.contact-card .card-icon {
  background-color: var(--cultured-2);
  color: var(--primary-blue);
  font-size: 25px;
  padding: 13px;
  border-radius: 50%;
  transition: var(--transition-1);
}

.contact-card:is(:hover, :focus) .card-icon {
  background-color: var(--primary-blue);
  color: var(--white-1);
}

.contact-card .card-title { margin-block-end: 5px; }

.contact-card :is(.card-link, .card-address) {
  font-size: var(--fs-6);
  transition: var(--transition-1);
}

.contact-card .card-link:is(:hover, :focus) { color: var(--primary-blue); }





/*-----------------------------------*\
  #QUOTE PAGE
\*-----------------------------------*/

.cta-title-link {
  color: inherit;
}

.cta-title-link:is(:hover, :focus) {
  color: var(--white-1);
  text-decoration: underline;
  text-underline-offset: 6px;
}

.quote-hero {
  background-color: var(--white-2);
  padding-block: 65px 55px;
}

.quote-hero-banner {
  position: relative;
  width: 100%;
  height: auto;
  margin-block: 0 42px;
  overflow: hidden;
}

.quote-hero-banner img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
}

.quote-kicker {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  line-height: 1;
  text-transform: uppercase;
}

.quote-title {
  max-width: 12ch;
  margin-block: 10px 14px;
}

.quote-text {
  max-width: 62ch;
  color: var(--gray-web);
  font-size: var(--fs-5);
}

.quote-builder {
  background-color: var(--white-1);
}

.quote-builder .container,
.quote-hero > .container {
  max-width: min(100% - 24px, 1440px);
}

.quote-layout {
  display: grid;
  gap: 28px;
}

.quote-form,
.quote-summary-card {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 34px;
}

.quote-form {
  position: relative;
  display: grid;
  gap: 30px;
}

.quote-form::before {
  content: "";
  position: absolute;
  top: 0;
  left: 34px;
  right: 34px;
  height: 3px;
  background-image: var(--gradient);
  border-radius: 0 0 var(--radius-5) var(--radius-5);
}

.quote-form-head {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 8px 16px;
  margin-block-end: 0;
  padding: 18px;
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
}

.quote-form-head-icon {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  color: var(--white-1);
  background-image: var(--gradient);
  box-shadow: 0 10px 24px hsla(205, 78%, 45%, 0.18);
  border-radius: 50%;
  font-size: 22px;
}

.quote-form-head .quote-kicker {
  width: max-content;
  max-width: 100%;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: 999px;
  padding: 6px 10px;
}

.quote-form-head .h2,
.quote-summary-card .h2 {
  margin-block-start: 8px;
}

.quote-form-head .h2 {
  margin-block-start: 0;
  letter-spacing: 0;
}

.quote-mode-panel {
  display: grid;
  gap: 18px;
  padding: 24px;
  background:
    linear-gradient(135deg, var(--cultured-2) 0%, var(--white-1) 58%, var(--accent-sage-light) 100%);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
}

.quote-mode-copy .h3 {
  margin-block-start: 8px;
}

.quote-mode-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.quote-mode-option {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: 14px;
  min-height: 118px;
  color: var(--eerie-black);
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: 0 12px 28px hsla(220, 18%, 12%, 0.07);
  padding: 16px;
  text-align: left;
  transition: var(--transition-1);
}

.quote-mode-option:is(:hover, :focus),
.quote-mode-option.is-selected {
  border-color: var(--primary-blue);
  box-shadow: 0 18px 38px hsla(205, 78%, 45%, 0.13);
  transform: translateY(-2px);
}

.quote-mode-option.is-selected {
  background-color: var(--cultured-2);
}

.quote-mode-icon {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: var(--primary-blue);
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: 50%;
  font-size: 22px;
}

.quote-mode-option.is-selected .quote-mode-icon {
  color: var(--white-1);
  background-image: var(--gradient);
  border-color: transparent;
}

.quote-mode-text {
  display: grid;
  gap: 5px;
}

.quote-mode-text strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2rem;
  line-height: 1.05;
}

.quote-mode-text small {
  color: var(--gray-web);
  font-size: 1.3rem;
  line-height: 1.35;
}

.quote-kit-panel {
  position: relative;
  display: grid;
  gap: 18px;
  margin-block-end: 0;
  padding: 24px;
  overflow: hidden;
  background:
    linear-gradient(135deg, var(--white-1) 0%, var(--cultured-2) 44%, var(--accent-sage-light) 100%);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow:
    inset 0 1px 0 hsla(0, 0%, 100%, 0.9),
    0 18px 48px hsla(220, 18%, 12%, 0.1);
  isolation: isolate;
}

.quote-kit-panel::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 118px;
  background:
    linear-gradient(135deg, hsla(202, 86%, 64%, 0.11), hsla(205, 78%, 45%, 0.1) 58%, transparent);
  pointer-events: none;
  z-index: 0;
}

.quote-kit-panel > * {
  position: relative;
  z-index: 1;
}

.quote-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

.quote-mode-panel[hidden],
.quote-kit-panel[hidden],
.quote-manual-title[hidden],
.quote-form-grid[hidden] {
  display: none;
}

.quote-kit-field {
  max-width: 100%;
}

.quote-kit-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 56px;
  gap: 10px;
  align-items: start;
}

.quote-kit-filter {
  position: relative;
}

.quote-filter-btn {
  position: relative;
  display: grid;
  place-items: center;
  width: 56px;
  height: 56px;
  color: var(--primary-blue);
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  font-size: 22px;
  transition: var(--transition-1);
}

.quote-filter-btn:is(:hover, :focus),
.quote-filter-btn.is-active {
  color: var(--white-1);
  background-image: var(--gradient);
  border-color: transparent;
}

.quote-filter-btn span {
  position: absolute;
  top: -7px;
  right: -7px;
  display: grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  color: var(--white-1);
  background-color: hsl(0, 84%, 50%);
  border: 2px solid var(--white-1);
  border-radius: 50%;
  font-size: 1.15rem;
  font-weight: var(--fw-700);
  line-height: 1;
}

.quote-filter-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: min(330px, calc(100vw - 48px));
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
  padding: 14px;
  z-index: 9;
}

.quote-filter-panel[hidden] {
  display: none;
}

.quote-filter-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-block-end: 12px;
}

.quote-filter-head strong {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2rem;
  line-height: 1.1;
}

.quote-filter-head button {
  color: var(--primary-blue);
  font-size: 1.3rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 8px 10px;
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  transition: var(--transition-1);
}

.quote-filter-head button:is(:hover, :focus) {
  border-color: var(--primary-blue);
  background-color: var(--cultured-2);
}

.quote-filter-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  max-height: 280px;
  overflow-y: auto;
  overscroll-behavior: contain;
}

.quote-filter-option {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  color: var(--eerie-black);
  background-color: var(--white-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  font-size: 1.32rem;
  font-weight: var(--fw-700);
  line-height: 1.25;
  padding: 9px;
  cursor: pointer;
  transition: var(--transition-1);
}

.quote-filter-option:has(input:checked) {
  color: var(--primary-blue);
  border-color: var(--primary-blue);
  background-color: var(--cultured-2);
}

.quote-filter-option input {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  accent-color: var(--primary-blue);
}

.quote-filter-option span {
  overflow-wrap: anywhere;
}

.quote-manual-title {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 10px 16px;
  margin-block-end: 0;
  padding: 20px 22px;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
}

.quote-manual-title .h3 {
  margin-block-start: 6px;
}

.quote-manual-title span {
  width: max-content;
  max-width: 100%;
  color: var(--primary-blue);
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  font-size: 1.35rem;
  font-weight: var(--fw-700);
  line-height: 1.3;
  padding: 8px 10px;
}

.quote-form-grid {
  display: grid;
  gap: 22px;
  margin-block-end: 0;
  padding: 22px;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
}

.quote-form-grid.is-locked {
  background-color: hsl(0, 0%, 98%);
  border-style: dashed;
  opacity: 0.58;
  filter: grayscale(0.16);
}

.quote-field {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.quote-label {
  color: var(--eerie-black);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  line-height: 1.2;
}

.quote-field-hint {
  color: var(--gray-web);
  font-size: 1.32rem;
  line-height: 1.45;
}

.quote-dropdown {
  position: relative;
}

.quote-dropdown-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  min-height: 62px;
  background-color: var(--white-2);
  color: var(--eerie-black);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  padding: 16px 18px;
  text-align: left;
  transition: var(--transition-1);
}

.quote-dropdown-button span {
  overflow-wrap: anywhere;
}

.quote-dropdown-button ion-icon {
  color: var(--primary-blue);
  flex-shrink: 0;
  font-size: 20px;
  transition: var(--transition-1);
}

.quote-dropdown.active .quote-dropdown-button,
.quote-dropdown-button:is(:hover, :focus) {
  border-color: var(--primary-blue);
  background-color: var(--white-1);
}

.quote-dropdown.active .quote-dropdown-button ion-icon {
  transform: rotate(180deg);
}

.quote-dropdown.is-disabled .quote-dropdown-button,
.quote-dropdown-button:disabled {
  cursor: not-allowed;
  opacity: 0.78;
}

.quote-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  display: grid;
  gap: 4px;
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
  padding: 8px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: var(--transition-1);
  z-index: 8;
}

.quote-dropdown.active .quote-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.quote-menu-scroll {
  max-height: min(390px, 52vh);
  overflow-y: auto;
  overscroll-behavior: contain;
}

.quote-menu-heading {
  position: sticky;
  top: -8px;
  color: var(--primary-blue);
  background-color: var(--white-1);
  border-block-end: 1px solid var(--platinum);
  font-size: 1.25rem;
  font-weight: var(--fw-700);
  line-height: 1.2;
  padding: 11px 12px 8px;
  text-transform: uppercase;
  z-index: 1;
}

.quote-option {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content 24px;
  align-items: center;
  gap: 12px;
  width: 100%;
  color: var(--eerie-black);
  border-radius: var(--radius-5);
  padding: 12px;
  text-align: left;
  transition: var(--transition-1);
}

.quote-option:is(:hover, :focus),
.quote-option.is-selected {
  background-color: var(--cultured-2);
}

.quote-option.is-selected {
  color: var(--primary-blue);
}

.quote-option-main {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.quote-option-main ion-icon {
  color: var(--primary-blue);
  flex-shrink: 0;
  font-size: 20px;
}

.quote-option-main span {
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.quote-option-price {
  color: var(--gray-web);
  font-size: 1.35rem;
  line-height: 1.2;
  white-space: nowrap;
}

.quote-check {
  grid-column: -2 / -1;
  color: var(--primary-blue);
  font-size: 1.7rem;
  font-weight: var(--fw-700);
  line-height: 1;
  opacity: 0;
  text-align: center;
  transform: scale(0.7);
  transition: var(--transition-1);
}

.quote-option.is-selected .quote-check {
  opacity: 1;
  transform: scale(1);
}

.platform-option {
  grid-template-columns: 38px minmax(0, 1fr) max-content 24px;
}

.platform-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-8);
  object-fit: contain;
}

.quote-template-carousel {
  position: relative;
  margin-inline: 0;
  overflow: hidden;
  padding: 26px 26px 16px;
  background:
    radial-gradient(circle at 12% 0%, hsla(205, 78%, 45%, 0.12), transparent 28%),
    radial-gradient(circle at 88% 6%, hsla(202, 86%, 64%, 0.12), transparent 30%),
    linear-gradient(180deg, hsla(0, 0%, 100%, 0.96), hsla(210, 44%, 97%, 0.88));
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow:
    inset 0 1px 0 hsla(0, 0%, 100%, 0.92),
    0 18px 42px hsla(220, 18%, 12%, 0.08);
}

.quote-template-carousel::before,
.quote-template-carousel::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 76px;
  pointer-events: none;
  z-index: 2;
}

.quote-template-carousel::before {
  left: 0;
  background: linear-gradient(90deg, hsla(0, 0%, 99%, 0.98), transparent);
}

.quote-template-carousel::after {
  right: 0;
  background: linear-gradient(270deg, hsla(0, 0%, 99%, 0.98), transparent);
}

.quote-template-track {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 24px;
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  padding: 10px 10px 22px;
  scroll-behavior: smooth;
  scroll-padding-inline: 10px;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}

.quote-template-track::-webkit-scrollbar {
  display: none;
}

.quote-carousel-btn {
  position: absolute;
  top: 45%;
  z-index: 3;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  color: var(--primary-blue);
  background-color: hsla(0, 0%, 100%, 0.88);
  border: 1px solid hsla(0, 0%, 82%, 0.9);
  border-radius: 50%;
  box-shadow: 0 16px 34px hsla(0, 0%, 22%, 0.18);
  backdrop-filter: blur(10px);
  transform: translateY(-50%);
  transition: var(--transition-1);
}

.quote-carousel-btn:is(:hover, :focus) {
  color: var(--white-1);
  background-color: var(--primary-blue);
  border-color: var(--primary-blue);
}

.quote-carousel-btn[hidden] {
  display: none;
}

.quote-carousel-btn:disabled {
  cursor: default;
  opacity: 0.42;
}

.quote-carousel-btn:disabled:is(:hover, :focus) {
  color: var(--primary-blue);
  background-color: hsla(0, 0%, 100%, 0.94);
  border-color: hsl(0, 0%, 86%);
}

.quote-carousel-btn ion-icon {
  font-size: 24px;
}

.quote-carousel-prev {
  left: 14px;
}

.quote-carousel-next {
  right: 14px;
}

.quote-template-card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr;
  flex: 0 0 min(580px, calc(100% - 74px));
  width: 100%;
  min-height: 100%;
  overflow: hidden;
  color: var(--eerie-black);
  background:
    linear-gradient(180deg, var(--white-1), hsl(0, 0%, 99%));
  border: 1px solid hsl(0, 0%, 84%);
  border-radius: var(--radius-8);
  box-shadow:
    0 14px 30px hsla(0, 0%, 22%, 0.1),
    inset 0 1px 0 hsla(0, 0%, 100%, 0.88);
  scroll-snap-align: start;
  text-align: left;
  transition: var(--transition-1);
}

.quote-template-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border: 2px solid transparent;
  border-radius: inherit;
  pointer-events: none;
  transition: var(--transition-1);
  z-index: 1;
}

.quote-template-card:is(:hover, :focus) {
  border-color: var(--primary-blue);
  box-shadow:
    0 22px 46px hsla(205, 78%, 45%, 0.16),
    inset 0 1px 0 hsla(0, 0%, 100%, 0.9);
  transform: translateY(-3px);
}

.quote-template-card.is-selected {
  border-color: var(--primary-blue);
  box-shadow:
    0 0 0 2px hsla(205, 78%, 45%, 0.14),
    0 20px 42px hsla(205, 78%, 45%, 0.16);
}

.quote-template-card.is-selected::before {
  border-color: hsla(205, 78%, 45%, 0.55);
}

.quote-template-media {
  position: relative;
  aspect-ratio: 16 / 11;
  overflow: hidden;
  background-color: var(--cultured-2);
}

.quote-template-media::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 42%;
  background: linear-gradient(0deg, hsla(0, 0%, 14%, 0.44), transparent);
  pointer-events: none;
}

.quote-template-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-2);
}

.quote-template-card:is(:hover, :focus) .quote-template-media img,
.quote-template-card.is-selected .quote-template-media img {
  transform: scale(1.04);
}

.quote-template-badge {
  position: absolute;
  left: 10px;
  top: 10px;
  width: max-content;
  max-width: calc(100% - 20px);
  color: var(--primary-blue-dark);
  background-color: hsla(0, 0%, 100%, 0.94);
  border: 1px solid hsla(0, 0%, 86%, 0.9);
  border-radius: 999px;
  font-size: 1.12rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 7px 9px;
  z-index: 1;
}

.quote-template-body {
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 12px;
  padding: 20px;
}

.quote-template-title {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.35rem;
  font-weight: var(--fw-700);
  line-height: 1.05;
}

.quote-template-includes {
  color: var(--gray-web);
  font-size: 1.48rem;
  line-height: 1.45;
}

.quote-template-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-block-start: 4px;
}

.quote-template-card .quote-option-price {
  color: var(--primary-blue-dark);
  background-color: hsl(0, 0%, 97%);
  border: 1px solid hsl(0, 0%, 86%);
  border-radius: 999px;
  font-size: 1.48rem;
  font-weight: var(--fw-700);
  padding: 8px 10px;
}

.quote-template-lock {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  width: max-content;
  max-width: 100%;
  color: hsl(213, 70%, 28%);
  background-color: hsl(206, 78%, 96%);
  border: 1px solid hsl(206, 58%, 82%);
  border-radius: 999px;
  font-size: 1.22rem;
  font-weight: var(--fw-700);
  line-height: 1;
  padding: 7px 9px;
}

.quote-template-lock ion-icon {
  color: hsl(205, 78%, 45%);
  font-size: 14px;
}

.quote-template-card .quote-check {
  position: absolute;
  top: 10px;
  right: 10px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  color: var(--white-1);
  background-color: var(--primary-blue);
  border: 2px solid var(--white-1);
  border-radius: 50%;
  font-size: 1.5rem;
  z-index: 2;
}

.quote-template-card.is-selected .quote-check {
  opacity: 1;
  transform: scale(1);
}

.quote-empty-option {
  color: var(--gray-web);
  background-color: var(--white-2);
  border: 1px dashed var(--platinum);
  border-radius: var(--radius-5);
  font-size: var(--fs-6);
  line-height: 1.45;
  padding: 14px;
}

.quote-lock-alert {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 14px;
  background-color: hsl(0, 0%, 97%);
  border: 1px solid hsl(0, 0%, 82%);
  border-inline-start-width: 5px;
  border-radius: var(--radius-8);
  color: var(--primary-blue-dark);
  padding: 16px;
}

.quote-lock-alert[hidden] {
  display: none;
}

.quote-lock-alert.is-confirming {
  background-color: hsl(0, 100%, 97%);
  border-color: hsl(0, 84%, 50%);
  color: hsl(0, 74%, 24%);
  animation: quote-warning-pulse 1.15s ease-in-out infinite;
}

@keyframes quote-warning-pulse {
  0%,
  100% { box-shadow: 0 0 0 0 hsla(0, 84%, 50%, 0.16); }
  50% { box-shadow: 0 0 0 8px hsla(0, 84%, 50%, 0.08); }
}

.quote-lock-alert ion-icon {
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  background-color: var(--white-1);
  border-radius: 50%;
  color: currentColor;
  font-size: 22px;
}

.quote-lock-alert strong {
  color: currentColor;
  font-family: var(--ff-league-spartan);
  font-size: 2.2rem;
  line-height: 1.1;
}

.quote-lock-alert p {
  font-size: var(--fs-6);
  line-height: 1.5;
  margin-block-start: 6px;
}

.quote-lock-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-block-start: 12px;
}

.quote-unlock-btn {
  color: var(--white-1);
  background-color: var(--primary-blue);
  border: 1px solid transparent;
  border-radius: var(--radius-5);
  font-size: 1.35rem;
  font-weight: var(--fw-700);
  line-height: 1.25;
  padding: 10px 12px;
  transition: var(--transition-1);
}

.quote-unlock-btn:is(:hover, :focus) {
  background-color: var(--primary-blue-dark);
  color: var(--white-1);
}

.quote-unlock-btn:disabled {
  cursor: default;
  opacity: 0.7;
}

.quote-contact-row {
  margin-block-end: 0;
}

.quote-summary-card .h2 {
  margin-block-end: 18px;
}

.quote-summary-list {
  display: grid;
  gap: 10px;
  max-height: 360px;
  overflow-y: auto;
  overscroll-behavior: contain;
}

.quote-summary-list li {
  display: grid;
  gap: 4px;
  background-color: var(--white-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  padding: 12px;
}

.quote-summary-list span {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  line-height: 1.2;
}

.quote-summary-list strong {
  color: var(--eerie-black);
  font-size: var(--fs-6);
  line-height: 1.4;
}

.quote-total-box {
  display: grid;
  gap: 8px;
  margin-block-start: 20px;
  background-image: var(--gradient);
  border-radius: var(--radius-8);
  color: var(--white-1);
  padding: 18px;
}

.quote-total-box span {
  font-size: var(--fs-6);
  font-weight: var(--fw-500);
}

.quote-total-box strong {
  color: var(--white-1);
  font-family: var(--ff-league-spartan);
  font-size: 3rem;
  line-height: 1;
}

.quote-send-btn {
  width: 100%;
  max-width: none;
  justify-content: center;
  margin-block-start: 14px;
}

.quote-monthly {
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  color: var(--eerie-black);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  margin-block-start: 12px;
  padding: 12px;
}

.quote-summary-note {
  font-size: var(--fs-6);
  margin-block-start: 14px;
}

.quote-contact-modal {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  z-index: 11;
}

.quote-contact-modal[hidden] {
  display: none;
}

.quote-contact-modal-overlay {
  position: absolute;
  inset: 0;
  background-color: hsla(0, 0%, 8%, 0.72);
  backdrop-filter: blur(4px);
}

.quote-contact-modal-dialog {
  position: relative;
  width: min(100%, 720px);
  max-height: min(760px, 90vh);
  overflow-y: auto;
  background-color: var(--white-1);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
  padding: 34px;
  z-index: 1;
}

.quote-contact-modal-dialog .h2 {
  margin-block: 8px 22px;
  padding-inline-end: 44px;
}

.quote-contact-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  background-color: var(--cultured-2);
  color: var(--eerie-black);
  border-radius: 50%;
  font-size: 24px;
  transition: var(--transition-1);
}

.quote-contact-modal-close:is(:hover, :focus) {
  background-color: var(--primary-blue);
  color: var(--white-1);
}

.quote-contact-modal-form .btn {
  width: 100%;
  max-width: none;
  justify-content: center;
}





/*-----------------------------------*\
  #LEGAL PAGES
\*-----------------------------------*/

.legal-hero {
  background-color: var(--white-2);
  padding-block: calc(var(--section-padding) + 55px) 50px;
  text-align: center;
}

.legal-subtitle {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  text-transform: uppercase;
}

.legal-title {
  max-width: 12ch;
  margin: 10px auto;
}

.legal-updated {
  color: var(--gray-web);
  font-size: var(--fs-6);
}

.legal-content {
  padding-block: 50px;
}

.legal-content .container {
  max-width: 900px;
}

.legal-card {
  background-color: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-1);
  padding: 24px;
}

.legal-card h2 {
  color: var(--eerie-black);
  font-family: var(--ff-league-spartan);
  font-size: 2.4rem;
  line-height: 1.2;
  margin-block: 28px 10px;
}

.legal-card p,
.legal-card li {
  font-size: var(--fs-6);
}

.legal-card p:not(:last-child) {
  margin-block-end: 12px;
}

.legal-card ul {
  padding-inline-start: 22px;
  margin-block: 12px 18px;
}

.legal-card li {
  list-style: disc;
}

.legal-card a:not(.btn) {
  color: var(--primary-blue);
  display: inline;
  font-weight: var(--fw-500);
}

.legal-card a:not(.btn):is(:hover, :focus) {
  text-decoration: underline;
}

.legal-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  margin-block-start: 34px;
  padding-block-start: 24px;
  border-block-start: 1px solid var(--platinum);
}

.legal-action-link {
  font-size: var(--fs-6);
}

.legal-footer-bottom {
  padding-block-start: 0;
}





/*-----------------------------------*\
  #FOOTER
\*-----------------------------------*/

.footer {
  background:
    radial-gradient(circle at 12% 0%, hsla(205, 78%, 45%, 0.18), transparent 30%),
    radial-gradient(circle at 90% 8%, hsla(202, 86%, 64%, 0.14), transparent 32%),
    hsl(220, 46%, 12%);
  color: var(--lavender-gray);
  padding-block: 60px 22px;
}

.footer-top {
  display: grid;
  gap: 35px;
  padding-block-end: 35px;
  border-block-end: 1px solid hsla(0, 0%, 100%, 0.12);
}

.footer-logo {
  color: var(--white-1);
  font-family: var(--ff-league-spartan);
  font-size: 3.8rem;
  font-weight: var(--fw-700);
  line-height: 1;
}

.footer-text {
  max-width: 36ch;
  margin-block: 16px 22px;
  font-size: var(--fs-6);
}

.footer-cta { padding-inline: 24px; }

.footer-title {
  color: var(--white-1);
  font-family: var(--ff-league-spartan);
  font-size: 2.2rem;
  line-height: 1.2;
  margin-block-end: 16px;
}

.footer-list,
.footer-contact-list {
  display: grid;
  gap: 10px;
}

.footer-link,
.footer-contact-link,
.footer-top-link {
  color: var(--lavender-gray);
  font-size: var(--fs-6);
  transition: var(--transition-1);
}

.footer-link:is(:hover, :focus),
.footer-contact-link:is(:hover, :focus),
.footer-top-link:is(:hover, :focus) {
  color: var(--primary-blue-light);
}

.footer-contact-link {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.footer-contact-link ion-icon {
  color: var(--primary-blue-light);
  font-size: 20px;
  flex-shrink: 0;
  margin-block-start: 3px;
}

.footer-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding-block-start: 22px;
}

.footer-bottom-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 20px;
}

.footer-credit-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  line-height: inherit;
  width: max-content;
}

.footer-credit-btn img {
  width: 18px;
  height: 18px;
  object-fit: contain;
}

.copyright {
  font-size: var(--fs-6);
  text-align: center;
}





/*-----------------------------------*\
  #CREDIT MODAL
\*-----------------------------------*/

.credit-modal {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 18px;
  z-index: 10;
}

.credit-modal[hidden] { display: none; }

.credit-modal-overlay {
  position: absolute;
  inset: 0;
  background-color: hsla(0, 0%, 8%, 0.72);
  backdrop-filter: blur(4px);
}

.credit-modal-dialog {
  position: relative;
  width: min(100%, 680px);
  max-height: min(720px, 88vh);
  overflow-y: auto;
  background-color: var(--white-1);
  border-radius: var(--radius-8);
  box-shadow: var(--shadow-2);
  padding: 28px;
  z-index: 1;
}

.credit-modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  background-color: var(--cultured-2);
  color: var(--eerie-black);
  border-radius: 50%;
  font-size: 24px;
  transition: var(--transition-1);
}

.credit-modal-close:is(:hover, :focus) {
  background-color: var(--primary-blue);
  color: var(--white-1);
}

.credit-modal-subtitle {
  color: var(--primary-blue);
  font-size: var(--fs-6);
  font-weight: var(--fw-700);
  text-transform: uppercase;
}

.credit-modal-heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 16px;
  margin-block: 8px 20px;
  padding-inline-end: 44px;
}

.credit-modal-title {
  margin-block: 0;
}

.credit-license-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  max-width: max-content;
  color: var(--primary-blue);
  font-size: var(--fs-5);
  font-weight: var(--fw-500);
  line-height: 1;
  padding: 8px 12px;
  background-color: var(--cultured-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  transition: var(--transition-1);
}

.credit-license-link:is(:hover, :focus) {
  border-color: var(--primary-blue);
  background-color: var(--white-1);
}

.credit-license-link img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}

.credit-list {
  display: grid;
  gap: 12px;
}

.credit-list a {
  color: var(--eerie-black);
  font-size: var(--fs-6);
  line-height: 1.5;
  padding: 14px 16px;
  background-color: var(--white-2);
  border: 1px solid var(--platinum);
  border-radius: var(--radius-5);
  transition: var(--transition-1);
}

.credit-list a:is(:hover, :focus) {
  border-color: var(--primary-blue);
  color: var(--primary-blue);
}





/*-----------------------------------*\
  #BACK TO TOP
\*-----------------------------------*/

.back-top-btn {
  position: fixed;
  bottom: 10px;
  right: 20px;
  background-color: var(--eerie-black);
  color: var(--white-1);
  padding: 12px;
  border-radius: 50%;
  box-shadow: var(--shadow-2);
  z-index: 4;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition-1);
}

.back-top-btn.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(-10px);
}

.back-top-btn:is(:hover, :focus) { opacity: 0.9; }





/*-----------------------------------*\
  #MEDIA QUERIES
\*-----------------------------------*/

/**
 * responsive for mobile screens
 */

@media (max-width: 574px) {

  /**
   * REUSED STYLE
   */

  .container { padding-inline: 18px; }

  .section { padding-block: 56px; }

  .btn {
    max-width: 100%;
    padding-inline: 20px;
    white-space: normal;
  }

  .section-title {
    max-width: 12ch;
    margin-inline: auto;
  }

  .section-text {
    max-width: 34ch;
    margin-inline: auto;
  }

  .service .grid-list,
  .project .grid-list,
  .blog .grid-list {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding: 4px 18px 18px;
    margin-inline: -18px;
    scroll-padding-inline: 18px;
    scroll-snap-type: inline mandatory;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .service .grid-list::-webkit-scrollbar,
  .project .grid-list::-webkit-scrollbar,
  .blog .grid-list::-webkit-scrollbar {
    height: 0;
  }

  .service .grid-list > li,
  .project .grid-list > li,
  .blog .grid-list > li {
    flex: 0 0 min(84vw, 340px);
    scroll-snap-align: start;
  }



  /**
   * HEADER
   */

  .header { padding-block: 6px; }

  .logo {
    width: 156px;
    height: 42px;
  }

  .logo img {
    height: 51px;
    transform: translateY(-2px) scale(1.08);
  }

  .nav-toggle-btn {
    width: 42px;
    height: 42px;
    font-size: 34px;
  }

  .navbar {
    max-width: calc(100% - 24px);
  }

  .navbar.active {
    max-height: calc(100vh - 86px);
    overflow-y: auto;
  }

  .navbar-list {
    padding: 16px;
  }



  /**
   * HERO
   */

  .hero {
    padding-block-start: 104px;
  }

  .hero-title {
    max-width: 11ch;
    margin-inline: auto;
  }

  .hero-text {
    max-width: 32ch;
    margin-inline: auto;
  }

  .hero-banner {
    max-width: 360px;
    margin-inline: auto;
  }



  /**
   * SERVICE
   */

  .service-card {
    min-height: 390px;
    height: auto;
    padding: 24px 20px;
  }



  /**
   * SERVICE DETAIL
   */

  .service-detail-hero {
    padding-block-start: 104px;
    text-align: center;
  }

  .service-detail-icon {
    margin-inline: auto;
  }

  .service-detail-summary {
    margin-inline: auto;
  }

  .service-detail-content {
    padding-block: 46px;
  }

  .service-detail-main,
  .service-detail-panel {
    padding: 22px 18px;
  }



  /**
   * PROJECT
   */

  .project-card .card-content {
    padding: 18px;
  }

  .project-card .btn {
    padding-inline: 18px;
  }



  /**
   * ABOUT
   */

  .about-banner {
    max-width: 340px;
    margin-inline: auto;
  }

  .about-content {
    max-width: 36ch;
    margin-inline: auto;
  }



  /**
   * CTA
   */

  .cta {
    background-attachment: scroll;
  }



  /**
   * CONTACT
   */

  .contact-form {
    padding: 18px;
  }

  .checkbox-wrapper {
    align-items: flex-start;
  }



  /**
   * FOOTER
   */

  .footer {
    padding-block-start: 48px;
  }

  .footer-bottom-links {
    flex-direction: column;
    align-items: center;
  }



  /**
   * CREDIT MODAL
   */

  .credit-modal {
    align-items: end;
    padding: 10px;
  }

  .credit-modal-dialog {
    width: 100%;
    max-height: 86vh;
    padding: 24px 18px;
  }

  .credit-modal-heading {
    align-items: flex-start;
    flex-direction: column;
    gap: 12px;
    padding-inline-end: 44px;
  }

}





/**
 * responsive for larger than 575px screen
 */

@media (min-width: 575px) {

  /**
   * REUSED STYLE
   */

  .container {
    max-width: 540px;
    width: 100%;
    margin-inline: auto;
  }

  .grid-list {
    grid-template-columns: 1fr 1fr;
    column-gap: 25px;
  }



  /**
   * BLOG
   */

  .blog .grid-list { grid-template-columns: 1fr; }

  .blog-card.grid {
    display: grid;
    grid-template-columns: 0.47fr 1fr;
    align-items: center;
    gap: 10px;
  }



  /**
   * CONTACT
   */

  .input-wrapper {
    display: flex;
    gap: 15px;
  }

  .contact-item { min-width: calc(50% - 18px); }

}





/**
 * responsive for larger than 768px screen
 */

@media (min-width: 768px) {

  /**
   * CUSTOM PROPERTY
   */

  :root {

    /**
     * typography
     */

    --fs-1: 4.5rem;
    --fs-2: 3.7rem;
    --fs-3: 2.3rem;
    --fs-4: 1.8rem;
    --fs-5: 1.5rem;
    --fs-6: 1.4rem;

  }



  /**
   * REUSED STYLE
   */

  .container { max-width: 720px; }

  .section-text {
    max-width: 65ch;
    margin-inline: auto;
  }



  /**
   * HERO
   */

  .hero-text {
    max-width: 60ch;
    margin-inline: auto;
  }



  /**
   * SERVICE DETAIL
   */

  .service-detail-head {
    grid-template-columns: auto 1fr;
    align-items: center;
  }

  .service-detail-main,
  .service-detail-panel {
    padding: 34px;
  }



  /**
   * ABOUT
   */

  .about-banner { max-width: 550px; }

  .about .section-text {
    max-width: unset;
    margin-inline: 0;
  }



  /**
   * CONTACT
   */

  .contact-form { padding: 30px; }

  .contact-item { min-width: calc(50% - 12.5px); }



  /**
   * LEGAL PAGES
   */

  .legal-card {
    padding: 40px;
  }

  .legal-actions {
    flex-direction: row;
    align-items: center;
  }



  /**
   * FOOTER
   */

  .footer-top {
    grid-template-columns: 1.4fr 1fr 1fr;
  }

  .footer-brand {
    grid-column: 1 / -1;
  }

  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
  }



  /**
   * CREDIT MODAL
   */

  .credit-modal-dialog {
    padding: 36px;
  }

}





/**
 * responsive for larger than 992px screen
 */

@media (min-width: 992px) {

  /**
   * CUSTOM PROPERTY
   */

  :root {

    /**
     * typography
     */

    --fs-1: 5rem;
    --fs-2: 4rem;
    --fs-3: 2.5rem;

    /**
     * spacing
     */

    --section-padding: 100px;

  }



  /**
   * REUSED STYLE
   */

  .container { max-width: 960px; }

  .grid-list { grid-template-columns: repeat(3, 1fr); }



  /**
   * HEADER
   */

  .nav-toggle-btn { display: none; }

  .navbar,
  .navbar.active { all: unset; }

  .navbar-list {
    all: unset;
    display: flex;
    align-items: center;
    gap: 20px;
    position: relative;
    z-index: 2;
  }

  .navbar-link { position: relative; }

  .navbar-link:is(:hover, :focus) { color: var(--eerie-black); }

  .navbar-link::after {
    content: "";
    position: absolute;
    bottom: 5px;
    left: 0;
    width: 100%;
    height: 2px;
    background-image: var(--gradient);
    transform: scaleX(0);
    transform-origin: left;
    transition: var(--transition-2);
  }

  .navbar-link:is(:hover, :focus)::after { transform: scaleX(1); }

  .header .btn { margin-block-start: 0; }



  /**
   * HERO
   */

  .hero .container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 30px;
    text-align: left;
  }

  .hero-content { margin-block-end: 0; }

  .hero-subtitle {
    position: relative;
    padding-inline-start: 15px;
  }

  .hero-subtitle::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 2px;
    height: 100%;
    background-color: var(--primary-blue);
  }

  .hero-text,
  .hero .btn { margin-inline: 0; }



  /**
   * SERVICE
   */

  .service-card { padding: 26px; }

  .service-card .h3 { --fs-3: 2.3rem; }



  /**
   * PROJECT
   */

  .project-card .card-subtitle { --fs-6: 1.5rem; }



  /**
   * SERVICE DETAIL
   */

  .service-detail-grid {
    grid-template-columns: 1fr 0.45fr;
    align-items: start;
  }

  .service-detail-panel {
    position: sticky;
    top: 110px;
  }



  /**
   * ABOUT
   */

  .about .container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 30px;
  }

  .about-banner { margin-block-end: 0; }



  /**
   * BLOG
   */

  .blog .grid-list {
    grid-template-columns: 1fr 1fr;
    row-gap: 20px;
  }

  .blog .grid-list > li:first-child {
    grid-column: 1 / 2;
    grid-row: 1 / 5;
  }

  .blog-card:not(.grid) { height: 100%; }

  .blog-card .card-content { padding-block: 10px; }

  .blog-card:not(.grid) .card-content { padding: 25px; }

  .blog-card.grid .h3 { --fs-3: 2rem; }

  .blog-card .time { --fs-6: 1.6rem; }



  /**
   * CONTACT
   */

  .checkbox-wrapper { margin-block: 20px; }

  .contact-item { min-width: calc(33.33% - 16.66px); }

  .contact-card { padding: 30px; }

  .contact-card .card-icon { font-size: 32px; }



  /**
   * FOOTER
   */

  .footer-top {
    grid-template-columns: 1.4fr 0.8fr 1fr 1.1fr;
    gap: 40px;
  }

  .footer-brand {
    grid-column: auto;
  }

}





/**
 * responsive for larger than 1200px screen
 */

@media (min-width: 1200px) {

  /**
   * CUSTOM PROPERTY
   */

  :root {

    /**
     * typography
     */

    --fs-1: 6.8rem;
    --fs-2: 4.5rem;
    --fs-4: 1.9rem;
    --fs-5: 1.6rem;
    --fs-6: 1.6rem;

  }



  /**
   * REUSED STYLE
   */

  .container { max-width: 1140px; }

  .btn { --fs-6: 1.5rem; }



  /**
   * HEADER
   */

  .logo { width: 218px; }

  .logo img {
    height: 65px;
    transform: translateY(-8px) scale(1.15);
  }



  /**
   * SERVICE
   */

  .service .grid-list { grid-template-columns: repeat(4, 1fr); }

  .service-card { padding: 30px; }

  .service-card .h3 { --fs-3: 2.5rem; }



  /**
   * PROJECT
   */

  .project-card .card-content { padding: 30px; }

  .project-card .card-subtitle { --fs-6: 1.6rem; }



  /**
   * ABOUT
   */

  .about .container { gap: 60px; }

  .about-item { gap: 7px; }

  .about-item ion-icon { font-size: 20px; }



  /**
   * CTA
   */

  .cta .section-title { margin-block: 15px 24px; }



  /**
   * BLOG
   */

  .blog-card .time { --fs-6: 1.6rem; }

  .blog-card.grid .h3 { --fs-3: 2.4rem; }



  /**
   * CONTACT
   */

  .contact-form { padding: 50px; }

  .contact-card { gap: 20px; }

  .contact-card .card-icon { padding: 15px; }

}





/**
 * quote page responsive rules
 */

@media (max-width: 574px) {

  .quote-hero {
    padding-block-start: 54px;
    text-align: center;
  }

  .quote-hero-banner {
    margin-block-end: 30px;
  }

  .quote-hero .service-detail-back,
  .quote-title,
  .quote-text {
    margin-inline: auto;
  }

  .quote-text {
    max-width: 34ch;
  }

  .quote-form,
  .quote-summary-card {
    padding: 18px;
  }

  .quote-form {
    gap: 22px;
  }

  .quote-builder .container,
  .quote-hero > .container {
    max-width: 100%;
  }

  .quote-form::before {
    left: 18px;
    right: 18px;
  }

  .quote-form-head {
    grid-template-columns: 42px 1fr;
    gap: 7px 12px;
    padding: 16px;
  }

  .quote-form-head-icon {
    width: 42px;
    height: 42px;
    font-size: 20px;
  }

  .quote-mode-panel,
  .quote-kit-panel {
    padding: 16px;
  }

  .quote-mode-options {
    grid-template-columns: 1fr;
  }

  .quote-mode-option {
    min-height: auto;
    padding: 14px;
  }

  .quote-kit-controls {
    grid-template-columns: minmax(0, 1fr) 52px;
  }

  .quote-filter-btn {
    width: 52px;
    height: 56px;
  }

  .quote-filter-panel {
    right: -2px;
    width: min(320px, calc(100vw - 36px));
  }

  .quote-filter-options {
    grid-template-columns: 1fr;
  }

  .quote-template-carousel {
    margin-inline: 0;
    padding: 14px 10px 8px;
  }

  .quote-template-carousel::before,
  .quote-template-carousel::after {
    width: 38px;
  }

  .quote-template-track {
    gap: 14px;
    padding: 6px 4px 14px;
  }

  .quote-template-card {
    flex-basis: min(340px, calc(100% - 42px));
  }

  .quote-template-body {
    padding: 14px;
  }

  .quote-template-title {
    font-size: 2rem;
  }

  .quote-template-includes {
    font-size: 1.32rem;
  }

  .quote-carousel-btn {
    width: 40px;
    height: 40px;
  }

  .quote-carousel-prev {
    left: 4px;
  }

  .quote-carousel-next {
    right: 4px;
  }

  .quote-manual-title {
    align-items: flex-start;
    flex-direction: column;
    padding: 16px;
  }

  .quote-form-grid {
    padding: 16px;
    gap: 18px;
  }

  .quote-dropdown-button {
    min-height: 58px;
    padding: 14px 15px;
  }

  .quote-option {
    grid-template-columns: minmax(0, 1fr) auto 22px;
    gap: 8px;
    padding: 11px;
  }

  .platform-option {
    grid-template-columns: 34px minmax(0, 1fr) auto 22px;
  }

  .quote-template-footer {
    align-items: flex-start;
    flex-direction: column;
  }

  .quote-lock-alert {
    grid-template-columns: 1fr;
  }

  .quote-lock-actions {
    flex-direction: column;
  }

  .quote-contact-modal {
    align-items: end;
    padding: 10px;
  }

  .quote-contact-modal-dialog {
    width: 100%;
    max-height: 88vh;
    padding: 24px 18px;
  }

  .quote-contact-modal-dialog .h2 {
    padding-inline-end: 44px;
  }

  .quote-option-price {
    font-size: 1.25rem;
  }

  .quote-total-box strong {
    font-size: 2.6rem;
  }

}

@media (min-width: 575px) {

  .quote-form-grid {
    grid-template-columns: 1fr 1fr;
  }

  .quote-field-wide {
    grid-column: 1 / -1;
  }

}

@media (min-width: 768px) {

  .quote-form,
  .quote-summary-card {
    padding: 34px;
  }

  .quote-kit-panel {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .quote-lock-alert {
    grid-column: 1 / -1;
  }

}

@media (min-width: 992px) {

  .quote-layout {
    grid-template-columns: minmax(0, 1fr) 400px;
    align-items: start;
    gap: 42px;
  }

  .quote-summary-card {
    position: sticky;
    top: 110px;
  }

}

@media (min-width: 1200px) {

  .quote-form,
  .quote-summary-card {
    padding: 40px;
  }

  .quote-form::before {
    left: 40px;
    right: 40px;
  }

  .quote-form-grid {
    gap: 22px;
  }

}

/* Melhorias do orçamento simples */
.quote-main-note {
  margin-block-start: 22px;
  padding: 18px;
  background: hsla(0, 0%, 100%, 0.78);
  border: 1px solid var(--platinum);
  border-radius: 16px;
  box-shadow: var(--shadow-1);
}

.quote-extra-textarea {
  min-height: 120px;
  resize: vertical;
  margin-block-start: 10px;
}

.quote-advanced-open {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  margin-block-start: 16px;
  color: var(--eerie-black);
  background: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: 999px;
  box-shadow: var(--shadow-1);
  font-weight: var(--fw-700);
  padding: 11px 16px;
  transition: var(--transition-1);
}

.quote-advanced-open:is(:hover, :focus-visible) {
  color: var(--white-1);
  background: var(--primary-blue-dark);
  border-color: var(--primary-blue-dark);
}

.quote-advanced-open ion-icon { font-size: 1.9rem; }

.quote-advanced-modal,
.quote-advanced-overlay {
  position: fixed;
  inset: 0;
  z-index: 30;
}

.quote-advanced-overlay {
  background: hsla(220, 18%, 10%, 0.62);
  backdrop-filter: blur(8px);
}

.quote-advanced-dialog {
  position: fixed;
  z-index: 31;
  top: 50%;
  left: 50%;
  width: min(920px, calc(100% - 28px));
  max-height: min(86vh, 760px);
  overflow: auto;
  transform: translate(-50%, -50%);
  background: var(--white-1);
  border: 1px solid var(--platinum);
  border-radius: 22px;
  box-shadow: 0 26px 80px hsla(220, 18%, 12%, 0.28);
  padding: 26px;
}

.quote-advanced-text {
  margin-block: 6px 20px;
  color: var(--gray-web);
  font-size: var(--fs-6);
}

.quote-advanced-dialog .quote-manual-title {
  margin-block-start: 8px;
}

.quote-advanced-dialog .quote-form-grid {
  margin-block-start: 18px;
}

.quote-template-card .quote-option-price,
.quote-option .quote-option-price,
.quote-total-box,
.quote-monthly { display: none !important; }

.quote-template-lock {
  color: var(--primary-blue-dark);
  background: var(--accent-sage-light);
  border-color: hsla(205, 78%, 45%, 0.18);
}

.quote-summary-note {
  background: hsla(205, 78%, 45%, 0.08);
  border: 1px solid hsla(205, 78%, 45%, 0.16);
  border-radius: 12px;
  padding: 12px;
}

@media (max-width: 575px) {
  .quote-advanced-dialog { padding: 20px; }
  .quote-advanced-open { width: 100%; justify-content: center; }
}
