/* Trzemivento - Strategiczne SEO | utility system inspired by Webflow + Tailwind */
:root{
  --primary-50:#F4ECFB;
  --primary-100:#E5D2F4;
  --primary-200:#C9A6E6;
  --primary-300:#A872D2;
  --primary-400:#8843BD;
  --primary-500:#6B2A9C;
  --primary-600:#4F1F7A;
  --primary-700:#3B1E5D;
  --primary-800:#2A1444;
  --primary-900:#1A0B2C;
  --primary-950:#120721;
  --accent-400:#E147ED;
  --accent-500:#C026D3;
  --accent-600:#A21CAF;
  --accent-700:#86198F;
  --slate-50:#F8FAFC;
  --slate-100:#F1F5F9;
  --slate-200:#E2E8F0;
  --slate-300:#CBD5E1;
  --slate-500:#64748B;
  --slate-600:#475569;
  --slate-700:#334155;
  --slate-800:#1E293B;
  --slate-900:#0F172A;
  --color-bg:#FFFFFF;
  --font-body:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-heading:"Lora", Georgia, "Times New Roman", serif;
  --shadow-sm:0 1px 2px rgba(15, 23, 42, .06);
  --shadow-md:0 8px 24px rgba(15, 23, 42, .08);
  --shadow-lg:0 24px 60px rgba(15, 23, 42, .12);
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:20px;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  color:var(--slate-900);
  background:var(--color-bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--accent-500);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--accent-600)}

/* Containers */
.container{max-width:1240px;margin:0 auto;width:100%;padding-left:24px;padding-right:24px}
.container-narrow{max-width:960px;margin:0 auto;width:100%;padding-left:24px;padding-right:24px}
.container-tight{max-width:760px;margin:0 auto;width:100%;padding-left:24px;padding-right:24px}

