/*
Theme Name: NewPass Theme
Theme URI: https://newpass.us/
Author: Vitalii Prokopiv
Description: Password generator theme with Random, Easy-to-Read, Easy-to-Say, PIN, and WiFi password generators. Includes Home landing.
Version: 1.0.0
Text Domain: newpass
*/

:root{
  --primary:#1245d5;
  --primary-contrast:#ffffff;
  --bg:#0f1b3d;
  --card:#ffffff;
  --muted:#667085;
  --border:#E5E7EB;
  --shadow:0 8px 24px rgba(2,14,79,.08);
  --radius:14px;
}

html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;background:var(--bg);color:#0f172a;}

.container{max-width:980px;margin:40px auto;padding:0 20px;}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;}
.h1{font-size:36px;line-height:1.2;margin:8px 0 10px 0;}
.p{font-size:16px;color:#334155;margin:0 0 24px 0;}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:10px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 18px;border-radius:12px;border:1px solid var(--border);
  cursor:pointer;background:#fff;font-weight:600;text-decoration:none;color:#111827;
  transition:.15s ease;min-width:180px;
}
.btn.primary{background:var(--primary);color:var(--primary-contrast);border-color:transparent;}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(2,14,79,.12);}

.header{background:transparent}
.site-brand{color:#fff;text-decoration:none;font-weight:800;font-size:20px}
.nav{display:flex;gap:12px;align-items:center}
.header-row{max-width:980px;margin:0 auto;padding:16px 20px;display:flex;align-items:center;justify-content:space-between}

.tabs{display:flex;gap:10px;background:#F8FAFC;border-radius:12px;padding:8px;border:1px solid var(--border);}
.tab{padding:10px 16px;border-radius:10px;border:1px solid transparent;font-weight:600;color:#111827;cursor:pointer}
.tab a{color:inherit;text-decoration:none;display:block}
.tab.active{background:#fff;border-color:var(--border);box-shadow:0 8px 30px rgba(2,14,79,.06);}

.section-title{font-weight:700;color:#0f172a;margin:24px 0 8px 0}
.divider{height:1px;background:var(--border);margin:16px 0}

.row{display:flex;gap:14px;align-items:center}
.range-wrap{display:flex;align-items:center;gap:14px}
.range{width:100%}
.badge{min-width:52px;text-align:center;border:1px solid var(--border);padding:8px 12px;border-radius:999px;background:#fff;font-weight:700}

.switch{position:relative;display:inline-flex;gap:10px;align-items:center;font-weight:600}
.switch input{display:none}
.switch .track{width:46px;height:26px;border-radius:999px;background:#e5e7eb;position:relative;transition:.2s}
.switch .dot{position:absolute;width:22px;height:22px;border-radius:50%;background:#fff;left:2px;top:2px;transition:.2s;box-shadow:0 1px 2px rgba(0,0,0,.1)}
.switch input:checked + .track{background:#1f2937}
.switch input:checked + .track .dot{left:22px}

.output{
  font-size:28px;font-weight:700;letter-spacing:1px;
  border:1px solid var(--border);padding:16px 18px;border-radius:12px;background:#fff;color:#1f2937
}

.footer{color:#cbd5e1;text-align:center;padding:30px 0}
.footer a{color:#e2e8f0}
.small{font-size:12px;color:#475569}


/* Мінімальні стилі (адаптуй під свою тему або винеси в CSS) */
.section-head { margin-bottom: 20px; }
.section-title { font-size: 28px; line-height: 1.2; margin: 0 0 6px; }
.section-sub { color: #6b7280; margin: 0; }
.blog-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
@media (min-width: 768px) {
  .blog-grid { gap: 20px; }
}
.blog-card {
  grid-column: span 12;
  display: flex; flex-direction: column; background: #fff;
  border: 1px solid rgba(0,0,0,.06); border-radius: 16px; overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
@media (min-width: 640px) { .blog-card { grid-column: span 6; } }
@media (min-width: 1024px){ .blog-card { grid-column: span 4; } }

.thumb, .thumb img { display: block; width: 100%; height: 220px; object-fit: cover; }
.thumb--placeholder { width: 100%; height: 220px; background: linear-gradient(135deg,#f3f4f6,#e5e7eb); }

.blog-card__body { padding: 16px; display: flex; gap: 10px; flex-direction: column; }
.meta { font-size: 13px; color: #6b7280; display: flex; align-items: center; gap: 8px; }
.blog-card__title { font-size: 18px; margin: 0; }
.blog-card__title a { text-decoration: none; }
.excerpt { margin: 0; color: #374151; }
.blog-card__footer { margin-top: auto; }
.btn.btn--ghost {
  display: inline-block; padding: 8px 12px; border-radius: 10px;
  border: 1px solid rgba(0,0,0,.1); text-decoration: none;
}

.pagination { margin-top: 22px; }
.pagination .page-numbers { display: inline-block; padding: 8px 12px; margin: 0 4px; border-radius: 8px; border: 1px solid rgba(0,0,0,.1); text-decoration: none; }
.pagination .current { background: #111827; color: #fff; border-color: #111827; }
.empty { color: #6b7280; }


/* Мінімальні стилі (можеш винести в assets/css або style.css) */
.site-main { padding: 32px 0 48px; }
.breadcrumbs { font-size: 14px; color:#6b7280; margin-bottom: 8px; }
.breadcrumbs a { color: inherit; text-decoration: none; }

.entry-title { font-size: clamp(26px, 4vw, 40px); line-height: 1.15; margin: 6px 0 10px; }
.entry-meta { color:#6b7280; display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:14px; }
.entry-thumb img { width:100%; height:auto; border-radius: 14px; }

.post-toc { background:#fafafa; border:1px solid rgba(0,0,0,.06); border-radius:12px; padding:12px; margin:18px 0; }
.post-toc__head { font-weight:600; margin-bottom:8px; }
.post-toc__list a { display:block; padding:6px 4px; text-decoration:none; border-radius:8px; }
.post-toc__list a:hover { background:#f3f4f6; }
.post-toc__list .lvl-2 { padding-left: 12px; opacity:.9; }

.entry-content { margin-top: 16px; }
.entry-content p { line-height: 1.75; }
.entry-content h2, .entry-content h3 { scroll-margin-top: 90px; }

.taxonomy { margin-top: 24px; display: grid; gap: 6px; color:#374151; }
.share { margin-top: 14px; display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.btn-share { display:inline-block; padding:8px 12px; border:1px solid rgba(0,0,0,.1); border-radius:10px; text-decoration:none; }
.copy-link { cursor:pointer; background:#fff; }

.related-posts { margin-top: 36px; }
.related-posts .section-title { font-size: 22px; margin-bottom: 10px; }
.related-grid { display:grid; grid-template-columns: repeat(12,1fr); gap:14px; }
.related-card { grid-column: span 12; background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:12px; overflow:hidden; }
@media (min-width:640px){ .related-card { grid-column: span 6; } }
@media (min-width:1024px){ .related-card { grid-column: span 4; } }
.related-card .thumb, .related-card .thumb img { display:block; width:100%; height:180px; object-fit:cover; }
.thumb--placeholder { width:100%; height:180px; background: linear-gradient(135deg,#f3f4f6,#e5e7eb); }
.related-card .title { font-size: 16px; padding: 10px 12px; margin:0; }

.post-nav { margin-top: 24px; display:flex; justify-content:space-between; gap:10px; }
.post-nav a { text-decoration:none; border:1px solid rgba(0,0,0,.1); border-radius:10px; padding:8px 12px; }

.comments-wrap { margin-top: 24px; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

