:root{
  --bg:#463148;            /* deep plum */
  --paper:#0f0a14;         /* slightly lighter */
  --accent1:#7b3cff;       /* bright purple */
  --accent2:#B99EB4;       /* smoked lilac */
  --muted:#bda6cf;
  --glass: rgba(255,255,255,0.04);
  --radius:12px;
  --max-w:1100px;
  font-family: 'HauntingEleanor';
  src: url('haunting_eleanor.ttf') format('truetype');
}
body {
  font-family: 'HauntingEleanor', serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 10% 10%, rgba(123,60,255,0.06), transparent 8%),
    radial-gradient(900px 400px at 90% 80%, rgba(200,140,255,0.04), transparent 6%),
    linear-gradient(180deg, var(--bg), #100117 30%);
  color:var(--muted);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.5;
  font-size:16px;
  padding-top:70px;
  background-attachment:fixed;
}
/* tiny paper grain overlay */
body::after{
  content:"";
  position:fixed; inset:0;
  background-image: radial-gradient(rgba(255,255,255,0.01) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity:0.12;
  pointer-events:none;
}
/* Header / nav */
.site-header{
  position:fixed;
  top:12px;
  right:18px;
  z-index:60;
  display:flex;
  gap:10px;
  align-items:center;
  backdrop-filter: blur(4px);
}
.menu-btn{
  appearance:none;
  border: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), var(--glass));
  padding:8px;
  border-radius:10px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:transform .18s ease;
}
.menu-btn:active{ transform: scale(.98)}
.icon{ display:block; filter: drop-shadow(0 2px 6px rgba(0,0,0,0.6)); }
.site-nav{
  display:flex;
  align-items:center;
  gap:14px;
  padding:8px 12px;
  border-radius:12px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  box-shadow: 0 6px 18px rgba(0,0,0,0.6);
}
.site-nav a{
  color:var(--muted);
  text-decoration:none;
  font-weight:700;
  letter-spacing:.2px;
  padding:6px 8px;
  border-radius:8px;
  transition:all .16s ease;
}
.site-nav a.logo{
  font-size:1rem;
  color:var(--accent2);
  font-weight:900;
}
.site-nav a:hover{ color: white; transform: translateY(-2px)}
/* HERO */
.hero{
  padding:60px 18px 40px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:64vh;
}
.hero-inner{
  max-width:var(--max-w);
  width:100%;
  margin:auto;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:28px;
  align-items:center;
}
.hero-art{ display:flex; align-items:center; justify-content:center; }
.hero-orb{ width:240px; height:240px; filter: drop-shadow(0 20px 40px rgba(40,0,40,0.6)); animation: slowGlow 6s ease-in-out infinite; border-radius:50%}
@keyframes slowGlow{ 0%{transform:translateY(0)}50%{transform:translateY(-8px)}100%{transform:translateY(0)}}
.hero-text h1{
  margin:0 0 6px 0;
  font-size: clamp(28px, 6vw, 46px);
  color: white;
  letter-spacing: -1px;
  line-height:1.02;
}
.lead{ color: #e9d7ff; margin:6px 0 12px; font-size:1.05rem; max-width:44ch}
.cta-row{ display:flex; gap:12px; margin:12px 0;}
.btn{
  background: linear-gradient(180deg, var(--accent1), #5a2bd9);
  color:white;
  padding:10px 14px;
  text-decoration:none;
  border-radius:10px;
  font-weight:700;
  box-shadow: 0 8px 30px rgba(123,60,255,0.14);
}
.btn.ghost{
  background: transparent;
  border: 1px solid rgba(255,255,255,0.06);
  color:var(--accent2);
}
/* panels (about, shop, journal, contact) */
.panel{
  margin:30px 18px;
  padding:28px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.08));
  max-width:var(--max-w);
  margin-left:auto;
  margin-right:auto;
  box-shadow: 0 10px 30px rgba(0,0,0,0.6);
}
.panel-inner{ max-width:920px }
.panel h2{ color:var(--accent2); margin-top:0; font-size:1.6rem; margin-bottom:8px; }
/* buttons & small text */
.small{ color: #b9a7cc; font-size:.95rem }
.links-grid{ display:grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap:12px; list-style:none; padding:0; margin:12px 0 0}
.link-card{
  display:block;
  padding:14px;
  border-radius:10px;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.02));
  color:var(--muted);
  text-decoration:none;
  font-weight:700;
  border: 1px solid rgba(255,255,255,0.03);
}
/* Journal posts */
.post-preview{ margin:12px 0 20px; border-left: 3px solid rgba(148,86,255,0.16); padding-left:12px;}
.post-preview h3{ margin:0; font-size:1.05rem; color: #fff }
.post-preview .meta{ color:#bfa7dd; font-size:.85rem; margin:6px 0 8px}
/* contact form */
.contact-form{ display:grid; gap:10px; margin-top:8px; max-width:520px}
.contact-form label{ display:flex; flex-direction:column; font-size:.9rem; color:var(--muted)}
.contact-form input, .contact-form textarea{
  margin-top:6px; padding:10px; border-radius:8px; border:1px solid rgba(255,255,255,0.04);
  background: rgba(0,0,0,0.3); color: #fff;
}
.form-ack{ color:var(--accent2); font-weight:700}
/* footer */
.site-footer{ margin-top:36px; padding:20px 18px; text-align:center; color:#a085c2; }
.foot-inner{ max-width:var(--max-w); margin: 0 auto; display:flex; gap:12px; align-items:center; justify-content:space-between; flex-wrap:wrap}
/* responsive */
@media (max-width:900px){
  .hero-inner{ grid-template-columns: 1fr; text-align:center }
  .site-nav{ display:none; position:fixed; right:18px; top:66px; padding:12px; flex-direction:column; gap:8px; width:200px }
  .site-nav.open{ display:flex; }
}