.section{padding-top:96px;padding-bottom:96px;position:relative;overflow:hidden}
.section--white{background:#fff}
.section--soft{background:var(--primary-50)}
.section--dark{background:var(--primary-700);color:#fff}

/* Typography */
h1,h2,h3,h4{font-weight:700;line-height:1.2;color:var(--slate-900);margin:0 0 .5em;font-family:var(--font-heading)}
h1{font-size:clamp(2.2rem, 4.4vw, 3.4rem);letter-spacing:-.02em}
h2{font-size:clamp(1.9rem, 3vw, 2.4rem);letter-spacing:-.015em;text-align:center}
h3{font-size:1.2rem;font-weight:600}
h4{font-size:1.05rem;font-weight:600}
p{margin:0 0 1em;color:var(--slate-700)}
.subhead{font-size:1.05rem;color:var(--slate-600);text-align:center;max-width:680px;margin:0 auto 56px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 24px;
  border-radius:var(--radius-sm);
  font-weight:600;font-size:.94rem;
  border:1.5px solid transparent;cursor:pointer;
  transition:background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  text-decoration:none;
  line-height:1.2;
  font-family:var(--font-body);
}
.btn--primary{background:var(--accent-500);color:#fff;box-shadow:0 6px 18px rgba(192,38,211,.32)}
.btn--primary:hover{background:var(--accent-600);color:#fff;transform:translateY(-1px);box-shadow:0 10px 26px rgba(192,38,211,.4)}
.btn--secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn--secondary:hover{background:rgba(255,255,255,.1);border-color:#fff;color:#fff}
.btn--outline{background:#fff;color:var(--primary-700);border-color:var(--primary-200)}
.btn--outline:hover{border-color:var(--accent-500);color:var(--accent-600)}
.btn--ghost{background:transparent;color:var(--slate-900);border-color:var(--slate-300)}
.btn--ghost:hover{border-color:var(--accent-500);color:var(--accent-500)}

/* Header (dark purple, full width with brand+nav+cta) */
.site-header{
  position:sticky;top:0;
  z-index:40;
  width:100%;
  background:var(--primary-700);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:18px 24px;max-width:1320px;margin:0 auto;
}
.site-header__brand{
  display:flex;align-items:center;gap:12px;
  font-weight:700;color:#fff;
  font-size:1.1rem;
  transition:transform .2s ease;
}
.site-header__brand:hover{transform:scale(1.03);color:#fff}
.site-header__logo{
  width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--accent-500), var(--primary-500));
  border-radius:12px;
  color:#fff;
  box-shadow:0 6px 18px rgba(192,38,211,.32);
}
.site-header__logo svg{width:22px;height:22px;fill:#fff}
.site-header__brand-text{
  display:flex;flex-direction:column;line-height:1.1;
}
.site-header__brand-text strong{font-size:1.15rem;font-weight:700;color:#fff;font-family:var(--font-heading)}
.site-header__brand-text span{font-size:.78rem;color:rgba(255,255,255,.7);font-weight:400;margin-top:2px}
.site-header__nav{display:flex;align-items:center;gap:8px;flex:1;justify-content:center}
.site-header__nav a{
  color:rgba(255,255,255,.85);font-size:.94rem;font-weight:500;
  padding:8px 18px;border-radius:8px;transition:background .2s, color .2s;
}
.site-header__nav a:hover, .site-header__nav a.is-current{color:#fff;background:rgba(255,255,255,.08)}
.site-header__cta{
  background:var(--accent-500);color:#fff;
  padding:11px 22px;border-radius:10px;
  font-weight:600;font-size:.92rem;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 6px 18px rgba(192,38,211,.32);
  transition:background .2s, transform .2s, box-shadow .2s;
}
.site-header__cta:hover{background:var(--accent-600);color:#fff;transform:translateY(-1px);box-shadow:0 10px 26px rgba(192,38,211,.4)}
.site-header__burger{
  display:none;background:none;border:none;width:42px;height:42px;
  padding:8px;cursor:pointer;color:#fff;
}
.site-header__burger span{display:block;width:100%;height:2px;background:currentColor;margin:5px 0;transition:transform .25s}

/* Hero (dark purple, two-column) */
.hero{
  background:var(--primary-700);
  color:#fff;
  position:relative;overflow:hidden;
  padding:80px 0 96px;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 12% 18%, rgba(192,38,211,.18) 0, transparent 38%),
    radial-gradient(circle at 88% 78%, rgba(168,114,210,.14) 0, transparent 42%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.025) 0 2px, transparent 2px 28px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,.025) 0 2px, transparent 2px 28px);
  pointer-events:none;
}
.hero__inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.hero__copy h1{color:#fff;margin:0 0 18px}
.hero__copy h1 span{color:var(--accent-400);display:block}
.hero__sub{color:rgba(255,255,255,.85);font-size:1.08rem;max-width:520px;margin:0 0 32px}
.hero__buttons{display:flex;gap:14px;flex-wrap:wrap}
.hero__image{
  position:relative;
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.35);
}
.hero__image img{width:100%;display:block;aspect-ratio:7/5;object-fit:cover}

/* Feature grid (4 column with magenta icon) */
.features-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  margin-top:8px;
}
.feature-tile{
  background:#fff;
  border:1px solid var(--primary-100);
  border-radius:var(--radius-md);
  padding:28px 24px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.feature-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-400)}
.feature-tile__icon{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg, var(--primary-700), var(--accent-500));
  color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:16px;font-size:1.2rem;
}
.feature-tile__num{
  display:inline-block;font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent-500);
  font-weight:700;margin-bottom:6px;
}
.feature-tile h3{font-size:1.06rem;margin:0 0 8px;color:var(--primary-700)}
.feature-tile p{margin:0;font-size:.92rem;color:var(--slate-600);line-height:1.55}

/* Split (text + image) */
.split-2{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center}
.split-2--reverse{grid-template-columns:1fr 1.05fr}
.split-2 img{
  width:100%;border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);
}
.split-2__head{
  font-size:.85rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent-500);
  margin:0 0 12px;
}
.split-2 h2{text-align:left;margin-top:0;color:var(--primary-700)}
.bullet-list{list-style:none;padding:0;margin:20px 0 0}
.bullet-list li{
  padding:10px 0 10px 32px;position:relative;
  color:var(--slate-700);font-size:.96rem;
}
.bullet-list li::before{
  content:"";position:absolute;left:0;top:14px;
  width:18px;height:18px;border-radius:50%;
  background:var(--accent-500);
}
.bullet-list li::after{
  content:"";position:absolute;left:5px;top:19px;
  width:8px;height:4px;
  border-left:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(-45deg);
}

