:root{ --bg:#0b0e14; --fg:#0b0e14; --brand:#d4af37; }
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:#fff;color:#0b0e14}
img{max-width:100%;height:auto}
a{color:#0b0e14;text-decoration:none}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section.alt{background:#fafafa}
.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media (max-width:900px){.grid.two{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid #eee;border-radius:16px;padding:24px;box-shadow:0 6px 18px rgba(0,0,0,.04)}
.btn{display:inline-block;background:var(--brand);color:#000;padding:12px 18px;border-radius:999px;font-weight:700}
.btn:hover{filter:brightness(1.05)}
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between;padding:10px 16px}
.brand{display:flex;gap:12px;align-items:center;font-weight:800}
.brand img{width:40px;height:40px;border-radius:50%}
.site-nav{display:flex;gap:18px}
.site-nav a{padding:8px 6px;border-radius:8px}
.site-nav a:hover{background:#f3f3f3}
.hamburger{display:none;background:none;border:0;cursor:pointer}
.hamburger span{display:block;width:24px;height:2px;background:#000;margin:5px 0}
@media (max-width:900px){
  .hamburger{display:block}
  .site-nav{position:fixed;inset:60px 12px auto 12px;display:none;flex-direction:column;background:#fff;border:1px solid #eee;border-radius:12px;padding:12px;box-shadow:0 12px 30px rgba(0,0,0,.1)}
  .site-nav.open{display:flex}
}
.hero{background:linear-gradient(180deg,#fff,#f9f6ee)}
.hero-logo{width:120px;margin-bottom:12px}
.hero h1{font-size:clamp(28px,4vw,48px);margin:0 0 12px}
.hero p{max-width:800px;color:#333;font-size:18px;line-height:1.6}
.steps{margin:0;padding-left:18px}
.steps li{margin:8px 0}
.faq .q{width:100%;text-align:left;background:#fff;border:1px solid #eee;border-radius:12px;padding:14px 16px;margin:8px 0;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.faq .a{display:none;padding:12px 4px 24px 4px;color:#333}
.faq .q.active + .a{display:block}
.faq .plus{font-weight:900;font-size:20px}
.form{display:grid;gap:12px;max-width:720px}
.form label{display:grid;gap:8px;font-weight:600}
.form input,.form textarea{padding:12px 14px;border:1px solid #ddd;border-radius:10px;font:inherit}
.human{display:flex;gap:10px;align-items:center}
.human span{font-weight:700}
.vcard{position:relative;display:flex;gap:12px;align-items:center;border:1px dashed #ddd;background:#fff;border-radius:16px;padding:10px 12px;margin-top:24px;box-shadow:0 4px 10px rgba(0,0,0,.04)}
.vcard img{width:48px;height:48px;border-radius:50%}
.site-footer{padding:22px 0;border-top:1px solid #eee;background:#fff}
.site-footer p{margin:0;color:#444}
.thank .center{min-height:60vh;display:grid;place-items:center;text-align:center;padding:24px}

/* Klickbara tjänstekort */
.card.service{display:block;transition:transform .15s ease, box-shadow .15s ease; cursor:pointer}
.card.service:hover{transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.08)}

/* Servicekort med ikon */
.card.service{display:block;transition:transform .15s ease, box-shadow .15s ease; cursor:pointer}
.card.service:hover{transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,.08)}
.card.service img.thumb{width:40px;height:40px;display:block;margin-bottom:10px}

/* Sekundär knapp (tillbaka) */
.btn.secondary{background:#eee;color:#111;border:1px solid #ddd}
.btn.secondary:hover{filter:none; background:#e9e9e9}

html{scroll-behavior:smooth}

/* Aktiv meny-stil */
.site-nav a.active{background:#f3f3f3;font-weight:700;border-radius:8px}

/* Om mig */
.about{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:center}
.about .avatar{width:200px;height:200px;object-fit:cover;border-radius:100%;border:6px solid #fff;box-shadow:0 10px 24px rgba(0,0,0,.08)}
.about .badges{list-style:none;padding:0;margin:16px 0;display:flex;flex-wrap:wrap;gap:10px}
.about .badges li{background:#fff;border:1px solid #eee;border-radius:999px;padding:8px 12px}
@media (max-width:900px){.about{grid-template-columns:1fr;text-align:left}.about .avatar{width:140px;height:140px}}

/* Portfolio grid */
.grid.three{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:1100px){.grid.three{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.grid.three{grid-template-columns:1fr}}
.card.service .link{display:inline-block;margin-top:6px;opacity:.8}
