/* Prairie Printworks styles */
:root{
  --bg:#154b73;
  --bg-deep:#103754;
  --panel:#1a5079;
  --panel-2:#15476c;

  --line:rgba(248,252,255,0.24);
  --line-soft:rgba(248,252,255,0.15);
  --line-strong:rgba(252,254,255,0.36);

  --text:#f2f6fb;
  --muted:#cfdae5;
  --heading:#fbfdff;

  --card-bg:rgba(255,255,255,0.025);
  --card-bg-2:rgba(255,255,255,0.01);

  --max:1200px;
  --radius:18px;

  --chrome-top:106px;
  --chrome-bottom:42px;
}

*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  overflow-x:clip;
}

body{
  margin:0;
  padding-top:var(--chrome-top);
  padding-bottom:var(--chrome-bottom);
  overflow-x:hidden;
  color:var(--text);
  font-family:"Arial Narrow","Bahnschrift","Segoe UI",system-ui,sans-serif;
  line-height:1.6;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,255,255,0.05), transparent 24%),
    radial-gradient(circle at 76% 68%, rgba(255,255,255,0.04), transparent 22%),
    radial-gradient(circle at 52% 48%, rgba(255,255,255,0.03), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)),
    repeating-linear-gradient(to right, rgba(245,250,255,0.035) 0 1px, transparent 1px 84px),
    repeating-linear-gradient(to bottom, rgba(245,250,255,0.035) 0 1px, transparent 1px 84px),
    linear-gradient(180deg, #1b5a89 0%, #154a74 45%, #103d63 100%);
}

body::before{
  content:"";
  position:fixed;
  inset:22px;
  border:1px solid rgba(245,250,255,0.16);
  pointer-events:none;
  z-index:0;
}

body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.72;
  background-image:
    url("../images/cyanotype-background-edges.jpg"),
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.85) 0 .7px, transparent .8px),
    radial-gradient(circle at 74% 30%, rgba(255,255,255,.6) 0 .6px, transparent .7px),
    radial-gradient(circle at 60% 78%, rgba(255,255,255,.55) 0 .7px, transparent .8px),
    radial-gradient(circle at 34% 56%, rgba(255,255,255,.4) 0 .6px, transparent .7px),
    repeating-linear-gradient(11deg, rgba(255,255,255,.018) 0 1px, transparent 1px 10px),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 18%, rgba(255,255,255,.03) 60%, transparent 100%);
  background-size:
  100% 100%,
    180px 180px,
    240px 240px,
    220px 220px,
    260px 260px,
    12px 12px,
    100% 100%;
  background-position:center;
  mix-blend-mode:screen;
}

a{color:inherit;text-decoration:none}

/* Show a clear callout-style arrow cursor on selectable controls */
a[href],
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
summary,
[role="button"],
[role="link"]{
  cursor:pointer;
}
img{max-width:100%;display:block}

.container{
  width:min(var(--max), calc(100% - 2rem));
  margin:auto;
  position:relative;
  z-index:2;
}

main{
  color:var(--text);
  position:relative;
}

  main::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.14;
  background:
    radial-gradient(circle at 8% 12%, rgba(255,255,255,0.08), transparent 18%),
    radial-gradient(circle at 92% 14%, rgba(255,255,255,0.05), transparent 20%),
    radial-gradient(circle at 14% 88%, rgba(255,255,255,0.06), transparent 16%),
    radial-gradient(circle at 86% 80%, rgba(255,255,255,0.07), transparent 18%),
    radial-gradient(circle at 50% 50%, transparent 55%, rgba(0,0,0,0.16) 100%);
  mix-blend-mode:screen;
}
  
.section{
  padding:5rem 0;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}

/* TOP FRAME / NAV */

.navbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:50;
  background:rgba(16,55,84,0.72);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}

.nav-revbar{
  border-bottom:1px solid var(--line-soft);
  background:rgba(255,255,255,0.025);
}

.nav-revbar-inner{
  display:grid;
  grid-template-columns:1.5fr .9fr .9fr .85fr;
  border-left:1px solid rgba(245,250,255,0.14);
  border-right:1px solid rgba(245,250,255,0.14);
}

