/*
Theme Name: Effekt Eltjänst
Theme URI: https://effekteltjanst.se
Author: Effekt Eltjänst
Description: Skräddarsydd tema för Effekt Eltjänst i Västsverige AB. Modern svartvit identitet med gul accent. Allt innehåll redigeras via Anpassa-fälten (ACF). Bygger på riktning A — Editorial.
Version: 1.0.1
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: effekt-eltjanst
*/

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body { margin: 0; background: var(--ee-white); color: var(--fg-1); font-family: var(--font-body); }
img { display: block; max-width: 100%; }
a { text-decoration: none; color: inherit; }

.wrap { max-width: 1120px; margin: 0 auto; padding: 0 var(--space-6); }

/* ---------- NAV ---------- */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(255,255,255,0.9); backdrop-filter: saturate(1.1) blur(10px); border-bottom: var(--bw-hair) solid var(--border-1); }
.nav-inner { max-width: 1120px; margin: 0 auto; padding: 0 var(--space-6); height: 80px; display: flex; align-items: center; gap: var(--space-6); }
.nav-logo { height: 50px; width: auto; }
.nav-links { margin-left: auto; display: flex; align-items: center; gap: var(--space-7); }
.nav-link { font-weight: 500; font-size: var(--fs-sm); color: var(--fg-2); padding: 4px 0; position: relative; transition: color var(--dur-fast) var(--ease-out); }
.nav-link::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -3px; height: 2px; background: var(--ee-yellow); transition: right var(--dur-base) var(--ease-out); }
.nav-link:hover { color: var(--ee-ink); }
.nav-link.active { color: var(--ee-ink); }
.nav-link.active::after { right: 0; }
.nav-cta { font-weight: 600; font-size: var(--fs-sm); background: var(--ee-ink); color: var(--ee-paper); padding: 11px 20px; border-radius: var(--radius-2); transition: background var(--dur-fast) var(--ease-out); }
.nav-cta:hover { background: var(--ee-ink-800); }

/* ---------- shared ---------- */
.eyebrow { font-family: var(--font-headline); font-weight: 700; font-size: var(--fs-xs); letter-spacing: var(--ls-wide); text-transform: uppercase; color: var(--fg-3); display: inline-flex; align-items: center; gap: 12px; }
.eyebrow::before { content: ""; width: 24px; height: 2px; background: var(--ee-yellow); }
.btn { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; font-size: var(--fs-base); padding: 15px 26px; border-radius: var(--radius-2); border: var(--bw-hair) solid transparent; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.btn .arr { width: 17px; height: 17px; }
.btn-primary { background: var(--ee-ink); color: var(--ee-paper); }
.btn-primary:hover { background: var(--ee-ink-800); }
.btn-ghost-light { background: transparent; color: var(--ee-paper); border-color: rgba(255,255,255,0.3); }
.btn-ghost-light:hover { border-color: rgba(255,255,255,0.7); }

section { padding: var(--space-10) 0; }
.sec-head { max-width: 56ch; margin-bottom: var(--space-9); }
.sec-head .eyebrow { margin-bottom: var(--space-5); }
.sec-title { font-family: var(--font-headline); font-weight: 800; font-size: var(--fs-2xl); line-height: var(--lh-snug); letter-spacing: -0.015em; margin: 0; color: var(--ee-ink); }

/* ---------- HERO ---------- */
.hero { background: var(--ee-ink); color: var(--fg-on-ink); position: relative; overflow: hidden; }
.hero-mark { position: absolute; right: -70px; top: 50%; transform: translateY(-50%); width: 640px; max-width: 58%; opacity: 0.07; pointer-events: none; user-select: none; }
.hero-inner { padding: var(--space-10) 0; position: relative; z-index: 1; }
.hero .eyebrow { color: var(--ee-ink-300); margin-bottom: var(--space-6); }
.hero h1 { font-family: var(--font-headline); font-weight: 800; font-size: clamp(var(--fs-3xl), 5.2vw, var(--fs-4xl)); line-height: var(--lh-tight); letter-spacing: -0.02em; color: var(--ee-white); margin: 0; max-width: 17ch; }
.hero-lead { font-size: var(--fs-md); line-height: var(--lh-loose); color: var(--ee-silver); max-width: 58ch; margin: var(--space-6) 0 var(--space-7); }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-4); }

/* ---------- ABOUT ---------- */
#om { border-bottom: var(--bw-hair) solid var(--border-1); }
.about-grid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: var(--space-9); align-items: start; }
.about-grid .sec-title { margin-bottom: 0; }
.about-body p { font-size: var(--fs-md); color: var(--fg-2); line-height: var(--lh-loose); margin: 0 0 var(--space-5); }
.about-body p:last-of-type { margin-bottom: var(--space-7); }
.values { list-style: none; padding: var(--space-6) 0 0; margin: 0; border-top: var(--bw-hair) solid var(--border-1); display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4) var(--space-6); }
.values li { display: flex; align-items: flex-start; gap: 11px; font-weight: 500; font-size: var(--fs-base); color: var(--ee-ink); }
.values .bolt { width: 10px; height: 15px; color: var(--ee-yellow); flex: none; margin-top: 4px; }

