/* ----- Type ----- */
@font-face{
  font-family:"Fraunces";
  font-style:normal;
  font-weight:300 700;
  font-display:swap;
  src:local("Fraunces");
}
@font-face{
  font-family:"Inter";
  font-style:normal;
  font-weight:300 700;
  font-display:swap;
  src:local("Inter");
}

:root{
  --tank-1:#3da8c8;
  --tank-2:#1f7da3;
  --tank-3:#0e547a;
  --gold:#FFC107;
  --gold-soft:rgba(255,193,7,0.25);
  --cream:#f5f0e8;
  --cream-dim:rgba(245,240,232,0.82);
  --coral:#c87b6a;
  --kelp-1:#0a4d3d;
  --kelp-2:#1a6b52;
  --sand:#9b7a3a;
  --glass-bg:rgba(6,28,52,0.68);
  --glass-border:rgba(255,193,7,0.32);
  --serif:"Fraunces", "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:#0e547a;color:var(--cream);}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  letter-spacing:0.005em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  min-height:100vh;
  overflow-x:hidden;
}

/* ----- Tank (fixed, full-bleed, behind everything) ----- */
.tank{
  position:fixed;
  inset:0;
  z-index:0;
  overflow:hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 10%, rgba(180,230,245,0.55), transparent 70%),
    linear-gradient(180deg, var(--tank-1) 0%, var(--tank-2) 55%, var(--tank-3) 100%);
}

/* Glass bezel */
.bezel{
  position:fixed;
  inset:24px;
  z-index:6;
  border:1px solid rgba(255,193,7,0.18);
  border-radius:6px;
  pointer-events:none;
  box-shadow:
    inset 0 0 60px rgba(0,0,0,0.45),
    inset 0 0 1px rgba(255,193,7,0.10);
}
.bezel::before,.bezel::after{
  content:"";
  position:absolute;
  width:120px;height:120px;
  background:radial-gradient(circle at center, rgba(255,193,7,0.18), transparent 60%);
  pointer-events:none;
}
.bezel::before{top:-30px;left:-30px}
.bezel::after{bottom:-30px;right:-30px}
.bezel-corner{
  position:fixed;
  z-index:6;
  width:140px;height:140px;
  pointer-events:none;
  background:radial-gradient(circle at center, rgba(255,193,7,0.14), transparent 65%);
}
.bezel-corner.tr{top:0;right:0}
.bezel-corner.bl{bottom:0;left:0}

/* Caustics */
.caustics{
  position:absolute;
  left:0;right:0;top:0;bottom:0;
  width:100%;
  height:100%;
  opacity:0.55;
  mix-blend-mode:screen;
  pointer-events:none;
  filter:blur(0.6px);
  transition:opacity 600ms ease;
  -webkit-mask-image:linear-gradient(180deg, rgba(255,255,255,0.85) 0%, rgba(255,255,255,0.95) 50%, rgba(255,255,255,0.7) 100%);
          mask-image:linear-gradient(180deg, rgba(255,255,255,0.85) 0%, rgba(255,255,255,0.95) 50%, rgba(255,255,255,0.7) 100%);
}
.caustics-dim{opacity:0.32}

/* Substrate */
.substrate{
  position:absolute;
  left:0;right:0;bottom:0;
  height:6vh;
  min-height:36px;
  background:linear-gradient(180deg, transparent 0%, rgba(155,122,58,0.18) 30%, rgba(155,122,58,0.55) 70%, rgba(40,28,12,0.9) 100%);
  pointer-events:none;
}
.substrate::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 60%, rgba(0,0,0,0.4), transparent 25%),
    radial-gradient(circle at 70% 80%, rgba(0,0,0,0.35), transparent 20%),
    radial-gradient(circle at 90% 50%, rgba(155,122,58,0.4), transparent 15%);
}

/* Plants */
.plants{
  position:absolute;
  left:0;right:0;bottom:0;
  height:55%;
  pointer-events:none;
}
.kelp{
  position:absolute;
  bottom:-2px;
  transform-origin:bottom center;
  animation:sway var(--sway-dur, 7s) ease-in-out infinite;
}
@keyframes sway{
  0%,100%{transform:rotate(var(--sway-from, -3deg)) skewX(-1deg)}
  50%{transform:rotate(var(--sway-to, 3deg)) skewX(1deg)}
}