.rev-cell{
  min-height:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.8rem;
  padding:0 .8rem;
  border-right:1px solid var(--line-soft);
  font-family:"Courier New",monospace;
  font-size:.58rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(245,250,255,0.68);
}

.rev-cell:last-child{border-right:none}

.rev-cell strong{
  font-weight:400;
  color:var(--heading);
}

.nav-inner{
  min-height:74px;
}

.titleblock-strip{
  display:grid;
  grid-template-columns:2.25fr 1.1fr 1.35fr 1fr;
  width:100%;
  border-left:1px solid rgba(245,250,255,0.14);
  border-right:1px solid rgba(245,250,255,0.14);
  position:relative;
}

.titleblock-strip::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(to bottom, rgba(255,255,255,0.03), transparent 35%),
    repeating-linear-gradient(to right, rgba(245,250,255,0.025) 0 1px, transparent 1px 120px);
  opacity:.55;
}

.strip-cell{
  min-height:74px;
  padding:.5rem .85rem;
  border-right:1px solid rgba(245,250,255,0.12);
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
}

.strip-cell:last-child{border-right:none}

.strip-label{
  font-family:"Courier New",monospace;
  font-size:.56rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(245,250,255,0.48);
  margin-bottom:.22rem;
}

.brand{
  font-size:.96rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  line-height:1.08;
  color:var(--heading);
}

.brand-sub{
  font-size:.68rem;
  color:var(--muted);
  margin-top:3px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.strip-meta{
  gap:.18rem;
}

.drafting-meta-row{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:.65rem;
  font-family:"Courier New",monospace;
  font-size:.6rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(245,250,255,0.62);
}

.drafting-meta-row span:last-child{
  text-align:right;
  color:var(--heading);
}

.nav-links{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  align-items:stretch;
  height:100%;
  min-height:74px;
}

.nav-links a{
  display:flex;
  align-items:center;
  justify-content:center;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.72rem;
  color:var(--muted);
  border-right:1px solid var(--line-soft);
  position:relative;
}

.nav-links a:last-child{border-right:none}

.nav-links a::before{
  content:"";
  position:absolute;
  left:12px;
  right:12px;
  top:10px;
  border-top:1px solid rgba(245,250,255,0.05);
}

.nav-links a:hover{
  color:var(--heading);
  background:rgba(255,255,255,0.03);
}

.mobile-nav{
  display:none;
}

.strip-cta{
  align-items:stretch;
  justify-content:stretch;
  padding:0;
}

.strip-cta-inner{
  display:grid;
  grid-template-rows:auto 1fr;
  height:100%;
  min-height:74px;
}

.btn{
  padding:.9rem 1.2rem;
  border-radius:0;
  border:1px solid rgba(245,250,255,0.16);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:.2s;
  text-transform:uppercase;
  letter-spacing:.13em;
  font-size:.74rem;
  font-weight:600;
  position:relative;
  overflow:hidden;
}

.btn::before{
  content:"";
  position:absolute;
  inset:8px;
  border:1px solid rgba(245,250,255,0.08);
  pointer-events:none;
}

.btn-primary{
  background:#f5f9ff;
  color:#133b5f;
  border-color:rgba(255,255,255,0.25);
}

.btn-primary:hover{
  background:#ffffff;
}

.btn-secondary{
  color:var(--heading);
  background:rgba(255,255,255,0.02);
}

.btn-secondary:hover{
  background:rgba(255,255,255,0.05);
}

.strip-cta .btn-primary{
  width:100%;
  height:100%;
  border:none;
  white-space:nowrap;
}

/* HERO */

.hero{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    repeating-linear-gradient(to right, rgba(245,250,255,0.04) 0 1px, transparent 1px 120px),
    repeating-linear-gradient(to bottom, rgba(245,250,255,0.04) 0 1px, transparent 1px 120px);
  opacity:.8;
}

.hero-inner{
  position:relative;
  min-height:680px;
  padding:.55rem 0 3rem;
  text-align:center;
}

.hero-frame{
  position:absolute;
  inset:1rem 1rem 1rem 1rem;
  border:1px solid rgba(245,250,255,0.16);
  pointer-events:none;
  z-index:0;
}

.hero-frame{
  position:absolute;
  inset:1rem 1rem 1rem 1rem;
  border:1px solid rgba(248,252,255,0.22);
  pointer-events:none;
  z-index:0;
}

.hero-frame::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  bottom:0;
  width:1px;
  transform:translateX(-50%);
  background:rgba(248,252,255,0.18);
}

