/*
Theme Name: Sanalaskuri
Theme URI: https://example.com/
Author: TWS_Crew + ChatGPT
Author URI: https://example.com/
Description: Kevyt, mobiiliystävällinen Word Counter / Merkkilaskuri -teema suomeksi. Sisältää etusivun laskurin, Tietoa meistä-, Yhteystiedot- ja 404-sivut sekä modernin footerin.
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sanalaskuri
Tags: blog, custom-logo, one-column, two-columns, accessibility-ready, responsive-layout
*/

/* Base / Reset */
:root{
  --bg: #fbf7f1;
  --surface: #ffffff;
  --surface-2: #f6efe7;
  --text: #2a2420;
  --muted: #6b5e52;
  --accent: #b08457; /* light brown */
  --accent-2: #d9c4ae;
  --border: #eadfD4;
  --shadow: 0 10px 30px rgba(0,0,0,.06);
  --radius: 16px;
  --radius-sm: 12px;
  --focus: 0 0 0 3px rgba(176,132,87,.25);
}

*{ box-sizing: border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: "Times New Roman", Times, serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: 18px; /* bigger on mobile by default */
}
@media (min-width: 768px){
  body{ font-size: 17px; }
}
a{
  color: var(--accent);
  text-decoration-thickness: .12em;
  text-underline-offset: .18em;
}
a:hover{ text-decoration-thickness: .16em; }
a:focus{ outline: none; box-shadow: var(--focus); border-radius: 6px; }

img{ max-width:100%; height:auto; }

.container{
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}
.site{
  min-height: 100svh;
  display:flex;
  flex-direction: column;
}
.site-main{ flex:1; padding: 24px 0 48px; }

.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  position:fixed;
  left:16px;
  top:16px;
  width:auto;
  height:auto;
  padding:10px 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  z-index:9999;
  box-shadow: var(--shadow);
}

/* Header */
.site-header{
  position: sticky;
  top:0;
  z-index:50;
  background: rgba(251,247,241,.86);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap:16px;
  padding: 14px 0;
}
.site-branding{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 0;
}
.custom-logo{
  display:block;
  max-height: 40px;
  width:auto;
}
@media (min-width: 768px){
  .custom-logo{ max-height: 48px; }
}
.site-title{
  margin:0;
  font-size: 22px;
  line-height:1.15;
  letter-spacing: .2px;
}
.site-title a{ color: var(--text); text-decoration: none; }
.site-description{ margin:0; color: var(--muted); font-size: 14px; }

.primary-nav{
  display:flex;
  align-items:center;
  gap:10px;
}
.primary-nav button{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--border);
  background: var(--surface);
  border-radius: 999px;
  padding: 10px 12px;
  box-shadow: 0 6px 16px rgba(0,0,0,.04);
  cursor:pointer;
  font-family: inherit;
  font-size: 16px;
}
.primary-nav button:focus{ outline:none; box-shadow: var(--focus); }
.primary-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:none;
  position:absolute;
  right:16px;
  top:64px;
  background: var(--surface);
  border:1px solid var(--border);
  border-radius: 14px;
  box-shadow: var(--shadow);
  min-width: 220px;
  overflow:hidden;
}
.primary-nav ul.is-open{ display:block; }
.primary-nav li a{
  display:block;
  padding: 12px 14px;
  color: var(--text);
  text-decoration: none;
}
.primary-nav li a:hover{
  background: var(--surface-2);
}
@media (min-width: 900px){
  .primary-nav button{ display:none; }
  .primary-nav ul{
    position:static;
    display:flex !important;
    gap:14px;
    background:transparent;
    border:none;
    box-shadow:none;
    min-width:auto;
  }
  .primary-nav li a{
    padding: 8px 10px;
    border-radius: 999px;
  }
  .primary-nav li a:hover{
    background: rgba(176,132,87,.10);
  }
}

