:root {
  --bg: #f7f4ee;
  --paper: #fbf9f4;
  --ink: #0c0c0c;
  --muted: #505050;
  --orange: #f25a0a;
  --blue: #2345ff;
  --line: rgba(12, 12, 12, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: radial-gradient(circle at top right, rgba(36,69,255,0.04), transparent 20%), var(--bg);
  color: var(--ink);
  font-family: 'Inter', system-ui, sans-serif;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.site-shell {
  width: min(100%, 1600px);
  margin: 0 auto;
  position: relative;
}

.site-header {
  display: grid;
  grid-template-columns: 240px 1fr 60px;
  align-items: start;
  gap: 24px;
  padding: 32px 34px 0;
  position: relative;
  z-index: 40;
}

.brand {
  display: inline-flex;
  flex-direction: column;
  gap: 1px;
  font-weight: 800;
  font-size: 2rem;
  line-height: 0.88;
  letter-spacing: -0.06em;
  position: relative;
  text-transform: none;
}

.brand i {
  display: block;
  width: 84px;
  height: 3px;
  background: var(--blue);
  transform: rotate(-8deg);
  margin-top: 10px;
}

.primary-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 42px;
  padding-top: 8px;
  text-transform: uppercase;
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}

.primary-nav a { position: relative; }
.primary-nav a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  transform: scaleX(0);
  transform-origin: left;
  background: var(--orange);
  transition: transform 0.22s ease;
}
.primary-nav a:hover::after { transform: scaleX(1); }

.nav-circle {
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--blue);
  color: white;
  font-size: 1.5rem;
  margin-left: auto;
}

.nav-toggle {
  display: none;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.8);
  padding: 10px 14px;
  border-radius: 999px;
  font: inherit;
}

.hero {
  min-height: 88vh;
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 12px;
  padding: 20px 36px 0;
  align-items: start;
}

.hero-copy {
  position: relative;
  padding: 52px 0 0 44px;
  z-index: 10;
}

.hero-side-note,
.edge-text {
  position: absolute;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: 0.78rem;
}

.hero-side-note {
  left: 0;
  top: 180px;
  color: var(--orange);
}

.hero h1 {
  margin: 0;
  font-size: clamp(4rem, 10vw, 8.7rem);
  line-height: 0.88;
  letter-spacing: -0.09em;
  text-transform: uppercase;
  position: relative;
  z-index: 20;
}

.hero h1 span {
  display: block;
  position: relative;
  z-index: 20;
}

.hero h1 span:last-child::after {
  content: '';
  display: block;
  width: 74%;
  height: 6px;
  background: var(--blue);
  transform: rotate(-3deg);
  margin-top: 14px;
}

.intro {
  max-width: 420px;
  margin-top: 34px;
  font-size: 1.28rem;
  line-height: 1.4;
  position: relative;
  z-index: 20;
}

.signature,
.orange-hand,
.scribble,
.cta-scribble {
  font-family: 'Caveat', cursive;
}

.signature {
  font-size: 3rem;
  margin: 18px 0 0;
  transform: rotate(-5deg);
  position: relative;
  z-index: 20;
}

.hero-meta {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 24px;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.8rem;
  font-weight: 700;
  position: relative;
  z-index: 20;
}

.hero-meta span:last-child { color: var(--orange); }

.hero-visual {
  position: relative;
  min-height: 850px;
  margin-top: 20px;
  z-index: 1;
}

.paint,
.map-lines,
.sail-frame,
.wave-visual,
.road-shot,
.paper-shot,
.map-card,
.coast-shot,
.stamp {
  position: absolute;
}

.paint-orange {
  width: 380px;
  height: 500px;
  right: 90px;
  top: 60px;
  background: linear-gradient(160deg, transparent 0 25%, var(--orange) 26% 82%, transparent 83% 100%);
  filter: saturate(120%);
  transform: rotate(-5deg);
}

