/* ════════════════════════════════════════════════════════════════
   Godsibb.net — site stylesheet (ported from the v11 design mock).
   GREY base (light + dark). Brand colour woven through accents + a
   muted per-theme background pattern. Calm at rest, alive on hover.
   ════════════════════════════════════════════════════════════════ */

/* Gecko Lunch = Godsibb display voice (local). Alpha only — no digits/punctuation. */
@font-face{font-family:"Gecko Lunch";src:url("/static/fonts/Gecko Lunch.ttf") format("truetype");font-display:swap}

:root{
  --canvas:#E8E9EC;--surface:#FFFFFF;--surface-2:#F2F3F6;
  --ink:#1C1E22;--ink-soft:#5E626B;--hairline:#D8DAE0;
  --shadow-sm:0 1px 2px rgba(20,22,28,.06),0 2px 6px rgba(20,22,28,.05);
  --shadow-md:0 6px 16px rgba(20,22,28,.10),0 2px 4px rgba(20,22,28,.06);
  --shadow-lg:0 16px 40px rgba(20,22,28,.16),0 4px 10px rgba(20,22,28,.08);
  --r-sm:8px;--r-md:14px;--r-lg:20px;--r-pill:999px;
  --pat-opacity:.10;
  /* per-theme accent + 3-stop brand gradient */
  --accent:#9B15DE;--accent-ink:#7A0FB0;--g1:#9B15DE;--g2:#FA6C8D;--g3:#E45735;
  --accent-wash:#F1E6FA;--glow:#9B15DE;
  --pattern-light:#C4B5FD;--pattern-mid:#06B6D4;--pattern-dark:#A78BFA;  /* original Melia */
}
[data-theme="kosmos"]{--accent:#2F6BE0;--accent-ink:#1E4FB3;--accent-wash:#EBEDF3;
  --g1:#2F6BE0;--g2:#E8A33D;--g3:#D6453B;--glow:#3B6FD6}  /* KOS-MOS: blue→gold→red */
[data-theme="pyra"]  {--accent:#E0473C;--accent-ink:#B62E25;--accent-wash:#FBE7E5;
  --g1:#D6453B;--g2:#F97316;--g3:#13BD9A;--glow:#E0473C;  /* green tail splash */
  --pattern-light:#FCD34D;--pattern-mid:#F97316;--pattern-dark:#DC2626}
[data-theme="mythra"]{--accent:#C9921A;--accent-ink:#9C700B;--accent-wash:#F8F0DA;
  --g1:#E0A92E;--g2:#FFE14D;--g3:#10B981;--glow:#E0A92E;  /* gold→yellow→emerald */
  --pattern-light:#FCD34D;--pattern-mid:#06B6D4;--pattern-dark:#10B981}
[data-theme="elly"]  {--accent:#E8743B;--accent-ink:#C2531D;--accent-wash:#FBEAE0;
  --g1:#E8743B;--g2:#FA6C8D;--g3:#9B15DE;--glow:#E8743B;
  --pattern-light:#FDBA74;--pattern-mid:#EC4899;--pattern-dark:#F97316}
[data-theme="elma"]  {--accent:#DD3A4D;--accent-ink:#B32637;--accent-wash:#FBE6E9;
  --g1:#DD3A4D;--g2:#9B6CC9;--g3:#2FB6C2;--glow:#DD3A4D}  /* scarlet→lavender→teal */

html.dark{
  --canvas:#141519;--surface:#1D1F24;--surface-2:#24272D;
  --ink:#EAEBEE;--ink-soft:#969BA4;--hairline:#2C2F36;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);--shadow-md:0 6px 16px rgba(0,0,0,.5);
  --shadow-lg:0 16px 40px rgba(0,0,0,.6);--accent-wash:#241B30;--pat-opacity:.15;
}
html.dark[data-theme="kosmos"]{--accent-wash:#15233A}
html.dark[data-theme="pyra"]  {--accent-wash:#2C1A18}
html.dark[data-theme="mythra"]{--accent-wash:#2A2412}
html.dark[data-theme="elly"]  {--accent-wash:#2C1E16}
html.dark[data-theme="elma"]  {--accent-wash:#2E1A1F}

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Inter,system-ui,sans-serif;background:var(--canvas);color:var(--ink);
  line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  transition:background .4s ease,color .4s ease}
a{color:inherit;text-decoration:none}

/* big SWEEPING ambient glow from the corners, layered UNDER pattern + content */
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(70% 60% at 108% -8%,var(--glow),transparent 60%),
    radial-gradient(60% 55% at -10% 112%,var(--g2),transparent 62%);
  opacity:.12;transition:background .4s,opacity .4s}
html.dark body::after{opacity:.20}
/* MUTED per-theme background pattern — texture, not noise */
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  opacity:var(--pat-opacity);transition:opacity .4s,background .4s}
/* Melia: big concentric 3-colour waves sweeping from the corners */
[data-theme="melia"]  body::before{background:
  radial-gradient(ellipse 300% 80% at -50% 30%,transparent 0%,transparent 15%,
    var(--pattern-light) 15%,var(--pattern-light) 18%,var(--pattern-mid) 18%,var(--pattern-mid) 21%,
    var(--pattern-dark) 21%,var(--pattern-dark) 24%,var(--pattern-light) 24%,var(--pattern-light) 27%,
    var(--pattern-mid) 27%,var(--pattern-mid) 30%,var(--pattern-dark) 30%,var(--pattern-dark) 33%,
    var(--pattern-light) 33%,var(--pattern-light) 36%,var(--pattern-mid) 36%,var(--pattern-mid) 39%,
    var(--pattern-dark) 39%,var(--pattern-dark) 42%,var(--pattern-light) 42%,var(--pattern-light) 45%,
    var(--pattern-mid) 45%,var(--pattern-mid) 48%,var(--pattern-dark) 48%,var(--pattern-dark) 51%,transparent 51%),
  radial-gradient(ellipse 300% 80% at 150% 70%,transparent 0%,transparent 15%,
    var(--pattern-dark) 15%,var(--pattern-dark) 18%,var(--pattern-mid) 18%,var(--pattern-mid) 21%,
    var(--pattern-light) 21%,var(--pattern-light) 24%,var(--pattern-dark) 24%,var(--pattern-dark) 27%,
    var(--pattern-mid) 27%,var(--pattern-mid) 30%,var(--pattern-light) 30%,var(--pattern-light) 33%,
    var(--pattern-dark) 33%,var(--pattern-dark) 36%,var(--pattern-mid) 36%,var(--pattern-mid) 39%,
    var(--pattern-light) 39%,var(--pattern-light) 42%,var(--pattern-dark) 42%,var(--pattern-dark) 45%,
    var(--pattern-mid) 45%,var(--pattern-mid) 48%,var(--pattern-light) 48%,var(--pattern-light) 51%,transparent 51%),
  radial-gradient(ellipse 250% 90% at 50% 50%,transparent 0%,transparent 20%,
    var(--pattern-mid) 20%,var(--pattern-mid) 23%,var(--pattern-light) 23%,var(--pattern-light) 26%,
    var(--pattern-dark) 26%,var(--pattern-dark) 29%,var(--pattern-mid) 29%,var(--pattern-mid) 32%,
    var(--pattern-light) 32%,var(--pattern-light) 35%,var(--pattern-dark) 35%,var(--pattern-dark) 38%,
    var(--pattern-mid) 38%,var(--pattern-mid) 41%,var(--pattern-light) 41%,var(--pattern-light) 44%,transparent 44%)}
/* Pyra: fish-scale flame pattern (green scales interleaved) */
[data-theme="pyra"]   body::before{
  background:
    radial-gradient(calc(1.28 * 32px + 8px/2) at top 50% right calc(-.8*32px),var(--pattern-dark) calc(99.5% - 8px),var(--canvas) calc(101% - 8px) 99.5%,#0000 101%) calc(-1*calc(1.8 * 32px + 8px)) 32px,
    radial-gradient(calc(1.28 * 32px + 8px/2) at top 50% left calc(-.8*32px),#34D399 calc(99.5% - 8px),var(--canvas) calc(101% - 8px) 99.5%,#0000 101%) calc(1.8 * 32px + 8px) calc(-1*32px),
    radial-gradient(calc(1.28 * 32px + 8px/2) at top 50% right calc(-.8*32px),#34D399 calc(99.5% - 8px),var(--canvas) calc(101% - 8px) 99.5%,#0000 101%) calc(calc(1.8 * 32px + 8px)/-2) calc(-1*32px),
    radial-gradient(calc(1.28 * 32px + 8px/2) at top 50% left calc(-.8*32px),var(--pattern-dark) calc(99.5% - 8px),var(--canvas) calc(101% - 8px) 99.5%,#0000 101%) calc(calc(1.8 * 32px + 8px)/ 2) 32px,
    linear-gradient(90deg,var(--pattern-dark) 50%,var(--pattern-light) 0);
  background-size:calc(1.8 * 32px + 8px) 128px}
/* Mythra: scattered polka dots + a few larger green splashes */
[data-theme="mythra"] body::before{background:
  radial-gradient(circle at 22% 30%,#10B981 30px,transparent 32px),
  radial-gradient(circle at 84% 50%,#10B981 40px,transparent 42px),
  radial-gradient(circle at 52% 88%,#10B981 24px,transparent 26px),
  radial-gradient(circle at 5% 15%,var(--pattern-light) 8px,transparent 8px),
  radial-gradient(circle at 25% 45%,var(--pattern-light) 12px,transparent 12px),
  radial-gradient(circle at 45% 8%,var(--pattern-light) 6px,transparent 6px),
  radial-gradient(circle at 65% 75%,var(--pattern-light) 10px,transparent 10px),
  radial-gradient(circle at 85% 35%,var(--pattern-light) 14px,transparent 14px),
  radial-gradient(circle at 15% 85%,var(--pattern-light) 9px,transparent 9px),
  radial-gradient(circle at 55% 55%,var(--pattern-light) 7px,transparent 7px),
  radial-gradient(circle at 95% 90%,var(--pattern-light) 11px,transparent 11px),
  radial-gradient(circle at 35% 25%,var(--pattern-light) 8px,transparent 8px),
  radial-gradient(circle at 75% 5%,var(--pattern-light) 13px,transparent 13px),
  radial-gradient(circle at 10% 40%,var(--pattern-mid) 10px,transparent 10px),
  radial-gradient(circle at 30% 70%,var(--pattern-mid) 7px,transparent 7px),
  radial-gradient(circle at 50% 30%,var(--pattern-mid) 11px,transparent 11px),
  radial-gradient(circle at 70% 95%,var(--pattern-mid) 9px,transparent 9px),
  radial-gradient(circle at 90% 60%,var(--pattern-mid) 6px,transparent 6px),
  radial-gradient(circle at 20% 10%,var(--pattern-mid) 12px,transparent 12px),
  radial-gradient(circle at 60% 85%,var(--pattern-mid) 8px,transparent 8px),
  radial-gradient(circle at 80% 20%,var(--pattern-mid) 10px,transparent 10px),
  radial-gradient(circle at 40% 50%,var(--pattern-mid) 14px,transparent 14px),
  radial-gradient(circle at 3% 65%,var(--pattern-mid) 7px,transparent 7px),
  radial-gradient(circle at 8% 55%,var(--pattern-dark) 9px,transparent 9px),
  radial-gradient(circle at 28% 20%,var(--pattern-dark) 11px,transparent 11px),
  radial-gradient(circle at 48% 80%,var(--pattern-dark) 8px,transparent 8px),
  radial-gradient(circle at 68% 45%,var(--pattern-dark) 13px,transparent 13px),
  radial-gradient(circle at 88% 10%,var(--pattern-dark) 7px,transparent 7px),
  radial-gradient(circle at 18% 95%,var(--pattern-dark) 10px,transparent 10px),
  radial-gradient(circle at 38% 60%,var(--pattern-dark) 6px,transparent 6px),
  radial-gradient(circle at 58% 15%,var(--pattern-dark) 12px,transparent 12px),
  radial-gradient(circle at 78% 70%,var(--pattern-dark) 9px,transparent 9px),
  radial-gradient(circle at 98% 40%,var(--pattern-dark) 8px,transparent 8px)}
/* Elly: pinwheel */
[data-theme="elly"]   body::before{
  background:
    radial-gradient(var(--pattern-mid) 24%,#0000 25%),
    repeating-conic-gradient(from 30deg,transparent 0 30deg,var(--pattern-light) 0 90deg);
  background-size:32px 32px}
/* Elma: large triangular sci-fi lattice */
[data-theme="elma"]   body::before{background:
  repeating-linear-gradient(0deg,var(--accent) 0 2px,transparent 2px 104px),
  repeating-linear-gradient(60deg,var(--accent) 0 2px,transparent 2px 104px),
  repeating-linear-gradient(120deg,var(--accent) 0 2px,transparent 2px 104px)}
/* KOS-MOS: seamless circuit rendered LARGE (300px tile) */
[data-theme="kosmos"] body::before{opacity:calc(var(--pat-opacity) * 1.9);
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'%3E%3Cg fill='none' stroke='%232F6BE0' stroke-width='2'%3E%3Cpath d='M0 72H120'/%3E%3Cpath d='M60 0V120'/%3E%3Cpath d='M60 30H94V72'/%3E%3Cpath d='M26 72V104'/%3E%3Cpath d='M60 96H32'/%3E%3C/g%3E%3Cg fill='%23E8A33D'%3E%3Ccircle cx='60' cy='72' r='5'/%3E%3Ccircle cx='94' cy='30' r='5'/%3E%3Ccircle cx='26' cy='104' r='5'/%3E%3Ccircle cx='32' cy='96' r='4'/%3E%3C/g%3E%3Cg fill='%23D6453B'%3E%3Crect x='90' y='46' width='8' height='10' rx='1'/%3E%3Crect x='54' y='12' width='12' height='7' rx='1'/%3E%3C/g%3E%3C/svg%3E") 0 0/300px 300px}

/* display helpers — generous room so Gecko's bouncy italic never clips */
.display{font-family:"Gecko Lunch",cursive;font-style:italic;font-weight:400;line-height:1.12}
.grad{display:inline-block;padding:0 .12em .1em 0;
  background:linear-gradient(100deg,var(--g1),var(--g2),var(--g3));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  -webkit-text-fill-color:transparent;transition:background .4s}

/* ── TOP BAR (global nav) ─────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:24px;
  padding:11px clamp(16px,4vw,52px);
  background:color-mix(in srgb,var(--canvas) 86%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--hairline)}
.brand{font-family:"Gecko Lunch",cursive;font-style:italic;font-size:1.5rem;line-height:1.3;
  color:var(--accent);-webkit-text-stroke:1px var(--ink);paint-order:stroke fill;
  padding-right:.1em;transition:color .4s;white-space:nowrap}
html.dark .brand{-webkit-text-stroke-color:#000}
.brand .tld{font-family:Inter,sans-serif;font-style:normal;font-weight:800;font-size:.5em;
  color:var(--ink-soft);-webkit-text-stroke:0;vertical-align:.18em;margin-left:.04em}
.brand .bug{display:inline-block;font-style:normal;font-size:.62em;vertical-align:.14em;
  margin-left:.16em;-webkit-text-stroke:0}
.topnav{display:flex;gap:22px;margin-left:6px}
.topnav a{position:relative;font-size:.9rem;font-weight:600;color:var(--ink-soft);padding:6px 1px;transition:color .2s}
.topnav a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--g1),var(--g2),var(--g3));
  transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.topnav a:hover,.topnav a.is-active{color:var(--ink)}
.topnav a:hover::after,.topnav a.is-active::after{transform:scaleX(1)}
.topbar-right{display:flex;align-items:center;gap:8px}
.ctl{display:inline-flex;align-items:center;gap:6px;cursor:pointer;font:inherit;font-size:.84rem;
  font-weight:600;color:var(--ink);background:var(--surface);border:1px solid var(--hairline);
  padding:7px 12px;border-radius:var(--r-pill);box-shadow:var(--shadow-sm);transition:.2s}
.ctl:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:var(--accent)}
select.ctl{appearance:none;padding-right:26px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 9px center;background-size:13px}

/* ── TOPBAR SEARCH ── */
.topbar-search{display:flex;align-items:center;margin-left:auto}
.topbar-q{font:inherit;font-size:.84rem;padding:6px 13px;width:148px;border-radius:var(--r-pill) 0 0 var(--r-pill);
  border:1px solid var(--hairline);border-right:0;background:var(--surface);color:var(--ink);
  outline:none;transition:.2s;box-shadow:var(--shadow-sm)}
.topbar-q:focus{width:200px;border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--glow) 18%,transparent)}
.topbar-q-btn{cursor:pointer;font:inherit;font-size:.9rem;padding:6px 11px;
  border:1px solid var(--hairline);border-radius:0 var(--r-pill) var(--r-pill) 0;
  background:var(--surface);color:var(--ink-soft);box-shadow:var(--shadow-sm);
  transition:.2s;line-height:1}
.topbar-q-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.topbar-right{margin-left:8px;display:flex;align-items:center;gap:8px}

/* ── HERO: art bleeds over a soft accent glow, no block ── */
.wrap{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:0 clamp(16px,4vw,52px)}
.hero{position:relative;display:grid;grid-template-columns:.9fr 1.1fr;align-items:center;gap:18px;
  min-height:clamp(270px,33vw,360px);margin-top:6px}
.hero-art{position:relative;height:100%;min-height:inherit}
.hero-art::before{content:"";position:absolute;left:50%;top:50%;width:80%;height:80%;
  transform:translate(-50%,-50%);border-radius:50%;z-index:0;
  background:radial-gradient(circle,var(--glow),transparent 68%);opacity:.32;filter:blur(34px);transition:background .4s}
html.dark .hero-art::before{opacity:.48}
.hero-art img{position:absolute;left:50%;top:var(--art-top,-4%);height:var(--art-h,114%);
  width:auto;object-fit:contain;transform:translateX(calc(-50% + var(--art-x,0%)));
  z-index:1;filter:drop-shadow(0 16px 28px rgba(20,22,28,.28))}
[data-theme="melia"]  .hero-art img{--art-h:128%;--art-top:-13%}
[data-theme="pyra"]   .hero-art img{--art-h:110%;--art-top:2%}
[data-theme="mythra"] .hero-art img{--art-h:116%;--art-top:-2%}
[data-theme="kosmos"] .hero-art img{--art-h:118%;--art-top:-3%}
[data-theme="elly"]   .hero-art img{--art-h:102%;--art-top:6%;--art-x:3%}
[data-theme="elma"]   .hero-art img{--art-h:108%;--art-top:-2%}
.eyebrow{font-weight:700;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent-ink);margin-bottom:10px}
.hero h1{font-family:"Gecko Lunch",cursive;font-style:italic;
  font-size:clamp(2.3rem,5vw,3.9rem);line-height:1.08;color:var(--ink);padding-bottom:.04em}
.hero .lede{margin:12px 0 20px;max-width:38ch;font-size:.98rem;color:var(--ink-soft)}
.cta-row{display:flex;gap:11px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font:inherit;font-weight:700;
  font-size:.94rem;padding:11px 20px;border-radius:var(--r-pill);border:2px solid transparent;transition:.2s}
.btn-primary{color:#fff;background:var(--accent);box-shadow:0 8px 22px color-mix(in srgb,var(--glow) 45%,transparent)}
.btn-primary:hover{transform:translateY(-2px);background:linear-gradient(100deg,var(--g1),var(--g2));
  box-shadow:0 12px 30px color-mix(in srgb,var(--glow) 55%,transparent)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--hairline)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-ink)}
.shuffle{cursor:pointer;font:inherit;font-size:.84rem;font-weight:600;color:var(--ink);
  background:var(--surface);border:1px solid var(--hairline);padding:7px 11px;border-radius:var(--r-pill);
  box-shadow:var(--shadow-sm);transition:.2s}
.shuffle:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:var(--accent)}

/* ── CONTENT: dense rows + contextual rail ── */
.layout{display:grid;grid-template-columns:1fr 280px;gap:28px;margin:38px 0 60px;align-items:start}
/* home gets a wider rail so the live chat (and its compose row) has room */
@media(min-width:881px){.layout.wide-rail{grid-template-columns:1fr 340px}}
.layout.no-rail{grid-template-columns:1fr}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.section-head h2{font-family:"Gecko Lunch",cursive;font-style:italic;font-size:1.75rem;line-height:1.15}
.section-head a{font-size:.85rem;font-weight:700;color:var(--accent-ink)}
.card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);overflow:hidden}
.row{position:relative;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;
  padding:15px 20px;border-bottom:1px solid var(--hairline);transition:.18s}
.row:last-child{border-bottom:0}
.row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--g1),var(--g2));transform:scaleY(0);transform-origin:top;transition:transform .22s}
.row:hover{background:var(--accent-wash)}
.row:hover::before{transform:scaleY(1)}
.row .dot{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0;
  background:var(--accent-wash);color:var(--accent-ink);font-size:1.1rem;transition:.22s;overflow:hidden}
.row .dot img{width:100%;height:100%;object-fit:cover}
.row:hover .dot{background:linear-gradient(135deg,var(--g1),var(--g2));color:#fff}
.row .t{font-weight:700;font-size:1rem}
.row .d{font-size:.88rem;color:var(--ink-soft)}
.row .meta{text-align:right;font-size:.8rem;color:var(--ink-soft);white-space:nowrap}
.row .meta b{display:block;color:var(--ink);font-size:.88rem;font-weight:700}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.gallery.cols-4{grid-template-columns:repeat(4,1fr)}
.tile{position:relative;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:.22s;cursor:pointer;display:block}
.tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.tile .thumb{aspect-ratio:4/3;background:var(--surface-2);position:relative;overflow:hidden}
.tile .thumb img{width:100%;height:100%;object-fit:cover}
.tile .thumb::after{content:"";position:absolute;inset:0;opacity:0;transition:opacity .25s;
  background:linear-gradient(135deg,var(--g1),var(--g2),var(--g3))}
.tile.placeholder:hover .thumb::after{opacity:.92}
.tile .cap{padding:9px 12px}
.tile .cap b{font-size:.9rem}
.tile .cap span{display:block;font-size:.78rem;color:var(--ink-soft)}
/* album / folder browsing */
.albums{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.tile .folder-ico{position:absolute;inset:0;display:grid;place-items:center;font-size:2.6rem;opacity:.65}
.crumbs{display:flex;flex-wrap:wrap;gap:7px;align-items:center;font-size:.86rem;color:var(--ink-soft);margin-bottom:18px}
.crumbs a{color:var(--accent-ink);font-weight:600}
.crumbs a:hover{text-decoration:underline}
.crumbs .sep{opacity:.45}
/* lightbox */
.lb{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  background:rgba(10,8,14,.86);backdrop-filter:blur(6px);padding:24px}
.lb.open{display:flex}
.lb-inner{position:relative;max-width:min(1100px,94vw);max-height:92vh;display:flex;flex-direction:column;gap:12px}
.lb-img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:var(--r-md);
  box-shadow:0 24px 60px rgba(0,0,0,.6);background:var(--surface-2)}
.lb-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;color:#fff}
.lb-name{font-size:.9rem;font-weight:600;color:rgba(255,255,255,.92);word-break:break-all}
.lb-actions{display:flex;gap:10px;flex-shrink:0}
.lb-close{position:absolute;top:-12px;right:-12px;width:38px;height:38px;border-radius:50%;border:0;
  cursor:pointer;background:var(--surface);color:var(--ink);font-size:1.1rem;box-shadow:var(--shadow-md)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;
  border:0;cursor:pointer;background:rgba(255,255,255,.14);color:#fff;font-size:1.4rem;transition:.18s}
.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-prev{left:-58px}.lb-next{right:-58px}
@media(max-width:780px){.lb-prev{left:4px}.lb-next{right:4px}}
.rail{display:flex;flex-direction:column;gap:16px}
.rail-sticky{position:sticky;top:80px}
.panel{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);padding:16px}
.panel h3{font-size:.72rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:6px}
.panel .ctx{font-size:.72rem;color:var(--accent-ink);font-weight:700;margin-bottom:11px;display:block}
.panel p{font-size:.9rem;color:var(--ink-soft);margin-bottom:11px}
.nav-list a{position:relative;display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-sm);
  font-weight:600;font-size:.93rem;transition:.18s;overflow:hidden}
.nav-list a::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--g1),var(--g2));transform:scaleY(0);transition:transform .2s}
.nav-list a:hover,.nav-list a.is-active{background:var(--accent-wash);color:var(--accent-ink)}
.nav-list a:hover::before,.nav-list a.is-active::before{transform:scaleY(1)}
.nav-list .ico{width:20px;text-align:center}
.nav-list .n{margin-left:auto;font-size:.78rem;color:var(--ink-soft);font-weight:600}
.aff a{display:block;font-size:.9rem;color:var(--ink-soft);padding:5px 0;transition:.16s}
.aff a:hover{color:var(--accent-ink);transform:translateX(3px)}
.chip{display:inline-block;font-size:.77rem;font-weight:700;color:#fff;
  background:linear-gradient(100deg,var(--g1),var(--g2));padding:5px 12px;border-radius:var(--r-pill)}
/* sidebar featured download */
.featured-dl{display:flex;align-items:center;gap:11px;transition:.16s}
.featured-dl .dot{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0;
  background:var(--accent-wash);color:var(--accent-ink);font-size:1.1rem;transition:.2s}
.featured-dl:hover .dot{background:linear-gradient(135deg,var(--g1),var(--g2));color:#fff}
.featured-dl b{display:block;font-size:.92rem;line-height:1.2}
.featured-dl small{font-size:.78rem;color:var(--ink-soft)}
.notice{background:var(--accent-wash);border:1px dashed var(--accent);color:var(--accent-ink);
  border-radius:var(--r-md);padding:12px 16px;font-size:.86rem;margin-bottom:18px}
/* full-text news articles */
.news-post{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);padding:20px 22px;margin-bottom:16px;transition:.2s;position:relative;overflow:hidden}
.news-post::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(var(--g1),var(--g2));transform:scaleY(0);transform-origin:top;transition:transform .25s}
.news-post:hover{box-shadow:var(--shadow-md)}
.news-post:hover::before{transform:scaleY(1)}
.news-post .ph{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.news-post .ph img{width:36px;height:36px;border-radius:50%;flex-shrink:0}
.news-post h3{font-family:"Gecko Lunch",cursive;font-style:italic;font-size:1.4rem;line-height:1.1}
.news-post h3 a{color:var(--ink)}
.news-post h3 a:hover{color:var(--accent-ink)}
.news-post .pmeta{font-size:.78rem;color:var(--ink-soft);font-weight:600}
.news-post .cta{margin-top:14px}
/* rendered Discourse post body */
.prose{font-size:.96rem;color:var(--ink);line-height:1.62}
.prose>*:first-child{margin-top:0}.prose>*:last-child{margin-bottom:0}
.prose p{margin:0 0 11px}
.prose a{color:var(--accent-ink);text-decoration:underline}
.prose img,.prose .lightbox-wrapper{max-width:100%;height:auto;border-radius:var(--r-sm);margin:10px 0}
.prose h1,.prose h2,.prose h3,.prose h4{margin:16px 0 8px;line-height:1.2}
.prose ul,.prose ol{margin:0 0 11px 22px}
.prose blockquote{border-left:3px solid var(--accent);padding:2px 0 2px 14px;color:var(--ink-soft);margin:10px 0}
.prose code{background:var(--surface-2);padding:1px 5px;border-radius:5px;font-size:.9em}
.prose pre{background:var(--surface-2);padding:12px;border-radius:var(--r-sm);overflow:auto;margin:10px 0}
.pager{display:flex;gap:10px;justify-content:center;align-items:center;margin-top:6px}
.pager a,.pager span{font-size:.84rem;font-weight:700;padding:8px 16px;border-radius:var(--r-pill);
  border:1px solid var(--hairline);background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm);transition:.18s}
.pager a:hover{border-color:var(--accent);color:var(--accent-ink);transform:translateY(-1px)}
.pager .disabled{opacity:.4;pointer-events:none;box-shadow:none}
.pager .count{border:0;background:none;box-shadow:none;color:var(--ink-soft)}
/* friend categories + cards */
.friend-category{margin-bottom:36px}
.friend-cat-heading{font-size:.72rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:13px;padding-bottom:8px;border-bottom:1px solid var(--hairline)}
.friends{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.friend{display:block;background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-lg);
  box-shadow:var(--shadow-sm);padding:16px 18px;transition:.2s;position:relative;overflow:hidden}
.friend::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(var(--g1),var(--g2));transform:scaleY(0);transform-origin:top;transition:transform .22s}
.friend:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:transparent}
.friend:hover::before{transform:scaleY(1)}
.friend b{font-size:1.02rem;display:block;margin-bottom:3px}
.friend .host{font-size:.78rem;color:var(--accent-ink);font-weight:600;margin-bottom:6px;display:block}
.friend p{font-size:.86rem;color:var(--ink-soft);margin:0}
.friend.is-archived{opacity:.85}
.friend.is-archived b{color:var(--ink-soft)}
.archive-note{font-size:.78rem;color:var(--ink-soft);margin-top:32px;padding-top:16px;border-top:1px solid var(--hairline)}

