/*
Theme Name: Diginuohooja Visual 2026
Theme URI: https://www.diginuohooja.fi/
Author: OpenAI
Description: Visuaalisempi ja kevyt WordPress-teema Diginuohooja-palvelulle. Sisältää etusivun SEO-perusasetukset, metakuvaukset, Open Graph -tagit, LocalBusiness-scheman, noindex-suositukset arkistosivuille sekä valmiit SVG-kuvitukset.
Version: 1.0.0
Requires at least: 5.7
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: diginuohooja-visual-2026
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/
:root{
  --bg:#ffffff;
  --surface:#f7f9fc;
  --surface-2:#eef3f9;
  --card:#ffffff;
  --text:#111827;
  --muted:#566173;
  --line:#d8e2ef;
  --accent:#c01722;
  --accent-2:#ff6b57;
  --dark:#0f1724;
  --dark-2:#182235;
  --success:#0f9d58;
  --shadow:0 12px 32px rgba(16,24,40,.08);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{width:min(100% - 32px,var(--max));margin:0 auto}
.section{padding:76px 0}
.section.alt{background:linear-gradient(180deg,var(--surface) 0%, #fff 100%)}
.small-label{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.84rem;font-weight:800;color:var(--dark)}
.section-title{font-size:clamp(1.9rem,3vw,2.9rem);line-height:1.08;letter-spacing:-.04em;margin:0 0 14px}
.section-intro{max-width:780px;color:var(--muted);margin:0 0 28px;font-size:1.03rem}
.muted{color:var(--muted)}

.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.93);backdrop-filter:blur(14px);border-bottom:1px solid rgba(216,226,239,.85)}
.topbar{background:linear-gradient(90deg,var(--dark),var(--dark-2));color:#fff;font-size:.92rem}
.topbar .container{display:flex;justify-content:space-between;gap:16px;padding:8px 0}
.topbar strong{font-weight:900}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:82px}
.branding a{display:flex;flex-direction:column;line-height:1.02;color:var(--text);font-weight:900;letter-spacing:-.03em}
.branding small{font-size:.83rem;color:var(--muted);font-weight:700;margin-top:4px}
.main-nav ul{list-style:none;display:flex;gap:22px;padding:0;margin:0;align-items:center}
.main-nav a{color:var(--text);font-weight:800}
.menu-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px 14px;font-weight:800}
.header-cta{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:12px 18px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:900;box-shadow:var(--shadow)}
.header-cta:hover{text-decoration:none;filter:brightness(.97)}

.hero{position:relative;overflow:hidden;background:radial-gradient(circle at top right, rgba(255,107,87,.18), transparent 28%), linear-gradient(180deg,#fff 0%,#f9fbfd 100%);padding:72px 0 40px}
.hero:before,.hero:after{content:"";position:absolute;border-radius:999px;filter:blur(28px);opacity:.55;pointer-events:none}
.hero:before{width:220px;height:220px;background:rgba(192,23,34,.09);left:-60px;top:70px}
.hero:after{width:240px;height:240px;background:rgba(15,157,88,.08);right:-80px;top:30px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.hero-copy h1{font-size:clamp(2.45rem,5vw,4.8rem);line-height:.98;letter-spacing:-.055em;margin:0 0 18px}
.hero-copy p{font-size:1.08rem;color:var(--muted);max-width:680px;margin:0 0 18px}
.hero-note{font-weight:900;color:var(--dark);margin:0 0 24px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin:0 0 22px}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:12px 18px;border-radius:999px;font-weight:900;border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{text-decoration:none;filter:brightness(.98)}
.btn-secondary{background:#fff;color:var(--text);border-color:var(--line)}
.btn-secondary:hover{text-decoration:none;background:var(--surface)}
.bullet-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.bullet-box{background:rgba(255,255,255,.9);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px;padding:14px 16px}
.bullet-box strong{display:block;font-size:1rem;margin-bottom:4px}
.bullet-box span{display:block;color:var(--muted);font-size:.95rem}
.hero-media{position:relative}
.hero-card{background:linear-gradient(180deg,#fff, #f7fafc);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:24px;position:relative;overflow:hidden}
.hero-card:after{content:"";position:absolute;inset:auto -60px -80px auto;width:180px;height:180px;background:radial-gradient(circle,rgba(192,23,34,.12),transparent 65%)}
.hero-visual{border-radius:20px;overflow:hidden;border:1px solid rgba(216,226,239,.9);background:#fff}
.hero-visual img{
  width:100%;
  display:block;
  /* Sama kuvasuhde kaikilla näytöillä -> ei veny eikä jätä tyhjää */
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}
.stat{border:1px solid var(--line);border-radius:16px;padding:14px;background:#fff}
.stat strong{display:block;font-size:1.25rem;line-height:1.05}
.stat span{display:block;color:var(--muted);font-size:.92rem}

.logo-strip{padding:20px 0 0}
.logo-strip .container{display:flex;flex-wrap:wrap;gap:12px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;font-weight:700;color:var(--muted)}

.cards-3,.cards-4,.pricing-grid,.faq-grid,.contact-grid,.process-grid,.image-grid{display:grid;gap:22px}
.cards-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cards-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.process-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.image-grid{grid-template-columns:1.05fr .95fr;align-items:center}
.pricing-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.faq-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.contact-grid{grid-template-columns:1.05fr .95fr;align-items:start}
.card,.process-card,.price-card,.faq-item,.contact-box,.image-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card{padding:24px}
.card h3{margin:0 0 10px;font-size:1.18rem}
.card p{margin:0;color:var(--muted)}
.card ul{margin:14px 0 0;padding-left:18px}
.card li{margin-bottom:8px}
.icon-circle{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,rgba(192,23,34,.12),rgba(255,107,87,.18));display:grid;place-items:center;margin-bottom:16px}
.icon-circle img{width:26px;height:26px}

