/* ============================================================
   UważnaPraktyka – styles.css
   Prefix: uwzp-   Variables: --uwzp-
   ============================================================ */

/* ---------- Google Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:wght@400;500;700&family=Source+Sans+3:wght@300;400;600&display=swap');

/* ---------- CSS Custom Properties ---------- */
:root {
  --uwzp-emerald:   #2E7D52;
  --uwzp-emerald-dk:#1C3825;
  --uwzp-brown:     #8B5E3C;
  --uwzp-cream:     #F4EDE3;
  --uwzp-cream-dk:  #EAE0D2;
  --uwzp-gold:      #D4AF37;
  --uwzp-gold-lt:   #E8C94A;
  --uwzp-text:      #2A1810;
  --uwzp-white:     #FFFFFF;
  --uwzp-shadow:    rgba(44,24,16,.15);
  --uwzp-radius:    10px;
  --uwzp-radius-lg: 18px;
  --uwzp-transition: .3s ease;
  --uwzp-font-head: 'EB Garamond', Georgia, serif;
  --uwzp-font-body: 'Source Sans 3', Arial, sans-serif;
  --uwzp-max-w:     1180px;
  --uwzp-nav-h:     68px;
}

/* ---------- Reset & Base ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--uwzp-font-body);
  background: var(--uwzp-cream);
  color: var(--uwzp-text);
  line-height: 1.7;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--uwzp-emerald); text-decoration: none; transition: color var(--uwzp-transition); }
a:hover { color: var(--uwzp-gold); }
ul { list-style: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--uwzp-font-head);
  color: var(--uwzp-emerald-dk);
  line-height: 1.25;
}

p { margin-bottom: 1rem; }
section { padding: 72px 0; }

/* ---------- Utility ---------- */
.uwzp-container {
  width: 100%;
  max-width: var(--uwzp-max-w);
  margin: 0 auto;
  padding: 0 20px;
}

.uwzp-section-title {
  font-size: clamp(1.9rem, 4vw, 2.7rem);
  font-weight: 700;
  text-align: center;
  margin-bottom: .5rem;
  color: var(--uwzp-emerald-dk);
}

.uwzp-section-sub {
  text-align: center;
  color: var(--uwzp-brown);
  font-size: 1.05rem;
  margin-bottom: 3rem;
  font-weight: 300;
}

.uwzp-btn {
  display: inline-block;
  padding: 14px 34px;
  border-radius: 50px;
  font-family: var(--uwzp-font-body);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: background var(--uwzp-transition), transform var(--uwzp-transition), box-shadow var(--uwzp-transition);
}

.uwzp-btn-gold {
  background: var(--uwzp-gold);
  color: var(--uwzp-emerald-dk);
}
.uwzp-btn-gold:hover {
  background: var(--uwzp-gold-lt);
  color: var(--uwzp-emerald-dk);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(212,175,55,.4);
}

.uwzp-btn-green {
  background: var(--uwzp-emerald);
  color: var(--uwzp-white);
}
.uwzp-btn-green:hover {
  background: var(--uwzp-emerald-dk);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(46,125,82,.4);
}

.uwzp-btn-outline {
  background: transparent;
  color: var(--uwzp-emerald);
  border: 2px solid var(--uwzp-emerald);
}
.uwzp-btn-outline:hover {
  background: var(--uwzp-emerald);
  color: var(--uwzp-white);
}

/* ---------- NAV ---------- */
.uwzp-nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--uwzp-emerald-dk);
  height: var(--uwzp-nav-h);
  display: flex;
  align-items: center;
  box-shadow: 0 2px 16px rgba(0,0,0,.25);
}

.uwzp-nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: var(--uwzp-max-w);
  margin: 0 auto;
  padding: 0 20px;
}

.uwzp-logo {
  font-family: var(--uwzp-font-head);
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--uwzp-gold);
  letter-spacing: .5px;
  white-space: nowrap;
}
.uwzp-logo span { color: var(--uwzp-white); font-weight: 400; }

