/* PassphraseMaker — shared styles */
:root{
  --bg:#f3f8f5;
  --card:#ffffff;
  --field:#eaf2ee;
  --border:#d7e4dd;
  --border-strong:#bcd0c7;
  --ink:#15302a;
  --body:#394a44;
  --soft:#586b63;
  --accent:#1f8a6d;
  --accent-deep:#13674f;
  --accent2:#e08a2c;
  --danger:#c0392b;
  --warn:#b8791b;
  --ok:#1f8a6d;
  --radius:16px;
  --maxw:1040px;
}

*,*::before,*::after{box-sizing:border-box}
html{font-size:100%;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--body);
  font-family:"Nunito",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-weight:400;
  font-size:1.0625rem;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{
  font-family:"Fraunces",Georgia,"Times New Roman",serif;
  color:var(--ink);
  font-weight:600;
  line-height:1.18;
  margin:0 0 .5em;
  font-optical-sizing:auto;
}
h1{font-size:clamp(2rem,5vw,3rem)}
h2{font-size:clamp(1.5rem,3.5vw,2.1rem);margin-top:1.6em}
h3{font-size:clamp(1.2rem,2.5vw,1.45rem);margin-top:1.4em}
p{margin:0 0 1.1em}
a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px}
a:hover{text-decoration:none}
strong{font-weight:700;color:var(--ink)}
small,.soft{color:var(--soft)}
code,kbd,samp{font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace}
img,svg{max-width:100%;height:auto}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* Skip link */
.skip{
  position:absolute;left:-9999px;top:0;background:var(--accent-deep);color:#fff;
  padding:12px 18px;border-radius:0 0 var(--radius) 0;z-index:200;text-decoration:none;
}
.skip:focus{left:0}

/* Focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,[tabindex]:focus-visible,summary:focus-visible{
  outline:3px solid var(--accent);
  outline-offset:2px;
  border-radius:8px;
}

/* Header / nav */
.site-header{
  background:var(--card);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:12px 20px;max-width:var(--maxw);margin:0 auto;
}
.brand{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Fraunces",serif;font-weight:600;font-size:1.3rem;
  color:var(--ink);text-decoration:none;
}
.brand svg{display:block}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;flex-wrap:wrap}
.nav-links a{
  color:var(--body);text-decoration:none;font-weight:600;
  padding:10px 12px;border-radius:10px;display:inline-block;
}
.nav-links a:hover{background:var(--field);color:var(--ink)}
.nav-links a[aria-current="page"]{color:var(--accent-deep);background:var(--field)}
.nav-cta{
  background:var(--accent-deep)!important;color:#fff!important;
}
.nav-cta:hover{background:var(--accent)!important;color:#fff!important}
.nav-toggle{
  display:none;background:var(--field);border:1px solid var(--border-strong);
  border-radius:10px;padding:10px;min-height:44px;min-width:44px;cursor:pointer;
}
.nav-toggle svg{display:block;color:var(--ink)}

@media (max-width:760px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;background:var(--card);
    border-bottom:1px solid var(--border);padding:10px 16px 16px;gap:2px;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:14px 12px}
  .nav{position:relative}
}

/* Main */
main{display:block}
section{padding:0}
.section{padding:56px 0}
.section-tight{padding:36px 0}

/* Hero */
.hero{
  padding:64px 0 40px;
  background:linear-gradient(180deg,#eef7f2 0%,var(--bg) 100%);
}
.hero-grid{display:grid;grid-template-columns:1fr;gap:36px;align-items:start}
@media (min-width:900px){.hero-grid{grid-template-columns:1.05fr 1fr;gap:48px}}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:700;color:var(--accent-deep);background:var(--field);
  border:1px solid var(--border);border-radius:999px;
  padding:6px 14px;font-size:.9rem;margin-bottom:18px;
}
.hero p.lead{font-size:1.2rem;color:var(--body);max-width:38ch}
.lead{font-size:1.18rem}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:"Nunito",sans-serif;font-weight:700;font-size:1.05rem;
  background:var(--accent-deep);color:#fff;border:2px solid var(--accent-deep);
  border-radius:12px;padding:13px 22px;min-height:48px;cursor:pointer;
  text-decoration:none;line-height:1.1;transition:background .15s,border-color .15s;
}
.btn:hover{background:var(--accent);border-color:var(--accent);color:#fff;text-decoration:none}
.btn-secondary{
  background:var(--card);color:var(--accent-deep);border:2px solid var(--border-strong);
}
.btn-secondary:hover{background:var(--field);color:var(--accent-deep);border-color:var(--accent)}
.btn-ghost{
  background:transparent;color:var(--accent-deep);border:2px solid transparent;
}
.btn-ghost:hover{background:var(--field);color:var(--accent-deep)}
.btn-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}

