/* =========================================================
   Puretika — Testolibidium
   Палитра: светли + сребристи + зелени + тъмнозелени
   ========================================================= */

:root{
  /* Палитра */
  --c-light:      #f4f8f5;
  --c-light-2:    #eaf1ec;
  --c-white:      #ffffff;
  --c-silver:     #c5d0cc;
  --c-silver-2:   #97a5a0;
  --c-green:      #4a9c6e;
  --c-green-l:    #6fbf91;
  --c-green-d:    #2f7a52;
  --c-dark:       #1a3d2f;
  --c-dark-2:     #12281f;
  --c-ink:        #16241d;

  /* Семантични */
  --bg:           var(--c-light);
  --surface:      var(--c-white);
  --text:         var(--c-ink);
  --muted:        #5b6b63;
  --line:         #dde6e0;
  --accent:       var(--c-green);
  --accent-d:     var(--c-green-d);
  --error:        #b23b3b;

  /* Градиенти */
  --grad-dark:    linear-gradient(150deg, var(--c-dark-2) 0%, var(--c-dark) 45%, var(--c-green-d) 100%);
  --grad-soft:    linear-gradient(160deg, var(--c-light) 0%, var(--c-light-2) 100%);
  --grad-green:   linear-gradient(135deg, var(--c-green) 0%, var(--c-green-d) 100%);

  /* Радиус и сенки */
  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 26px;
  --r-xl: 36px;
  --shadow-sm: 0 4px 16px rgba(26,61,47,.07);
  --shadow-md: 0 14px 40px rgba(26,61,47,.12);
  --shadow-lg: 0 30px 70px rgba(18,40,31,.22);

  /* Типография */
  --font-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-display: "Segoe UI", -apple-system, BlinkMacSystemFont, Roboto, Georgia, serif;

  /* Spacing */
  --space-section: clamp(3.5rem, 7vw, 7rem);
  --shell: 1180px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-base);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:var(--accent-d); text-decoration:none; }
a:hover{ text-decoration:underline; }
h1,h2,h3{ line-height:1.18; margin:0; font-family:var(--font-display); letter-spacing:-.01em; }
p{ margin:0 0 1rem; }
ul,ol{ margin:0; padding:0; list-style:none; }

.pt-shell{ width:100%; max-width:var(--shell); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2rem); }
.pt-visually-hidden{ position:absolute!important; width:1px;height:1px; padding:0;margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }

.pt-skip{
  position:absolute; left:-999px; top:0; z-index:200;
  background:var(--c-dark); color:#fff; padding:.7rem 1.1rem; border-radius:0 0 var(--r-sm) 0;
}
.pt-skip:focus{ left:0; }

/* ---------- Typography helpers ---------- */
.pt-eyebrow{
  display:inline-block;
  font-size:.78rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent-d);
  padding:.35rem .8rem; border-radius:999px;
  background:rgba(74,156,110,.12);
  margin-bottom:1.1rem;
}
.pt-h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); font-weight:700; color:var(--c-dark); margin-bottom:1rem; }
.pt-note{ font-size:.92rem; color:var(--muted); border-left:3px solid var(--c-silver); padding-left:.9rem; margin-top:1.2rem; }