.hero-frame::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:56%;
  height:1px;
  transform:translateY(-50%);
  background:rgba(248,252,255,0.18);
}

.zone{
  position:absolute;
  width:26px;
  height:26px;
  border:1px solid rgba(245,250,255,0.18);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:"Courier New",monospace;
  font-size:.62rem;
  letter-spacing:.08em;
  color:rgba(245,250,255,0.72);
  background:rgba(10,47,81,0.45);
  z-index:3;
}

.zone-top-1{top:1.25rem;left:8%}
.zone-top-2{top:1.25rem;left:32%}
.zone-top-3{top:1.25rem;left:56%}
.zone-top-4{top:1.25rem;left:80%}

.zone-left-a{left:1.2rem;top:18%}
.zone-left-b{left:1.2rem;top:42%}
.zone-left-c{left:1.2rem;top:66%}

.callout{
  position:absolute;
  z-index:3;
  pointer-events:none;
  font-family:"Courier New",monospace;
  font-size:.62rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(250,253,255,0.88);
}

.callout-label{
  position:absolute;
  white-space:nowrap;
}

.callout-line-h,
.callout-line-v{
  position:absolute;
  background:rgba(250,253,255,0.34);
}

.callout-line-h{height:1px}
.callout-line-v{width:1px}

.callout-arrow{
  position:absolute;
  width:8px;
  height:8px;
  border-top:1px solid rgba(245,250,255,0.28);
  border-right:1px solid rgba(245,250,255,0.28);
  transform:rotate(45deg);
}

/* top-left reference note */
.callout-1{left:16%;top:8.4rem;width:220px;height:70px}
.callout-1 .callout-label{left:0;top:0}
.callout-1 .callout-line-h{left:86px;top:9px;width:96px}
.callout-1 .callout-line-v{left:182px;top:9px;height:40px}
.callout-1 .callout-arrow{left:178px;top:44px}

/* diameter note to construction circle */
.callout-2{left:calc(50% + 17rem);top:47%;width:160px;height:44px}
.callout-2 .callout-label{left:0;top:0}
.callout-2 .callout-line-h{left:46px;top:9px;width:52px}
.callout-2 .callout-line-v{left:98px;top:-26px;height:35px}
.callout-2 .callout-arrow{left:94px;top:-30px}

/* radial note */
.callout-3{left:calc(50% + 18rem);top:66%;width:150px;height:52px}
.callout-3 .callout-label{left:0;top:0}
.callout-3 .callout-line-h{left:34px;top:9px;width:48px}
.callout-3 .callout-line-v{left:82px;top:-18px;height:27px}
.callout-3 .callout-arrow{left:78px;top:-22px}

/* centerline note lands on actual vertical centerline */
.callout-4{left:calc(50% - 20rem);top:82%;width:330px;height:26px}
.callout-4 .callout-label{left:0;top:0}
.callout-4 .callout-line-h{left:96px;top:9px;width:202px}
.callout-4 .callout-arrow{left:292px;top:5px}

.logo{
  max-width:780px;
  margin:auto;
  position:relative;
  z-index:2;
  filter:drop-shadow(0 20px 40px rgba(0,20,40,.25));
  transform-style:preserve-3d;
  perspective:1100px;
}

.logo-wrap{
  padding:.75rem 0 .2rem;
}

.logo img{
  width:100%;
  position:relative;
  z-index:2;
  transform:translateZ(0);
  animation:hero-float 8s ease-in-out infinite;
  filter:drop-shadow(0 26px 45px rgba(0, 20, 40, .45));
}