.uwzp-nav-links {
  display: flex;
  align-items: center;
  gap: 28px;
}

.uwzp-nav-links a {
  color: rgba(255,255,255,.85);
  font-size: .92rem;
  font-weight: 400;
  letter-spacing: .3px;
  transition: color var(--uwzp-transition);
}
.uwzp-nav-links a:hover { color: var(--uwzp-gold); }

.uwzp-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.uwzp-hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: var(--uwzp-white);
  border-radius: 2px;
  transition: all var(--uwzp-transition);
}

.uwzp-mobile-menu {
  display: none;
  position: fixed;
  top: var(--uwzp-nav-h);
  left: 0;
  right: 0;
  background: var(--uwzp-emerald-dk);
  padding: 24px 20px;
  z-index: 999;
  flex-direction: column;
  gap: 16px;
  box-shadow: 0 8px 20px rgba(0,0,0,.3);
  transform: translateY(-10px);
  opacity: 0;
  transition: transform var(--uwzp-transition), opacity var(--uwzp-transition);
}

.uwzp-mobile-menu.uwzp-open {
  display: flex;
  transform: translateY(0);
  opacity: 1;
}

.uwzp-mobile-menu a {
  color: rgba(255,255,255,.9);
  font-size: 1rem;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.uwzp-mobile-menu a:hover { color: var(--uwzp-gold); }

/* ---------- HERO ---------- */
.uwzp-hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(46,125,82,.18) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 30%, rgba(28,56,37,.3) 0%, transparent 50%),
    linear-gradient(160deg, #0d1f14 0%, #1C3825 40%, #0f2a1a 70%, #0a1a10 100%);
}

/* CSS Star dots */
.uwzp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1.5px 1.5px at 10% 15%, rgba(255,255,255,.9) 0%, transparent 100%),
    radial-gradient(1px 1px at 25% 8%, rgba(255,255,255,.7) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 22%, rgba(212,175,55,.8) 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 5%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(2px 2px at 70% 18%, rgba(255,255,255,.9) 0%, transparent 100%),
    radial-gradient(1px 1px at 85% 10%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 92% 28%, rgba(212,175,55,.7) 0%, transparent 100%),
    radial-gradient(1px 1px at 15% 35%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 30% 45%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 60% 38%, rgba(255,255,255,.7) 0%, transparent 100%),
    radial-gradient(2px 2px at 78% 42%, rgba(212,175,55,.6) 0%, transparent 100%),
    radial-gradient(1px 1px at 5% 55%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 48% 60%, rgba(255,255,255,.8) 0%, transparent 100%),
    radial-gradient(1px 1px at 88% 55%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 20% 70%, rgba(212,175,55,.7) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 72%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(2px 2px at 35% 80%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 80% 78%, rgba(255,255,255,.7) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 88%, rgba(212,175,55,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 12% 90%, rgba(255,255,255,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 95% 85%, rgba(255,255,255,.6) 0%, transparent 100%),
    radial-gradient(1.5px 1.5px at 3% 25%, rgba(255,255,255,.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 45% 12%, rgba(255,255,255,.8) 0%, transparent 100%),
    radial-gradient(2px 2px at 58% 50%, rgba(212,175,55,.4) 0%, transparent 100%),
    radial-gradient(1px 1px at 72% 65%, rgba(255,255,255,.6) 0%, transparent 100%);
  pointer-events: none;
}

.uwzp-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(46,125,82,.12) 0%, transparent 70%);
  pointer-events: none;
}

.uwzp-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 60px 20px 40px;
  max-width: 820px;
}

.uwzp-hero-eyebrow {
  display: inline-block;
  font-family: var(--uwzp-font-body);
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--uwzp-gold);
  margin-bottom: 1.2rem;
}

.uwzp-hero-title {
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  font-weight: 700;
  color: var(--uwzp-white);
  margin-bottom: 1.2rem;
  text-shadow: 0 2px 20px rgba(0,0,0,.5);
}

