/* ============================================================
   UAP Globe - the investigation board
   The whole site is a corkboard: aged news clippings, real
   photographed pushpins, sticky notes, tape, red string, and a
   draggable vintage map where the globe used to be.
   ============================================================ */
:root{
  --cork-dark:#3a2614;
  --wood:#2b1c10;          /* header/footer wood bar */
  --paper:#f2e9d2;         /* clipping paper */
  --paper-2:#ece1c4;
  --paper-deep:#e4d6b2;
  --ink:#241c14;           /* ink on paper */
  --ink-soft:#5d4c33;
  --cream:#f1ecd9;         /* text on wood */
  --cream-soft:#cdbfa3;
  --red:#a51f12;           /* string + accents */
  --note-yellow:#f5e27a;
  --note-pink:#f0a8b8;
  /* tier ink colors (handwritten verdicts) */
  --t-strong:#1d6e3c;
  --t-contested:#1c5f9e;
  --t-unknown:#6c3fae;
  --t-discredited:#8a4a1c;
  /* tier dot colors for dark surfaces */
  --td-strong:#5fe07a;
  --td-contested:#5bc8ff;
  --td-unknown:#b48cff;
  --td-discredited:#9aa3b5;
}
*{box-sizing:border-box;min-width:0}
html,body{margin:0;padding:0}
body{
  color:var(--cream);
  font-family:"Zilla Slab",Georgia,serif;
  line-height:1.6;overflow-x:hidden;
  background-color:#2e1f10;
  background-image:url('/img/cork-tile.jpg');
  background-size:900px auto;background-repeat:repeat;
}
/* dim investigation-room vignette over the cork */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(120% 90% at 50% 30%, rgba(20,10,2,.18), rgba(20,10,2,.62) 85%);
}
body::after{ /* faint grain */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;
  background-image:radial-gradient(rgba(0,0,0,.06) 0.5px, transparent 0.6px);
  background-size:4px 4px;opacity:.5;
}
body > *{position:relative;z-index:1}
a{color:inherit;text-decoration:none}