/* Bubbles (DOM) */
.bubbler{
  position:absolute;
  left:5%;
  bottom:0;
  width:60px;
  height:100%;
  pointer-events:none;
}
.bubble{
  position:absolute;
  bottom:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.85), rgba(212,232,240,0.35) 60%, rgba(212,232,240,0) 75%);
  border-radius:50%;
  box-shadow:inset 0 0 4px rgba(255,255,255,0.5);
  opacity:0;
  animation-name:rise;
  animation-timing-function:ease-in;
  animation-iteration-count:infinite;
}
@keyframes rise{
  0%{transform:translate(0,0) scale(0.6); opacity:0}
  10%{opacity:0.55}
  60%{opacity:0.55}
  85%{opacity:0.4}
  100%{transform:translate(var(--drift,8px), calc(-1 * var(--rise,80vh))) scale(1.05); opacity:0}
}

/* Ornamental diver */
.diver{
  position:absolute;
  right:8%;
  bottom:5.5vh;
  width:130px;
  height:200px;
  z-index:3;
  pointer-events:none;
  filter:drop-shadow(0 10px 14px rgba(0,0,0,0.45));
  animation:diver-bob 6.5s ease-in-out infinite;
  transform-origin:50% 90%;
}
@keyframes diver-bob{
  0%,100%{transform:translateY(0) rotate(-1.2deg)}
  50%{transform:translateY(-6px) rotate(1.2deg)}
}
.diver-helmet{
  transform-origin:50% 70%;
  animation:diver-look 9s ease-in-out infinite;
}
@keyframes diver-look{
  0%,100%{transform:rotate(-3deg)}
  50%{transform:rotate(3deg)}
}
.diver-bubbles{
  position:fixed;
  pointer-events:none;
  z-index:3;
  width:60px;
  height:90vh;
}
.diver-bub{
  position:absolute;
  bottom:0;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.95), rgba(212,232,240,0.4) 60%, transparent 78%);
  border-radius:50%;
  opacity:0;
  box-shadow:inset 0 0 4px rgba(255,255,255,0.6);
}
@keyframes diver-bubble-rise{
  0%{transform:translate(0,0) scale(0.4); opacity:0}
  10%{opacity:0.85}
  85%{opacity:0.55}
  100%{transform:translate(var(--db-drift,10px), -90vh) scale(1.15); opacity:0}
}
@media (max-width:560px){
  .diver{width:90px; height:140px; right:5%; bottom:4.5vh}
}
@media (prefers-reduced-motion:reduce){
  .diver, .diver-helmet{animation:none}
}

/* Filter outflow particles */
.outflow{
  position:absolute;
  top:0;right:0;
  width:38vw;
  height:42vh;
  pointer-events:none;
  opacity:0.18;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(225deg, #000 0%, #000 40%, transparent 80%);
          mask-image:linear-gradient(225deg, #000 0%, #000 40%, transparent 80%);
}
.particle{
  position:absolute;
  width:1.5px;height:1.5px;
  background:#fff;
  border-radius:50%;
  animation:drift var(--p-dur, 6s) linear infinite;
}
@keyframes drift{
  from{transform:translate(0,-10px); opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  to{transform:translate(calc(-1 * var(--p-x, 200px)), var(--p-y, 350px)); opacity:0}
}

/* Fish canvas */
#fish-canvas{
  position:fixed;
  inset:0;
  z-index:2;
  pointer-events:none;
}

/* Cursor trail bubbles */
.cursor-bubble{
  position:fixed;
  z-index:3;
  pointer-events:none;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,0.9), rgba(212,232,240,0.2) 70%, transparent);
  border-radius:50%;
  animation:cursor-rise 1.6s ease-out forwards;
}
@keyframes cursor-rise{
  0%{opacity:0; transform:translate(0,0) scale(0.4)}
  20%{opacity:0.7}
  100%{opacity:0; transform:translate(var(--cb-x,4px), -60px) scale(1)}
}

