:root {
  --background: #faeee7;
  --headline: #33272a;
  --paragraph: #594a4e;
  --white: #fffffe;
  --pink: #ffa3c6;
  --soft-pink: #ffc6c7;
  --green: #c3f0ca;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.35), transparent 28rem),
    radial-gradient(circle at top right, rgba(195, 240, 202, 0.55), transparent 26rem),
    var(--background);
  color: var(--paragraph);
  font-family: "Poppins", Arial, sans-serif;
  line-height: 1.6;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

header {
  background: rgba(255, 255, 254, 0.94);
  padding: 14px 7%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  border-bottom: 3px solid var(--soft-pink);
  position: sticky;
  top: 0;
  z-index: 10;
}

.logo-link {
  width: 280px;
  flex-shrink: 0;
}

.header-logo {
  width: 280px;
}

nav {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  justify-content: center;
}

nav a {
  color: var(--headline);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.95rem;
}

nav a:hover {
  color: var(--pink);
}

main {
  width: min(1100px, 90%);
  margin: 0 auto;
}

h1,
h2,
h3 {
  font-family: "Fraunces", Georgia, serif;
  color: var(--headline);
  line-height: 1.12;
}

h1 {
  font-size: clamp(2.3rem, 5vw, 4.7rem);
  margin: 0 0 18px;
}

h2 {
  font-size: clamp(1.7rem, 3vw, 2.7rem);
  margin: 0 0 14px;
}

h3 {
  font-size: 1.35rem;
  margin: 0 0 10px;
}

p {
  margin: 0 0 18px;
}

ul {
  padding-left: 22px;
  margin: 14px 0 0;
}

li {
  margin-bottom: 8px;
}

.eyebrow {
  color: var(--pink);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.82rem;
}

.sticker {
  display: inline-block;
  background: var(--green);
  color: var(--headline);
  font-weight: 700;
  padding: 8px 16px;
  border-radius: 999px;
  margin-bottom: 14px;
}

.hero {
  padding: 70px 0 50px;
  display: grid;
  grid-template-columns: 1fr 260px;
  align-items: center;
  gap: 46px;
}

.hero-text {
  position: relative;
}

.hero-text::before {
  content: "";
  width: 70px;
  height: 70px;
  background: var(--green);
  border-radius: 50%;
  position: absolute;
  left: -28px;
  top: -20px;
  z-index: -1;
}

.hero-logo-box {
  background: var(--white);
  border: 3px solid var(--green);
  border-radius: 32px;
  padding: 22px;
  width: 330px;
  box-shadow: 0 18px 35px rgba(51, 39, 42, 0.1);
  transform: rotate(2deg);
}

.hero-logo {
  width: 280px;
  margin: 0 auto;
}

.button-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.button {
  display: inline-block;
  background: var(--pink);
  color: var(--headline);
  text-decoration: none;
  font-weight: 700;
  padding: 12px 22px;
  border-radius: 999px;
  border: 2px solid var(--pink);
  box-shadow: 4px 4px 0 var(--headline);
}

.button:hover {
  background: var(--green);
  border-color: var(--green);
}

.secondary-button {
  background: var(--white);
  border-color: var(--green);
}

.intro-section,
.page-hero,
.callout {
  text-align: center;
  background: var(--white);
  border-radius: 34px;
  padding: 46px;
  margin: 42px 0;
  border: 3px solid var(--green);
  box-shadow: 0 12px 25px rgba(51, 39, 42, 0.06);
}

.intro-section p,
.page-hero p,
.callout p {
  max-width: 790px;
  margin-left: auto;
  margin-right: auto;
}

.fun-section {
  border-color: var(--soft-pink);
}

.cards-section {
  padding: 38px 0;
  text-align: center;
}

.card-grid,
.service-grid,
.portfolio-grid,
.process-grid {
  display: grid;
  gap: 24px;
  margin-top: 28px;
}

.card-grid,
.process-grid {
  grid-template-columns: repeat(3, 1fr);
}

.service-grid,
.portfolio-grid {
  grid-template-columns: repeat(2, 1fr);
}

.card,
.service-card,
.portfolio-card,
.process-grid article,
.contact-card {
  background: var(--white);
  border-radius: 28px;
  padding: 28px;
  border: 3px solid var(--soft-pink);
  box-shadow: 0 10px 22px rgba(51, 39, 42, 0.06);
}

.card {
  text-align: left;
}

.green-card,
.service-card:nth-child(4),
.portfolio-card:nth-child(1) {
  border-color: var(--green);
}

.card-number {
  display: inline-block;
  color: var(--headline);
  background: var(--green);
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  margin-bottom: 14px;
}

.card h3,
.service-card h2,
.portfolio-card h2 {
  color: var(--pink);
}

.green-card h3,
.service-card:nth-child(4) h2,
.portfolio-card:nth-child(1) h2 {
  color: var(--headline);
}

.bento-section {
  margin: 50px 0;
  display: grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: 24px;
  align-items: stretch;
}

.bento-text,
.process-section {
  background: var(--headline);
  color: var(--white);
  border-radius: 34px;
  padding: 36px;
}

.bento-text h2,
.process-section h2,
.process-section h3 {
  color: var(--white);
}

.bento-text p {
  color: var(--white);
}

.bento-img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  border-radius: 30px;
  border: 3px solid var(--green);
  background: var(--white);
}

