/*
Theme Name: PROINVEST Rypin
Theme URI: https://proinvest-rypin.pl/
Author: PROINVEST / ChatGPT
Description: Lekki, responsywny motyw dla firmy budowlanej – gotowy pod Gutenberg. Kolory: granat #0F172A, pomarańcz #F97316. Czcionka: Inter.
Version: 1.0.0
License: GNU GPL v2 or later
Text Domain: proinvest
*/

/* Reset i bazowe zmienne */
:root{--primary:#0F172A;--accent:#F97316;--text:#0b1224;--muted:#6b7280;--bg:#ffffff;--radius:16px;--shadow:0 10px 24px rgba(2,8,23,.06)}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";color:var(--text);background:var(--bg);line-height:1.65}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
.container{width:100%;max-width:1200px;margin-inline:auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.1rem;border-radius:12px;border:1px solid transparent;font-weight:600;transition:.2s;cursor:pointer}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(.95)}
.btn-outline{border-color:var(--accent);color:var(--accent);background:#fff}
.btn-outline:hover{background:#fff3eb}
.section{padding:64px 0}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow)}
.kafel{padding:20px;border:1px solid #eef1f5;border-radius:14px;transition:.2s}
.kafel:hover{transform:translateY(-2px)}
.badge{display:inline-block;background:#fff3eb;color:var(--accent);padding:.25rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600;border:1px solid #ffd9bf}
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.grid-3,.grid-4,.grid-2{grid-template-columns:1fr}}

/* Header sticky */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #eef1f5}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--primary)}
.logo svg{width:28px;height:28px}
.nav{display:flex;gap:20px;align-items:center}
.nav a{color:var(--text);font-weight:600}
.nav .phone{color:#fff;background:var(--primary);padding:.5rem .75rem;border-radius:10px}
.burger{display:none}
@media (max-width:960px){.nav{display:none}.burger{display:inline-flex;padding:10px;border:1px solid #e5e7eb;border-radius:12px}}
.mobile-nav{display:none}
.mobile-nav.open{display:block;padding:10px 0;border-bottom:1px solid #eef1f5}
.mobile-nav a{display:block;padding:10px 0}

/* Hero */
.hero{padding:80px 0;background:linear-gradient(180deg,#fafafa,transparent)}
.hero h1{font-size:clamp(28px,4vw,44px);color:var(--primary);margin:0 0 12px}
.hero p{font-size:18px;color:#364152;margin:0 0 20px}
.hero .ctas{display:flex;gap:12px;flex-wrap:wrap}

/* Sections */
.services h2,.why h2,.realisations h2,.offer h1,.about h1,.contact h1{color:var(--primary)}
.services .kafel h3{margin:.5rem 0;font-size:18px}
.services .kafel p{margin:0;color:var(--muted);font-size:14px}

/* Gallery */
.gallery{gap:14px}
.gallery img{border-radius:14px}

/* Footer */
.site-footer{background:#0F172A;color:#cbd5e1;padding:40px 0;margin-top:40px}
.site-footer a{color:#cbd5e1}
.site-footer .brand{font-weight:800;color:#fff;margin-bottom:8px}
.copyright{border-top:1px solid #223; margin-top:20px;padding-top:12px;color:#94a3b8}

/* Forms */
.form{display:grid;gap:12px}
.form input,.form select,.form textarea{width:100%;padding:12px 14px;border:1px solid #e5e7eb;border-radius:12px;font:inherit}
.form label{font-weight:600;color:var(--primary)}
.form .row{display:grid;gap:12px}
@media(min-width:640px){.form .row{grid-template-columns:1fr 1fr}}
.form .consent{display:flex;gap:10px;align-items:flex-start}
.form .message{padding:12px;border-radius:10px}
.form .ok{background:#f0fdf4;border:1px solid #86efac}
.form .err{background:#fef2f2;border:1px solid #fecaca}


/* ======= Menu lepszy wygląd ======= */
.menu{list-style:none;margin:0;padding:0;display:flex;gap:24px;align-items:center}
.menu li{margin:0;padding:0}
.menu a{display:inline-block;padding:8px 0;color:var(--text);text-decoration:none;position:relative;font-weight:600}
.menu a:after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:transparent;border-radius:2px;transition:.2s}
.menu a:hover:after{background:var(--accent)}
.menu .current-menu-item>a{color:var(--primary)}
.site-header .bar{min-height:68px}
.custom-logo-link img{display:block;max-height:42px;width:auto}
/* Mobile */
@media (max-width:960px){
  .mobile-nav .menu{flex-direction:column;gap:10px}
}


/* ======= Header layout ======= */
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:14px 0;min-height:72px}
.nav-wrap{display:flex;align-items:center;gap:28px;flex:1;justify-content:flex-end;flex-wrap:nowrap}
.menu{list-style:none;margin:0;padding:0;display:flex;gap:22px;align-items:center}
.menu li{margin:0;padding:0}
.menu a{display:inline-block;padding:10px 0;color:var(--text);text-decoration:none;position:relative;font-weight:600}
.menu a:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:transparent;border-radius:2px;transition:.2s}
.menu a:hover:after{background:var(--accent)}
.menu .current-menu-item>a{color:var(--primary)}
.nav-ctas{display:flex;gap:12px;align-items:center;flex-shrink:0}
.custom-logo-link img{display:block;max-height:44px;width:auto}
.phone{display:inline-flex;align-items:center;justify-content:center;padding:.5rem .75rem;border-radius:10px;background:var(--primary);color:#fff;font-weight:700}

/* burger */
.burger{display:none;flex-direction:column;gap:4px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:8px 10px}
.burger span{width:20px;height:2px;background:#0F172A;display:block;border-radius:2px}

/* Mobile drawer */
.drawer-overlay{position:fixed;inset:0;background:rgba(15,23,42,.45);opacity:0;visibility:hidden;transition:.2s;z-index:80}
.mobile-drawer{position:fixed;top:0;right:0;height:100vh;width:min(86vw,360px);background:#fff;box-shadow:-12px 0 32px rgba(2,8,23,.2);transform:translateX(100%);transition:transform .25s ease;z-index:90;display:flex;flex-direction:column;padding:18px}
.mobile-drawer .menu{flex-direction:column;gap:10px}
.mobile-drawer .menu a{padding:10px 4px}
.drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.drawer-close{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:6px 10px;font-size:20px;line-height:1}
.drawer-ctas{margin-top:auto;display:grid;gap:10px}

/* Responsive */
@media (max-width:960px){
  .nav-wrap{display:none}
  .burger{display:flex}
}
/* Drawer open state */
.drawer-open .drawer-overlay{opacity:1;visibility:visible}
.drawer-open .mobile-drawer{transform:translateX(0)}
body.drawer-open{overflow:hidden}


/* Force horizontal main menu, no bullets */
.nav ul, .nav .menu, .main-menu, .site-header .menu {list-style:none !important; margin:0 !important; padding:0 !important; display:flex !important; gap:22px; align-items:center;}
.nav ul li, .site-header .menu li {list-style:none !important; margin:0; padding:0;}
.nav ul li a {display:inline-block; padding:10px 0; font-weight:600; text-decoration:none; color:var(--text); position:relative;}
.nav ul li a:hover:after{content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px; background:var(--accent); border-radius:2px;}


/* Footer high-contrast */
.site-footer, .site-footer p, .site-footer li, .site-footer a, .site-footer strong { color:#ffffff !important; }
.site-footer .brand, .site-footer .brand *{ color:#ffffff !important; }
.site-footer .menu a:hover{ text-decoration:underline; }

/* Hide homepage default title */



/* === Services: list layout (2 kolumny / mobile 1 kolumna) === */
.section.services-list .list-grid { gap:18px; }
.section.services-list .service-row{
  display:flex; gap:14px; align-items:flex-start;
  padding:16px 18px; background:#fff;
  border:1px solid #eef1f5; border-radius:16px; box-shadow:var(--shadow);
  position:relative; overflow:hidden;
}
.section.services-list .service-row::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:linear-gradient(180deg,#F97316,#fb923c);
}
.section.services-list .badge{
  width:36px; height:36px; border-radius:10px;
  background:#fff3eb; border:1px solid #ffd9bf; color:#F97316;
  display:flex; align-items:center; justify-content:center; font-weight:800; flex:0 0 36px;
}
.section.services-list h3{ margin:0 0 4px; color:var(--primary); }
.section.services-list p{ margin:0; color:#435071; }
.section.services-list .service-row:hover{ transform:translateY(-2px); box-shadow:0 14px 34px rgba(2,8,23,.10); }

@media (min-width:900px){
  /* wymuszamy prawdziwe 2 kolumny, równo w pionie */
  .section.services-list .wp-block-columns.list-grid{
    display:grid; grid-template-columns:1fr 1fr; gap:18px;
  }
}
@media (max-width:899px){
  .section.services-list .wp-block-columns.list-grid{ display:block; }
  .section.services-list .wp-block-column{ margin:0 0 18px; }
}


/* Why section cards */
.section.why-modern .why-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:18px}
@media(max-width:1024px){.section.why-modern .why-grid{grid-template-columns:1fr}}
.feature-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.feature-list li{display:flex;gap:10px;align-items:flex-start}
.feature-list li:before{content:"✔";display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:#f0f9ff;color:#0F172A;border:1px solid #dbeafe;font-weight:700;line-height:1;margin-top:2px}
.callout{background:#fff;border:1px solid #eef1f5;border-radius:16px;box-shadow:var(--shadow);padding:20px}
.callout strong{color:var(--primary)}

/* Hero bez tła/cieni */
.section.hero,
.section.hero .wp-block-group {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