.uwzp-hero-title span { color: var(--uwzp-gold); }

.uwzp-hero-sub {
  font-size: clamp(1rem, 2.2vw, 1.25rem);
  font-weight: 300;
  color: rgba(255,255,255,.82);
  margin-bottom: 2.4rem;
  line-height: 1.6;
}

.uwzp-hero-cta { margin-bottom: 0; }

.uwzp-hero-disclaimer {
  position: relative;
  z-index: 2;
  width: 100%;
  background: rgba(0,0,0,.35);
  padding: 12px 20px;
  text-align: center;
  font-size: .78rem;
  color: rgba(255,255,255,.62);
  font-family: var(--uwzp-font-body);
  letter-spacing: .2px;
  margin-top: auto;
}

/* ---------- FAQ ---------- */
.uwzp-faq { background: var(--uwzp-cream-dk); }

.uwzp-faq-list { max-width: 780px; margin: 0 auto; }

.uwzp-faq-item {
  border-bottom: 1px solid rgba(139,94,60,.2);
  overflow: hidden;
}

.uwzp-faq-item:first-child { border-top: 1px solid rgba(139,94,60,.2); }

.uwzp-faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 22px 4px;
  cursor: pointer;
  font-family: var(--uwzp-font-head);
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--uwzp-emerald-dk);
  user-select: none;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  transition: color var(--uwzp-transition);
}

.uwzp-faq-question:hover { color: var(--uwzp-emerald); }

.uwzp-faq-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--uwzp-emerald);
  color: var(--uwzp-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  font-weight: 300;
  line-height: 1;
  transition: transform var(--uwzp-transition), background var(--uwzp-transition);
}

.uwzp-faq-item.uwzp-active .uwzp-faq-icon {
  transform: rotate(45deg);
  background: var(--uwzp-gold);
  color: var(--uwzp-emerald-dk);
}

.uwzp-faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s ease, padding .3s ease;
  font-size: .97rem;
  color: #4a3626;
  line-height: 1.75;
}

.uwzp-faq-answer-inner { padding: 0 4px 20px; }

.uwzp-faq-item.uwzp-active .uwzp-faq-answer { max-height: 400px; }

/* ---------- FEATURES ---------- */
.uwzp-features { background: var(--uwzp-cream); }

.uwzp-features-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 28px;
}

.uwzp-feature-card {
  background: var(--uwzp-white);
  border-radius: var(--uwzp-radius-lg);
  padding: 36px 28px;
  text-align: center;
  box-shadow: 0 4px 24px var(--uwzp-shadow);
  transition: transform var(--uwzp-transition), box-shadow var(--uwzp-transition);
  border-top: 4px solid var(--uwzp-emerald);
}

.uwzp-feature-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 36px var(--uwzp-shadow);
}

.uwzp-feature-icon {
  font-size: 2.6rem;
  margin-bottom: 1rem;
  display: block;
}

.uwzp-feature-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: .6rem;
  color: var(--uwzp-emerald-dk);
}

.uwzp-feature-desc {
  font-size: .92rem;
  color: #5a4030;
  line-height: 1.65;
  margin: 0;
}

/* ---------- REVIEWS ---------- */
.uwzp-reviews { background: var(--uwzp-emerald-dk); }
.uwzp-reviews .uwzp-section-title { color: var(--uwzp-cream); }
.uwzp-reviews .uwzp-section-sub { color: rgba(244,237,227,.65); }

.uwzp-reviews-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 22px;
}

.uwzp-review-card {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--uwzp-radius-lg);
  padding: 26px 22px;
  transition: background var(--uwzp-transition);
  backdrop-filter: blur(4px);
}

.uwzp-review-card:hover { background: rgba(255,255,255,.12); }

.uwzp-review-stars {
  color: var(--uwzp-gold);
  font-size: 1rem;
  margin-bottom: .7rem;
  letter-spacing: 2px;
}