/* ----- Content layer ----- */
.page{
  position:relative;
  z-index:10;
  width:100%;
}
.shell{
  max-width:1180px;
  margin:0 auto;
  padding:0 32px;
}

/* Topbar — fixed, scroll-aware aquarium glass */
.topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:50;
  padding:18px 0;
  /* slight base glass so the topbar reads on light page bgs (e.g. /press cream)
     while still feeling transparent over tank */
  background:rgba(2,8,28,0.32);
  backdrop-filter:blur(8px) saturate(120%);
  -webkit-backdrop-filter:blur(8px) saturate(120%);
  border-bottom:1px solid rgba(255,193,7,0.10);
  transition:background 280ms ease, backdrop-filter 280ms ease, border-color 280ms ease, padding 280ms ease;
}
.topbar.scrolled{
  background:rgba(2,8,28,0.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:rgba(255,193,7,0.22);
  padding:12px 0;
  box-shadow:0 12px 40px rgba(1,3,15,0.55);
}
.topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brandmark{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--cream);
}
.brandmark-glyph{
  width:34px;height:34px;
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, rgba(255,193,7,0.95), rgba(255,193,7,0.15) 70%, transparent);
  border:1px solid rgba(255,193,7,0.35);
  position:relative;
  flex:0 0 auto;
}
.brandmark-glyph::after{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(245,240,232,0.6), transparent 60%);
}
.brandmark-text{
  font-family:var(--serif);
  font-weight:500;
  font-size:18px;
  letter-spacing:0.01em;
  line-height:1.1;
}
.brandmark-text small{
  display:block;
  font-family:var(--sans);
  font-weight:400;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--cream-dim);
  margin-top:3px;
}
nav.topnav{
  display:flex;
  gap:28px;
  align-items:center;
  font-size:13.5px;
  letter-spacing:0.04em;
}
nav.topnav > a,
nav.topnav .nav-item > .nav-trigger{
  color:var(--cream-dim);
  text-decoration:none;
  padding:6px 2px;
  border-bottom:1px solid transparent;
  transition:color 200ms, border-color 200ms;
  background:none;
  border-top:none;
  border-left:none;
  border-right:none;
  font:inherit;
  letter-spacing:inherit;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
}
nav.topnav > a:hover,
nav.topnav .nav-item > .nav-trigger:hover,
nav.topnav .nav-item.open > .nav-trigger{
  color:var(--cream);
  border-bottom-color:var(--gold-soft);
}
nav.topnav .nav-trigger .chev{
  width:9px;
  height:9px;
  border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  transition:transform 200ms ease;
  margin-left:2px;
}
nav.topnav .nav-item.open .nav-trigger .chev{
  transform:rotate(225deg) translateY(-2px);
}
.nav-item{
  position:relative;
}
.nav-panel{
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%) translateY(-6px);
  min-width:340px;
  max-width:380px;
  padding:14px;
  /* Lightened so the aquarium caustics + plants show through behind the menu. */
  background:linear-gradient(135deg, rgba(6,28,52,0.55), rgba(2,6,27,0.62));
  border:1px solid rgba(255,193,7,0.36);
  border-radius:14px;
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  box-shadow:0 24px 60px rgba(1,3,15,0.55), 0 0 0 1px rgba(255,193,7,0.06) inset;
  display:flex;
  flex-direction:column;
  gap:4px;
  opacity:0;
  pointer-events:none;
  visibility:hidden;
  transition:opacity 200ms ease, transform 200ms ease, visibility 0s linear 200ms;
  z-index:60;
}
.nav-panel::before{
  content:"";
  position:absolute;
  top:-8px;
  left:50%;
  transform:translateX(-50%) rotate(45deg);
  width:14px;
  height:14px;
  background:rgba(6,28,52,0.55);
  backdrop-filter:blur(28px) saturate(160%);
  -webkit-backdrop-filter:blur(28px) saturate(160%);
  border-left:1px solid rgba(255,193,7,0.36);
  border-top:1px solid rgba(255,193,7,0.36);
}
.nav-item.open .nav-panel{
  opacity:1;
  pointer-events:auto;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
  transition:opacity 200ms ease, transform 200ms ease, visibility 0s;
}
@media (hover:hover) and (pointer:fine){
  .nav-item:hover .nav-panel{
    opacity:1;
    pointer-events:auto;
    visibility:visible;
    transform:translateX(-50%) translateY(0);
    transition:opacity 200ms ease, transform 200ms ease, visibility 0s;
  }
}
.nav-link{
  display:block;
  padding:11px 14px;
  border-radius:10px;
  text-decoration:none;
  color:var(--cream);
  border:1px solid transparent;
  background:transparent;
  transition:background 180ms ease, border-color 180ms ease, transform 180ms ease;
}
.nav-link:hover{
  background:rgba(255,193,7,0.07);
  border-color:rgba(255,193,7,0.22);
  transform:translateX(2px);
}
.nav-link-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-family:var(--serif);
  font-weight:500;
  font-size:14.5px;
  letter-spacing:0.005em;
  color:var(--cream);
  margin-bottom:3px;
}
.nav-link-badge{
  font-family:var(--mono, ui-monospace, monospace);
  font-size:9px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  padding:3px 7px;
  border-radius:3px;
  background:rgba(255,193,7,0.15);
  color:var(--gold);
  border:1px solid rgba(255,193,7,0.35);
  font-weight:500;
}
.nav-link-badge.live{background:rgba(86,154,109,0.18); color:#9bd0a8; border-color:rgba(86,154,109,0.42)}
.nav-link-badge.demo{background:rgba(255,193,7,0.18); color:var(--gold); border-color:rgba(255,193,7,0.42)}
.nav-link-desc{
  font-family:var(--sans);
  font-size:11.5px;
  letter-spacing:0.01em;
  line-height:1.45;
  color:rgba(245,240,232,0.6);
}
.nav-mobile-toggle{
  display:none;
  background:none;
  border:1px solid rgba(255,193,7,0.3);
  border-radius:6px;
  padding:8px 12px;
  color:var(--cream);
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  cursor:pointer;
}

/* Hero */
.hero{
  min-height:calc(100vh - 80px);
  display:flex;
  align-items:center;
  padding:140px 0 60px;
}
.hero-inner{
  max-width:880px;
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-size:11.5px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin-bottom:28px;
}
.eyebrow::before{
  content:"";
  width:32px;height:1px;
  background:var(--gold);
  opacity:0.6;
}
h1.headline{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(36px, 6vw, 68px);
  line-height:1.05;
  letter-spacing:-0.018em;
  margin:0 0 28px;
  color:var(--cream);
  text-wrap:balance;
}
h1.headline em{
  font-style:italic;
  font-weight:400;
  color:var(--gold);
}
.subhead{
  font-size:clamp(16px, 1.45vw, 19.5px);
  line-height:1.6;
  color:var(--cream-dim);
  max-width:65ch;
  margin:0 0 40px;
  font-weight:400;
}
.cta-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 24px;
  border-radius:2px;
  font-family:var(--sans);
  font-size:14px;
  font-weight:500;
  letter-spacing:0.05em;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform 200ms ease, background 200ms, color 200ms, border-color 200ms;
}
.btn-primary{
  background:var(--gold);
  color:#1a1308;
  border-color:var(--gold);
}
.btn-primary:hover{background:#e6c14a; transform:translateY(-1px)}
.btn-secondary{
  background:transparent;
  color:var(--cream);
  border-color:rgba(245,240,232,0.45);
}
.btn-secondary:hover{border-color:var(--cream); transform:translateY(-1px)}
.btn .arrow{
  font-family:var(--serif);
  font-size:18px;
  line-height:1;
  transform:translateY(-1px);
  transition:transform 200ms;
}
.btn:hover .arrow{transform:translate(3px,-1px)}

/* Focus rings */
:focus{outline:none}
:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:2px;
}

