/* ==========================================================================
   Juvane Nayeno — Design System / Asymmetric Balance
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@600;700;800&family=Inter:wght@400;500;600&display=swap');

:root{
  --ink:#23263A;
  --clay:#DD5B32;
  --sand:#C89B5C;
  --cream:#FAF6EF;
  --text:#2B2A28;

  --ink-10: color-mix(in oklch, var(--ink), white 92%);
  --ink-20: color-mix(in oklch, var(--ink), white 82%);
  --ink-40: color-mix(in oklch, var(--ink), white 60%);
  --ink-60: color-mix(in oklch, var(--ink), white 35%);
  --ink-dark: color-mix(in oklch, var(--ink), black 18%);

  --clay-10: color-mix(in oklch, var(--clay), white 88%);
  --clay-20: color-mix(in oklch, var(--clay), white 75%);
  --clay-hover: color-mix(in oklch, var(--clay), black 12%);
  --clay-soft: color-mix(in oklch, var(--clay), white 60%);

  --sand-10: color-mix(in oklch, var(--sand), white 85%);
  --sand-30: color-mix(in oklch, var(--sand), white 60%);

  --surface: var(--cream);
  --surface-alt: color-mix(in oklch, var(--cream), var(--ink) 4%);
  --surface-dark: var(--ink);
  --border-soft: color-mix(in oklch, var(--ink), white 85%);

  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 28px;
  --radius-xl: 40px;
  --radius-full: 999px;

  --shadow-sm: 0 1px 2px rgba(35,38,58,.06), 0 1px 1px rgba(35,38,58,.04);
  --shadow-md: 0 10px 26px -10px rgba(35,38,58,.22), 0 3px 8px rgba(35,38,58,.08);
  --shadow-lg: 0 26px 54px -16px rgba(35,38,58,.28), 0 10px 20px -8px rgba(35,38,58,.14);

  --space-xs:.5rem; --space-sm:1rem; --space-md:1.5rem; --space-lg:2.5rem; --space-xl:4rem;
  --section-pad: clamp(3.5rem, 7vw, 7rem);
  --container: 1240px;

  --font-head: 'Plus Jakarta Sans', sans-serif;
  --font-body: 'Inter', sans-serif;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; font-family:var(--font-body); color:var(--text); background:var(--surface);
  line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--font-head); color:var(--ink); line-height:1.18; margin:0; font-weight:800; }
p{ margin:0; }
figure{ margin:0; }
.sr-only{ position:absolute; width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0; }
mark{ background:var(--clay-soft); color:var(--ink-dark); padding:.05em .3em; border-radius:4px; }
small{ color:var(--ink-60); font-size:.85rem; }

h1{ font-size:clamp(2.4rem, 4.6vw + .6rem, 4.2rem); letter-spacing:-.02em; }
h2{ font-size:clamp(1.9rem, 2.6vw + .8rem, 2.9rem); letter-spacing:-.015em; }
h3{ font-size:1.2rem; }

.global-eyebrow{
  display:inline-flex; align-items:center; gap:.5rem; font-family:var(--font-head);
  font-weight:700; font-size:.78rem; text-transform:uppercase; letter-spacing:.14em;
  color:var(--clay-hover); margin-bottom:1rem;
}
.global-eyebrow::before{ content:''; width:22px; height:2px; background:var(--clay); display:inline-block; border-radius:2px; }


.global-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.9rem 1.7rem; border-radius:var(--radius-md); font-family:var(--font-head);
  font-weight:700; font-size:.95rem; min-height:48px; transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.global-btn-primary{ background:var(--clay); color:#fff; box-shadow:var(--shadow-md); }
.global-btn-primary:hover{ background:var(--clay-hover); transform:translateY(-2px); box-shadow:var(--shadow-lg); }
.global-btn-outline{ background:transparent; color:var(--ink); border:1.5px solid var(--ink-40); }
.global-btn-outline:hover{ background:var(--ink); color:#fff; border-color:var(--ink); transform:translateY(-2px); }


.global-header{ background:var(--surface); border-bottom:1px solid var(--border-soft); }
.global-nav{
  max-width:var(--container); margin:0 auto; padding:1.1rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem; position:relative;
}
.global-logo{ display:flex; align-items:center; gap:.65rem; font-family:var(--font-head); font-weight:700; font-size:1.05rem; color:var(--ink); }
.global-logo strong{ font-weight:800; }
.global-nav-links{ display:flex; align-items:center; gap:2rem; }
.global-nav-links a{ font-weight:600; font-size:.95rem; color:var(--ink-60); transition:color .2s ease; position:relative; }
.global-nav-links a:hover{ color:var(--ink); }
.global-nav-links a[aria-current="page"]{ color:var(--ink); }
.global-nav-links a[aria-current="page"]::after{ content:''; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--clay); border-radius:2px; }
.global-nav-cta{ background:var(--ink); color:#fff !important; padding:.65rem 1.4rem; border-radius:var(--radius-md); transition:background .25s ease, transform .25s ease; }
.global-nav-cta:hover{ background:var(--clay); transform:translateY(-2px); }
.global-nav-cta::after{ display:none !important; }

.global-mobile-toggle{ display:none; font-size:1.4rem; color:var(--ink); min-width:44px; min-height:44px; align-items:center; justify-content:center; }
.global-mobile-close{ display:none; }
.global-mobile-overlay{
  position:fixed; inset:0; background:rgba(35,38,58,.55); opacity:0; pointer-events:none;
  transition:opacity .35s ease; z-index:60;
}
.global-mobile-overlay.is-active{ opacity:1; pointer-events:auto; }

@media (max-width:960px){
  .global-mobile-toggle{ display:flex; }
  .global-nav-links{
    position:fixed; top:0; right:0; height:100vh; width:min(85vw,360px); background:var(--cream);
    flex-direction:column; align-items:flex-start; justify-content:flex-start; gap:1.6rem;
    padding:5.5rem 2rem 2rem; transform:translateX(100%); transition:transform .4s cubic-bezier(.6,0,.3,1);
    box-shadow:var(--shadow-lg); z-index:70;
  }
  .global-nav-links.is-open{ transform:translateX(0); }
  .global-nav-links a{ font-size:1.15rem; width:100%; }
  .global-mobile-close{ display:flex; position:absolute; top:1.4rem; right:1.5rem; font-size:1.3rem; color:var(--ink); min-width:44px; min-height:44px; align-items:center; justify-content:center; }
  .global-nav-cta{ margin-top:.5rem; }
}


.global-back-to-top{
  position:fixed; right:1.6rem; bottom:1.6rem; width:52px; height:52px; border-radius:50%;
  background:var(--ink); color:#fff; display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-lg); opacity:0; visibility:hidden; transform:translateY(12px);
  transition:opacity .3s ease, transform .3s ease, background .25s ease; z-index:50;
}
.global-back-to-top.is-visible{ opacity:1; visibility:visible; transform:translateY(0); }
.global-back-to-top:hover{ background:var(--clay); }


.global-footer{ background:var(--ink); color:color-mix(in oklch, white, var(--ink) 8%); margin-top:auto; }
.global-footer-top{
  max-width:var(--container); margin:0 auto; padding:var(--section-pad) 1.5rem 3rem;
  display:grid; grid-template-columns:1.2fr 2fr; gap:3rem;
}
.global-footer-brand p{ margin-top:1rem; color:color-mix(in oklch, white, var(--ink) 30%); max-width:32ch; }
.global-footer-brand .global-logo{ color:#fff; }
.global-footer-nav{ display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.global-footer-nav h3{ color:#fff; font-size:.85rem; text-transform:uppercase; letter-spacing:.1em; margin-bottom:1.1rem; }
.global-footer-nav a{ display:block; color:color-mix(in oklch, white, var(--ink) 30%); padding:.3rem 0; transition:color .2s ease; }
.global-footer-nav a:hover{ color:var(--sand); }
.global-footer-nav address p{ color:color-mix(in oklch, white, var(--ink) 30%); padding:.3rem 0; }
.global-footer-nav address a:hover{ color:var(--sand); }
.global-footer-bottom{
  max-width:var(--container); margin:0 auto; padding:1.5rem; border-top:1px solid color-mix(in oklch, white, var(--ink) 70%);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:.5rem;
}
.global-footer-bottom small{ color:color-mix(in oklch, white, var(--ink) 40%); }

@media (max-width:800px){
  .global-footer-top{ grid-template-columns:1fr; }
  .global-footer-nav{ grid-template-columns:1fr 1fr; }
}


.global-cookie-pill{
  position:fixed; bottom:1.5rem; left:50%; transform:translateX(-50%);
  background:var(--ink); color:#fff; border-radius:var(--radius-full); padding:.85rem 1rem .85rem 1.5rem;
  display:flex; align-items:center; gap:1rem; box-shadow:var(--shadow-lg); z-index:90;
  max-width:min(92vw,560px); opacity:0; visibility:hidden; transition:opacity .4s ease, visibility .4s ease;
}
.global-cookie-pill.is-visible{ opacity:1; visibility:visible; }
.global-cookie-pill p{ font-size:.85rem; margin:0; }
.global-cookie-pill a{ color:var(--sand); text-decoration:underline; }
.global-cookie-pill-actions{ display:flex; gap:.5rem; flex-shrink:0; }
.global-cookie-customize, .global-cookie-accept{
  padding:.55rem 1rem; border-radius:var(--radius-full); font-size:.8rem; font-weight:600; transition:all .2s ease; min-height:38px;
}
.global-cookie-customize{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,.3); }
.global-cookie-customize:hover{ background:rgba(255,255,255,.1); }
.global-cookie-accept{ background:var(--clay); color:#fff; }
.global-cookie-accept:hover{ background:var(--clay-hover); }

.global-cookie-modal{
  position:fixed; inset:0; background:rgba(35,38,58,.6); display:flex; align-items:center; justify-content:center;
  z-index:95; opacity:0; visibility:hidden; transition:opacity .35s ease, visibility .35s ease; padding:1.5rem;
}
.global-cookie-modal.is-visible{ opacity:1; visibility:visible; }
.global-cookie-modal-inner{
  background:var(--cream); border-radius:var(--radius-lg); padding:2.2rem; max-width:520px; width:100%;
  box-shadow:var(--shadow-lg); transform:scale(.95); transition:transform .35s ease;
}
.global-cookie-modal.is-visible .global-cookie-modal-inner{ transform:scale(1); }
.global-cookie-modal-inner h3{ margin-bottom:.6rem; }
.global-cookie-modal-inner > p{ color:var(--ink-60); margin-bottom:1.4rem; font-size:.92rem; }
.global-cookie-category{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.9rem 0; border-top:1px solid var(--border-soft); }
.global-cookie-category div strong{ display:block; font-size:.92rem; }
.global-cookie-category div span{ font-size:.8rem; color:var(--ink-60); }
.global-cookie-category input{ width:22px; height:22px; flex-shrink:0; accent-color:var(--clay); }
.global-cookie-modal-actions{ display:flex; gap:.8rem; margin-top:1.6rem; flex-wrap:wrap; }

/* ==========================================================================
   HOME
   ========================================================================== */
