/*
Theme Name: Ravenkey Village Portal
Author: OpenAI
Description: Ravenkey portal theme with village directory, single village pages, archive gateway, and collection discovery.
Version: 2.0
Text Domain: ravenkey
*/

:root{
  --bg:#081018;
  --text:#eef4fb;
  --muted:#b8c5d6;
  --accent:#4edcf3;
  --accent-2:#7be7ff;
  --line:rgba(255,255,255,.09);
  --line-strong:rgba(78,220,243,.22);
  --max:1180px;
  --shadow:0 16px 50px rgba(0,0,0,.28);
  --panel:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(78,220,243,.11), transparent 35%),
    linear-gradient(180deg,#05080d 0%, #081018 35%, #0b1420 100%);
  line-height:1.6;
}
a{color:var(--accent); text-decoration:none}
a:hover{color:var(--accent-2)}
img{max-width:100%; height:auto}
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:none;
  background:#000;
  border-bottom:1px solid var(--line);
}
.site-header .wrap{padding-left:16px; padding-right:16px}
.wrap{max-width:var(--max); margin:0 auto; padding:0 24px}
.header-inner{
  min-height:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:16px;
  position:relative;
  width:100%;
  padding:18px 0 20px;
}
.branding{
  flex:0 0 auto;
  min-width:0;
  max-width:540px;
}
.branding a{display:block; margin-left:0}
.branding img{
  width:100%;
  max-width:min(56vw, 500px);
  mix-blend-mode:screen;
  transform:translateX(-14px);
}
.site-nav-shell{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:16px;
  flex:0 0 auto;
  min-width:0;
  margin-left:0;
  transform:none;
  padding-top:6px;
}
.site-nav ul,.site-menu{list-style:none; margin:0; padding:0; display:flex; gap:8px; align-items:center; justify-content:center; flex-wrap:wrap}
.site-nav a{
  color:#d3deea; font-weight:600; font-size:.95rem;
  display:inline-flex; align-items:center; justify-content:center;
  min-height:40px; padding:0 14px; border-radius:10px;
  border:1px solid transparent; transition:.2s ease;
  letter-spacing:.02em;
}
.site-nav .current-menu-item > a,
.site-nav .current_page_item > a,
.site-nav a:hover{
  color:var(--accent-2);
}
.site-nav .current-menu-item > a,
.site-nav .current_page_item > a{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.08);
}
.site-nav a:hover{
  background:rgba(78,220,243,.09);
  border-color:rgba(78,220,243,.18);
}
.nav-cta{
  display:inline-flex; align-items:center; justify-content:center; min-height:42px;
  padding:0 16px; border-radius:12px; font-weight:700;
  color:#07131c; background:var(--accent);
  box-shadow:none;
}
.nav-cta:hover{background:var(--accent-2); color:#041018}
.nav-toggle{
  display:none; width:52px; height:52px; border-radius:16px; border:1px solid var(--line);
  background:rgba(255,255,255,.04); padding:0; cursor:pointer;
}
.nav-toggle span{
  display:block; width:22px; height:2px; margin:5px auto;
  background:#e8f1fb; transition:.2s ease;
}
body.nav-open{overflow:hidden}

@media (min-width: 981px){
  .nav-toggle{
    display:none !important;
    visibility:hidden;
    pointer-events:none;
  }
}

.hero{padding:92px 0 72px}
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:42px; align-items:center}
.kicker{
  display:inline-block; padding:8px 14px; border:1px solid rgba(78,220,243,.25);
  border-radius:999px; color:var(--accent-2); font-size:.85rem; letter-spacing:.04em;
  background:rgba(78,220,243,.08); margin-bottom:20px;
}
h1,h2,h3,h4{line-height:1.08}
.hero h1{margin:0 0 18px; font-size:clamp(1.95rem,3.8vw,3.55rem); letter-spacing:-.03em}
.hero p{margin:0 0 28px; color:var(--muted); font-size:1.08rem; max-width:700px}
.cta-row{display:flex; gap:16px; flex-wrap:wrap}
.btn{
  display:inline-flex; align-items:center; justify-content:center; padding:14px 22px;
  border-radius:14px; font-weight:700; transition:.2s ease; border:1px solid var(--line);
}
.btn-primary{background:var(--accent); color:#07131c; border-color:transparent}
.btn-primary:hover{background:var(--accent-2); color:#041018}
.btn-secondary{color:var(--text); background:rgba(255,255,255,.04)}
.btn-secondary:hover{background:rgba(255,255,255,.08)}
.hero-card,.card,.archive-card,.village-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:24px; padding:24px; box-shadow:var(--shadow);
}
.metric-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:16px}
.metric{border:1px solid var(--line); border-radius:18px; padding:16px; background:rgba(255,255,255,.02)}
.metric strong{display:block; font-size:1.3rem; margin-bottom:6px}
.section{padding:72px 0}
.section h2{margin:0 0 12px; font-size:clamp(1.6rem,2.3vw,2.25rem)}
.section .lead{max-width:800px; color:var(--muted); margin:0 0 28px}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.grid-2{display:grid; grid-template-columns:repeat(2,1fr); gap:24px}
.card h3,.archive-card h3,.village-card h3{margin:0 0 12px; font-size:1.25rem}
.card p,.archive-card p,.village-card p{margin:0; color:var(--muted)}
.list{margin:14px 0 0; padding-left:18px; color:var(--muted)}
.feature-band{
  background:linear-gradient(180deg, rgba(78,220,243,.09), rgba(78,220,243,.03));
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.portal-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.village-card{border-color:var(--line-strong)}
.badge{
  display:inline-block; margin-bottom:14px; padding:6px 10px; border-radius:999px;
  font-size:.8rem; font-weight:700; letter-spacing:.03em;
  background:rgba(255,255,255,.08); color:#dfe8f3;
}
.badge.live{background:rgba(78,220,243,.16); color:var(--accent-2)}
.page-hero{padding:64px 0 26px}
.page-hero h1{font-size:clamp(1.8rem,3vw,2.65rem); margin:0 0 12px}
.page-hero p{max-width:780px; color:var(--muted)}
.page-content-section{padding-top:12px}
.page-content-shell{
  padding:0;
  max-width:1000px;
}
.archive-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.archive-card{border-color:rgba(78,220,243,.18)}
.meta-row{display:flex; gap:14px; flex-wrap:wrap; color:var(--muted); font-size:.95rem; margin:10px 0 0}
.split-layout{display:grid; grid-template-columns:2fr 1fr; gap:26px}
.sidebar-stack{display:grid; gap:18px}
.quote{
  padding:26px; border-radius:24px; background:rgba(255,255,255,.03); border:1px solid var(--line);
  color:#dbe6f4; font-size:1.08rem;
}
.notice{
  border:1px solid rgba(78,220,243,.22);
  background:rgba(78,220,243,.06);
  border-radius:18px; padding:16px 18px; color:#dbe8f5;
}
.cta-banner{
  border:1px solid rgba(78,220,243,.28);
  background:linear-gradient(180deg, rgba(78,220,243,.12), rgba(78,220,243,.05));
  border-radius:28px; padding:34px;
}
.tax-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px}
.post-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:22px}
.site-footer{padding:44px 0 52px; color:#a8b9cb; border-top:1px solid var(--line)}
.footer-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.4fr) repeat(3, minmax(0, .8fr));
  gap:28px;
  align-items:start;
}
.footer-title{
  margin:0 0 10px;
  font-size:1.15rem;
  font-weight:700;
  color:var(--text);
}
.footer-heading{
  margin:0 0 12px;
  font-size:.82rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#dbe8f5;
}
.footer-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.footer-list a,
.footer-contact a{color:#d3deea}
.footer-list a:hover,
.footer-contact a:hover{color:var(--accent-2)}
.footer-meta{
  margin-top:28px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.footer-support{
  margin-top:28px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.08);
}
.footer-support-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.footer-support-card{
  padding:16px 18px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  background:rgba(255,255,255,.03);
}
.footer-support-title{
  margin:0 0 8px;
  color:var(--text);
  font-weight:700;
}
.page-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 280px;
  gap:28px;
  align-items:start;
}
.on-this-page{
  position:sticky;
  top:110px;
  padding:18px 18px 14px;
}
.on-this-page-title{
  margin:0 0 10px;
  font-size:.9rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#dbe8f5;
  font-weight:700;
}
.on-this-page-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:10px;
}
.on-this-page-list a{
  color:var(--accent-2);
  font-weight:700;
}
.on-this-page-list a:hover{
  color:var(--accent-1);
}
.on-this-page-list .toc-depth-3 a{
  padding-left:10px;
  display:block;
  font-weight:600;
  color:var(--muted);
}
.small{font-size:.95rem; color:var(--muted)}
.content-prose > *:first-child{margin-top:0}
.content-prose > *:last-child{margin-bottom:0}
.content-prose p,
.content-prose ul,
.content-prose ol{margin:0 0 16px; color:var(--muted)}
.content-prose h2,
.content-prose h3{margin:24px 0 12px}
.content-prose strong{color:var(--text)}
.content-prose a{color:var(--accent-2)}
.contact-shell{display:grid; gap:24px}
.contact-intro{max-width:760px}
.contact-form{display:grid; gap:18px}
.form-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.field{display:grid; gap:8px}
.field-full{grid-column:1 / -1}
.field label{font-weight:700; color:#dbe8f5}
.field input,
.field textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:rgba(255,255,255,.04);
  color:var(--text);
  padding:14px 16px;
  font:inherit;
}
.field input:focus,
.field textarea:focus{
  outline:none;
  border-color:rgba(78,220,243,.45);
  box-shadow:0 0 0 3px rgba(78,220,243,.12);
}
.field textarea{resize:vertical; min-height:180px}
.contact-honeypot{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.form-actions{display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap}
.form-message{
  margin-bottom:18px;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid transparent;
}
.form-message a{font-weight:700}
.form-message-success{
  background:rgba(92, 214, 160, .14);
  border-color:rgba(92, 214, 160, .24);
  color:#dffbef;
}
.form-message-error{
  background:rgba(255, 132, 132, .14);
  border-color:rgba(255, 132, 132, .24);
  color:#ffe0e0;
}
@media (max-width: 1100px){
  .archive-grid{grid-template-columns:repeat(2,1fr)}
  .page-layout{grid-template-columns:1fr}
  .on-this-page{position:relative; top:auto}
}
@media (max-width: 980px){
  .hero-grid,.grid-3,.grid-2,.portal-grid,.tax-grid,.post-grid,.split-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .footer-support-grid{grid-template-columns:1fr}
  .branding img{width:280px; max-width:100%}
  .branding img{transform:none}
  .branding a{margin-left:0}
  .site-nav-shell{transform:none}
  .nav-toggle{display:inline-block; margin-left:auto}
  .site-nav-shell{
    position:absolute; top:calc(100% + 14px); left:24px; right:24px;
    display:none; flex-direction:column; align-items:stretch; gap:14px;
    padding:18px; border-radius:24px; border:1px solid var(--line);
    background:rgba(6,10,16,.97); box-shadow:var(--shadow);
  }
  .site-nav-shell.is-open{display:flex}
  .site-nav ul,.site-menu{flex-direction:column; align-items:stretch; gap:8px}
  .site-nav a,.nav-cta{
    width:100%; justify-content:flex-start; min-height:48px; padding:0 16px;
  }
  .nav-cta{justify-content:center}
  .form-grid{grid-template-columns:1fr}
}
@media (max-width: 700px){
  .footer-grid{grid-template-columns:1fr}
  .footer-meta{flex-direction:column}
  .header-inner{align-items:flex-start; padding:14px 0}
  .nav-toggle{position:absolute; top:14px; right:0}
  .hero{padding-top:48px}
  .archive-grid{grid-template-columns:1fr}
}