/* Hero meta strip */
.hero-meta{
  margin-top:54px;
  display:flex;
  flex-wrap:wrap;
  gap:24px 36px;
  font-size:13px;
  color:var(--cream-dim);
  letter-spacing:0.03em;
}
.hero-meta span{display:inline-flex; align-items:center; gap:10px}
.hero-meta .dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--gold);
}

/* Section heading */
.section{padding:90px 0}
.section-eyebrow{
  font-size:11px;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
  margin:0 0 18px;
}
.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(28px, 3.4vw, 42px);
  line-height:1.12;
  letter-spacing:-0.012em;
  margin:0 0 20px;
  color:var(--cream);
  max-width:22ch;
  text-wrap:balance;
}
.section-lede{
  font-size:16px;
  line-height:1.6;
  color:var(--cream-dim);
  max-width:60ch;
  margin:0 0 50px;
}

/* Glass cards */
.glass{
  background:var(--glass-bg);
  -webkit-backdrop-filter:blur(14px) saturate(115%);
          backdrop-filter:blur(14px) saturate(115%);
  border:1px solid var(--glass-border);
  border-radius:20px;
  padding:32px 30px;
  position:relative;
  overflow:hidden;
}
.glass::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,193,7,0.06) 0%, transparent 35%);
  pointer-events:none;
}