.home-hero{
  max-width:var(--container); margin:0 auto; padding:3rem 1.5rem 7rem;
  display:grid; grid-template-columns:1fr; gap:2.5rem; position:relative;
}
.home-hero-content{ order:1; }
.home-hero-media{ order:2; position:relative; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.home-hero-media img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.home-hero-media figcaption{ position:absolute; left:0; right:0; bottom:0; padding:1rem 1.3rem; background:linear-gradient(to top, rgba(35,38,58,.85), transparent); color:#fff; font-size:.85rem; }

.global-badge{
  display:inline-flex; align-items:center; gap:.5rem; background:var(--clay-10); color:var(--clay-hover);
  font-weight:700; font-size:.82rem; padding:.5rem 1rem; border-radius:var(--radius-full); margin-bottom:1.4rem;
}
.home-hero-lead{ margin-top:1.4rem; font-size:1.1rem; color:var(--ink-60); max-width:56ch; }
.home-hero-actions{ display:flex; gap:1rem; margin-top:2rem; flex-wrap:wrap; }
.home-hero-meta{ display:flex; gap:2rem; margin-top:2.6rem; flex-wrap:wrap; }
.home-hero-meta div{ display:flex; flex-direction:column; gap:.2rem; }
.home-hero-meta strong{ font-family:var(--font-head); font-size:1.1rem; color:var(--ink); }
.home-hero-meta span{ font-size:.82rem; color:var(--ink-60); }

.home-hero-float{
  background:var(--ink); color:#fff; border-radius:var(--radius-lg); padding:1.6rem 1.8rem; box-shadow:var(--shadow-lg);
  display:flex; gap:1rem; align-items:flex-start; max-width:420px;
  position:relative; margin-top:-3.5rem; margin-left:auto; z-index:5;
}
.home-hero-float i{ color:var(--sand); font-size:1.3rem; flex-shrink:0; }
.home-hero-float p{ font-size:.95rem; font-style:italic; color:color-mix(in oklch, white, var(--ink) 15%); }

@media (min-width:960px){
  .home-hero{ grid-template-columns:1.15fr .85fr; align-items:start; padding-top:5rem; }
  .home-hero-content{ order:1; padding-top:1rem; }
  .home-hero-media{ order:2; margin-top:-1.5rem; }
  .home-hero-float{ max-width:380px; margin-right:2rem; }
}

.home-intro{ padding:var(--section-pad) 1.5rem; }
.home-intro-text{ max-width:var(--container); margin:0 auto; }
.home-intro-lead{ font-family:var(--font-head); font-size:clamp(1.4rem,1.6vw + 1rem,2.1rem); font-weight:700; color:var(--ink); max-width:70ch; }
.home-intro-text p + p{ margin-top:1.3rem; color:var(--ink-60); max-width:62ch; font-size:1.02rem; }
@media (min-width:960px){
  .home-intro-text{ margin-left:8%; }
}

.home-services{ padding:var(--section-pad) 1.5rem; background:var(--surface-alt); }
.home-services-head{ max-width:var(--container); margin:0 auto 3rem; max-width:640px; }
.home-services-head p{ margin-top:1rem; color:var(--ink-60); }
.home-services-grid{ max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr; gap:1.6rem; }
.home-service-card{
  background:var(--cream); border-radius:var(--radius-lg); padding:2rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--border-soft); transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.home-service-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--clay-20); }