footer{border-top:1px solid var(--hairline);background:var(--surface);position:relative;z-index:1}
.foot{max-width:1180px;margin:0 auto;padding:36px clamp(16px,4vw,52px);
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.foot .brand{font-size:1.6rem;display:inline-block;margin-bottom:8px;-webkit-text-stroke:0;color:var(--accent)}
.foot .brand .tld{color:var(--ink-soft)}
.foot p{color:var(--ink-soft);font-size:.88rem;max-width:30ch}
.foot h4{font-size:.72rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:11px}
.foot a{display:block;color:var(--ink-soft);font-size:.9rem;padding:4px 0;transition:.16s}
.foot a:hover{color:var(--accent-ink);transform:translateX(3px)}
.foot-base{border-top:1px solid var(--hairline);text-align:center;padding:14px 15px 20px;color:var(--ink-soft)}
.foot-copy{font-size:.83rem;margin-bottom:7px}
.foot-legal{font-size:.74rem;opacity:.65;max-width:820px;margin:0 auto;line-height:1.65}
@media(max-width:880px){
  .topnav,.topbar-search{display:none}
  .hero{grid-template-columns:1fr;min-height:0;padding-top:18px}
  .hero-art{height:280px;order:-1}
  .hero-art img{left:50%;transform:translateX(-50%);height:104%}
  .layout{grid-template-columns:1fr}.gallery,.gallery.cols-4{grid-template-columns:repeat(2,1fr)}.foot{grid-template-columns:1fr 1fr}
}

/* ── DISCOURSE CHAT (native, no iframe) ───────────────────────────
   Rendered by static/js/chat.js straight from the visitor's Scientia
   session. Two surfaces share the look: an inline card at the top of
   the home rail, and a right slide-out drawer on every other page
   (topbar 💬 button). Messages echo the posts-feed vocabulary. */
.chat-head{display:flex;align-items:center;gap:9px;padding:12px 15px;
  border-bottom:1px solid var(--hairline);background:var(--surface)}
.chat-head .ttl{font-size:.72rem;font-weight:800;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-soft);display:flex;align-items:center;gap:7px}
.chat-head .ttl .ico{font-size:1rem}
.chat-head .live{margin-left:auto;font-size:.64rem;font-weight:700;letter-spacing:.09em;
  text-transform:uppercase;color:var(--accent-ink);display:flex;align-items:center;gap:6px}
