    :root {
      --cream: #f4efe6;
      --cream-deep: #ece4d6;
      --sage: #41584b;
      --sage-deep: #2f4138;
      --sage-soft: #7d9082;
      --clay: #bd7c52;
      --clay-soft: #d9a87f;
      --ink: #2b2a26;
      --muted: #6c685f;
      --line: rgba(43, 42, 38, .12);
    }

    * {
      box-sizing: border-box
    }

    html {
      scroll-behavior: smooth
    }

    body {
      font-family: 'Mulish', sans-serif;
      color: var(--ink);
      background: var(--cream);
      line-height: 1.7;
      overflow-x: hidden;
    }

    h1,
    h2,
    h3,
    h4,
    .display-font {
      font-family: 'Fraunces', serif;
      font-weight: 400;
      letter-spacing: -.01em;
      line-height: 1.1;
    }

    .text-clay {
      color: var(--clay) !important
    }

    .text-sage {
      color: var(--sage) !important
    }

    .eyebrow {
      font-family: 'Mulish', sans-serif;
      text-transform: uppercase;
      letter-spacing: .28em;
      font-size: .72rem;
      font-weight: 600;
      color: var(--clay);
    }

    /* soft grain / texture backdrop */
    .grain::before {
      content: "";
      position: fixed;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      background-image: radial-gradient(rgba(65, 88, 75, .04) 1px, transparent 1px);
      background-size: 22px 22px;
    }

    /* NAV */
    .navbar {
      background: rgba(244, 239, 230, .82);
      backdrop-filter: blur(12px);
      border-bottom: 1px solid var(--line);
      transition: padding .3s ease;
    }

    .navbar-brand {
      font-family: 'Fraunces', serif;
      font-size: 1.25rem;
      color: var(--sage) !important;
      letter-spacing: -.01em;
      display: flex;
      align-items: center;
      gap: .6rem
    }

    .navbar-brand img {
      height: 38px;
      width: auto;
      max-width: min(55vw, 240px);
      object-fit: contain;
      display: block
    }

    .navbar-brand span {
      color: var(--clay)
    }

    .nav-link {
      color: var(--ink) !important;
      font-weight: 500;
      font-size: .92rem;
      position: relative;
      margin: 0 .35rem
    }

    .nav-link::after {
      content: "";
      position: absolute;
      left: .6rem;
      right: .6rem;
      bottom: .25rem;
      height: 1px;
      background: var(--clay);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .3s ease;
    }

    .nav-link:hover::after {
      transform: scaleX(1)
    }

    .lang-switch .btn {
      border: 1px solid var(--line);
      color: var(--muted);
      font-weight: 600;
      font-size: .72rem;
      padding: .2rem .5rem;
      border-radius: 2px;
      background: transparent;
    }

    .lang-switch .btn.active {
      background: var(--sage);
      color: var(--cream);
      border-color: var(--sage)
    }

    /* HERO */
    .hero {
      position: relative;
      padding: 9rem 0 6rem;
      background:
        radial-gradient(120% 90% at 85% 10%, rgba(189, 124, 82, .10), transparent 60%),
        radial-gradient(100% 80% at 0% 100%, rgba(65, 88, 75, .10), transparent 55%);
    }

    .hero h1 {
      font-size: clamp(2.6rem, 6vw, 5rem)
    }

    .hero .lede {
      font-size: 1.15rem;
      color: var(--muted);
      max-width: 34ch
    }

    .hero-mark {
      font-family: 'Fraunces', serif;
      font-style: italic;
      color: var(--clay);
    }

    .orb {
      position: absolute;
      border-radius: 50%;
      background: linear-gradient(160deg, var(--sage), var(--sage-soft));
      filter: blur(1px);
      opacity: .9;
    }

    .hero-card {
      background: var(--sage-deep);
      color: var(--cream);
      border-radius: 6px;
      padding: 2.5rem;
      position: relative;
      overflow: hidden;
      box-shadow: 0 30px 60px -30px rgba(47, 65, 56, .55);
    }

    .hero-card::after {
      content: "";
      position: absolute;
      right: -40px;
      bottom: -40px;
      width: 180px;
      height: 180px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(217, 168, 127, .35), transparent 70%);
    }

    .hero-card .leaf {
      font-size: 1.6rem;
      color: var(--clay-soft)
    }

    /* buttons */
    .btn-clay {
      background: var(--clay);
      color: #fff;
      border: none;
      border-radius: 2px;
      padding: .7rem 1.6rem;
      font-weight: 600;
      letter-spacing: .02em;
      transition: .25s;
    }

    .btn-clay:hover {
      background: #a96a43;
      color: #fff;
      transform: translateY(-2px)
    }

    .btn-ghost {
      border: 1px solid var(--sage);
      color: var(--sage);
      border-radius: 2px;
      padding: .7rem 1.6rem;
      font-weight: 600;
      background: transparent;
      transition: .25s;
    }

    .btn-ghost:hover {
      background: var(--sage);
      color: var(--cream)
    }

    section {
      padding: 5.5rem 0
    }

    .section-line {
      width: 46px;
      height: 2px;
      background: var(--clay);
      display: inline-block;
      margin-bottom: 1.2rem
    }

    /* about */
    .about-img {
      background: linear-gradient(150deg, var(--cream-deep), #e3d8c4);
      border-radius: 6px;
      min-height: 420px;
      position: relative;
      overflow: hidden;
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .about-img .mono {
      font-family: 'Fraunces', serif;
      font-size: 8rem;
      color: rgba(65, 88, 75, .18)
    }

    .quality-seal {
      display: block;
      width: auto;
      height: auto;
      max-width: calc(100% - 2rem);
      max-height: 350px;
      object-fit: contain
    }

    .quality-seal-double {
      max-width: calc(100% - 1rem);
      max-height: 370px
    }
    
    .about-img .badge-soft {
      position: absolute;
      bottom: 1.4rem;
      left: 1.4rem;
      background: var(--cream);
      padding: .6rem 1rem;
      border-radius: 3px;
      font-size: .8rem;
      font-weight: 600;
      color: var(--sage);
      box-shadow: 0 12px 30px -18px rgba(0, 0, 0, .4);
    }

    /* services */
    .service-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: 5px;
      padding: 2rem;
      height: 100%;
      transition: .3s;
    }

    .service-card:hover {
      transform: translateY(-5px);
      box-shadow: 0 24px 40px -28px rgba(47, 65, 56, .4);
      border-color: transparent
    }

    .service-card .ico {
      width: 48px;
      height: 48px;
      border-radius: 50%;
      background: var(--cream-deep);
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--sage);
      font-size: 1.3rem;
      margin-bottom: 1.2rem;
    }

    .service-card h3 {
      font-size: 1.3rem;
      margin-bottom: .5rem
    }

    /* team */
    .team-band {
      background: var(--sage-deep);
      color: var(--cream)
    }

    .team-band .eyebrow {
      color: var(--clay-soft)
    }

    .team-card {
      background: rgba(255, 255, 255, .05);
      border: 1px solid rgba(255, 255, 255, .12);
      border-radius: 5px;
      padding: 1.8rem;
      height: 100%;
      transition: .3s;
    }

    .team-card:hover {
      background: rgba(255, 255, 255, .09);
      transform: translateY(-4px)
    }

    .team-card .avatar {
      width: 56px;
      height: 56px;
      border-radius: 50%;
      background: linear-gradient(160deg, var(--clay), var(--clay-soft));
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: 'Fraunces', serif;
      color: #fff;
      font-size: 1.4rem;
      margin-bottom: 1rem;
    }

    .team-card a {
      color: var(--clay-soft);
      text-decoration: none;
      font-size: .85rem;
      word-break: break-all
    }

    .team-card a:hover {
      text-decoration: underline
    }

    .team-card.lead-card {
      background: rgba(189, 124, 82, .16);
      border-color: rgba(217, 168, 127, .4)
    }

    /* info strip */
    .info-strip {
      background: var(--cream-deep)
    }

    .info-item i {
      color: var(--clay);
      font-size: 1.5rem
    }

    /* contact */
    .contact-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: 6px;
      padding: 2.5rem
    }

    .map-wrap {
      border-radius: 6px;
      overflow: hidden;
      border: 1px solid var(--line);
      min-height: 340px
    }

    .map-wrap iframe {
      width: 100%;
      height: 100%;
      min-height: 340px;
      border: 0;
      display: block
    }

    .contact-card a {
      color: var(--sage);
      font-weight: 600
    }

    /* footer */
    footer {
      background: var(--sage-deep);
      color: rgba(244, 239, 230, .8)
    }

    footer a {
      color: var(--clay-soft);
      text-decoration: none
    }

    footer a:hover {
      text-decoration: underline
    }

    footer .brand {
      font-family: 'Fraunces', serif;
      color: var(--cream);
      font-size: 1.3rem
    }

    .vab-banner {
      background: linear-gradient(120deg, var(--clay), #a96a43);
      color: #fff;
      border-radius: 6px;
      padding: 2rem 2.4rem;
    }

    .vab-banner a.btn {
      background: #fff;
      color: var(--clay);
      border: none;
      font-weight: 700;
      border-radius: 2px
    }

    .vab-banner a.btn:hover {
      background: var(--cream)
    }

    /* reveal */
    .reveal {
      opacity: 0;
      transform: translateY(24px);
      transition: opacity .7s ease, transform .7s ease
    }

    .reveal.in {
      opacity: 1;
      transform: none
    }

    @media(max-width:991px) {
      .hero {
        padding: 7rem 0 4rem
      }

      section {
        padding: 4rem 0
      }
    }
