/* ============================================================
   ANIMAL RESOURCES — site.css  (shared: index + gallery)
   A sad HR department for animals. Manila, sign-green, washed
   brown, faded black, one brick-red stamp. No gloss.
   ============================================================ */

:root{
  --paper:    #e3dbc4;
  --paper-2:  #ece5d2;
  --green:    #3e4a33;
  --green-2:  #586a44;
  --wood:     #6b5740;
  --wood-dk:  #463829;
  --ink:      #2a2620;
  --ink-soft: #57503f;
  --stamp:    #9a4736;

  --mono: "Courier New", ui-monospace, "DejaVu Sans Mono", monospace;
  --sans: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --cond: "Arial Narrow", "Helvetica Neue", Helvetica, Arial, sans-serif;

  --maxw: 980px;
}

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }

body{
  margin:0;
  overflow-x:hidden;
  background-color:var(--paper);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:var(--green); }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 22px; }
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0;
}

/* ===================== TOP BAR ===================== */
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  max-width:var(--maxw); margin:0 auto; padding:16px 22px 14px;
  border-bottom:1px solid var(--wood);
}
.brand{ display:flex; align-items:center; gap:10px; text-decoration:none; }
.brand img{
  width:34px; height:34px; border-radius:50%;
  border:1.5px solid var(--wood-dk);
}
.brand span{
  font-family:var(--cond); font-weight:700; text-transform:uppercase;
  letter-spacing:.06em; font-size:1.05rem; color:var(--ink);
}
.nav-link{
  font-family:var(--mono); text-transform:uppercase; letter-spacing:.12em;
  font-size:.74rem; color:var(--green); text-decoration:none;
}
.nav-link:hover{ text-decoration:underline; }

/* ===================== HERO ===================== */
.hero{ position:relative; padding:30px 22px 36px; text-align:center; overflow:hidden; }
.hero::before{
  content:""; position:absolute; left:50%; top:-70px; transform:translateX(-50%);
  width:120%; height:180px;
  background:radial-gradient(60% 100% at 50% 0%, rgba(255,250,222,.5), rgba(255,250,222,0) 70%);
  pointer-events:none;
}
.hero-inner{ position:relative; max-width:760px; margin:0 auto; }

.banner{
  width:100%;
  border:1px solid var(--wood-dk);
  box-shadow:0 6px 22px rgba(0,0,0,.22);
  margin:0 auto 22px;
}

.hero-line{
  margin:0 auto 24px; max-width:34ch;
  color:var(--ink-soft); font-size:1.05rem;
}

