/* GrottoMud — Alternate Reality. Dark fantasy / terminal theme. */
:root{
  --bg:#0a0c08; --bg2:#0f120c; --panel:#13160f; --panel2:#171b12;
  --line:#2a3320; --line2:#3a4628;
  --ink:#cdbf9e;        /* parchment text */
  --ink-dim:#8f8669;
  --gold:#e0b357; --gold-bright:#f2cd72;
  --green:#7fdc6a; --green-dim:#4f9f44;
  --red:#d9543b; --magenta:#b367c9; --cyan:#5fc9c9;
  --maxw:1080px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:
    radial-gradient(1200px 600px at 50% -200px, rgba(224,179,87,.07), transparent 60%),
    radial-gradient(900px 500px at 100% 100%, rgba(127,220,106,.05), transparent 60%),
    var(--bg);
  color:var(--ink); font-family:'EB Garamond','Georgia',serif; font-size:18px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--gold); text-decoration:none}
a:hover{color:var(--gold-bright); text-decoration:underline}
h1,h2,h3{font-family:'Cinzel',serif; font-weight:700; letter-spacing:.04em; line-height:1.2; color:var(--gold-bright)}
code,.mono,pre{font-family:'IBM Plex Mono',Consolas,monospace}
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 22px}

/* nav */
header.nav{position:sticky; top:0; z-index:20; background:rgba(10,12,8,.92);
  backdrop-filter:blur(6px); border-bottom:1px solid var(--line)}
.nav .wrap{display:flex; align-items:center; gap:24px; height:60px}
.brand{font-family:'Cinzel',serif; font-weight:700; font-size:20px; color:var(--gold-bright);
  letter-spacing:.06em; white-space:nowrap}
.brand small{display:block; font-family:'IBM Plex Mono',monospace; font-size:10px; letter-spacing:.3em;
  color:var(--green-dim); font-weight:400; margin-top:-2px}
.nav nav{margin-left:auto; display:flex; gap:20px; flex-wrap:wrap}
.nav nav a{color:var(--ink); font-family:'IBM Plex Mono',monospace; font-size:13px; letter-spacing:.08em; text-transform:uppercase}
.nav nav a:hover{color:var(--green); text-decoration:none}

/* hero */
.hero{text-align:center; padding:54px 0 36px; border-bottom:1px solid var(--line)}
.dragon{color:var(--green); font-size:13px; line-height:1.05; margin:0 auto 8px; display:inline-block; text-align:left;
  text-shadow:0 0 14px rgba(127,220,106,.25)}
.dragon .eye{color:var(--red)}
.hero h1{font-size:clamp(34px,6vw,64px); margin:.1em 0 .05em; letter-spacing:.12em;
  text-shadow:0 0 24px rgba(224,179,87,.25)}
.hero .tag{color:var(--ink-dim); font-style:italic; font-size:20px; margin-bottom:6px}
.hero .world{font-family:'IBM Plex Mono',monospace; font-size:12px; letter-spacing:.35em; color:var(--green-dim); text-transform:uppercase}

/* connect bar */
.connect{display:flex; gap:16px; justify-content:center; flex-wrap:wrap; margin:26px 0 6px}
.telnet{font-family:'IBM Plex Mono',monospace; background:#06120a; border:1px solid var(--green-dim);
  color:var(--green); padding:12px 18px; border-radius:8px; font-size:18px; box-shadow:0 0 20px rgba(127,220,106,.1)}