.how-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}

/* Specialties (MWS) */
.spec-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.spec-card .num{
  font-family:var(--serif);
  font-style:italic;
  font-size:13px;
  color:var(--gold);
  letter-spacing:0.05em;
  margin-bottom:18px;
  display:block;
}
.spec-card h3{
  font-family:var(--serif);
  font-weight:500;
  font-size:24px;
  line-height:1.2;
  margin:0 0 14px;
  color:var(--cream);
}
.spec-card p{
  margin:0;
  font-size:14.5px;
  line-height:1.65;
  color:var(--cream-dim);
}

/* Platform / org section (MWS) */
.platform-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:22px;
}
.platform-card{
  text-decoration:none;
  color:inherit;
  transition:transform 250ms ease;
}
.platform-card:hover{transform:translateY(-3px)}
.platform-card .divider{
  height:1px;
  background:linear-gradient(90deg, var(--gold), transparent 80%);
  opacity:0.5;
  margin-bottom:20px;
}
.platform-card .kicker{
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px;
  font-weight:500;
}
.platform-card h4{
  font-family:var(--serif);
  font-weight:500;
  font-size:22px;
  line-height:1.25;
  margin:0 0 16px;
  color:var(--cream);
  text-wrap:balance;
}
.platform-card p{
  font-size:14.5px;
  line-height:1.65;
  color:var(--cream-dim);
  margin:0;
}
.platform-card .meta{
  font-size:12.5px;
  color:var(--cream-dim);
  letter-spacing:0.03em;
  margin-top:16px;
}

/* Pricing (MWS) */
.pricing-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px 24px;
  align-items:center;
  margin-top:28px;
}
.price-tag{
  font-family:var(--serif);
  font-size:28px;
  color:var(--gold);
  font-weight:500;
}
.price-note{
  font-size:13.5px;
  color:var(--cream-dim);
  max-width:40ch;
}

/* Calendly embed (MWS) */
.cal-embed{
  background:rgba(0,0,0,0.35);
  border:1px solid rgba(245,240,232,0.18);
  border-bottom-color:rgba(255,193,7,0.35);
  border-radius:12px;
  overflow:hidden;
  min-height:540px;
}

.how-card .num{
  font-family:var(--serif);
  font-style:italic;
  font-size:13px;
  color:var(--gold);
  letter-spacing:0.05em;
  margin-bottom:18px;
  display:block;
}
.how-card h3{
  font-family:var(--serif);
  font-weight:500;
  font-size:24px;
  line-height:1.2;
  margin:0 0 14px;
  color:var(--cream);
}
.how-card p{
  margin:0;
  font-size:14.5px;
  line-height:1.65;
  color:var(--cream-dim);
}