.uwzp-review-text {
  font-size: .9rem;
  color: rgba(244,237,227,.88);
  line-height: 1.6;
  margin-bottom: 1rem;
  font-style: italic;
}

.uwzp-review-author {
  font-size: .82rem;
  font-weight: 600;
  color: var(--uwzp-gold);
}

.uwzp-review-date {
  font-size: .76rem;
  color: rgba(255,255,255,.4);
  margin-top: 2px;
}

/* ---------- PLANS ---------- */
.uwzp-plans { background: var(--uwzp-cream); }

.uwzp-plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 28px;
  align-items: start;
}

.uwzp-plan-box {
  background: var(--uwzp-white);
  border-radius: var(--uwzp-radius-lg);
  padding: 38px 30px;
  box-shadow: 0 4px 20px var(--uwzp-shadow);
  position: relative;
  border: 2px solid transparent;
  transition: transform var(--uwzp-transition);
}

.uwzp-plan-box:hover { transform: translateY(-4px); }

.uwzp-plan-box.uwzp-plan-featured {
  border-color: var(--uwzp-gold);
  transform: scale(1.03);
  box-shadow: 0 12px 40px rgba(212,175,55,.25);
}

.uwzp-plan-box.uwzp-plan-featured:hover { transform: scale(1.03) translateY(-4px); }

.uwzp-plan-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--uwzp-gold);
  color: var(--uwzp-emerald-dk);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 18px;
  border-radius: 50px;
  white-space: nowrap;
}

.uwzp-plan-name {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--uwzp-emerald-dk);
  margin-bottom: .3rem;
}

.uwzp-plan-level {
  font-size: .83rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--uwzp-brown);
  margin-bottom: 1.4rem;
}

.uwzp-plan-features {
  margin-bottom: 2rem;
}

.uwzp-plan-features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .93rem;
  color: #4a3626;
  padding: 7px 0;
  border-bottom: 1px solid rgba(139,94,60,.1);
}

.uwzp-plan-features li::before {
  content: '✓';
  color: var(--uwzp-emerald);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

.uwzp-plan-cta { width: 100%; text-align: center; display: block; }

/* ---------- CONTACT FORM SECTION ---------- */
.uwzp-contact-section { background: var(--uwzp-cream-dk); }

.uwzp-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 60px;
  align-items: start;
}

.uwzp-contact-info-title {
  font-size: 1.6rem;
  margin-bottom: 1.2rem;
  color: var(--uwzp-emerald-dk);
}

.uwzp-contact-info p {
  font-size: .95rem;
  color: #4a3626;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: .8rem;
}

.uwzp-contact-info-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }

/* Form */
.uwzp-message-form { width: 100%; }

.uwzp-form-title {
  font-size: 1.6rem;
  margin-bottom: 1.4rem;
  color: var(--uwzp-emerald-dk);
}

.uwzp-form-group { margin-bottom: 1.2rem; }

.uwzp-form-group label {
  display: block;
  font-size: .88rem;
  font-weight: 600;
  color: var(--uwzp-emerald-dk);
  margin-bottom: .4rem;
  letter-spacing: .2px;
}

.uwzp-form-group input,
.uwzp-form-group textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid rgba(139,94,60,.3);
  border-radius: var(--uwzp-radius);
  font-family: var(--uwzp-font-body);
  font-size: .95rem;
  background: var(--uwzp-white);
  color: var(--uwzp-text);
  transition: border-color var(--uwzp-transition), box-shadow var(--uwzp-transition);
  outline: none;
}

.uwzp-form-group input:focus,
.uwzp-form-group textarea:focus {
  border-color: var(--uwzp-emerald);
  box-shadow: 0 0 0 3px rgba(46,125,82,.12);
}

.uwzp-form-group textarea { resize: vertical; min-height: 130px; }