.logo::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:3.2rem;
  width:min(54vw, 480px);
  height:74px;
  transform:translateX(-50%);
  background:radial-gradient(ellipse at center, rgba(8, 16, 28, .45) 0%, rgba(8, 16, 28, 0) 72%);
  pointer-events:none;
  z-index:1;
  animation:hero-shadow-float 8s ease-in-out infinite;
}

@keyframes hero-float{
  0%,
  100%{transform:translate3d(0, 0, 0) rotateX(0deg) rotateY(0deg) scale(1)}
  50%{transform:translate3d(0, -14px, 46px) rotateX(2.2deg) rotateY(-2deg) scale(1.015)}
}

@keyframes hero-shadow-float{
  0%,
  100%{opacity:.52;transform:translateX(-50%) scale(.93)}
  50%{opacity:.34;transform:translateX(-50%) scale(.82)}
}

.logo-ring,
.logo-dashed-circle{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  border-radius:50%;
  pointer-events:none;
}

.logo-ring{
  width:min(62vw,520px);
  height:min(62vw,520px);
  border:1px solid rgba(248,252,255,0.15);
  opacity:.9;
}

.logo-dashed-circle{
  width:min(74vw,620px);
  height:min(74vw,620px);
  border:1px dashed rgba(248,252,255,0.11);
  opacity:.46;
}

h1{
  font-size:clamp(2.35rem,6vw,4.3rem);
  line-height:1.02;
  letter-spacing:.02em;
  margin:.45rem auto .8rem;
  font-family:"Bahnschrift","DIN Alternate","Arial Narrow","Segoe UI",sans-serif;
  text-transform:uppercase;
  max-width:900px;
  position:relative;
  z-index:2;
  color:var(--heading);
}

.hero h1{
  font-size:clamp(1.25rem,2.8vw,2.1rem);
  line-height:1.08;
  max-width:1100px;
  color:rgba(33, 40, 50, 0.84);
}

.lead{
  max-width:720px;
  margin:auto;
  color:var(--muted);
  font-size:1.1rem;
  position:relative;
  z-index:2;
}

.hero .lead{
  max-width:1100px;
  font-size:clamp(1.95rem,4.5vw,3.35rem);
  line-height:1.14;
  font-weight:700;
  color:var(--heading);
}

.hero-actions{
  margin-top:2rem;
  display:flex;
  gap:.9rem;
  justify-content:center;
  flex-wrap:wrap;
  position:relative;
  z-index:2;
}

/* SECTION HEADERS */

.section-header{
  margin-bottom:2rem;
  position:relative;
  padding-left:5.8rem;
}

.section-kicker{
  position:absolute;
  left:0;
  top:.2rem;
  font-family:"Courier New",monospace;
  font-size:.64rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(245,250,255,0.62);
}

.section-kicker::after{
  content:"";
  position:absolute;
  left:100%;
  top:50%;
  width:3.7rem;
  height:1px;
  background:rgba(245,250,255,0.2);
  margin-left:.8rem;
}

.section-title{
  margin:0 0 .35rem;
  font-size:clamp(1.65rem,3vw,2.35rem);
  text-transform:uppercase;
  letter-spacing:.06em;
  line-height:1.05;
  color:var(--heading);
}

.section-sub{
  margin:0;
  color:var(--muted);
  max-width:760px;
}

/* CARDS */

.card{
  background:linear-gradient(180deg, rgba(255,255,255,0.018), rgba(255,255,255,0.008));
  border:1px solid rgba(245,250,255,0.09);
  border-radius:var(--radius);
  padding:1.7rem;
  position:relative;
  box-shadow:none;
}
  
.card::before{
  content:"";
  position:absolute;
  top:.9rem;
  left:.9rem;
  width:22px;
  height:22px;
  border-top:1px solid var(--line-strong);
  border-left:1px solid var(--line-strong);
}