/* Typography / Content */
.entry-title{
  font-size: 30px;
  line-height:1.2;
  margin: 0 0 16px;
}
@media (min-width: 768px){
  .entry-title{ font-size: 38px; }
}
.subtitle, h2, h3{
  letter-spacing: .2px;
}
h2{
  font-size: 24px;
  margin: 24px 0 12px;
}
h3{
  font-size: 20px;
  margin: 20px 0 10px;
}
p{ margin: 0 0 14px; }

blockquote{
  margin: 18px 0;
  padding: 14px 16px;
  border-left: 4px solid var(--accent);
  background: #f2e7dc; /* light brown quote bg */
  border-radius: 12px;
}
blockquote p{ margin:0; }
strong{ font-weight: 700; }
em{ font-style: italic; }

ul, ol{ padding-left: 22px; }
li{ margin: 6px 0; }

/* Cards & surfaces */
.card{
  background: var(--surface);
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.card-pad{ padding: 16px; }
@media (min-width: 768px){
  .card-pad{ padding: 18px; }
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border:1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 14px;
  cursor:pointer;
  font-family: inherit;
  font-size: 16px;
  box-shadow: 0 6px 16px rgba(0,0,0,.04);
}
.btn:hover{ background: var(--surface-2); }
.btn:focus{ outline:none; box-shadow: var(--focus); }
.btn-primary{
  background: var(--accent);
  border-color: rgba(0,0,0,.06);
  color: #fff;
}
.btn-primary:hover{ filter: brightness(.97); }

/* Blog (grid archives / category) */
.archive-desc{ color: var(--muted); margin: 0 0 16px; }
.blog-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 640px){
  .blog-grid{ grid-template-columns: 1fr 1fr; }
}
@media (min-width: 1000px){
  .blog-grid{ grid-template-columns: 1fr 1fr 1fr; }
}

.blog-card{
  display:block;
  text-decoration: none;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 10px 28px rgba(0,0,0,.05);
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}
.blog-card:hover{ transform: translateY(-2px); box-shadow: 0 14px 34px rgba(0,0,0,.07); }
.blog-card:focus{ outline:none; box-shadow: var(--focus); }

.blog-thumb{ aspect-ratio: 16 / 9; background: var(--surface-2); }
.blog-thumb img{ width:100%; height:100%; object-fit: cover; display:block; }

.blog-card-body{ padding: 12px 12px 14px; }
.blog-card-title{
  margin: 0 0 8px;
  font-size: 20px;
  line-height: 1.25;
}
.blog-card-excerpt{ margin:0; color: var(--muted); font-size: 15px; }

.blog-pagination{ margin-top: 18px; }

/* Single post */
.post-featured{ margin: 0 0 14px; }
.post-featured img{ width:100%; height:auto; border-radius: 14px; display:block; }

/* Footer */
.site-footer{
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,.55);
}
.footer-inner{
  padding: 28px 0;
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.footer-title{
  margin:0 0 8px;
  font-size: 18px;
}
.footer-meta{
  color: var(--muted);
  font-size: 14px;
}
.footer-links{
  list-style:none;
  padding:0;
  margin:0;
}
.footer-links a{
  display:inline-block;
  padding: 4px 0;
  color: var(--text);
  text-decoration: none;
}
.footer-links a:hover{ color: var(--accent); text-decoration: underline; }
@media (min-width: 900px){
  .footer-inner{ grid-template-columns: 2fr 1fr; align-items: start; }
  .footer-grid{ grid-template-columns: 1fr 1fr; }
}

/* Forms */
input[type="text"], input[type="email"], textarea{
  font-family: inherit;
  font-size: 16px;
}
.form-row{
  display:flex;
  flex-direction: column;
  gap: 6px;
  margin: 12px 0;
}
.form-row label{ font-weight: 700; }
.form-row input, .form-row textarea{
  padding: 12px 12px;
  border:1px solid var(--border);
  border-radius: 12px;
  background: var(--surface);
}
.form-row input:focus, .form-row textarea:focus{
  outline:none;
  box-shadow: var(--focus);
}
.notice{
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--surface-2);
}
.notice.success{ border-color: rgba(0,120,70,.25); }
.notice.error{ border-color: rgba(160,20,20,.25); }