.tall-img {
  height: 100%;
  min-height: 260px;
}

.process-section {
  margin: 50px 0;
  text-align: center;
}

.process-grid article {
  text-align: left;
  background: var(--white);
}

.process-grid h3,
.process-grid p {
  color: var(--headline);
}

.image-feature {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 30px;
  align-items: center;
  margin: 42px 0;
  background: var(--white);
  border-radius: 30px;
  padding: 28px;
  border: 3px solid var(--green);
}

.image-feature.reverse {
  grid-template-columns: 1fr 260px;
}

.image-feature.reverse img {
  order: 2;
}

.feature-img {
  width: 240px;
  height: 170px;
  object-fit: cover;
  border-radius: 24px;
  border: 3px solid var(--soft-pink);
}

.portfolio-img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 24px;
  border: 3px solid var(--green);
  margin-bottom: 18px;
}

.about-layout,
.contact-layout {
  padding: 60px 0 35px;
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 40px;
  align-items: center;
}

.about-img,
.contact-img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  border-radius: 34px;
  border: 3px solid var(--pink);
  background: var(--white);
}

.contact-layout {
  grid-template-columns: 1fr 340px;
}

.callout {
  border-color: var(--pink);
}

footer {
  margin-top: 60px;
  padding: 34px 7%;
  text-align: center;
  background: var(--headline);
  color: var(--white);
}

.footer-logo {
  width: 100px;
  max-width: 100px;
  height: auto;
  margin: 0 auto 12px;
}

footer p {
  margin-bottom: 6px;
}

@media screen and (max-width: 900px) {
  header {
    flex-direction: column;
  }

  .hero,
  .bento-section,
  .image-feature,
  .image-feature.reverse,
  .about-layout,
  .contact-layout {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .hero-logo-box {
    margin: 0 auto;
  }

  .button-row {
    justify-content: center;
  }

  .card-grid,
  .service-grid,
  .portfolio-grid,
  .process-grid {
    grid-template-columns: 1fr;
  }

  .image-feature.reverse img {
    order: 0;
  }

  .feature-img {
    margin: 0 auto;
  }

  .intro-section,
  .page-hero,
  .callout {
    padding: 34px 24px;
  }

  .about-img,
  .contact-img {
    max-width: 340px;
    margin: 0 auto;
  }
}

/* Contact page */

.contact-layout-stacked {
  display: block;
  margin: 45px auto;
  max-width: 900px;
}

.contact-intro-card {
  text-align: center;
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.35), transparent 18rem),
    radial-gradient(circle at bottom right, rgba(195, 240, 202, 0.55), transparent 18rem),
    var(--white);
  border: 3px solid var(--green);
  border-radius: 34px;
  padding: 42px;
  margin-bottom: 28px;
}

.contact-intro-card h2 {
  margin-bottom: 16px;
}

.contact-mini-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 24px;
}

.contact-mini-grid div {
  background: var(--background);
  border: 2px solid var(--soft-pink);
  border-radius: 22px;
  padding: 20px;
}

.contact-mini-grid h3 {
  color: var(--pink);
  font-size: 1.2rem;
}