/* Testimonials */
.testimonials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.testimonial{
  background:#fff;
  border:1px solid var(--primary-100);
  border-radius:var(--radius-md);
  padding:28px;
}
.testimonial__quote{
  font-size:1rem;line-height:1.6;margin:0 0 18px;color:var(--slate-700);
}
.testimonial__stars{color:#F59E0B;font-size:.95rem;letter-spacing:2px;margin-bottom:14px}
.testimonial__author{
  display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid var(--primary-100);
}
.testimonial__avatar{
  width:42px;height:42px;border-radius:50%;
  object-fit:cover;
}
.testimonial__name{font-weight:600;font-size:.94rem;color:var(--slate-900)}
.testimonial__role{font-size:.82rem;color:var(--slate-500)}

/* Stats */
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  margin-top:8px;
}
.stat-card{
  background:linear-gradient(135deg, var(--primary-700), var(--primary-800));
  color:#fff;
  border-radius:var(--radius-md);
  padding:32px 24px;
  text-align:center;
}
.stat-card__num{
  font-size:2.6rem;font-weight:800;
  color:var(--accent-400);font-family:var(--font-heading);
  line-height:1;margin-bottom:10px;
}
.stat-card__label{font-size:.94rem;color:rgba(255,255,255,.85)}

/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:#fff;border:1px solid var(--primary-100);
  border-radius:var(--radius-md);
  padding:22px 26px;
}
.faq-item summary{
  font-weight:600;font-size:1.02rem;color:var(--slate-900);
  cursor:pointer;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:18px;
  font-family:var(--font-heading);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";color:var(--accent-500);font-size:1.4rem;font-weight:400;line-height:1;
  transition:transform .25s ease;
}
.faq-item[open] summary::after{content:"–"}
.faq-item p{margin:14px 0 0;color:var(--slate-600);font-size:.95rem;line-height:1.6}

/* CTA section */
.cta-section{
  text-align:center;
  background:var(--primary-700);
  color:#fff;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(192,38,211,.18) 0, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(168,114,210,.14) 0, transparent 42%);
  pointer-events:none;
}
.cta-section h2{margin-bottom:18px;color:#fff;position:relative;z-index:1}
.cta-section p.subhead{margin-bottom:36px;color:rgba(255,255,255,.85);position:relative;z-index:1}
.cta-section .btn{position:relative;z-index:1}
.cta-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin-bottom:48px;position:relative;z-index:1;
}
.cta-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius-md);padding:24px;
  text-align:left;
  backdrop-filter:blur(8px);
}
.cta-card h3{color:var(--accent-400);font-size:1rem;margin:0 0 8px}
.cta-card p{margin:0;font-size:.9rem;color:rgba(255,255,255,.85)}