/* ---------- header: dark wood bar ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 26px;background:linear-gradient(180deg,#33220f,#241708);
  border-bottom:3px solid #120a03;box-shadow:0 4px 14px rgba(10,5,1,.6);
}
.brand{display:flex;align-items:center;gap:12px}
.brand-icon{height:30px;width:auto;display:block;filter:drop-shadow(0 2px 3px rgba(0,0,0,.6)) brightness(1.1)}
.brand-text{font-family:"Anton",sans-serif;font-size:21px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cream)}
.brand-text::first-letter{color:#e8b13c}
.site-nav{display:flex;gap:24px;font-family:"Special Elite",monospace;font-size:14px;text-transform:uppercase;letter-spacing:1px}
.site-nav a{color:var(--cream-soft);padding:3px 2px;border-bottom:2px solid transparent;transition:.18s}
.site-nav a:hover,.site-nav a.active{color:#e8b13c;border-color:#e8b13c}

/* ---------- header search (file-card style) ---------- */
.search-wrap{position:relative;margin-left:14px;flex:0 1 230px;min-width:120px}
#caseSearch{
  width:100%;padding:7px 12px;border-radius:3px;border:1px solid #58401f;
  background:#f4ecd6;color:var(--ink);font-family:"Special Elite",monospace;font-size:13px;
  outline:none;transition:.16s;box-shadow:inset 0 1px 3px rgba(0,0,0,.25);
}
#caseSearch::placeholder{color:#9a8a66}
#caseSearch:focus{border-color:#e8b13c;box-shadow:0 0 8px rgba(232,177,60,.4)}
.search-results{
  position:absolute;top:calc(100% + 6px);right:0;width:min(86vw,360px);max-height:380px;overflow-y:auto;z-index:60;
  background:#f4ecd6;border:1px solid #58401f;border-radius:4px;box-shadow:0 16px 40px rgba(10,5,1,.55);
}
.search-results a{display:flex;gap:10px;align-items:center;padding:9px 11px;border-bottom:1px solid #d9cba6;transition:.12s;color:var(--ink)}
.search-results a:hover,.search-results a.sel{background:#e8dab4}
.search-results img{width:44px;height:44px;object-fit:cover;border-radius:2px;flex:0 0 auto;border:1px solid #c5b48e}
.search-results .sr-title{font-family:"Playfair Display",serif;font-weight:900;font-size:13.5px;color:var(--ink);line-height:1.15}
.search-results .sr-meta{font-family:"Special Elite",monospace;font-size:10.5px;color:var(--ink-soft)}
.search-results .sr-none{padding:12px;font-family:"Special Elite",monospace;font-size:12px;color:var(--ink-soft)}

/* ---------- board hero ---------- */
.hero{padding:26px 24px 0;text-align:center;max-width:980px;margin:0 auto}
.hero h1{
  display:inline-block;font-family:"Special Elite",monospace;font-weight:400;
  font-size:clamp(22px,3.6vw,34px);line-height:1.15;margin:0 0 10px;padding:12px 30px;
  text-transform:uppercase;letter-spacing:3px;color:var(--ink);
  background:var(--paper);box-shadow:0 6px 16px rgba(10,5,1,.55);transform:rotate(-.8deg);position:relative;
}
.hero h1::before,.hero h1::after{
  content:"";position:absolute;top:-10px;width:84px;height:24px;background:rgba(228,214,180,.65);
  box-shadow:0 1px 4px rgba(20,10,2,.35);
}
.hero h1::before{left:-30px;transform:rotate(-5deg)}
.hero h1::after{right:-30px;transform:rotate(4deg)}
.hero-sub{
  color:#3a2e1d;font-size:clamp(15px,2vw,19px);max-width:600px;margin:14px auto 0;
  font-family:"Caveat",cursive;font-weight:500;background:var(--note-yellow);
  padding:10px 18px;box-shadow:0 5px 12px rgba(20,10,2,.45);transform:rotate(.7deg);position:relative;
}
.hero-sub::before{
  content:"";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  width:20px;height:27px;background:url('/img/pins/pin-red.png') center/contain no-repeat;
  filter:drop-shadow(0 4px 3px rgba(20,10,2,.45));
}

/* the daily-sweep note: a typed index card taped under the title */
.daily-note{
  position:relative;max-width:660px;margin:22px auto 0;padding:14px 18px 13px;
  background:var(--paper);box-shadow:0 6px 16px rgba(10,5,1,.5);transform:rotate(-.5deg);
  text-align:left;
}
.daily-note::before{
  content:"";position:absolute;top:-11px;left:50%;transform:translateX(-50%) rotate(-2deg);
  width:96px;height:24px;background:rgba(228,214,180,.65);box-shadow:0 1px 4px rgba(20,10,2,.35);
}
.daily-note .dn-stamp{
  display:inline-block;font-family:"Special Elite",monospace;text-transform:uppercase;
  letter-spacing:2.5px;font-size:12px;color:var(--red);border:2px solid var(--red);
  padding:2px 9px;transform:rotate(-1.6deg);margin-bottom:8px;opacity:.85;
}
.daily-note p{
  margin:0;font-family:"Special Elite",monospace;font-size:13px;line-height:1.65;color:var(--ink);
}
.daily-note a{color:var(--red);text-decoration:underline}

/* ---------- the antique desk globe (a free-floating 3D object on the board) ----------
   The globe IS the site's main feature: it dominates the viewport. */
.map-wrap{max-width:1700px;margin:6px auto 0;padding:0 2vw;position:relative}
.map-panel{position:relative;background:transparent;padding:0;box-shadow:none;transform:none}
/* soft resting shadow under the ball */
.map-panel::after{
  content:"";position:absolute;left:50%;bottom:4px;transform:translateX(-50%);z-index:0;
  width:54%;height:46px;border-radius:50%;
  background:radial-gradient(ellipse at center, rgba(15,8,2,.5), rgba(15,8,2,0) 70%);
}
.map-label{
  position:absolute;top:-10px;left:50%;transform:translateX(-50%) rotate(-1deg);z-index:31;
  background:rgba(233,220,189,.92);color:#6b3a16;font-family:"Caveat",cursive;font-weight:700;font-size:18px;
  letter-spacing:.5px;padding:5px 20px;box-shadow:0 3px 8px rgba(20,10,2,.4);
}
#pinmap{width:100%;height:min(88vh,1000px);background:transparent;cursor:grab}
#pinmap:active{cursor:grabbing}
/* OrbitControls sets touch-action:none, which traps page scrolling on phones;
   pan-y lets vertical swipes scroll the page while horizontal drags spin the globe */
#pinmap canvas{touch-action:pan-y !important}
/* DOM pushpins stuck in the desk globe: generous hit areas, easy to click.
   globe.gl's CSS2D layer ships pointer-events:none; force it back on or pins are dead. */
.globe-pin{position:relative;width:26px;height:35px;transform:translate(-50%,-86%);transition:opacity .2s;cursor:pointer;pointer-events:auto}
.globe-pin img{width:26px;height:35px;display:block;filter:drop-shadow(0 4px 4px rgba(20,10,2,.5));transition:transform .15s}
.globe-pin:hover img{transform:scale(1.25)}
.globe-pin .gp-hit{position:absolute;inset:-10px}
/* zoom buttons (wheel zoom is disabled on desktop; these are THE zoom control):
   magnifying-glass icons so their purpose is obvious at a glance */
.globe-zoom{position:absolute;right:14px;bottom:18px;z-index:32;display:flex;flex-direction:column;gap:10px}
.globe-zoom button{
  width:56px;height:56px;cursor:pointer;display:flex;align-items:center;justify-content:center;
  background:var(--paper);color:var(--ink);border:1px solid #b8a87f;border-radius:3px;
  box-shadow:0 3px 8px rgba(20,10,2,.45);padding:0;
}
.globe-zoom svg{width:34px;height:34px;display:block}
.globe-zoom button:hover{background:#e8dab4}
.globe-zoom button:active{transform:translateY(1px)}
@media (max-width:620px){
  .globe-zoom{right:8px;bottom:12px}
  .globe-zoom button{width:50px;height:50px}
  .globe-zoom svg{width:30px;height:30px}
}

/* fullscreen globe mode (phones): the inline globe is a preview, the button
   below it opens this mode with full touch control */
.globe-expand{
  display:none;cursor:pointer;
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-1.2deg);z-index:40;
  align-items:center;gap:11px;font-family:"Special Elite",monospace;font-size:17px;font-weight:700;
  letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);white-space:nowrap;
  background:var(--paper);border:2.5px solid var(--red);border-radius:3px;
  padding:16px 24px;box-shadow:0 14px 34px rgba(10,5,1,.6);
  animation:expandNudge 2.6s ease-in-out infinite;
}
.globe-expand svg{width:22px;height:22px;flex:0 0 auto;color:var(--red)}
@keyframes expandNudge{
  0%,100%{transform:translate(-50%,-50%) rotate(-1.2deg) scale(1)}
  50%{transform:translate(-50%,-50%) rotate(-1.2deg) scale(1.06)}
}
.globe-close{
  display:none;position:fixed;top:14px;right:14px;z-index:4100;
  width:54px;height:54px;align-items:center;justify-content:center;cursor:pointer;
  font-size:34px;line-height:1;color:var(--ink);background:var(--paper);
  border:1px solid #b8a87f;border-radius:50%;box-shadow:0 4px 12px rgba(10,5,1,.6);padding:0;
}
@media (pointer:coarse){
  .globe-expand{display:flex}
  /* inline zoom buttons are pointless while the inline globe is a preview */
  .map-panel:not(.globe-full) .globe-zoom{display:none}
}
.map-panel.globe-full{
  position:fixed;inset:0;z-index:4000;margin:0;
  background:#2a1a0e url('/img/cork-tile.jpg');background-size:420px;
}
.map-panel.globe-full #pinmap{height:100%;width:100%}
.map-panel.globe-full .map-label{display:none}
.map-panel.globe-full .globe-expand{display:none}
.map-panel.globe-full .globe-close{display:flex}
.map-panel.globe-full::after{display:none}
.map-panel.globe-full .globe-zoom{position:fixed;right:14px;bottom:24px;display:flex}
/* paper preview card: opens centered over the globe on pin click */
.pin-preview{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-.6deg);z-index:1000;
  display:flex;flex-direction:column;gap:9px;width:min(88%,300px);
  background:var(--paper);border:1px solid #cfc2a2;padding:12px 14px 14px;color:var(--ink);
  box-shadow:0 22px 54px rgba(10,5,1,.65);
}
.pin-preview[hidden]{display:none}
.pin-preview img{width:100%;height:150px;object-fit:cover;border:1px solid #cfc2a2;filter:sepia(.25)}
.pin-preview .pp-body{min-width:0;display:flex;flex-direction:column;gap:2px}
.pin-preview .pp-title{font-family:"Playfair Display",serif;font-weight:900;font-size:17px;color:var(--ink);line-height:1.12;padding-right:16px}
.pin-preview .pp-meta{font-family:"Special Elite",monospace;font-size:11px;color:var(--ink-soft)}
.pin-preview .pp-tier{font-family:"Caveat",cursive;font-size:17px;font-weight:700}
.pin-preview .pp-tier.strong{color:var(--t-strong)}.pin-preview .pp-tier.contested{color:var(--t-contested)}
.pin-preview .pp-tier.unknown{color:var(--t-unknown)}.pin-preview .pp-tier.discredited{color:var(--t-discredited)}
.pin-preview .pp-cta{font-family:"Special Elite",monospace;font-size:11px;color:var(--red);margin-top:3px}
.pin-preview .pp-close{position:absolute;top:2px;right:7px;background:none;border:none;color:var(--ink-soft);font-size:21px;line-height:1;cursor:pointer;padding:5px}
/* vintage atlas treatment on the tiles */
#pinmap .leaflet-tile-pane{filter:sepia(.34) saturate(.78) contrast(.96) brightness(1.02)}
#pinmap .leaflet-control-attribution{font-size:9px;background:rgba(242,233,210,.8);color:#5d4c33}
#pinmap .leaflet-control-zoom a{
  background:var(--paper);color:var(--ink);border:1px solid #b8a87f;
  font-family:"Anton",sans-serif;box-shadow:0 2px 6px rgba(20,10,2,.4);
}
#pinmap .leaflet-control-zoom a:hover{background:#e8dab4}
.map-pin-icon{background:none;border:none}
.map-pin-icon img{width:22px;height:30px;filter:drop-shadow(0 4px 3px rgba(20,10,2,.5))}
/* clipping-style map popup */
.leaflet-popup-content-wrapper{
  background:var(--paper);border-radius:2px;box-shadow:0 10px 26px rgba(10,5,1,.6);
  border:1px solid #cfc2a2;
}
.leaflet-popup-tip{background:var(--paper)}
.leaflet-popup-content{margin:10px 12px;font-family:"Zilla Slab",serif;color:var(--ink)}
.map-pop{display:block;width:210px;color:var(--ink)}
.map-pop img{width:100%;height:100px;object-fit:cover;border:1px solid #cfc2a2;filter:sepia(.3) contrast(1.04);margin:4px 0 6px}
.map-pop .mp-head{font-family:"Playfair Display",serif;font-weight:900;font-size:15px;line-height:1.1}
.map-pop .mp-meta{font-family:"Special Elite",monospace;font-size:10px;color:var(--ink-soft)}
.map-pop .mp-tier{font-family:"Caveat",cursive;font-size:16px;font-weight:700}
.map-pop .mp-cta{font-family:"Special Elite",monospace;font-size:10.5px;color:var(--red);display:block;margin-top:4px}
.map-pop .mp-tier.strong{color:var(--t-strong)}.map-pop .mp-tier.contested{color:var(--t-contested)}
.map-pop .mp-tier.unknown{color:var(--t-unknown)}.map-pop .mp-tier.discredited{color:var(--t-discredited)}

/* ---------- the evidence board grid ---------- */
.corkboard{max-width:none;width:100%;margin:46px 0 0;padding:30px 4vw 60px;position:relative}
.corkboard .cork-title{
  display:inline-block;border-bottom:none;margin:0 0 6px;padding:10px 26px;
  background:var(--paper);color:var(--ink);font-family:"Special Elite",monospace;font-size:24px;
  letter-spacing:2px;text-transform:uppercase;box-shadow:0 5px 12px rgba(20,10,2,.5);transform:rotate(-1.2deg);position:relative;
}
.corkboard .cork-title::before,.corkboard .cork-title::after{
  content:"";position:absolute;top:-9px;width:74px;height:22px;background:rgba(228,214,180,.7);
  box-shadow:0 1px 4px rgba(20,10,2,.35);transform:rotate(-4deg);
}
.corkboard .cork-title::before{left:-26px}
.corkboard .cork-title::after{right:-26px;transform:rotate(5deg)}
.corkboard .index-intro{
  background:#f7f1dd;color:#3a2e1d;max-width:560px;padding:14px 18px;margin:18px 0 30px;
  font-family:"Caveat",cursive;font-size:21px;line-height:1.35;transform:rotate(.6deg);
  box-shadow:0 5px 12px rgba(20,10,2,.45);position:relative;
}
.corkboard .index-intro::before{
  content:"";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  width:20px;height:27px;background:url('/img/pins/pin-yellow.png') center/contain no-repeat;
  filter:drop-shadow(0 4px 3px rgba(20,10,2,.45));
}
.corkboard .index-intro strong{color:#7a1f1f}
.case-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:15px}

/* aged-newsprint clippings of varying size, pinned with real photographed pushpins */
.corkboard .case-list{
  grid-template-columns:repeat(auto-fill,minmax(225px,1fr));grid-auto-flow:dense;
  gap:38px 28px;position:relative;z-index:2;align-items:start;
}
.corkboard li.clip-v1{grid-column:span 2}
.corkboard li.clip-v4{grid-row:span 2}
.corkboard .case-card.clip{
  display:flex;flex-direction:column;align-items:stretch;gap:6px;
  background:transparent;border:none;border-radius:0;padding:14px 15px 15px;
  transform:rotate(var(--tilt,0deg));position:relative;color:var(--ink);
}
/* the torn newsprint sheet lives on a backdrop layer so pins/tape/stickies can overhang it */
.corkboard .case-card.clip::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(160deg,rgba(242,233,210,.62) 0%,rgba(228,214,178,.66) 100%), url('/img/newsprint.jpg');
  background-size:cover,420px auto;
  clip-path:polygon(0.6% 1.8%, 4% 0.4%, 11% 1.4%, 21% 0.2%, 33% 1.6%, 45% 0.5%, 58% 1.8%, 70% 0.3%, 82% 1.5%, 93% 0.4%, 99.4% 2%, 99.8% 12%, 98.9% 26%, 99.7% 41%, 98.8% 57%, 99.6% 72%, 98.9% 86%, 99.5% 97.8%, 94% 99.4%, 83% 98.4%, 70% 99.6%, 57% 98.5%, 44% 99.7%, 31% 98.6%, 18% 99.5%, 7% 98.5%, 0.4% 99.2%, 1.2% 88%, 0.2% 74%, 1.1% 59%, 0.3% 44%, 1.2% 29%, 0.3% 14%);
  filter:drop-shadow(0 7px 9px rgba(20,10,2,.5)) drop-shadow(0 2px 3px rgba(20,10,2,.35));
}
.corkboard .case-list li:nth-child(2n) .case-card.clip::before{
  clip-path:polygon(0.3% 2.5%, 6% 0.6%, 16% 1.9%, 28% 0.3%, 41% 1.7%, 53% 0.4%, 66% 1.9%, 78% 0.5%, 90% 1.6%, 99.6% 0.8%, 99% 14%, 99.8% 30%, 98.8% 47%, 99.7% 63%, 98.9% 79%, 99.6% 98.6%, 91% 98.6%, 79% 99.7%, 66% 98.4%, 52% 99.6%, 38% 98.5%, 25% 99.6%, 12% 98.6%, 0.7% 99.5%, 0.2% 84%, 1.3% 68%, 0.3% 52%, 1.2% 36%, 0.2% 20%);
}
.corkboard .case-card.clip:hover{transform:rotate(0deg) scale(1.03);z-index:5}
.corkboard .case-card.clip:hover::before{filter:drop-shadow(0 14px 20px rgba(20,10,2,.6)) drop-shadow(0 3px 5px rgba(20,10,2,.4))}
.corkboard .case-list li:nth-child(6n) .clip{--tilt:1.5deg}
.corkboard .case-list li:nth-child(6n+1) .clip{--tilt:-1.7deg}
.corkboard .case-list li:nth-child(6n+2) .clip{--tilt:.8deg}
.corkboard .case-list li:nth-child(6n+3) .clip{--tilt:-1deg}
.corkboard .case-list li:nth-child(6n+4) .clip{--tilt:1.9deg}
.corkboard .case-list li:nth-child(6n+5) .clip{--tilt:-.6deg}
/* the real photographed pushpin */
.corkboard .pin,.paper-sheet .pin{
  position:absolute;top:-15px;left:50%;transform:translateX(-50%) rotate(2deg);z-index:6;
  width:24px;height:33px;background-size:contain;background-repeat:no-repeat;background-position:center;
  filter:drop-shadow(0 5px 4px rgba(20,10,2,.45));
}
.pin-red{background-image:url('/img/pins/pin-red.png')}
.pin-blue{background-image:url('/img/pins/pin-blue.png')}
.pin-yellow{background-image:url('/img/pins/pin-yellow.png')}
.corkboard li:nth-child(3n) .pin{left:18%;transform:rotate(-7deg)}
.corkboard li:nth-child(3n+1) .pin{left:78%;transform:rotate(6deg)}
/* tape year label on each clipping */
.clip-year{
  position:absolute;top:-13px;right:14%;z-index:5;transform:rotate(2.5deg);
  background:rgba(233,220,189,.92);color:#6b3a16;font-family:"Caveat",cursive;font-weight:700;
  font-size:16px;line-height:1;padding:4px 14px;box-shadow:0 2px 6px rgba(20,10,2,.35);
}
.corkboard li:nth-child(2n) .clip-year{right:auto;left:12%;transform:rotate(-3deg)}
/* sticky note (location) on some clippings */
.clip-note{
  position:absolute;bottom:-15px;right:-9px;z-index:5;transform:rotate(-4deg);
  background:var(--note-yellow);color:#4a3a10;font-family:"Caveat",cursive;font-weight:700;
  font-size:15px;line-height:1.2;padding:8px 11px;max-width:140px;
  box-shadow:0 5px 10px rgba(20,10,2,.45);
}
.corkboard li:nth-child(3n) .clip-note{transform:rotate(3deg);background:#aede9d;color:#23420f}
.corkboard li:nth-child(5n) .clip-note{background:var(--note-pink);color:#5e1f30}
/* clipping anatomy */
.corkboard .clip-mast{
  display:flex;justify-content:space-between;align-items:baseline;
  border-bottom:2px solid var(--ink);padding-bottom:3px;margin-bottom:2px;
  font-family:"Special Elite",monospace;font-size:9.5px;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink-soft);
}
.corkboard .clip-head{
  font-family:"Playfair Display",serif;font-weight:900;font-size:19px;line-height:1.08;
  margin:2px 0;color:#1c150e;text-transform:none;letter-spacing:0;
}
.corkboard li.clip-v1 .clip-head{font-size:26px}
.corkboard li.clip-v5 .clip-head{font-family:"Special Elite",monospace;font-weight:400;font-size:15px;text-transform:uppercase}
.corkboard .clip-date{
  font-family:"Special Elite",monospace;font-size:10px;color:var(--ink-soft);letter-spacing:.4px;
  border-bottom:1px solid #c9bb98;padding-bottom:5px;
}
.corkboard .clip img{
  width:100%;height:120px;object-fit:cover;border:1px solid #b8aa85;border-radius:0;margin-top:3px;
  filter:sepia(.42) contrast(1.08) saturate(.7) brightness(1.02);
}
.corkboard li.clip-v1 .clip img{height:170px}
.corkboard li.clip-v4 .clip img{height:230px}
.corkboard li.clip-v3 .clip img{height:88px}
.corkboard li.clip-v5 .clip img{height:96px;filter:grayscale(.85) sepia(.25) contrast(1.08)}
.corkboard .clip-body{
  font-family:"Zilla Slab",Georgia,serif;font-size:11.5px;line-height:1.45;color:#3a2e1d;text-align:justify;
}
.corkboard li.clip-v1 .clip-body{column-count:2;column-gap:14px;font-size:12px}
.corkboard .clip .cc-tier{
  font-family:"Caveat",cursive;font-size:17px;letter-spacing:0;text-transform:none;font-weight:700;margin-top:2px;
  align-self:flex-end;transform:rotate(-2deg);
}
.cc-tier.strong{color:var(--t-strong)}.cc-tier.contested{color:var(--t-contested)}
.cc-tier.unknown{color:var(--t-unknown)}.cc-tier.discredited{color:var(--t-discredited)}
.cc-tier.unidentified{color:var(--t-contested)}.cc-tier.speculative{color:var(--t-unknown)}
.corkboard .strings{position:absolute;inset:0;z-index:1;pointer-events:none}
.corkboard p.index-intro[style]{background:#f7f1dd;color:#3a2e1d}
.corkboard p.index-intro a{color:#7a1f1f !important;font-weight:700}

/* special board items: checklist + stats notes */
.board-note{
  background:#f7f1dd;color:#3a2e1d;padding:14px 16px;position:relative;
  box-shadow:0 6px 14px rgba(20,10,2,.5);font-family:"Caveat",cursive;
  transform:rotate(var(--tilt,1deg));
}
.board-note h3{font-family:"Special Elite",monospace;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
  margin:0 0 8px;border-bottom:2px solid #3a2e1d;padding-bottom:4px;color:#241c14}
.board-note ul{list-style:none;margin:0;padding:0;font-size:18px;line-height:1.5}
.board-note li::before{content:"\2611  ";color:#1d6e3c}
.board-note li.todo::before{content:"\2610  ";color:#5d4c33}
.board-note .pin{position:absolute;top:-15px;left:50%;width:24px;height:33px;background-size:contain;background-repeat:no-repeat}
.stats-note .pie{
  width:120px;height:120px;border-radius:50%;margin:6px auto 10px;border:2px solid #d9cba6;
  box-shadow:inset 0 0 12px rgba(20,10,2,.2);
}
.stats-note .leg{font-size:16px;line-height:1.45}
.stats-note .leg i{display:inline-block;width:11px;height:11px;border-radius:2px;margin-right:7px}

/* archives & documents row */
.board-docs{max-width:1280px;margin:40px auto 0;padding:0 4vw}
.board-docs h2{
  display:inline-block;background:rgba(233,220,189,.92);color:#3a2814;font-family:"Caveat",cursive;
  font-size:26px;font-weight:700;padding:6px 22px;margin:0 0 20px;transform:rotate(-1deg);
  box-shadow:0 3px 8px rgba(20,10,2,.4);letter-spacing:1px;
}
.docs-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:22px}
.doc-card{
  background:linear-gradient(165deg,#f4ecd6,#e9dcba);color:var(--ink);padding:14px 14px 16px;position:relative;
  box-shadow:0 6px 14px rgba(20,10,2,.5);transform:rotate(var(--tilt,0deg));transition:.16s;
}
.doc-card:hover{transform:rotate(0) translateY(-4px);box-shadow:0 12px 26px rgba(20,10,2,.6)}
.docs-row a:nth-child(odd) .doc-card{--tilt:-1.2deg}
.docs-row a:nth-child(2n) .doc-card{--tilt:1.1deg}
.doc-card h3{font-family:"Special Elite",monospace;font-size:13px;text-transform:uppercase;letter-spacing:1px;margin:0 0 6px;
  border-bottom:1.5px solid var(--ink);padding-bottom:4px}
.doc-card p{font-size:12.5px;line-height:1.45;color:#3a2e1d;margin:0}
.doc-card::before{
  content:"";position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-2deg);
  width:58px;height:18px;background:rgba(228,214,180,.7);box-shadow:0 1px 4px rgba(20,10,2,.35);
}

/* ---------- article pages: a typed report pinned to the board ---------- */
.article{max-width:780px;margin:0 auto;padding:46px 24px 0;position:relative}
.paper-sheet,.article{color:var(--cream)}
.article > *{position:relative}
.article{
  background:transparent;
}
.article-inner-fallback{display:none}
.article > nav.crumbs{margin-bottom:18px}
.crumbs{font-family:"Special Elite",monospace;font-size:12px;color:#e9ddc0;margin-bottom:16px;text-shadow:0 1px 3px rgba(20,10,2,.6)}
.crumbs a{color:#f0c060}.crumbs span{margin:0 6px;opacity:.6}
/* the report sheet */
main.article::before{content:none}
.article .tier-pill,.article h1,.article .article-meta,.article .article-hero,.article .lead,
.article h2,.article p,.article ul,.article .prevnext,.article figure,.article .hub-link{position:relative;z-index:2}
.article-paper{position:absolute;inset:30px -28px 0;z-index:1}
/* simpler: wrap everything visually via a backdrop */
.article{isolation:isolate}
.article::after{
  content:"";position:absolute;left:-30px;right:-30px;top:36px;bottom:-20px;z-index:0;
  background:linear-gradient(170deg,#f2e9d2 0%,#ece1c4 60%,#e2d3ae 100%);
  box-shadow:0 14px 36px rgba(10,5,1,.6);transform:rotate(-.3deg);
}
.article > *{z-index:1}
.article h1{
  font-family:"Playfair Display",serif;font-weight:900;font-size:clamp(28px,4.8vw,46px);line-height:1.04;margin:8px 0 10px;
  color:#1c150e;text-transform:none;letter-spacing:0;
}
.article-meta{font-family:"Special Elite",monospace;font-size:12.5px;color:var(--ink-soft);margin:0 0 20px;
  border-top:2px solid var(--ink);border-bottom:1px solid #c9bb98;padding:6px 0}
.article-hero{margin:0 0 24px}
.article-hero img,.article-hero video{
  width:100%;border:1px solid #cfc2a2;display:block;filter:sepia(.18) contrast(1.03);
  box-shadow:0 8px 20px rgba(20,10,2,.35);background:#181208;
}
.article-hero video{filter:none}
.article-hero figcaption{font-family:"Special Elite",monospace;font-size:11.5px;color:var(--ink-soft);margin-top:9px}
.article .lead{
  font-size:18px;line-height:1.6;color:#241c14;margin:0 0 24px;font-style:normal;
  font-family:"Zilla Slab",serif;font-weight:600;border-left:3px solid var(--red);padding-left:16px;
}
.article h2{
  font-family:"Special Elite",monospace;font-weight:400;font-size:17px;letter-spacing:1px;text-transform:uppercase;
  color:#42301a;margin:30px 0 8px;padding-top:10px;border-top:2px solid #c9bb98;
}
.article p{font-size:16.5px;line-height:1.74;color:#33281a}
.article .tier-pill{margin-bottom:6px}
.tier-pill{display:inline-block;font-family:"Caveat",cursive;font-size:20px;font-weight:700;padding:0;border:none;background:none !important;transform:rotate(-2deg)}
.tier-pill.strong{color:var(--t-strong)}.tier-pill.contested{color:var(--t-contested)}
.tier-pill.unknown{color:var(--t-unknown)}.tier-pill.discredited{color:var(--t-discredited)}
.tier-pill.unidentified{color:var(--t-contested)}.tier-pill.speculative{color:var(--t-unknown)}
.sources{padding-left:18px;font-size:13px;font-family:"Special Elite",monospace}
.sources a{color:#8a2113;word-break:break-all}
.hub-link{font-family:"Special Elite",monospace;font-size:13.5px;color:var(--ink-soft);margin-top:22px}
.hub-link a{color:#8a2113 !important;font-weight:700}
.extra-media{margin:0 0 22px}
.extra-media img,.extra-media video{width:100%;border:1px solid #cfc2a2;display:block;background:#181208;
  box-shadow:0 8px 18px rgba(20,10,2,.3);filter:sepia(.14) contrast(1.02)}
.extra-media video{filter:none}
.extra-media figcaption{font-family:"Special Elite",monospace;font-size:11.5px;color:var(--ink-soft);margin-top:8px}
.yt-wrap{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border:1px solid #cfc2a2;background:#000;
  box-shadow:0 8px 18px rgba(20,10,2,.3)}
.yt-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.prevnext{display:flex;justify-content:space-between;gap:14px;margin:38px 0 10px}
.prevnext .pn{flex:1;background:#efe5c8;border:1px solid #cfc2a2;padding:12px 14px;color:var(--ink);
  font-family:"Playfair Display",serif;font-weight:700;font-size:15px;transition:.16s;box-shadow:0 4px 10px rgba(20,10,2,.3)}
.prevnext .pn:hover{background:#e4d6b2;transform:translateY(-2px)}
.prevnext .pn.right{text-align:right}
.prevnext .pn span{display:block;font-family:"Special Elite",monospace;font-size:11px;color:var(--ink-soft);font-weight:400;margin-bottom:3px}
.tier-legend{list-style:none;padding:0;margin:14px 0;display:grid;gap:12px}
.tier-legend li{display:flex;align-items:center;gap:12px;font-size:15.5px;color:#33281a}
/* related case mini-cards inside articles */
.related-list{margin-top:6px !important;display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:15px;list-style:none;padding:0}
.related-list .case-card{display:flex;gap:12px;align-items:center;background:#efe5c8;border:1px solid #cfc2a2;padding:10px;color:var(--ink);
  box-shadow:0 4px 10px rgba(20,10,2,.3);transition:.16s}
.related-list .case-card:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(20,10,2,.4)}
.related-list .case-card img{width:74px;height:74px;object-fit:cover;border:1px solid #cfc2a2;filter:sepia(.25)}
.related-list .case-card h3{margin:0 0 3px;font-family:"Playfair Display",serif;font-weight:900;font-size:15px;line-height:1.15}
.related-list .cc-meta{font-family:"Special Elite",monospace;font-size:10.5px;color:var(--ink-soft)}
.related-list .cc-tier{font-family:"Caveat",cursive;font-size:15px;font-weight:700}

/* ---------- gallery on the board ---------- */
.gallery-main{max-width:1180px;margin:0 auto;padding:30px 24px 0}
.gallery-main h1{
  display:inline-block;font-family:"Special Elite",monospace;font-weight:400;font-size:clamp(24px,4vw,34px);
  text-transform:uppercase;letter-spacing:3px;margin:6px 0 10px;color:var(--ink);
  background:var(--paper);padding:10px 28px;box-shadow:0 6px 16px rgba(10,5,1,.55);transform:rotate(-.8deg);
}
.gallery-main{text-align:center}
.gallery-main > *{text-align:left}
.gallery-main h1,.g-hero{text-align:center}
.gallery-intro{
  color:#3a2e1d;max-width:640px;margin:10px auto 26px;text-align:center;font-family:"Caveat",cursive;font-size:20px;
  background:var(--note-yellow);padding:10px 18px;box-shadow:0 5px 12px rgba(20,10,2,.45);transform:rotate(.5deg);
}
.gallery-editorial{max-width:720px;margin:0 auto 32px;background:var(--paper);padding:20px 26px;
  box-shadow:0 8px 18px rgba(20,10,2,.5);transform:rotate(-.3deg)}
.gallery-editorial p{font-size:14.5px;line-height:1.65;color:#33281a;font-family:"Zilla Slab",serif}
.gallery-editorial a{color:#8a2113 !important;font-weight:700}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:30px 24px}
.g-card{
  position:relative;background:var(--paper);padding:10px 10px 14px;display:block;color:var(--ink);
  box-shadow:0 7px 16px rgba(20,10,2,.5);transform:rotate(var(--tilt,0deg));transition:.18s;
}
.gallery-grid a:nth-child(4n) {--tilt:1.4deg}
.gallery-grid a:nth-child(4n+1){--tilt:-1.5deg}
.gallery-grid a:nth-child(4n+2){--tilt:.9deg}
.gallery-grid a:nth-child(4n+3){--tilt:-.8deg}
.g-card:hover{transform:rotate(0) scale(1.04);box-shadow:0 14px 30px rgba(20,10,2,.6);z-index:3}
.g-card::before{
  content:"";position:absolute;top:-14px;left:50%;transform:translateX(-50%);z-index:6;
  width:22px;height:30px;background:url('/img/pins/pin-red.png') center/contain no-repeat;
  filter:drop-shadow(0 4px 4px rgba(20,10,2,.45));
}
.gallery-grid a:nth-child(3n) .g-card::before{background-image:url('/img/pins/pin-yellow.png')}
.gallery-grid a:nth-child(3n+1) .g-card::before{background-image:url('/img/pins/pin-blue.png')}
.g-card img{width:100%;height:170px;object-fit:cover;display:block;border:1px solid #cfc2a2;filter:sepia(.3) contrast(1.05)}
.g-cap{position:static;display:flex;flex-direction:column;gap:2px;background:none;padding:8px 2px 0}
.g-cap strong{font-family:"Playfair Display",serif;font-weight:900;font-size:14.5px;color:var(--ink)}
.g-cap em{font-family:"Special Elite",monospace;font-size:10.5px;color:var(--ink-soft);font-style:normal}
.g-hook{font-size:11.5px;color:#3a2e1d;line-height:1.35;margin-top:2px;font-family:"Zilla Slab",serif}
.g-tier{margin-top:3px;font-family:"Caveat",cursive;font-size:15px;font-weight:700;border:none !important;background:none !important;padding:0 !important}
.g-tier.strong{color:var(--t-strong)}.g-tier.contested{color:var(--t-contested)}
.g-tier.unknown{color:var(--t-unknown)}.g-tier.discredited{color:var(--t-discredited)}
.g-tier.unidentified{color:var(--t-contested)}.g-tier.speculative{color:var(--t-unknown)}
/* gallery hero: saucer + peeking alien stay */
.g-hero{height:200px;display:flex;align-items:flex-end;justify-content:center;margin-top:14px;position:relative}
.g-hero-saucer{position:relative;animation:ghover 4.5s ease-in-out infinite}
.g-alien{position:absolute;left:50%;top:0;z-index:-1;transform:translate(-50%,-8%) rotate(-6deg);
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.5));animation:peek 7s ease-in-out infinite}
@keyframes peek{0%,55%,100%{transform:translate(-50%,28%) rotate(-6deg)}65%,90%{transform:translate(-50%,-46%) rotate(4deg)}}
@keyframes ghover{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}}
.g-hero-saucer img:not(.g-alien){width:190px;height:auto;display:block;filter:drop-shadow(0 8px 14px rgba(0,0,0,.6)) contrast(1.06);position:relative;z-index:2}
.g-hero-saucer img.g-alien{width:68px}
.g-beam{position:absolute;left:50%;top:60%;transform:translateX(-50%);width:90px;height:120px;
  background:linear-gradient(180deg,rgba(232,177,60,.4),rgba(232,177,60,0));clip-path:polygon(34% 0,66% 0,100% 100%,0 100%);animation:gbeam 2.8s ease-in-out infinite;z-index:-1}
@keyframes gbeam{0%,100%{opacity:.4}50%{opacity:.8}}

/* ---------- 404 ---------- */
.nf-main{text-align:center;padding-top:70px}
.nf-title{font-family:"Playfair Display",serif;font-weight:900;font-size:clamp(30px,5.4vw,52px);color:#1c150e;margin:6px 0 14px}
.nf-saucer{height:120px;position:relative;overflow:visible;margin-bottom:8px}
.nf-saucer img{width:150px;position:absolute;left:-180px;top:20px;animation:flyby 9s linear infinite;filter:drop-shadow(0 6px 12px rgba(0,0,0,.5))}
@keyframes flyby{0%{left:-180px;top:50px;transform:rotate(-4deg) scale(.8)}45%{top:6px;transform:rotate(3deg) scale(1)}100%{left:calc(100% + 60px);top:34px;transform:rotate(-6deg) scale(.85)}}

/* ---------- footer: wood bar ---------- */
.site-footer{
  margin:60px 0 0;padding:26px 24px 44px;color:var(--cream-soft);font-size:13.5px;text-align:center;
  background:linear-gradient(180deg,#241708,#180e04);border-top:3px solid #120a03;
}
.site-footer a{color:#e8b13c;font-weight:600}
.footer-credit a{color:#f0c060 !important}

/* ---------- mobile ---------- */
@media(max-width:620px){
  .site-header{flex-wrap:wrap;gap:8px;padding:10px 14px}
  .site-nav{gap:12px;font-size:12px;order:3;width:100%;justify-content:center}
  .search-wrap{flex:1 1 auto;margin-left:8px}
  .brand-text{font-size:16px}
  #pinmap{height:70vh}
  .corkboard li.clip-v1{grid-column:auto}
  .corkboard li.clip-v1 .clip-body{column-count:1}
  .corkboard li.clip-v4{grid-row:auto}
  .corkboard li.clip-v4 .clip img{height:150px}
  .article::after{left:-12px;right:-12px}
}