/* ---------- Buttons ---------- */
.pt-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font:inherit; font-weight:700; cursor:pointer; border:0;
  padding:.95rem 1.8rem; border-radius:999px;
  transition:transform .2s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  text-decoration:none; line-height:1;
}
.pt-btn:hover{ text-decoration:none; transform:translateY(-2px); }
.pt-btn:active{ transform:translateY(0); }
.pt-btn:focus-visible{ outline:3px solid var(--c-green-l); outline-offset:3px; }
.pt-btn--primary{ background:var(--grad-green); color:#fff; box-shadow:0 10px 26px rgba(47,122,82,.32); }
.pt-btn--primary:hover{ box-shadow:0 16px 34px rgba(47,122,82,.42); }
.pt-btn--ghost{ background:transparent; color:var(--c-dark); border:1.5px solid var(--c-silver); }
.pt-btn--ghost:hover{ border-color:var(--c-green); color:var(--c-green-d); background:rgba(74,156,110,.06); }
.pt-btn--block{ width:100%; }
.pt-btn--sm{ padding:.65rem 1.1rem; font-size:.9rem; }

/* ---------- Header ---------- */
.pt-header{
  position:sticky; top:0; z-index:100;
  background:rgba(244,248,245,.82);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.pt-header__inner{ display:flex; align-items:center; justify-content:space-between; height:72px; }
.pt-brand{ display:inline-flex; align-items:center; gap:.6rem; font-weight:800; color:var(--c-dark); }
.pt-brand:hover{ text-decoration:none; }
.pt-brand__mark{
  width:30px; height:30px; border-radius:9px;
  background:var(--grad-green);
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.55), 0 4px 12px rgba(47,122,82,.4);
  position:relative;
}
.pt-brand__mark::after{
  content:""; position:absolute; inset:8px; border-radius:4px;
  background:linear-gradient(135deg,#fff,rgba(255,255,255,.4));
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
}
.pt-brand__name{ font-family:var(--font-display); font-size:1.25rem; letter-spacing:.01em; }

.pt-nav{ display:flex; align-items:center; }
.pt-nav__list{ display:flex; align-items:center; gap:1.6rem; }
.pt-nav__list a{ color:var(--c-dark); font-weight:600; font-size:.97rem; }
.pt-nav__list a:hover{ color:var(--c-green-d); text-decoration:none; }
.pt-nav__cta{
  background:var(--grad-green); color:#fff!important; padding:.6rem 1.2rem; border-radius:999px;
  box-shadow:0 8px 20px rgba(47,122,82,.3);
}
.pt-nav__cta:hover{ transform:translateY(-1px); }
.pt-nav__toggle{
  display:none; flex-direction:column; gap:5px; width:44px; height:44px;
  background:transparent; border:0; cursor:pointer; align-items:center; justify-content:center;
}
.pt-nav__toggle span:not(.pt-visually-hidden){ width:24px; height:2px; background:var(--c-dark); border-radius:2px; transition:.25s; }
.pt-nav__toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.pt-nav__toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.pt-nav__toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ---------- Hero ---------- */
.pt-hero{ position:relative; color:#fff; overflow:hidden; padding-top:clamp(3rem,6vw,5rem); padding-bottom:2rem; }
.pt-hero__bg{
  position:absolute; inset:0; z-index:-2;
  background:var(--grad-dark);
}
.pt-hero__bg::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(closest-side at 80% 20%, rgba(111,191,145,.5), transparent 70%),
    radial-gradient(closest-side at 15% 80%, rgba(197,208,204,.28), transparent 70%);
}
.pt-hero__grid{
  display:grid; grid-template-columns:1.1fr .9fr; gap:2.5rem; align-items:center;
  padding-block:clamp(1.5rem,4vw,3rem);
}
.pt-hero__copy{ animation:pt-rise .8s ease both; }
.pt-hero .pt-eyebrow{ background:rgba(255,255,255,.16); color:#dff3e8; }
.pt-hero__title{ font-size:clamp(2.3rem,5.4vw,3.9rem); font-weight:800; margin-bottom:1.1rem; color:#fff; }
.pt-hero__lead{ font-size:clamp(1.02rem,1.6vw,1.18rem); color:#dfeee6; max-width:34ch; margin-bottom:1.8rem; }
.pt-hero__actions{ display:flex; flex-wrap:wrap; gap:.9rem; margin-bottom:1.8rem; }
.pt-hero__actions .pt-btn--ghost{ color:#fff; border-color:rgba(255,255,255,.5); }
.pt-hero__actions .pt-btn--ghost:hover{ background:rgba(255,255,255,.12); border-color:#fff; color:#fff; }
.pt-hero__price{ display:flex; align-items:baseline; gap:.7rem; flex-wrap:wrap; }
.pt-price__amount{ font-size:2rem; font-weight:800; color:#fff; }
.pt-price__note{ color:#bcd6c8; font-size:.92rem; }

.pt-hero__media{ position:relative; display:flex; justify-content:center; }
.pt-hero__glow{
  position:absolute; width:80%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(111,191,145,.55), transparent 65%);
  filter:blur(10px); top:50%; left:50%; transform:translate(-50%,-50%);
}
.pt-hero__product{
  position:relative; width:min(340px,80%); height:auto;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.45));
  animation:pt-float 6s ease-in-out infinite;
}
.pt-hero__disclaimer{
  position:relative; font-size:.85rem; color:#bcd6c8; margin:0;
  padding-top:1.4rem; border-top:1px solid rgba(255,255,255,.14);
}

@keyframes pt-float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-14px); } }
@keyframes pt-rise{ from{ opacity:0; transform:translateY(24px); } to{ opacity:1; transform:translateY(0); } }

/* ---------- Sections ---------- */
.pt-section{ padding-block:var(--space-section); }
.pt-section__head{ max-width:62ch; margin:0 auto clamp(2rem,4vw,3rem); text-align:center; }
.pt-section__head .pt-eyebrow{ margin-inline:auto; }
.pt-section__sub{ color:var(--muted); font-size:1.02rem; }

/* reveal animation */
.pt-reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
.pt-reveal.is-in{ opacity:1; transform:none; }

/* ---------- About ---------- */
.pt-about{ background:var(--grad-soft); }
.pt-about__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.pt-about__media img{ border-radius:var(--r-lg); box-shadow:var(--shadow-md); width:100%; aspect-ratio:4/3; object-fit:cover; }
.pt-tags{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.4rem; }
.pt-tags li{
  font-size:.85rem; font-weight:600; color:var(--c-green-d);
  background:rgba(74,156,110,.12); padding:.4rem .9rem; border-radius:999px;
}

/* ---------- Cards ---------- */
.pt-cards{ display:grid; gap:1.4rem; }
.pt-cards--4{ grid-template-columns:repeat(4,1fr); }
.pt-cards--3{ grid-template-columns:repeat(3,1fr); }
.pt-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:1.8rem 1.5rem; box-shadow:var(--shadow-sm);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.pt-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:var(--c-green-l); }
.pt-card__icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:52px; height:52px; border-radius:15px; font-size:1.4rem; color:#fff;
  background:var(--grad-green); margin-bottom:1rem; box-shadow:0 8px 18px rgba(47,122,82,.28);
}
.pt-card__title{ font-size:1.18rem; font-weight:700; color:var(--c-dark); margin-bottom:.5rem; }
.pt-card p{ color:var(--muted); margin:0; font-size:.96rem; }

/* ---------- Features ---------- */
.pt-features{ background:var(--grad-soft); }
.pt-features__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.pt-features__media img{ border-radius:var(--r-lg); box-shadow:var(--shadow-md); width:100%; aspect-ratio:1/1; object-fit:cover; }
.pt-spec{ display:grid; gap:1rem; margin-top:1.4rem; }
.pt-spec li{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md);
  padding:1.1rem 1.3rem; box-shadow:var(--shadow-sm);
}
.pt-spec__name{ display:block; font-weight:700; color:var(--c-dark); margin-bottom:.2rem; }
.pt-spec__text{ color:var(--muted); font-size:.95rem; }