.paint-blue {
  width: 120px;
  height: 120px;
  left: 20px;
  bottom: 36px;
  background: var(--blue);
  clip-path: polygon(0 0, 100% 4%, 70% 100%, 0 82%);
}

.map-lines {
  width: 230px;
  height: 280px;
  right: 410px;
  top: 120px;
  border: 1px dashed rgba(0,0,0,0.1);
  opacity: 0.35;
  clip-path: polygon(30% 0, 58% 8%, 72% 24%, 100% 36%, 76% 70%, 62% 100%, 24% 92%, 0 64%, 6% 26%);
}

.scribble {
  position: absolute;
  right: 310px;
  top: 140px;
  color: var(--blue);
  font-size: 3rem;
  line-height: 0.82;
  transform: rotate(-8deg);
}

.sail-frame {
  right: 0;
  top: 85px;
  width: 760px;
  height: 720px;
  overflow: hidden;
  transform: rotate(-3deg);
}

.sail-photo {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02)),
    linear-gradient(140deg, #2f3138 0%, #4f5766 16%, #8ea3b8 35%, #2a4258 58%, #0d1d2b 77%, #6c7f90 100%);
  clip-path: polygon(6% 18%, 62% 0, 97% 7%, 100% 94%, 20% 100%, 0 46%);
}

.sail-photo::before {
  content: '';
  position: absolute;
  left: 52%;
  top: -5%;
  width: 5px;
  height: 115%;
  background: rgba(255,255,255,0.92);
  transform: rotate(12deg);
}

.sail-photo::after {
  content: '';
  position: absolute;
  left: 49%;
  top: 12%;
  width: 210px;
  height: 480px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(230,236,242,0.92));
  clip-path: polygon(50% 0, 98% 10%, 72% 100%, 10% 100%, 0 18%);
  transform: skewX(-7deg);
  box-shadow: inset 0 0 0 2px rgba(25,25,25,0.08);
}

.sail-mask {
  position: absolute;
  left: -6%;
  bottom: -2%;
  width: 110%;
  height: 34%;
  background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(14,36,57,0.78) 50%, rgba(19,34,46,0.95) 100%);
  clip-path: polygon(0 18%, 56% 0, 100% 20%, 100% 100%, 0 100%);
}