.telnet b{color:var(--green-bright,#bfffae)}
.btn{display:inline-block; font-family:'IBM Plex Mono',monospace; font-size:14px; letter-spacing:.06em;
  padding:12px 18px; border-radius:8px; border:1px solid var(--gold); color:var(--gold); background:transparent; cursor:pointer; transition:.15s}
.btn:hover{background:var(--gold); color:#1a1206; text-decoration:none}
.btn.solid{background:var(--gold); color:#1a1206}
.btn.solid:hover{background:var(--gold-bright)}

/* sections */
section{padding:48px 0; border-bottom:1px solid var(--line)}
section h2{font-size:30px; margin:0 0 6px}
section .lead{color:var(--ink-dim); margin:0 0 26px; max-width:62ch}
.kicker{font-family:'IBM Plex Mono',monospace; color:var(--green-dim); font-size:12px;
  letter-spacing:.3em; text-transform:uppercase; margin-bottom:6px}

/* lore */
.lore p{max-width:70ch}
.lore p:first-letter{}
.dropcap::first-letter{font-family:'Cinzel',serif; font-size:3.4em; line-height:.8; float:left;
  color:var(--gold); padding:6px 10px 0 0}

/* cards / grid */
.grid{display:grid; gap:16px}
.g3{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.g2{grid-template-columns:repeat(auto-fill,minmax(330px,1fr))}
.card{background:linear-gradient(180deg,var(--panel),var(--panel2)); border:1px solid var(--line);
  border-radius:10px; padding:18px 20px}
.card h3{font-size:19px; margin:0 0 4px}
.card.light{border-left:3px solid var(--cyan)}
.card.dark{border-left:3px solid var(--magenta)}
.tag-pill{display:inline-block; font-family:'IBM Plex Mono',monospace; font-size:11px; letter-spacing:.1em;
  padding:2px 9px; border-radius:20px; text-transform:uppercase}
.pill-light{background:rgba(95,201,201,.12); color:var(--cyan); border:1px solid rgba(95,201,201,.4)}
.pill-dark{background:rgba(179,103,201,.12); color:var(--magenta); border:1px solid rgba(179,103,201,.4)}
.card ul{margin:10px 0 0; padding-left:18px; color:var(--ink)}
.card .classes{font-family:'IBM Plex Mono',monospace; font-size:13px; color:var(--green); margin-top:8px}

/* class chips */
.chips{display:flex; flex-wrap:wrap; gap:8px}
.chip{font-family:'IBM Plex Mono',monospace; font-size:13px; padding:6px 12px; border-radius:6px;
  background:var(--panel2); border:1px solid var(--line2); color:var(--ink)}
.chip.remort{border-color:var(--gold); color:var(--gold)}

/* steps / help */
.steps{counter-reset:s; display:grid; gap:14px}
.step{display:flex; gap:16px; align-items:flex-start; background:var(--panel); border:1px solid var(--line); border-radius:10px; padding:16px 18px}
.step::before{counter-increment:s; content:counter(s); font-family:'Cinzel',serif; font-weight:700;
  color:var(--gold); background:#1a1206; border:1px solid var(--gold); width:38px; height:38px; flex:0 0 38px;
  display:grid; place-items:center; border-radius:50%}
.step b{color:var(--gold-bright)}
kbd{font-family:'IBM Plex Mono',monospace; background:#06120a; border:1px solid var(--green-dim); color:var(--green);
  padding:1px 7px; border-radius:4px; font-size:.9em}

/* news */
.news-item{border-left:2px solid var(--line2); padding:4px 0 22px 20px; position:relative}
.news-item::before{content:''; position:absolute; left:-6px; top:6px; width:10px; height:10px; border-radius:50%;
  background:var(--gold); box-shadow:0 0 10px var(--gold)}
.news-item .date{font-family:'IBM Plex Mono',monospace; color:var(--green-dim); font-size:13px; letter-spacing:.1em}
.news-item h3{margin:.1em 0 .3em; font-size:20px}
.news-item.archive::before{background:var(--ink-dim); box-shadow:none}

/* gallery */
.shots{display:grid; gap:18px; grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.shot{border:1px solid var(--line); border-radius:10px; overflow:hidden; background:#000}
.shot img{width:100%; display:block}
.shot figcaption{padding:10px 14px; font-family:'IBM Plex Mono',monospace; font-size:12px; color:var(--ink-dim)}

/* footer */
footer{padding:34px 0; text-align:center; color:var(--ink-dim); font-size:14px}
footer .mono{color:var(--green-dim)}

@media(max-width:640px){ body{font-size:16px} .nav .wrap{height:auto; padding:10px 16px; flex-wrap:wrap} .dragon{font-size:10px} }