/* ---------- Audience ---------- */
.pt-audience__grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; }
.pt-audience__item{
  position:relative; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:1.7rem; box-shadow:var(--shadow-sm);
  border-left:5px solid var(--c-green);
  transition:transform .3s ease, box-shadow .3s ease;
}
.pt-audience__item:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.pt-audience__item h3{ font-size:1.2rem; color:var(--c-dark); margin-bottom:.45rem; }
.pt-audience__item p{ color:var(--muted); margin:0; font-size:.96rem; }

/* ---------- Reviews ---------- */
.pt-reviews{ background:var(--grad-soft); }
.pt-review{
  margin:0; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:1.9rem; box-shadow:var(--shadow-sm);
  display:flex; flex-direction:column; gap:1.2rem;
  transition:transform .3s ease, box-shadow .3s ease;
}
.pt-review:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.pt-review blockquote{ margin:0; font-size:1.05rem; color:var(--text); position:relative; padding-top:1.6rem; }
.pt-review blockquote::before{
  content:"“"; position:absolute; top:-.6rem; left:-.2rem;
  font-size:3.4rem; line-height:1; color:var(--c-green-l); font-family:Georgia,serif;
}
.pt-review figcaption{ display:flex; flex-direction:column; border-top:1px solid var(--line); padding-top:1rem; }
.pt-review__name{ font-weight:700; color:var(--c-dark); }
.pt-review__meta{ font-size:.85rem; color:var(--muted); }