/* Licensure pills */
.lic-strip{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  align-items:center;
  margin-bottom:22px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 18px;
  border:1px solid rgba(255,193,7,0.35);
  border-radius:999px;
  font-size:13px;
  letter-spacing:0.05em;
  color:var(--cream);
  background:rgba(2,6,23,0.4);
}
.pill .state{font-family:var(--serif); font-size:14px; color:var(--gold)}
.lic-note{
  font-size:14px;
  color:var(--cream-dim);
  max-width:65ch;
  margin:0;
}

/* Recent writing */
.writing-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.post{
  display:flex;
  flex-direction:column;
  gap:0;
  text-decoration:none;
  color:inherit;
  transition:transform 250ms ease;
}
.post:hover{transform:translateY(-3px)}
.post .divider{
  height:1px;
  background:linear-gradient(90deg, var(--gold), transparent 80%);
  opacity:0.5;
  margin-bottom:20px;
}
.post .kicker{
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px;
  font-weight:500;
}
.post h4{
  font-family:var(--serif);
  font-weight:500;
  font-size:22px;
  line-height:1.25;
  margin:0 0 16px;
  color:var(--cream);
  text-wrap:balance;
}
.post .meta{
  font-size:12.5px;
  color:var(--cream-dim);
  letter-spacing:0.03em;
  margin-top:auto;
}

/* Consult form */
.consult{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:40px;
  align-items:start;
}
.consult-copy h2{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(28px, 3vw, 38px);
  line-height:1.15;
  margin:0 0 18px;
  letter-spacing:-0.01em;
  text-wrap:balance;
}
.consult-copy p{
  font-size:15.5px;
  color:var(--cream-dim);
  line-height:1.65;
  margin:0 0 14px;
  max-width:50ch;
}
.consult-copy .note{
  font-size:13px;
  color:rgba(245,240,232,0.55);
  font-style:italic;
  margin-top:24px;
}

form.consult-form{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.field label{
  display:block;
  font-size:11px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:8px;
  font-weight:500;
}
.field input,
.field select,
.field textarea{
  width:100%;
  background:rgba(0,0,0,0.35);
  border:1px solid rgba(245,240,232,0.18);
  border-bottom-color:rgba(255,193,7,0.35);
  border-radius:4px;
  color:var(--cream);
  font:inherit;
  font-size:14.5px;
  padding:12px 14px;
  transition:border-color 200ms, background 200ms;
}
.field input:focus-visible,
.field select:focus-visible,
.field textarea:focus-visible{
  border-color:var(--gold);
  background:rgba(0,0,0,0.55);
  outline:none;
}
.field textarea{min-height:120px; resize:vertical}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}

.form-submit{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:6px;
}
.form-disclaimer{
  font-size:11.5px;
  color:rgba(245,240,232,0.55);
  letter-spacing:0.02em;
  max-width:32ch;
  line-height:1.5;
}

/* Footer */
footer.foot{
  position:relative;
  z-index:10;
  padding:80px 0 40px;
  border-top:1px solid rgba(255,193,7,0.12);
  margin-top:40px;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:50px;
}
.foot h5{
  font-family:var(--sans);
  font-weight:500;
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 16px;
}
.foot p, .foot li{
  font-size:13.5px;
  color:var(--cream-dim);
  line-height:1.65;
  margin:0 0 8px;
}
.foot ul{list-style:none; padding:0; margin:0}
.foot a{color:var(--cream-dim); text-decoration:none; border-bottom:1px solid transparent; transition:border-color 200ms, color 200ms}
.foot a:hover{color:var(--cream); border-bottom-color:var(--gold-soft)}
.foot-bottom{
  margin-top:60px;
  padding-top:24px;
  border-top:1px solid rgba(245,240,232,0.08);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:14px;
  font-size:12px;
  color:rgba(245,240,232,0.45);
  letter-spacing:0.03em;
}