/* ---------- SERVICES ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.svc { padding: 0 var(--space-6); border-left: var(--bw-hair) solid var(--border-1); }
.svc:first-child { padding-left: 0; border-left: none; }
.svc:last-child { padding-right: 0; }
.svc-num { font-family: var(--font-mono); font-size: var(--fs-sm); color: var(--ee-ink-300); }
.svc h3 { font-family: var(--font-headline); font-weight: 700; font-size: var(--fs-lg); margin: var(--space-5) 0 var(--space-4); line-height: var(--lh-snug); }
.svc p { font-size: var(--fs-base); color: var(--fg-2); margin: 0; line-height: var(--lh-normal); }

/* ---------- TEAM ---------- */
.team { background: var(--ee-paper); }
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-7) var(--space-5); }
.member-photo { aspect-ratio: 4/5; background: var(--ee-silver-100); display: flex; align-items: center; justify-content: center; position: relative; }
.member-photo .initials { font-family: var(--font-headline); font-weight: 700; font-size: var(--fs-2xl); color: var(--ee-silver); }
.member-photo .ph-tag { position: absolute; bottom: 9px; left: 9px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ee-ink-400); }
.member h4 { font-family: var(--font-headline); font-weight: 700; font-size: var(--fs-md); margin: var(--space-4) 0 3px; }
.member .role { font-size: var(--fs-sm); color: var(--fg-2); }
.member-photo img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); transition: filter var(--dur-base) var(--ease-out); }
.member:hover .member-photo img { filter: grayscale(0); }
.member-contact { display: flex; flex-direction: column; gap: 3px; margin-top: 8px; }
.member-contact a { font-size: var(--fs-sm); color: var(--fg-2); text-decoration: none; word-break: break-word; transition: color var(--dur-fast) var(--ease-out); }
.member-contact a:hover { color: var(--ee-ink); }
.member-contact .m-tel { font-family: var(--font-mono); font-size: var(--fs-xs); }

/* ---------- CONTACT ---------- */
.contact { background: var(--ee-ink); color: var(--fg-on-ink); }
.contact .eyebrow { color: var(--ee-ink-300); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-9); align-items: start; }
.contact-lead .sec-title { color: var(--ee-white); margin: var(--space-5) 0; }
.contact-lead p { color: var(--ee-silver); font-size: var(--fs-md); line-height: var(--lh-loose); max-width: 46ch; margin: 0 0 var(--space-7); }
.contact-card { display: flex; align-items: center; gap: var(--space-5); padding: var(--space-5); border: var(--bw-hair) solid rgba(255,255,255,0.16); border-radius: var(--radius-3); max-width: 440px; }
.contact-card img { width: 76px; height: 76px; border-radius: 50%; object-fit: cover; flex-shrink: 0; filter: grayscale(1); }
.contact-card .cc-name { font-family: var(--font-headline); font-weight: 700; font-size: var(--fs-md); color: var(--ee-white); }
.contact-card .cc-role { font-size: var(--fs-sm); color: var(--ee-ink-300); margin: 2px 0 10px; }
.contact-card .cc-links { display: flex; flex-direction: column; gap: 3px; }
.contact-card .cc-links a { font-size: var(--fs-sm); color: var(--ee-silver); text-decoration: none; transition: color var(--dur-fast) var(--ease-out); }
.contact-card .cc-links a:hover { color: var(--ee-white); }
.contact-card .cc-tel { font-family: var(--font-mono); }
.cc-prompt { color: var(--ee-white); font-weight: 600; font-size: var(--fs-base); margin: 0 0 var(--space-3); }
.contact-list { display: grid; gap: 0; }
.contact-row { display: grid; grid-template-columns: 150px 1fr; gap: var(--space-4); padding: var(--space-5) 0; border-top: var(--bw-hair) solid rgba(255,255,255,0.14); align-items: baseline; }
.contact-row:last-child { border-bottom: var(--bw-hair) solid rgba(255,255,255,0.14); }
.contact-row dt { font-size: var(--fs-sm); color: var(--ee-ink-300); }
.contact-row dd { margin: 0; font-family: var(--font-headline); font-weight: 600; font-size: var(--fs-md); color: var(--ee-white); }

/* ---------- FOOTER ---------- */
.footer { background: var(--ee-ink); border-top: var(--bw-hair) solid rgba(255,255,255,0.12); padding: var(--space-7) 0; }
.footer-inner { display: flex; align-items: center; gap: var(--space-6); flex-wrap: wrap; }
.footer img { height: 46px; }
.footer .legal { font-size: var(--fs-sm); color: var(--ee-ink-300); margin-left: auto; text-align: right; line-height: 1.7; }
.footer .legal, .footer .legal p, .footer .legal a { color: var(--ee-ink-300); }
.footer .legal p { margin: 0; }

@media (max-width: 880px) {
  .nav-links .nav-link { display: none; }
  .about-grid, .contact-grid { grid-template-columns: 1fr; gap: var(--space-7); }
  .svc-grid { grid-template-columns: 1fr; gap: var(--space-7); }
  .svc { border-left: none; padding: 0; }
  .team-grid { grid-template-columns: 1fr 1fr; }
  .values { grid-template-columns: 1fr; }
}
