:root {
    --paper:#FCFAF4; --white:#FFFFFF;
    --green:#2C4A33; --green-dk:#16271C; --green-fresh:#356046;
    --ink:#243D2A; --muted:#5C6F60; --gold:#A8801F; --gold-br:#E0BC6E; --cream:#F4E9D2;
    --border:rgba(36,61,42,.14);
    --w:140px; --h:121px;
  }
  * { box-sizing:border-box; margin:0; padding:0; }
  html { scroll-behavior:smooth; }
  body { background:var(--paper); color:var(--ink);
         font-family:'Montserrat',-apple-system,sans-serif; font-weight:400;
         font-size:17px; line-height:1.7; -webkit-font-smoothing:antialiased; }
  .container { max-width:1214px; margin:0 auto; padding:0 24px; }

  /* ===== header ===== */
  header { position:sticky; top:0; z-index:30; display:flex; align-items:center; justify-content:space-between;
           padding:18px 40px; background:rgba(252,250,244,.7); backdrop-filter:blur(14px); border-bottom:1px solid var(--border); }
  .hdr-left { display:flex; align-items:center; gap:22px; }
  .logo { display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink); }
  .logo .hex { width:32px; height:28px; display:grid; place-items:center;
               clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%); background:var(--green); }
  .logo .hex img { width:74%; }
  .logo .wm { font-family:'Montserrat',sans-serif; font-weight:700; letter-spacing:.14em; font-size:22px; }
  .nav-pills { display:flex; align-items:center; gap:4px; background:rgba(255,255,255,.6);
               border:1px solid var(--border); border-radius:40px; padding:5px 10px; }
  .nav-link { text-decoration:none; color:var(--ink); font-size:12px; font-weight:500; text-transform:uppercase;
              letter-spacing:.6px; padding:8px 14px; border-radius:30px; transition:.25s; }
  .nav-link:hover, .nav-link.active { background:rgba(44,74,51,.1); color:var(--green); }
  .btn-cta { display:inline-flex; align-items:center; gap:8px; background:var(--green); color:var(--cream);
             text-decoration:none; font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.6px;
             padding:13px 20px; border-radius:30px; transition:.25s; }
  .btn-cta:hover { background:var(--green-fresh); }
  @media (max-width:980px){ header{padding:14px 18px;} .nav-pills{display:none;} }

  /* ===== HERO — honeycomb behind the phone ===== */
  .hero { position:relative; overflow:hidden; background:var(--green-dk); }
  .hero__comb { position:absolute; inset:0; z-index:0; overflow:hidden; }
  .hcell { position:absolute; width:var(--w); height:var(--h); transform:translate(-50%,-50%);
           clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%); background:var(--green-dk); }
  .hface { position:absolute; inset:0; clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);
           background:var(--green); transform:scale(.94); }
  .hbg { position:absolute; inset:0; background-size:cover; background-position:center;
         filter:grayscale(1) contrast(1.1); }   /* статично; прозрачность задаётся inline на ячейку */
  .hero__comb::after { content:""; position:absolute; inset:0;
        background:radial-gradient(120% 90% at 18% 40%, rgba(22,39,28,.86) 0%, rgba(22,39,28,.5) 45%, rgba(22,39,28,.15) 100%); }

  .hero .container { position:relative; z-index:1; }
  .hero__inner { display:grid; grid-template-columns:repeat(12,minmax(0,1fr)); gap:40px; align-items:end; min-height:620px; padding-top:30px; }
  .hero__details { grid-column:1/7; padding-bottom:70px; align-self:center; }
  .hero__eyebrow { font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-br); margin-bottom:18px; }
  .hero__title { font-family:'Montserrat',sans-serif; font-weight:700; font-size:96px; line-height:.92; letter-spacing:-.04em; color:var(--cream); }
  .hero__desc { margin-top:22px; max-width:30em; font-size:19px; line-height:1.55; color:rgba(244,233,210,.82); font-weight:300; }
  .hero__links { margin-top:30px; }
  .hero__links a { color:var(--gold-br); text-decoration:none; font-size:17px; border-bottom:1px solid rgba(224,188,110,.5); padding-bottom:3px; }
  .hero__tags { margin-top:34px; display:flex; gap:10px; flex-wrap:wrap; }
  .hero__tags .label { height:34px; display:flex; align-items:center; padding:0 14px; font-size:14px;
                       color:var(--cream); border:1px solid rgba(244,233,210,.28); border-radius:30px; }
  .hero__poster { grid-column:8/13; display:flex; justify-content:center; align-items:flex-end; }

  /* phone mockup placeholder — later swapped for a honey jar */
  .phone { position:relative; width:300px; height:600px; margin-bottom:0; background:#0F1A13; border-radius:46px;
           padding:13px; box-shadow:0 40px 90px rgba(0,0,0,.45), inset 0 0 0 2px rgba(224,188,110,.18); }
  .phone::before { content:""; position:absolute; top:20px; left:50%; transform:translateX(-50%);
                   width:120px; height:26px; background:#0F1A13; border-radius:0 0 16px 16px; z-index:2; }
  .phone__screen { position:relative; width:100%; height:100%; border-radius:34px; overflow:hidden;
                   background:radial-gradient(120% 80% at 50% 25%, #2E5238, #1B3322 70%, #122318);
                   display:flex; flex-direction:column; align-items:center; justify-content:center; }
  .phone__screen img { width:46%; }
  .phone__screen .ti { margin-top:14px; font-family:'Montserrat',sans-serif; font-weight:600; font-size:30px; letter-spacing:.14em; color:var(--gold-br); }
  .phone__screen .cap { margin-top:6px; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:rgba(244,233,210,.55); }
  .phone__note { position:absolute; bottom:-30px; left:0; right:0; text-align:center; font-size:12px; color:rgba(244,233,210,.5); }

  /* ===== content (zhiznem project layout) ===== */
  .content { padding:56px 0 20px; }
  .section__content { max-width:980px; margin:0 auto; display:flex; flex-direction:column; gap:56px; }
  strong { font-weight:600; color:var(--green-dk); }
  .muted { color:var(--muted); }

  /* big bold lead */
  .project-about h2 { font-weight:600; font-size:22px; letter-spacing:-.02em; color:var(--green-dk); margin-bottom:20px; }
  .project-about .lead { font-weight:600; font-size:46px; line-height:1.08; letter-spacing:-.02em; color:var(--green-dk); }

  /* two-column detail: heading left, content right */
  .project-detail { display:grid; grid-template-columns:200px auto; gap:20px; }
  .project-detail__heading h2 { font-weight:600; font-size:22px; letter-spacing:-.02em; color:var(--green-dk); }
  .project-detail__content { font-size:19px; line-height:1.5; }
  .project-detail__content p { max-width:60ch; }
  .project-detail__content p + p { margin-top:16px; }

  .project-gallery img { width:100%; max-height:560px; object-fit:cover; border-radius:20px; display:block; }

  .notice-block { background:var(--green-dk); color:var(--cream); border-radius:20px; padding:42px 46px; }
  .notice-block .sub { font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-br); }
  .notice-block .big { font-weight:700; font-size:62px; line-height:1; letter-spacing:-.03em; margin:8px 0 8px; }
  .notice-block .desc { color:rgba(244,233,210,.72); font-size:18px; }

  .chips { display:flex; flex-wrap:wrap; gap:10px; }
  .chip { padding:10px 14px; background:#EFE9DB; border-radius:8px; font-size:15px; letter-spacing:-.02em; color:var(--ink); }

  .layers { list-style:none; display:grid; gap:14px; margin-top:6px; }
  .layers li { display:flex; gap:16px; align-items:flex-start; }
  .layers .n { flex:0 0 auto; width:36px; height:31px; display:grid; place-items:center;
               clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);
               background:var(--green); color:var(--gold-br); font-weight:700; font-size:16px; }
  .note { font-size:14px; font-style:italic; color:var(--muted); margin-top:18px; }

  .faq details { border-bottom:1px solid var(--border); }
  .faq summary { list-style:none; cursor:pointer; padding:16px 0; font-weight:600; font-size:20px;
                 display:flex; justify-content:space-between; align-items:center; gap:16px; color:var(--green-dk); }
  .faq summary::-webkit-details-marker{display:none;}
  .faq summary::after { content:"+"; color:var(--gold); font-size:24px; }
  .faq details[open] summary::after { content:"\2212"; }
  .faq .a { padding:0 0 16px; color:var(--muted); max-width:60ch; font-size:16px; }

  /* next-section navigation */
  .project-nav { border-top:1px solid var(--border); }
  .project-nav .container { max-width:980px; padding-top:64px; padding-bottom:30px; }
  .project-nav .h { font-size:20px; font-weight:600; color:var(--muted); margin-bottom:18px; }
  .project-link { display:inline-flex; align-items:center; gap:16px; text-decoration:none;
                  font-weight:700; font-size:48px; letter-spacing:-.04em; color:var(--green-dk); transition:color .25s; }
  .project-link svg { transition:transform .25s; }
  .project-link:hover { color:var(--gold); }
  .project-link:hover svg { transform:translate(4px,-4px); }

  @media (max-width:767.98px){
    .content{padding:70px 0 10px;} .section__content{gap:40px;}
    .project-about .lead{font-size:30px;}
    .project-detail{display:flex; flex-direction:column; gap:10px;}
    .notice-block .big{font-size:46px;} .project-link{font-size:32px;}
  }

  /* ===== order / contact form ===== */
  .form-section { padding:50px 0 10px; }
  .form-container { background:var(--green-dk); border-radius:24px; padding:56px 50px; display:grid; grid-template-columns:1fr 1fr; gap:56px; color:var(--cream); }
  .form-details { display:flex; flex-direction:column; justify-content:space-between; gap:30px; }
  .form-title { font-weight:700; font-size:clamp(2.2rem,4.5vw,3.4rem); line-height:1.02; letter-spacing:-.03em; color:var(--cream); }
  .form-title b { color:var(--gold-br); }
  .form-desc { font-size:18px; line-height:1.5; color:rgba(244,233,210,.6); margin-top:16px; }
  .contact-pills { display:flex; gap:10px; flex-wrap:wrap; }
  .contact-pill { display:inline-flex; align-items:center; gap:8px; padding:12px 20px; background:rgba(244,233,210,.08);
                  border:1px solid rgba(244,233,210,.14); border-radius:40px; font-size:15px; color:var(--cream); text-decoration:none; transition:.25s; }
  .contact-pill:hover { background:rgba(224,188,110,.18); border-color:rgba(224,188,110,.4); }
  .form-form { display:flex; flex-direction:column; gap:4px; }
  .input { height:58px; width:100%; border:0; outline:0; background:transparent; border-bottom:1px solid rgba(244,233,210,.16);
           color:var(--cream); font-family:inherit; font-size:16px; transition:border-color .2s; }
  .input:focus { border-color:var(--gold-br); }
  .input::placeholder { color:rgba(244,233,210,.35); }
  textarea.input { resize:vertical; min-height:92px; padding-top:18px; height:auto; }
  .button { margin-top:24px; height:58px; border:0; border-radius:40px; background:var(--gold); color:var(--green-dk);
            font-family:inherit; font-weight:700; font-size:15px; display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:0 30px; cursor:pointer; transition:.25s; }
  .button:hover { background:var(--gold-br); transform:translateY(-2px); }

  /* ===== footer ===== */
  .page-footer { margin:40px 10px 10px; background:var(--green-dk); border-radius:24px; padding:46px 0; color:var(--cream); }
  .footer-inner { display:flex; flex-direction:column; gap:34px; }
  .footer-top { display:flex; justify-content:space-between; align-items:flex-start; gap:30px; flex-wrap:wrap; }
  .footer-brand__name { font-weight:700; letter-spacing:.16em; font-size:18px; }
  .footer-brand__desc { color:rgba(244,233,210,.55); font-size:15px; margin-top:6px; }
  .footer-nav { display:flex; gap:8px; flex-wrap:wrap; list-style:none; }
  .footer-nav a { display:flex; align-items:center; height:42px; padding:0 18px; background:rgba(244,233,210,.08);
                  border-radius:10px; color:var(--cream); text-decoration:none; font-size:15px; transition:.25s; }
  .footer-nav a:hover { background:rgba(244,233,210,.16); }
  .footer-divider { height:1px; background:rgba(244,233,210,.12); }
  .footer-bottom { display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; color:rgba(244,233,210,.6); font-size:14px; align-items:center; }
  .footer-bottom a { color:rgba(244,233,210,.6); text-decoration:none; border-bottom:1px solid rgba(224,188,110,.4); }
  .formula { font-size:20px; }
  .formula b { color:var(--gold-br); font-weight:700; }
  @media (max-width:767.98px){ .form-container{ grid-template-columns:1fr; padding:40px 26px; gap:34px; } }

  @media (max-width:900px){
    .hero__inner{ display:flex; flex-direction:column; align-items:flex-start; min-height:0; padding:28px 0 18px; gap:16px; }
    .hero__details{ padding-bottom:0; }
    .hero__title{ font-size:64px; }
    .hero__poster{ width:100%; justify-content:center; }
    .hero__poster.product{ padding-bottom:0; gap:10px; }
    .hero__inner{ grid-template-columns:none; }
  }
  @media (max-width:560px){ .hero__title{font-size:48px;} .phone{width:240px;height:480px;} body{font-size:16px;} }

/* product hero (мёд): банка справа, блок покупки (цена+кнопка) слева */
.hero__poster .jar { width:min(440px,92%); height:auto; align-self:center; filter:drop-shadow(0 26px 44px rgba(0,0,0,.5)); }
.next-row { display:flex; gap:40px; flex-wrap:wrap; }
/* блок покупки под банкой: цена внутри кнопки */
.hero__poster.product { flex-direction:column; align-items:center; justify-content:center; gap:16px; align-self:center; padding-bottom:48px; }
.btn-buy { position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; gap:10px; width:min(340px,100%);
           background:linear-gradient(180deg,#F0BA42,#DB9F1F); color:#3A2A08; font-weight:700; font-size:17px; padding:18px 28px;
           border-radius:40px; text-decoration:none; box-shadow:0 8px 24px rgba(219,159,31,.35);
           transition:filter .25s, transform .25s, box-shadow .25s; }
.btn-buy .mid { opacity:.5; font-weight:400; }
.btn-buy .wt { font-size:13px; font-weight:500; opacity:.6; }
.btn-buy:hover { filter:brightness(1.07); transform:translateY(-2px); box-shadow:0 12px 30px rgba(219,159,31,.45); }
/* блеск — световой блик пробегает по кнопке */
.btn-buy::after { content:""; position:absolute; top:0; bottom:0; left:-60%; width:45%; pointer-events:none;
                  background:linear-gradient(110deg, transparent, rgba(255,255,255,.6), transparent); transform:skewX(-18deg); }
.anim .btn-buy::after { animation:shine 4.5s ease-in-out 1.2s infinite; }
@keyframes shine { 0%{ left:-60%; } 15%{ left:150%; } 100%{ left:150%; } }

/* scroll reveal + hero parallax */
.anim .section__content > *,
.anim .form-container,
.anim .project-nav .container > * {
  opacity:0; transform:translateY(28px);
  transition:opacity .7s ease, transform .8s cubic-bezier(.2,.72,.2,1);
}
.anim .in { opacity:1 !important; transform:none !important; }
#comb, .hero__poster .jar { will-change:transform; }

/* hero: каскадное появление на загрузке */
@keyframes heroIn { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:none; } }
.anim .hero__eyebrow { animation: heroIn .6s ease .05s backwards; }
.anim .hero__title   { animation: heroIn .7s cubic-bezier(.2,.72,.2,1) .14s backwards; }
.anim .hero__desc    { animation: heroIn .7s ease .24s backwards; }
.anim .hero__links   { animation: heroIn .7s ease .30s backwards; }
.anim .hero__tags    { animation: heroIn .7s ease .34s backwards; }
.anim .hero__poster  { animation: heroIn .8s cubic-bezier(.2,.72,.2,1) .42s backwards; }