.chat-head .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);
  animation:chatpulse 2.2s infinite}
@keyframes chatpulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--glow) 55%,transparent)}
  70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* wrap = flex column shell the JS fills with .chat-scroll + .chat-compose */
.chat-wrap{display:flex;flex-direction:column;min-height:0}
.chat-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;padding:13px 14px;
  display:flex;flex-direction:column;gap:13px}

/* message rows */
.chat-msg{display:flex;gap:9px;align-items:flex-start}
.chat-msg .av{flex:0 0 auto;width:30px;height:30px;border-radius:50%;overflow:hidden;
  background:var(--surface-2);display:grid;place-items:center;font-size:.78rem;font-weight:700;color:var(--ink-soft)}
.chat-msg .av img{width:100%;height:100%;object-fit:cover;display:block}
.chat-msg .bub{min-width:0}
.chat-msg .by{font-size:.8rem;font-weight:700;color:var(--ink)}
.chat-msg .ago{font-size:.68rem;color:var(--ink-soft);font-weight:600;margin-left:6px}
.chat-msg .tx{font-size:.88rem;color:var(--ink-soft);line-height:1.5;overflow-wrap:anywhere}
.chat-msg .tx p{margin:.18em 0}
.chat-msg .tx img,.chat-msg .tx .emoji{max-width:100%;height:auto}
.chat-msg .tx .emoji{width:1.2em;height:1.2em;vertical-align:middle}
.chat-msg .tx a{color:var(--accent-ink);font-weight:600}