/* Cards */
.card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:28px;
}
.card-soft{background:var(--field);border:1px solid var(--border)}
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:1fr}
@media (min-width:760px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.grid-2{grid-template-columns:1fr}
@media (min-width:760px){.grid-2{grid-template-columns:repeat(2,1fr)}}

.feature h3{margin-top:0;display:flex;align-items:center;gap:10px}
.feature .ico{
  display:inline-flex;width:40px;height:40px;align-items:center;justify-content:center;
  background:var(--field);border:1px solid var(--border);border-radius:12px;color:var(--accent-deep);
  flex:0 0 auto;
}

/* Generator */
.gen{
  background:var(--card);border:1px solid var(--border-strong);
  border-radius:var(--radius);padding:24px;
  box-shadow:0 8px 28px -18px rgba(19,103,79,.35);
}
.gen-title{display:flex;align-items:center;gap:10px;margin:0 0 4px;font-size:1.35rem}
.gen-out-wrap{margin:10px 0 6px}
.gen-output{
  display:block;width:100%;
  background:var(--field);border:1px solid var(--border-strong);
  border-radius:12px;padding:18px 16px;
  font-family:"JetBrains Mono",monospace;font-weight:700;
  font-size:clamp(1.15rem,3.5vw,1.7rem);color:var(--ink);
  word-break:break-all;line-height:1.4;
  user-select:all;-webkit-user-select:all;
  min-height:64px;
}
.gen-hint{font-size:.95rem;color:var(--soft);margin:8px 0 0}
.gen-hint strong{color:var(--body)}

.strength{margin:18px 0 6px}
.strength-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:6px}
.strength-label{font-weight:700}
.strength-bits{font-family:"JetBrains Mono",monospace;font-size:.9rem;color:var(--soft)}
.bar{height:12px;border-radius:999px;background:var(--field);border:1px solid var(--border);overflow:hidden}
.bar-fill{height:100%;width:0;border-radius:999px;transition:width .25s ease}
.lvl-weak{color:var(--danger)}
.lvl-fair{color:var(--warn)}
.lvl-ok{color:var(--ok)}
.fill-weak{background:var(--danger)}
.fill-fair{background:var(--warn)}
.fill-ok{background:var(--ok)}

.controls{display:grid;gap:18px;margin-top:20px}
.control label,.control legend{font-weight:700;color:var(--ink);display:block;margin-bottom:6px}
.control .desc{font-size:.9rem;color:var(--soft);margin:0 0 8px;font-weight:400}
.range-row{display:flex;align-items:center;gap:14px}
input[type="range"]{flex:1;accent-color:var(--accent-deep);height:32px}
.range-val{
  font-family:"JetBrains Mono",monospace;font-weight:700;color:var(--ink);
  background:var(--field);border:1px solid var(--border);border-radius:10px;
  padding:6px 12px;min-width:48px;text-align:center;
}
select,input[type="text"],input[type="email"],textarea{
  width:100%;font-family:"Nunito",sans-serif;font-size:1rem;color:var(--ink);
  background:var(--field);border:1px solid var(--border-strong);border-radius:12px;
  padding:12px 14px;min-height:48px;
}
textarea{min-height:120px;resize:vertical}
.toggles{display:grid;gap:12px}
@media (min-width:560px){.toggles{grid-template-columns:repeat(3,1fr)}}
.toggle{
  display:flex;align-items:center;gap:10px;background:var(--field);
  border:1px solid var(--border);border-radius:12px;padding:12px 14px;
  min-height:48px;cursor:pointer;font-weight:600;color:var(--ink);
}
.toggle input{width:20px;height:20px;accent-color:var(--accent-deep);flex:0 0 auto}
.gen-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}
.gen-note{
  display:flex;align-items:flex-start;gap:10px;margin-top:18px;
  background:var(--field);border:1px solid var(--border);border-radius:12px;
  padding:12px 14px;font-size:.95rem;color:var(--body);
}
.gen-note svg{flex:0 0 auto;color:var(--accent-deep);margin-top:2px}
.gen-error{color:var(--danger);font-weight:700;margin-top:10px}

