
/*
Theme Name: Świadectwa MG Premium
Theme URI: https://example.com/
Author: OpenAI
Description: Premiumowy motyw WordPress dla strony świadectw energetycznych.
Version: 3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: swiadectwamg
*/

:root{
  --bg:#f5f6f2;
  --bg-soft:#eef2eb;
  --card:#ffffff;
  --card-soft:#f7faf6;
  --text:#20383a;
  --muted:#667676;
  --primary:#1f7a45;
  --primary-dark:#15583a;
  --primary-soft:#dff0e4;
  --accent:#c8dc87;
  --gold:#d7b85b;
  --line:#dde6dc;
  --shadow:0 18px 40px rgba(24, 44, 35, .08);
  --shadow-soft:0 12px 30px rgba(24, 44, 35, .06);
  --radius:28px;
  --radius-sm:18px;
  --container:min(1180px, calc(100% - 32px));
  --hero-grad:linear-gradient(135deg, #f5f7f3 0%, #edf3ea 50%, #f6f7f2 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 0 0, rgba(200,220,135,.25), transparent 22%),
    radial-gradient(circle at 100% 0, rgba(31,122,69,.08), transparent 26%),
    var(--bg);
  line-height:1.6;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-dark)}
.container{width:var(--container);margin:0 auto}
.section{padding:84px 0}
.section-muted{background:linear-gradient(180deg,#f1f4ef 0%, #f7f8f5 100%)}
.section-head{
  text-align:center;
  max-width:760px;
  margin:0 auto 42px;
}
.section-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  border-radius:999px;
  background:var(--primary-soft);
  color:var(--primary-dark);
  font-size:13px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.section-head h2{
  margin:18px 0 12px;
  font-size:clamp(2rem, 4vw, 3rem);
  line-height:1.1;
}
.section-head p{
  margin:0;
  color:var(--muted);
  font-size:1.05rem;
}
p{margin:0 0 1rem}
ul{margin:0;padding-left:1.1rem}
h1,h2,h3,h4{margin:0 0 1rem;line-height:1.1}
.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(255,255,255,.86);
  border-bottom:1px solid rgba(20,88,58,.08);
}
.site-header::before{
  content:""; position:absolute; left:0; right:0; top:0; height:5px;
  background:linear-gradient(90deg, var(--primary-dark), var(--primary), var(--accent));
}
.header-inner{
  min-height:92px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex; align-items:center; gap:14px;
  min-width:0;
}
.brand-symbol{
  width:180px; max-width:40vw; height:auto; flex:0 0 auto;
  filter: drop-shadow(0 6px 18px rgba(31,122,69,.16));
}
.brand-mark{
  display:flex; flex-direction:column; gap:2px;
}
.brand-title{
  font-size:1.18rem; font-weight:800; color:var(--text);
}
.brand-subtitle{
  font-size:.92rem; color:var(--muted);
}
.main-nav ul{
  list-style:none; margin:0; padding:0; display:flex; align-items:center; gap:8px;
}
.main-nav a{
  display:inline-flex; padding:12px 16px; border-radius:14px;
  color:var(--text); font-weight:700;
}
.main-nav a:hover, .main-nav .current-menu-item > a{
  background:rgba(31,122,69,.08);
  color:var(--primary-dark);
}
.menu-toggle{
  display:none;
  border:1px solid var(--line); background:#fff; color:var(--text);
  border-radius:14px; padding:11px 14px; font:inherit; font-weight:700;
}
.hero{
  position:relative;
  overflow:hidden;
  padding:48px 0 72px;
}
.hero::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:90px;
  background:linear-gradient(180deg, rgba(245,246,242,0) 0%, var(--bg) 100%);
  pointer-events:none;
}
.hero-shell{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:32px;
  align-items:stretch;
}
.hero-copy, .hero-visual{
  background:var(--hero-grad);
  border:1px solid var(--line);
  border-radius:36px;
  box-shadow:var(--shadow);
  position:relative;
}
.hero-copy{
  padding:46px;
}
.hero-copy::before{
  content:"";
  position:absolute;
  right:-60px; top:-100px;
  width:260px; height:260px; border-radius:50%;
  background:radial-gradient(circle, rgba(215,184,91,.18) 0%, rgba(215,184,91,0) 70%);
}
.hero-badge{
  display:inline-flex; gap:10px; align-items:center;
  padding:10px 14px; border-radius:999px;
  background:#fff; border:1px solid var(--line);
  font-size:13px; font-weight:800; letter-spacing:.02em;
  color:var(--primary-dark);
}
.hero h1{
  margin-top:22px;
  font-size:clamp(2.45rem, 5vw, 4.35rem);
}
.hero-lead{
  font-size:1.12rem; color:var(--muted);
  max-width:620px;
}
.hero-points{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px 18px;
  list-style:none; padding:0; margin:26px 0;
}
.hero-points li{
  position:relative; padding-left:30px; font-weight:700;
}
.hero-points li::before{
  content:""; position:absolute; left:0; top:3px; width:20px; height:20px;
  border-radius:50%; background:var(--primary-soft);
  box-shadow:inset 0 0 0 6px rgba(31,122,69,.13);
}
.hero-points li::after{
  content:""; position:absolute; left:7px; top:9px; width:7px; height:4px;
  border-left:2px solid var(--primary); border-bottom:2px solid var(--primary);
  transform:rotate(-45deg);
}