.uwzp-send-btn {
  width: 100%;
  font-size: 1rem;
  padding: 15px;
}

.uwzp-form-disclaimer {
  font-size: .76rem;
  color: #7a6050;
  margin-top: .8rem;
  line-height: 1.5;
}

.uwzp-form-success {
  display: none;
  background: rgba(46,125,82,.12);
  border: 1px solid var(--uwzp-emerald);
  border-radius: var(--uwzp-radius);
  padding: 20px;
  text-align: center;
  color: var(--uwzp-emerald-dk);
  font-weight: 600;
  font-size: 1.05rem;
  margin-top: 1rem;
}

.uwzp-form-success.uwzp-visible { display: block; }

/* ---------- CTA SECTION ---------- */
.uwzp-cta-section {
  background: var(--uwzp-emerald);
  text-align: center;
  padding: 80px 20px;
}

.uwzp-cta-section .uwzp-section-title { color: var(--uwzp-white); margin-bottom: .8rem; }
.uwzp-cta-section p { color: rgba(255,255,255,.82); font-size: 1.05rem; margin-bottom: 2rem; }

/* ---------- FOOTER ---------- */
.uwzp-footer {
  background: var(--uwzp-emerald-dk);
  color: rgba(244,237,227,.75);
  padding: 60px 0 0;
}

.uwzp-footer-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 60px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.uwzp-footer-brand .uwzp-logo { font-size: 1.3rem; margin-bottom: 1rem; display: block; }

.uwzp-footer-copy {
  font-size: .82rem;
  color: rgba(244,237,227,.5);
  margin-bottom: 1.2rem;
  line-height: 1.6;
}

