/*
Theme Name: Ravenkey Village Portal
Author: OpenAI
Description: WordPress portal theme for Ravenkey 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: blur(12px);
  background:rgba(5,8,13,.72);
  border-bottom:1px solid var(--line);
}
.wrap{max-width:var(--max); margin:0 auto; padding:0 24px}
.header-inner{min-height:82px; display:flex; align-items:center; justify-content:space-between; gap:24px; position:relative}
.branding img{width:210px; max-width:44vw}
.site-nav-shell{display:flex; align-items:center; gap:16px}
.site-nav ul,.site-menu{list-style:none; margin:0; padding:0; display:flex; gap:10px; align-items:center}
.site-nav a{
  color:#dfe8f3; font-weight:600; font-size:.98rem;
  display:inline-flex; align-items:center; justify-content:center;
  min-height:44px; padding:0 16px; border-radius:999px;
  border:1px solid transparent; transition:.2s ease;
}
.site-nav .current-menu-item > a,
.site-nav .current_page_item > a,
.site-nav a:hover{
  color:var(--accent-2);
  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:46px;
  padding:0 18px; border-radius:14px; font-weight:700;
  color:#07131c; background:var(--accent);
}
.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}
.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(2.5rem,5vw,4.7rem); 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.9rem,3vw,2.9rem)}
.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(2rem,4vw,3.3rem); margin:0 0 12px}
.page-hero p{max-width:780px; color:var(--muted)}
.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:36px 0 52px; color:#a8b9cb; border-top:1px solid var(--line)}
.small{font-size:.95rem; color:var(--muted)}
@media (max-width: 1100px){
  .archive-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 980px){
  .hero-grid,.grid-3,.grid-2,.portal-grid,.tax-grid,.post-grid,.split-layout{grid-template-columns:1fr}
  .branding img{width:175px}
  .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}
}
@media (max-width: 700px){
  .header-inner{flex-direction:column; 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}
}
