/*
Theme Name: Legitimate Baby Names
Theme URI: https://legitimatebabynames.com
Description: A clean, elegant, easy-to-navigate theme for Legitimate Baby Names. Features A–Z browsing, browse-by-theme and browse-by-language/origin, a refined name-entry layout, and built-in ad slots. Designed and built for legitimatebabynames.com.
Author: Manus for Sebastiane
Version: 1.0.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: legit-revamp
*/

:root{
  --max:1180px;
  --radius:14px;
  --shadow:0 6px 24px rgba(0,0,0,.08);
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --bg:#faf7f1;
  --surface:#ffffff;
  --ink:#23291f;
  --muted:#6d7466;
  --accent:#3f6b4d;       /* deep sage green */
  --accent-2:#b8945f;     /* warm gold */
  --line:#e7e0d3;
  --chip:#f0ebe0;
  --serif:"Cormorant Garamond","Georgia",serif;
  --sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);line-height:1.6;font-size:16px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
.skip-link{position:absolute;left:-9999px}

/* header */
header.masthead{background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.topbar{display:flex;align-items:center;gap:18px;padding:14px 20px;max-width:var(--max);margin:0 auto}
.brand{display:flex;flex-direction:column;line-height:1.05}
.brand .name{font-family:var(--serif);font-weight:700;font-size:26px;letter-spacing:.01em;color:var(--accent);text-decoration:none}
.brand .custom-logo,.custom-logo{max-height:56px;width:auto;display:block}
.brand img{max-height:56px;width:auto}
.brand .tag{font-size:12px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase}
.search{margin-left:auto;display:flex;align-items:center;background:var(--bg);border:1px solid var(--line);border-radius:99px;padding:8px 16px;min-width:230px}
.search input{border:0;background:transparent;outline:0;width:100%;font-size:14px;color:var(--ink)}
.search button{border:0;background:transparent;cursor:pointer;color:var(--muted);font-size:14px;padding:0;margin-right:8px}

/* nav */
nav.mainnav{border-top:1px solid var(--line);background:var(--surface)}
nav.mainnav .wrap{display:flex;gap:6px;flex-wrap:wrap;padding-top:6px;padding-bottom:6px;align-items:center}
nav.mainnav a{padding:10px 16px;font-size:14px;font-weight:500;color:var(--ink);border-radius:8px;text-decoration:none}
nav.mainnav a:hover{background:var(--chip);color:var(--accent);text-decoration:none}
nav.mainnav a.active{color:var(--accent);background:var(--chip)}
.navtoggle{display:none}

/* hero */
.hero{padding:54px 0 30px;text-align:center}
.hero h1{font-family:var(--serif);font-size:clamp(34px,5vw,54px);line-height:1.05;margin:0 0 14px;font-weight:700}
.hero p{max-width:620px;margin:0 auto 26px;color:var(--muted);font-size:18px}
.azbar{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;max-width:760px;margin:0 auto}
.azbar a{width:38px;height:38px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--line);border-radius:10px;font-weight:600;font-size:14px;box-shadow:var(--shadow-sm);text-decoration:none;color:var(--ink)}
.azbar a:hover{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}

/* section heading */
.sec{padding:34px 0}
.sec h2{font-family:var(--serif);font-size:30px;margin:0 0 4px;font-weight:700}
.sec .sub{color:var(--muted);margin:0 0 22px;font-size:15px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}
.sec-head h2{margin:0}
.viewall{font-size:13px;font-weight:600;color:var(--accent);white-space:nowrap;text-decoration:none}

/* cards grid */
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;text-decoration:none;color:var(--ink);display:block}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.card h3{margin:0 0 4px;font-family:var(--serif);font-size:21px;font-weight:700}
.card .meta{font-size:13px;color:var(--muted)}
.card .count{display:inline-block;margin-top:10px;font-size:12px;font-weight:600;color:var(--accent);background:var(--chip);padding:3px 10px;border-radius:99px}

/* name tiles */
.tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.tile{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:2px;text-decoration:none;color:var(--ink)}
.tile:hover{border-color:var(--accent);background:var(--chip);text-decoration:none}
.tile .n{font-family:var(--serif);font-weight:700;font-size:18px}
.tile .o{font-size:12px;color:var(--muted)}
.tile .d{font-size:11px;color:var(--accent-2);margin-top:2px}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:99px;padding:7px 14px;font-size:13.5px;font-weight:500;text-decoration:none;color:var(--ink)}
.chip:hover{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}
.chip .c{color:var(--muted);font-size:11px;margin-left:6px}
.chip:hover .c{color:rgba(255,255,255,.8)}

/* alpha index */
.az-strip{position:sticky;top:58px;z-index:5;background:var(--bg);padding:12px 0;border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;gap:5px;justify-content:center}
.az-strip a{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;font-weight:600;font-size:13px;background:var(--surface);border:1px solid var(--line);text-decoration:none;color:var(--ink)}
.az-strip a:hover,.az-strip a.on{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}
.letter-block{margin:26px 0}
.letter-block h3{font-family:var(--serif);font-size:26px;color:var(--accent);border-bottom:2px solid var(--line);padding-bottom:6px;margin:0 0 14px}