.uwzp-footer-legal {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.uwzp-footer-legal a {
  font-size: .83rem;
  color: rgba(244,237,227,.6);
  transition: color var(--uwzp-transition);
}
.uwzp-footer-legal a:hover { color: var(--uwzp-gold); }

.uwzp-footer-links {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.uwzp-footer-group-title {
  font-family: var(--uwzp-font-head);
  font-size: .85rem;
  font-weight: 700;
  color: var(--uwzp-gold);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 1rem;
}

.uwzp-footer-group ul { display: flex; flex-direction: column; gap: 8px; }

.uwzp-footer-group ul a {
  font-size: .88rem;
  color: rgba(244,237,227,.65);
  transition: color var(--uwzp-transition);
}
.uwzp-footer-group ul a:hover { color: var(--uwzp-gold); }

.uwzp-footer-bottom {
  text-align: center;
  padding: 18px 20px;
  font-size: .78rem;
  color: rgba(244,237,227,.38);
  letter-spacing: .3px;
}

/* ---------- COOKIE BANNER ---------- */
.uwzp-gdpr-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: var(--uwzp-emerald-dk);
  border-top: 3px solid var(--uwzp-gold);
  padding: 18px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  box-shadow: 0 -4px 24px rgba(0,0,0,.3);
  transform: translateY(100%);
  transition: transform .4s ease;
}

.uwzp-gdpr-banner.uwzp-visible { transform: translateY(0); }

.uwzp-gdpr-text {
  flex: 1;
  font-size: .85rem;
  color: rgba(244,237,227,.85);
  min-width: 200px;
  line-height: 1.55;
}

.uwzp-gdpr-text a { color: var(--uwzp-gold); }
.uwzp-gdpr-text a:hover { text-decoration: underline; }

.uwzp-gdpr-btns {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.uwzp-gdpr-accept {
  background: var(--uwzp-gold);
  color: var(--uwzp-emerald-dk);
  border: none;
  padding: 10px 22px;
  border-radius: 50px;
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--uwzp-transition);
}
.uwzp-gdpr-accept:hover { background: var(--uwzp-gold-lt); }

.uwzp-gdpr-essential {
  background: transparent;
  color: rgba(244,237,227,.75);
  border: 1.5px solid rgba(244,237,227,.3);
  padding: 10px 18px;
  border-radius: 50px;
  font-size: .83rem;
  cursor: pointer;
  transition: border-color var(--uwzp-transition), color var(--uwzp-transition);
}
.uwzp-gdpr-essential:hover { border-color: var(--uwzp-white); color: var(--uwzp-white); }

/* ---------- BREADCRUMB ---------- */
.uwzp-breadcrumb {
  background: var(--uwzp-cream-dk);
  padding: 14px 0;
  font-size: .83rem;
  color: var(--uwzp-brown);
}

.uwzp-breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.uwzp-breadcrumb li { display: flex; align-items: center; gap: 6px; }
.uwzp-breadcrumb li::after { content: '/'; color: rgba(139,94,60,.4); }
.uwzp-breadcrumb li:last-child::after { display: none; }
.uwzp-breadcrumb a { color: var(--uwzp-emerald); }
.uwzp-breadcrumb a:hover { color: var(--uwzp-gold); }

/* ---------- CONTENT PAGES ---------- */
.uwzp-article-hero {
  background: linear-gradient(135deg, var(--uwzp-emerald-dk) 0%, #163d22 100%);
  padding: 70px 20px 60px;
  text-align: center;
}

.uwzp-article-hero h1 {
  color: var(--uwzp-white);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  margin-bottom: 1rem;
}

.uwzp-article-hero p {
  color: rgba(255,255,255,.78);
  font-size: 1.08rem;
  max-width: 640px;
  margin: 0 auto;
}

.uwzp-article-body {
  max-width: 760px;
  margin: 0 auto;
  padding: 60px 20px;
}

.uwzp-article-body h2 {
  font-size: 1.65rem;
  margin: 2.5rem 0 .9rem;
  color: var(--uwzp-emerald-dk);
  padding-bottom: .5rem;
  border-bottom: 2px solid rgba(46,125,82,.15);
}

.uwzp-article-body p {
  font-size: 1rem;
  line-height: 1.8;
  color: #3a2818;
}

.uwzp-article-body ul {
  list-style: disc;
  padding-left: 1.6rem;
  margin-bottom: 1rem;
}

.uwzp-article-body ul li {
  margin-bottom: .4rem;
  font-size: .97rem;
  color: #3a2818;
}

.uwzp-article-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: .92rem;
}

.uwzp-article-body th {
  background: var(--uwzp-emerald);
  color: var(--uwzp-white);
  padding: 10px 14px;
  text-align: left;
  font-weight: 600;
}

.uwzp-article-body td {
  padding: 10px 14px;
  border-bottom: 1px solid rgba(139,94,60,.15);
  color: #3a2818;
}

.uwzp-article-body tr:nth-child(even) td { background: rgba(46,125,82,.05); }

.uwzp-also-read {
  background: var(--uwzp-cream-dk);
  border-left: 4px solid var(--uwzp-emerald);
  border-radius: 0 var(--uwzp-radius) var(--uwzp-radius) 0;
  padding: 22px 26px;
  margin: 2.5rem 0;
}

.uwzp-also-read h3 {
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--uwzp-emerald-dk);
  margin-bottom: .7rem;
}

.uwzp-also-read ul {
  list-style: none;
  padding: 0;
}

.uwzp-also-read ul li {
  margin-bottom: .4rem;
}

.uwzp-also-read ul li a {
  color: var(--uwzp-emerald);
  font-weight: 600;
  font-size: .95rem;
}

/* ---------- CONTACT PAGE CARDS ---------- */
.uwzp-contact-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;
  margin-bottom: 60px;
}

.uwzp-contact-card {
  background: var(--uwzp-white);
  border-radius: var(--uwzp-radius-lg);
  padding: 32px 24px;
  text-align: center;
  box-shadow: 0 4px 20px var(--uwzp-shadow);
}