/* Footer (dark purple, 4 cols) */
.site-footer{
  background:var(--primary-800);
  color:rgba(255,255,255,.85);
  padding:80px 0 28px;
  border-top:1px solid rgba(255,255,255,.08);
}
.site-footer__grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;
  margin-bottom:40px;
}
.site-footer__brand{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.site-footer__brand-text{font-weight:700;font-size:1.15rem;color:#fff;font-family:var(--font-heading)}
.site-footer h4{
  font-size:1rem;font-weight:600;color:#fff;
  margin:0 0 18px;font-family:var(--font-heading);
}
.site-footer p{font-size:.94rem;line-height:1.6;color:rgba(255,255,255,.72);margin:0 0 18px}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.site-footer ul li a{color:rgba(255,255,255,.78);font-size:.94rem}
.site-footer ul li a:hover{color:var(--accent-400)}
.site-footer__contact{font-size:.94rem;line-height:1.7;color:rgba(255,255,255,.78)}
.site-footer__contact strong{display:block;color:#fff;font-weight:600;margin-top:14px}
.site-footer__contact strong:first-child{margin-top:0}
.site-footer__contact a{color:rgba(255,255,255,.85)}
.site-footer__contact a:hover{color:var(--accent-400)}
.site-footer__social{display:flex;gap:14px;margin-top:6px}
.site-footer__social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:8px;
  background:rgba(255,255,255,.06);
  color:#fff;font-size:1rem;
  transition:background .2s, color .2s, transform .2s;
}
.site-footer__social a:hover{background:var(--accent-500);color:#fff;transform:translateY(-2px)}
.site-footer__divider{height:1px;background:rgba(255,255,255,.1);margin:8px 0 28px}
.site-footer__bottom{
  padding-top:22px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;
  font-size:.88rem;color:rgba(255,255,255,.6);
}
.site-footer__legal-row{display:flex;gap:24px;flex-wrap:wrap}
.site-footer__legal-row a{color:rgba(255,255,255,.78);font-size:.88rem}
.site-footer__legal-row a:hover{color:var(--accent-400)}

/* Cookie banner — TOP full-width dark purple */
.cookie-banner{
  position:fixed;top:0;left:0;right:0;
  z-index:1050;
  background:var(--primary-800);
  border-bottom:1px solid rgba(255,255,255,.1);
  padding:18px 24px;
  display:none;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
}
.cookie-banner.is-visible{display:block}
.cookie-banner__inner{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
}
.cookie-banner__icon{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg, var(--accent-500), var(--primary-500));
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;
  flex-shrink:0;
}
.cookie-banner__body{color:rgba(255,255,255,.92)}
.cookie-banner__title{
  font-weight:700;color:#fff;font-size:1rem;margin:0 0 4px;
  font-family:var(--font-heading);
}
.cookie-banner__sub{font-size:.78rem;color:rgba(255,255,255,.65);margin:0 0 6px;letter-spacing:.04em}
.cookie-banner__text{font-size:.88rem;line-height:1.5;color:rgba(255,255,255,.85);margin:0}
.cookie-banner__text a{color:var(--accent-400);text-decoration:underline}
.cookie-banner__actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-btn{
  padding:10px 18px;border-radius:999px;
  font-size:.88rem;font-weight:600;cursor:pointer;
  border:1px solid rgba(255,255,255,.4);
  background:transparent;color:#fff;
  display:inline-flex;align-items:center;gap:8px;
  transition:background .2s, border-color .2s;
  font-family:var(--font-body);
}
.cookie-btn:hover{background:rgba(255,255,255,.1);border-color:#fff}
.cookie-btn--accept{background:var(--accent-500);border-color:var(--accent-500);color:#fff}
.cookie-btn--accept:hover{background:var(--accent-600);border-color:var(--accent-600)}

/* Page hero (inner pages) */
.page-hero{
  background:var(--primary-700);
  color:#fff;
  padding:80px 0 64px;
  text-align:center;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(192,38,211,.16) 0, transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(168,114,210,.12) 0, transparent 42%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.025) 0 2px, transparent 2px 28px);
  pointer-events:none;
}
.page-hero h1{color:#fff;position:relative;z-index:1;margin:0 auto 14px;max-width:780px}
.page-hero p{color:rgba(255,255,255,.85);max-width:600px;margin:0 auto;position:relative;z-index:1}

/* Legal */
.legal-shell{max-width:840px;margin:0 auto}
.legal-shell h2{text-align:left;margin-top:1.6em;font-size:1.5rem;color:var(--primary-700)}
.legal-shell h3{margin-top:1.4em;font-size:1.15rem;color:var(--primary-700)}
.legal-shell p,.legal-shell li{color:var(--slate-700);font-size:.98rem;line-height:1.7}
.legal-shell ul{padding-left:1.3em}
.legal-shell li{margin:.4em 0}
.legal-shell .badge{
  display:inline-block;padding:6px 14px;
  background:var(--primary-50);color:var(--accent-600);
  font-size:.84rem;font-weight:600;border-radius:999px;
  margin-bottom:14px;
}

/* Team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.team-card{
  background:#fff;border:1px solid var(--primary-100);
  border-radius:var(--radius-md);padding:0 0 24px;
  text-align:center;overflow:hidden;
  transition:transform .25s, box-shadow .25s;
}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.team-card img{width:100%;height:240px;object-fit:cover;margin-bottom:18px}
.team-card h3{margin:0 0 4px;font-size:1.1rem;color:var(--primary-700)}
.team-card p{margin:0 24px;color:var(--slate-600);font-size:.9rem}
.team-card .role{
  display:inline-block;font-size:.78rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent-500);
  font-weight:700;margin:0 0 10px;
}

/* Process */
.process-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.process-card{
  background:#fff;border:1px solid var(--primary-100);
  border-radius:var(--radius-md);
  padding:26px 22px;
  position:relative;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.process-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-400)}
.process-card__step{
  width:40px;height:40px;border-radius:10px;
  background:var(--primary-700);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:700;font-family:var(--font-heading);
  margin-bottom:14px;
}
.process-card h3{margin:0 0 8px;font-size:1.04rem;color:var(--primary-700)}
.process-card p{margin:0;font-size:.92rem;color:var(--slate-600)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-card{
  padding:22px 24px;background:var(--primary-50);
  border-radius:var(--radius-md);margin-bottom:14px;
  border-left:3px solid var(--accent-500);
}
.contact-card strong{
  display:block;color:var(--accent-600);
  margin-bottom:6px;font-size:.78rem;letter-spacing:.08em;
  text-transform:uppercase;font-weight:700;
}
.contact-card a, .contact-card .value{color:var(--slate-900);font-weight:500;font-size:1rem}

.form-field{margin-bottom:18px}
.form-field label{display:block;font-weight:500;margin-bottom:6px;color:var(--slate-900);font-size:.92rem}
.form-field input,
.form-field textarea{
  width:100%;padding:12px 16px;
  border:1px solid var(--slate-200);
  border-radius:var(--radius-sm);
  font-family:inherit;font-size:1rem;color:var(--slate-900);
  transition:border-color .2s, box-shadow .2s;
  background:#fff;
}
.form-field input:focus,
.form-field textarea:focus{
  outline:none;border-color:var(--accent-500);
  box-shadow:0 0 0 3px rgba(192,38,211,.14);
}
.form-field textarea{min-height:140px;resize:vertical}

/* Service tiles */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.service-card{
  background:#fff;border:1px solid var(--primary-100);
  border-radius:var(--radius-md);
  padding:30px 26px;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-400)}
.service-card__icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg, var(--primary-700), var(--accent-500));
  color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:18px;font-size:1.4rem;
}
.service-card h3{margin:0 0 10px;font-size:1.15rem;color:var(--primary-700)}
.service-card p{margin:0 0 14px;color:var(--slate-600);font-size:.95rem}
.service-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.service-card ul li{
  padding:0 0 0 22px;position:relative;
  font-size:.9rem;color:var(--slate-700);
}
.service-card ul li::before{
  content:"\2713";position:absolute;left:0;top:0;
  color:var(--accent-500);font-weight:700;
}

