:root{
  --spruce:#0F2A21;
  --ocean:#163A5F;
  --amber:#B8773A;

  --paper:#F7F1E3;  /* Vanilla Cream */
  --paper2:#EFE6D3; /* Sun-Faded Linen */
  --ink:#111213;

  --muted: rgba(17,18,19,.68);
  --line: rgba(17,18,19,.14);

  --serif: "EB Garamond", ui-serif, "Iowan Old Style", "Garamond", "Georgia", serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--ink);
  background:
    radial-gradient(1100px 520px at 50% -180px, rgba(255,255,255,.45), var(--paper)),
    linear-gradient(180deg, var(--paper), var(--paper2));
  font-family: var(--sans);
}

.grain{
  pointer-events:none;
  position:fixed;
  inset:0;
  opacity:.07;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
}

.wrap{max-width: 980px; margin: 0 auto; padding: 0 18px;}

/* FULL-PAGE COLLAGE */
.collagePage{
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}

.collage{
  position: absolute;
  inset: -40px;
  background: linear-gradient(180deg, rgba(247,241,227,.55), rgba(239,230,211,.75));
}

.shot{
  position:absolute;
  margin:0;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(15,42,33,.18);
  box-shadow:
    0 18px 46px rgba(0,0,0,.18),
    0 3px 0 rgba(255,255,255,.28) inset;
  background: rgba(255,255,255,.26);
  transform-origin: 50% 50%;
}

.shot img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  filter: contrast(1.02) saturate(0.98);
}

/* some shots feel like printed photos */
.shot.print{
  padding: 7px;
  background: rgba(247,241,227,.88);
  border-color: rgba(15,42,33,.16);
  border-radius: 10px;
}
.shot.print img{
  border-radius: 8px;
}

/* a lil film vignette on each shot */
.shot::after{
  content:"";
  position:absolute;
  inset:0;
  background: radial-gradient(120% 120% at 50% 30%, rgba(255,255,255,.08), rgba(0,0,0,.16));
  mix-blend-mode: multiply;
  pointer-events:none;
}

/* placement: overlapping 'teen bedroom wall' vibe (values set inline on each .shot) */
.shot{
  left: calc(var(--x) * 1%);
  top: calc(var(--y) * 1%);
  width: clamp(120px, calc(var(--w) * 1vw), 560px);
  height: clamp(120px, calc(var(--h) * 1vw), 560px);
  transform: rotate(calc(var(--r) * 1deg));
  z-index: var(--z);
}

@media (max-width: 720px){
  .collage{inset: -26px;}
  .shot{
    width: clamp(130px, calc(var(--w) * 1.25vw), 520px);
    height: clamp(130px, calc(var(--h) * 1.25vw), 520px);
  }
}

/* overlay layers */
.overlay{
  position: relative;
  z-index: 2;
  padding-top: 42px;
}

.card{
  margin: 0 auto;
  max-width: 720px;
  padding: 26px 22px 22px;
  border-radius: 22px;
  background: rgba(247,241,227,.82);
  border: 1px solid rgba(15,42,33,.18);
  box-shadow:
    0 26px 90px rgba(0,0,0,.22),
    0 1px 0 rgba(255,255,255,.7) inset;
  backdrop-filter: blur(8px);
}

.brand{line-height:1.0;}
.brandTop{
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: clamp(28px, 3.6vw, 46px);
  color: var(--spruce);
}
.brandSub{
  margin-top: 10px;
  font-family: var(--sans);
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(15,42,33,.70);
}

.tagline{
  margin: 14px 0 0;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: -0.01em;
  color: rgba(17,18,19,.86);
}

.waitlist{display:flex; gap:10px; flex-wrap: wrap; margin-top: 18px;}

input{
  flex:1;
  min-width: 240px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(15,42,33,.18);
  background: rgba(255,255,255,.72);
  font-size: 16px;
}

button{
  padding: 12px 16px;
  border-radius: 999px;
  border: 1px solid rgba(15,42,33,.30);
  background: var(--spruce);
  color: rgba(247,241,227,.98);
  font-weight: 800;
  letter-spacing: .01em;
  cursor: pointer;
}
button:hover{filter: brightness(1.03);}
button:disabled{opacity:.7; cursor:not-allowed;}

.fine{margin: 10px 0 0; color: var(--muted); font-size: 13px;}

.refrainTop{
  margin-top: 18px;
  font-family: var(--sans);
  letter-spacing: .20em;
  text-transform: uppercase;
  color: rgba(15,42,33,.62);
  font-size: 12px;
}

.rule{height:1px; width:100%; background: var(--line); margin: 34px 0;}

/* QUOTE PAGE */
/* Minimal footer anchored near bottom */
.overlayFooter{
  position: relative;
  z-index: 2;
  padding-top: 22px;
  padding-bottom: 26px;
}

.footerLine{height:1px; width:100%; background: rgba(15,42,33,.22); opacity:.7; margin-bottom: 12px;}
.footRow{display:flex; justify-content:space-between; gap: 12px; flex-wrap: wrap;}

.muted{color: var(--muted); font-size: 13px;}

.refrain{
  font-family: var(--sans);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(15,42,33,.62);
}

.srOnly{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;}