/* compose */
.chat-compose{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--hairline);background:var(--surface)}
.chat-compose textarea{flex:1 1 auto;min-width:0;resize:none;font:inherit;font-size:.88rem;line-height:1.4;height:38px;
  padding:8px 11px;border:1px solid var(--hairline);border-radius:var(--r-md);
  background:var(--surface-2);color:var(--ink);outline:none;transition:.18s}
.chat-compose textarea:focus{border-color:var(--accent);background:var(--surface);
  box-shadow:0 0 0 2px color-mix(in srgb,var(--glow) 16%,transparent)}
.chat-send{flex:0 0 auto;white-space:nowrap;cursor:pointer;font:inherit;font-weight:700;font-size:.85rem;color:#fff;
  background:var(--accent);border:0;border-radius:var(--r-md);padding:0 15px;transition:.18s}
.chat-send:hover:not(:disabled){background:linear-gradient(100deg,var(--g1),var(--g2))}
.chat-send:disabled{opacity:.5;cursor:default}
/* inline send-status line (rate-limited / can't-post / join-failed) */
.chat-note{padding:7px 14px;font-size:.8rem;line-height:1.4;color:var(--accent-ink);
  background:var(--accent-wash);border-top:1px solid var(--hairline)}
.chat-note a{color:var(--accent-ink);font-weight:700;text-decoration:underline}