.uwzp-contact-card-icon { font-size: 2.2rem; margin-bottom: .8rem; display: block; }
.uwzp-contact-card h3 { font-size: 1.1rem; margin-bottom: .4rem; color: var(--uwzp-emerald-dk); }
.uwzp-contact-card p { font-size: .88rem; color: #5a4030; margin: 0; }
.uwzp-contact-card a { color: var(--uwzp-emerald); font-weight: 600; }

/* ---------- ABOUT PAGE ---------- */
.uwzp-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 28px;
  margin-top: 2rem;
}

.uwzp-team-card {
  background: var(--uwzp-white);
  border-radius: var(--uwzp-radius-lg);
  padding: 32px 24px;
  text-align: center;
  box-shadow: 0 4px 20px var(--uwzp-shadow);
}

.uwzp-team-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--uwzp-emerald), var(--uwzp-emerald-dk));
  margin: 0 auto 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--uwzp-gold);
}

.uwzp-team-name { font-size: 1.2rem; margin-bottom: .3rem; color: var(--uwzp-emerald-dk); }
.uwzp-team-role { font-size: .85rem; color: var(--uwzp-brown); font-weight: 600; text-transform: uppercase; letter-spacing: .8px; margin-bottom: .8rem; }
.uwzp-team-bio { font-size: .88rem; color: #4a3626; line-height: 1.6; margin: 0; }

/* ---------- LEGAL PAGES ---------- */
.uwzp-legal-body {
  max-width: 800px;
  margin: 0 auto;
  padding: 60px 20px;
}

.uwzp-legal-body h1 { font-size: 2rem; margin-bottom: .5rem; color: var(--uwzp-emerald-dk); }
.uwzp-legal-body .uwzp-legal-meta { font-size: .83rem; color: var(--uwzp-brown); margin-bottom: 2.5rem; }
.uwzp-legal-body h2 { font-size: 1.3rem; margin: 2rem 0 .7rem; color: var(--uwzp-emerald-dk); }
.uwzp-legal-body p, .uwzp-legal-body li { font-size: .96rem; line-height: 1.78; color: #3a2818; }
.uwzp-legal-body ul { list-style: disc; padding-left: 1.6rem; margin-bottom: 1rem; }
.uwzp-legal-body li { margin-bottom: .35rem; }

/* ---------- PAGE HERO (non-index) ---------- */
.uwzp-page-hero {
  background: linear-gradient(135deg, var(--uwzp-emerald-dk) 0%, #163d22 100%);
  padding: 60px 20px 50px;
  text-align: center;
}

.uwzp-page-hero h1 {
  color: var(--uwzp-white);
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  margin-bottom: .8rem;
}

.uwzp-page-hero p {
  color: rgba(255,255,255,.75);
  font-size: 1.05rem;
  max-width: 580px;
  margin: 0 auto;
}

/* ---------- MEDIA QUERIES ---------- */
@media (max-width: 900px) {
  .uwzp-contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .uwzp-footer-grid { grid-template-columns: 1fr; gap: 40px; }
  .uwzp-footer-links { grid-template-columns: 1fr 1fr; gap: 24px; }
  .uwzp-plans-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
  .uwzp-plan-box.uwzp-plan-featured { transform: none; }
  .uwzp-plan-box.uwzp-plan-featured:hover { transform: translateY(-4px); }
}

@media (max-width: 768px) {
  .uwzp-nav-links { display: none; }
  .uwzp-hamburger { display: flex; }
  section { padding: 52px 0; }
  .uwzp-hero { min-height: 85vh; }
  .uwzp-reviews-grid { grid-template-columns: 1fr 1fr; }
  .uwzp-footer-links { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .uwzp-reviews-grid { grid-template-columns: 1fr; }
  .uwzp-gdpr-banner { flex-direction: column; align-items: flex-start; }
  .uwzp-gdpr-btns { width: 100%; }
  .uwzp-gdpr-accept, .uwzp-gdpr-essential { flex: 1; text-align: center; }
  .uwzp-hero-content { padding: 40px 16px 30px; }
}
