/* ============================================================
   snowdeaf — public stylesheet
   Built entirely from the LOCKED design tokens (tokens.css).
   Direction: editorial-feature · SUBTLE deep-rust on warm sand.
   Adapted from mockup #4 (subtle mode, default rust palette).
   ============================================================ */

@import url('tokens.css');

*{ box-sizing:border-box; }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

a{ color:inherit; }
img{ max-width:100%; }
.mono{ font-family:var(--font-mono); }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--pad); }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ---------- header ---------- */
header.site{
  display:flex; justify-content:space-between; align-items:center;
  padding:26px 0; gap:18px; flex-wrap:wrap;
}
.brand{ font-weight:800; font-size:22px; letter-spacing:-.03em; text-decoration:none; }
.brand b{ color:var(--accent); }
nav.main a{
  text-decoration:none; color:var(--soft); font-size:13px; font-weight:600;
  margin-left:22px; text-transform:uppercase; letter-spacing:.06em;
}
nav.main a:first-child{ margin-left:0; }
nav.main a:hover, nav.main a[aria-current="page"]{ color:var(--accent); }

/* ---------- lead feature (rust colour block) ---------- */
.lead{
  display:grid; grid-template-columns:1.1fr 1fr; gap:0; align-items:stretch;
  border-radius:16px; overflow:hidden; margin:14px 0 10px; border:1px solid var(--line);
}
.lead .txt{
  background:var(--block-bg); color:var(--block-fg);
  padding:38px 36px; display:flex; flex-direction:column; justify-content:center;
}
.lead .meta{
  font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  opacity:.85; margin-bottom:14px;
}
.lead h1{ font-weight:800; font-size:36px; line-height:1.08; letter-spacing:-.03em; margin:0 0 14px; }
.lead h1 a{ text-decoration:none; color:inherit; }
.lead h1 a:hover{ opacity:.85; }
.lead p{ margin:0 0 18px; opacity:.92; font-size:16px; }
.lead .tags a{
  display:inline-block; font-size:12px; font-weight:600; text-decoration:none;
  margin:0 8px 8px 0; padding:4px 10px; border-radius:99px;
  background:rgba(255,255,255,.18); color:var(--block-fg);
}
.lead .tags a:hover{ background:rgba(255,255,255,.30); }
.lead .ph-img{ position:relative; }
.lead .ph-img img{ width:100%; height:100%; object-fit:cover; display:block; min-height:260px; }
.lead .ph-img .ph{
  width:100%; height:100%; min-height:260px; background:rgba(0,0,0,.14);
  display:flex; align-items:center; justify-content:center;
  color:var(--block-fg); font-family:var(--font-mono); font-size:13px;
  font-weight:700; letter-spacing:.14em; text-transform:uppercase;
}

/* ---------- list ---------- */
.section-label{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent); margin:38px 0 6px; font-weight:700;
}
.list article{
  display:grid; grid-template-columns:130px 1fr auto; gap:22px; align-items:center;
  padding:18px 0; border-bottom:1px solid var(--line);
}
.list .thumb{ width:130px; aspect-ratio:16/10; object-fit:cover; border-radius:7px; display:block; }
.list .ph{
  width:130px; aspect-ratio:16/10; border-radius:7px; background:var(--accent);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:11px; font-weight:700; letter-spacing:.12em; text-align:center;
}
.list .ph.ig{ background:var(--block-bg); }
.list h3{ font-weight:700; font-size:20px; line-height:1.22; margin:0 0 7px; letter-spacing:-.015em; }
.list h3 a{ text-decoration:none; color:inherit; }
.list h3 a:hover{ color:var(--accent); }
.list .sub a{
  font-size:12px; font-weight:600; text-decoration:none; color:var(--accent);
  background:var(--tint); padding:3px 9px; border-radius:99px; margin-right:6px;
  display:inline-block; margin-bottom:4px;
}
.list .sub a:hover{ background:var(--accent); color:#fff; }
.list .badge{
  display:inline-block; font-family:var(--font-mono); font-size:11px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:#fff; background:var(--accent);
  padding:2px 8px; border-radius:5px; margin-right:6px; vertical-align:middle;
}
.list .when{ font-family:var(--font-mono); font-size:12px; color:var(--soft); white-space:nowrap; }

/* instagram embed inside a list row */
.list .ig-embed{ grid-column:1 / -1; margin-top:6px; }

/* ---------- single post ---------- */
.post-head{ margin:28px 0 8px; }
.post-head .meta{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--accent); font-weight:700; margin-bottom:10px;
}
.post-head .meta .dot{ color:var(--soft); margin:0 8px; }
.post-head .meta .when{ color:var(--soft); }
.post-head h1{ font-weight:800; font-size:38px; line-height:1.1; letter-spacing:-.03em; margin:0 0 14px; }
.post-tags{ margin:0 0 22px; }
.post-tags a{
  display:inline-block; font-size:12px; font-weight:600; text-decoration:none; color:var(--accent);
  background:var(--tint); padding:4px 11px; border-radius:99px; margin:0 8px 8px 0;
}
.post-tags a:hover{ background:var(--accent); color:#fff; }

.post-body{ font-size:18px; }
.post-body p{ margin:0 0 1.1em; }
.post-body h2{ font-size:26px; font-weight:700; letter-spacing:-.02em; margin:1.6em 0 .5em; }
.post-body h3{ font-size:21px; font-weight:700; margin:1.4em 0 .4em; }
.post-body a{ color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.post-body ul, .post-body ol{ padding-left:1.4em; margin:0 0 1.1em; }
.post-body li{ margin:.3em 0; }
.post-body img{ border-radius:var(--radius); display:block; margin:1.2em 0; }
.post-body blockquote{
  margin:1.2em 0; padding:2px 0 2px 18px; border-left:3px solid var(--accent);
  color:var(--soft); font-style:italic;
}
.post-body code{
  font-family:var(--font-mono); font-size:.88em; background:var(--tint);
  padding:.12em .4em; border-radius:5px;
}
.post-body pre{
  background:var(--ink); color:var(--bg); padding:16px 18px; border-radius:var(--radius);
  overflow-x:auto; margin:1.2em 0;
}
.post-body pre code{ background:none; padding:0; color:inherit; font-size:.86em; }
.post-body hr{ border:0; border-top:1px solid var(--line); margin:2em 0; }

/* responsive 16:9 embed (YouTube) */
.embed-16x9{
  position:relative; width:100%; aspect-ratio:16/9; margin:0 0 28px;
  border-radius:var(--radius); overflow:hidden; background:var(--ink);
}
.embed-16x9 iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* instagram embed wrapper */
.ig-wrap{ margin:0 0 28px; display:flex; justify-content:center; }
.ig-wrap .instagram-media{ margin:0 auto !important; }

.back-link{
  display:inline-block; margin:34px 0 0; font-family:var(--font-mono); font-size:12px;
  font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--accent);
  text-decoration:none;
}
.back-link:hover{ text-decoration:underline; }

/* ---------- page header (tags/downloads/about/sampler) ---------- */
.page-head{ margin:18px 0 6px; }
.page-head .kicker{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--accent); font-weight:700; margin-bottom:8px;
}
.page-head h1{ font-weight:800; font-size:34px; letter-spacing:-.03em; margin:0 0 6px; }
.page-head p.lede{ color:var(--soft); margin:0 0 8px; max-width:60ch; }

