/* =====================================================
   Fresh Air — site_06_brizery
   Fresh, ecology, health. Plus Jakarta Sans 400/600.
   Green #059669, soft blue #38BDF8, white.
   Cards: green shadow on hover. Hero: light green → white.
   ===================================================== */

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

:root {
  --green:      #059669;
  --green-dark: #047857;
  --green-deep: #064E3B;
  --green-light:#D1FAE5;
  --green-pale: #ECFDF5;
  --sky:        #38BDF8;
  --sky-dark:   #0EA5E9;
  --sky-light:  #E0F2FE;
  --slate-50:   #F8FAFC;
  --slate-100:  #F1F5F9;
  --slate-200:  #E2E8F0;
  --white:      #FFFFFF;
  --ink:        #0F172A;
  --ink-soft:   #1E293B;
  --steel:      #475569;
  --muted:      #64748B;
  --success:    #059669;
  --danger:     #EF4444;

  --font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --r-sm: 8px; --r: 12px; --r-lg: 18px; --r-xl: 26px;
  --sh-sm: 0 2px 8px rgba(5,150,105,.05);
  --sh:    0 4px 20px rgba(5,150,105,.10), 0 2px 8px rgba(15,23,42,.04);
  --sh-lg: 0 12px 36px rgba(5,150,105,.14), 0 4px 12px rgba(15,23,42,.06);
  --sh-green: 0 4px 18px rgba(5,150,105,.30);
  --sh-green-lg: 0 10px 32px rgba(5,150,105,.40);
  --dur: 220ms; --ease: cubic-bezier(.4,0,.2,1); --w: 1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{font-family:var(--font);font-size:16px;line-height:1.65;color:var(--ink-soft);background:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--green);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover{color:var(--green-dark)}
ul{list-style:none}
button{font-family:var(--font)}

h1,h2,h3,h4{font-family:var(--font);line-height:1.12;color:var(--ink);letter-spacing:-0.025em}
h1{font-size:clamp(32px,5vw,56px);font-weight:700}
h2{font-size:clamp(26px,3.8vw,42px);font-weight:700;margin-bottom:14px}
h3{font-size:clamp(15px,1.7vw,19px);font-weight:600}
.section-title{text-align:center}
.section-subtitle{text-align:center;color:var(--steel);font-size:17px;max-width:680px;margin:0 auto 56px;line-height:1.6}
.container{width:100%;max-width:var(--w);margin:0 auto;padding:0 24px}
section{padding:96px 0}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:var(--r);font-family:var(--font);font-weight:600;font-size:15px;line-height:1;border:none;cursor:pointer;text-decoration:none;transition:all var(--dur) var(--ease);white-space:nowrap}
.btn-primary{background:var(--green);color:#fff;box-shadow:var(--sh-green)}
.btn-primary:hover{background:var(--green-dark);color:#fff;box-shadow:var(--sh-green-lg);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.24);backdrop-filter:blur(10px)}
.btn-ghost:hover{background:rgba(255,255,255,.22);color:#fff}
.btn-outline{background:transparent;color:var(--green);border:1.5px solid var(--green)}
.btn-outline:hover{background:var(--green);color:#fff}
.btn-lg{padding:18px 40px;font-size:16px;border-radius:var(--r-lg)}
.btn-block{width:100%}

/* HEADER */
.site-header{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.94);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid rgba(5,150,105,.10);transition:box-shadow var(--dur) var(--ease)}
.site-header.scrolled{box-shadow:0 2px 20px rgba(5,150,105,.10)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:16px}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;flex-shrink:0}
.logo__mark{width:40px;height:40px;border-radius:var(--r);background:linear-gradient(135deg,#059669,#064E3B);display:grid;place-items:center;color:#fff;font-weight:700;font-size:17px;box-shadow:0 3px 12px rgba(5,150,105,.25);flex-shrink:0;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.logo:hover .logo__mark{transform:scale(1.06);box-shadow:0 5px 18px rgba(5,150,105,.40)}
.logo__text{display:flex;flex-direction:column;line-height:1.2}
.logo__name{font-weight:700;font-size:14px;color:var(--ink);letter-spacing:-0.02em}
.logo__tag{font-size:11px;color:var(--muted)}
.header-nav{display:flex;gap:24px;flex:1;justify-content:center}
.header-nav a{color:var(--ink-soft);font-weight:500;font-size:14px;padding:4px 0;position:relative}
.header-nav a::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--green);border-radius:1px;transform:scaleX(0);transition:transform var(--dur) var(--ease);transform-origin:left}
.header-nav a:hover{color:var(--green)}
.header-nav a:hover::after{transform:scaleX(1)}
.header-cta{display:flex;align-items:center;gap:14px;flex-shrink:0}
.header-phone{display:flex;flex-direction:column;align-items:flex-end;text-decoration:none;gap:2px}
.header-phone__num{font-weight:700;font-size:16px;color:var(--ink);letter-spacing:-0.025em;transition:color var(--dur) var(--ease)}
.header-phone:hover .header-phone__num{color:var(--green)}
.header-phone__hint{font-size:11px;color:var(--muted)}
.burger{display:none;background:none;border:1.5px solid rgba(5,150,105,.2);border-radius:var(--r-sm);width:38px;height:38px;align-items:center;justify-content:center;color:var(--ink);cursor:pointer;transition:all var(--dur) var(--ease)}
.burger:hover{border-color:var(--green);color:var(--green)}
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:#fff;z-index:800;padding:32px 24px;flex-direction:column;gap:8px;overflow-y:auto}
.mobile-menu.is-open{display:flex}
.mobile-menu a{display:block;padding:14px 0;font-size:18px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--green-pale)}
.mobile-menu a:hover{color:var(--green)}
.mobile-menu .btn{margin-top:16px}

/* HERO — light green gradient → white */
.hero{padding:100px 0 120px;background:linear-gradient(155deg,#E8F8F2 0%,#D1FAE5 35%,#ECFDF5 65%,#F0F9FF 100%);color:var(--ink);overflow:hidden;position:relative}
.hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(5,150,105,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(56,189,248,.08) 0%,transparent 50%)}
.hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent);opacity:.3}
.hero__grid{display:grid;grid-template-columns:1.2fr 0.8fr;align-items:center;gap:64px;position:relative;z-index:1}
.hero__badge{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;background:rgba(5,150,105,.10);border:1px solid rgba(5,150,105,.25);border-radius:40px;font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--green-dark);margin-bottom:28px}
.hero__badge .dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(5,150,105,.20);animation:dot-pulse 2.2s ease-in-out infinite}
@keyframes dot-pulse{0%,100%{box-shadow:0 0 0 3px rgba(5,150,105,.20)}50%{box-shadow:0 0 0 6px rgba(5,150,105,.06)}}
.hero h1{color:var(--ink);margin-bottom:20px}
.hero h1 span{color:var(--green)}
.hero__sub{font-size:17px;color:var(--steel);line-height:1.65;max-width:540px;margin-bottom:40px}
.hero__actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:52px}
/* override ghost for light hero */
.hero .btn-ghost{background:rgba(5,150,105,.10);color:var(--green-dark);border:1px solid rgba(5,150,105,.25);backdrop-filter:none}
.hero .btn-ghost:hover{background:rgba(5,150,105,.18);color:var(--green-dark)}
.hero__metrics{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid rgba(5,150,105,.15);padding-top:32px;max-width:520px}
.hero__metric-item{padding-right:24px}
.hero__metric-item:not(:first-child){padding-left:24px;border-left:1px solid rgba(5,150,105,.12)}
.hero__metric-num{font-size:30px;font-weight:700;color:var(--green);line-height:1;letter-spacing:-0.03em}
.hero__metric-label{font-size:12px;color:var(--muted);margin-top:6px}
.hero__visual{position:relative;display:flex;align-items:center;justify-content:center}
.hero__visual svg{width:100%;max-width:420px;filter:drop-shadow(0 20px 48px rgba(5,150,105,.15));animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero__visual-ring{position:absolute;border-radius:50%;border:1px solid rgba(5,150,105,.10);animation:ring-pulse 4s ease-in-out infinite}
.hero__visual-ring:nth-child(1){width:180px;height:180px;animation-delay:0s}
.hero__visual-ring:nth-child(2){width:300px;height:300px;animation-delay:.9s}
.hero__visual-ring:nth-child(3){width:420px;height:420px;animation-delay:1.8s}
@keyframes ring-pulse{0%,100%{opacity:.25}50%{opacity:.55}}

/* PAINS */
.pains{background:var(--green-pale);border-top:1px solid var(--green-light);border-bottom:1px solid var(--green-light)}
.pains__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pain{background:#fff;border-radius:var(--r-lg);padding:28px 24px;border:1px solid rgba(5,150,105,.08);box-shadow:var(--sh-sm);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.pain:hover{border-color:rgba(5,150,105,.2);box-shadow:var(--sh-green);transform:translateY(-3px)}
.pain__icon{width:44px;height:44px;border-radius:var(--r);background:var(--green-light);display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--green);margin-bottom:16px;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
.pain:hover .pain__icon{background:var(--green);color:#fff}
.pain h3{font-size:14px;font-weight:600;margin-bottom:8px}
.pain p{font-size:13px;color:var(--steel);line-height:1.6}

/* SERVICES */
.services{background:#fff}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.service{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(5,150,105,.08);box-shadow:var(--sh-sm);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease),border-color var(--dur) var(--ease);display:flex;flex-direction:column}
.service:hover{box-shadow:var(--sh-green-lg);transform:translateY(-5px);border-color:rgba(5,150,105,.25)}
.service__visual{aspect-ratio:16/9;background:var(--green-pale);overflow:hidden;display:flex;align-items:center;justify-content:center}
.service__visual img{width:100%;height:100%;object-fit:cover;transition:transform 400ms var(--ease)}
.service:hover .service__visual img{transform:scale(1.04)}
.service__visual svg{width:72px;height:72px;color:rgba(5,150,105,.2);transition:color var(--dur) var(--ease)}
.service:hover .service__visual svg{color:var(--green)}
.service__body{padding:22px 20px;display:flex;flex-direction:column;flex:1}
.service__body h3{font-size:15px;margin-bottom:8px}
.service__desc{font-size:13px;color:var(--steel);line-height:1.6;margin-bottom:14px}
.service__features{display:flex;flex-direction:column;gap:5px;margin-bottom:18px;flex:1}
.service__features li{font-size:13px;color:var(--steel);padding-left:16px;position:relative}
.service__features li::before{content:'';position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--green)}
.service__footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid rgba(5,150,105,.06)}
.service__price{font-size:13px;color:var(--steel)}
.service__price strong{font-size:15px;color:var(--ink);font-weight:700}
.service__btn{font-size:13px;font-weight:600;color:var(--green);display:flex;align-items:center;gap:4px;transition:gap var(--dur) var(--ease)}
.service__btn:hover{color:var(--green-dark);gap:8px}

/* ADVANTAGES */
.advantages{background:var(--green-pale)}
.advantages__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.advantage{background:#fff;border-radius:var(--r-lg);padding:30px 26px;border:1px solid rgba(5,150,105,.08);box-shadow:var(--sh-sm);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.advantage:hover{box-shadow:var(--sh-green);transform:translateY(-3px);border-color:rgba(5,150,105,.20)}
.advantage__num{font-size:40px;font-weight:700;color:var(--green);letter-spacing:-0.04em;line-height:1;margin-bottom:10px}
.advantage h3{font-size:15px;margin-bottom:6px}
.advantage p{font-size:13px;color:var(--steel);line-height:1.6}

/* STEPS */
.steps{background:#fff}
.steps__list{display:grid;grid-template-columns:repeat(5,1fr);position:relative;counter-reset:step}
.steps__list::before{content:'';position:absolute;top:28px;left:calc(10% + 14px);right:calc(10% + 14px);height:1px;background:linear-gradient(90deg,var(--green-light),var(--green));opacity:.6}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 12px;position:relative;z-index:1;counter-increment:step}
.step::before{content:counter(step);width:56px;height:56px;border-radius:50%;background:#fff;border:2px solid var(--slate-200);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;color:var(--muted);margin-bottom:20px;transition:all 300ms var(--ease);flex-shrink:0}
.step:hover::before{border-color:var(--green);color:var(--green-dark);background:var(--green-pale);box-shadow:0 0 0 5px rgba(5,150,105,.08)}
.step h3{font-size:14px;font-weight:600;margin-bottom:6px}
.step p{font-size:13px;color:var(--steel);line-height:1.6}

/* PORTFOLIO */
.portfolio{background:var(--green-pale)}
.portfolio__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.portfolio-item{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(5,150,105,.08);box-shadow:var(--sh-sm);transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease)}
.portfolio-item:hover{box-shadow:var(--sh-green-lg);transform:translateY(-4px)}
.portfolio-item__visual{aspect-ratio:16/9;background:var(--green-pale);overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}
.portfolio-item__visual img{width:100%;height:100%;object-fit:cover;transition:transform 500ms var(--ease)}
.portfolio-item:hover .portfolio-item__visual img{transform:scale(1.05)}
.portfolio-item__visual svg{width:60px;height:60px;color:rgba(5,150,105,.2)}
.portfolio-item__label{position:absolute;top:12px;left:12px;background:rgba(6,78,59,.75);color:#fff;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:5px 10px;border-radius:var(--r-sm);backdrop-filter:blur(8px)}
.portfolio-item__body{padding:18px 22px}
.portfolio-item__body h3{font-size:14px;margin-bottom:5px}
.portfolio-item__meta{font-size:12px;color:var(--steel);margin-bottom:8px}
.portfolio-item__result{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--green)}
.portfolio-item__result::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green)}

/* REVIEWS */
.reviews{background:#fff}
.reviews__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.review{background:var(--green-pale);border-radius:var(--r-lg);padding:28px;border:1px solid rgba(5,150,105,.08);transition:box-shadow var(--dur) var(--ease),border-color var(--dur) var(--ease)}
.review:hover{border-color:rgba(5,150,105,.22);box-shadow:var(--sh-green)}
.review__stars{color:#F59E0B;font-size:14px;letter-spacing:2px;margin-bottom:12px}
.review__text{font-size:14px;color:var(--steel);line-height:1.7;margin-bottom:18px}
.review__author{display:flex;align-items:center;gap:12px}
.review__avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--green-deep));display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.review__meta strong{font-size:14px;color:var(--ink);font-weight:600;display:block}
.review__meta span{font-size:12px;color:var(--muted)}

/* FORM — light airy */
.form-section{background:linear-gradient(155deg,#E8F8F2 0%,#D1FAE5 40%,#ECFDF5 100%);padding:96px 0;position:relative;overflow:hidden}
.form-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 10% 80%,rgba(56,189,248,.08) 0%,transparent 40%),radial-gradient(circle at 90% 20%,rgba(5,150,105,.06) 0%,transparent 40%)}
.form-section__grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.form-section__text h2{color:var(--ink);margin-bottom:16px}
.form-section__lead{color:var(--steel);font-size:16px;line-height:1.7;margin-bottom:32px}
.form-section__perks{display:flex;flex-direction:column;gap:10px}
.form-section__perks li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--steel)}
.form-section__perks li::before{content:'';width:18px;height:18px;border-radius:50%;flex-shrink:0;background:rgba(5,150,105,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23059669' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E") no-repeat center/10px;border:1px solid rgba(5,150,105,.30)}
.form-card{background:#fff;border-radius:var(--r-xl);padding:36px;box-shadow:0 20px 48px rgba(5,150,105,.15),0 8px 16px rgba(15,23,42,.06)}
.form-card h3{font-size:21px;margin-bottom:6px}
.form-card__sub{font-size:14px;color:var(--steel);margin-bottom:28px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group label{font-size:13px;font-weight:600;color:var(--ink-soft)}
.form-group input,.form-group textarea{padding:12px 16px;border:1.5px solid rgba(5,150,105,.15);border-radius:var(--r);font-family:var(--font);font-size:15px;color:var(--ink);background:#fff;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);outline:none;width:100%}
.form-group input:focus,.form-group textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(5,150,105,.12)}
.form-group input.error{border-color:var(--danger)}
.form-group textarea{resize:vertical;min-height:88px}
.form-policy{margin-top:12px;font-size:12px;color:var(--muted);text-align:center}
.form-policy a{color:var(--steel);text-decoration:underline}

/* FAQ */
.faq{background:var(--green-pale)}
.faq__list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.faq-item{background:#fff;border:1px solid rgba(5,150,105,.08);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.faq-item.is-open{border-color:rgba(5,150,105,.25);box-shadow:var(--sh-sm)}
.faq-item__q{width:100%;background:none;border:none;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;font-size:15px;font-weight:600;color:var(--ink);cursor:pointer;transition:color var(--dur) var(--ease)}
.faq-item__q:hover,.faq-item.is-open .faq-item__q{color:var(--green)}
.faq-item__q::after{content:'';width:20px;height:20px;flex-shrink:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M5 7.5L10 12.5L15 7.5' stroke='%2364748B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center/contain;transition:transform 250ms var(--ease)}
.faq-item.is-open .faq-item__q::after{transform:rotate(180deg)}
.faq-item__a{max-height:0;overflow:hidden;transition:max-height 300ms var(--ease)}
.faq-item__a-inner{padding:0 22px 18px;font-size:14px;color:var(--steel);line-height:1.7}

/* SEO */
.seo-text{background:#fff;border-top:1px solid rgba(5,150,105,.06);padding:64px 0}
.seo-text__inner{max-width:820px;margin:0 auto}
.seo-text__inner h2{font-size:clamp(18px,2.2vw,26px);margin-bottom:22px}
.seo-text__inner p{font-size:14px;color:var(--steel);line-height:1.8;margin-bottom:14px}

/* FOOTER */
.site-footer{background:var(--ink);color:rgba(255,255,255,.6);padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-col h4{font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer-col p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.7}
.footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.50);padding:4px 0;transition:color var(--dur) var(--ease)}
.footer-col a:hover{color:var(--green)}
.footer-contacts{display:flex;flex-direction:column;gap:8px}
.footer-contacts li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.50)}
.footer-contacts i{margin-top:3px;color:var(--green);font-size:12px;flex-shrink:0}
.footer-contacts a{display:inline;padding:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:12px;color:rgba(255,255,255,.30)}
.footer-bottom a{color:rgba(255,255,255,.30);font-size:12px}
.footer-bottom a:hover{color:var(--green)}

/* POPUP */
.popup-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.popup-overlay.is-open{display:flex}
.popup{background:#fff;border-radius:var(--r-xl);padding:40px 36px;max-width:420px;width:100%;text-align:center;position:relative;box-shadow:0 32px 64px rgba(0,0,0,.20),0 8px 24px rgba(5,150,105,.10);animation:popup-in 300ms ease-out}
@keyframes popup-in{from{opacity:0;transform:scale(.94) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}
.popup__close{position:absolute;top:14px;right:14px;background:var(--slate-100);border:none;width:30px;height:30px;border-radius:50%;font-size:18px;cursor:pointer;color:var(--steel);display:grid;place-items:center;transition:all var(--dur) var(--ease)}
.popup__close:hover{background:var(--slate-200)}
.popup__icon{font-size:40px;margin-bottom:12px}
.popup__title{font-size:22px;margin-bottom:10px}
.popup__text{font-size:14px;color:var(--steel);line-height:1.6;margin-bottom:24px}
.popup__btn{width:100%}
.popup__note{margin-top:10px;font-size:12px;color:var(--muted)}

/* MESSENGER */
.messenger-buttons{position:fixed;bottom:28px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:700}
.messenger-btn{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;font-size:11px;font-weight:700;box-shadow:var(--sh-lg);transition:transform var(--dur) var(--ease)}
.messenger-btn:hover{transform:scale(1.1) translateY(-2px);color:#fff}
.messenger-btn--tg{background:#29A9EB}
.messenger-btn--max{background:var(--green-deep)}
.messenger-btn svg{width:22px;height:22px}

/* REVEAL */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 560ms var(--ease),transform 560ms var(--ease)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
[data-delay="1"]{transition-delay:80ms}
[data-delay="2"]{transition-delay:160ms}
[data-delay="3"]{transition-delay:240ms}
[data-delay="4"]{transition-delay:320ms}
[data-delay="5"]{transition-delay:400ms}
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--green),var(--sky));z-index:1000;width:0%;transition:width .1s linear}

@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}.steps__list{grid-template-columns:1fr 1fr;gap:28px}.steps__list::before{display:none}}
@media(max-width:900px){.hero__grid{grid-template-columns:1fr}.hero__visual{display:none}.services__grid{grid-template-columns:repeat(2,1fr)}.pains__grid{grid-template-columns:repeat(2,1fr)}.advantages__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){section{padding:64px 0}.header-nav{display:none}.header-cta .btn{display:none}.burger{display:flex}.form-section__grid{grid-template-columns:1fr;gap:40px}.reviews__grid{grid-template-columns:1fr}.portfolio__grid{grid-template-columns:1fr}}
@media(max-width:640px){.services__grid{grid-template-columns:1fr}.pains__grid{grid-template-columns:1fr}.advantages__grid{grid-template-columns:1fr}.steps__list{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr;gap:24px}}
