/* ————————————————————————————————————————————————
   The World Through My Eyes — shared chrome
   Light sepia field-journal aesthetic.
   Fonts: Cormorant Garamond · Newsreader · IBM Plex Mono
   ———————————————————————————————————————————————— */

:root{
  --paper:   #f3ecdf;
  --paper-2: #eadfc9;
  --paper-3: #e2d4b8;
  --ink:     #3a3024;
  --ink-2:   #6b5c48;
  --ink-3:   #93826b;
  --line:    rgba(58,48,36,.16);
  --line-2:  rgba(58,48,36,.32);
  --rust:    #a34d2c;
  --gold:    #b9853d;
  --gilt:    #c8a04b;
  --serif:   "Cormorant Garamond", Georgia, serif;
  --body:    "Newsreader", Georgia, serif;
  --mono:    "IBM Plex Mono", ui-monospace, monospace;
  --shadow:  0 18px 50px -18px rgba(58,48,36,.38), 0 4px 14px -6px rgba(58,48,36,.22);
  --shadow-sm: 0 10px 26px -14px rgba(58,48,36,.35);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }

body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{ background:rgba(185,133,61,.28); }

h1,h2,h3{ font-family:var(--serif); font-weight:600; line-height:1.12; text-wrap:balance; }
a{ color:inherit; }
img{ display:block; max-width:100%; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

.mono{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-2); }
.mono.dim{ color:var(--ink-3); }

/* ——— layers ——— */
#paper-bg{ position:fixed; inset:0; z-index:0; pointer-events:none; }
#vehicle-fx{ position:fixed; inset:0; z-index:1; pointer-events:none; }
#map-bg{ position:fixed; inset:0; z-index:0; pointer-events:none; mix-blend-mode:multiply; opacity:.34; }
main{ position:relative; z-index:2; }

/* ——— nav ——— */
.site-nav{
  position:fixed; top:0; left:0; right:0; z-index:40;
  display:flex; align-items:center; gap:28px;
  padding:14px 28px;
  background:color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-nav .brand{
  font-family:var(--serif); font-weight:600; font-size:19px; letter-spacing:.04em;
  text-decoration:none; white-space:nowrap;
}
.site-nav .brand em{ font-style:normal; color:var(--rust); }
.site-nav nav{ display:flex; gap:22px; margin-left:auto; align-items:center; }
.site-nav nav a{
  font-family:var(--mono); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  text-decoration:none; color:var(--ink-2); padding:6px 2px; position:relative;
}
.site-nav nav a::after{
  content:""; position:absolute; left:0; right:100%; bottom:2px; height:1px;
  background:var(--rust); transition:right .35s cubic-bezier(.7,0,.2,1);
}
.site-nav nav a:hover::after, .site-nav nav a.active::after{ right:0; }
.site-nav nav a.active{ color:var(--ink); }
.lang-switch{
  display:flex; align-items:center; gap:6px; margin-left:4px;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.14em;
}
.lang-switch i{ width:1px; height:12px; background:var(--line-2); }
.lang-switch button{
  color:var(--ink-3); padding:6px 2px; letter-spacing:.14em; transition:color .3s;
}
.lang-switch button:hover{ color:var(--ink); }
.lang-switch button.on{ color:var(--rust); }
.pill{
  display:inline-block; font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; text-decoration:none; color:var(--ink);
  border:1px solid var(--line-2); border-radius:999px; padding:9px 18px;
  transition:background .3s, color .3s, border-color .3s;
}
.pill:hover{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pill.solid{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.pill.solid:hover{ background:var(--rust); border-color:var(--rust); }

/* ——— footer ——— */
.site-footer{
  position:relative; z-index:2;
  margin-top:120px; border-top:1px solid var(--line);
  padding:56px 28px 40px;
  background:color-mix(in srgb, var(--paper-2) 55%, transparent);
}
.site-footer .cols{
  max-width:1180px; margin:0 auto; display:grid; gap:36px;
  grid-template-columns:2fr 1fr 1fr;
}
.site-footer h4{ font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3); margin-bottom:14px; font-weight:500; }
.site-footer a{ text-decoration:none; color:var(--ink-2); display:block; padding:3px 0; font-size:15px; }
.site-footer a:hover{ color:var(--rust); }
.site-footer .brandline{ font-family:var(--serif); font-size:24px; font-weight:600; margin-bottom:8px; }
.site-footer .colophon{
  max-width:1180px; margin:44px auto 0; padding-top:18px; border-top:1px solid var(--line);
  display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap;
}

/* ——— photo plates ——— */
figure.plate{
  position:relative; background:var(--paper-2);
  border:1px solid var(--line); box-shadow:var(--shadow-sm);
  padding:10px 10px 12px;
}
figure.plate .ph{ position:relative; overflow:hidden; background:var(--paper-3); }
figure.plate .ph::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(120% 90% at 50% 8%, rgba(243,236,223,.14), transparent 55%),
             radial-gradient(120% 120% at 50% 110%, rgba(185,133,61,.14), transparent 60%);
  opacity:0; transition:opacity .7s ease;
}
figure.plate:hover .ph::after{ opacity:1; }
figure.plate img{
  width:100%; height:100%; object-fit:cover;
  filter:sepia(.5) saturate(.78) contrast(.97) brightness(1.02);
  transition:filter .7s ease, transform 1.6s cubic-bezier(.2,.6,.2,1);
}
figure.plate:hover img, figure.plate.x img{ filter:none; }
figure.plate:hover img{ transform:scale(1.015); }
figure.plate figcaption{
  display:flex; align-items:baseline; gap:10px; padding:10px 4px 0;
}
figure.plate figcaption .cap{ font-style:italic; font-size:15.5px; color:var(--ink-2); }
figure.plate figcaption .idx{ font-family:var(--mono); font-size:10px; letter-spacing:.14em; color:var(--ink-3); }

figure.plate .ph .sk{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  pointer-events:none; opacity:1; transition:opacity .45s ease;
}
figure.plate .ph .nib{
  position:absolute; left:6%; bottom:8px; z-index:2; opacity:0; pointer-events:none;
  transition:opacity .35s ease, left .25s linear, bottom .25s linear;
  filter:drop-shadow(0 1px 1px rgba(58,48,36,.3));
}
figure.plate .datestamp{
  position:absolute; right:20px; bottom:26px; z-index:3; display:none;
  transform:rotate(7deg); padding:7px 14px 8px; text-align:center; pointer-events:none;
  border:2px solid rgba(163,77,44,.6); border-radius:7px;
  box-shadow:inset 0 0 0 1px rgba(163,77,44,.35), inset 0 0 12px rgba(163,77,44,.12);
  color:rgba(163,77,44,.85); mix-blend-mode:multiply;
}
figure.plate.x .datestamp{ display:block; }
.datestamp .d1{ font-family:var(--mono); font-size:12.5px; letter-spacing:.14em; font-weight:600; white-space:nowrap; }
.datestamp .d2{ font-family:var(--mono); font-size:8.5px; letter-spacing:.22em; text-transform:uppercase; margin-top:3px; }

/* expand-in-place */
.xbtn{
  position:absolute; top:16px; right:16px; z-index:3;
  font-family:var(--mono); font-size:10px; letter-spacing:.14em;
  background:color-mix(in srgb, var(--paper) 88%, transparent);
  border:1px solid var(--line-2); padding:6px 10px; border-radius:999px;
  opacity:0; transform:translateY(-4px); transition:opacity .3s, transform .3s, background .3s;
}
figure.plate:hover .xbtn, figure.plate.x .xbtn{ opacity:1; transform:none; }
.xbtn:hover{ background:var(--ink); color:var(--paper); }
figure.plate .stamp{
  position:absolute; left:18px; bottom:22px; z-index:3;
  display:none; align-items:flex-end; gap:10px; pointer-events:none;
}
figure.plate.x .stamp{ display:flex; }
figure.plate .stamp canvas{ display:block; }
figure.plate .stamp .coords{
  font-family:var(--mono); font-size:10px; letter-spacing:.12em;
  color:var(--paper); text-shadow:0 1px 8px rgba(30,24,16,.8);
  padding-bottom:6px;
}

/* placeholder slot for missing photos */
.slot{
  position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:8px; min-height:100%; width:100%; text-align:center; padding:20px;
  background:repeating-linear-gradient(-45deg, var(--paper-2) 0 14px, color-mix(in srgb, var(--paper-3) 72%, var(--paper-2)) 14px 28px);
}
.slot::after{ content:""; position:absolute; inset:8px; border:1px dashed var(--line-2); }
.slot .fname{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--ink-2); }
.slot .hint{ font-family:var(--mono); font-size:9.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }

/* ——— reveals ——— */
[data-reveal]{ opacity:0; transform:translateY(26px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.65,.2,1); }
[data-reveal].in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  [data-reveal]{ opacity:1; transform:none; transition:none; }
  figure.plate img{ transition:none; }
}

/* pen underline holder */
.pen-line{ display:block; height:12px; margin-top:6px; overflow:visible; }
.pen-line path{ fill:none; stroke:var(--rust); stroke-width:2; stroke-linecap:round; opacity:.75; }

/* ——— generic page shell ——— */
.page-shell{ max-width:1180px; margin:0 auto; padding:150px 28px 60px; }
.page-shell.narrow{ max-width:820px; }
.eyebrow{ font-family:var(--mono); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--rust); margin-bottom:18px; }
.page-title{ font-size:clamp(42px,6vw,72px); font-weight:600; }

/* paper card */
.card{
  background:color-mix(in srgb, var(--paper) 60%, var(--paper-2));
  border:1px solid var(--line); box-shadow:var(--shadow-sm); padding:34px 38px;
}

@media (max-width:860px){
  .site-nav{ gap:14px; padding:12px 16px; }
  .site-nav nav{ gap:14px; }
  .site-nav .sub-pill{ display:none; }
  .site-footer .cols{ grid-template-columns:1fr 1fr; }
  .page-shell{ padding:120px 18px 40px; }
}
@media (max-width:640px){
  .site-nav{ flex-wrap:wrap; justify-content:center; row-gap:0; padding:10px 12px 6px; }
  .site-nav .brand{ font-size:17px; }
  .site-nav nav{ margin-left:0; flex-wrap:wrap; justify-content:center; row-gap:2px; }
}

/* —— embedded mailing-list fields —— */
.mc-mini{ display:flex; margin-top:2px; max-width:250px; border:1px solid var(--line-2);
  background:color-mix(in srgb, var(--paper) 72%, transparent); border-radius:3px; overflow:hidden; }
.mc-mini input{ flex:1; min-width:0; border:0; background:transparent; padding:9px 12px;
  font-family:var(--serif); font-size:14px; color:var(--ink); outline:none; }
.mc-mini input::placeholder{ color:var(--ink-3); font-style:italic; }
.mc-mini button{ border:0; border-left:1px solid var(--line-2); background:transparent;
  padding:0 14px; font-size:15px; color:var(--accent); cursor:pointer; transition:background .25s, color .25s; }
.mc-mini button:hover{ background:var(--ink); color:var(--paper); }
.mc-hint{ display:block; margin-top:8px; font-size:9.5px; }