/* ---------- tags index ---------- */
.tag-cloud{ display:flex; flex-wrap:wrap; gap:10px; margin:24px 0 40px; }
.tag-cloud a{
  display:inline-flex; align-items:baseline; gap:7px; text-decoration:none;
  background:var(--tint); color:var(--accent); border:1px solid var(--line);
  padding:7px 13px; border-radius:99px; font-weight:600; font-size:14px;
}
.tag-cloud a:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }
.tag-cloud a .count{ font-family:var(--font-mono); font-size:11px; opacity:.7; }

/* ---------- about / generic prose page ---------- */
.prose{ font-size:18px; margin:24px 0 10px; }
.prose h3{ font-size:22px; font-weight:700; letter-spacing:-.02em; margin:1.5em 0 .4em; color:var(--ink); }
.prose ul{ padding-left:1.3em; }
.prose li{ margin:.35em 0; }
.prose a{ color:var(--accent); text-decoration:none; }
.prose a:hover{ text-decoration:underline; }

/* sampler */
.sampler-embed{ margin:26px 0; border-radius:var(--radius); overflow:hidden; }
.sampler-embed iframe{ display:block; width:100%; border:0; }

/* ---------- empty state ---------- */
.empty{
  margin:40px 0; padding:34px; border:1px dashed var(--line); border-radius:var(--radius);
  color:var(--soft); text-align:center; font-family:var(--font-mono); font-size:13px;
  letter-spacing:.04em;
}

/* ---------- pagination ---------- */
.pager{ display:flex; gap:10px; align-items:center; justify-content:center; margin:34px 0 10px; flex-wrap:wrap; }
.pager a, .pager span{
  font-family:var(--font-mono); font-size:13px; font-weight:600;
  padding:8px 14px; border-radius:8px; text-decoration:none; border:1px solid var(--line);
  color:var(--accent);
}
.pager a:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }
.pager .disabled{ color:var(--soft); opacity:.5; }
.pager .current{ background:var(--accent); color:#fff; border-color:var(--accent); }
/* Laravel default paginator markup fallback */
.pager nav{ display:flex; gap:10px; align-items:center; flex-wrap:wrap; justify-content:center; }
.pager svg{ width:18px; height:18px; }

/* ---------- footer ---------- */
footer.site{
  padding:42px 0 90px; margin-top:30px; border-top:2px solid var(--ink);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; align-items:center;
}
footer.site nav a{
  text-decoration:none; color:var(--soft); font-size:13px; font-weight:600;
  margin-right:16px; text-transform:uppercase; letter-spacing:.05em;
}
footer.site nav a:hover{ color:var(--accent); }
footer.site .cr{ font-family:var(--font-mono); font-size:12px; color:var(--soft); }

/* ---------- responsive ---------- */
@media (max-width:720px){
  body{ font-size:16px; }
  .lead{ grid-template-columns:1fr; }
  .lead .ph-img{ order:-1; }
  .lead .ph-img img, .lead .ph-img .ph{ min-height:200px; }
  .lead .txt{ padding:28px 24px; }
  .lead h1{ font-size:28px; }
  .post-head h1{ font-size:28px; }
  .list article{ grid-template-columns:88px 1fr; gap:14px; }
  .list .when{ display:none; }
  .list .thumb, .list .ph{ width:88px; }
  .post-body, .prose{ font-size:17px; }
}