.card::after{
  content:"";
  position:absolute;
  right:.9rem;
  bottom:.9rem;
  width:22px;
  height:22px;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.card h3{
  color:var(--heading);
  margin-top:0;
  text-transform:uppercase;
  letter-spacing:.07em;
}

.card p{
  color:var(--muted);
}

.project{
  overflow:hidden;
  padding:0;
  border-radius:0;
  background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.012));
}

.project::before{
  content:"DETAIL";
  position:absolute;
  top:.85rem;
  left:1rem;
  font-family:"Courier New",monospace;
  font-size:.58rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#000;
}

.project::after{
  content:"";
  position:absolute;
  left:1rem;
  right:1rem;
  bottom:1rem;
  height:1px;
  background:rgba(245,250,255,0.2);
}

.project-img{
  aspect-ratio:16/10;
  border-bottom:1px solid rgba(0,0,0,0.9);
  display:flex;
  justify-content:center;
  align-items:center;
  color:rgba(245,250,255,0.48);
  font-size:.75rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  background:
    repeating-linear-gradient(to right, rgba(245,250,255,0.03) 0 1px, transparent 1px 40px),
    repeating-linear-gradient(to bottom, rgba(245,250,255,0.03) 0 1px, transparent 1px 40px);
  position:relative;
}

.project-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.project-img::before{
  content:"";
  position:absolute;
  inset:14px;
  border:1px solid rgba(0,0,0,0.9);
}

.project-img::after{
  content:"FIG.";
  position:absolute;
  right:16px;
  bottom:12px;
  font-family:"Courier New",monospace;
  font-size:.56rem;
  letter-spacing:.18em;
  color:#000;
}

.project-body{
  padding:1.25rem 1.4rem 1.55rem;
  position:relative;
}

.project-body h3{
  margin:.2rem 0 .45rem;
}

.project-ref{
  display:block;
  margin-bottom:.55rem;
  font-family:"Courier New",monospace;
  font-size:.58rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#000;
}

.project-intake-grid{
  align-items:stretch;
}

.project-intake-card{
  position:relative;
  background:rgba(7, 29, 43, 0.78);
  border:1px solid rgba(210, 235, 255, 0.35);
  box-shadow:0 0 0 1px rgba(210, 235, 255, 0.08) inset;
  padding:1.25rem;
  display:flex;
  flex-direction:column;
}

.project-intake-card::before{
  content:"";
  position:absolute;
  inset:10px;
  border:1px solid rgba(210, 235, 255, 0.16);
  pointer-events:none;
}

.project-intake-card .drawing-overline{
  margin:0 0 .55rem;
  font-size:.62rem;
}

.project-intake-card h3{
  margin:0 0 .8rem;
  text-transform:uppercase;
  letter-spacing:.07em;
  color:var(--heading);
}

