/* Token aliases onto the site design system (styles.css). */
:root{--ink-soft:var(--ink-2);--white:var(--surface);--bone:var(--surface-2);--font:var(--sans);--mist:#E4DBCB;--page:var(--paper)}

/* =========================================================================
   Kaught, Field Notes (articles)
   Extends styles.css. Clean single-accent register only (Catch Coral).
   Rarity is shown by FILLED-DIAMOND COUNT in coral, never the app's
   blue/purple/gold rarity palette, page chrome stays single-accent.
   ========================================================================= */

/* ------------------------------ hub ------------------------------------ */
.hub{padding:clamp(40px,6vw,72px) 0 clamp(64px,9vw,112px)}
.hub-head{max-width:60ch;margin:0 auto clamp(36px,5vw,56px);text-align:center}
.hub-head h1{font-size:clamp(34px,5vw,54px);margin-bottom:16px}
.hub-head .lede{margin:0 auto;font-size:clamp(14.5px,1.35vw,16.5px)}

/* search field notes */
.hub-search{position:relative;display:flex;align-items:center;max-width:440px;margin:0 auto clamp(30px,4.5vw,46px)}
.hub-search-icon{position:absolute;left:16px;width:19px;height:19px;color:var(--muted-2);pointer-events:none}
.hub-search input{
  width:100%;font:inherit;font-size:15.5px;padding:13px 16px 13px 44px;
  border-radius:14px;border:1px solid var(--line);background:var(--white);color:var(--ink);
  box-shadow:var(--sh-sm);transition:border-color .15s ease,box-shadow .15s ease;
}
.hub-search input::placeholder{color:var(--muted-2)}
.hub-search input:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px rgba(255,122,82,.16)}

.hub-card[hidden]{display:none}
.hub-empty{text-align:center;color:var(--muted);font-size:15.5px;margin:clamp(26px,4vw,40px) 0 0}

.hub-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:20px;
}
.hub-card{
  display:flex;flex-direction:column;background:var(--white);
  border:1px solid var(--line-2);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--sh-sm);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;
}
.hub-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:var(--coral)}
.hub-card .thumb{
  aspect-ratio:16/10;display:grid;place-items:center;font-size:54px;
  background:radial-gradient(120% 120% at 30% 10%,var(--cream),#EADBC6);
  border-bottom:1px solid var(--line-2);
}
.hub-card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.hub-card .body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.hub-card .kicker{font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-deep)}
.hub-card h2{font-size:21px;line-height:1.22;letter-spacing:-.02em}
.hub-card p{font-size:14.5px;color:var(--muted);line-height:1.5}
.hub-card .more{margin-top:auto;font-size:14.5px;font-weight:600;color:var(--coral-deep);display:inline-flex;align-items:center;gap:7px}
.hub-card .more svg{width:16px;height:16px}

/* ---------------------------- article ---------------------------------- */
.article{padding:clamp(28px,4vw,44px) 0 clamp(56px,8vw,96px)}
.article-wrap{max-width:740px;margin:0 auto}

.crumbs{font-size:13.5px;color:var(--muted);margin-bottom:26px;display:flex;gap:8px;align-items:center}
.crumbs a{color:var(--muted);font-weight:500}
.crumbs a:hover{color:var(--coral-deep)}
.crumbs span{opacity:.5}

.article-hero{margin-bottom:30px}
.article-hero .eyebrow{margin-bottom:14px}
.article-hero h1{font-size:clamp(31px,4.6vw,46px);line-height:1.08;margin-bottom:18px}
.byline{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--muted)}
.byline .av{
  width:38px;height:38px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:var(--cream);color:var(--coral-deep);font-family:var(--round);font-weight:800;font-size:15px;
}
.byline b{color:var(--ink-soft);font-weight:600}
.byline .dotsep{opacity:.45}

/* lead figure: real CC-licensed species photo + visible credit (emoji fallback = .is-emoji) */
.lead-fig{margin:28px 0 10px}
.lead-fig img{
  width:100%;aspect-ratio:16/9;object-fit:cover;display:block;
  border-radius:var(--radius);border:1px solid var(--line-2);box-shadow:var(--sh-sm);
}
.lead-credit{font-size:11px;color:var(--muted-2);margin-top:8px;text-align:right;letter-spacing:.01em}
.lead-credit a{color:var(--muted);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:2px}
.lead-fig.is-emoji{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line-2);
  aspect-ratio:16/9;display:grid;place-items:center;font-size:clamp(64px,12vw,108px);
  background:radial-gradient(130% 130% at 28% 8%,#FFF4EC 0%,var(--cream) 46%,#E7D6BF 100%);
  box-shadow:var(--sh-sm);
}

/* TL;DR, the extractable answer block (GEO) */
.tldr{
  background:var(--coral-soft);border:1px solid rgba(233,84,47,.16);
  border-left:4px solid var(--coral);border-radius:14px;
  padding:20px 22px;margin:30px 0;
}
.tldr .lab{font-size:11.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--coral-deep);margin-bottom:8px}
.tldr p{font-size:16.5px;line-height:1.58;color:var(--ink-soft)}