/* Mobile */
@media (max-width:880px){
  .how-grid, .spec-grid, .platform-grid, .writing-grid{grid-template-columns:1fr}
  .consult{grid-template-columns:1fr; gap:28px}
  .foot-grid{grid-template-columns:1fr; gap:32px}
  nav.topnav{
    position:fixed;
    top:64px;
    left:0;
    right:0;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    padding:18px 22px 24px;
    background:rgba(2,8,28,0.96);
    backdrop-filter:blur(18px) saturate(140%);
    -webkit-backdrop-filter:blur(18px) saturate(140%);
    border-bottom:1px solid rgba(255,193,7,0.22);
    transform:translateY(-12px);
    opacity:0;
    pointer-events:none;
    visibility:hidden;
    transition:transform 220ms ease, opacity 220ms ease, visibility 0s linear 220ms;
    max-height:calc(100vh - 64px);
    overflow-y:auto;
  }
  nav.topnav.open{
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
    visibility:visible;
    transition:transform 220ms ease, opacity 220ms ease, visibility 0s;
  }
  nav.topnav > a,
  nav.topnav .nav-item > .nav-trigger{
    width:100%;
    justify-content:space-between;
    padding:12px 4px;
    border-bottom:1px solid rgba(255,193,7,0.08);
  }
  .nav-panel{
    position:static;
    transform:none;
    opacity:1;
    pointer-events:auto;
    visibility:visible;
    min-width:0;
    max-width:none;
    box-shadow:none;
    background:rgba(6,28,52,0.5);
    border-color:rgba(255,193,7,0.14);
    margin:6px 0 10px;
    display:none;
  }
  .nav-panel::before{display:none}
  .nav-item.open .nav-panel{display:flex}
  .nav-mobile-toggle{display:inline-flex; align-items:center; gap:8px}
  .shell{padding:0 22px}
  .bubbler{left:2%; width:46px}
  .outflow{width:55vw; height:38vh}
  .hero{padding:120px 0 50px}
  .topbar{padding:14px 0}
  .topbar.scrolled{padding:10px 0}
  .brandmark-text{font-size:16px}
  .brandmark-text small{font-size:10px; letter-spacing:0.16em}
  .hero-meta{gap:14px 24px; font-size:12.5px}
  .consult-form{margin-top:8px}
}
@media (max-width:560px){
  .bezel{inset:12px; border-radius:4px}
  .bezel-corner{width:90px; height:90px}
  .hero{min-height:auto; padding:108px 0 36px}
  h1.headline{font-size:32px !important; line-height:1.08; margin-bottom:22px}
  .subhead{font-size:15.5px; margin-bottom:30px}
  .eyebrow{font-size:10.5px; letter-spacing:0.18em; margin-bottom:20px; gap:10px}
  .eyebrow::before{width:22px}
  .field-row{grid-template-columns:1fr}
  .topbar{padding:10px 0}
  .topbar.scrolled{padding:8px 0}
  .section{padding:54px 0}
  .section-title{font-size:26px}
  .section-lede{font-size:15px; margin-bottom:34px}
  .glass{padding:22px 20px; border-radius:14px}
  .cta-row{gap:10px; width:100%}
  .cta-row .btn{flex:1 1 auto; justify-content:center; padding:14px 18px; font-size:13.5px}
  .form-submit{flex-direction:column; align-items:stretch; gap:12px}
  .form-submit .btn{justify-content:center}
  .form-disclaimer{max-width:none; text-align:center}
  .pill{font-size:12px; padding:8px 14px}
  .post h4{font-size:20px}
  .hero-meta{margin-top:36px}
  .topbar-inner{justify-content:flex-start}
  .brandmark{gap:10px}
  .brandmark-glyph{width:30px; height:30px}
  .consult-copy h2{font-size:24px}
  /* Lower fish/plant density on small screens already handled in JS via isMobile */
}
@media (max-width:560px){
  /* iOS fallback: backdrop-filter is expensive; if unsupported, raise glass-bg opacity */
  @supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
    .glass{background:rgba(2,18,38,0.82)}
  }
}
@media (orientation:landscape) and (max-height:520px){
  .hero{padding:80px 0 24px; min-height:auto}
  h1.headline{font-size:30px !important}
  .hero-meta{margin-top:22px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  .kelp{animation:none}
  .particle{display:none}
  .caustics{opacity:0.15; animation:none}
  .bubble{animation-duration:calc(var(--b-dur, 6s) * 3)}
}