/* states: loading / login-required / error / empty */
.chat-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:11px;text-align:center;padding:26px 22px;color:var(--ink-soft)}
.chat-state .ic{font-size:1.7rem}
.chat-state p{font-size:.9rem;max-width:30ch;margin:0}
.chat-state .btn{font-size:.86rem;padding:9px 16px}
.chat-err{font-size:.82rem;color:var(--accent-ink);font-weight:700}
.chat-spin{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--hairline);
  border-top-color:var(--accent);animation:chatspin .7s linear infinite}
@keyframes chatspin{to{transform:rotate(360deg)}}

/* surface: home rail card */
.chat-card{padding:0;overflow:hidden;display:flex;flex-direction:column}
.chat-card .chat-wrap{height:clamp(360px,50vh,520px)}
.chat-card .chat-foot{padding:9px 14px;border-top:1px solid var(--hairline);text-align:center;font-size:.82rem}
.chat-card .chat-foot a{color:var(--accent-ink);font-weight:700}

/* surface: inner-page slide-out drawer + dimmer */
.chat-toggle .ico{font-size:1rem}
.chat-overlay{position:fixed;inset:0;background:rgba(16,18,24,.42);z-index:110;
  opacity:0;visibility:hidden;transition:opacity .28s,visibility .28s}
.chat-overlay.open{opacity:1;visibility:visible}
.chat-drawer{position:fixed;top:0;right:0;height:100dvh;width:min(420px,94vw);z-index:120;
  display:flex;flex-direction:column;background:var(--surface);
  border-left:1px solid var(--hairline);box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.chat-drawer.open{transform:translateX(0)}
.chat-drawer .chat-wrap{flex:1 1 auto;min-height:0}
.chat-close{margin-left:auto;cursor:pointer;font:inherit;font-size:1.05rem;line-height:1;
  color:var(--ink-soft);background:none;border:0;padding:4px 7px;border-radius:var(--r-sm);transition:.16s}
.chat-close:hover{color:var(--accent-ink);background:var(--accent-wash)}
@media(max-width:880px){.chat-drawer{width:100vw}}
