/* ============================================================
   Names Engine — design system
   Direction: "etymology nameplate" — a names dictionary with a
   premium editorial feel. Plum + brass on cool ivory.
   ============================================================ */

:root{
  --bg:        #f5f4f8;   /* cool ivory */
  --surface:   #ffffff;
  --ink:       #211a2b;   /* deep plum-black, body text */
  --muted:     #6b6478;
  --brand:     #5b3e8e;   /* royal plum */
  --brand-deep:#2e1f47;
  --brand-soft:#efeaf6;
  --accent:    #b88a1e;   /* brass gold */
  --accent-soft:#f6edd6;
  --line:      #e7e3ee;
  --boy:       #2f6f8f;
  --girl:      #a8466e;
  --unisex:    #5b3e8e;
  --radius:    14px;
  --radius-sm: 9px;
  --shadow:    0 1px 2px rgba(33,26,43,.04), 0 8px 28px -12px rgba(46,31,71,.18);
  --wrap:      1120px;
  --ff-display:"Fraunces", Georgia, serif;
  --ff-body:   "Plus Jakarta Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--ff-body); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; height:auto; display:block}
a{color:var(--brand); text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--ff-display); line-height:1.12; font-weight:600; letter-spacing:-.01em}
.wrap{max-width:var(--wrap); margin-inline:auto; padding-inline:20px}
.muted{color:var(--muted)}
.skip{position:absolute; left:-999px}
.skip:focus{left:12px; top:12px; background:var(--surface); padding:10px 14px; border-radius:8px; z-index:50}
:focus-visible{outline:3px solid var(--accent); outline-offset:2px; border-radius:4px}

/* ---------- Header ---------- */
.site-header{position:sticky; top:0; z-index:40; background:rgba(245,244,248,.85);
  backdrop-filter:saturate(1.4) blur(10px); border-bottom:1px solid var(--line)}
.header-inner{display:flex; align-items:center; gap:24px; height:66px}
.brand{display:inline-flex; align-items:center; gap:10px; color:var(--ink); font-weight:700}
.brand:hover{text-decoration:none}
.brand-name{font-family:var(--ff-display); font-size:1.25rem; letter-spacing:-.02em}
.main-nav{margin-left:auto; display:flex; gap:22px}
.main-nav a{color:var(--ink); font-weight:500; font-size:.97rem}
.main-nav a:hover{color:var(--brand); text-decoration:none}
.nav-toggle{display:none; margin-left:auto; font-size:1.5rem; background:none; border:0; color:var(--ink); cursor:pointer}

/* ---------- Hero (signature nameplate) ---------- */
.hero{position:relative; padding:64px 0 52px; overflow:hidden}
.hero::before{content:""; position:absolute; inset:0;
  background:
    radial-gradient(60% 90% at 85% -10%, var(--brand-soft), transparent 60%),
    radial-gradient(40% 70% at 0% 110%, var(--accent-soft), transparent 55%);
  z-index:-1}
.hero .eyebrow{font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--accent); font-weight:700}
.hero h1{font-size:clamp(2.4rem,5.5vw,4rem); margin:.3em 0 .2em; max-width:14ch}
.hero h1 em{font-style:italic; color:var(--brand)}
.hero .lede{font-size:1.15rem; color:var(--muted); max-width:48ch; margin:0 0 28px}

/* the dictionary-style nameplate that animates on load */
.nameplate{display:inline-flex; flex-direction:column; gap:2px; padding:14px 20px;
  background:var(--surface); border:1px solid var(--line); border-left:4px solid var(--accent);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0; box-shadow:var(--shadow);
  margin-top:30px; animation:rise .6s ease both}
.nameplate .np-head{font-family:var(--ff-display); font-size:1.6rem; font-weight:600}
.nameplate .np-pron{color:var(--muted); font-style:italic; font-size:.95rem}
.nameplate .np-mean{font-size:.95rem}
@keyframes rise{from{opacity:0; transform:translateY(10px)} to{opacity:1; transform:none}}
@media (prefers-reduced-motion:reduce){.nameplate{animation:none}}

/* ---------- Search box ---------- */
.search{position:relative; max-width:560px}
.search input{width:100%; font-size:1.05rem; font-family:var(--ff-body);
  padding:16px 18px 16px 48px; border:1.5px solid var(--line); border-radius:var(--radius);
  background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none' stroke='%236b6478' stroke-width='2' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m20 20-3-3'/%3E%3C/svg%3E") 16px center no-repeat;
  box-shadow:var(--shadow)}