.colorful-form {
  background:
    linear-gradient(135deg, rgba(255, 198, 199, 0.45), rgba(195, 240, 202, 0.45)),
    var(--white);
  border: 3px solid var(--soft-pink);
  border-radius: 34px;
  padding: 38px;
  box-shadow: 0 16px 30px rgba(51, 39, 42, 0.09);
}

.form-header {
  text-align: center;
  margin-bottom: 28px;
}

.form-header h2 {
  margin-bottom: 10px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}

.form-group {
  margin-bottom: 20px;
}

.contact-form label {
  display: block;
  color: var(--headline);
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: 8px;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  display: block;
  width: 100%;
  min-height: 54px;
  padding: 14px 16px;
  border: 2px solid var(--pink);
  border-radius: 18px;
  background: #fffffe;
  color: var(--headline);
  font-family: "Poppins", Arial, sans-serif;
  font-size: 1.05rem;
  line-height: 1.5;
}

.contact-form textarea {
  min-height: 185px;
  resize: vertical;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: #8a7479;
  font-family: "Poppins", Arial, sans-serif;
  font-size: 1rem;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--green);
  box-shadow: 0 0 0 5px rgba(195, 240, 202, 0.7);
}

.form-button {
  display: block;
  margin: 10px auto 0;
  cursor: pointer;
  font-family: "Poppins", Arial, sans-serif;
  font-size: 1rem;
}

@media screen and (max-width: 850px) {
  .contact-intro-card,
  .colorful-form {
    padding: 28px;
  }

  .contact-mini-grid,
  .form-row {
    grid-template-columns: 1fr;
  }
}

/* Idea path section */

.idea-path-section {
  margin: 60px 0;
  padding: 44px;
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.45), transparent 18rem),
    radial-gradient(circle at bottom right, rgba(195, 240, 202, 0.65), transparent 18rem),
    var(--white);
  border: 3px solid var(--soft-pink);
  border-radius: 36px;
  box-shadow: 0 14px 28px rgba(51, 39, 42, 0.08);
}

.idea-path-heading {
  text-align: center;
  max-width: 780px;
  margin: 0 auto 32px;
}

.idea-path-heading h2 {
  margin-bottom: 14px;
}

.idea-path-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}

.idea-path-card {
  min-height: 340px;
  display: flex;
  flex-direction: column;
}

.idea-path-card p {
  font-size: 0.95rem;
  line-height: 1.55;
  margin-bottom: 18px;
}

.idea-path-card a {
  display: inline-block;
  width: fit-content;
  margin-top: auto;
  color: var(--headline);
  background: var(--pink);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.92rem;
  padding: 9px 16px;
  border-radius: 999px;
  border: 2px solid var(--pink);
}

.mint-card a {
  background: var(--green);
  border-color: var(--green);
}

.mint-card::before {
  background: rgba(195, 240, 202, 0.6);
}

.idea-path-number {
  width: 44px;
  height: 44px;
  background: var(--pink);
  color: var(--headline);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  margin-bottom: 18px;
  box-shadow: 3px 3px 0 var(--headline);
}

.mint-card .idea-path-number {
  background: var(--green);
}

.idea-path-card h3 {
  color: var(--headline);
  font-size: 1.35rem;
  margin-bottom: 10px;
}

.idea-path-card p {
  font-size: 0.95rem;
  margin-bottom: 18px;
}

.idea-path-card a {
  display: inline-block;
  color: var(--headline);
  background: var(--pink);
  text-decoration: none;
  font-weight: 700;
  padding: 9px 14px;
  border-radius: 999px;
  border: 2px solid var(--pink);
}

.mint-card a {
  background: var(--green);
  border-color: var(--green);
}

.idea-path-card a:hover {
  background: var(--headline);
  color: var(--white);
  border-color: var(--headline);
}

@media screen and (max-width: 1000px) {
  .idea-path-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media screen and (max-width: 650px) {
  .idea-path-section {
    padding: 30px 22px;
  }

  .idea-path-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Pricing section */

.pricing-section {
  margin: 55px 0;
  padding: 44px;
  text-align: center;
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.4), transparent 18rem),
    radial-gradient(circle at bottom right, rgba(195, 240, 202, 0.6), transparent 18rem),
    var(--white);
  border: 3px solid var(--green);
  border-radius: 36px;
  box-shadow: 0 14px 28px rgba(51, 39, 42, 0.08);
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 30px;
}