.project-intake-card .title-block{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.project-intake-card .title-cell{
  min-height:58px;
  padding:.48rem .55rem;
}

.project-intake-card .title-cell span{
  font-size:.56rem;
}

.project-intake-card .title-cell strong{
  font-size:.74rem;
}

.project-intake-card .sheet-divider{
  margin:1rem 0 .85rem;
}

.project-intake-card .sheet-notes{
  margin-top:auto;
  padding:.75rem .8rem;
}

.project-intake-card .sheet-notes p{
  font-size:.86rem;
  line-height:1.55;
}

.project-intake-card-image .project-img{
  margin:-1.25rem -1.25rem .9rem;
  border-bottom:1px solid rgba(210, 235, 255, 0.18);
}

.project-intake-card-image .project-img::before,
.project-intake-card-image .project-img::after{
  display:none;
}

/* FOOTER */

.titlebar-bottom{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:35;
  background:rgba(16,55,84,0.72);
  backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
}

.titlebar-bottom .titleblock-strip{
  grid-template-columns:1.6fr 1fr 1fr;
}

.titlebar-bottom .strip-cell{
  min-height:40px;
  padding:.28rem .6rem;
  flex-direction:row;
  align-items:center;
  justify-content:flex-start;
  gap:.38rem;
  white-space:nowrap;
}

.titlebar-bottom .strip-label,
.titlebar-bottom .brand,
.titlebar-bottom .brand-sub{
  margin:0;
  line-height:1;
}

.titlebar-bottom .strip-label{
  font-size:.5rem;
}

.titlebar-bottom .brand{
  font-size:.7rem;
  letter-spacing:.14em;
}

.titlebar-bottom .brand-sub{
  font-size:.56rem;
  letter-spacing:.07em;
}

.titlebar-bottom .footer-meta{
  flex-direction:row;
  align-items:center;
  gap:.38rem;
}

.footer-meta{
  font-family:"Courier New",monospace;
  font-size:.6rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:rgba(245,250,255,0.62);
  gap:.12rem;
}

.footer-meta strong{
  color:var(--heading);
  font-weight:400;
}

.footer-right{
  align-items:flex-end;
  text-align:right;
}

/* RESPONSIVE */

@media(max-width:960px){
  .grid-3{
    grid-template-columns:1fr;
  }

  .nav-revbar-inner{
    grid-template-columns:1fr 1fr;
  }

  .rev-cell:nth-child(n+3){
    display:none;
  }

  .titleblock-strip{
    grid-template-columns:1.5fr .9fr;
  }

  .strip-meta-secondary,
  .strip-cta{
    display:none;
  }

  .strip-cell{
    min-height:60px;
    padding:.42rem .65rem;
  }

  .mobile-nav{
    display:flex;
    flex-wrap:nowrap;
    border-left:1px solid rgba(245,250,255,0.14);
    border-right:1px solid rgba(245,250,255,0.14);
    border-top:1px solid rgba(245,250,255,0.08);
    overflow-x:auto;
  }

  .mobile-nav a{
    min-height:36px;
    flex:1 0 auto;
    display:flex;
    align-items:center;
    justify-content:center;
    text-transform:uppercase;
    letter-spacing:.08em;
    font-size:.56rem;
    white-space:nowrap;
    color:var(--muted);
    border-right:1px solid rgba(245,250,255,0.09);
  }

  .mobile-nav a:last-child{
    border-right:none;
  }

  .mobile-nav a:hover{
    color:var(--heading);
    background:rgba(255,255,255,0.03);
  }

  .section-header{
    padding-left:0;
  }

  .section-kicker{
    position:relative;
    display:inline-block;
    top:auto;
    left:auto;
    margin-bottom:.9rem;
  }

  .section-kicker::after{
    display:none;
  }

  .hero-inner{
    min-height:auto;
    padding:.7rem 0 3.5rem;
  }

  .hero-frame{
    inset:.8rem .8rem .8rem .8rem;
  }

  .zone,
  .callout{
    display:none;
  }

  .logo-wrap{
    padding:.55rem 0 .25rem;
  }

  .logo-ring{
  width:min(62vw,520px);
  height:min(62vw,520px);
  border:1px solid rgba(245,250,255,0.11);
}

.logo-dashed-circle{
  width:min(74vw,620px);
  height:min(74vw,620px);
  border:1px dashed rgba(245,250,255,0.09);
  opacity:.42;
}

  .footer-meta{
    font-size:.56rem;
  }

  .titlebar-bottom .titleblock-strip{
    grid-template-columns:1.4fr 1fr 1fr;
  }

  .titlebar-bottom .strip-cell{
    min-height:36px;
    padding:.24rem .4rem;
    gap:.26rem;
  }

  .titlebar-bottom .brand{
    font-size:.58rem;
    letter-spacing:.12em;
  }

  .titlebar-bottom .brand-sub{
    font-size:.5rem;
    letter-spacing:.06em;
  }

  .titlebar-bottom .strip-label,
  .titlebar-bottom .footer-meta{
    font-size:.48rem;
    letter-spacing:.1em;
  }

  .brand{
    font-size:.82rem;
  }

  .brand-sub{
    font-size:.62rem;
  }
}

@media(max-width:640px){
  .hero-actions{
    flex-direction:column;
    align-items:stretch;
    width:min(320px,100%);
    margin-left:auto;
    margin-right:auto;
  }

  .hero-actions .btn{
    width:100%;
  }

  .rev-cell{
    font-size:.54rem;
    padding:0 .55rem;
  }

  .project-intake-card .title-block{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .project-intake-card .title-cell:nth-child(3n){
    border-right:1px solid rgba(210, 235, 255, 0.18);
  }

  .project-intake-card .title-cell:nth-child(2n){
    border-right:none;
  }

  .project-intake-card .title-cell:nth-last-child(-n + 3){
    border-bottom:1px solid rgba(210, 235, 255, 0.18);
  }

  .project-intake-card .title-cell:nth-last-child(-n + 2){
    border-bottom:none;
  }
}

.intake-page {
  padding: 3.5rem 0 5rem;
}

.intake-sheet {
  position: relative;
  background: rgba(7, 29, 43, 0.78);
  border: 1px solid rgba(210, 235, 255, 0.35);
  box-shadow:
    0 0 0 1px rgba(210, 235, 255, 0.08) inset,
    0 18px 50px rgba(0, 0, 0, 0.28);
  padding: 2rem;
  backdrop-filter: blur(1px);
}

.intake-sheet::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(210, 235, 255, 0.16);
  pointer-events: none;
}

.drawing-overline {
  margin: 0 0 1rem;
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.72;
}

.sheet-header {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: 1.5rem;
  align-items: start;
}

.sheet-header h1 {
  margin: 0 0 0.65rem;
  font-size: clamp(2.2rem, 4vw, 3.25rem);
  line-height: 1.02;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.sheet-subtitle {
  margin: 0 0 0.75rem;
  max-width: 42rem;
  font-size: 1rem;
  line-height: 1.55;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  opacity: 0.86;
}

.sheet-intro {
  max-width: 60ch;
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  opacity: 0.92;
}

.title-block {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border: 1px solid rgba(210, 235, 255, 0.28);
  background: rgba(255, 255, 255, 0.03);
}

.title-cell {
  min-height: 74px;
  padding: 0.7rem 0.8rem;
  border-right: 1px solid rgba(210, 235, 255, 0.18);
  border-bottom: 1px solid rgba(210, 235, 255, 0.18);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.title-cell:nth-child(3n) {
  border-right: none;
}

.title-cell:nth-last-child(-n + 3) {
  border-bottom: none;
}

.title-cell span {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  opacity: 0.68;
}

.title-cell strong {
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.sheet-divider {
  height: 1px;
  margin: 1.35rem 0 1.1rem;
  background: linear-gradient(
    to right,
    rgba(210, 235, 255, 0),
    rgba(210, 235, 255, 0.45),
    rgba(210, 235, 255, 0)
  );
}

.sheet-notes-wrap {
  margin-bottom: 1.35rem;
}

.sheet-label {
  margin: 0 0 0.5rem;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  opacity: 0.72;
}

.sheet-notes {
  padding: 0.95rem 1rem;
  border-left: 2px solid rgba(210, 235, 255, 0.34);
  background: rgba(255, 255, 255, 0.025);
}

.sheet-notes p {
  margin: 0.2rem 0;
  font-size: 0.95rem;
  line-height: 1.6;
  opacity: 0.9;
}

.form-launch {
  text-align: center;
  padding: 2.25rem 1rem 1.25rem;
  border: 1px solid rgba(210, 235, 255, 0.24);
  background: rgba(239, 248, 255, 0.05);
  position: relative;
}

.form-launch::before,
.form-launch::after {
  content: "";
  position: absolute;
  top: 12px;
  bottom: 12px;
  width: 1px;
  background: rgba(210, 235, 255, 0.1);
}

.form-launch::before {
  left: 12px;
}

.form-launch::after {
  right: 12px;
}

.form-note {
  max-width: 52ch;
  margin: 0 auto 1.25rem;
  font-size: 1rem;
  line-height: 1.7;
  opacity: 0.9;
}

.intake-button {
  display: inline-block;
  padding: 0.95rem 1.75rem;
  border: 1px solid rgba(210, 235, 255, 0.45);
  background: rgba(210, 235, 255, 0.08);
  color: inherit;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 600;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 0 0 1px rgba(210, 235, 255, 0.08) inset;
}

.intake-button:hover {
  background: rgba(210, 235, 255, 0.16);
  border-color: rgba(210, 235, 255, 0.7);
  transform: translateY(-2px);
  box-shadow: 0 0 0 1px rgba(210, 235, 255, 0.18) inset;
}

.form-microcopy {
  margin: 0.95rem auto 0;
  max-width: 46ch;
  font-size: 0.85rem;
  line-height: 1.6;
  opacity: 0.72;
}

@media (max-width: 860px) {
  .sheet-header {
    grid-template-columns: 1fr;
  }

  .title-block {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .title-cell:nth-child(3n) {
    border-right: 1px solid rgba(210, 235, 255, 0.18);
  }

  .title-cell:nth-child(2n) {
    border-right: none;
  }

  .title-cell:nth-last-child(-n + 3) {
    border-bottom: 1px solid rgba(210, 235, 255, 0.18);
  }

  .title-cell:nth-last-child(-n + 2) {
    border-bottom: none;
  }

  .intake-sheet {
    padding: 1.25rem;
  }
}

@media (max-width: 560px) {
  .title-block {
    grid-template-columns: 1fr;
  }

  .title-cell,
  .title-cell:nth-child(3n),
  .title-cell:nth-child(2n) {
    border-right: none;
  }

  .title-cell:nth-last-child(-n + 2) {
    border-bottom: 1px solid rgba(210, 235, 255, 0.18);
  }

  .title-cell:last-child {
    border-bottom: none;
  }

  .sheet-header h1 {
    font-size: 2rem;
  }

  .sheet-subtitle {
    font-size: 0.92rem;
  }
}

@media(max-width:960px){
  :root{
    --chrome-top:97px;
    --chrome-bottom:38px;
  }
}

.page-shell {
  width: min(var(--max), calc(100% - 2rem));
  margin: 0 auto;
  padding: 2.5rem 0 5rem;
  position: relative;
  z-index: 2;
}

.page-hero {
  border: 1px solid rgba(210, 235, 255, 0.26);
  background: rgba(7, 29, 43, 0.72);
  padding: 1.4rem 1.5rem;
}

.page-kicker {
  margin: 0 0 0.4rem;
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.72;
}

.page-hero h1 {
  margin: 0 0 0.6rem;
  font-size: clamp(2rem, 3.8vw, 3rem);
}

.page-hero p {
  margin: 0;
  max-width: 64ch;
  color: var(--muted);
}

.page-section {
  margin-top: 1.35rem;
  border: 1px solid rgba(210, 235, 255, 0.22);
  background: rgba(7, 29, 43, 0.7);
  padding: 1.4rem 1.5rem;
}

.projects-notebook-intro p {
  max-width: 82ch;
}

.project-jump-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.7rem;
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(245, 250, 255, 0.84);
}

.project-jump-link::after {
  content: "→";
}

.project-intake-card-image .project-img a {
  display: block;
  width: 100%;
  height: 100%;
}

.projects-notebook-list {
  display: grid;
  gap: 1.35rem;
}

.project-notebook {
  border: 1px solid rgba(210, 235, 255, 0.28);
  background: rgba(10, 35, 52, 0.72);
  padding: 1.25rem;
}

.project-notebook-header h2 {
  margin: 0 0 0.45rem;
  font-size: clamp(1.35rem, 2.4vw, 2rem);
}

.project-notebook-header p {
  margin: 0;
  color: var(--muted);
}

.project-notebook-meta {
  margin-top: 1rem;
}

.project-notebook-layout {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 1rem;
  align-items: start;
}

.project-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.7rem;
}

.project-gallery-item {
  border: 1px solid rgba(210, 235, 255, 0.22);
  background: rgba(255, 255, 255, 0.02);
  padding: 0.42rem;
}

.project-gallery-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

.project-gallery-item span {
  display: block;
  margin-top: 0.45rem;
  text-align: center;
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  opacity: 0.78;
}

@media (max-width: 900px) {
  .project-notebook-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .project-gallery {
    grid-template-columns: 1fr;
  }
}