.search input:focus{border-color:var(--brand); outline:none}
.search-results{position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow);
  overflow:hidden; z-index:30; display:none}
.search-results.open{display:block}
.search-results a{display:flex; justify-content:space-between; gap:12px; align-items:baseline;
  padding:12px 16px; color:var(--ink); border-bottom:1px solid var(--line)}
.search-results a:last-child{border-bottom:0}
.search-results a:hover{background:var(--brand-soft); text-decoration:none}
.search-results .sr-name{font-family:var(--ff-display); font-weight:600}
.search-results .sr-mean{color:var(--muted); font-size:.85rem; text-align:right}

/* ---------- Sections ---------- */
.section{padding:48px 0}
.section-head{display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:22px}
.section-head h2{font-size:1.7rem; margin:0}
.section-head .kicker{font-size:.76rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); font-weight:700; display:block; margin-bottom:4px}
.section-head a{font-size:.92rem; font-weight:600; white-space:nowrap}

/* ---------- Name cards (dictionary entries) ---------- */
.name-grid{display:grid; gap:14px; grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.name-card{position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 18px 16px; box-shadow:var(--shadow);
  transition:transform .18s ease, box-shadow .18s ease}
.name-card:hover{transform:translateY(-3px); box-shadow:0 12px 30px -14px rgba(46,31,71,.35); text-decoration:none}
.name-card .nc-name{font-family:var(--ff-display); font-size:1.35rem; font-weight:600; color:var(--ink)}
.name-card .nc-mean{color:var(--muted); font-size:.92rem; margin-top:2px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden}
.gender-pill{display:inline-block; font-size:.68rem; letter-spacing:.06em; text-transform:uppercase;
  font-weight:700; padding:3px 9px; border-radius:999px; margin-bottom:8px}
.gender-pill.boy{background:#e4eff4; color:var(--boy)}
.gender-pill.girl{background:#f7e6ee; color:var(--girl)}
.gender-pill.unisex{background:var(--brand-soft); color:var(--unisex)}

/* ---------- Pills / chips row ---------- */
.chip-row{display:flex; flex-wrap:wrap; gap:10px}
.chip{display:inline-block; padding:9px 16px; background:var(--surface); border:1px solid var(--line);
  border-radius:999px; color:var(--ink); font-size:.92rem; font-weight:500; box-shadow:var(--shadow)}
.chip:hover{border-color:var(--brand); color:var(--brand); text-decoration:none}

/* ---------- Name detail page ---------- */
.breadcrumb{font-size:.85rem; color:var(--muted); padding:18px 0 0}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--brand)}
.name-hero{padding:18px 0 34px}
.name-hero .display{font-family:var(--ff-display); font-size:clamp(2.6rem,7vw,4.4rem); margin:.1em 0}
.name-hero .pron{color:var(--muted); font-style:italic; font-size:1.1rem}
.fact-grid{display:grid; gap:12px; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); margin:26px 0}
.fact{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-sm); padding:14px 16px}
.fact .label{font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); font-weight:700}
.fact .value{font-weight:600; margin-top:2px}
.prose{max-width:72ch}
.prose h2{font-size:1.5rem; margin:1.6em 0 .5em}
.prose p{margin:0 0 1em}
.faq{border-top:1px solid var(--line); margin-top:32px}
.faq details{border-bottom:1px solid var(--line); padding:6px 0}
.faq summary{cursor:pointer; font-family:var(--ff-display); font-weight:600; font-size:1.08rem; padding:12px 0; list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+"; float:right; color:var(--accent); font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 14px; margin:0; color:var(--muted)}

/* ---------- A–Z nav ---------- */
.az-nav{display:flex; flex-wrap:wrap; gap:6px; margin:20px 0 30px}
.az-nav a{width:38px; height:38px; display:grid; place-items:center; background:var(--surface);
  border:1px solid var(--line); border-radius:9px; font-weight:600; color:var(--ink)}
.az-nav a.is-active{background:var(--brand); color:#fff; border-color:var(--brand)}
.az-nav a:hover{border-color:var(--brand); text-decoration:none}

/* ---------- Pagination ---------- */
.pager ul{list-style:none; display:flex; gap:6px; padding:0; margin:34px 0 0; justify-content:center; flex-wrap:wrap}
.pager a{display:block; padding:9px 14px; background:var(--surface); border:1px solid var(--line);
  border-radius:9px; color:var(--ink); font-weight:600}
.pager .is-active a{background:var(--brand); color:#fff; border-color:var(--brand)}
.pager a:hover{border-color:var(--brand); text-decoration:none}

/* ---------- CTA / newsletter ---------- */
.callout{background:var(--brand-deep); color:#fff; border-radius:var(--radius); padding:40px;
  display:flex; gap:24px; align-items:center; justify-content:space-between; flex-wrap:wrap}
.callout h2{color:#fff; margin:0}
.callout p{color:#d8cfe6; margin:.4em 0 0}
.btn{display:inline-block; background:var(--accent); color:#241500; font-weight:700;
  padding:13px 22px; border-radius:10px; border:0; cursor:pointer; font-size:1rem; font-family:var(--ff-body)}
.btn:hover{filter:brightness(1.06); text-decoration:none}
.btn--ghost{background:transparent; color:var(--brand); border:1.5px solid var(--brand)}

/* ---------- Footer ---------- */
.site-footer{background:var(--surface); border-top:1px solid var(--line); margin-top:60px; padding-top:48px}
.footer-grid{display:grid; gap:30px; grid-template-columns:1.4fr repeat(3,1fr); padding-bottom:34px}
.footer-grid h3{font-size:.95rem; margin:0 0 12px}
.footer-grid nav a{display:block; color:var(--muted); padding:4px 0; font-size:.93rem}
.footer-grid nav a:hover{color:var(--brand)}
.brand--footer .brand-name{font-size:1.1rem}
.footer-base{border-top:1px solid var(--line); padding:18px 0; color:var(--muted)}

/* ---------- Forms (search page + admin reuse) ---------- */
.field{margin-bottom:14px}
.field label{display:block; font-size:.85rem; font-weight:600; margin-bottom:5px}
.field input,.field select,.field textarea{width:100%; padding:11px 13px; border:1.5px solid var(--line);
  border-radius:9px; font-family:var(--ff-body); font-size:1rem; background:var(--surface); color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand); outline:none}
.filters{display:grid; gap:12px; grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:18px; margin-bottom:24px}

/* ---------- Layout helpers ---------- */
.two-col{display:grid; grid-template-columns:1fr 320px; gap:40px}
.split{display:grid; gap:30px; grid-template-columns:1fr 1fr}

/* ---------- Responsive (mobile first refinements) ---------- */
@media (max-width:820px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
}
@media (max-width:640px){
  body{font-size:16px}
  .main-nav{display:none}
  .main-nav.open{display:flex; position:absolute; top:66px; left:0; right:0; flex-direction:column;
    background:var(--surface); border-bottom:1px solid var(--line); padding:14px 20px; gap:14px}
  .nav-toggle{display:block}
  .callout{padding:26px}
  .footer-grid{grid-template-columns:1fr 1fr; gap:22px}
}

/* ============================================================
   Name detail page
   ============================================================ */
.name-head{padding-top:8px}
.name-title{font-size:clamp(2.4rem,6vw,3.4rem); margin:.18em 0 .1em}
.name-pron{color:var(--muted); font-size:1.1rem; margin:0 0 .4em}
.name-mean{font-size:1.22rem; color:var(--brand-deep); margin:0; max-width:60ch}
.name-aside{display:flex; flex-direction:column; gap:22px}
.aside-block{background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 20px}
.aside-block h2{font-size:1.05rem; margin:0 0 10px}
.link-list{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px}
.link-list li{font-size:.97rem; line-height:1.4}
.link-list .muted{font-size:.88rem}

/* ============================================================
   Blog
   ============================================================ */
.post-grid{display:grid; gap:24px; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); margin-top:8px}
.post-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow); transition:transform .15s ease}
.post-card:hover{transform:translateY(-3px)}
.post-thumb img{width:100%; height:180px; object-fit:cover}
.post-body{padding:18px 20px}
.post-body h2{font-size:1.2rem; margin:0 0 8px}
.post-body h2 a{color:var(--ink)}
.post-meta{font-size:.85rem; color:var(--muted); margin:10px 0 0}
.post-hero{width:100%; height:auto; border-radius:var(--radius); margin-top:20px; object-fit:cover}

/* ============================================================
   Error pages
   ============================================================ */
.error-page{text-align:center; padding:60px 0}
.error-code{font-family:var(--ff-display); font-size:5rem; font-weight:700;
  color:var(--brand); line-height:1; display:block}
.error-page h1{font-size:2rem; margin:.2em 0 .3em}
.error-page .btn{margin:0 6px}

/* ============================================================
   Auth (blank layout)
   ============================================================ */
.blank-body{background:linear-gradient(160deg,var(--brand-soft),var(--bg)); min-height:100vh}
.blank-main{min-height:100vh; display:grid; place-items:center; padding:24px}
.blank-card{background:var(--surface); border:1px solid var(--line); border-radius:18px;
  padding:34px 32px; width:100%; max-width:400px; box-shadow:var(--shadow)}
.alert{padding:11px 14px; border-radius:9px; font-size:.92rem; margin-bottom:16px}
.alert--error{background:#fdecec; color:#9b2c2c; border:1px solid #f5c2c2}

/* ============================================================
   Admin
   ============================================================ */
.admin-body{background:var(--bg)}
.admin-shell{display:grid; grid-template-columns:240px 1fr; min-height:100vh}
.admin-side{background:var(--brand-deep); color:#e9e3f4; display:flex; flex-direction:column;
  padding:22px 18px; position:sticky; top:0; height:100vh}
.brand--admin{color:#fff; margin-bottom:26px}
.brand--admin .brand-name{color:#fff}
.admin-nav{display:flex; flex-direction:column; gap:4px; flex:1}
.admin-nav a{color:#ccc1e4; padding:10px 12px; border-radius:9px; font-weight:500; font-size:.96rem}
.admin-nav a:hover{background:rgba(255,255,255,.08); text-decoration:none; color:#fff}
.admin-nav a.is-active{background:var(--brand); color:#fff}
.admin-side-foot{border-top:1px solid rgba(255,255,255,.12); padding-top:14px; display:flex;
  flex-direction:column; gap:6px; font-size:.88rem}
.admin-side-foot .muted{color:#a89bc4}
.admin-logout{color:#e8b0b0; font-weight:600}
.admin-main{display:flex; flex-direction:column; min-width:0}
.admin-topbar{background:var(--surface); border-bottom:1px solid var(--line); padding:18px 30px}
.admin-topbar h1{font-size:1.5rem; margin:0}
.admin-content{padding:28px 30px}

.stat-grid{display:grid; gap:16px; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); margin-bottom:26px}
.stat-card{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:20px}
.stat-value{font-family:var(--ff-display); font-size:2rem; font-weight:700; color:var(--brand)}
.stat-label{font-size:.82rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-top:2px}

.admin-cols{display:grid; gap:22px; grid-template-columns:1fr 1fr}
.panel{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius);
  padding:20px 22px; margin-bottom:22px}
.panel-title{font-size:1.1rem; margin:0 0 16px}
.panel-head{display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:14px}
.panel-head h2{font-size:1.15rem; margin:0}

.table{width:100%; border-collapse:collapse; font-size:.94rem}
.table th{text-align:left; font-size:.74rem; text-transform:uppercase; letter-spacing:.07em;
  color:var(--muted); border-bottom:2px solid var(--line); padding:8px 10px}
.table td{padding:11px 10px; border-bottom:1px solid var(--line); vertical-align:middle}
.table .num{text-align:right}
.row-actions a, .row-actions .link-danger{margin-left:12px; font-size:.9rem}
.link-danger{background:none; border:0; color:#b3261e; cursor:pointer; font:inherit; padding:0}
.link-danger:hover{text-decoration:underline}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:.82rem}

.status-tag{font-size:.74rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
  padding:3px 9px; border-radius:20px}
.status-published{background:#e4f3ea; color:#1f7a45}
.status-draft{background:#f3eede; color:#8a6d12}
.status-archived{background:#efeaf0; color:#776}

.btn--sm{padding:7px 14px; font-size:.86rem}
.admin-search{display:flex; gap:8px; flex:1; max-width:420px}
.admin-search input{flex:1; padding:9px 12px; border:1.5px solid var(--line); border-radius:9px;
  font:inherit; background:var(--surface)}

.admin-form .form-grid{display:grid; gap:14px; grid-template-columns:1fr 1fr}
.admin-form .req{color:#b3261e}
.form-actions{display:flex; gap:10px; align-items:center; margin-top:6px}

@media (max-width:900px){
  .admin-shell{grid-template-columns:1fr}
  .admin-side{position:static; height:auto; flex-direction:row; align-items:center; flex-wrap:wrap; gap:10px}
  .admin-side .brand--admin{margin-bottom:0}
  .admin-nav{flex-direction:row; flex-wrap:wrap}
  .admin-side-foot{border-top:0; padding-top:0; flex-direction:row; margin-left:auto}
  .admin-cols{grid-template-columns:1fr}
  .admin-form .form-grid{grid-template-columns:1fr}
}