.pricing-card {
  background: #fffffe;
  border: 3px solid var(--soft-pink);
  border-radius: 28px;
  padding: 26px;
  text-align: left;
  box-shadow: 0 8px 18px rgba(51, 39, 42, 0.06);
  display: flex;
  flex-direction: column;
}

.mint-pricing {
  border-color: var(--green);
}

.price-label {
  color: var(--pink);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.8rem;
  margin-bottom: 10px;
}

.pricing-card h3 {
  color: var(--headline);
  font-size: 1.6rem;
  margin-bottom: 14px;
}

.pricing-card p {
  font-size: 0.95rem;
}

.pricing-card a {
  display: inline-block;
  width: fit-content;
  margin-top: auto;
  color: var(--headline);
  background: var(--pink);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.92rem;
  padding: 9px 16px;
  border-radius: 999px;
  border: 2px solid var(--pink);
}

.mint-pricing a {
  background: var(--green);
  border-color: var(--green);
}

.pricing-card a:hover {
  background: var(--headline);
  color: var(--white);
  border-color: var(--headline);
}

@media screen and (max-width: 1000px) {
  .pricing-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (max-width: 650px) {
  .pricing-section {
    padding: 30px 22px;
  }

  .pricing-grid {
    grid-template-columns: 1fr;
  }
}

/* Center and match pricing button sizes */

.pricing-card a {
  width: 100%;
  max-width: 230px;
  min-height: 54px;
  margin-top: auto;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
}

/* Pricing polish */

.pricing-card {
  min-height: 390px;
  padding: 24px;
}

.pricing-card p {
  line-height: 1.45;
}

.pricing-card a {
  width: 100%;
  max-width: 210px;
  min-height: 50px;
  margin-top: auto;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pricing-grid {
  align-items: stretch;
}

/* FAQ section */

.faq-section {
  margin: 55px 0;
  padding: 44px;
  background: var(--white);
  border: 3px solid var(--soft-pink);
  border-radius: 36px;
  box-shadow: 0 14px 28px rgba(51, 39, 42, 0.08);
  text-align: center;
}

.faq-section h2 {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
}

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 30px;
  text-align: left;
}

.faq-card {
  background:
    radial-gradient(circle at top right, rgba(195, 240, 202, 0.45), transparent 12rem),
    #fffffe;
  border: 3px solid var(--green);
  border-radius: 28px;
  padding: 26px;
}

.faq-card:nth-child(odd) {
  border-color: var(--soft-pink);
  background:
    radial-gradient(circle at top right, rgba(255, 163, 198, 0.35), transparent 12rem),
    #fffffe;
}

.faq-card h3 {
  color: var(--headline);
  font-size: 1.35rem;
}

.faq-card p {
  margin-bottom: 0;
}

@media screen and (max-width: 850px) {
  .faq-section {
    padding: 30px 22px;
  }

  .faq-grid {
    grid-template-columns: 1fr;
  }
}

/* Portfolio proof section */

.portfolio-proof-section {
  margin: 50px 0;
  padding: 44px;
  text-align: center;
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.38), transparent 18rem),
    radial-gradient(circle at bottom right, rgba(195, 240, 202, 0.58), transparent 18rem),
    var(--white);
  border: 3px solid var(--soft-pink);
  border-radius: 36px;
  box-shadow: 0 14px 28px rgba(51, 39, 42, 0.08);
}

.proof-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 30px;
}

.proof-card {
  text-align: left;
  background: #fffffe;
  border: 3px solid var(--soft-pink);
  border-radius: 28px;
  padding: 26px;
  box-shadow: 0 8px 18px rgba(51, 39, 42, 0.06);
}

.mint-proof {
  border-color: var(--green);
}

.proof-card span {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  background: var(--pink);
  color: var(--headline);
  border-radius: 50%;
  font-weight: 800;
  box-shadow: 3px 3px 0 var(--headline);
  margin-bottom: 16px;
}

.mint-proof span {
  background: var(--green);
}

.proof-card h3 {
  color: var(--headline);
}

.skill-note {
  background: var(--background);
  border-left: 5px solid var(--pink);
  border-radius: 14px;
  padding: 14px;
  font-size: 0.92rem;
  font-weight: 600;
  margin-top: 16px;
}