.coords {
  position: absolute;
  right: -4px;
  top: 310px;
  font-size: 0.82rem;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.drift-section {
  position: relative;
  min-height: 420px;
  margin-top: 10px;
}

.section-number {
  position: absolute;
  font-weight: 900;
  font-size: clamp(4rem, 10vw, 7rem);
  line-height: 0.8;
  letter-spacing: -0.08em;
}
.orange { color: var(--orange); }
.blue { color: var(--blue); }
.black { color: var(--ink); }

.section-copy h2,
.contact-copy h2 {
  margin: 0 0 10px;
  font-size: clamp(3rem, 7vw, 5.2rem);
  line-height: 0.9;
  text-transform: uppercase;
  letter-spacing: -0.08em;
}

.section-copy p,
.contact-copy p {
  max-width: 430px;
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.5;
}

.large-copy,
.tall-copy,
.medium-copy,
.contact-copy { position: absolute; }
.text-link {
  display: inline-block;
  margin-top: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.82rem;
}
.text-link::after { content: ' →'; }

.place-list {
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  max-width: 430px;
}
.place-list li {
  margin: 0 0 8px;
  color: var(--ink);
  font-weight: 600;
}

.drift-work .section-number { left: 420px; top: 120px; }
.drift-work .large-copy { left: 470px; top: 135px; }
.wave-visual {
  left: 0;
  bottom: 14px;
  width: 560px;
  height: 220px;
  background: radial-gradient(circle at 30% 30%, #edf4ff 0 14%, #58738f 26%, #24364a 49%, #0e1926 72%, transparent 73%);
  clip-path: polygon(0 62%, 16% 43%, 28% 26%, 42% 18%, 57% 26%, 72% 17%, 81% 26%, 100% 46%, 100% 100%, 0 100%);
  filter: contrast(1.1);
}
.orange-hand {
  position: absolute;
  left: 740px;
  top: 170px;
  color: var(--orange);
  font-size: 2.5rem;
  line-height: 0.8;
  transform: rotate(-9deg);
}

.drift-journal { min-height: 500px; }
.drift-journal .section-number { left: 825px; top: 10px; }
.drift-journal .tall-copy { left: 920px; top: 26px; }
.road-shot {
  right: 70px;
  top: 90px;
  width: 270px;
  height: 380px;
  background: linear-gradient(180deg, #d8d8d8 0%, #8b8b8b 40%, #464646 100%);
  transform: rotate(-8deg);
  box-shadow: 0 18px 40px rgba(0,0,0,0.12);
}
.road-shot::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 0 37%, #f4f4f4 38% 41%, transparent 42% 100%),
              linear-gradient(185deg, transparent 0 58%, #212121 59% 73%, transparent 74% 100%),
              linear-gradient(180deg, transparent 0 45%, #727272 46% 47%, transparent 48% 100%);
  mix-blend-mode: screen;
}
.edge-text.right-edge { right: 24px; top: 70px; color: var(--orange); }
.edge-text.left-edge { left: 28px; top: 78px; color: var(--ink); }
.edge-text.lower { top: auto; bottom: 24px; }

.drift-about { min-height: 430px; }
.drift-about .section-number { left: 86px; top: 74px; }
.drift-about .medium-copy { left: 200px; top: 100px; }
.paper-shot {
  position: absolute;
  left: 510px;
  top: 66px;
  width: 420px;
  height: 280px;
  transform: rotate(-8deg);
}
.paper-stack {
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.76);
  box-shadow: 0 20px 40px rgba(0,0,0,0.08);
}
.paper-stack::before,
.paper-stack::after {
  content: '';
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(0,0,0,0.05);
}
.paper-stack::after {
  inset: 18px;
  transform: rotate(3deg);
  background: rgba(245,245,245,0.5);
}
.paper-line {
  height: 2px;
  background: rgba(27,53,255,0.1);
  margin: 36px 38px 0;
}
.paper-line.short { width: 72%; }
.paper-writing {
  position: absolute;
  right: 34px;
  top: 70px;
  width: 160px;
  font-family: 'Caveat', cursive;
  font-size: 2rem;
  line-height: 0.95;
  transform: rotate(8deg);
}
.pen {
  position: absolute;
  right: 14px;
  bottom: 18px;
  width: 16px;
  height: 170px;
  background: linear-gradient(180deg, #141414, #2c2c2c);
  border-radius: 12px;
  transform: rotate(15deg);
}

.drift-places { min-height: 520px; }
.drift-places .section-number { left: 770px; top: 40px; }
.drift-places .medium-copy { left: 892px; top: 68px; }
.map-card {
  left: 1040px;
  top: 215px;
  width: 210px;
  height: 180px;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,0.035) 0 3px, transparent 3px 22px), #f0ebdf;
  transform: rotate(7deg);
}
.coast-shot {
  right: 30px;
  bottom: 18px;
  width: 370px;
  height: 250px;
  background: linear-gradient(180deg, #b8d1e2 0%, #88a2b0 28%, #3e6272 52%, #233642 72%, #101417 100%);
  box-shadow: 0 18px 40px rgba(0,0,0,0.1);
}
.coast-shot::before {
  content: '';
  position: absolute;
  left: 0;
  bottom: -15px;
  width: 100%;
  height: 70px;
  background: var(--orange);
  transform: skewX(-18deg);
}
.coast-shot::after {
  content: '';
  position: absolute;
  left: -30px;
  top: 0;
  width: 170px;
  height: 100%;
  background: linear-gradient(160deg, rgba(255,255,255,0.06), rgba(255,255,255,0) 70%);
  clip-path: polygon(0 0, 60% 0, 12% 100%, 0 100%);
}

.drift-contact {
  min-height: 380px;
  padding-bottom: 70px;
}
.drift-contact .section-number { left: 96px; top: 48px; }
.contact-copy {
  left: 190px;
  top: 48px;
}
.contact-copy h2 {
  font-family: 'Caveat', cursive;
  font-size: clamp(4rem, 7vw, 6rem);
  color: var(--orange);
  text-transform: none;
  letter-spacing: -0.04em;
}
.contact-links {
  display: flex;
  flex-wrap: wrap;
  gap: 26px;
  margin-top: 24px;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.1em;
  font-size: 0.84rem;
}
.stamp {
  right: 330px;
  top: 112px;
  width: 180px;
  height: 180px;
  border: 2px solid rgba(0,0,0,0.36);
  border-radius: 999px;
  display: grid;
  place-items: center;
  text-align: center;
  font-size: 0.88rem;
  line-height: 1.35;
  transform: rotate(-8deg);
}
.cta-scribble {
  position: absolute;
  right: 70px;
  top: 110px;
  color: var(--blue);
  font-size: 3.2rem;
  line-height: 0.82;
  transform: rotate(-7deg);
}

@media (max-width: 1200px) {
  .site-header {
    grid-template-columns: 1fr auto auto;
    padding: 24px 20px 0;
  }

  .nav-toggle { display: inline-flex; }
  .primary-nav {
    display: none;
    position: absolute;
    left: 20px;
    right: 20px;
    top: 92px;
    background: rgba(255,255,255,0.95);
    border: 1px solid var(--line);
    padding: 18px;
    border-radius: 20px;
    flex-direction: column;
    gap: 16px;
    z-index: 30;
  }
  .primary-nav.open { display: flex; }

  .hero {
    grid-template-columns: 1fr;
    padding: 10px 20px 0;
  }
  .hero-copy { padding: 32px 0 0 28px; }
  .hero-side-note,
  .edge-text { display: none; }
  .hero-visual { min-height: 620px; }
  .paint-orange { right: 20px; width: 270px; height: 390px; }
  .scribble { right: 130px; top: 84px; font-size: 2.4rem; }
  .map-lines { right: 280px; top: 90px; }
  .sail-frame { right: 0; width: min(100%, 620px); height: 540px; }
  .coords { right: 4px; top: 180px; }

  .drift-section {
    min-height: auto;
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 10px 20px 30px;
  }

  .section-number,
  .large-copy,
  .tall-copy,
  .medium-copy,
  .contact-copy,
  .wave-visual,
  .road-shot,
  .paper-shot,
  .map-card,
  .coast-shot,
  .stamp,
  .orange-hand,
  .cta-scribble {
    position: relative;
    left: auto;
    top: auto;
    right: auto;
    bottom: auto;
  }

  .section-number { margin-bottom: -10px; }
  .wave-visual,
  .road-shot,
  .paper-shot,
  .coast-shot,
  .stamp { margin-top: 12px; }
  .wave-visual { width: 100%; max-width: 500px; }
  .road-shot { width: 240px; height: 320px; }
  .paper-shot { width: min(100%, 380px); height: 250px; }
  .map-card { width: 180px; height: 150px; }
  .coast-shot { width: min(100%, 360px); height: 220px; }
  .stamp { width: 150px; height: 150px; }
  .orange-hand { font-size: 2rem; }
  .cta-scribble { font-size: 2.6rem; }
}

@media (max-width: 700px) {
  .brand { font-size: 1.55rem; }
  .nav-circle { width: 46px; height: 46px; }
  .hero h1 { font-size: clamp(3rem, 17vw, 5.6rem); }
  .intro { font-size: 1.05rem; }
  .hero h1 span:last-child::after { width: 88%; }
  .hero-visual { min-height: 430px; }
  .sail-frame { height: 360px; }
  .paint-orange { width: 180px; height: 240px; }
  .map-lines { display: none; }
  .scribble { font-size: 1.8rem; right: 70px; }
  .section-copy h2,
  .contact-copy h2 { font-size: clamp(2.4rem, 14vw, 4rem); }
}
