:root {
  --cream: #f9f6ef;
  --sand: #eadfce;
  --forest: #1e473c;
  --mint: #8bc7aa;
  --text: #23322e;
  --muted: #5d7069;
  --white: #ffffff;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  color: var(--text);
  font-family: "Manrope", "Segoe UI", sans-serif;
  background: var(--white);
}
main { background: var(--white); }
a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; display: block; border-radius: 20px; }
.container { width: min(1160px, 92%); margin-inline: auto; }
.nav {
  position: sticky; top: 0; z-index: 40;
  background: var(--white);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid color-mix(in oklab, var(--sand) 80%, white);
}
.nav-inner { display: flex; justify-content: space-between; align-items: center; gap: 1rem; padding: .95rem 0; }
.brand { display: flex; align-items: center; gap: .7rem; font-weight: 700; }
.logo-img {
  width: 420px;
  height: 60px;
  border-radius: .6rem;
  object-fit: cover;
  border: 2px solid var(--white);
  box-shadow: 0 6px 14px rgba(30,71,60,.2);
}
.links { display: flex; gap: 1rem; color: var(--muted); }
.hero { padding: 4rem 0 2rem; position: relative; overflow: hidden; }
.blob {
  position: absolute; border-radius: 999px; filter: blur(45px); opacity: .35; pointer-events: none;
}
.blob.one { width: 280px; height: 280px; background: #95d6b1; top: -70px; right: -20px; }
.blob.two { width: 260px; height: 260px; background: #efdcc1; bottom: -100px; left: -50px; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-items: center; }
.kicker { font-size: .9rem; letter-spacing: .12em; text-transform: uppercase; color: var(--forest); }
.hero h1 { font-family: "Fraunces", serif; font-size: clamp(2.2rem, 5.5vw, 4.6rem); line-height: .96; margin: .6rem 0 .7rem; }
.hero p { color: var(--muted); max-width: 47ch; }
.btn { display: inline-block; margin-top: 1rem; padding: .75rem 1.15rem; border-radius: 999px; background: var(--forest); color: #fff; }
.frame { background: #fff; border: 1px solid #eadfce; border-radius: 24px; padding: .9rem; box-shadow: 0 18px 30px rgba(49,73,64,.08); }
.section { padding: 2.4rem 0; }
.section h2 { font-family: "Fraunces", serif; font-size: clamp(1.7rem, 4vw, 3rem); margin: 0 0 .6rem; }
.ribbon {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
}
.ribbon-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.ribbon article {
  border: 1px solid #e8dccd;
  background: #fff;
  border-radius: 16px;
  padding: 1rem;
  position: relative;
  overflow: hidden;
  transition: color .35s ease, transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.ribbon article::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 110% -10%, rgba(11,48,115,.22) 0%, rgba(11,48,115,0) 60%);
  opacity: 0;
  transform: translateY(10%);
  transition: opacity .35s ease, transform .35s ease;
  z-index: 0;
}
.ribbon article > * { position: relative; z-index: 1; }
.ribbon article:hover {
  color: #23322e;
  transform: translateY(-4px);
  border-color: #c9d5ea;
  box-shadow: 0 18px 30px rgba(11,48,115,.2);
}
.ribbon article:hover::after { opacity: 1; transform: translateY(0); }
.ribbon article:hover p { color: #4b5a69; }
.ribbon p { color: var(--muted); margin: .35rem 0 0; }
.journey { display: grid; grid-template-columns: repeat(auto-fit,minmax(210px,1fr)); gap: .8rem; }
.journey article { border: 1px dashed #d8c8b3; background: #fff; border-radius: 16px; padding: 1rem; }
.journey strong { font-size: 1.8rem; color: var(--forest); }
.wall {
  columns: 3 240px;
  column-gap: .8rem;
}
.wall figure {
  break-inside: avoid;
  margin: 0 0 .8rem;
  border-radius: 16px;
  overflow: hidden;
}
.wall .floaty { transform: translateY(0); }
.wall img, .wall video { width: 100%; transition: transform 1s ease; }
.wall figure:hover img { transform: scale(1.08); }
.gallery-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .8rem;
}
.gallery-row img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  border-radius: 18px;
  box-shadow: 0 14px 26px rgba(49,73,64,.12);
}
.contact {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
}
.card { border: 1px solid #e8dccd; background: #fff; border-radius: 18px; padding: 1rem; }
.input { width: 100%; border: 1px solid #dfd0be; border-radius: 12px; padding: .75rem; margin-bottom: .6rem; font: inherit; }
.send { border: 0; border-radius: 999px; padding: .72rem 1rem; background: var(--forest); color: #fff; }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.reveal.show { opacity: 1; transform: translateY(0); }
.floaty { transform: translateY(var(--drift, 0)); transition: transform .1s linear; }
footer { color: var(--muted); padding: 2rem 0 3rem; }

.intro-overlay {
  position: fixed;
  inset: 0;
  background: var(--white);
  display: grid;
  place-items: center;
  z-index: 9999;
  opacity: 1;
  transition: opacity .4s ease;
}
.intro-overlay.hidden { opacity: 0; pointer-events: none; }
.intro-logo-wrap {
  position: relative;
  width: min(1296px, 96vw);
  height: min(360px, 55vw);
}
.intro-logo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.intro-logo.base {
  filter: grayscale(1) contrast(1.1);
  -webkit-mask-image: linear-gradient(120deg, transparent 0%, #fff 10%, #fff 28%, transparent 40%);
  -webkit-mask-size: 200% 100%;
  -webkit-mask-position: 0% 0%;
  mask-image: linear-gradient(120deg, transparent 0%, #fff 10%, #fff 28%, transparent 40%);
  mask-size: 200% 100%;
  mask-position: 0% 0%;
  animation: logo-write 1.2s ease forwards;
}
.intro-logo.color {
  opacity: 0;
  animation: logo-color 1.2s ease .6s forwards;
}
@keyframes logo-write {
  from { -webkit-mask-position: 0% 0%; mask-position: 0% 0%; }
  to { -webkit-mask-position: 120% 0%; mask-position: 120% 0%; }
}
@keyframes logo-color {
  from { opacity: 0; }
  to { opacity: 1; }
}
@media (max-width: 900px) {
  .hero-grid, .contact { grid-template-columns: 1fr; }
  .ribbon { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ribbon-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .ribbon, .ribbon-2 { grid-template-columns: 1fr; }
}