.portfolio-card:nth-child(even) .skill-note {
  border-left-color: var(--green);
}

@media screen and (max-width: 850px) {
  .portfolio-proof-section {
    padding: 30px 22px;
  }

  .proof-grid {
    grid-template-columns: 1fr;
  }
}

/* About page polish */

.about-story-section,
.about-strengths-section {
  margin: 50px 0;
  padding: 44px;
  text-align: center;
  background: var(--white);
  border: 3px solid var(--soft-pink);
  border-radius: 36px;
  box-shadow: 0 14px 28px rgba(51, 39, 42, 0.08);
}

.about-story-section {
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.35), transparent 18rem),
    radial-gradient(circle at bottom right, rgba(195, 240, 202, 0.55), transparent 18rem),
    var(--white);
}

.about-story-section p,
.about-strengths-section p {
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
}

.strength-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 30px;
}

.strength-card {
  text-align: left;
  background: #fffffe;
  border: 3px solid var(--soft-pink);
  border-radius: 28px;
  padding: 26px;
  box-shadow: 0 8px 18px rgba(51, 39, 42, 0.06);
}

.mint-strength {
  border-color: var(--green);
}

.strength-card span {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  background: var(--pink);
  color: var(--headline);
  border-radius: 50%;
  font-weight: 800;
  box-shadow: 3px 3px 0 var(--headline);
  margin-bottom: 16px;
}

.mint-strength span {
  background: var(--green);
}

.strength-card h3 {
  color: var(--headline);
}

@media screen and (max-width: 850px) {
  .about-story-section,
  .about-strengths-section {
    padding: 30px 22px;
  }

  .strength-grid {
    grid-template-columns: 1fr;
  }
}

/* Bottom CTA */

.bottom-cta {
  margin: 60px 0 30px;
  padding: 48px 34px;
  text-align: center;
  background:
    radial-gradient(circle at top left, rgba(255, 163, 198, 0.45), transparent 18rem),
    radial-gradient(circle at bottom right, rgba(195, 240, 202, 0.65), transparent 18rem),
    var(--white);
  border: 3px solid var(--green);
  border-radius: 36px;
  box-shadow: 0 16px 30px rgba(51, 39, 42, 0.09);
}

.bottom-cta h2 {
  max-width: 780px;
  margin-left: auto;
  margin-right: auto;
}

.bottom-cta p {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

.bottom-cta .button {
  margin-top: 10px;
}

@media screen and (max-width: 650px) {
  .bottom-cta {
    padding: 34px 22px;
  }
}

/* Taller portfolio images */

.portfolio-img {
  width: 100%;
  height: 320px;
  object-fit: cover;
  object-position: center;
  border-radius: 22px;
}

/* Fix squished portfolio images */

.portfolio-card .portfolio-img {
  width: 100%;
  height: auto;
  max-height: none;
  aspect-ratio: auto;
  object-fit: contain;
  object-position: center;
  border-radius: 22px;
  background: var(--background);
}

/* Make main page images taller and less cropped */

.hero-logo {
  height: auto;
}

.feature-img,
.portfolio-img,
.contact-img,
.about-img,
.card-img {
  width: 100%;
  min-height: 340px;
  object-fit: cover;
  object-position: center;
  border-radius: 28px;
}

/* Let logo images stay normal */
.header-logo,
.footer-logo,
.hero-logo {
  min-height: 0;
  object-fit: contain;
}

/* Portfolio images can show more of the design work */
.portfolio-card .portfolio-img {
  min-height: 360px;
  object-fit: contain;
  background: var(--background);
  padding: 10px;
}

/* About portrait should not get weirdly stretched */
.about-img {
  min-height: 420px;
  object-fit: cover;
  object-position: center;
}

/* Contact page image */
.contact-img {
  min-height: 420px;
  object-fit: cover;
}

/* Mobile sizing */
@media screen and (max-width: 650px) {
  .feature-img,
  .portfolio-img,
  .contact-img,
  .about-img,
  .card-img {
    min-height: 260px;
  }

  .portfolio-card .portfolio-img {
    min-height: 300px;
  }

  .about-img,
  .contact-img {
    min-height: 320px;
  }
}