:root{
  --bg:#f5f7fb; --card:#ffffff; --text:#111827; --muted:#6b7280; --line:#e5e7eb;
  --accent:#ff7a32; --accent-dark:#d95f1c; --dark:#23262f;
  --shadow:0 12px 30px rgba(17,24,39,.08); --radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(1180px, calc(100% - 32px));margin:0 auto}
.topbar{background:var(--dark);color:#fff;font-size:14px}
.topbar .container{display:flex;justify-content:space-between;gap:14px;padding:10px 0;align-items:center}
.topbar a{color:#fff;text-decoration:none}
.nav{background:#fff;border-bottom:1px solid var(--line)}
.nav .container{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:16px 0}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;font-weight:900;font-size:26px}
.brand img{height:42px;width:auto}
.navlinks{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.pill,.btn,.form button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:11px 16px;border-radius:999px;text-decoration:none;border:1px solid var(--line);background:#fff;color:var(--text);font-weight:700;cursor:pointer}
.pill.cta,.btn.primary,.form button,button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.hero{padding:28px 0 24px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:20px;align-items:start}
.kicker{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.08em;color:var(--accent-dark);background:#fff3ec;border:1px solid #ffd7c2;border-radius:999px;padding:7px 11px;margin-bottom:14px}
h1{font-size:56px;line-height:1.05;margin:0 0 14px}
h2{font-size:34px;line-height:1.15;margin:0 0 12px}
h3{font-size:24px;line-height:1.2;margin:0 0 10px}
.lead{font-size:20px;color:#374151;max-width:780px}
.small{color:var(--muted);font-size:15px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.card.soft{background:#fff}
.hr{height:1px;background:var(--line);margin:16px 0}
.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin:18px 0 20px}
.badges{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}
.badge{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:var(--shadow)}
.badge b{display:block;margin-bottom:4px}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;margin:22px 0}
.section-copy{margin:26px auto}
.form{display:grid;gap:10px}
.form label{font-weight:700;font-size:14px}
.form input,.form select,.form textarea{width:100%;border:1px solid #d1d5db;border-radius:12px;padding:12px 14px;font:inherit;background:#fff}
.form textarea{min-height:120px;resize:vertical}
.hp-field{position:absolute!important;left:-9999px!important;opacity:0!important;pointer-events:none!important}
.linkcard{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;text-decoration:none;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);font-weight:700}
.footer{background:#fff;border-top:1px solid var(--line);margin-top:36px}
.footer .container{padding:28px 0}
.footer .cols{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:20px}
.footer a{text-decoration:none}
ul{padding-left:20px;margin:10px 0} li{margin:6px 0}
.project-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.project-card{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.project-thumb{height:220px;background:#f3f4f6}
.project-thumb img{width:100%;height:100%;object-fit:cover}
.project-body{padding:18px}
.project-title{font-size:30px;font-weight:900;line-height:1.1;margin:0 0 8px}
.project-layout{display:grid;grid-template-columns:1.2fr .8fr;gap:16px}
.project-gallery{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:16px;margin:18px 0}
.project-gallery .imgbox{background:#f3f4f6;border:1px solid var(--line);border-radius:18px;overflow:hidden;min-height:260px}
.project-gallery img{width:100%;height:100%;object-fit:cover}
#pt-home-project-grid a{display:block;position:relative;z-index:20;pointer-events:auto!important;text-decoration:none}
#pt-home-project-grid .pill{pointer-events:none}
@media (max-width:900px){
  .card,.soft,.project-card,.service-card,.linkcard,.container,.hero,.grid,.project-grid,.project-layout,.project-gallery{position:relative;z-index:1;overflow:visible!important}
  a,button,.btn,.pill,.linkcard{position:relative;z-index:5;pointer-events:auto!important;touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.08)}
  .card::before,.card::after,.soft::before,.soft::after{pointer-events:none!important}
}
@media (max-width:1000px){
  .hero-grid,.project-layout,.project-gallery,.footer .cols{grid-template-columns:1fr}
  .project-grid,.badges{grid-template-columns:1fr 1fr}
  h1{font-size:42px} h2{font-size:28px}
}
@media (max-width:720px){
  .container{width:min(1180px, calc(100% - 24px))}
  .topbar .container,.nav .container{display:block}
  .navlinks{margin-top:14px}
  .brand{font-size:22px} .brand img{height:36px}
  h1{font-size:34px} .lead{font-size:18px}
  .grid,.project-grid,.project-layout,.project-gallery,.footer .cols,.badges{grid-template-columns:1fr!important}
  .cta-row{flex-direction:column}
  .pill,.btn,.form button{width:100%}
}

/* ===== HERO FIX FINAL ===== */
.hero{
  position:relative;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, rgba(0,0,0,0.55), rgba(0,0,0,0.2));
  z-index:0;
  pointer-events:none;
}
.hero > *{
  position:relative;
  z-index:1;
}
.hero h1{
  color:#fff !important;
}
.hero p,
.hero .lead,
.hero .small{
  color:rgba(255,255,255,0.92) !important;
}
.hero-grid{
  max-width:1200px;
  margin:0 auto;
  padding-left:32px;
  padding-right:32px;
}
.hero .card{
  max-width:420px;
  margin-left:auto;
}
@media (max-width:900px){
  .hero-grid{
    padding-left:20px;
    padding-right:20px;
  }
  .hero .card{
    margin:0 auto;
    max-width:100%;
  }
}
/* FIX – text i kort på Stockholm/kommun-sidor */ body.stockholmsida .card, body.seo-city-page .card, body.kommun-page .card {
  color: #111827 !important;
}

body.stockholmsida .card h1,
body.stockholmsida .card h2,
body.stockholmsida .card h3,
body.seo-city-page .card h1,
body.seo-city-page .card h2,
body.seo-city-page .card h3,
body.kommun-page .card h1,
body.kommun-page .card h2,
body.kommun-page .card h3 {
  color: #111827 !important;
}

body.stockholmsida .card p,
body.stockholmsida .card li,
body.stockholmsida .card .small,
body.seo-city-page .card p,
body.seo-city-page .card li,
body.seo-city-page .card .small,
body.kommun-page .card p,
body.kommun-page .card li,
body.kommun-page .card .small {
  color: #374151 !important;
  opacity: 1 !important;
}

body.stockholmsida .card *,
body.seo-city-page .card *,
body.kommun-page .card * {
  opacity: 1 !important;
}
/* === FIX 1: Stockholm-/ortsidor, vänstra stora kortet ska inte behandlas som högra boxen === */ body.seo-city-page .hero .hero-grid > .card.soft, body.stockholmsida .hero .hero-grid > .card.soft {
  max-width: none !important;
  width: auto !important;
  margin-left: 0 !important;
  justify-self: start !important;
}

/* högra sidans box/kolumn på dessa sidor */ body.seo-city-page .hero .hero-grid > .hero-side, body.stockholmsida .hero .hero-grid > .hero-side, body.seo-city-page .hero .hero-grid > :last-child:not(.card.soft), body.stockholmsida .hero .hero-grid > :last-child:not(.card.soft) {
  max-width: 420px !important;
  width: 100% !important;
  margin-left: 0 !important;
  justify-self: end !important;
}

/* === FIX 2: Tjänster-sidans vita info-ruta ska ha mörk text === */ #services-box-title, #services-box-list, #services-box-list li {
  color: #111827 !important;
}

#services-box-list + .hr + .small {
  color: #374151 !important;
}
/* === Stockholm SEO-sidor – snygg layout === */ .container.stockholmsida.seo-city-page > .hero > .card.soft {
  width: 100% !important;
  max-width: 1000px !important;   /* bredare */
  margin: 40px auto !important;   /* luft runt */
  padding: 40px !important;       /* mer premium */
  border-radius: 18px !important;
}

/* rubrik */
.container.stockholmsida.seo-city-page .card.soft h1 {
  font-size: 42px !important;
  line-height: 1.2 !important;
  margin-bottom: 16px !important;
}

/* text */
.container.stockholmsida.seo-city-page .card.soft p {
  font-size: 16px !important;
  line-height: 1.6 !important;
  max-width: 700px;
}

/* info-boxar under */
.container.stockholmsida.seo-city-page .card.soft .card {
  margin-top: 20px;
  border-radius: 14px;
}
/* FIX: formulär i hero (offertbox) */
.hero .card,
.hero .card * {
  color: #1f2937 !important;
}

/* labels + inputs */
.hero .card label {
  color: #374151 !important;
}

.hero .card input,
.hero .card select,
.hero .card textarea {
  color: #111827 !important;
  background: #fff;
}