/* The Kaught catalog card, the proprietary stat block (NOT a "Dex") */
.catalog-card{
  background:var(--white);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--sh-md);padding:22px 24px;margin:30px 0;
}
.cc-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line-2)}
.cc-name{font-family:var(--round);font-weight:800;font-size:20px;letter-spacing:-.02em}
.cc-name i{display:block;font-family:var(--font);font-style:italic;font-weight:500;font-size:14px;color:var(--muted);margin-top:2px}
.cc-no{font-family:var(--mono);font-size:12.5px;color:var(--muted);white-space:nowrap;letter-spacing:.02em}
.cc-rows{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 22px}
.cc-row{display:flex;flex-direction:column;gap:3px}
.cc-row .k{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.cc-row .v{font-size:15px;font-weight:600;color:var(--ink-soft)}
.cc-row .v.lineage{font-size:13.5px;font-weight:500}
.cc-chips{display:flex;gap:7px;flex-wrap:wrap}
.type-chip{font-size:12.5px;font-weight:600;padding:4px 11px;border-radius:999px;
  background:var(--cream);color:var(--ink-soft);border:1px solid var(--line-2)}
.type-chip.sec{background:transparent;color:var(--coral-deep);border-color:rgba(233,84,47,.3)}
.diamonds{font-size:15px;letter-spacing:2px;color:var(--coral)}
.diamonds .off{color:var(--mist)}
.diamonds em{font-style:normal;font-size:14px;font-weight:600;color:var(--ink-soft);margin-left:8px;letter-spacing:0}
.cc-src{margin-top:14px;padding-top:13px;border-top:1px solid var(--line-2);font-size:12px;color:var(--muted-2)}
.cc-src b{color:var(--muted);font-weight:600}

/* prose */
.prose{font-size:17px;line-height:1.7;color:var(--ink-soft)}
.prose > h2{font-size:clamp(23px,3vw,30px);line-height:1.18;letter-spacing:-.02em;margin:42px 0 14px;color:var(--ink)}
.prose > h3{font-size:20px;margin:28px 0 10px;color:var(--ink)}
.prose p{margin:0 0 18px}
.prose a{color:var(--coral-deep);font-weight:600;text-decoration:underline;text-decoration-color:rgba(233,84,47,.3);text-underline-offset:2px}
.prose a:hover{text-decoration-color:var(--coral-deep)}
.prose strong{color:var(--ink);font-weight:680}
.prose ul,.prose ol{margin:0 0 18px;padding-left:0;list-style:none;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:28px}
.prose ul li::before{content:"";position:absolute;left:4px;top:10px;width:7px;height:7px;border-radius:2px;background:var(--coral);transform:rotate(45deg)}
.prose ol{counter-reset:li;padding-left:0}
.prose ol li{position:relative;padding-left:34px;counter-increment:li}
.prose ol li::before{content:counter(li);position:absolute;left:0;top:1px;width:24px;height:24px;border-radius:7px;
  background:var(--coral-soft);color:var(--coral-deep);font-family:var(--round);font-weight:800;font-size:13px;display:grid;place-items:center}

/* a compact catalog line for listicles */
.minicard{display:flex;align-items:center;gap:14px;background:var(--white);border:1px solid var(--line-2);
  border-radius:14px;padding:13px 16px;margin:0 0 16px;box-shadow:var(--sh-sm);font-size:14px}
.minicard .em{width:44px;height:44px;border-radius:12px;background:var(--cream);display:grid;place-items:center;font-size:24px;flex:none}
.minicard .mc-body{display:flex;flex-direction:column;gap:2px}
.minicard .mc-body b{font-size:15.5px}
.minicard .mc-meta{color:var(--muted);font-size:12.5px}
.minicard .diamonds{font-size:13px;margin-left:auto;flex:none}

/* pull tip */
.tip{background:var(--bone);border:1px solid var(--line-2);border-radius:14px;padding:16px 18px;margin:24px 0;font-size:15px;color:var(--ink-soft)}
.tip b{color:var(--coral-deep)}

/* FAQ on article */
.article-faq{margin:40px 0 0}
.article-faq h2{font-size:clamp(23px,3vw,30px);margin-bottom:18px}
.article-faq details{background:var(--white);border:1px solid var(--line-2);border-radius:14px;box-shadow:var(--sh-sm);overflow:hidden;margin-bottom:10px}
.article-faq summary{list-style:none;cursor:pointer;padding:18px 20px;font-size:16.5px;font-weight:600;display:flex;justify-content:space-between;gap:14px;align-items:center}
.article-faq summary::-webkit-details-marker{display:none}
.article-faq summary .chev{flex:none;width:20px;height:20px;color:var(--coral-deep);transition:transform .22s ease}
.article-faq details[open] summary .chev{transform:rotate(45deg)}
.article-faq .ans{padding:0 20px 20px;color:var(--muted);font-size:15.5px;line-height:1.62}

/* article CTA */
.article-cta{margin:48px 0 0;background:linear-gradient(165deg,var(--coral),#F2683E 55%,var(--coral-deep));
  border-radius:var(--radius-lg);padding:clamp(34px,5vw,52px);text-align:center;position:relative;overflow:hidden;box-shadow:var(--sh-lg)}
.article-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 50% -10%,rgba(255,255,255,.28),transparent 60%)}
.article-cta>*{position:relative;z-index:1}
.article-cta .eyebrow{color:rgba(255,255,255,.85)}
.article-cta h2{color:#fff;font-size:clamp(24px,3.4vw,34px);margin-bottom:12px;line-height:1.1}
.article-cta p{color:rgba(255,255,255,.92);max-width:42ch;margin:0 auto 24px;font-size:16px}

/* sources/footnote on articles */
.endnote{margin-top:40px;padding-top:22px;border-top:1px solid var(--line-2);font-size:13px;color:var(--muted-2);line-height:1.6}

@media(max-width:560px){
  .cc-rows{grid-template-columns:1fr}
  .prose{font-size:16.5px}
}
