/* GENERATED by _port.py from creative/mockups/ — edit the mockup, not this file. */
  :root {
    --cream: #F8F4EB;
    --cream-2: #F1EADC;
    --paper: #FBF8F1;
    --navy: #1C2B4A;
    --navy-2: #22345A;
    --navy-3: #16223C;
    --navy-soft: rgba(28,43,74,0.68);
    --navy-faint: rgba(28,43,74,0.45);
    --gold: #C7A44D;
    --gold-2: #D8B968;
    --gold-deep: #9A7B2D;
    --wood: #C9A36B;
    --border: rgba(28,43,74,0.14);
    --radius: 0.5rem;
  }
  * { margin: 0; padding: 0; box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body { font-family: 'Instrument Sans', system-ui, sans-serif; background: var(--cream); color: var(--navy); -webkit-font-smoothing: antialiased; }
  .container { max-width: 1280px; margin: 0 auto; padding-left: clamp(1.25rem, 3vw, 2.5rem); padding-right: clamp(1.25rem, 3vw, 2.5rem); }
  section { padding: clamp(4rem, 9vh, 7rem) 0; }
  h3 { font-size: 1.08rem; font-weight: 700; }
  .kicker { display: inline-block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.18em; color: var(--gold-deep); margin-bottom: 1rem; }
  .lede { margin-top: 1rem; max-width: 56ch; font-size: 1.08rem; line-height: 1.6; color: var(--navy-soft); }
  .gold-i { font-style: italic; color: var(--gold-deep); }
  .placeholder-tag { display: none; } /* internal annotations — flip back to inline-block to review open items */
  /* ---------- topbar / nav ---------- */
  .topbar { position: sticky; top: 0; z-index: 50; background: rgba(248,244,235,0.92); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
  .topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; max-width: 1280px; margin: 0 auto; padding: 0.9rem clamp(1.25rem, 3vw, 2.5rem); }
  .brand-chip { display: inline-flex; align-items: center; }
  .brand-chip img { height: 38px; width: auto; display: block; }
  .nav-links { display: flex; align-items: center; gap: 1.5rem; font-size: 0.92rem; font-weight: 500; }
  .nav-links > a, .nav-trigger { position: relative; color: var(--navy-soft); text-decoration: none; transition: color .2s; padding: 0.35rem 0; }
  .nav-links > a:hover { color: var(--gold-deep); }
  .nav-trigger { font: inherit; background: none; border: 0; cursor: pointer; display: inline-flex; align-items: center; gap: 0.35rem; }
  .nav-trigger:hover { color: var(--gold-deep); }
  .nav-trigger svg { transition: transform .25s ease; margin-top: 1px; }
  .nav-item { position: relative; }
  .nav-item.open .nav-trigger svg { transform: rotate(180deg); }
  @media (hover: hover) { .nav-item:hover .nav-trigger svg { transform: rotate(180deg); } }
  /* dropdown */
  .drop { position: absolute; top: 100%; left: 50%; transform: translateX(-50%); padding-top: 12px; opacity: 0; visibility: hidden; translate: 0 8px; transition: opacity .25s cubic-bezier(0.22,0.61,0.36,1), translate .25s cubic-bezier(0.22,0.61,0.36,1), visibility .25s; z-index: 60; }
  .nav-item.open .drop { opacity: 1; visibility: visible; translate: 0 0; }
  @media (hover: hover) { .nav-item:hover .drop { opacity: 1; visibility: visible; translate: 0 0; } }
  .drop-inner { min-width: 272px; background: #fff; border: 1px solid var(--border); border-radius: 16px; box-shadow: 0 28px 56px -28px rgba(28,43,74,0.45); padding: 0.55rem; display: flex; flex-direction: column; }
  .drop-inner a { display: flex; align-items: center; gap: 0.75rem; padding: 0.55rem 0.7rem; border-radius: 12px; font-size: 0.93rem; font-weight: 500; color: var(--navy); text-decoration: none; transition: background .2s, color .2s; }
  .ico { width: 42px; height: 42px; border-radius: 12px; flex: 0 0 auto; display: grid; place-items: center;
    background: linear-gradient(150deg, #FFFDF6, rgba(199,164,77,0.14));
    border: 1px solid rgba(199,164,77,0.3);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 2px 6px -3px rgba(28,43,74,0.25);
    transition: transform .25s cubic-bezier(0.22,0.61,0.36,1), box-shadow .25s; }
  .ico svg { width: 30px; height: 30px; }
  .d-txt { display: flex; flex-direction: column; gap: 0.1rem; }
  .d-title { font-weight: 600; font-size: 0.93rem; color: var(--navy); display: inline-flex; align-items: center; gap: 0.5rem; }
  .d-desc { font-size: 0.78rem; color: var(--navy-faint); }
  .drop-inner a:hover .ico, .mobile-panel a:hover .ico { transform: translateY(-1px) scale(1.07); box-shadow: 0 8px 16px -8px rgba(199,164,77,0.75); }
  .mobile-panel a { display: flex; align-items: center; gap: 0.7rem; }
  .mobile-panel .mp-cta { display: inline-flex; justify-content: center; }
  .drop-inner a:hover { background: rgba(199,164,77,0.1); color: var(--gold-deep); }
  .soon { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold-deep); background: rgba(199,164,77,0.14); border-radius: 4px; padding: 0.12rem 0.4rem; }
  .nav-right { display: flex; align-items: center; gap: 0.7rem; }
  /* burger + mobile panel */
  .nav-burger { display: none; background: none; border: 0; cursor: pointer; padding: 0.4rem; }
  .nav-burger svg line { stroke: var(--navy); stroke-width: 2; stroke-linecap: round; transition: transform .3s ease, opacity .3s ease; transform-origin: center; }
  .nav-burger.open .l1 { transform: translateY(6px) rotate(45deg); }
  .nav-burger.open .l2 { opacity: 0; }
  .nav-burger.open .l3 { transform: translateY(-6px) rotate(-45deg); }
  .mobile-panel { display: none; position: absolute; top: 100%; left: 0; right: 0; background: rgba(248,244,235,0.98); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); padding: 1.2rem clamp(1.25rem, 3vw, 2.5rem) 1.6rem; max-height: calc(100vh - 62px); overflow: auto; }
  .topbar.menu-open .mobile-panel { display: block; animation: mpDown .3s cubic-bezier(0.22,0.61,0.36,1); }
  @keyframes mpDown { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
  .mp-label { display: block; font-size: 0.68rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold-deep); margin: 1.1rem 0 0.3rem; }
  .mobile-panel a { display: block; padding: 0.55rem 0; font-size: 1.02rem; font-weight: 500; color: var(--navy); text-decoration: none; }
  .mp-group a { padding-left: 0.9rem; }
  .mobile-panel .mp-cta { margin-top: 1.3rem; text-align: center; }
  body.menu-locked { overflow: hidden; }
  @media (max-width: 860px) {
    .nav-links { display: none; }
    .nav-burger { display: inline-flex; }
    .topbar .nav-cta { display: none; } /* .topbar prefix beats global .btn display on mobile */
  }
  @media (prefers-reduced-motion: reduce) {
    .drop { transition: none; }
    .topbar.menu-open .mobile-panel { animation: none; }
    .nav-trigger svg, .nav-burger svg line { transition: none; }
  }
  .rise { opacity: 0; transform: translateY(24px); animation: rise .8s cubic-bezier(0.22,0.61,0.36,1) forwards; }
  @keyframes rise { to { opacity: 1; transform: translateY(0); } }
  .final { color: var(--navy); background:
      radial-gradient(90% 55% at 50% 100%, rgba(199,164,77,0.16) 0%, transparent 60%),
      radial-gradient(60% 40% at 12% 0%, rgba(255,255,255,0.5) 0%, transparent 55%),
      linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 55%, #EAE0C8 100%); }
  .final-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2.5rem, 5vw, 5rem); align-items: start; }
  @media (max-width: 900px) { .final-grid { grid-template-columns: 1fr; } }
  .final h2 em { font-style: italic; color: var(--gold-deep); }
  .final .lede { color: var(--navy-soft); }
  .reach { margin-top: 2rem; list-style: none; display: flex; flex-direction: column; gap: 1rem; }
  .reach a { display: inline-flex; align-items: center; gap: 0.75rem; font-size: 1.05rem; font-weight: 600; color: var(--navy); text-decoration: none; transition: color .2s; }
  .reach a:hover { color: var(--gold-deep); }
  .reach .r-ico { flex: 0 0 auto; width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--border); background: #fff; display: grid; place-items: center; color: var(--gold-deep); }
  .reach .r-ico svg { width: 17px; height: 17px; }
  .reach .r-hint { display: block; font-size: 0.8rem; font-weight: 500; color: var(--navy-faint); margin-top: 0.1rem; }
  .form { background: linear-gradient(165deg, var(--navy-2) 0%, var(--navy) 55%, var(--navy-3) 100%); color: var(--cream); border-radius: 20px; padding: 2rem; display: flex; flex-direction: column; gap: 0.9rem; box-shadow: 0 40px 80px -42px rgba(28,43,74,0.65), 0 14px 30px -18px rgba(28,43,74,0.35); }
  .form label { font-size: 0.82rem; font-weight: 600; color: rgba(248,244,235,0.85); }
  .form input, .form textarea { font: inherit; font-size: 0.95rem; width: 100%; border: 1px solid rgba(248,244,235,0.14); border-radius: 10px; padding: 0.75rem 0.9rem; background: var(--paper); color: var(--navy); margin-top: 0.3rem; }
  .form input::placeholder, .form textarea::placeholder { color: var(--navy-faint); }
  .form textarea { min-height: 90px; resize: vertical; }
  .form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 0.9rem; }
  @media (max-width: 560px) { .form .row2 { grid-template-columns: 1fr; } }
  .form .btn { position: relative; z-index: 0; overflow: hidden; align-self: flex-start; justify-content: center; margin-top: 0.4rem; background: linear-gradient(105deg, var(--gold) 0%, var(--gold-2) 100%); color: var(--navy-3); font-weight: 700; border: none; box-shadow: 0 14px 30px -14px rgba(199,164,77,0.55); }
  .form .btn::before { content: ""; position: absolute; inset: 0; z-index: -1; border-radius: inherit;
    background: linear-gradient(105deg, var(--navy) 0%, var(--gold-2) 32%, var(--gold) 80%); opacity: 0; transition: opacity .35s ease; }
  .form .btn:hover::before { opacity: 1; }
  .form .fine { font-size: 0.78rem; color: rgba(248,244,235,0.55); }
  footer { background: var(--navy-3); color: rgba(248,244,235,0.6); font-size: 0.88rem; }
  .foot-inner { display: grid; grid-template-columns: 1.45fr 1.1fr 0.85fr 0.85fr 1fr; gap: 2.5rem 2.6rem; padding: 3.2rem clamp(1.25rem, 3vw, 2.5rem) 2.6rem; max-width: 1280px; margin: 0 auto; }
  .foot-inner > .foot-group:nth-child(3) { padding-left: 1.8rem; }
  @media (max-width: 1020px) { .foot-inner { grid-template-columns: 1fr 1fr; } .foot-inner > .foot-group:nth-child(3) { padding-left: 0; } }
  @media (max-width: 600px) { .foot-inner { grid-template-columns: 1fr; } }
  .foot-logo { display: block; }
  .foot-logo img { width: 170px; height: auto; display: block; }
  .foot-desc { margin-top: 1rem; line-height: 1.65; max-width: 34ch; }
  .certs { list-style: none; margin-top: 1.5rem; display: flex; flex-direction: column; gap: 0.6rem; }
  .certs li { display: flex; align-items: center; gap: 0.65rem; color: rgba(248,244,235,0.78); }
  .certs svg { width: 16px; height: 16px; color: var(--gold-2); flex: 0 0 auto; }
  footer a { color: rgba(248,244,235,0.75); text-decoration: none; }
  footer a:hover { color: var(--gold-2); }
  .foot-group .label { display: block; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(248,244,235,0.45); margin-bottom: 0.9rem; }
  .contact-list { list-style: none; display: flex; flex-direction: column; gap: 0.75rem; }
  .contact-list li { display: flex; align-items: flex-start; gap: 0.65rem; }
  .contact-list svg { width: 15px; height: 15px; color: var(--gold-2); flex: 0 0 auto; margin-top: 2px; }
  .icon-row { display: flex; flex-wrap: wrap; gap: 0.6rem; }
  .s-icon { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 50%; border: 1px solid rgba(248,244,235,0.22); color: rgba(248,244,235,0.85); transition: border-color .2s, color .2s; }
  .s-icon:hover { border-color: var(--gold-2); color: var(--gold-2); }
  .s-icon svg { width: 17px; height: 17px; }
  .foot-links { list-style: none; display: flex; flex-direction: column; gap: 0.6rem; }
  .link-cols { display: flex; gap: 2.5rem; }
  .link-cols > div { flex: 1; }
  .sub-gap { height: 1.6rem; }
  .foot-base { border-top: 1px solid rgba(248,244,235,0.12); }
  .foot-base-inner { display: flex; justify-content: center; text-align: center; padding: 1.3rem clamp(1.25rem, 3vw, 2.5rem); max-width: 1280px; margin: 0 auto; font-size: 0.8rem; color: rgba(248,244,235,0.45); }
  .form select { font: inherit; font-size: 0.95rem; width: 100%; border: 1px solid var(--border); border-radius: 10px; padding: 0.75rem 0.9rem; background: var(--paper); color: var(--navy); margin-top: 0.3rem; }

  /* ---------- global buttons (single source for every .btn site-wide) ---------- */
  .btn { display: inline-flex; align-items: center; gap: 0; font: inherit; font-size: 0.98rem; font-weight: 600; cursor: pointer; text-decoration: none; padding: 0.85rem 1.7rem; border-radius: 999px; border: 1.5px solid transparent; transition: color .2s ease, border-color .2s ease, background .2s ease; }
  .btn::after { content: ""; flex: none; width: 0; height: 16px; margin-left: 0; opacity: 0; background-color: currentColor;
    -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.4'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M5%2012h14M13%206l6%206-6%206'/%3E%3C/svg%3E") left center / 16px 16px no-repeat;
    mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.4'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M5%2012h14M13%206l6%206-6%206'/%3E%3C/svg%3E") left center / 16px 16px no-repeat;
    transition: width .28s cubic-bezier(0.22,0.61,0.36,1), opacity .2s ease, margin-left .28s cubic-bezier(0.22,0.61,0.36,1); }
  .btn:hover::after { width: 16px; margin-left: 0.45rem; opacity: 1; }
  .btn-primary { position: relative; z-index: 0; overflow: hidden; background: var(--navy); color: var(--cream); box-shadow: 0 16px 36px -14px rgba(28,43,74,0.5); }
  .btn-primary::before { content: ""; position: absolute; inset: 0; z-index: -1; border-radius: inherit;
    background: linear-gradient(105deg, var(--gold) 0%, var(--gold-deep) 32%, var(--navy) 80%); opacity: 0; transition: opacity .35s ease; }
  .btn-primary:hover::before { opacity: 1; }
  .btn-ghost { background: #fff; border-color: rgba(28,43,74,0.2); color: var(--navy); }
  .btn-ghost:hover { background: rgba(28,43,74,0.05); border-color: rgba(28,43,74,0.32); }
  @media (prefers-reduced-motion: reduce) {
    .btn::after { width: 16px; margin-left: 0.45rem; opacity: 1; transition: none; }
    .btn-primary::before { transition: none; }
  }