/* ad slot */
.ad-slot{margin:22px auto;text-align:center;min-height:90px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.ad-slot.box{min-height:250px}
.ad-ph{background:repeating-linear-gradient(45deg,#f3f1ea,#f3f1ea 12px,#efece3 12px,#efece3 24px);border:1px dashed #c9c2b0;border-radius:12px;display:grid;place-items:center;color:#9a927e;font-size:12px;letter-spacing:.08em;text-transform:uppercase;text-align:center;width:100%;padding:30px 10px}

/* name detail */
.namepage{display:grid;grid-template-columns:1fr 320px;gap:30px;padding:30px 0}
.namehead{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.namehead h1{font-family:var(--serif);font-size:52px;margin:0;font-weight:700}
.namehead .pron{color:var(--muted);font-style:italic;font-size:18px}
.factbar{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 6px}
.fact{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:10px 16px}
.fact .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.fact .v{font-weight:600;font-family:var(--serif);font-size:17px}
.namebody{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:26px 30px;margin-top:18px;box-shadow:var(--shadow-sm)}
.namebody h2,.namebody h4{font-family:var(--serif)}
.namebody h4{font-size:20px;margin:22px 0 8px}
.namebody p{margin:0 0 14px}
.namebody img{border-radius:10px}
aside .panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
aside .panel h4{margin:0 0 12px;font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-family:var(--sans)}
.taglist{display:flex;flex-wrap:wrap;gap:7px}
.taglist a{font-size:12.5px;background:var(--chip);border-radius:99px;padding:5px 12px;text-decoration:none;color:var(--ink)}
.taglist a:hover{background:var(--accent);color:#fff}

/* generic page / archive */
.pagehead{padding:40px 0 10px;text-align:center}
.pagehead h1{font-family:var(--serif);font-size:clamp(30px,4vw,44px);margin:0 0 8px}
.pagehead p{color:var(--muted);margin:0 auto;max-width:620px}
.breadcrumb{font-size:13px;color:var(--muted);padding:14px 0 0}
.breadcrumb a{color:var(--muted)}
.pagination{display:flex;gap:8px;justify-content:center;margin:30px 0;flex-wrap:wrap}
.pagination .page-numbers{padding:8px 14px;border:1px solid var(--line);border-radius:8px;background:var(--surface);text-decoration:none;color:var(--ink)}
.pagination .page-numbers.current{background:var(--accent);color:#fff;border-color:var(--accent)}
.content-narrow{max-width:760px;margin:0 auto;padding:20px 0 10px}
.content-narrow h1,.content-narrow h2,.content-narrow h3{font-family:var(--serif)}

/* footer */
footer.foot{background:var(--ink);color:#e9e6df;margin-top:50px;padding:40px 0 30px}
footer.foot a{color:#c8c4ba;font-size:14px;display:block;padding:3px 0;text-decoration:none}
footer.foot a:hover{color:#fff}
footer.foot .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px}
footer.foot .name{font-family:var(--serif);font-size:22px;color:#fff;margin-bottom:8px}
footer.foot h5{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:#fff;margin:0 0 8px;opacity:.7}
footer.foot .copy{border-top:1px solid rgba(255,255,255,.12);margin-top:26px;padding-top:18px;font-size:12.5px;color:#8f8b81;text-align:center}

@media(max-width:860px){
  .namepage{grid-template-columns:1fr}
  .grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .search{min-width:auto;flex:1}
  .namehead h1{font-size:40px}
  footer.foot .cols{grid-template-columns:1fr}
}
@media(max-width:560px){
  .grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}
  .topbar{flex-wrap:wrap}
}

/* ---------- Masterlist (navigable culture/language lists) ---------- */
.masterlist-body{max-width:1000px}
.masterlist-body img.aligncenter{display:block;margin:0 auto 18px;max-width:160px;height:auto}
.masterlist-body p{font-size:16px;color:#4a4f43}
.ml-secnav{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 6px}
.ml-secnav a{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--accent);background:var(--chip);padding:6px 16px;border-radius:99px;text-decoration:none}
.ml-secnav a:hover{background:var(--accent);color:#fff;text-decoration:none}
.ml-azbar{position:sticky;top:96px;z-index:30;display:flex;flex-wrap:wrap;gap:5px;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:10px;margin:10px 0 24px;box-shadow:var(--shadow-sm)}
.ml-azbar a{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;font-weight:600;font-size:13px;text-decoration:none}
.ml-azbar a.on{color:var(--ink);background:var(--bg);border:1px solid var(--line)}
.ml-azbar a.on:hover{background:var(--accent);color:#fff;border-color:var(--accent);text-decoration:none}
.ml-azbar a.off{color:#c9c4b8;background:transparent;cursor:default;pointer-events:none}
.ml-section{margin:0 0 34px}
.ml-section-title{font-family:var(--serif);font-size:30px;color:var(--accent);border-bottom:2px solid var(--line);padding-bottom:8px;margin:30px 0 18px}
.ml-letter-group{margin:0 0 18px;scroll-margin-top:150px}
.ml-letter-head{font-family:var(--serif);font-weight:700;font-size:20px;color:var(--accent-2);background:var(--chip);width:40px;height:40px;display:grid;place-items:center;border-radius:8px;margin-bottom:10px}
ul.ml-names{list-style:none;margin:0;padding:0;columns:4;column-gap:26px}
ul.ml-names li{break-inside:avoid;padding:3px 0;font-size:15.5px;line-height:1.5;border-bottom:1px solid #f0ece2}
ul.ml-names li a{text-decoration:none}
ul.ml-names li a:hover{text-decoration:underline}
@media(max-width:900px){ul.ml-names{columns:3}}
@media(max-width:640px){ul.ml-names{columns:2};.ml-azbar{top:80px}}
@media(max-width:420px){ul.ml-names{columns:1}}
