/* Repro Files — adapted from the oppofiles Wiki.js theme
   Palette: cream bg, navy + teal, coral accent. PT Serif headings / Josefin Sans body. */
:root {
  --cream:      #fff0e1;
  --cream-lt:   #fff7f0;
  --navy:       #0b1640;
  --navy2:      #1e4d7f;
  --coral:      #e06656;
  --teal:       #509ab6;
  --tan:        #e8dcd0;
  --rule:       #b8c3c9;
  --ink:        #58595b;
  --sans: 'Josefin Sans', system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --serif: 'PT Serif', Georgia, serif;
}
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
}
::selection { background: #82e2f7; color: var(--navy); }
a { color: var(--navy2); font-weight: 600; text-decoration: none;
    border-bottom: 1px solid transparent; transition: color .2s ease, border-color .2s ease; }
a:hover { color: var(--teal); border-bottom-color: var(--teal); }

.wrap { width: 90%; max-width: 1040px; margin: 0 auto; padding: 0 4%; }

/* ---- top bar / breadcrumbs ---- */
.crumbs { width: 90%; max-width: 1040px; margin: 0 auto; padding: 18px 4% 0; font-size: .85rem;
          letter-spacing: .04em; text-transform: uppercase; }
.crumbs a { color: var(--navy2); }

/* ---- hero ---- */
.hero { width: 90%; max-width: 1040px; margin: 28px auto 8px; padding: 0 4%; }
.hero h1 {
  font-family: var(--serif); font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  text-align: center; color: var(--cream-lt);
  background: linear-gradient(135deg, var(--navy) 0, var(--navy2) 100%);
  padding: 26px 24px; margin: 0; border-radius: 8px;
  box-shadow: 0 6px 18px rgba(11,22,64,.18); font-size: 2.1rem;
}
.tagline { text-align: center; color: var(--ink); margin: 16px auto 0; max-width: 60ch; font-size: 1.05rem; }
.tagline .accent { color: var(--coral); font-weight: 700; }

/* ---- prominent archive callout card on the index ---- */
.callout {
  display: block; width: 90%; max-width: 1040px; margin: 22px auto 0; padding: 18px 22px;
  border-radius: 8px; text-align: center; text-decoration: none; border: none;
  background: linear-gradient(135deg, var(--coral) 0, #c94e3f 100%);
  color: var(--cream-lt); box-shadow: 0 4px 12px rgba(224,102,86,.25);
  transition: transform .2s ease, box-shadow .2s ease;
}
.callout:hover { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(224,102,86,.35);
                 color: var(--cream-lt); border: none; }
.callout strong { font-family: var(--serif); text-transform: uppercase; letter-spacing: .04em; font-size: 1.15rem; }
.callout span { display: block; opacity: .92; font-size: .92rem; margin-top: 2px; }

main { width: 90%; max-width: 1040px; margin: 0 auto; padding: 8px 4% 48px; }

/* ---- landing page ---- */
.landing-body { display: flex; flex-direction: column; min-height: 100vh; }
.landing { flex: 1; width: 90%; max-width: 760px; margin: 0 auto; padding: 40px 4% 24px;
           text-align: center; display: flex; flex-direction: column; align-items: center; }
.hero-wrap { position: relative; width: 100%; padding: 22px 0 18px; }
.hero-wrap::before {
  content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(rgba(11,22,64,.10) 1px, transparent 1.4px);
  background-size: 24px 24px;
  -webkit-mask-image: radial-gradient(ellipse 72% 82% at 50% 44%, #000 28%, transparent 78%);
          mask-image: radial-gradient(ellipse 72% 82% at 50% 44%, #000 28%, transparent 78%);
}
.hero-wrap > * { position: relative; z-index: 1; }
.landing .logo { width: 188px; height: auto; margin: 0 auto 6px; display: block; }
.hero-band {
  width: 100%; background: transparent; padding: 2px 24px 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
}
.hero-band h1 {
  font-family: var(--serif); font-weight: 700; text-transform: uppercase; letter-spacing: .03em;
  font-size: clamp(2.9rem, 9vw, 4.9rem); line-height: 1.02; margin: 0; color: var(--navy);
  -webkit-text-stroke: 0.5px var(--navy);
}
.hero-sub { font-family: var(--sans); color: var(--navy2); font-weight: 700; margin: 12px 0 0;
            font-size: 1.05rem; letter-spacing: .03em; }
.accent-rule { width: 60px; height: 3px; margin: 16px auto 2px; border-radius: 2px;
               background: linear-gradient(90deg, var(--coral), var(--teal)); }
.lead { color: var(--ink); font-size: 1.06rem; line-height: 1.7; margin: 18px auto 0; max-width: 62ch; }

/* gentle one-time entrance (no perpetual motion) */
@media (prefers-reduced-motion: no-preference) {
  .landing .logo, .hero-band h1, .hero-sub, .accent-rule, .lead, .cta-btn, .stats {
    opacity: 0; animation: rise .7s cubic-bezier(.2,.7,.2,1) forwards;
  }
  .hero-band h1 { animation-delay: .05s; }
  .hero-sub { animation-delay: .12s; }
  .accent-rule { animation-delay: .18s; }
  .lead { animation-delay: .24s; }
  .cta-btn { animation-delay: .32s; }
  .stats { animation-delay: .40s; }
}
@keyframes rise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.lead strong { color: var(--navy2); }
.cta-btn {
  display: inline-block; margin: 28px 0 6px; padding: 14px 30px; border: none; border-radius: 8px;
  font-family: var(--sans); font-weight: 700; font-size: 1.1rem; letter-spacing: .03em;
  color: var(--cream-lt); background: linear-gradient(135deg, var(--coral) 0, #c94e3f 100%);
  box-shadow: 0 4px 14px rgba(224,102,86,.3); transition: transform .2s ease, box-shadow .2s ease;
}
.cta-btn:hover { color: var(--cream-lt); border: none; transform: translateY(-2px);
                 box-shadow: 0 8px 22px rgba(224,102,86,.42); }
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 34px 0 0; width: 100%; }
.stat { background: linear-gradient(135deg, var(--navy) 0, var(--navy2) 100%); border-radius: 8px;
        padding: 18px 10px; box-shadow: 0 3px 10px rgba(11,22,64,.18); }
.stat strong { display: block; font-family: var(--serif); font-size: 1.9rem; color: var(--cream-lt); }
.stat span { font-size: .8rem; text-transform: uppercase; letter-spacing: .06em; color: #cfe0e8; }
@media (max-width: 520px) { .hero-band h1 { font-size: 1.9rem; } .stat strong { font-size: 1.4rem; } }

/* ---- source tags ---- */
.src { display: inline-block; font-size: .62rem; font-weight: 700; text-transform: uppercase;
       letter-spacing: .06em; padding: 2px 7px; border-radius: 10px; margin-left: 8px;
       vertical-align: middle; color: var(--cream-lt); white-space: nowrap; }
.tag-rb { background: var(--teal); }
.tag-tr { background: var(--navy2); }
.tag-ar { background: var(--coral); }

/* ---- source section (index) ---- */
.source { margin-top: 30px; }
.source > h2 {
  font-family: var(--serif); font-weight: 700; font-size: 1.3rem; color: var(--cream-lt);
  background: var(--coral); padding: 9px 16px; margin: 26px 0 14px; border-radius: 6px;
  box-shadow: 0 2px 8px rgba(224,102,86,.18);
}
.source > h2 a { color: var(--cream-lt); border: none; }
.source > h2 a:hover { color: #fff; border: none; }

/* ---- collapsible candidate groups ---- */
details.grp { margin: 0 0 10px; }
details.grp > summary {
  list-style: none; cursor: pointer; font-family: var(--serif); font-weight: 700;
  font-size: 1.08rem; text-transform: uppercase; letter-spacing: .03em; color: var(--navy2);
  padding: 8px 0 8px 22px; border-bottom: 2px solid var(--coral); position: relative;
  user-select: none;
}
details.grp > summary::-webkit-details-marker { display: none; }
details.grp > summary::before {
  content: '\25B8'; position: absolute; left: 2px; color: var(--coral);
  transition: transform .2s ease; display: inline-block;
}
details.grp[open] > summary::before { transform: rotate(90deg); }
details.grp > summary:hover { color: var(--teal); }

/* ---- card link lists (with shimmer sweep) ---- */
.links-list { list-style: none; padding: 0; margin: 12px 0 18px; }
.links-list li {
  background: #fff; border: 2px solid var(--teal); border-radius: 6px;
  box-shadow: 0 2px 6px rgba(11,22,64,.10); padding: .85rem 1rem; margin-bottom: 10px;
  position: relative; overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}
.links-list li::before {
  content: ''; position: absolute; top: 0; left: -100%; width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(80,154,182,.35), rgba(255,255,255,.6), rgba(80,154,182,.35), transparent);
  transform: skewX(-20deg); transition: left .6s ease; pointer-events: none; z-index: 1;
}
.links-list li:hover::before { left: 150%; }
.links-list li:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(80,154,182,.32); }
.links-list li a { display: block; color: var(--navy); font-weight: 700; border: none;
                   position: relative; z-index: 2; }
.links-list li a:hover { color: var(--navy); border: none; }

/* ---- archive index controls ---- */
.controls { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin: 18px 0 6px; }
.controls input[type=search] {
  flex: 1 1 240px; font-family: var(--sans); font-size: 1rem; padding: 10px 14px;
  border: 2px solid var(--teal); border-radius: 6px; background: #fff; color: var(--ink);
}
.controls input[type=search]:focus { outline: none; border-color: var(--navy2); }
.controls button {
  font-family: var(--sans); font-weight: 700; letter-spacing: .03em; cursor: pointer;
  background: var(--teal); color: var(--cream-lt); border: none; border-radius: 6px;
  padding: 10px 14px; transition: background .2s ease;
}
.controls button:hover { background: var(--navy2); }
.count-note { color: var(--ink); font-size: .9rem; margin: 4px 0 0; }
details.grp.hidden { display: none; }

/* ============ archive article pages (rendered wiki content) ============ */
.contents {
  width: 90%; max-width: 1040px; margin: 8px auto 0; padding: 8px 4% 16px;
  font-family: var(--sans); color: var(--ink); line-height: 1.6;
}
.contents h1 {
  font-family: var(--serif); font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
  text-align: center; color: var(--cream-lt);
  background: linear-gradient(135deg, var(--navy) 0, var(--navy2) 100%);
  padding: 16px 24px; margin: 28px 0 22px; border-radius: 6px; font-size: 1.9rem;
  box-shadow: 0 4px 12px rgba(11,22,64,.15);
}
.contents h2 {
  font-family: var(--serif); font-weight: 700; font-size: 1.3rem; color: var(--cream-lt);
  background: var(--coral); padding: 8px 16px; margin: 22px 0 14px; border-radius: 5px;
  box-shadow: 0 2px 8px rgba(224,102,86,.15); cursor: pointer; position: relative;
}
.contents h2.collapsed { opacity: .85; }
.contents h2.sectionable::after {
  content: '\25BE'; position: absolute; right: 16px; transition: transform .2s ease;
}
.contents h2.sectionable.collapsed::after { transform: rotate(-90deg); }
.contents h3 {
  font-family: var(--serif); font-weight: 700; font-size: 1.2rem; text-transform: uppercase;
  letter-spacing: .03em; color: var(--navy2); padding: 8px 0; margin: 22px 0 12px;
  border-bottom: 2px solid var(--coral);
}
.contents h4 { font-family: var(--sans); font-weight: 700; font-size: 1.05rem; color: var(--ink);
               padding: 6px 0; margin: 18px 0 10px; border-bottom: 1px solid var(--rule); }
.contents h5, .contents h6 { font-family: var(--sans); font-weight: 700; margin: 14px 0 8px; }
.contents p { margin: 0 0 12px; }
.contents ul, .contents ol { padding-left: 24px; }
.contents li { margin-bottom: 6px; }
.contents ul > li::marker { color: var(--teal); }
.contents img { max-width: 100%; height: auto; display: block; margin: 14px auto; border-radius: 4px; }
.contents figure { margin: 14px 0; }
.contents blockquote { border: 2px solid var(--coral); background: transparent; padding: 12px 20px;
                       margin: 16px 0; border-radius: 6px; color: var(--ink); }
.contents code { background: var(--tan); color: var(--navy); padding: 2px 6px; border-radius: 4px; font-size: .9em; }
.contents pre { background: var(--navy); color: var(--cream-lt); padding: 16px 20px; border-radius: 6px; overflow-x: auto; }
.contents pre code { background: transparent; color: inherit; padding: 0; }
.contents table { width: 100%; border-collapse: collapse; margin: 20px 0; }
.contents th { background: var(--navy); color: var(--cream-lt); padding: 12px 16px; text-align: left; border: 1px solid var(--navy2); }
.contents td { padding: 10px 16px; border: 1px solid var(--rule); vertical-align: top; }
.contents tr:nth-child(2n) { background: var(--tan); }
.contents tr:hover { background: rgba(80,154,182,.1); }
.contents hr { border: none; height: 3px; background: linear-gradient(90deg, var(--coral), var(--teal));
               margin: 30px 0; border-radius: 2px; }
.contents a { word-break: break-word; }

/* ---- footer ---- */
footer { width: 90%; max-width: 1040px; margin: 0 auto; padding: 18px 4% 52px;
         border-top: 2px solid var(--rule); color: var(--ink); font-size: .85rem; }
footer a { color: var(--navy2); }

@media (max-width: 520px) {
  .hero h1 { font-size: 1.55rem; padding: 18px 14px; }
  .contents h1 { font-size: 1.45rem; }
}
