/*
Theme Name: Spendavis
Theme URI: https://spendavis.com
Author: Spendavis
Description: Spendavis-yhtiön kotisivuteema. Hankintatoimen kehityskumppani pk-yrityksille. Kaikki tekstit ja kuvat muokattavissa WordPress-editorin Mukauta-valikosta.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
Text Domain: spendavis
*/

:root{
  --orange:#F07830;
  --blue:#4878C0;
  --blue-deep:#2D5494;
  --yellow:#F0C000;
  --ink:#0F1115;
  --ink-2:#2A2E36;
  --muted:#6B7280;
  --line:#E5E7EB;
  --paper:#FBFAF7;
  --white:#FFFFFF;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--white);color:var(--ink);font-family:'Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased}
a{color:inherit}
img{max-width:100%;display:block;height:auto}

.container{max-width:1240px;margin:0 auto;padding:0 32px}

/* Nav */
.nav{display:flex;align-items:center;justify-content:space-between;padding:22px 32px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(255,255,255,0.96);backdrop-filter:blur(6px);z-index:10}
.nav .logo{display:flex;align-items:center;gap:12px}
.nav .logo img{height:28px;width:auto}
.nav-links{display:flex;gap:32px;font-weight:500;font-size:14.5px;color:var(--ink-2);list-style:none;margin:0;padding:0}
.nav-links a{color:inherit;text-decoration:none;transition:color .15s}
.nav-links a:hover{color:var(--blue-deep)}
.nav-cta{background:var(--blue-deep);color:#fff;text-decoration:none;padding:11px 20px;border-radius:6px;font-weight:600;font-size:14px;transition:background .15s}
.nav-cta:hover{background:#1f4080;color:#fff}

/* Hero */
.hero{padding:88px 0 96px;background:radial-gradient(ellipse 800px 400px at 85% 20%, rgba(72,120,192,0.08), transparent 70%),var(--white);border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font:500 12px/1 'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-deep);background:rgba(72,120,192,0.08);padding:7px 12px;border-radius:999px}
.eyebrow .pulse{width:7px;height:7px;background:var(--orange);border-radius:50%}
.hero h1{font-family:'Inter',sans-serif;font-size:64px;line-height:1.04;letter-spacing:-0.025em;font-weight:700;margin:22px 0 24px;color:var(--ink);text-wrap:balance}
.hero h1 em{font-style:normal;color:var(--blue-deep);position:relative;display:inline-block;z-index:1}
.hero h1 em::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:8px;background:var(--yellow);opacity:.55;z-index:-1;border-radius:2px}
.lede{font-size:19px;line-height:1.55;color:var(--ink-2);max-width:540px;margin-bottom:36px}
.cta-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;text-decoration:none;font-weight:600;font-size:15px;padding:14px 22px;border-radius:6px;transition:all .15s;cursor:pointer;border:0}
.btn-primary{background:var(--blue-deep);color:#fff}
.btn-primary:hover{background:#1f4080;transform:translateY(-1px);color:#fff}
.btn-ghost{color:var(--ink);border:1px solid var(--line);background:transparent}
.btn-ghost:hover{border-color:var(--ink)}
.btn .arrow{transition:transform .15s}
.btn:hover .arrow{transform:translateX(3px)}

/* Hero visual */
.hero-visual{position:relative;aspect-ratio:4/5;background:linear-gradient(180deg,#F4F6FA 0%,#E9EEF7 100%);border-radius:14px;overflow:hidden;border:1px solid var(--line);padding:28px}
.dash-card{background:#fff;border-radius:10px;border:1px solid var(--line);box-shadow:0 1px 0 rgba(15,17,21,0.04);padding:18px 20px}
.dash-card + .dash-card{margin-top:14px}
.dc-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.dc-title{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.dc-tag{font:500 10px 'JetBrains Mono',monospace;background:rgba(34,140,90,0.1);color:#1f8050;padding:3px 7px;border-radius:4px}
.dc-tag.warn{background:rgba(240,120,48,0.12);color:#C75D14}
.dc-num{font-size:32px;font-weight:700;letter-spacing:-0.02em;color:var(--ink)}
.dc-sub{font-size:13px;color:var(--muted);margin-top:4px}
.bar{display:flex;gap:3px;margin-top:14px;align-items:end;height:48px}
.bar div{flex:1;background:var(--blue);border-radius:2px 2px 0 0;opacity:.7}
.bar div:nth-child(odd){opacity:.45}
.bar div.hi{background:var(--orange);opacity:1}
.donut{width:72px;height:72px;border-radius:50%;background:conic-gradient(var(--blue) 0 62%, var(--orange) 62% 84%, var(--yellow) 84% 100%);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.donut::after{content:"";position:absolute;inset:14px;background:#fff;border-radius:50%}
.donut span{position:relative;z-index:1;font-weight:700;font-size:14px;color:var(--ink)}
.dc-row{display:flex;justify-content:space-between;align-items:center;gap:18px}
.legend{font-size:12px;color:var(--muted);line-height:1.8;flex:1}
.legend .lk{display:flex;align-items:center;gap:6px}
.legend .lk i{width:8px;height:8px;border-radius:2px;display:inline-block}

/* Trust */
.trust{padding:36px 0;border-bottom:1px solid var(--line);background:var(--paper)}
.trust .container{display:flex;align-items:center;gap:48px;flex-wrap:wrap}
.trust .label{font:500 12px 'JetBrains Mono',monospace;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.trust .logos{display:flex;gap:40px;flex-wrap:wrap;align-items:center;flex:1}
.trust .logos div{font-weight:600;color:var(--ink-2);opacity:.5;letter-spacing:.02em;font-size:18px}

section{padding:96px 0}
.sec-head{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-bottom:56px;align-items:end}
.sec-eyebrow{font:500 12px 'JetBrains Mono',monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--orange)}
h2{font-size:44px;line-height:1.08;letter-spacing:-0.02em;font-weight:700;margin:14px 0 0;text-wrap:balance}
.sec-lede{font-size:17px;line-height:1.6;color:var(--muted);max-width:480px}

/* Pillars */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.pillar{background:#fff;padding:32px 28px;display:flex;flex-direction:column;gap:14px;min-height:240px;transition:background .2s}
.pillar:hover{background:#FBFAF7}
.pillar h3{font-size:19px;font-weight:600;margin:0;line-height:1.3}
.pillar p{font-size:14.5px;line-height:1.55;color:var(--muted);margin:0}
.pillar .glyph{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:rgba(72,120,192,0.1);color:var(--blue-deep);font-weight:700;font-size:12px;font-family:'JetBrains Mono',monospace}
.pillar.p2 .glyph{background:rgba(240,120,48,0.12);color:var(--orange)}
.pillar.p3 .glyph{background:rgba(240,192,0,0.22);color:#A07800}

/* Process */
.how{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.steps::before{content:"";position:absolute;left:0;right:0;top:24px;height:1px;background:var(--line);z-index:0}
.step{position:relative;z-index:1}
.step .marker{width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font:700 16px 'Inter';color:var(--blue-deep);margin-bottom:20px}
.step.active .marker{background:var(--blue-deep);color:#fff;border-color:var(--blue-deep)}
.step h4{font-size:16px;margin:0 0 6px;font-weight:600}
.step p{font-size:14px;line-height:1.55;color:var(--muted);margin:0}
.step .duration{font:500 11px 'JetBrains Mono',monospace;color:var(--orange);margin-top:10px;display:block}

/* Categories */
.cats-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px}
.cat-card{border:1px solid var(--line);border-radius:12px;padding:32px;background:#fff}
.cat-card h4{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin:0 0 24px;color:var(--ink-2)}
.cat-card h4 .swatch{width:12px;height:12px;border-radius:3px}
.cat-list{list-style:none;margin:0;padding:0}
.cat-list li{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:14px 0;border-top:1px solid var(--line);font-size:15px}
.cat-list li:first-child{border-top:0;padding-top:0}
.cat-list li .pct{font:500 12px 'JetBrains Mono',monospace;color:var(--orange)}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:48px}
.stat .num{font-size:72px;font-weight:700;letter-spacing:-0.04em;line-height:1;background:linear-gradient(180deg,var(--ink) 0%, var(--blue-deep) 120%);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{font-size:15px;color:var(--muted);margin-top:14px;line-height:1.5;max-width:280px}

/* CTA banner */
.cta-banner{background:var(--ink);color:#fff;border-radius:16px;padding:56px;display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;position:relative;overflow:hidden}
.cta-banner::before{content:"";position:absolute;right:-100px;top:-100px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle, rgba(240,120,48,0.4) 0%, transparent 70%)}
.cta-banner h2{color:#fff;font-size:36px;margin:0 0 14px;position:relative}
.cta-banner p{color:rgba(255,255,255,0.7);font-size:16px;line-height:1.55;margin:0;position:relative}
.cta-banner .actions{display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.cta-banner .btn-primary{background:var(--orange);color:#fff;justify-content:center}
.cta-banner .btn-primary:hover{background:#d96820}
.cta-banner .btn-ghost{color:#fff;border-color:rgba(255,255,255,0.25);justify-content:center}

/* Footer */
.site-footer{padding:48px 0 32px;background:#fff;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:36px}
.foot-brand img{height:24px;margin-bottom:14px}
.foot-brand p{font-size:14px;color:var(--muted);line-height:1.55;max-width:300px}
.foot-col h5{font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:0 0 16px}
.foot-col a{display:block;color:var(--muted);text-decoration:none;font-size:14px;padding:5px 0;transition:color .15s}
.foot-col a:hover{color:var(--blue-deep)}
.foot-bot{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;font-size:13px;color:var(--muted);flex-wrap:wrap;gap:12px}

@media (max-width: 960px){
  .hero-grid,.sec-head,.cta-banner,.foot-grid,.cats-grid{grid-template-columns:1fr}
  .pillars,.steps,.stats{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:44px}
  h2{font-size:34px}
  section{padding:64px 0}
  .hero{padding:48px 0 64px}
  .nav-links{display:none}
  .cta-banner{padding:36px}
}
@media (max-width: 560px){
  .pillars,.steps,.stats{grid-template-columns:1fr}
  .steps::before{display:none}
}