.image-box{padding:24px}
.image-box img{
  width:100%;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fff;
  /* Parempi asettelu mobiilissa: sama “kortti”-koko joka kerta */
  aspect-ratio: 16 / 10;
  object-fit: cover;
}
.check-list{list-style:none;padding:0;margin:18px 0 0}
.check-list li{padding:10px 0 10px 28px;position:relative;border-top:1px solid var(--line)}
.check-list li:first-child{border-top:0;padding-top:0}
.check-list li:before{content:"✓";position:absolute;left:0;top:10px;color:var(--success);font-weight:900}

.process-card{padding:22px;position:relative}
.process-card .step{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:900;margin-bottom:14px}
.process-card h3{margin:0 0 8px;font-size:1.1rem}
.process-card p{margin:0;color:var(--muted)}

.highlight-banner{background:linear-gradient(135deg,var(--dark),#18293f);color:#fff;border-radius:28px;padding:24px 26px;display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;box-shadow:var(--shadow)}
.highlight-banner strong{display:block;font-size:1.16rem;margin-bottom:6px}
.highlight-banner p{margin:0;color:rgba(255,255,255,.82)}
.inline-actions{display:flex;flex-wrap:wrap;gap:12px}
.inline-actions .btn-secondary{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.2);color:#fff}
.inline-actions .btn-secondary:hover{background:rgba(255,255,255,.14)}

.price-card{padding:26px;position:relative;overflow:hidden}
.price-card.featured{border:2px solid var(--accent)}
.badge{display:inline-block;padding:7px 11px;border-radius:999px;background:#ffe7e4;color:#8a131a;font-size:.8rem;font-weight:900;margin-bottom:14px}
.price-card h3{margin:0 0 10px}
.price-wrap{display:flex;align-items:flex-end;gap:10px;margin:8px 0 14px}
.price-old{text-decoration:line-through;color:var(--muted);font-weight:700}
.price-main{font-size:2.45rem;line-height:1;font-weight:900}
.price-main small{font-size:1rem;color:var(--muted);font-weight:800}
.price-card p{margin:0 0 14px;color:var(--muted)}
.price-card ul{list-style:none;padding:0;margin:0}
.price-card li{padding:11px 0;border-top:1px solid var(--line)}

.area-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.area-list span{display:inline-flex;padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-weight:800}

.faq-item{padding:22px}
.faq-item h3{margin:0 0 8px;font-size:1.08rem}
.faq-item p{margin:0;color:var(--muted)}

.contact-box{padding:24px}
.contact-box h3{margin:0 0 10px}
.contact-list,.footer-links{list-style:none;padding:0;margin:0}
.contact-list li{padding:10px 0;border-top:1px solid var(--line)}
.contact-list li:first-child{border-top:0;padding-top:0}

.site-footer{background:linear-gradient(180deg,var(--dark),#0b1220);color:rgba(255,255,255,.86);padding:36px 0 52px}
.site-footer a{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.1fr .9fr .9fr;gap:24px}
.footer-title{color:#fff;margin:0 0 10px}
.footer-links li{margin-bottom:10px}
.footer-copy{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:.95rem;color:rgba(255,255,255,.72)}

@media (max-width:1024px){
  .hero-grid,.cards-3,.cards-4,.pricing-grid,.faq-grid,.contact-grid,.process-grid,.image-grid,.footer-grid,.bullet-row{grid-template-columns:1fr}
  .highlight-banner{grid-template-columns:1fr}
}
@media (max-width:820px){
  .menu-toggle{display:inline-flex}
  .main-nav{display:none;position:absolute;left:16px;right:16px;top:100%;padding:14px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
  .main-nav.is-open{display:block}
  .main-nav ul{flex-direction:column;align-items:flex-start;gap:12px}
  .header-cta{display:none}
  .topbar .container{flex-direction:column;align-items:flex-start}
  .section{padding:60px 0}
  .hero{padding:52px 0 30px}
}