.hero-compliance{
  margin-top:18px;
  padding:14px 16px;
  border-radius:18px;
  background:linear-gradient(180deg,#f7fbf5 0%,#edf6ef 100%);
  border:1px solid #d8e7db;
  color:var(--primary-dark);
  font-weight:700;
  box-shadow:var(--shadow-soft);
}
.hero-eco-premium{
  width:min(100%, 520px);
  border-radius:28px;
}
.about-logo-box::before,
.about-logo-box::after{display:none;}
.about-logo-box{display:grid;place-items:center;}
.about-logo-large{width:min(100%, 360px); filter: drop-shadow(0 18px 34px rgba(23,55,39,.16));}
.why-grid{grid-template-columns:repeat(5,1fr);}

.hero-actions{
  display:flex; gap:14px; flex-wrap:wrap; margin:28px 0 0;
}
.button, button, input[type=submit]{
  appearance:none; border:none; cursor:pointer; font:inherit;
}
.button{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:16px 24px; border-radius:16px; font-weight:800;
  transition:.2s transform ease, .2s box-shadow ease, .2s background ease;
}
.button:hover{transform:translateY(-1px)}
.button-primary{
  background:linear-gradient(180deg, var(--primary) 0%, var(--primary-dark) 100%);
  color:#fff; box-shadow:0 14px 32px rgba(31,122,69,.22);
}
.button-outline{
  background:#fff; color:var(--text); border:1px solid var(--line); box-shadow:var(--shadow-soft);
}
.hero-mini{
  display:flex; gap:12px; flex-wrap:wrap; margin-top:22px;
}
.mini-stat{
  min-width:130px;
  padding:14px 16px; border-radius:18px;
  background:#fff; border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.mini-stat strong{display:block;font-size:1.2rem}
.mini-stat span{display:block;font-size:.9rem;color:var(--muted)}
.hero-visual{
  padding:34px;
  display:flex; flex-direction:column; justify-content:space-between;
  background:
    radial-gradient(circle at 100% 0, rgba(200,220,135,.26), transparent 32%),
    linear-gradient(145deg,#eef4ee 0%, #f8f9f5 50%, #eef3ed 100%);
}
.visual-top{
  display:flex; justify-content:space-between; align-items:flex-start; gap:12px;
}
.visual-card{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.92);
  border-radius:22px;
  padding:18px;
  box-shadow:var(--shadow-soft);
}
.visual-note{
  max-width:210px;
}
.visual-note strong{display:block;font-size:1.4rem;margin-bottom:4px}
.hero-illustration{
  position:relative;
  min-height:320px;
  display:grid;
  place-items:center;
  margin:12px 0 10px;
}
.house-plate{
  position:absolute; inset:auto 8% 16px 8%; height:14px;
  background:linear-gradient(90deg, rgba(31,122,69,.15), rgba(215,184,91,.35), rgba(31,122,69,.15));
  filter:blur(8px); border-radius:999px;
}
.hero-eco{
  width:min(100%, 440px);
  filter:drop-shadow(0 18px 34px rgba(23, 55, 39, .12));
}
.hero-stack{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:10px;
}
.chip{
  background:#fff; border:1px solid var(--line); border-radius:18px;
  padding:16px 14px; text-align:center;
}
.chip strong{display:block}
.chip span{display:block;color:var(--muted);font-size:.88rem}
.offer-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:22px;
}
.card{
  background:var(--card); border:1px solid var(--line); border-radius:30px;
  box-shadow:var(--shadow-soft);
}
.offer-card{padding:28px}
.icon-badge{
  width:72px; height:72px; border-radius:22px;
  display:grid; place-items:center;
  background:linear-gradient(180deg, #f3f8f1, #e6f0e4);
  border:1px solid var(--line);
  margin-bottom:20px;
}
.icon-badge img{width:42px;height:42px}
.offer-card h3{font-size:1.45rem;margin-bottom:12px}
.offer-card p{color:var(--muted);margin-bottom:18px}
.offer-meta{
  display:flex; gap:10px; flex-wrap:wrap;
}
.pill{
  display:inline-flex; padding:8px 12px; border-radius:999px;
  background:#f3f6f1; border:1px solid var(--line); color:var(--primary-dark); font-size:.88rem; font-weight:700;
}
.pricing-grid{
  display:grid; grid-template-columns:repeat(5,1fr); gap:22px; align-items:stretch;
}
.price-card{
  padding:26px;
  position:relative;
}
.price-card.featured{
  background:linear-gradient(180deg,#ffffff 0%, #f3faf5 100%);
  border-color:#d6e8db;
}
.price-tag{
  display:inline-flex; padding:7px 12px; border-radius:999px;
  background:var(--primary-soft); color:var(--primary-dark); font-size:13px; font-weight:800; margin-bottom:16px;
}
.price{
  font-size:2.05rem; font-weight:900; letter-spacing:-.03em; color:var(--primary-dark); margin-bottom:12px;
}
.price.small{font-size:1.35rem; line-height:1.28}
.price-card p{color:var(--muted)}
.price-list{
  margin:18px 0 0; padding:0; list-style:none;
}
.price-list li{
  padding-left:24px; position:relative; margin:0 0 10px;
}
.price-list li::before{
  content:""; position:absolute; left:0; top:8px; width:8px; height:8px; border-radius:50%;
  background:var(--primary);
}
.process-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.process-card{
  padding:28px;
  text-align:center;
}
.process-step{
  width:58px; height:58px; border-radius:18px;
  background:linear-gradient(180deg,#1f7a45,#15583a);
  color:#fff; display:grid; place-items:center; font-size:1.2rem; font-weight:900; margin:0 auto 16px;
  box-shadow:0 14px 26px rgba(31,122,69,.2);
}
.why-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
}
.why-card{
  padding:24px; text-align:center;
}
.why-card strong{
  display:block; margin-top:14px; font-size:1.05rem;
}
.why-card p{color:var(--muted); margin:.45rem 0 0}
.about-grid{
  display:grid; grid-template-columns:.95fr 1.05fr; gap:26px; align-items:stretch;
}
.about-photo{
  padding:20px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg,#ffffff 0%, #eff4ef 100%);
}
.about-avatar{
  width:100%; min-height:100%;
  border-radius:26px;
  overflow:hidden;
  background:
    radial-gradient(circle at 20% 15%, rgba(200,220,135,.45), transparent 28%),
    linear-gradient(160deg, #e0efe5 0%, #fefefe 50%, #dfe8de 100%);
  position:relative;
  min-height:440px;
}
.about-avatar::before{
  content:""; position:absolute; inset:0;
  background:
    url('assets/images/logo-symbol.png') no-repeat 14px 18px / 76px auto,
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0));
  opacity:.92;
}
.about-avatar::after{
  content:"AGH • OZE • Projekty energetyczne";
  position:absolute; left:28px; bottom:26px;
  padding:11px 14px; border-radius:999px;
  background:rgba(255,255,255,.9); border:1px solid rgba(255,255,255,.95);
  box-shadow:var(--shadow-soft); font-size:.9rem; font-weight:800; color:var(--primary-dark);
}
.about-lines{
  position:absolute; inset:86px 26px 26px;
  border-radius:24px;
  background:
    linear-gradient(135deg, rgba(31,122,69,.16) 0%, rgba(31,122,69,0) 40%),
    radial-gradient(circle at 80% 30%, rgba(215,184,91,.22), transparent 25%),
    #ffffff;
  border:1px solid rgba(31,122,69,.08);
}
.about-lines::before{
  content:"";
  position:absolute; inset:22px;
  border-radius:18px;
  background:
    linear-gradient(rgba(31,122,69,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,122,69,.06) 1px, transparent 1px);
  background-size:32px 32px;
}
.about-copy{
  padding:34px;
}
.about-copy h2{font-size:clamp(2rem,4vw,2.8rem)}
.about-copy p{color:var(--muted); font-size:1.03rem}
.about-points{
  display:grid; grid-template-columns:repeat(2,1fr); gap:14px; list-style:none; padding:0; margin:22px 0 0;
}
.about-points li{
  background:#fff; border:1px solid var(--line); border-radius:18px;
  padding:14px 16px; font-weight:700;
}
.cta-panel{
  padding:36px;
  display:grid; grid-template-columns:1.2fr .8fr; gap:24px; align-items:center;
  background:linear-gradient(135deg,#184d37 0%, #1f7a45 55%, #8bb565 100%);
  color:#fff;
}
.cta-panel p{color:rgba(255,255,255,.88)}
.cta-actions{display:flex; gap:14px; justify-content:flex-end; flex-wrap:wrap}
.button-white{
  background:#fff; color:var(--primary-dark);
}
.contact-grid{
  display:grid; grid-template-columns:.88fr 1.12fr; gap:24px;
}
.contact-card{padding:30px}
.contact-list{
  list-style:none; padding:0; margin:18px 0 0;
}
.contact-list li{
  padding:16px 0; border-bottom:1px solid var(--line);
}
.contact-list li:last-child{border-bottom:none}
.contact-list strong{display:block; font-size:.88rem; text-transform:uppercase; letter-spacing:.04em; color:var(--muted); margin-bottom:4px}
.contact-list span, .contact-list a{font-size:1.08rem; font-weight:700}
.contact-note{
  margin-top:22px; padding:16px 18px; border-radius:18px; background:#f3f7f2; border:1px solid var(--line); color:var(--muted);
}
.contact-form{
  display:grid; grid-template-columns:repeat(2,1fr); gap:14px;
}
.contact-form .full{grid-column:1/-1}
.contact-form input, .contact-form textarea, .contact-form select{
  width:100%;
  padding:15px 16px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:16px;
  font:inherit;
  color:var(--text);
}
.contact-form textarea{min-height:148px; resize:vertical}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{
  outline:2px solid rgba(31,122,69,.15);
  border-color:#b9d5c2;
}
.notice{
  display:none;
  margin:0 0 16px; padding:14px 16px; border-radius:16px;
  border:1px solid #d7e7da; background:#f4fbf5; color:var(--primary-dark); font-weight:700;
}
.notice.is-visible{display:block}
.notice.error{
  border-color:#f0d0cf; background:#fff4f4; color:#8c3131;
}
.site-footer{
  padding:34px 0 48px;
}
.footer-shell{
  padding:24px 28px;
  border-radius:26px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.8);
  box-shadow:var(--shadow-soft);
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; align-items:center;
}
.footer-brand{
  display:flex; gap:14px; align-items:center;
}
.footer-brand img{width:54px}
.footer-meta{color:var(--muted)}
.page-content{padding:56px 0 80px}
.page-card{
  padding:34px; background:#fff; border:1px solid var(--line); border-radius:28px; box-shadow:var(--shadow-soft);
}
.hp-field{
  position:absolute !important; left:-9999px !important; width:1px !important; height:1px !important; opacity:0 !important;
}
@media (max-width:1160px){
  .offer-grid,.pricing-grid,.why-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:960px){
  .hero-shell,.about-grid,.contact-grid,.cta-panel{grid-template-columns:1fr}
  .cta-actions{justify-content:flex-start}
  .hero-visual{order:-1}
}
@media (max-width:760px){
  .header-inner{min-height:82px}
  .menu-toggle{display:inline-flex}
  .main-nav{
    display:none; position:absolute; left:16px; right:16px; top:78px;
    background:#fff; border:1px solid var(--line); border-radius:22px; box-shadow:var(--shadow);
  }
  .main-nav.is-open{display:block}
  .main-nav ul{flex-direction:column; align-items:flex-start; padding:18px}
  .hero-copy,.hero-visual,.contact-card,.about-copy,.price-card,.offer-card,.process-card,.why-card{padding:24px}
  .hero-points,.about-points,.contact-form{grid-template-columns:1fr}
  .offer-grid,.pricing-grid,.process-grid,.why-grid,.hero-stack{grid-template-columns:1fr}
  .section{padding:68px 0}
  .brand-subtitle{display:none}
  .brand-title{font-size:1rem}
  .about-avatar{min-height:320px}
}


.about-logo-box{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  padding:36px;
  background:
    radial-gradient(circle at 20% 20%, rgba(200,220,135,.32), transparent 30%),
    radial-gradient(circle at 80% 18%, rgba(31,122,69,.12), transparent 28%),
    linear-gradient(145deg,#f7faf5 0%, #eef4ee 100%);
}
.about-logo-large{
  width:min(100%, 420px);
  filter:drop-shadow(0 16px 30px rgba(24,44,35,.10));
}
.about-badge{
  margin-top:18px;
  display:inline-flex;
  padding:11px 16px;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(31,122,69,.10);
  box-shadow:var(--shadow-soft);
  font-size:.92rem;
  font-weight:800;
  color:var(--primary-dark);
}
.about-avatar::before,.about-avatar::after,.about-lines,.about-lines::before{display:none !important}
.consent{
  display:flex;
  gap:12px;
  align-items:flex-start;
  font-size:.95rem;
  color:var(--muted);
  padding:4px 2px;
}
.consent input{
  width:18px !important;
  height:18px;
  margin-top:3px;
  flex:0 0 auto;
}
.consent a{font-weight:700}
.footer-meta a{font-weight:700}
.page-card h1{font-size:2.3rem}
@media (max-width:760px){
  .brand-symbol{width:150px}
  .about-logo-large{width:min(100%, 340px)}
  .about-badge{font-size:.84rem; text-align:center}
}


.hero-badge{display:none !important;}
.brand{gap:14px;}
.brand-symbol{width:84px; max-width:none; height:auto; filter:drop-shadow(0 10px 22px rgba(24,44,35,.12));}
.brand-title{font-size:1.14rem; letter-spacing:-0.02em;}
.brand-subtitle{font-size:.8rem; color:#5b6f65;}
.hero-visual .visual-card img{width:112px !important;}
.hero-illustration{padding:10px 12px 0;}
.hero-eco{width:min(100%, 520px); filter:drop-shadow(0 20px 38px rgba(26,58,43,.14));}
.about-logo-box{padding:44px;}
.about-logo-large{width:min(100%, 360px);}
.about-badge{display:none !important;}
@media (max-width:760px){
  .brand-symbol{width:70px;}
  .brand-title{font-size:1rem;}
  .brand-subtitle{font-size:.72rem;}
  .about-logo-large{width:min(100%, 280px);}
}