.home-service-card i{ font-size:1.6rem; color:var(--clay); margin-bottom:1.2rem; display:block; }
.home-service-card hgroup h3{ margin-bottom:.25rem; }
.home-service-card hgroup p{ color:var(--sand); font-weight:600; font-size:.85rem; margin-bottom:.9rem; }
.home-service-card > p{ color:var(--ink-60); font-size:.96rem; }
@media (min-width:700px){ .home-services-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1100px){ .home-services-grid{ grid-template-columns:repeat(3,1fr); } }

.home-method{ padding:var(--section-pad) 1.5rem; display:grid; grid-template-columns:1fr; gap:0; max-width:var(--container); margin:0 auto; position:relative; }
.home-method-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.home-method-media img{ width:100%; aspect-ratio:5/4; object-fit:cover; }
.home-method-content{ background:var(--ink); color:#fff; border-radius:var(--radius-xl); padding:2.6rem; margin-top:-2.5rem; position:relative; z-index:3; box-shadow:var(--shadow-lg); }
.home-method-content h2{ color:#fff; margin-top:.5rem; }
.home-method-content p{ color:color-mix(in oklch, white, var(--ink) 22%); margin-top:1.1rem; }
.home-method-content .global-eyebrow{ color:var(--sand); }
.home-method-content .global-eyebrow::before{ background:var(--sand); }
.home-method-list{ margin-top:1.6rem; display:flex; flex-direction:column; gap:.7rem; }
.home-method-list li{ display:flex; align-items:flex-start; gap:.6rem; font-size:.94rem; color:color-mix(in oklch, white, var(--ink) 15%); }
.home-method-list i{ color:var(--sand); margin-top:.2rem; }
@media (min-width:960px){
  .home-method{ grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center; }
  .home-method-content{ margin-top:0; margin-left:-3.5rem; }
}

.home-tabs{ padding:var(--section-pad) 1.5rem; }
.home-tabs-head{ max-width:var(--container); margin:0 auto 2.5rem; max-width:640px; }
.home-tabs-wrap{ max-width:var(--container); margin:0 auto; background:var(--surface-alt); border-radius:var(--radius-xl); padding:2rem; box-shadow:var(--shadow-sm); }
.home-tab-buttons{ display:flex; flex-wrap:wrap; gap:.6rem; border-bottom:1px solid var(--border-soft); padding-bottom:1.2rem; margin-bottom:1.6rem; }
.home-tab-btn{
  padding:.75rem 1.3rem; border-radius:var(--radius-full); font-weight:600; font-size:.9rem; color:var(--ink-60);
  background:transparent; transition:background .25s ease, color .25s ease; min-height:44px;
}
.home-tab-btn.is-active{ background:var(--ink); color:#fff; }
.home-tab-btn:not(.is-active):hover{ background:var(--ink-10); color:var(--ink); }
.home-tab-panel{ display:none; }
.home-tab-panel.is-active{ display:block; animation:fadeInPanel .4s ease; }
.home-tab-panel p + p{ margin-top:1rem; }
.home-tab-panel p{ color:var(--ink-60); }
@keyframes fadeInPanel{ from{ opacity:0; transform:translateY(8px);} to{ opacity:1; transform:translateY(0);} }

.home-location{ padding:var(--section-pad) 1.5rem; max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr; gap:2.5rem; }
.home-location-info h2{ margin-top:.5rem; }
.home-location-info p{ color:var(--ink-60); margin-top:1rem; max-width:52ch; }
.home-location-info .contact-details{ margin:1.6rem 0; display:flex; flex-direction:column; gap:.6rem; }
.home-location-info .contact-details p{ display:flex; align-items:center; gap:.6rem; color:var(--ink); margin:0; }
.home-location-info .contact-details i{ color:var(--clay); width:18px; }
.home-location-map{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); min-height:320px; }
.home-location-map iframe{ width:100%; height:100%; min-height:320px; border:0; display:block; }
@media (min-width:960px){ .home-location{ grid-template-columns:.85fr 1.15fr; align-items:stretch; } }

/* ==========================================================================
   ABOUT (co-nas-pohani)
   ========================================================================== */
.about-hero{ max-width:var(--container); margin:0 auto; padding:3rem 1.5rem 5rem; display:grid; grid-template-columns:1fr; gap:2.5rem; }
.about-hero-text p{ color:var(--ink-60); margin-top:1.3rem; max-width:56ch; font-size:1.05rem; }
.about-hero-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.about-hero-media img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
@media (min-width:960px){ .about-hero{ grid-template-columns:1.1fr .9fr; align-items:center; } }

.about-story{ padding:var(--section-pad) 1.5rem; background:var(--surface-alt); }
.about-story-inner{ max-width:760px; margin:0 auto; }
.about-story-inner h2{ margin-bottom:1.4rem; }
.about-story-inner p + p{ margin-top:1.1rem; color:var(--ink-60); }

.about-values{ padding:var(--section-pad) 1.5rem; max-width:var(--container); margin:0 auto; }
.about-values-head{ max-width:600px; margin-bottom:3rem; }
.about-values-grid{ display:grid; grid-template-columns:1fr; gap:1.6rem; }
.about-value-card{ background:var(--cream); border:1px solid var(--border-soft); border-radius:var(--radius-lg); padding:2rem; transition:transform .3s ease, box-shadow .3s ease; }
.about-value-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.about-value-card i{ color:var(--clay); font-size:1.5rem; margin-bottom:1rem; display:block; }
.about-value-card hgroup p{ color:var(--sand); font-size:.85rem; font-weight:600; margin:.2rem 0 .8rem; }
.about-value-card > p{ color:var(--ink-60); font-size:.95rem; }
@media (min-width:700px){ .about-values-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1100px){ .about-values-grid{ grid-template-columns:repeat(4,1fr); } }

.about-approach{ max-width:var(--container); margin:0 auto; padding:var(--section-pad) 1.5rem; display:grid; grid-template-columns:1fr; gap:2rem; }
.about-approach-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.about-approach-media img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
.about-approach-text p{ color:var(--ink-60); margin-top:1.1rem; }
@media (min-width:960px){ .about-approach{ grid-template-columns:.9fr 1.1fr; align-items:center; } }

.about-cta{ padding:var(--section-pad) 1.5rem; background:var(--ink); }
.about-cta-inner{ max-width:700px; margin:0 auto; text-align:center; }
.about-cta-inner h2{ color:#fff; }
.about-cta-inner p{ color:color-mix(in oklch, white, var(--ink) 25%); margin-top:1rem; }
.about-cta-inner .home-hero-actions{ justify-content:center; margin-top:2rem; }

/* ==========================================================================
   PRICING (cenik)
   ========================================================================== */
.pricing-hero{ max-width:900px; margin:0 auto; padding:4rem 1.5rem 3rem; text-align:center; }
.pricing-hero p{ color:var(--ink-60); margin-top:1.2rem; font-size:1.05rem; }

.pricing-plans{ max-width:var(--container); margin:0 auto; padding:1rem 1.5rem var(--section-pad); display:grid; grid-template-columns:1fr; gap:1.8rem; }
.pricing-plan-card{ background:var(--cream); border:1px solid var(--border-soft); border-radius:var(--radius-lg); padding:2.2rem; box-shadow:var(--shadow-sm); position:relative; transition:transform .3s ease, box-shadow .3s ease; }
.pricing-plan-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.pricing-plan-featured{ background:var(--ink); color:#fff; box-shadow:var(--shadow-lg); }
.pricing-plan-featured hgroup h3, .pricing-plan-featured .pricing-plan-price{ color:#fff; }
.pricing-plan-featured hgroup p{ color:var(--sand); }
.pricing-plan-featured p, .pricing-plan-featured li{ color:color-mix(in oklch, white, var(--ink) 20%); }
.pricing-plan-featured li i{ color:var(--sand); }
.pricing-plan-tag{ position:absolute; top:-14px; left:2.2rem; background:var(--clay); color:#fff; font-size:.75rem; font-weight:700; padding:.4rem .9rem; border-radius:var(--radius-full); box-shadow:var(--shadow-sm); }
.pricing-plan-card hgroup p{ color:var(--sand); font-weight:600; font-size:.85rem; margin-top:.2rem; }
.pricing-plan-price{ font-family:var(--font-head); font-size:1.9rem; font-weight:800; color:var(--ink); margin:1rem 0; }
.pricing-plan-price span{ font-size:.85rem; font-weight:500; color:var(--ink-60); }
.pricing-plan-card > p{ color:var(--ink-60); font-size:.94rem; margin-bottom:1.2rem; }
.pricing-plan-meter{ margin-bottom:1.3rem; }
.pricing-plan-meter span{ display:block; font-size:.78rem; color:var(--ink-60); margin-bottom:.4rem; }
.pricing-plan-featured .pricing-plan-meter span{ color:color-mix(in oklch, white, var(--ink) 25%); }
meter{ width:100%; height:10px; }
.pricing-plan-card ul{ display:flex; flex-direction:column; gap:.55rem; margin-bottom:1.6rem; }
.pricing-plan-card li{ display:flex; gap:.5rem; align-items:flex-start; font-size:.92rem; }
.pricing-plan-card li i{ color:var(--clay); margin-top:.2rem; }
@media (min-width:960px){ .pricing-plans{ grid-template-columns:repeat(3,1fr); } .pricing-plan-featured{ transform:scale(1.04); } }

.pricing-note{ max-width:var(--container); margin:0 auto; padding:0 1.5rem 3rem; }
.pricing-note-inner{ background:var(--sand-10); border-radius:var(--radius-lg); padding:1.6rem 2rem; display:flex; gap:1rem; align-items:flex-start; }
.pricing-note-inner i{ color:var(--sand); font-size:1.3rem; margin-top:.2rem; }
.pricing-note-inner p{ color:var(--ink-60); font-size:.94rem; }

.pricing-faq{ padding:var(--section-pad) 1.5rem; background:var(--surface-alt); }
.pricing-faq-head{ max-width:var(--container); margin:0 auto 2.5rem; max-width:600px; }
.pricing-faq-grid{ max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr; gap:1.4rem; }
.pricing-faq-item{ background:var(--cream); border-radius:var(--radius-md); padding:1.6rem 1.8rem; border:1px solid var(--border-soft); }
.pricing-faq-item hgroup h3{ font-size:1.05rem; }
.pricing-faq-item p{ color:var(--ink-60); margin-top:.6rem; font-size:.94rem; }
@media (min-width:800px){ .pricing-faq-grid{ grid-template-columns:repeat(2,1fr); } }

/* ==========================================================================
   AUDIENCE (komu-to-pomaha)
   ========================================================================== */
.audience-hero{ max-width:var(--container); margin:0 auto; padding:3rem 1.5rem 5rem; display:grid; grid-template-columns:1fr; gap:2.5rem; }
.audience-hero-text p{ color:var(--ink-60); margin-top:1.2rem; max-width:56ch; font-size:1.05rem; }
.audience-hero-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.audience-hero-media img{ width:100%; aspect-ratio:4/3; object-fit:cover; }
@media (min-width:960px){ .audience-hero{ grid-template-columns:1fr 1fr; align-items:center; } }

.audience-grid{ max-width:var(--container); margin:0 auto; padding:0 1.5rem var(--section-pad); display:grid; grid-template-columns:1fr; gap:1.6rem; }
.audience-card{ background:var(--cream); border:1px solid var(--border-soft); border-radius:var(--radius-lg); padding:2rem; transition:transform .3s ease, box-shadow .3s ease; }
.audience-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.audience-card i{ color:var(--clay); font-size:1.5rem; margin-bottom:1rem; display:block; }
.audience-card hgroup p{ color:var(--sand); font-size:.85rem; font-weight:600; margin:.2rem 0 .8rem; }
.audience-card > p{ color:var(--ink-60); font-size:.95rem; }
@media (min-width:700px){ .audience-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1100px){ .audience-grid{ grid-template-columns:repeat(3,1fr); } }

.audience-scenarios{ padding:var(--section-pad) 1.5rem; background:var(--surface-alt); }
.audience-scenarios-head{ max-width:var(--container); margin:0 auto 3rem; max-width:600px; }
.audience-scenarios-body{ max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr; gap:2.4rem; }
.audience-scenarios-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.audience-scenarios-media img{ width:100%; aspect-ratio:5/4; object-fit:cover; }
.audience-scenario-item{ display:flex; gap:1rem; padding:1.2rem 0; border-bottom:1px solid var(--border-soft); }
.audience-scenario-item:last-child{ border-bottom:none; }
.audience-scenario-item i{ color:var(--clay); font-size:1.2rem; margin-top:.2rem; flex-shrink:0; }
.audience-scenario-item p{ color:var(--ink-60); font-size:.95rem; }
.audience-scenario-item strong{ color:var(--ink); }
@media (min-width:960px){ .audience-scenarios-body{ grid-template-columns:.9fr 1.1fr; align-items:center; } }

/* ==========================================================================
   CONTACT
   ========================================================================== */
.contact-hero{ max-width:var(--container); margin:0 auto; padding:3rem 1.5rem 4rem; display:grid; grid-template-columns:1fr; gap:2.5rem; }
.contact-hero-text p{ color:var(--ink-60); margin-top:1.2rem; max-width:52ch; font-size:1.05rem; }
.contact-hero-media{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.contact-hero-media img{ width:100%; aspect-ratio:16/10; object-fit:cover; }
@media (min-width:960px){ .contact-hero{ grid-template-columns:1fr 1fr; align-items:center; } }

.contact-facts{ background:var(--ink); padding:1.8rem 1.5rem; }
.contact-facts-inner{ max-width:var(--container); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:1.4rem; }
.contact-facts-inner div{ display:flex; align-items:center; gap:.8rem; color:#fff; font-size:.9rem; font-weight:600; }
.contact-facts-inner i{ color:var(--sand); font-size:1.1rem; }
@media (min-width:800px){ .contact-facts-inner{ grid-template-columns:repeat(4,1fr); } }

.contact-form-section{ max-width:var(--container); margin:0 auto; padding:var(--section-pad) 1.5rem; display:grid; grid-template-columns:1fr; gap:3rem; }
.contact-info h2{ margin-bottom:1.2rem; }
.contact-info .contact-details{ display:flex; flex-direction:column; gap:.7rem; margin-bottom:1.4rem; }
.contact-info .contact-details p{ display:flex; align-items:center; gap:.7rem; }
.contact-info .contact-details i{ color:var(--clay); width:18px; }
.contact-info-note{ color:var(--ink-60); font-size:.88rem; max-width:40ch; }

.contact-form fieldset{ border:none; padding:0; margin:0 0 1.8rem; }
.contact-form legend{ font-family:var(--font-head); font-weight:700; font-size:.9rem; color:var(--ink); margin-bottom:1rem; text-transform:uppercase; letter-spacing:.06em; }
.contact-form-row{ display:grid; grid-template-columns:1fr; gap:1.2rem; margin-bottom:1.2rem; }
.contact-form-field{ display:flex; flex-direction:column; gap:.4rem; }
.contact-form-field label{ font-size:.85rem; font-weight:600; color:var(--ink-60); }
.contact-form input, .contact-form textarea{
  padding:.85rem 1rem; border-radius:var(--radius-sm); border:1.5px solid var(--border-soft);
  font-family:var(--font-body); font-size:.95rem; background:var(--cream); color:var(--ink);
  transition:border-color .25s ease, box-shadow .25s ease; min-height:48px;
}
.contact-form textarea{ min-height:150px; resize:vertical; }
.contact-form input:focus, .contact-form textarea:focus{ outline:none; border-color:var(--clay); box-shadow:0 0 0 3px var(--clay-10); }
.contact-form-checkbox{ display:flex; align-items:flex-start; gap:.7rem; font-size:.88rem; color:var(--ink-60); }
.contact-form-checkbox input{ width:20px; height:20px; margin-top:.15rem; accent-color:var(--clay); flex-shrink:0; }
.contact-form-checkbox a{ color:var(--clay-hover); text-decoration:underline; }
@media (min-width:700px){ .contact-form-row{ grid-template-columns:1fr 1fr; } }
@media (min-width:960px){ .contact-form-section{ grid-template-columns:.8fr 1.2fr; } }

.contact-map-section{ max-width:var(--container); margin:0 auto; padding:0 1.5rem var(--section-pad); }
.contact-map{ border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.contact-map iframe{ width:100%; height:400px; border:0; display:block; }

/* ==========================================================================
   THANKS
   ========================================================================== */
.thanks-section{ padding:6rem 1.5rem; display:flex; justify-content:center; }
.thanks-inner{ max-width:520px; text-align:center; }
.thanks-icon{ font-size:4rem; color:var(--clay); margin-bottom:1.5rem; }
.thanks-inner h1{ margin-bottom:1rem; }
.thanks-inner p{ color:var(--ink-60); margin-top:.9rem; }
.thanks-inner .global-btn{ margin-top:2rem; }

/* ==========================================================================
   LEGAL PAGES (accordion)
   ========================================================================== */
.legal-hero{ max-width:900px; margin:0 auto; padding:4rem 1.5rem 2.5rem; }
.legal-hero p{ margin-top:.8rem; }
.legal-accordion{ max-width:840px; margin:0 auto; padding:0 1.5rem var(--section-pad); display:flex; flex-direction:column; gap:1rem; }
.legal-accordion-item{ background:var(--cream); border:1px solid var(--border-soft); border-radius:var(--radius-md); overflow:hidden; }
.legal-accordion-header{
  width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.3rem 1.6rem; font-family:var(--font-head); font-weight:700; font-size:1rem; color:var(--ink);
  text-align:left; transition:background .2s ease;
}
.legal-accordion-header:hover{ background:var(--ink-10); }
.legal-accordion-header i{ transition:transform .3s ease; color:var(--clay); flex-shrink:0; }
.legal-accordion-item.is-open .legal-accordion-header i{ transform:rotate(180deg); }
.legal-accordion-body{ max-height:0; overflow:hidden; transition:max-height .4s ease, padding .4s ease; padding:0 1.6rem; }
.legal-accordion-item.is-open .legal-accordion-body{ padding:0 1.6rem 1.6rem; }
.legal-accordion-body p{ color:var(--ink-60); font-size:.96rem; }

/* ==========================================================================
   Utility
   ========================================================================== */
.contact-details{ font-style:normal; }