/* ===================== BUTTONS ===================== */
.links{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
.btn{
  display:inline-block; min-width:150px; padding:11px 18px;
  background:var(--paper-2); color:var(--ink); text-decoration:none;
  font-family:var(--mono); text-transform:uppercase; letter-spacing:.08em;
  font-size:.78rem; border:1.5px solid var(--wood-dk); border-radius:3px;
  box-shadow:0 3px 0 var(--wood-dk);
  transition:transform .08s ease, box-shadow .08s ease, background .15s ease;
}
.btn small{ display:block; text-transform:none; letter-spacing:0; font-size:.72rem; color:var(--ink-soft); margin-top:2px; }
.btn:hover{ background:#f3eedd; }
.btn:active{ transform:translateY(3px); box-shadow:0 0 0 var(--wood-dk); }
.btn:focus-visible{ outline:3px solid var(--green-2); outline-offset:2px; }

/* ===================== SECTIONS ===================== */
.section{ max-width:var(--maxw); margin:0 auto; padding:40px 22px; }
.eyebrow{
  margin:0 0 20px; font-family:var(--mono); text-transform:uppercase;
  letter-spacing:.22em; font-size:.72rem; color:var(--green);
  border-bottom:1px solid var(--wood); padding-bottom:8px;
  display:flex; justify-content:space-between; align-items:baseline; gap:12px;
}
.eyebrow a{ font-size:.68rem; letter-spacing:.12em; color:var(--green-2); text-decoration:none; }
.eyebrow a:hover{ text-decoration:underline; }

/* ===================== FEATURED ===================== */
.featured{
  margin:0; background:var(--paper-2); padding:12px 12px 0;
  border:1px solid var(--wood); box-shadow:0 5px 18px rgba(0,0,0,.18);
  max-width:560px; margin-inline:auto;
}
.featured .card-btn img{ width:100%; border:1px solid rgba(70,56,41,.25); }
.featured .tag{ border-top:1px dashed var(--wood); }

/* ===================== GRID / CARDS ===================== */
.grid{ display:grid; grid-template-columns:1fr; gap:24px; }
.card{
  margin:0; background:var(--paper-2); padding:10px 10px 0;
  border:1px solid var(--wood); box-shadow:0 4px 14px rgba(0,0,0,.16);
}
.card:nth-child(odd){ transform:rotate(-.5deg); }
.card:nth-child(even){ transform:rotate(.6deg); }
.card-btn{ display:block; width:100%; padding:0; margin:0; border:0; background:transparent; cursor:zoom-in; }
.card-btn img{ width:100%; border:1px solid rgba(70,56,41,.25); }
.card-btn:focus-visible{ outline:3px solid var(--green-2); outline-offset:3px; }
.tag{
  font-family:var(--mono); font-size:.76rem; letter-spacing:.03em; color:var(--ink);
  padding:10px 4px 4px;
}
.tag small{ display:block; font-size:.72rem; color:var(--ink-soft); letter-spacing:0; padding-bottom:8px; }

/* ===================== PREMISE MEMO ===================== */
.memo{
  position:relative; max-width:580px; margin:0 auto;
  background:var(--paper-2); border:1px solid var(--wood);
  padding:26px 26px 30px; box-shadow:0 4px 14px rgba(0,0,0,.14); overflow:hidden;
}
.memo::after{
  content:""; position:absolute; right:-26px; bottom:-26px;
  width:104px; height:104px; border-radius:50%;
  border:7px solid rgba(120,82,46,.16); pointer-events:none;
}
.memo-head{
  margin:0 0 12px; font-family:var(--mono); text-transform:uppercase;
  letter-spacing:.2em; font-size:.72rem; color:var(--green);
}
.memo-body{ margin:0; color:var(--ink); font-size:1.05rem; max-width:48ch; position:relative; }

/* ===================== FOOTER ===================== */
.footer{ text-align:center; padding:38px 22px 50px; border-top:1px solid var(--wood); margin-top:18px; }
.foot-name{ margin:0 0 4px; font-family:var(--cond); text-transform:uppercase; letter-spacing:.08em; font-weight:700; font-size:1.3rem; color:var(--ink); }
.foot-tag{ margin:0 0 16px; font-family:var(--mono); font-size:.8rem; letter-spacing:.08em; color:var(--stamp); }
.foot-links{ font-family:var(--mono); font-size:.8rem; letter-spacing:.06em; color:var(--ink-soft); }
.foot-links a{ color:var(--green); text-decoration:none; }
.foot-links a:hover{ text-decoration:underline; }
.foot-links span{ margin:0 8px; color:var(--wood); }
.foot-note{ margin:18px auto 0; max-width:40ch; font-family:var(--mono); font-size:.7rem; letter-spacing:.03em; color:var(--ink-soft); }
.foot-fine{ margin:14px 0 0; font-family:var(--mono); font-size:.7rem; letter-spacing:.06em; color:var(--ink-soft); opacity:.8; }

/* ===================== LIGHTBOX ===================== */
.lightbox{ position:fixed; inset:0; z-index:50; display:flex; align-items:center; justify-content:center; padding:24px; background:rgba(24,20,15,.92); cursor:zoom-out; }
.lightbox[hidden]{ display:none; }
.lightbox img{ max-width:100%; max-height:92vh; border:3px solid var(--paper-2); box-shadow:0 12px 40px rgba(0,0,0,.5); }
.lightbox-close{ position:absolute; top:14px; right:18px; width:44px; height:44px; background:transparent; border:0; color:var(--paper-2); font-size:2.2rem; line-height:1; cursor:pointer; }
.lightbox-close:focus-visible{ outline:3px solid var(--green-2); outline-offset:2px; }

/* ===================== RESPONSIVE ===================== */
@media (min-width:620px){
  .grid{ grid-template-columns:1fr 1fr; }
  .banner{ max-height:74vh; width:auto; }
}
@media (min-width:920px){
  .grid{ grid-template-columns:1fr 1fr 1fr; }
}

/* ===================== MOTION ===================== */
@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  *{ transition:none !important; }
  .card{ transform:none; }
}
