/*
Theme Name: LokalRang
Theme URI: https://lokalrang.de
Author: LokalRang
Description: Schnelles, SEO-freundliches Theme fuer LokalRang — lokales Online-Marketing fuer Meisterbetriebe in Deutschland. Custom Post Types fuer Leistungen, Referenzen und Bewertungen, Theme-Optionen, Blog und 1-Klick-Demo-Import.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: lokalrang
*/

:root{
  --navy:#0F2A43; --navy2:#16385A; --blue:#1A73E8; --blue-soft:#E8F0FE;
  --yellow:#F9AB00; --green:#188038; --ink:#1B2733; --grey:#5F6368;
  --line:#E3E8EF; --bg:#fff; --bg2:#F4F7FB; --radius:14px; --wrap:1140px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--ink);line-height:1.65;background:var(--bg)}
h1,h2,h3,h4{font-family:'Archivo',sans-serif;line-height:1.15;color:var(--navy)}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 20px}
.btn{display:inline-block;background:var(--blue);color:#fff;font-weight:700;padding:13px 26px;border-radius:50px;transition:transform .15s,background .15s}
.btn:hover{transform:translateY(-2px);background:#1557b0}
.btn-ghost{background:transparent;border:2px solid var(--blue);color:var(--blue)}
.btn-yellow{background:var(--yellow);color:var(--navy)}
.section{padding:72px 0}
.section.alt{background:var(--bg2)}
.section-head{text-align:center;max-width:680px;margin:0 auto 48px}
.section-head h2{font-size:clamp(1.6rem,4vw,2.3rem)}
.section-head p{color:var(--grey);margin-top:10px}
.eyebrow{display:inline-block;color:var(--blue);font-weight:700;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:#fff;border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.site-logo{font-family:'Archivo';font-weight:800;font-size:1.4rem;color:var(--navy)}
.site-logo span{color:var(--yellow)}
.main-nav ul{list-style:none;display:flex;gap:26px;align-items:center}
.main-nav a{color:var(--ink);font-weight:600;font-size:.95rem}
.main-nav a:hover{color:var(--blue)}
.menu-toggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--navy)}


/* Custom logo sizing (fits header bar) */
.site-header .custom-logo-link{display:inline-flex;align-items:center}
.site-header .custom-logo{max-height:44px;width:auto;height:auto;display:block}
@media(max-width:640px){.site-header .custom-logo{max-height:36px}}

/* Hero */
.hero{background:linear-gradient(160deg,var(--navy),var(--navy2));color:#fff;padding:80px 0}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);font-weight:800}
.hero p{color:#C9D6E5;font-size:1.1rem;margin:18px 0 28px;max-width:540px}
.hero .btn-row{display:flex;gap:14px;flex-wrap:wrap}
.hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:28px}
.hero-card h3{color:#fff;font-size:1.1rem;margin-bottom:14px}
.hero-stat{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1);color:#C9D6E5}
.hero-stat b{color:var(--yellow);font-family:'Archivo'}

/* Trust bar */
.trustbar{background:#fff;border-bottom:1px solid var(--line);padding:22px 0}
.trustbar .row{display:flex;justify-content:center;gap:40px;flex-wrap:wrap;align-items:center;opacity:.7;font-weight:700;color:var(--grey)}

/* Cards grid */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:0 12px 30px rgba(15,42,67,.1);transform:translateY(-3px)}
.card .ic{width:52px;height:52px;border-radius:12px;background:var(--blue-soft);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:16px}
.card h3{font-size:1.15rem;margin-bottom:8px}
.card h3 a{color:var(--navy)}
.card p{color:var(--grey);font-size:.95rem}
.card .more{display:inline-block;margin-top:14px;font-weight:700;font-size:.9rem}

/* Why-us */
.why{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center}
.why .item .ic{width:60px;height:60px;margin:0 auto 14px;border-radius:50%;background:var(--navy);color:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:1.6rem}
.why h4{margin-bottom:6px}
.why p{color:var(--grey);font-size:.92rem}

/* Case studies */
.case{display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius);border:1px solid var(--line);background:#fff}
.case img{aspect-ratio:16/9;object-fit:cover;width:100%}
.case .body{padding:22px}
.case .tag{font-size:.72rem;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.05em}
.case h3{font-size:1.1rem;margin:8px 0}
.case h3 a{color:var(--navy)}
.case .metric{font-family:'Archivo';font-size:1.8rem;color:var(--green);font-weight:800}

/* Testimonials */
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.tcard .stars{color:var(--yellow);margin-bottom:10px}
.tcard p{font-style:italic;color:var(--ink)}
.tcard .who{margin-top:14px;font-weight:700;color:var(--navy)}
.tcard .who span{display:block;font-weight:400;font-size:.85rem;color:var(--grey)}

/* CTA band */
.cta-band{background:linear-gradient(160deg,var(--navy),var(--navy2));color:#fff;text-align:center;padding:64px 20px;border-radius:20px}
.cta-band h2{color:#fff}
.cta-band p{color:#C9D6E5;max-width:560px;margin:12px auto 24px}

/* Blog */
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.post-card img{aspect-ratio:16/9;object-fit:cover}
.post-card .body{padding:22px}
.post-card .meta{font-size:.8rem;color:var(--grey);margin-bottom:6px}
.post-card h3{font-size:1.1rem}.post-card h3 a{color:var(--navy)}

/* Single / pages */
.entry{max-width:760px;margin:0 auto;padding:56px 20px}
.entry h1{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:10px}
.entry .meta{color:var(--grey);margin-bottom:24px;font-size:.9rem}
.entry p{margin:0 0 18px}.entry h2{margin:28px 0 12px}.entry h3{margin:22px 0 10px}
.entry ul,.entry ol{margin:0 0 18px 22px}.entry li{margin-bottom:8px}
.entry img{border-radius:var(--radius);margin:20px 0}
.breadcrumbs{font-size:.85rem;color:var(--grey);padding:16px 0}
.breadcrumbs a{color:var(--grey)}

/* Sidebar / archive */
.layout{display:grid;grid-template-columns:1fr 300px;gap:40px;max-width:var(--wrap);margin:0 auto;padding:48px 20px}
.widget{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:22px}
.widget h4{margin-bottom:12px}
.widget ul{list-style:none}.widget li{padding:6px 0;border-bottom:1px solid var(--line)}
.related{margin-top:40px}

/* Contact form */
.cform{display:grid;gap:14px;max-width:560px}
.cform input,.cform textarea{width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:10px;font:inherit}
.cform textarea{min-height:140px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.contact-info .line{display:flex;gap:12px;margin-bottom:16px}

/* Footer */
.site-footer{background:var(--navy);color:#9FC2F5;padding:56px 0 24px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:14px}
.site-footer ul{list-style:none}.site-footer li{padding:5px 0}
.site-footer a{color:#C9D6E5;font-size:.92rem}.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:36px;padding-top:20px;text-align:center;font-size:.85rem}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:36px}
.pagination .page-numbers{padding:8px 14px;border:1px solid var(--line);border-radius:8px;color:var(--navy)}
.pagination .current{background:var(--navy);color:#fff}

@media(max-width:980px){
  .hero-grid,.contact-grid{grid-template-columns:1fr}
  .grid-3,.grid-4,.why{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .layout{grid-template-columns:1fr}
}
@media(max-width:640px){
  .main-nav{display:none;position:absolute;top:72px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:16px 20px}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:14px;align-items:flex-start}
  .menu-toggle{display:block}
  .grid-3,.grid-4,.why,.grid-2{grid-template-columns:1fr}
}

/* ===== Responsive refinements ===== */
@media(max-width:1180px){
  .wrap{max-width:960px}
  .hero h1{font-size:clamp(1.8rem,4.5vw,2.8rem)}
}
@media(max-width:980px){
  .main-nav ul{gap:18px}
  .hero{padding:60px 0}
  .section{padding:56px 0}
}
@media(max-width:860px){
  /* tablet: collapse nav to toggle earlier so it never overlaps the button */
  .main-nav{display:none;position:absolute;top:72px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:16px 20px;z-index:99}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;gap:14px;align-items:flex-start}
  .menu-toggle{display:block}
  .header-inner .btn{display:none}
}
@media(max-width:760px){
  .grid-3,.grid-4,.why{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:560px){
  .grid-2,.grid-3,.grid-4,.why,.prices,.footer-grid{grid-template-columns:1fr}
  .hero h1{font-size:1.7rem}
  .section-head h2{font-size:1.4rem}
  .entry{padding:40px 16px}
  .cta-band{padding:40px 18px}
  .hero .btn-row{flex-direction:column}
  .hero .btn-row .btn{width:100%;text-align:center}
  .layout{padding:32px 16px}
}
/* Prevent any element forcing horizontal scroll on mobile */
html,body{overflow-x:hidden}
img{max-width:100%;height:auto}
.wrap{width:100%}

/* Footer widget areas */
.footer-widget{margin-bottom:18px}
.footer-widget h4{color:#fff;font-size:1rem;margin-bottom:14px}
.footer-widget ul{list-style:none}
.footer-widget li{padding:5px 0}
.footer-widget a{color:#C9D6E5}
.footer-widget a:hover{color:#fff}
.footer-col{min-width:0}
.footer-logo{margin-bottom:6px}
.footer-logo-img{display:block;margin-bottom:6px}