/* FAQ */
.faq{display:grid;gap:12px}
.faq details{
  background:var(--card);border:1px solid var(--border);border-radius:12px;
  padding:4px 18px;
}
.faq summary{
  cursor:pointer;font-weight:700;color:var(--ink);padding:14px 0;
  font-family:"Fraunces",serif;font-size:1.1rem;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:"JetBrains Mono",monospace;color:var(--accent-deep);font-size:1.4rem}
.faq details[open] summary::after{content:"–"}
.faq details p{margin:0 0 16px}

/* Blog */
.post-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;display:flex;flex-direction:column;height:100%;
}
.post-card h3{margin-top:0}
.post-card h3 a{color:var(--ink);text-decoration:none}
.post-card h3 a:hover{color:var(--accent-deep)}
.meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:.85rem;color:var(--soft);margin-bottom:12px}
.tag{
  display:inline-block;background:var(--field);border:1px solid var(--border);
  color:var(--accent-deep);font-weight:700;border-radius:999px;padding:3px 10px;font-size:.78rem;
}
.post-card .excerpt{flex:1}
.read-more{font-weight:700;text-decoration:none}
.read-more:hover{text-decoration:underline}

/* Article */
.article{max-width:760px;margin:0 auto;padding:48px 20px}
.article .meta{font-size:.92rem}
.article p{font-size:1.08rem}
.article ul,.article ol{margin:0 0 1.2em;padding-left:1.4em}
.article li{margin-bottom:.5em}
.breadcrumb{font-size:.9rem;color:var(--soft);margin-bottom:18px}
.breadcrumb a{color:var(--accent-deep)}
.callout{
  background:var(--field);border:1px solid var(--border);border-left:4px solid var(--accent);
  border-radius:12px;padding:18px 20px;margin:24px 0;
}
.callout p:last-child{margin-bottom:0}
.author-box{
  display:flex;gap:16px;align-items:flex-start;background:var(--card);
  border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin:28px 0;
}
.author-box .avatar{
  flex:0 0 auto;width:64px;height:64px;border-radius:50%;
  background:var(--field);border:1px solid var(--border-strong);
  display:flex;align-items:center;justify-content:center;color:var(--accent-deep);
  font-family:"Fraunces",serif;font-weight:600;font-size:1.5rem;
}
.author-box h3{margin:0 0 4px}
.author-box p{margin:0;font-size:.95rem;color:var(--body)}

/* Contact */
.field-group{margin-bottom:18px}
.field-group label{font-weight:700;color:var(--ink);display:block;margin-bottom:6px}
.req{color:var(--danger)}
.form-note{font-size:.9rem;color:var(--soft)}

/* 404 */
.center-narrow{max-width:620px;margin:0 auto;text-align:center;padding:72px 20px}
.code-404{font-family:"Fraunces",serif;font-size:clamp(4rem,15vw,7rem);color:var(--accent);line-height:1;margin:0}

/* Footer */
.site-footer{
  background:var(--card);border-top:1px solid var(--border);
  margin-top:64px;padding:40px 0 28px;
}
.footer-grid{display:grid;gap:28px;grid-template-columns:1fr}
@media (min-width:680px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer-grid h4{font-size:1rem;margin:0 0 12px}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-links a{color:var(--body);text-decoration:none}
.footer-links a:hover{color:var(--accent-deep);text-decoration:underline}
.footer-brand p{font-size:.95rem;color:var(--soft);max-width:34ch}
.footer-bottom{
  border-top:1px solid var(--border);margin-top:28px;padding-top:18px;
  font-size:.9rem;color:var(--soft);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;
}

/* Utility */
.center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.muted{color:var(--soft)}
.lead-block{max-width:60ch}
.pill-list{display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;margin:18px 0 0}
.pill-list li{
  background:var(--field);border:1px solid var(--border);border-radius:999px;
  padding:8px 14px;font-weight:600;color:var(--body);display:flex;align-items:center;gap:8px;font-size:.95rem;
}
.pill-list svg{color:var(--accent-deep)}
.cta-band{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:36px;text-align:center;margin-top:8px;
}
.cta-band h2{margin-top:0}