/* ---------- Routine ---------- */
.pt-routine__grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.pt-routine__media img{ border-radius:var(--r-lg); box-shadow:var(--shadow-md); width:100%; aspect-ratio:4/3; object-fit:cover; }
.pt-steps{ display:grid; gap:1rem; margin:1.4rem 0; }
.pt-steps li{ display:flex; gap:1rem; align-items:flex-start; }
.pt-steps__num{
  flex:0 0 auto; width:40px; height:40px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-weight:800; color:#fff;
  background:var(--grad-green); box-shadow:0 6px 14px rgba(47,122,82,.3);
}
.pt-steps__text{ color:var(--muted); padding-top:.35rem; }

/* ---------- Order ---------- */
.pt-order{ background:var(--grad-dark); color:#fff; position:relative; overflow:hidden; }
.pt-order::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(closest-side at 20% 30%, rgba(111,191,145,.35), transparent 70%);
}
.pt-order__grid{ position:relative; display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.pt-order .pt-h2{ color:#fff; }
.pt-order .pt-eyebrow{ background:rgba(255,255,255,.16); color:#dff3e8; }
.pt-order__intro{ color:#dfeee6; }
.pt-order__product{ position:relative; display:flex; flex-direction:column; align-items:center; gap:1.4rem; }
.pt-order__product img{ width:min(250px,70%); filter:drop-shadow(0 26px 44px rgba(0,0,0,.5)); position:relative; z-index:1; }
.pt-order__glow{
  position:absolute; top:40%; left:50%; transform:translate(-50%,-50%);
  width:75%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(111,191,145,.5), transparent 65%); filter:blur(12px);
}
.pt-order__pricecard{
  position:relative; z-index:1; text-align:center;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  padding:1rem 1.6rem; border-radius:var(--r-md); display:flex; flex-direction:column;
}
.pt-order__pricecard .pt-price__amount{ font-size:1.8rem; }

/* ---------- Forms ---------- */
.pt-form{
  background:var(--surface); border-radius:var(--r-lg); padding:clamp(1.5rem,3vw,2.2rem);
  box-shadow:var(--shadow-lg); color:var(--text);
}
.pt-field{ margin-bottom:1.2rem; }
.pt-field label{ display:block; font-weight:700; color:var(--c-dark); margin-bottom:.4rem; font-size:.95rem; }
.pt-field input[type="text"],
.pt-field input[type="tel"]{
  width:100%; font:inherit; padding:.85rem 1rem;
  border:1.5px solid var(--line); border-radius:var(--r-sm); background:var(--c-light);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.pt-field input:focus{ outline:0; border-color:var(--c-green); box-shadow:0 0 0 3px rgba(74,156,110,.18); background:#fff; }
.pt-field input.is-invalid{ border-color:var(--error); box-shadow:0 0 0 3px rgba(178,59,59,.15); }
.pt-field__error{ display:block; color:var(--error); font-size:.85rem; margin-top:.35rem; min-height:1em; }

.pt-check{ display:flex; gap:.7rem; align-items:flex-start; cursor:pointer; font-size:.92rem; color:var(--muted); }
.pt-check input{ position:absolute; opacity:0; width:1px; height:1px; }
.pt-check__box{
  flex:0 0 auto; width:22px; height:22px; border-radius:6px;
  border:1.5px solid var(--c-silver-2); background:#fff; margin-top:1px;
  display:inline-flex; align-items:center; justify-content:center; transition:.2s;
}
.pt-check__box::after{ content:"✓"; color:#fff; font-size:.8rem; opacity:0; transform:scale(.5); transition:.2s; }
.pt-check input:checked + .pt-check__box{ background:var(--grad-green); border-color:var(--c-green); }
.pt-check input:checked + .pt-check__box::after{ opacity:1; transform:scale(1); }
.pt-check input:focus-visible + .pt-check__box{ outline:3px solid var(--c-green-l); outline-offset:2px; }
.pt-check--disabled{ opacity:.7; cursor:default; }
.pt-check__text a{ color:var(--c-green-d); font-weight:600; }
.pt-field--check{ margin-top:.4rem; }
.pt-form__privacy{ font-size:.82rem; color:var(--muted); margin:1rem 0 0; }

/* ---------- Contact ---------- */
.pt-contact{ background:var(--grad-soft); }
.pt-contact__grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.pt-contact__list{ display:grid; gap:1rem; }
.pt-contact__list li{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md);
  padding:1.2rem 1.4rem; box-shadow:var(--shadow-sm); display:grid; gap:.2rem;
  border-left:5px solid var(--c-green);
}
.pt-contact__label{ font-size:.78rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--c-green-d); }
.pt-contact__value{ color:var(--c-dark); font-weight:600; }

/* ---------- Footer ---------- */
.pt-footer{ background:var(--c-dark-2); color:#cfe0d6; }
.pt-footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:2rem; padding-block:clamp(2.5rem,5vw,4rem); }
.pt-footer .pt-brand__name{ color:#fff; }
.pt-footer__about{ color:#9db8a9; margin-top:1rem; font-size:.95rem; max-width:32ch; }
.pt-footer h3{ font-size:1rem; color:#fff; margin-bottom:1rem; }
.pt-footer__nav a{ color:#cfe0d6; font-size:.95rem; }
.pt-footer__nav a:hover{ color:#fff; }
.pt-footer__nav li{ margin-bottom:.55rem; }
.pt-footer__contact p{ font-size:.93rem; color:#9db8a9; }
.pt-footer__contact a{ color:#cfe0d6; }
.pt-footer__bottom{ border-top:1px solid rgba(255,255,255,.1); padding-block:1.3rem; }
.pt-footer__bottom p{ margin:0; font-size:.82rem; color:#8aa697; }

/* ---------- Cookie banner ---------- */
.pt-cookie{
  position:fixed; left:50%; bottom:1.2rem; transform:translateX(-50%) translateY(140%);
  width:min(960px,calc(100% - 2rem)); z-index:160;
  background:rgba(244,248,245,.96); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); padding:1.4rem 1.6rem;
  transition:transform .45s cubic-bezier(.2,.8,.2,1);
}
.pt-cookie.is-visible{ transform:translateX(-50%) translateY(0); }
.pt-cookie__inner{ display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap; }
.pt-cookie__text{ flex:1 1 320px; }
.pt-cookie__text strong{ color:var(--c-dark); display:block; margin-bottom:.3rem; }
.pt-cookie__text p{ margin:0; font-size:.9rem; color:var(--muted); }
.pt-cookie__actions{ display:flex; gap:.6rem; flex-wrap:wrap; }
.pt-cookie__prefs{ margin-top:1.2rem; padding-top:1.2rem; border-top:1px solid var(--line); display:grid; gap:.8rem; }
[hidden]{ display:none!important; }
.pt-cookie__prefs .pt-btn{ justify-self:start; margin-top:.3rem; }

/* ---------- To top ---------- */
.pt-totop{
  position:fixed; right:1.2rem; bottom:1.2rem; z-index:150;
  width:48px; height:48px; border-radius:50%; border:0; cursor:pointer;
  background:var(--grad-green); color:#fff; font-size:1.2rem;
  box-shadow:0 10px 24px rgba(47,122,82,.4); opacity:0; transform:translateY(20px);
  transition:opacity .3s ease, transform .3s ease;
}
.pt-totop.is-visible{ opacity:1; transform:translateY(0); }
.pt-totop:focus-visible{ outline:3px solid var(--c-green-l); outline-offset:3px; }

/* ---------- Legal / inner pages ---------- */
.pt-page{ padding-block:clamp(3rem,6vw,5rem); }
.pt-page__head{ background:var(--grad-dark); color:#fff; padding-block:clamp(2.5rem,5vw,4rem); }
.pt-page__head .pt-eyebrow{ background:rgba(255,255,255,.16); color:#dff3e8; }
.pt-page__head h1{ font-size:clamp(1.9rem,4vw,2.8rem); color:#fff; }
.pt-page__head p{ color:#dfeee6; margin:.6rem 0 0; max-width:60ch; }
.pt-prose{ max-width:760px; margin-inline:auto; }
.pt-prose h2{ font-size:1.4rem; color:var(--c-dark); margin:2.2rem 0 .8rem; }
.pt-prose h3{ font-size:1.1rem; color:var(--c-green-d); margin:1.5rem 0 .5rem; }
.pt-prose p, .pt-prose li{ color:var(--text); }
.pt-prose ul{ list-style:disc; padding-left:1.3rem; margin:0 0 1rem; display:grid; gap:.4rem; }
.pt-prose ul li{ padding-left:.2rem; }
.pt-prose .pt-note{ margin:1.5rem 0; }
.pt-back{ display:inline-flex; align-items:center; gap:.5rem; margin-top:2rem; }

/* ---------- Success page ---------- */
.pt-success{ min-height:70vh; display:flex; align-items:center; }
.pt-success__card{
  max-width:560px; margin-inline:auto; text-align:center;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-xl);
  padding:clamp(2rem,5vw,3.5rem); box-shadow:var(--shadow-md);
}
.pt-success__check{
  width:84px; height:84px; border-radius:50%; margin:0 auto 1.5rem;
  background:var(--grad-green); display:flex; align-items:center; justify-content:center;
  font-size:2.4rem; color:#fff; box-shadow:0 14px 30px rgba(47,122,82,.4);
  animation:pt-pop .5s cubic-bezier(.2,1.4,.4,1) both;
}
.pt-success__card h1{ font-size:clamp(1.7rem,4vw,2.3rem); color:var(--c-dark); margin-bottom:.8rem; }
.pt-success__card p{ color:var(--muted); }
.pt-success__ref{
  display:inline-block; margin:1rem 0; font-weight:700; color:var(--c-green-d);
  background:rgba(74,156,110,.12); padding:.5rem 1rem; border-radius:999px;
}
@keyframes pt-pop{ from{ opacity:0; transform:scale(.5); } to{ opacity:1; transform:scale(1); } }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .pt-cards--4{ grid-template-columns:repeat(2,1fr); }
  .pt-footer__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:860px){
  .pt-nav__toggle{ display:flex; }
  .pt-nav__list{
    position:absolute; top:72px; left:0; right:0;
    flex-direction:column; align-items:stretch; gap:0;
    background:rgba(244,248,245,.98); backdrop-filter:blur(14px);
    border-bottom:1px solid var(--line);
    padding:.5rem 1rem 1.2rem; box-shadow:var(--shadow-md);
    max-height:0; overflow:hidden; opacity:0; pointer-events:none;
    transition:max-height .35s ease, opacity .25s ease;
  }
  .pt-nav__list.is-open{ max-height:400px; opacity:1; pointer-events:auto; }
  .pt-nav__list li{ border-bottom:1px solid var(--line); }
  .pt-nav__list li:last-child{ border-bottom:0; }
  .pt-nav__list a{ display:block; padding:.9rem .5rem; }
  .pt-nav__cta{ text-align:center; margin-top:.6rem; }

  .pt-hero__grid{ grid-template-columns:1fr; text-align:center; }
  .pt-hero__copy{ order:2; }
  .pt-hero__media{ order:1; }
  .pt-hero__lead{ margin-inline:auto; }
  .pt-hero__actions{ justify-content:center; }
  .pt-hero__price{ justify-content:center; }

  .pt-about__grid,
  .pt-features__grid,
  .pt-routine__grid,
  .pt-order__grid,
  .pt-contact__grid{ grid-template-columns:1fr; }
  .pt-about__media,
  .pt-features__media{ order:-1; }
  .pt-cards--3{ grid-template-columns:1fr; }
}
@media (max-width:620px){
  body{ font-size:16px; }
  .pt-cards--4{ grid-template-columns:1fr; }
  .pt-audience__grid{ grid-template-columns:1fr; }
  .pt-footer__grid{ grid-template-columns:1fr; }
  .pt-cookie__actions{ width:100%; }
  .pt-cookie__actions .pt-btn{ flex:1 1 auto; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .pt-reveal{ opacity:1; transform:none; }
}