/* Notice */
.notice{
  background:var(--primary-50);
  border-left:3px solid var(--accent-500);
  padding:16px 22px;border-radius:var(--radius-sm);
  font-size:.95rem;color:var(--slate-700);
  margin:20px 0;
}

/* Reveal animation */
[data-reveal]{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
[data-reveal].is-visible{opacity:1;transform:none}

/* Body offset when cookie banner visible */
body.has-cookie-banner{padding-top:120px;transition:padding-top .3s}

/* Responsive */
@media (max-width:980px){
  .features-grid, .testimonials-grid, .team-grid, .cta-cards, .stats-grid, .services-grid, .process-grid{grid-template-columns:1fr 1fr}
  .hero__inner, .split-2, .split-2--reverse{grid-template-columns:1fr;gap:36px}
  .site-footer__grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
  .cookie-banner__inner{grid-template-columns:1fr;text-align:left;gap:14px}
  .cookie-banner__actions{justify-content:flex-start}
}
@media (max-width:700px){
  .section{padding-top:64px;padding-bottom:64px}
  .hero{padding:64px 0 56px}
  .features-grid, .testimonials-grid, .team-grid, .cta-cards, .stats-grid, .services-grid, .process-grid{grid-template-columns:1fr}
  .site-footer__grid{grid-template-columns:1fr;gap:30px}
  .site-header__nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--primary-800);flex-direction:column;padding:18px;gap:12px;border-radius:0 0 12px 12px;box-shadow:var(--shadow-md);margin-top:0}
  .site-header__nav.is-open{display:flex}
  .site-header__nav a{width:100%;text-align:center}
  .site-header__cta{display:none}
  .site-header__burger{display:block}
  body.has-cookie-banner{padding-top:0}
  .cookie-banner{position:relative}
}
