/* Nem5 — Nemesis World :: Romantic Digital Atelier
   Custom CSS is authoritative for layout. CDN libs (Font Awesome, AOS) are enhancement only. */

:root{
  --plum:#5b2a4e;
  --plum-dark:#3d1a35;
  --plum-deep:#2d1229;
  --rose:#b5476a;
  --rose-soft:#d98aa5;
  --gold:#c9a24b;
  --gold-soft:#e2c988;
  --cream:#fbf6ef;
  --parchment:#f3e9db;
  --card:#fffdf9;
  --ink:#2e2430;
  --muted:#6d6270;
  --line:rgba(91,42,78,.14);
  --shadow:0 14px 40px -18px rgba(61,26,53,.45);
  --shadow-sm:0 6px 18px -10px rgba(61,26,53,.4);
  --radius:14px;
  --maxw:1160px;
  --readw:768px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Nunito Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.72;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--rose);text-decoration:none;transition:color .2s}
a:hover{color:var(--plum);text-decoration:underline;text-underline-offset:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

h1,h2,h3,h4{font-family:"Playfair Display",Georgia,serif;line-height:1.18;color:var(--plum-dark);font-weight:700}
h1{font-size:clamp(2rem,4.6vw,3.2rem);margin:.2em 0}
h2{font-size:clamp(1.5rem,2.9vw,2.05rem);margin:1.9rem 0 .7rem}
h3{font-size:1.2rem;margin:1.3rem 0 .5rem;letter-spacing:.01em}

.skip{position:absolute;left:-999px;top:0;background:var(--plum);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* ---------- Nav ---------- */
.topnav{
  position:sticky;top:0;z-index:100;
  background:rgba(45,18,41,.94);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(201,162,75,.35);
}
.navwrap{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:70px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand:hover{text-decoration:none}
.brand-mark{
  display:inline-grid;place-items:center;width:42px;height:42px;flex:0 0 42px;
  background:linear-gradient(140deg,var(--gold),var(--rose));
  color:var(--plum-deep);font-family:"Playfair Display",serif;font-weight:700;font-size:1rem;
  border-radius:11px;box-shadow:inset 0 0 0 2px rgba(255,255,255,.25);
}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text strong{font-family:"Playfair Display",serif;font-size:1.28rem;color:#fff;letter-spacing:.02em}
.brand-text small{font-family:"Cormorant Garamond",serif;font-size:.9rem;color:var(--gold-soft);letter-spacing:.16em;text-transform:uppercase}
.navlinks{list-style:none;display:flex;flex-wrap:wrap;gap:2px;margin:0;padding:0}
.navlinks a{
  display:block;color:#f3e5ee;padding:9px 12px;border-radius:9px;font-size:.93rem;font-weight:600;letter-spacing:.01em;
}
.navlinks a:hover{background:rgba(201,162,75,.16);color:#fff;text-decoration:none}
.navlinks a.active{color:var(--gold-soft);background:rgba(201,162,75,.12)}
.navtoggle{display:none;background:none;border:1px solid rgba(226,201,136,.5);color:var(--gold-soft);font-size:1.15rem;padding:7px 12px;border-radius:9px;cursor:pointer}

/* ---------- Hero ---------- */
.hero{
  position:relative;background-size:cover;background-position:center;color:#fff;
  padding:clamp(3.4rem,9vw,6.6rem) 22px;text-align:center;
}
.hero-inner{max-width:900px;margin:0 auto}
.hero h1{color:#fff;text-shadow:0 2px 22px rgba(0,0,0,.4)}
.hero-sub{max-width:640px;margin:1rem auto 0;color:#f5e9f0;font-size:1.08rem}
.eyebrow{
  font-family:"Cormorant Garamond",serif;text-transform:uppercase;letter-spacing:.32em;
  font-size:.82rem;color:var(--gold-soft);margin:0 0 .5rem;font-weight:600;
}
.eyebrow i{color:var(--rose-soft);margin-right:.35em;font-size:.7em;vertical-align:middle}
.pagehead{
  background:
    radial-gradient(circle at 12% -10%,rgba(201,162,75,.16),transparent 45%),
    var(--parchment);
  border-bottom:1px solid var(--line);
  padding:clamp(2.4rem,6vw,4rem) 0 clamp(1.8rem,4vw,2.6rem);
  text-align:center;
}
.pagehead .eyebrow{color:var(--rose)}
.pagehead .eyebrow i{color:var(--gold)}

/* ---------- Prose ---------- */
.prose{max-width:var(--readw);margin:0 auto;padding-top:clamp(2rem,5vw,3.2rem);padding-bottom:1rem}
.prose > p,.prose > ul,.prose > ol,.prose > blockquote{margin:0 0 1.1rem}
.prose h2{position:relative;padding-top:.4rem}
.prose h2::before{content:"";display:block;width:44px;height:3px;margin-bottom:.7rem;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--rose))}
.lede{font-family:"Cormorant Garamond",serif;font-size:1.42rem;line-height:1.5;color:#4a3a48}
.lede::first-letter{
  font-family:"Playfair Display",serif;font-size:3.4rem;line-height:.8;float:left;
  color:var(--rose);margin:.06em .12em 0 0;font-weight:700;
}
.prose ul,.prose ol{padding-left:1.25rem}
.prose li{margin:.34rem 0}
.prose strong{color:var(--plum-dark)}
.prose a{border-bottom:1px solid rgba(181,71,106,.35)}
.prose a:hover{border-bottom-color:var(--plum)}

blockquote{
  margin:1.4rem 0;padding:1.1rem 1.4rem;background:var(--card);
  border-left:4px solid var(--gold);border-radius:0 var(--radius) var(--radius) 0;
  box-shadow:var(--shadow-sm);font-family:"Cormorant Garamond",serif;font-size:1.25rem;
  color:#4a3a48;font-style:italic;
}
.poem{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem 1.8rem;box-shadow:var(--shadow-sm);margin:1.4rem 0;
}
.poem p{font-family:"Cormorant Garamond",serif;font-size:1.32rem;line-height:1.6;color:#3f2f3d;margin:0 0 1.1rem}
.poem p:last-child{margin-bottom:0}

/* card grid on home */
.cardgrid{list-style:none;padding:0;margin:1.2rem 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}
.cardgrid li{margin:0}
.cardgrid a{
  display:block;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem 1.3rem;height:100%;box-shadow:var(--shadow-sm);color:var(--ink);
  border-bottom:1px solid var(--line);transition:transform .2s,box-shadow .2s,border-color .2s;
}
.cardgrid a:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold);text-decoration:none}
.cardgrid i{font-size:1.5rem;color:var(--rose);display:block;margin-bottom:.4rem}
.cardgrid span{display:block;font-family:"Playfair Display",serif;font-weight:700;color:var(--plum-dark);font-size:1.12rem;margin-bottom:.25rem}

/* ---------- Cross links ---------- */
.crosslinks{padding:2rem 22px 3rem;text-align:center}
.xl-title{font-size:1.35rem;color:var(--plum);margin-bottom:1rem}
.xl-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:12px}
.xl-grid a{
  display:inline-flex;align-items:center;gap:.5rem;background:var(--parchment);
  border:1px solid var(--line);color:var(--plum-dark);padding:.7rem 1.15rem;border-radius:999px;font-weight:600;font-size:.95rem;
}
.xl-grid a:hover{background:var(--plum);color:#fff;border-color:var(--plum);text-decoration:none}
.xl-grid i{color:var(--rose)}
.xl-grid a:hover i{color:var(--gold-soft)}

/* ---------- Footer ---------- */
.site-footer{background:var(--plum-deep);color:#e9dce6;margin-top:2rem}
.footgrid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:28px;padding:2.8rem 22px 1.6rem}
.site-footer h3{color:var(--gold-soft);font-size:1.05rem;margin:0 0 .7rem;font-family:"Playfair Display",serif}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:.3rem 0}
.site-footer a{color:#e9dce6;font-size:.95rem}
.site-footer a:hover{color:#fff}
.foot-brand .brand-mark{margin-bottom:.6rem}
.foot-brand p{margin:.2rem 0}
.foot-brand strong{font-family:"Playfair Display",serif;font-size:1.2rem;color:#fff}
.muted{color:#b79fb2;font-size:.9rem}
.foot-legal{border-top:1px solid rgba(201,162,75,.28);padding:1rem 22px 1.6rem}
.foot-legal p{margin:0;color:#b79fb2;font-size:.83rem;text-align:center;max-width:var(--maxw)}

/* ---------- 404 ---------- */
.err-body{display:flex;flex-direction:column;min-height:100vh}
.err-main{flex:1;display:grid;place-items:center;background:var(--parchment);padding:3rem 0}
.err-wrap{text-align:center;max-width:640px}
.err-code{font-family:"Playfair Display",serif;font-size:clamp(4rem,16vw,8rem);line-height:1;color:var(--gold);margin:0}
.err-links{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:1.5rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--plum);color:#fff;padding:.75rem 1.3rem;border-radius:999px;font-weight:600}
.btn:hover{background:var(--rose);text-decoration:none;color:#fff}
.btn.ghost{background:transparent;color:var(--plum);border:1px solid var(--plum)}
.btn.ghost:hover{background:var(--plum);color:#fff}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .footgrid{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1 / -1}
}
@media(max-width:720px){
  body{font-size:17px}
  .navtoggle{display:block;order:3}
  .navlinks{
    flex-basis:100%;flex-direction:column;gap:0;
    max-height:0;overflow:hidden;transition:max-height .32s ease;
  }
  .navlinks.open{max-height:640px;padding-bottom:10px}
  .navlinks a{padding:11px 8px;border-bottom:1px solid rgba(255,255,255,.06)}
  .footgrid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important;transition:none!important}
  [data-aos]{opacity:1!important;transform:none!important}
}
