/* vipflowers_new home page — Warm Botanical Boutique */
:root{
  --base:#F8F5F0; --paper:#FFFFFF;
  --sage:#8A9A7B; --sage-soft:#E7ECE1;
  --deep:#2E4A3B; --deep-2:#24382d;
  --terra:#C17B5E; --terra-soft:#F2E2D9;
  --char:#2A2A2A; --muted:#7A756C; --line:#E6E0D6;
  --serif:"Fraunces", Georgia, serif;
  --sans:"Manrope", system-ui, sans-serif;
  --shadow-card:0 1px 2px rgba(46,74,59,.04), 0 8px 24px -12px rgba(46,74,59,.18);
  --shadow-lift:0 2px 6px rgba(46,74,59,.06), 0 26px 50px -20px rgba(46,74,59,.32);
}
.vfn *{box-sizing:border-box; margin:0; padding:0}
.vfn-html{scroll-behavior:smooth}
.vfn-body{background:var(--base); color:var(--char); font-family:var(--sans); -webkit-font-smoothing:antialiased; overflow-x:hidden}
.vfn-body::after{content:""; position:fixed; inset:0; z-index:9999; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E")}
.vfn a{color:inherit; text-decoration:none}
.vfn .wrap{max-width:1240px; margin:0 auto; padding:0 24px}
.vfn .serif{font-family:var(--serif)} .vfn em{font-style:italic}

/* header */
.vfn header.site{position:sticky; top:0; z-index:100; background:rgba(248,245,240,.82); backdrop-filter:blur(12px); border-bottom:1px solid var(--line)}
.vfn .nav{display:flex; align-items:center; gap:28px; height:68px; position:relative}
.vfn .logo{font-family:var(--serif); font-weight:600; font-size:25px; color:var(--deep); display:flex; align-items:center; gap:9px; letter-spacing:-.01em}
.vfn .logo svg{width:34px; height:34px}
.vfn .nav-links{display:flex; gap:4px; margin-left:6px}
.vfn .nav-links a{font-weight:600; font-size:14.5px; color:var(--muted); padding:8px 12px; border-radius:8px; transition:.18s}
.vfn .nav-links a:hover{color:var(--deep); background:var(--sage-soft)}
.vfn .nav-actions{margin-left:auto; display:flex; align-items:center; gap:10px}
.vfn .icon-btn{width:42px; height:42px; border-radius:11px; border:1px solid var(--line); background:var(--paper); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:.18s; color:var(--char)}

/* header search */
.vfn .hdr-search{display:flex; align-items:center; gap:6px; position:relative}
.vfn .hdr-search input{width:0; opacity:0; padding:0; border:1px solid var(--line); border-radius:11px; background:var(--paper); font-family:var(--sans); font-size:14px; color:var(--char); height:42px; transition:width .28s cubic-bezier(.2,.8,.2,1), opacity .2s, padding .28s; pointer-events:none; box-sizing:border-box; outline:none}
.vfn .hdr-search.open input{width:240px; opacity:1; padding:0 14px; pointer-events:auto}
.vfn .hdr-search.open input:focus{border-color:var(--terra); box-shadow:0 0 0 3px rgba(193,123,94,.12)}
.vfn .hdr-search.open .icon-btn{background:var(--sage-soft); border-color:var(--sage); color:var(--deep)}
@media(max-width:520px){.vfn .hdr-search.open input{width:160px}}
.vfn .icon-btn:hover{border-color:var(--sage); color:var(--deep)} .vfn .icon-btn svg{width:20px;height:20px}
.vfn .cart-btn{position:relative; background:var(--deep); border:none; color:#fff} .vfn .cart-btn:hover{background:var(--deep-2)}
.vfn .cart-count{position:absolute; top:-5px; right:-5px; background:var(--terra); color:#fff; font-size:11px; font-weight:700; min-width:18px; height:18px; border-radius:10px; display:flex; align-items:center; justify-content:center; padding:0 5px}
.vfn .fav-btn{position:relative}
.vfn .fav-btn .fav-count{position:absolute; top:-5px; right:-5px; background:var(--terra); color:#fff; font-size:11px; font-weight:700; min-width:18px; height:18px; border-radius:10px; align-items:center; justify-content:center; padding:0 5px}
.vfn .card-fav.on svg{color:var(--terra) !important; fill:var(--terra) !important}

/* buttons */
.vfn .btn{font-family:var(--sans); font-weight:700; font-size:15px; border-radius:10px; padding:14px 24px; border:1.5px solid transparent; cursor:pointer; transition:.18s; display:inline-flex; align-items:center; justify-content:center; gap:9px; letter-spacing:.2px}
.vfn .btn svg{width:18px;height:18px}
.vfn .btn-primary{background:var(--terra); color:#fff} .vfn .btn-primary:hover{background:#a96746; transform:translateY(-1px); box-shadow:0 10px 24px -10px rgba(193,123,94,.7)}
.vfn .btn-secondary{background:transparent; color:var(--deep); border-color:var(--sage)} .vfn .btn-secondary:hover{background:var(--sage-soft)}
.vfn .btn-sm{padding:9px 15px; font-size:13px; border-radius:8px} .vfn .btn-sm svg{width:15px;height:15px}

.vfn .badge{font-size:11px; font-weight:700; padding:4px 10px; border-radius:20px; white-space:nowrap; display:inline-flex; align-items:center; gap:4px} .vfn .badge svg{width:12px;height:12px}
.vfn .b-sage{background:var(--sage-soft); color:var(--deep)} .vfn .b-terra{background:var(--terra-soft); color:#9c5638}
.vfn .b-hit{background:#FBEFD6; color:#8a6a1e} .vfn .b-neutral{background:#EFEAE1; color:var(--muted)}

/* AI viz badge */
.vfn .viz-badge{position:absolute; left:10px; bottom:10px; z-index:3; background:rgba(255,255,255,.84); backdrop-filter:blur(4px); padding:5px 10px; border-radius:20px; font-size:10.5px; font-weight:700; color:var(--deep); display:inline-flex; align-items:center; gap:5px; max-width:calc(100% - 20px)}
.vfn .viz-badge svg{width:12px;height:12px; color:var(--terra); flex-shrink:0}
.vfn .viz-badge.lg{font-size:12px; padding:7px 13px}

/* hero */
.vfn .hero{position:relative; padding:60px 0 36px}
.vfn .hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; position:relative; z-index:2}
.vfn .eyebrow{display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--terra)}
.vfn .eyebrow::before{content:""; width:26px; height:1.5px; background:var(--terra)}
.vfn h1.hero-title{font-family:var(--serif); font-weight:500; font-size:clamp(40px,5vw,66px); line-height:1.02; letter-spacing:-.02em; margin:18px 0 16px}
.vfn h1.hero-title em{color:var(--deep); font-weight:600}
.vfn .hero-sub{font-size:18px; line-height:1.6; color:var(--muted); max-width:450px; margin-bottom:18px}
.vfn .delivery-line{display:inline-flex; align-items:center; gap:9px; background:var(--sage-soft); color:var(--deep); font-weight:600; font-size:13px; padding:9px 14px; border-radius:30px; margin-bottom:26px}
.vfn .delivery-line svg{width:16px;height:16px; color:var(--terra)}
.vfn .hero-cta{display:flex; gap:12px; flex-wrap:wrap}
.vfn .hero-stats{display:flex; gap:32px; margin-top:32px; padding-top:26px; border-top:1px solid var(--line)}
.vfn .stat strong{font-family:var(--serif); font-size:30px; font-weight:600; color:var(--deep); display:block; line-height:1}
.vfn .stat span{font-size:12.5px; color:var(--muted); margin-top:4px; display:block}

/* hero art */
.vfn .hero-art{position:relative; aspect-ratio:1/1.05; border-radius:24px; overflow:hidden; box-shadow:var(--shadow-lift)}
.vfn .hero-float{position:absolute; background:var(--paper); border-radius:16px; padding:12px 14px; box-shadow:var(--shadow-card); display:flex; align-items:center; gap:10px; z-index:4}
.vfn .hero-float svg{width:26px;height:26px; color:var(--sage)}
.vfn .hero-float .hf-t{font-family:var(--serif); font-size:16px; color:var(--deep); line-height:1}
.vfn .hero-float .hf-s{font-size:11px; color:var(--muted); margin-top:3px}
.vfn .hf-1{top:24px; right:-18px} .vfn .hf-2{bottom:74px; left:-26px}
.vfn .deco-blob{position:absolute; border-radius:50%; filter:blur(60px); z-index:1; opacity:.55}
.vfn .blob-1{width:340px; height:340px; background:var(--sage-soft); top:-80px; left:-120px}
.vfn .blob-2{width:300px; height:300px; background:var(--terra-soft); bottom:-60px; right:30%}

/* see-strip */
.vfn .see-strip{background:var(--paper); border:1px solid var(--line); border-radius:20px; padding:26px 28px; margin:8px 0 16px; box-shadow:var(--shadow-card); position:relative; z-index:2}
.vfn .see-head{display:flex; align-items:center; gap:10px; margin-bottom:20px}
.vfn .see-head svg{width:22px;height:22px; color:var(--terra)}
.vfn .see-head h3{font-family:var(--serif); font-weight:600; font-size:24px; letter-spacing:-.01em}
.vfn .see-steps{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.vfn .see-step{display:flex; gap:14px; align-items:flex-start}
.vfn .see-num{flex-shrink:0; width:34px; height:34px; border-radius:50%; background:var(--sage-soft); color:var(--deep); font-family:var(--serif); font-weight:600; font-size:17px; display:flex; align-items:center; justify-content:center}
.vfn .see-step b{display:block; font-size:14.5px; font-weight:700; margin-bottom:3px}
.vfn .see-step span{font-size:13px; color:var(--muted); line-height:1.45}
.vfn .see-step.active .see-num{background:var(--terra); color:#fff}

/* sections */
.vfn .section{padding:52px 0}
.vfn .sec-head{display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:30px; gap:20px}
.vfn .sec-head h2{font-family:var(--serif); font-weight:500; font-size:clamp(28px,3.4vw,40px); letter-spacing:-.02em; line-height:1.05}
.vfn .sec-head h2 em{color:var(--deep); font-weight:600}
.vfn .sec-note{font-size:14.5px; color:var(--muted); max-width:320px}
.vfn .link-arrow{font-weight:700; font-size:14px; color:var(--deep); display:inline-flex; align-items:center; gap:6px; white-space:nowrap}
.vfn .link-arrow svg{width:16px;height:16px; transition:.18s} .vfn .link-arrow:hover svg{transform:translateX(4px)}

/* scenario cards */
.vfn .scen-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.vfn .scen{position:relative; border-radius:18px; overflow:hidden; cursor:pointer; aspect-ratio:4/3.2; transition:.22s; box-shadow:var(--shadow-card)}
.vfn .scen:hover{transform:translateY(-4px); box-shadow:var(--shadow-lift)}
.vfn .scen .scen-img{position:absolute; inset:0}
.vfn .scen .scen-img img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s ease}
.vfn .scen:hover .scen-img img{transform:scale(1.04)}
.vfn .scen .scen-shade{position:absolute; inset:0; background:linear-gradient(to top, rgba(36,56,45,.78) 0%, rgba(36,56,45,.12) 55%, transparent 100%)}
.vfn .scen .scen-txt{position:absolute; left:18px; bottom:16px; right:18px; z-index:2; color:#fff}
.vfn .scen .scen-txt h3{font-family:var(--serif); font-size:24px; font-weight:600; margin-bottom:3px}
.vfn .scen .scen-txt p{font-size:12.5px; opacity:.85}
.vfn .scen .scen-chip{position:absolute; top:14px; left:14px; z-index:2; background:rgba(255,255,255,.85); backdrop-filter:blur(4px); border-radius:20px; padding:5px 11px; font-size:11px; font-weight:700; color:var(--deep); display:inline-flex; align-items:center; gap:5px}
.vfn .scen .scen-chip svg{width:13px;height:13px; color:var(--terra)}

/* product cards */
.vfn .cards{display:grid !important; grid-template-columns:repeat(auto-fill,minmax(238px,1fr)) !important; gap:20px !important; align-items:stretch !important}
.vfn .cards > .card{align-self:stretch !important; height:100% !important; display:flex !important; flex-direction:column !important}
.vfn .card{background:var(--paper); border:1px solid var(--line); border-radius:16px; overflow:hidden; transition:.2s}
.vfn .card:hover{transform:translateY(-4px); box-shadow:var(--shadow-lift); border-color:transparent}
.vfn .cards > .card > .card-art{flex:0 0 auto !important; display:block !important}
.vfn .card-art{position:relative; aspect-ratio:4/5; margin:10px; border-radius:12px; overflow:hidden}
.vfn .card-art .scen-img{position:absolute; inset:0}
.vfn .card-badges{position:absolute; top:10px; left:10px; display:flex; flex-direction:column; gap:5px; z-index:3; align-items:flex-start}
.vfn .card-fav{position:absolute; top:10px; right:10px; width:34px; height:34px; border-radius:50%; background:rgba(255,255,255,.85); border:none; display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:3; transition:.16s}
.vfn .card-fav svg{width:17px;height:17px; color:var(--muted)} .vfn .card-fav:hover{background:#fff} .vfn .card-fav.on svg{color:var(--terra); fill:var(--terra)}
.vfn .cards > .card > .card-body{flex:1 1 auto !important; display:flex !important; flex-direction:column !important; min-height:0}
.vfn .card-body{padding:2px 16px 16px}
.vfn .card h3{font-family:var(--serif); font-size:22px; font-weight:600; line-height:1.05; cursor:pointer; color:var(--char)}
.vfn .card .latin{font-style:italic; font-size:12.5px; color:var(--muted); margin-top:2px}
.vfn .trust-line{display:inline-flex; align-items:center; gap:5px; font-size:11.5px; font-weight:600; color:var(--sage); margin-top:8px}
.vfn .trust-line svg{width:13px;height:13px}
.vfn .care-row{display:flex; gap:2px; margin:12px 0; padding-top:12px; border-top:1px solid var(--line)}
.vfn .care-item{flex:1; display:flex; flex-direction:column; align-items:center; gap:5px}
.vfn .care-item svg{width:20px;height:20px; color:var(--sage)}
.vfn .care-item span{font-size:10px; color:var(--muted); text-align:center; line-height:1.15}
.vfn .care-row-mini{display:flex; gap:8px; flex-wrap:wrap; margin:10px 0 8px; font-size:11px; color:var(--muted)}
.vfn .ci-mini{display:inline-flex; align-items:center; gap:4px}
.vfn .ci-mini svg{width:13px; height:13px; color:var(--sage); flex-shrink:0}
.vfn .price-row{display:flex; align-items:baseline; gap:8px}

/* Глобальный тост корзины — рендерится в _vfn_layout */
.vfn-toast{position:fixed; left:50%; bottom:26px; transform:translate(-50%, 140%); z-index:300; background:var(--deep); color:#fff; padding:14px 20px; border-radius:14px; box-shadow:var(--shadow-lift); display:flex; align-items:center; gap:11px; font-size:14px; font-weight:600; max-width:90vw; opacity:0; transition:transform .35s cubic-bezier(.2,.8,.2,1), opacity .35s; pointer-events:none}
.vfn-toast svg{width:20px; height:20px; color:var(--terra); flex-shrink:0}
.vfn-toast.on{transform:translate(-50%, 0); opacity:1; pointer-events:auto}
.vfn .price{font-weight:800; font-size:20px; color:var(--deep)} .vfn .price-old{font-size:13px; color:var(--muted); text-decoration:line-through}
.vfn .price-from{font-size:12px; color:var(--muted); font-weight:600; margin-right:2px; text-transform:lowercase}
.vfn .card-cta{display:flex; gap:8px; margin-top:auto !important; padding-top:13px; align-items:stretch}
.vfn .card-cta > *{flex:1; min-width:0}
.vfn .card-cta .btn{white-space:nowrap; padding:10px 8px; font-size:13px; gap:5px; justify-content:center}
.vfn .card-cta .btn svg{width:14px; height:14px; flex-shrink:0}
.vfn .card-cta form{display:flex}
.vfn .card-cta form .btn{width:100%}

/* quiz */
.vfn .quiz-card{background:var(--paper); border-radius:22px; padding:32px; box-shadow:var(--shadow-lift); max-width:580px; margin:0 auto; position:relative; overflow:hidden}
.vfn .quiz-card::before{content:""; position:absolute; top:-40px; right:-40px; width:160px; height:160px; background:var(--sage-soft); border-radius:50%; opacity:.5}
.vfn .quiz-prog{display:flex; gap:6px; margin-bottom:20px; position:relative}
.vfn .quiz-prog i{flex:1; height:5px; border-radius:5px; background:var(--line); transition:.3s} .vfn .quiz-prog i.on{background:var(--terra)}
.vfn .quiz-step-n{font-size:12px; font-weight:700; letter-spacing:.05em; text-transform:uppercase; color:var(--terra); position:relative}
.vfn .quiz-q{font-family:var(--serif); font-size:30px; font-weight:500; margin:8px 0 22px; line-height:1.05; position:relative}
.vfn .quiz-opts{display:grid; grid-template-columns:1fr 1fr; gap:10px; position:relative}
.vfn .quiz-opt{padding:16px 14px; border-radius:13px; border:1.5px solid var(--line); background:var(--base); font-family:var(--sans); font-weight:600; font-size:15px; color:var(--char); cursor:pointer; transition:.16s; display:flex; align-items:center; gap:10px; text-align:left}
.vfn .quiz-opt svg{width:22px;height:22px; color:var(--sage); flex-shrink:0}
.vfn .quiz-opt:hover{border-color:var(--sage); background:var(--sage-soft); transform:translateY(-1px)}
.vfn .quiz-back{margin-top:16px; background:none; border:none; color:var(--muted); font-family:var(--sans); font-size:13px; cursor:pointer; position:relative}
.vfn .quiz-results{display:flex; flex-direction:column; gap:12px}
.vfn .qr-card{display:flex; gap:16px; background:var(--paper); border:1px solid var(--line); border-radius:16px; padding:14px; align-items:center}
.vfn .qr-art{width:96px; height:108px; border-radius:12px; flex-shrink:0; overflow:hidden; position:relative}
.vfn .qr-card h4{font-family:var(--serif); font-size:22px; font-weight:600; margin:0}
.vfn .qr-why{font-size:12.5px; color:var(--terra); font-weight:700; margin:5px 0 6px}
.vfn .qr-meta{font-size:13px; color:var(--muted)}
.vfn .qr-actions{display:flex; gap:8px; align-items:center; margin-top:10px}
.vfn .qr-price{font-weight:800; font-size:18px; color:var(--deep); margin-right:auto}

/* trust */
.vfn .trust{background:var(--deep); color:#fff; border-radius:24px; padding:44px; display:grid; grid-template-columns:1.1fr 1fr; gap:36px; align-items:center; position:relative; overflow:hidden}
.vfn .trust .leaf-watermark{position:absolute; right:-40px; bottom:-60px; width:320px; opacity:.08}
.vfn .trust h2{font-family:var(--serif); font-weight:500; font-size:clamp(28px,3.4vw,42px); line-height:1.05; margin-bottom:14px}
.vfn .trust p{font-size:15.5px; line-height:1.6; opacity:.82; margin-bottom:14px; max-width:430px}
.vfn .trust .deliv-mc{display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600; opacity:.95; background:rgba(255,255,255,.1); padding:8px 13px; border-radius:24px; margin-bottom:22px}
.vfn .trust .deliv-mc svg{width:15px;height:15px}
.vfn .trust-steps{display:flex; gap:14px}
.vfn .tstep{flex:1; background:rgba(255,255,255,.07); border-radius:14px; padding:18px}
.vfn .tstep svg{width:26px;height:26px; color:#fff; opacity:.9; margin-bottom:10px}
.vfn .tstep b{font-family:var(--serif); font-size:17px; font-weight:600; display:block; margin-bottom:4px}
.vfn .tstep span{font-size:12.5px; opacity:.7; line-height:1.4}

/* guarantee + faq */
.vfn .guarantee{text-align:center; background:var(--sage-soft); border-radius:24px; padding:48px; position:relative; overflow:hidden}
.vfn .guarantee .shield{width:52px; height:52px; color:var(--deep); margin:0 auto 14px}
.vfn .guarantee h2{font-family:var(--serif); font-weight:600; font-size:38px; color:var(--deep); margin-bottom:10px}
.vfn .guarantee p{font-size:15.5px; color:var(--char); max-width:560px; margin:0 auto; line-height:1.6}
.vfn .faq{max-width:760px}
.vfn .faq-item{border-bottom:1px solid var(--line)}
.vfn .faq-q{width:100%; background:none; border:none; padding:20px 4px; display:flex; justify-content:space-between; align-items:center; gap:16px; cursor:pointer; font-family:var(--sans); font-weight:700; font-size:16px; color:var(--char); text-align:left}
.vfn .faq-q .pm{flex-shrink:0; width:24px; height:24px; border-radius:50%; border:1.5px solid var(--sage); display:flex; align-items:center; justify-content:center; color:var(--sage); transition:.2s} .vfn .faq-q .pm svg{width:13px;height:13px}
.vfn .faq-item.open .pm{background:var(--sage); color:#fff; transform:rotate(180deg)}
.vfn .faq-a{max-height:0; overflow:hidden; transition:max-height .3s ease; font-size:14.5px; color:var(--muted); line-height:1.65}
.vfn .faq-item.open .faq-a{max-height:200px; padding:0 4px 20px}

.vfn footer.site{background:var(--deep-2); color:#fff; margin-top:64px; padding:48px 0 32px}
.vfn .foot-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:32px; padding-bottom:32px; border-bottom:1px solid rgba(255,255,255,.12)}
.vfn .foot-grid h4{font-family:var(--serif); font-size:18px; margin-bottom:14px}
.vfn .foot-col a{display:block; font-size:13.5px; opacity:.7; padding:5px 0; transition:.16s} .vfn .foot-col a:hover{opacity:1; padding-left:4px}
.vfn .foot-bottom{padding-top:24px; display:flex; justify-content:space-between; font-size:12.5px; opacity:.6; flex-wrap:wrap; gap:12px}

.vfn .reveal{opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1)} .vfn .reveal.in{opacity:1; transform:none}
.vfn .mobile-bar{display:none}

@media(max-width:860px){
  .vfn .hero-grid{grid-template-columns:1fr; gap:32px} .vfn .hero-art{max-width:420px; margin:0 auto; width:100%}
  .vfn .hf-1,.vfn .hf-2{display:none}
  .vfn .see-steps{grid-template-columns:1fr; gap:14px}
  .vfn .trust{grid-template-columns:1fr; padding:32px}
  .vfn .scen-grid{grid-template-columns:1fr 1fr} .vfn .nav-links{display:none}
  .vfn .foot-grid{grid-template-columns:1fr 1fr}
  .vfn-body{padding-bottom:64px}
  .vfn .mobile-bar{display:flex; position:fixed; bottom:0; left:0; right:0; z-index:200; background:var(--paper); border-top:1px solid var(--line); padding:7px 0 9px}
  .vfn .mb-item{flex:1; background:none; border:none; cursor:pointer; display:flex; flex-direction:column; align-items:center; gap:3px; color:var(--muted)}
  .vfn .mb-item svg{width:21px;height:21px} .vfn .mb-item span{font-size:10px; font-weight:600} .vfn .mb-item.on{color:var(--deep)}
}
@media(max-width:520px){ .vfn .scen-grid{grid-template-columns:1fr} .vfn .quiz-opts{grid-template-columns:1fr} .vfn .hero-stats{gap:20px} }

/* === SOURCE OVERLAY (debug, активируется через ?src=1) === */
.vfn-show-src [data-src]{position:relative}
.vfn-show-src [data-src]::before{content:attr(data-src);position:absolute;top:-12px;left:8px;font-size:10px;font-weight:700;text-transform:uppercase;background:#fff;border:1.5px solid;padding:1px 7px;border-radius:8px;line-height:1.4;letter-spacing:.04em;z-index:50;white-space:nowrap;pointer-events:none}
.vfn-show-src [data-src^="AI"]{outline:1px dashed #C17B5E;outline-offset:3px;border-radius:4px}
.vfn-show-src [data-src^="AI"]::before{color:#C17B5E;border-color:#C17B5E}
.vfn-show-src [data-src^="IMG"]{outline:2px dashed #C17B5E;outline-offset:3px}
.vfn-show-src [data-src^="IMG"]::before{color:#C17B5E;border-color:#C17B5E;background:#FCE9DD}
.vfn-show-src [data-src^="STATIC"]{outline:1px dashed #8A9A7B;outline-offset:3px;border-radius:4px}
.vfn-show-src [data-src^="STATIC"]::before{color:#5B7A5C;border-color:#8A9A7B;background:#EFF3EB}
.vfn-show-src [data-src^="WA+JS"]{outline:1px dashed #7d4ab3;outline-offset:3px;border-radius:4px}
.vfn-show-src [data-src^="WA+JS"]::before{color:#7d4ab3;border-color:#7d4ab3;background:#F1ECF7}
.vfn-show-src [data-src^="WA"]:not([data-src^="WA+JS"]){outline:1px dashed #5b7aab;outline-offset:3px;border-radius:4px}
.vfn-show-src [data-src^="WA"]:not([data-src^="WA+JS"])::before{color:#5b7aab;border-color:#5b7aab;background:#EAF0F8}
.vfn-src-legend{position:fixed;bottom:18px;right:18px;z-index:9999;background:#fff;border:1px solid #e6e0d6;border-radius:14px;padding:14px 16px;box-shadow:0 8px 28px rgba(46,74,59,.22);font-size:12px;font-family:Manrope,sans-serif;line-height:1.45;max-width:260px}
.vfn-src-legend h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#7A756C;margin-bottom:8px}
.vfn-src-legend .row{display:flex;align-items:center;gap:8px;margin:4px 0}
.vfn-src-legend .ch{width:12px;height:12px;border-radius:3px;flex-shrink:0}
.vfn-src-legend .ai{background:#C17B5E}
.vfn-src-legend .img{background:#C17B5E;outline:2px dashed #C17B5E;outline-offset:1px}
.vfn-src-legend .static{background:#8A9A7B}
.vfn-src-legend .wa{background:#5b7aab}
.vfn-src-legend .js{background:#7d4ab3}
.vfn-src-legend a{display:block;margin-top:10px;color:#9c5638;font-weight:700;font-size:11px;text-decoration:none}
.vfn-src-legend a:hover{text-decoration:underline}


/* ============================================================
   CHECKOUT (onestep plugin) — clean v3 (фикс развалившегося layout)
   ============================================================ */

/* основной контейнер — flex column, никаких grid тут */
.vfn .checkout{max-width:1240px;margin:30px auto;padding:0 24px;display:flex;flex-direction:column;gap:16px;box-sizing:border-box}

/* форма прозрачная — дети flow в .checkout */
.vfn .checkout-form{display:contents}

/* верхний блок auth selector — на всю ширину */
.vfn .checkout-step-content.auth{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:18px 22px}
.vfn .checkout-step-content.auth .menu-v{display:flex;gap:0;background:var(--sage-soft);padding:4px;border-radius:11px;width:fit-content;list-style:none;margin:0}
.vfn .checkout-step-content.auth .menu-v li{margin:0}
.vfn .checkout-step-content.auth .menu-v label{background:transparent;border:none;padding:8px 16px;border-radius:8px;font-weight:600;font-size:13.5px;color:var(--char);cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.vfn .checkout-step-content.auth .menu-v label:has(input:checked){background:var(--paper);color:var(--deep);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.vfn .checkout-step-content.auth .menu-v input[type=radio]{display:none}
.vfn .checkout-step-content.auth blockquote{background:var(--sage-soft);border-left:3px solid var(--sage);padding:14px 18px;border-radius:10px;margin:14px 0 0;font-size:13.5px;color:var(--char);display:flex;gap:12px;align-items:flex-start}
.vfn .checkout-step-content.auth blockquote img{border-radius:50%;flex-shrink:0;width:42px;height:42px}
.vfn .checkout-step-content.auth blockquote p{margin:0}
.vfn .checkout-step-content.auth blockquote .black{color:var(--deep);font-weight:600;display:inline}
.vfn .checkout-step-content.auth blockquote em{color:var(--muted);font-style:italic;display:block;margin-top:4px;font-size:12.5px}

/* контейнер с шагами 1-3 (main) и шагом 4 (sidebar) — 2 колонки */
.vfn .checkout-container{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.vfn .checkout.sticky .checkout-sidebar{position:sticky;top:90px}
.vfn .checkout-main{display:flex;flex-direction:column;gap:16px;min-width:0}
.vfn .checkout-sidebar{display:flex;flex-direction:column;gap:16px;min-width:0}

/* карточка шага */
.vfn .checkout-step{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:24px 26px;position:relative}
.vfn .checkout-step h2{font-family:var(--serif);font-weight:500;font-size:24px;color:var(--char);letter-spacing:-.01em;margin:0 0 18px;display:flex;align-items:center;gap:12px}
.vfn .checkout-step h2.upcoming{opacity:.45}
.vfn .checkout-step h2 .gray{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--terra);background:var(--terra-soft);border-radius:50%;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}
.vfn .checkout-step h2 .loading{display:none}
.vfn .checkout-step h3{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--char);margin:14px 0 8px}
.vfn .checkout-step-content{font-size:14px;color:var(--char);line-height:1.55}

/* === wa-form (контактная информация) — V5: вертикальный stacking === */
.vfn .checkout .wa-form{display:flex;flex-direction:column;gap:16px;max-width:560px}
.vfn .checkout .wa-field{display:flex;flex-direction:column;gap:6px;margin:0}
.vfn .checkout .wa-field .wa-name{font-weight:600;font-size:13px;color:var(--muted);padding:0;margin:0;text-transform:none;letter-spacing:0}
.vfn .checkout .wa-field .wa-name .wa-required-mark{color:var(--terra);margin-left:2px}
.vfn .checkout .wa-field .wa-value{margin:0}
.vfn .checkout .wa-field .wa-value > input[type=text],
.vfn .checkout .wa-field .wa-value > input[type=email],
.vfn .checkout .wa-field .wa-value > input[type=tel],
.vfn .checkout .wa-field .wa-value > input[type=password],
.vfn .checkout .wa-field .wa-value > select,
.vfn .checkout .wa-field .wa-value > textarea{width:100%;font-family:var(--sans);font-size:14.5px;color:var(--char);background:var(--paper);border:1.5px solid var(--line);border-radius:11px;padding:11px 14px;box-sizing:border-box;transition:.14s}
.vfn .checkout .wa-field input:focus,.vfn .checkout .wa-field select:focus,.vfn .checkout .wa-field textarea:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(193,123,94,.12)}
.vfn .checkout .wa-field .wa-value > p{margin:6px 0 0;font-size:12px;color:var(--muted)}
.vfn .checkout .wa-field-address .wa-value > p{margin-bottom:4px}
.vfn .checkout .wa-field-address input{margin-top:4px}
.vfn .checkout .wa-field-error{color:#9c5638;font-size:12.5px;margin-top:5px}

/* policy + checkbox */
.vfn .checkout .wa-captcha{margin:6px 0}
.vfn .checkout .wa-field-checkbox label,.vfn .checkout .wa-field-checkbox{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--char);line-height:1.45}
.vfn .checkout input[type=checkbox],.vfn .checkout input[type=radio]{accent-color:var(--terra);width:16px;height:16px;margin:2px 0 0;cursor:pointer}

/* shipping/payment opcards === */
.vfn .checkout-options{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.vfn .checkout-options li{background:var(--base);border:1.5px solid var(--line);border-radius:14px;padding:14px 18px;cursor:pointer;transition:.14s;display:flex;gap:14px;align-items:flex-start;position:relative}
.vfn .checkout-options li:hover{border-color:var(--sage)}
.vfn .checkout-options li.selected,.vfn .checkout-options li:has(input[type=radio]:checked){border-color:var(--terra);background:var(--terra-soft)}
.vfn .checkout-options li input[type=radio]{margin-top:3px;flex-shrink:0}
.vfn .checkout-options li img{max-width:50px;max-height:30px;object-fit:contain;flex-shrink:0;margin-top:1px}
.vfn .checkout-options li > div,.vfn .checkout-options li label{flex:1;min-width:0}
.vfn .checkout-options strong,.vfn .checkout-options b{font-family:var(--serif);font-weight:600;font-size:15px;color:var(--char);display:block;margin:0 0 3px;line-height:1.2}
.vfn .checkout-options small,.vfn .checkout-options p{font-size:12.5px;color:var(--muted);line-height:1.4;margin:2px 0 0}
.vfn .checkout-options .price{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--deep);margin-left:auto;flex-shrink:0;text-align:right;padding-left:12px}

/* === confirmation block (sidebar) === */
.vfn .checkout-step.step-confirmation{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:22px 22px 24px}
.vfn .checkout-step.step-confirmation h3{font-family:var(--serif);font-weight:600;font-size:15px;color:var(--char);margin:14px 0 6px}
.vfn .checkout-step.step-confirmation p{font-size:13px;color:var(--muted);line-height:1.5;margin:0 0 12px}
.vfn .checkout-step.step-confirmation table{width:100%;border-collapse:collapse;margin:10px 0}
.vfn .checkout-step.step-confirmation table th{background:transparent;color:var(--muted);padding:6px 8px;border-bottom:1px solid var(--line);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;text-align:left}
.vfn .checkout-step.step-confirmation table th:last-child{text-align:right}
.vfn .checkout-step.step-confirmation table td{padding:9px 8px;border-bottom:1px solid var(--line);font-size:13px;color:var(--char);vertical-align:middle}
.vfn .checkout-step.step-confirmation table td:last-child{text-align:right;font-weight:600;color:var(--deep);white-space:nowrap}
.vfn .checkout-step.step-confirmation .quantity input[type=text]{width:54px;padding:5px 6px;font-size:12.5px;text-align:center;border:1px solid var(--line);border-radius:6px}
.vfn .checkout-step.step-confirmation .total td:last-child,
.vfn .checkout-step.step-confirmation .grand-total td:last-child{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--deep)}
.vfn .checkout-step.step-confirmation .grand-total td{border-bottom:none;padding-top:14px}

/* комментарий textarea */
.vfn .checkout textarea{width:100%;font-family:var(--sans);font-size:14px;color:var(--char);background:var(--paper);border:1.5px solid var(--line);border-radius:11px;padding:11px 14px;min-height:80px;resize:vertical;box-sizing:border-box}
.vfn .checkout textarea:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(193,123,94,.12)}

/* buttons */
.vfn .checkout .button,.vfn .checkout input[type=submit],.vfn .checkout button[type=submit]{background:var(--terra);color:#fff;border:none;font-family:var(--sans);font-weight:700;font-size:15px;padding:13px 24px;border-radius:11px;cursor:pointer;transition:.14s;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.vfn .checkout .button:hover,.vfn .checkout input[type=submit]:hover,.vfn .checkout button[type=submit]:hover{background:#a96746}
.vfn .checkout .checkout-submit{margin-top:16px;width:100%;padding:15px}

/* errors */
.vfn .checkout .errormsg,.vfn .checkout .error{color:#9c5638;font-size:13px;font-weight:600;margin-top:4px}

/* links */
.vfn .checkout a{color:var(--terra);text-decoration:underline;text-decoration-color:rgba(193,123,94,.3);text-underline-offset:3px}
.vfn .checkout a:hover{text-decoration-color:var(--terra)}

/* пустые <p><br></p> которые ломают ритм — скрыть */
.vfn .checkout p:empty{display:none}
.vfn .checkout .clear-both{clear:both;height:0;line-height:0;font-size:0;display:none}

/* мобилка */
@media(max-width:880px){
  .vfn .checkout{padding:0 14px}
  .vfn .checkout-container{grid-template-columns:1fr;gap:16px}
  .vfn .checkout.sticky .checkout-sidebar{position:static}
}

/* === CHECKOUT V4 — точечные фиксы под скрин user === */

/* H2 не должен переноситься: убираем flex, badge inline-block */
.vfn .checkout-step h2{display:block !important;line-height:1.15;white-space:normal;font-size:22px}
.vfn .checkout-step h2 .gray{display:inline-flex !important;vertical-align:middle;margin-right:10px;width:30px;height:30px;font-size:16px}
.vfn .checkout-step h2 .loading{display:none}

/* ============================================================
   CHECKOUT V5 — fix распухающегося layout (cart + checkout)
   ============================================================ */

/* верхний враппер всего onestep — центрируем и ограничиваем */
.vfn .onestep-cart{max-width:1240px; margin:0 auto; padding:24px 24px 60px; display:flex; flex-direction:column; gap:24px; box-sizing:border-box}
.vfn .onestep-cart > .clear-both{display:none}

/* карточка с товарами корзины */
.vfn .onestep-cart-form{background:var(--paper); border:1px solid var(--line); border-radius:18px; padding:18px 22px; margin:0}
.vfn .onestep-cart-form > .buy1click-open-button{display:none !important}

/* таблица товаров в корзине */
.vfn .onestep-cart .table.cart{width:100%; border-collapse:collapse}
.vfn .onestep-cart .table.cart tbody{border:none}
.vfn .onestep-cart .table.cart td{padding:14px 10px; border-bottom:1px solid var(--line); vertical-align:middle; font-size:14px; color:var(--char)}
.vfn .onestep-cart .table.cart tr:last-child td,
.vfn .onestep-cart .table.cart tr.large td,
.vfn .onestep-cart .table.cart tr.no-border td{border-bottom:none}
.vfn .onestep-cart .table.cart td.min-width{width:64px}
.vfn .onestep-cart .table.cart td.min-width img{width:64px; height:64px; object-fit:cover; border-radius:10px; display:block; max-width:none}
.vfn .onestep-cart .table.cart .bold{font-weight:600; color:var(--deep); font-family:var(--serif); font-size:15.5px; line-height:1.25; text-decoration:none}
.vfn .onestep-cart .table.cart .bold:hover{color:var(--terra); text-decoration:underline}
.vfn .onestep-cart .table.cart td.align-center{text-align:center}
.vfn .onestep-cart .table.cart .item-total{font-weight:700; color:var(--deep); font-size:15px; white-space:nowrap}

/* qty stepper */
.vfn .onestep-cart .table.cart .choice{display:inline-flex; align-items:center; border:1.5px solid var(--line); border-radius:10px; overflow:hidden; height:36px; background:var(--paper)}
.vfn .onestep-cart .table.cart .choice .plus,
.vfn .onestep-cart .table.cart .choice .minus{width:34px; height:34px; display:inline-flex; align-items:center; justify-content:center; cursor:pointer; color:var(--char); font-weight:700; font-size:18px; user-select:none; background:transparent}
.vfn .onestep-cart .table.cart .choice .plus:hover,
.vfn .onestep-cart .table.cart .choice .minus:hover{background:var(--sage-soft); color:var(--deep)}
.vfn .onestep-cart .table.cart .choice .qty{width:44px; height:34px; text-align:center; border:none; outline:none; font-family:var(--sans); font-weight:600; font-size:14px; background:transparent; color:var(--char)}

/* services (открытка, упаковка) */
.vfn .onestep-cart .table.cart .services{margin-top:6px; display:flex; flex-direction:column; gap:6px; font-size:13px}
.vfn .onestep-cart .table.cart .services > div{display:flex; align-items:center; gap:8px; flex-wrap:wrap}
.vfn .onestep-cart .table.cart .services label{display:inline-flex; align-items:center; gap:6px; color:var(--muted); cursor:pointer}
.vfn .onestep-cart .table.cart .services label:has(input:checked){color:var(--char); font-weight:600}
.vfn .onestep-cart .table.cart .services select{font-family:var(--sans); font-size:12.5px; padding:5px 8px; border:1px solid var(--line); border-radius:7px; background:var(--paper); color:var(--char)}
.vfn .onestep-cart .table.cart .services select:disabled{opacity:.55}

/* delete (×) */
.vfn .onestep-cart .table.cart a.delete{display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; color:var(--muted); text-decoration:none; transition:.14s}
.vfn .onestep-cart .table.cart a.delete:hover{background:var(--terra-soft); color:#9c5638}
.vfn .onestep-cart .table.cart a.delete i.icon16.remove{display:inline-block; width:14px; height:14px; background:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 6l12 12M6 18L18 6'/%3E%3C/svg%3E") center/contain no-repeat}

/* coupon row */
.vfn .onestep-cart .table.cart tr.no-border td{font-size:13px; color:var(--muted)}
.vfn .onestep-cart .table.cart tr.no-border input[type=text]{font-family:var(--sans); font-size:13px; padding:7px 10px; border:1.5px solid var(--line); border-radius:8px; background:var(--paper); margin-left:6px; width:140px}
.vfn .onestep-cart .table.cart tr.no-border input[type=submit]{background:var(--sage); color:#fff; border:none; padding:7px 12px; border-radius:8px; font-weight:600; font-size:12.5px; cursor:pointer; margin-left:6px}
.vfn .onestep-cart .table.cart tr.no-border input[type=submit]:hover{background:var(--deep)}
.vfn .onestep-cart .table.cart tr.no-border td.align-right{text-align:right; color:var(--char); font-weight:600}

/* totals row */
.vfn .onestep-cart .table.cart tr.large td{padding-top:18px; font-size:14px}
.vfn .onestep-cart .table.cart tr.large td.cart-total{font-family:var(--serif); font-weight:600; font-size:22px; color:var(--deep)}
.vfn .onestep-cart .table.cart tr.large td.align-right{color:var(--muted); font-size:13px; text-transform:uppercase; letter-spacing:.04em; font-weight:700}

/* checkout block теперь сидит внутри centered onestep-cart, не нужен повторный max-width */
.vfn .onestep-cart > .checkout{max-width:none !important; margin:0 !important; padding:0 !important}

/* sidebar шире — чтобы названия товаров не ломались по буквам */
.vfn .checkout-container{grid-template-columns:1fr 400px !important}
.vfn .checkout-sidebar{min-width:0}

/* confirmation table — нормальный word-wrap (не break-all char-by-char) */
.vfn .checkout-step.step-confirmation table td{word-break:normal; overflow-wrap:break-word; hyphens:none}
.vfn .checkout-step.step-confirmation table td:first-child{word-wrap:break-word; line-height:1.35}

/* checkout-submit button row */
.vfn .checkout .float-right{display:flex; justify-content:stretch; margin-top:18px}
.vfn .checkout .float-right input[type=submit]{width:100%; padding:15px 24px; font-size:16px}

/* комментарий-textarea — отступ */
.vfn .checkout-step.step-confirmation textarea.comment{margin-top:8px}

/* мобилка */
@media(max-width:880px){
  .vfn .onestep-cart{padding:14px 14px 40px; gap:16px}
  .vfn .onestep-cart-form{padding:12px 14px}
  .vfn .onestep-cart .table.cart td{padding:10px 6px; font-size:13px}
  .vfn .onestep-cart .table.cart td.min-width{width:56px}
  .vfn .onestep-cart .table.cart td.min-width img{width:56px; height:56px}
  .vfn .checkout-container{grid-template-columns:1fr !important; gap:16px}
}

/* ============================================================
   CHECKOUT V6 — финальная полировка
   ============================================================ */

/* H2 заголовки шагов — не разрываем «КОНТАКТНАЯ ИНФОРМАЦИЯ» на 2 строки */
.vfn .checkout-step h2{font-size:18px !important; line-height:1.25; text-transform:none; letter-spacing:-.01em}
.vfn .checkout-step h2 .gray{width:26px; height:26px; font-size:14px; margin-right:8px}

/* sidebar — увеличиваем до 420px и компактим внутренний padding */
.vfn .checkout-container{grid-template-columns:1fr 420px !important; gap:28px}
.vfn .checkout-step.step-confirmation{padding:18px 18px 20px}
.vfn .checkout-step.step-confirmation table th{font-size:9.5px; padding:5px 6px}
.vfn .checkout-step.step-confirmation table td{padding:8px 6px; font-size:12.5px; line-height:1.3}
.vfn .checkout-step.step-confirmation table td:first-child{padding-right:8px}
.vfn .checkout-step.step-confirmation .grand-total td:last-child{font-size:18px}

/* поле "Получатель" блока — пустой <p><br></p> убрать */
.vfn .checkout-step.step-confirmation h3 + p{margin-bottom:8px; font-size:12px}

/* инпуты в форме — comfortable max-width 100% но visible padding */
.vfn .checkout .wa-field .wa-value > input[type=text],
.vfn .checkout .wa-field .wa-value > input[type=email],
.vfn .checkout .wa-field .wa-value > input[type=tel],
.vfn .checkout .wa-field .wa-value > input[type=password]{padding:12px 14px; height:auto}

/* поле адреса — span с placeholder-эффектом убрать (mislabeling) */
.vfn .checkout .wa-field-address-street{position:relative; display:block}
.vfn .checkout .wa-field-address-street > span{position:absolute; left:14px; top:-9px; font-size:11.5px; font-weight:600; background:var(--paper); padding:0 6px; color:var(--muted); pointer-events:none}
.vfn .checkout .wa-field-address-street > input{margin-top:0 !important}

/* политика и чекбокс-регистрации — на всю ширину, нормальный wrap */
.vfn .checkout .wa-form > .wa-field:not(.wa-field-name):not(.wa-field-phone):not(.wa-field-email):not(.wa-field-address) > .wa-value{max-width:none; width:100%}
.vfn .checkout .wa-form > .wa-field > .wa-value > label{display:block; font-size:12.5px; color:var(--muted); line-height:1.5; word-spacing:normal; white-space:normal; max-width:560px}
.vfn .checkout .wa-form > .wa-field > .wa-value > label > input[type=checkbox]{margin-right:8px; vertical-align:middle}
.vfn .checkout .wa-form > .wa-field > .wa-value > label a{color:var(--terra)}

/* «Я новый покупатель» — компактнее */
.vfn .checkout-step-content.auth{padding:14px 18px}
.vfn .checkout-step-content.auth .menu-v label{font-size:13px; padding:7px 13px}

/* ============================================================
   CHECKOUT V7 — ПЕРЕБИВАЕМ tmp0.onestep.css плагина
   (плагин грузит свой CSS позже нашего → нужна выше специфичность)
   ============================================================ */

/* Шаг — карточка вместо плоского фона #eee */
.vfn .onestep-cart .checkout .checkout-step{background:var(--paper) !important; border:1px solid var(--line) !important; border-radius:18px !important; padding:0 !important; overflow:hidden}

/* H2 шага — белый/paper, не серый #eee, не uppercase */
.vfn .onestep-cart .checkout .checkout-step h2{background:transparent !important; text-transform:none !important; font-family:var(--serif) !important; font-weight:600 !important; font-size:17px !important; padding:18px 22px 8px !important; color:var(--char) !important; line-height:1.25; letter-spacing:-.005em; display:block !important; margin:0}
.vfn .onestep-cart .checkout .checkout-step h2 .gray{background:var(--terra-soft); color:var(--terra); font-family:var(--serif); font-weight:700; width:26px; height:26px; border-radius:50%; display:inline-flex !important; align-items:center; justify-content:center; font-size:13px; margin-right:8px; vertical-align:middle; float:none !important}

/* checkout-step-content — paper, не белый, с padding 22px */
.vfn .onestep-cart .checkout .checkout-step-content{background:transparent !important; padding:6px 22px 22px !important}
.vfn .onestep-cart .checkout .checkout-step-content.auth{background:var(--paper) !important; border:1px solid var(--line); border-radius:18px; padding:14px 18px !important}

/* wa-form — flex column, не float */
.vfn .onestep-cart .wa-form,
.vfn .onestep-cart .checkout .wa-form{display:flex !important; flex-direction:column !important; gap:14px !important; float:none !important; clear:both !important; margin:0 !important; max-width:560px; overflow:visible}

/* wa-field — flex column (label сверху, input снизу) */
.vfn .onestep-cart .checkout .wa-form .wa-field{display:flex !important; flex-direction:column !important; gap:5px !important; clear:none !important; float:none !important; padding:0 !important; margin:0 !important}

/* wa-name — НЕ float, нормальный label */
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-name{float:none !important; width:auto !important; padding:0 !important; font-size:12.5px !important; font-weight:600 !important; color:var(--muted) !important; margin:0; line-height:1.2}

/* wa-value — НЕ margin-left:180px */
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value{margin:0 !important; padding:0 !important; position:static}
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value p{margin:0 !important; line-height:1; min-height:auto; padding:0}

/* inputs — нормальная ширина, не 30% min-width 260px */
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value input[type=text],
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value input[type=email],
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value input[type=tel],
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value input[type=password]{width:100% !important; min-width:0 !important; max-width:520px !important; margin:0 !important; padding:11px 14px !important; box-sizing:border-box; border:1.5px solid var(--line); border-radius:11px; font-family:var(--sans); font-size:14.5px; background:var(--paper); color:var(--char); height:auto; transition:.14s}
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value input:focus{outline:none; border-color:var(--terra); box-shadow:0 0 0 3px rgba(193,123,94,.12)}

/* policy/checkbox-label — НЕ display:block внутри p */
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value > label{display:block; font-size:12.5px; color:var(--muted); line-height:1.5; max-width:560px; padding:6px 0}
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value > label > input[type=checkbox]{margin-right:8px; vertical-align:middle}
.vfn .onestep-cart .checkout .wa-form .wa-field .wa-value > label a{color:var(--terra); text-decoration:underline}

/* address-street: убираем дубль-лейбл (есть wa-name "Адрес" сверху) */
.vfn .onestep-cart .checkout .wa-form .wa-field-address-street{position:relative; display:block}
.vfn .onestep-cart .checkout .wa-form .wa-field-address-street > span{display:none !important}

/* убрать пустые <p><br></p> */
.vfn .onestep-cart .checkout p:empty{display:none}
.vfn .onestep-cart .checkout h3 + p > br:only-child{display:none}
.vfn .onestep-cart .checkout .float-right{float:none !important; display:flex; margin-top:14px}
.vfn .onestep-cart .checkout .float-right input[type=submit]{width:100%; background:var(--terra) !important; color:#fff !important; border:none; padding:15px 24px; border-radius:12px; font-family:var(--sans); font-weight:700; font-size:16px; cursor:pointer; transition:.14s}
.vfn .onestep-cart .checkout .float-right input[type=submit]:hover{background:#a96746 !important}

/* === Cart table (плагин: padding 20px 7px 25px, vertical-align:top) === */
.vfn .onestep-cart table.cart td{vertical-align:middle !important; padding:14px 10px !important; border-bottom:1px solid var(--line); font-size:14px; color:var(--char)}
.vfn .onestep-cart table.cart tr.large td,
.vfn .onestep-cart table.cart tr.no-border td,
.vfn .onestep-cart table.cart tr:last-child td{border-bottom:none !important}
.vfn .onestep-cart table.cart td.min-width{width:64px}
.vfn .onestep-cart table.cart td.min-width img{width:64px !important; height:64px !important; max-width:none; object-fit:cover; border-radius:10px; display:block}
.vfn .onestep-cart table.cart td input.qty{max-width:44px !important; width:44px; text-align:center !important; padding:5px}

/* «1.2em» итог большим — переопределяем под наш стиль */
.vfn .onestep-cart .checkout .checkout-step input.large{font-size:16px !important}

/* === Confirmation sidebar table === */
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table th{padding:6px 8px; font-size:9.5px; text-transform:uppercase; letter-spacing:.04em; color:var(--muted); font-weight:700; border-bottom:1px solid var(--line); background:transparent; text-align:left}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table th:last-child{text-align:right}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table td{padding:9px 6px !important; vertical-align:middle !important; font-size:12.5px; word-break:normal; overflow-wrap:break-word; hyphens:none; line-height:1.35}

/* убираем поле "padding: 17px 20px 15px" у h2 совсем */
.vfn .onestep-cart .checkout .checkout-step.step-confirmation h2{padding:18px 18px 8px !important}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation .checkout-step-content{padding:6px 18px 18px !important}

/* ============================================================
   CHECKOUT V8 — финал: shipping/payment options + sidebar overflow
   ============================================================ */

/* === Shipping/Payment options — плагин использует float:right на .rate === */
.vfn .onestep-cart .checkout ul.checkout-options{padding-left:0 !important; list-style:none; margin:0; display:flex; flex-direction:column; gap:10px}
.vfn .onestep-cart .checkout ul.checkout-options li{position:relative; margin:0 !important; padding:14px 18px 14px 44px !important; clear:none !important; width:auto !important; min-width:0; background:var(--base); border:1.5px solid var(--line); border-radius:14px; cursor:pointer; transition:.14s; list-style:none; user-select:none}
.vfn .onestep-cart .checkout ul.checkout-options li:hover{border-color:var(--sage)}
.vfn .onestep-cart .checkout ul.checkout-options li:has(input[type=radio]:checked){border-color:var(--terra); background:var(--terra-soft)}

/* Radio — крупная, видимая, слева */
.vfn .onestep-cart .checkout ul.checkout-options li input[type=radio]{position:absolute !important; top:18px !important; left:16px !important; width:18px !important; height:18px !important; margin:0 !important; accent-color:var(--terra); cursor:pointer}

/* .rate (цена) — НЕ float, ставим в правую часть через flex/grid */
.vfn .onestep-cart .checkout ul.checkout-options li .rate{float:none !important; position:absolute !important; top:16px !important; right:18px !important; width:auto !important; min-width:0 !important; max-width:none !important; text-align:right !important; padding:0 !important}
.vfn .onestep-cart .checkout ul.checkout-options li .rate .price{font-family:var(--serif) !important; font-weight:700 !important; font-size:17px !important; color:var(--deep) !important; display:block; line-height:1}
.vfn .onestep-cart .checkout ul.checkout-options li .rate .hint{display:none !important}
.vfn .onestep-cart .checkout ul.checkout-options li .rate em.hint{display:none !important}

/* h3 (название) — нормальный текст, не bold */
.vfn .onestep-cart .checkout ul.checkout-options li h3{font-family:var(--serif) !important; font-weight:600 !important; font-size:15px !important; color:var(--char) !important; margin:0 !important; padding-right:80px; line-height:1.3; min-height:24px}
.vfn .onestep-cart .checkout ul.checkout-options li h3 label{font-weight:inherit; cursor:pointer; display:block; margin:0 !important; padding:0 !important; color:var(--char)}
.vfn .onestep-cart .checkout ul.checkout-options li h3 label input[type=radio]{position:absolute !important; top:18px !important; left:16px !important}

/* p (комментарий под опцией доставки) — нормальная ширина */
.vfn .onestep-cart .checkout ul.checkout-options li p{width:auto !important; max-width:100%; padding-right:80px; margin:6px 0 0 !important; font-size:12.5px; color:var(--muted); line-height:1.45}

/* method-logo (иконка оплаты) — НЕ float, inline-flex inside h3 */
.vfn .onestep-cart .checkout ul.checkout-options li img.method-logo{float:none !important; position:static !important; max-width:50px !important; max-height:28px; object-fit:contain; margin:0 8px 0 0 !important; top:0 !important; vertical-align:middle; display:inline-block}

/* Самовывоз: внутри li есть .wa-form.wa-address (адрес доставки) — он не нужен */
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form.wa-address{display:none !important}

/* Любые wa-form внутри option-li показываем ТОЛЬКО когда radio этой опции выбран */
.vfn .onestep-cart .checkout ul.checkout-options li:not(:has(input[type=radio]:checked)) .wa-form{display:none !important}
.vfn .onestep-cart .checkout ul.checkout-options li:has(input[type=radio]:checked) .wa-form:not(.wa-address){display:flex !important; flex-direction:column !important; gap:10px !important; margin-top:14px !important}

/* ИНН/Компания форма для счёта — НУКЛЕАРНОЕ ПЕРЕБИВАНИЕ */
.vfn .onestep-cart .checkout ul.checkout-options li > .wa-form,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form{margin:12px 0 0 !important; padding:0 !important; float:none !important; clear:both !important; width:100% !important; max-width:100% !important; overflow:visible !important; position:static !important; transform:none !important; right:auto !important; left:auto !important; top:auto !important; box-sizing:border-box}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form > .wa-field,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field{display:flex !important; flex-direction:column !important; gap:4px !important; clear:none !important; float:none !important; padding:0 !important; margin:0 0 10px !important; position:static !important; right:auto !important; left:auto !important; width:100% !important; max-width:100% !important}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field .wa-name{float:none !important; width:auto !important; max-width:100% !important; padding:0 !important; margin:0 !important; font-size:12px !important; color:var(--muted) !important; font-weight:600 !important; position:static !important}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field .wa-value{margin:0 !important; padding:0 !important; position:static !important; width:auto !important}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field .wa-value p,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field .wa-value p > span{margin:0 !important; padding:0 !important; line-height:1.1 !important; position:static !important; display:block !important; width:100% !important}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form input[type=text]{width:100% !important; max-width:340px !important; min-width:0 !important; padding:10px 12px !important; box-sizing:border-box !important; border:1.5px solid var(--line) !important; border-radius:9px !important; font-size:13.5px !important; margin:0 !important; float:none !important; position:static !important}

/* === Sidebar (confirmation) overflow fix === */
.vfn .onestep-cart .checkout-sidebar{min-width:0; overflow:hidden}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table{width:100%; table-layout:fixed; border-collapse:collapse}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table th:first-child{width:auto}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table th:nth-child(2),
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table th:nth-child(3),
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table td:nth-child(2),
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table td:nth-child(3){width:78px; text-align:right; white-space:normal !important; word-break:normal; overflow-wrap:break-word}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation table td .gray{font-size:11.5px; color:var(--muted); display:inline-block}

/* «Комментарий» — лейбл нормальный, textarea на всю ширину */
.vfn .onestep-cart .checkout .checkout-step.step-confirmation .checkout-content > br{display:none}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation textarea.comment{width:100%; box-sizing:border-box; margin-top:6px; min-height:80px; border:1.5px solid var(--line); border-radius:10px; padding:10px 12px; font-family:var(--sans); font-size:13.5px; resize:vertical}

/* «Получатель» — убрать пустую строку под h3 */
.vfn .onestep-cart .checkout .checkout-step.step-confirmation h3{margin:0 0 6px !important; font-family:var(--serif); font-size:14px; font-weight:600}
.vfn .onestep-cart .checkout .checkout-step.step-confirmation h3 + p{display:none !important}

/* === V9: 2-кол flex (плагин использует width:60%/40% + float — ломает grid) === */
.vfn .onestep-cart .checkout.sticky .checkout-container,
.vfn .onestep-cart .checkout .checkout-container{display:flex !important; flex-direction:row !important; gap:28px !important; align-items:flex-start; flex-wrap:nowrap; position:static !important; max-width:none}
.vfn .onestep-cart .checkout.sticky .checkout-main,
.vfn .onestep-cart .checkout .checkout-main{flex:1 1 auto !important; width:auto !important; max-width:680px !important; min-width:0 !important; float:none !important; display:flex; flex-direction:column; gap:16px}
.vfn .onestep-cart .checkout.sticky .checkout-sidebar,
.vfn .onestep-cart .checkout .checkout-sidebar{flex:0 0 380px !important; width:380px !important; max-width:380px !important; min-width:0 !important; float:none !important; display:flex; flex-direction:column; gap:16px; position:sticky !important; top:90px !important; align-self:flex-start}

/* мобилка */
@media(max-width:980px){
  .vfn .onestep-cart .checkout.sticky .checkout-container,
  .vfn .onestep-cart .checkout .checkout-container{flex-direction:column !important; gap:16px !important}
  .vfn .onestep-cart .checkout.sticky .checkout-main,
  .vfn .onestep-cart .checkout .checkout-main{max-width:none !important; width:100% !important}
  .vfn .onestep-cart .checkout.sticky .checkout-sidebar,
  .vfn .onestep-cart .checkout .checkout-sidebar{flex:1 1 auto !important; width:100% !important; max-width:none !important}
}

/* ============================================================
   V10 — Cart row layout + qty-stepper (fix плагина .choice > span)
   ============================================================ */

/* Cart table TD widths — name column растягиваем, чтобы убрать пустоту в центре */
.vfn .onestep-cart table.cart{table-layout:auto !important}
.vfn .onestep-cart table.cart td:nth-child(1){width:64px !important}
.vfn .onestep-cart table.cart td:nth-child(2){width:auto !important}
.vfn .onestep-cart table.cart td:nth-child(3){width:1% !important; white-space:nowrap}
.vfn .onestep-cart table.cart td:nth-child(4){width:1% !important; white-space:nowrap}
.vfn .onestep-cart table.cart td:nth-child(5){width:40px !important}

/* Services компактнее — горизонтальный layout */
.vfn .onestep-cart .table.cart .services{margin-top:8px !important; display:flex !important; flex-wrap:wrap; gap:14px 18px !important}
.vfn .onestep-cart .table.cart .services > div{display:inline-flex !important; align-items:center; gap:8px; flex-wrap:nowrap}
.vfn .onestep-cart .table.cart .services label{display:inline-flex !important; align-items:center; gap:6px; margin:0; padding:0; cursor:pointer; color:var(--char); font-size:13px}
.vfn .onestep-cart .table.cart .services label input[type=checkbox]{margin:0; accent-color:var(--terra)}
.vfn .onestep-cart .table.cart .services select{font-size:12.5px; padding:5px 9px 5px 10px; border:1.5px solid var(--line); border-radius:8px; background:var(--paper); color:var(--char); font-family:var(--sans); cursor:pointer; transition:.14s}
.vfn .onestep-cart .table.cart .services select:disabled{opacity:.45; cursor:not-allowed}
.vfn .onestep-cart .table.cart .services select:hover:not(:disabled){border-color:var(--sage)}

/* убираем <br><br> между названием и services */
.vfn .onestep-cart .table.cart td br{display:none !important}
.vfn .onestep-cart .table.cart td .services{margin-top:10px !important}

/* === QTY STEPPER fix === */
/* плагин: .choice {position:relative; display:table}, .choice>input {float:left}, .choice>span {position:absolute; right:-19px; width:20px; height:17px} */
.vfn .onestep-cart .table.cart .choice{display:inline-flex !important; align-items:stretch !important; flex-direction:row; border:1.5px solid var(--line) !important; border-radius:10px !important; overflow:hidden !important; height:36px !important; width:auto !important; background:var(--paper) !important; position:relative; vertical-align:middle}
.vfn .onestep-cart .table.cart .choice > input,
.vfn .onestep-cart .table.cart .choice > input.qty{float:none !important; border:none !important; border-radius:0 !important; padding:0 4px !important; margin:0 !important; width:40px !important; min-width:40px !important; max-width:40px !important; height:auto !important; text-align:center !important; font-family:var(--sans) !important; font-weight:600 !important; font-size:14px !important; background:transparent !important; color:var(--char) !important; outline:none !important; order:1 !important; box-sizing:border-box}
.vfn .onestep-cart .table.cart .choice > input:focus{box-shadow:none !important}
.vfn .onestep-cart .table.cart .choice > span,
.vfn .onestep-cart .table.cart .choice > span.plus,
.vfn .onestep-cart .table.cart .choice > span.minus{position:static !important; display:inline-flex !important; align-items:center !important; justify-content:center !important; width:32px !important; min-width:32px !important; height:auto !important; right:auto !important; left:auto !important; top:auto !important; bottom:auto !important; background:transparent !important; background-image:none !important; border:none !important; border-left:1px solid var(--line) !important; border-radius:0 !important; padding:0 !important; margin:0 !important; font-family:var(--sans) !important; font-size:18px !important; font-weight:600 !important; line-height:1 !important; color:var(--char) !important; cursor:pointer !important; user-select:none !important; text-indent:0 !important; box-shadow:none !important; box-sizing:border-box}
.vfn .onestep-cart .table.cart .choice > span.minus{order:0 !important; border-left:none !important; border-right:1px solid var(--line) !important}
.vfn .onestep-cart .table.cart .choice > span.plus{order:2 !important}
.vfn .onestep-cart .table.cart .choice > span:hover{background:var(--sage-soft) !important; color:var(--deep) !important}
.vfn .onestep-cart .table.cart .choice > span:active{background:var(--sage) !important; color:#fff !important}

/* item-total — крупно справа */
.vfn .onestep-cart table.cart td.item-total{font-family:var(--serif); font-weight:700; font-size:18px; color:var(--deep); padding-right:14px}

/* delete cross — стилизуем нормально */
.vfn .onestep-cart table.cart a.delete{display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:50%; color:var(--muted); text-decoration:none; transition:.14s; background:transparent}
.vfn .onestep-cart table.cart a.delete:hover{background:var(--terra-soft); color:var(--terra)}
.vfn .onestep-cart table.cart a.delete i.icon16,
.vfn .onestep-cart table.cart a.delete i.icon16.remove{background-image:none !important; background:none !important; width:16px; height:16px; position:relative; text-indent:0 !important; overflow:visible}
.vfn .onestep-cart table.cart a.delete i.icon16.remove::before{content:"×"; font-size:22px; font-weight:300; line-height:1; color:currentColor; display:block; position:absolute; inset:0; text-align:center}

/* wa-field-address — внутренний <span>Адрес доставки</span> как placeholder сверху */
.vfn .checkout .wa-field-address .wa-value > p{margin:0;padding:0}
.vfn .checkout .wa-field-address .wa-field-address-street{display:block;position:relative}
.vfn .checkout .wa-field-address .wa-field-address-street > span:first-child{position:absolute;top:-9px;left:14px;background:var(--paper);padding:0 6px;font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.02em;border-radius:4px;line-height:1}
.vfn .checkout .wa-field-address input{width:100%;font-family:var(--sans);font-size:14.5px;color:var(--char);background:var(--paper);border:1.5px solid var(--line);border-radius:11px;padding:13px 14px 11px;box-sizing:border-box;transition:.14s}
.vfn .checkout .wa-field-address input:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px rgba(193,123,94,.12)}

/* confirmation TABLE — товары не должны бить по словам */
.vfn .checkout-step.step-confirmation table{table-layout:auto}
.vfn .checkout-step.step-confirmation td{overflow-wrap:break-word;word-wrap:break-word;hyphens:auto;font-size:12.5px;line-height:1.4}
.vfn .checkout-step.step-confirmation td:first-child{width:auto;min-width:0;padding-right:6px}
.vfn .checkout-step.step-confirmation td:last-child{width:1%;white-space:nowrap}
.vfn .checkout-step.step-confirmation .quantity{width:1%;white-space:nowrap;text-align:right}
.vfn .checkout-step.step-confirmation .quantity input[type=text]{width:48px;padding:4px 6px;font-size:12px;text-align:center}

/* «Нажимая на кнопку подтверждения…» под формой — не сжимать вертикально */
.vfn .checkout-step.step-contactinfo .checkout-content > p,
.vfn .checkout-step.step-contactinfo > p,
.vfn .checkout .wa-form + p,
.vfn .checkout .wa-form > p:last-of-type{font-size:12.5px;color:var(--muted);line-height:1.5;margin:14px 0 0;padding:0 4px}

/* Чекбоксы вне wa-form (типа "Зарегистрировать как постоянный покупатель") */
.vfn .checkout label:has(> input[type=checkbox]){display:inline-flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--char);line-height:1.45;margin-top:8px;cursor:pointer}

/* «Быстрый заказ» buy1click — отключаем чужие стили + скрываем эту плавающую кнопку наверху (в чекауте лишняя) */
.vfn .checkout .buy1click-open-button,
.vfn-body > .buy1click-open-button,
.vfn .b1c-wrap > .buy1click-open-button{display:none}

/* Если оставлять — приводим к нашему стилю */
.vfn .checkout-step .buy1click-open-button{display:inline-flex;align-items:center;gap:8px;background:var(--terra);color:#fff;border:none;font-family:var(--sans);font-weight:700;font-size:14px;padding:11px 18px;border-radius:11px;cursor:pointer;letter-spacing:0;text-transform:none}
.vfn .checkout-step .buy1click-open-button:hover{background:#a96746}
.vfn .checkout-step .buy1click-svg-icon{width:14px;height:14px}

/* немного шире sidebar чтобы товары в подтверждении не бились на слова */
@media(min-width:1100px){
  .vfn .checkout-container{grid-template-columns:1fr 400px}
}

/* «Получатель» — h3 первый в confirmation: чуть крупнее */
.vfn .checkout-step.step-confirmation > h3:first-of-type,
.vfn .checkout-step.step-confirmation .checkout-content > h3:first-of-type{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--char);margin:0 0 6px}

/* «1. Контактная информация» — отступ под заголовком меньше */
.vfn .checkout-step > h2{margin-bottom:14px}

/* фикс: фон h2 не должен быть отдельным */
.vfn .checkout-step{background:var(--paper)}
.vfn .checkout-step > h2{background:transparent;padding:0}

/* === HOME hero-values (потерялись при перезаписи checkout CSS) === */
.vfn .hero-values{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;margin-top:32px;padding-top:26px;border-top:1px solid var(--line)}
.vfn .hv{display:flex;gap:11px;align-items:flex-start}
.vfn .hv svg{width:28px;height:28px;color:var(--terra);flex-shrink:0}
.vfn .hv > div{flex:1;min-width:0}
.vfn .hv b{font-family:var(--serif);font-size:15px;font-weight:600;color:var(--deep);display:block;line-height:1.15;margin-bottom:3px}
.vfn .hv span{font-size:12.5px;color:var(--muted);line-height:1.4;display:block}
@media(max-width:520px){.vfn .hero-values{grid-template-columns:1fr;gap:14px}}

/* hero-float fix: тоже b/span слиплись */
.vfn .hero-float .hf-t{display:block}
.vfn .hero-float .hf-s{display:block}

/* ============================================================
   V11 — финальные перебивки
   ============================================================ */

/* ИНН/Компания форма — БРУТАЛЬНО прижимаем влево внутри карточки */
.vfn .onestep-cart .checkout ul.checkout-options li > .wa-form,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form{
  display:block !important;
  position:static !important;
  float:none !important;
  clear:both !important;
  width:100% !important;
  max-width:100% !important;
  margin:14px 0 0 !important;
  padding:0 !important;
  text-align:left !important;
  right:auto !important; left:auto !important; top:auto !important; bottom:auto !important;
  transform:none !important;
}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form > div,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field{
  display:block !important;
  position:static !important;
  float:none !important;
  clear:both !important;
  width:100% !important;
  max-width:340px !important;
  margin:0 0 12px !important;
  padding:0 !important;
  right:auto !important; left:auto !important;
}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-name{
  display:block !important;
  float:none !important; width:auto !important; max-width:100% !important;
  padding:0 0 4px !important; margin:0 !important;
  font-size:12px !important; color:var(--muted) !important; font-weight:600 !important;
  text-align:left !important;
  position:static !important;
}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-value,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-value p,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-value p > span{
  display:block !important; float:none !important; clear:none !important;
  margin:0 !important; padding:0 !important; line-height:1.1 !important;
  width:auto !important; max-width:100% !important; min-width:0 !important;
  position:static !important; text-align:left !important;
}
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form input[type=text]{
  display:block !important; float:none !important;
  width:100% !important; max-width:340px !important; min-width:0 !important;
  padding:10px 12px !important; margin:0 !important;
  box-sizing:border-box !important;
  border:1.5px solid var(--line) !important; border-radius:9px !important;
  font-family:var(--sans) !important; font-size:13.5px !important;
  background:var(--paper) !important; color:var(--char) !important;
  position:static !important;
}

/* === Success-страница (checkout/success/) — огромный SVG-кружок === */
.notice-image,
svg.notice-image{
  display:block !important;
  width:120px !important;
  height:120px !important;
  max-width:120px !important;
  max-height:120px !important;
  margin:30px auto 20px !important;
}
.notice-image__secondary-dark{fill:#e8e2d5}
.notice-image__shadow{fill:rgba(0,0,0,.05)}
.notice-image__background{fill:#8A9A7B}

/* ============================================================
   V12 — airSticky kill + finalize ИНН-form
   ============================================================ */

/* убиваем airSticky плагина: оно ставит position:absolute|fixed + сдвиги
   когда блок упирается в низ контейнера — sidebar пропадает.
   Заменяем на нативный position:sticky который держит блок в окне всегда. */
.vfn .onestep-cart .checkout-step.step-confirmation,
.vfn .onestep-cart .checkout-step.step-confirmation.airSticky_absolute,
.vfn .onestep-cart .checkout-step.step-confirmation.airSticky_fixed,
.vfn .onestep-cart .checkout-step.step-confirmation.airSticky{
  position:static !important;
  top:auto !important; bottom:auto !important; left:auto !important; right:auto !important;
  transform:none !important;
  width:auto !important; max-width:none !important; min-width:0 !important;
}
/* sticky на самом .checkout-sidebar — он становится липким и движется с прокруткой */
.vfn .onestep-cart .checkout .checkout-sidebar{
  position:sticky !important;
  top:20px !important;
  align-self:flex-start !important;
  max-height:calc(100vh - 40px);
  overflow-y:auto;
}

/* === ИНН / Компания — финальная ультра-перебивка с супер-специфичностью === */
ul.checkout-options li .wa-form,
.checkout-options li .wa-form,
.onestep-cart .checkout ul.checkout-options li .wa-form,
.vfn .onestep-cart .checkout ul.checkout-options li .wa-form,
.vfn body .onestep-cart .checkout ul.checkout-options li .wa-form,
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form{
  display:block !important;
  position:static !important;
  float:none !important; clear:both !important;
  width:100% !important; max-width:100% !important;
  min-width:0 !important;
  margin:14px 0 0 !important;
  padding:0 !important;
  left:auto !important; right:auto !important; top:auto !important; bottom:auto !important;
  transform:none !important;
  text-align:left !important;
  vertical-align:top !important;
}
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field{
  display:block !important;
  position:static !important;
  float:none !important; clear:both !important;
  width:100% !important; max-width:380px !important;
  margin:0 0 12px !important;
  padding:0 !important;
  left:auto !important; right:auto !important;
  text-align:left !important;
}
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field .wa-name{
  display:block !important;
  float:none !important;
  width:auto !important; max-width:100% !important;
  padding:0 0 4px !important; margin:0 !important;
  font-size:12px !important; color:#7a7a7a !important;
  font-weight:600 !important;
  text-align:left !important;
}
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-field .wa-value,
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-value p,
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form .wa-value p > span{
  display:block !important;
  float:none !important; clear:none !important;
  margin:0 !important; padding:0 !important;
  width:100% !important; max-width:380px !important; min-width:0 !important;
  position:static !important;
  text-align:left !important;
}
html body .vfn .onestep-cart .checkout ul.checkout-options li .wa-form input[type=text]{
  display:block !important;
  float:none !important; position:static !important;
  width:100% !important; max-width:380px !important; min-width:0 !important;
  padding:10px 12px !important; margin:0 !important;
  box-sizing:border-box !important;
  border:1.5px solid #e4ddd0 !important; border-radius:9px !important;
  font-family:var(--sans) !important; font-size:13.5px !important;
  background:#fff !important;
}

/* ============================================================
   V13 — общие стили лендингов (.dlv-page-wrap) для /delivery/, /pay/ и др.
   ============================================================ */
.dlv-page-wrap{padding:0 0 60px}
.dlv-page-wrap .crumbs{font-size:13px;color:var(--muted);padding:20px 0 0}
.dlv-page-wrap .crumbs a{color:var(--sage);font-weight:700}
.dlv-page-wrap .crumbs span{color:var(--char)}
.dlv-page-wrap .page-hero{padding:28px 0 18px;max-width:780px}
.dlv-page-wrap .eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--terra)}
.dlv-page-wrap .eyebrow::before{content:"";width:26px;height:1.5px;background:var(--terra)}
.dlv-page-wrap .page-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,4.2vw,52px);letter-spacing:-.02em;line-height:1.02;margin:14px 0 16px;color:var(--char)}
.dlv-page-wrap .page-hero h1 em{color:var(--deep);font-style:italic}
.dlv-page-wrap .page-hero .lead{font-size:16.5px;line-height:1.55;color:var(--muted);max-width:680px;margin:0}

.dlv-page-wrap .section{padding:30px 0}
.dlv-page-wrap .sec-title{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.2vw,34px);letter-spacing:-.02em;line-height:1.1;margin:0 0 22px;color:var(--char)}
.dlv-page-wrap .sec-title em{color:var(--deep);font-style:italic}

.dlv-page-wrap .cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.dlv-page-wrap .cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.dlv-page-wrap .icard{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:24px;transition:.18s}
.dlv-page-wrap .icard:hover{border-color:var(--sage);box-shadow:var(--shadow-card);transform:translateY(-3px)}
.dlv-page-wrap .icard .ic{width:46px;height:46px;border-radius:13px;background:var(--sage-soft);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.dlv-page-wrap .icard .ic svg{width:24px;height:24px;color:var(--deep)}
.dlv-page-wrap .icard h3{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--char);margin:0 0 8px;line-height:1.15}
.dlv-page-wrap .icard p{font-size:14px;color:var(--muted);line-height:1.55;margin:0}

.dlv-page-wrap .band{background:linear-gradient(135deg,var(--deep) 0%,var(--deep-2) 100%);color:#fff;border-radius:24px;padding:48px 44px;position:relative;overflow:hidden;text-align:center}
.dlv-page-wrap .band .leaf-wm{position:absolute;right:-30px;bottom:-30px;width:220px;height:220px;opacity:.08}
.dlv-page-wrap .band h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,40px);letter-spacing:-.02em;line-height:1.05;margin:0 0 14px}
.dlv-page-wrap .band p{font-size:15.5px;line-height:1.55;color:rgba(255,255,255,.85);max-width:600px;margin:0 auto 22px}
.dlv-page-wrap .band .btn{color:#fff;background:var(--terra)}
.dlv-page-wrap .band .btn:hover{background:#a96746}

.dlv-page-wrap .steps-num{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.dlv-page-wrap .snum{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:24px;position:relative}
.dlv-page-wrap .snum .n{font-family:var(--serif);font-weight:600;font-size:24px;width:42px;height:42px;border-radius:50%;background:var(--terra-soft);color:var(--terra);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.dlv-page-wrap .snum h4{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--char);margin:0 0 6px}
.dlv-page-wrap .snum p{font-size:13.5px;color:var(--muted);line-height:1.5;margin:0}

.dlv-page-wrap .guarantee{background:var(--sage-soft);border-radius:24px;padding:38px 44px;text-align:center;max-width:760px;margin:0 auto;position:relative}
.dlv-page-wrap .guarantee .shield{width:54px;height:54px;color:var(--sage);margin-bottom:14px}
.dlv-page-wrap .guarantee h2{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.4vw,36px);letter-spacing:-.02em;line-height:1.05;color:var(--deep);margin:0 0 12px}
.dlv-page-wrap .guarantee p{font-size:15px;line-height:1.6;color:var(--char);max-width:560px;margin:0 auto}

.dlv-page-wrap .faq-list{display:flex;flex-direction:column;gap:10px;max-width:880px}
.dlv-page-wrap .faq-item{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.dlv-page-wrap .faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:18px 20px;font-family:var(--sans);font-size:15px;font-weight:600;color:var(--char);display:flex;align-items:center;justify-content:space-between;gap:14px}
.dlv-page-wrap .faq-q:hover{color:var(--terra)}
.dlv-page-wrap .faq-q .pm{flex-shrink:0;color:var(--muted);transition:transform .2s}
.dlv-page-wrap .faq-q .pm svg{width:18px;height:18px;display:block}
.dlv-page-wrap .faq-item.open .faq-q .pm{transform:rotate(180deg);color:var(--terra)}
.dlv-page-wrap .faq-a{padding:0 20px 18px;font-size:14px;color:var(--muted);line-height:1.55;display:none}
.dlv-page-wrap .faq-item.open .faq-a{display:block}

.dlv-page-wrap .info-cta{margin-top:48px;background:linear-gradient(135deg,var(--sage-soft) 0%,var(--terra-soft) 100%);border-radius:24px;padding:36px 40px}
.dlv-page-wrap .info-cta-inner{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.dlv-page-wrap .info-cta h2{font-family:var(--serif);font-weight:500;font-size:clamp(24px,3vw,32px);letter-spacing:-.02em;color:var(--char);margin:0 0 6px;line-height:1.1}
.dlv-page-wrap .info-cta p{color:var(--muted);font-size:14.5px;margin:0;line-height:1.5;max-width:500px}
.dlv-page-wrap .info-cta-btns{display:flex;gap:10px;flex-wrap:wrap}

@media(max-width:780px){
  .dlv-page-wrap .cards3,.dlv-page-wrap .steps-num{grid-template-columns:1fr}
  .dlv-page-wrap .cards2{grid-template-columns:1fr}
  .dlv-page-wrap .band{padding:32px 24px}
  .dlv-page-wrap .info-cta-inner{grid-template-columns:1fr}
  .dlv-page-wrap .info-cta{padding:28px 24px}
}

/* ============================================================
   V14 — Mega-menu (dropdown под «Каталог»)
   ============================================================ */
.vfn .nav-cat-wrap{position:static}
.vfn .nav-cat-trigger{display:inline-flex !important;align-items:center;gap:5px}
.vfn .nav-cat-trigger .nav-caret{width:14px;height:14px;color:currentColor;transition:transform .18s}
.vfn .nav-cat-wrap:hover .nav-caret{transform:rotate(180deg)}

.vfn .mega-menu{
  position:absolute; top:100%; left:0; right:0; transform:translateY(-6px);
  width:auto; max-width:1180px; margin:8px auto 0;
  background:var(--paper); border:1px solid var(--line); border-radius:18px;
  box-shadow:0 30px 60px -20px rgba(46,74,59,.25), 0 8px 24px -12px rgba(46,74,59,.12);
  padding:28px 32px 22px;
  opacity:0; pointer-events:none; visibility:hidden;
  transition:opacity .25s ease .12s, transform .28s ease .12s, visibility 0s linear .42s;
  z-index:300;
}
.vfn .nav-cat-wrap:hover .mega-menu,
.vfn .nav-cat-wrap:focus-within .mega-menu,
.vfn .nav-cat-wrap.mega-open .mega-menu{
  opacity:1; pointer-events:auto; visibility:visible;
  transform:translateY(0);
  transition:opacity .18s ease, transform .22s ease, visibility 0s linear 0s;
}
.vfn .mega-menu::before{
  content:""; position:absolute; top:-16px; left:0; right:0; height:18px; background:transparent;
}
.vfn .mega-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:22px 28px; padding-bottom:18px; border-bottom:1px solid var(--line); margin-bottom:18px}
.vfn .mega-col{min-width:0}
.vfn .mega-h{font-family:var(--serif); font-weight:600; font-size:13px; color:var(--terra); text-transform:uppercase; letter-spacing:.06em; margin-bottom:10px; line-height:1.3}
.vfn .mega-col > a{display:block !important; padding:5px 0 !important; font-size:13.5px !important; font-weight:500 !important; color:var(--char) !important; text-decoration:none; line-height:1.35; transition:.12s; border-radius:6px; margin:1px 0; background:transparent !important}
.vfn .mega-col > a:hover{color:var(--terra) !important; padding-left:6px !important; background:transparent !important}

.vfn .mega-promo{display:flex; align-items:center; justify-content:space-between; gap:24px; background:linear-gradient(135deg,var(--sage-soft) 0%,var(--terra-soft) 100%); border-radius:14px; padding:14px 20px}
.vfn .mega-promo-text b{display:block; font-family:var(--serif); font-weight:600; font-size:15px; color:var(--deep); margin-bottom:2px}
.vfn .mega-promo-text span{font-size:13px; color:var(--char); line-height:1.4}
.vfn .mega-promo-cta{display:flex; gap:8px; flex-shrink:0}

/* перебиваем глобальное .nav-links a для кнопок в mega-promo */
.vfn .nav-links .mega-promo-cta a.btn{padding:9px 16px !important; font-size:13px !important; border-radius:9px; color:#fff !important; background:var(--terra); border:none; font-weight:700; text-decoration:none}
.vfn .nav-links .mega-promo-cta a.btn:hover{background:#a96746 !important; color:#fff !important}
.vfn .nav-links .mega-promo-cta a.btn.btn-secondary{background:transparent !important; color:var(--deep) !important; border:1.5px solid var(--sage)}
.vfn .nav-links .mega-promo-cta a.btn.btn-secondary:hover{background:var(--sage-soft) !important; color:var(--deep) !important}

/* мобилка — скрываем mega, показываем обычную ссылку */
@media(max-width:920px){
  .vfn .nav-cat-wrap .mega-menu,
  .vfn .nav-cat-trigger .nav-caret{display:none !important}
}

/* ============================================================
   V15 — Mobile drawer (бургер + меню справа)
   ============================================================ */
.vfn .vfn-burger{display:none}
.vfn .mnav{position:fixed; inset:0; z-index:1000; visibility:hidden; pointer-events:none}
.vfn .mnav.open{visibility:visible; pointer-events:auto}
.vfn .mnav-scrim{position:absolute; inset:0; background:rgba(36,56,45,.45); opacity:0; transition:.25s}
.vfn .mnav.open .mnav-scrim{opacity:1}
.vfn .mnav-panel{position:absolute; top:0; right:0; bottom:0; width:min(88vw, 380px); background:var(--base); box-shadow:-12px 0 40px -10px rgba(36,56,45,.4); transform:translateX(100%); transition:transform .28s cubic-bezier(.2,.8,.2,1); display:flex; flex-direction:column; overflow-y:auto}
.vfn .mnav.open .mnav-panel{transform:translateX(0)}
.vfn .mnav-top{display:flex; align-items:center; justify-content:space-between; padding:16px 18px; border-bottom:1px solid var(--line); position:sticky; top:0; background:var(--base); z-index:2}
.vfn .mnav-top .logo{display:flex; align-items:center; gap:8px; color:var(--deep)}
.vfn .mnav-close{width:38px; height:38px; border-radius:10px; border:1px solid var(--line); background:var(--paper); cursor:pointer; display:flex; align-items:center; justify-content:center; padding:0}
.vfn .mnav-close svg{width:20px; height:20px; color:var(--char)}
.vfn .mnav-links{padding:10px 8px 4px; display:flex; flex-direction:column}
.vfn .mnav-links a{display:block; padding:13px 14px; font-size:15.5px; font-weight:700; color:var(--char); text-decoration:none; border-radius:10px; transition:.14s}
.vfn .mnav-links a:active{background:var(--sage-soft)}
.vfn .mnav-sec{margin:6px 8px 4px; padding-top:10px; border-top:1px solid var(--line)}
.vfn .mnav-sec-h{font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); padding:8px 14px 6px}
.vfn .mnav-allcat{display:flex; align-items:center; justify-content:space-between; margin:4px 6px 10px; padding:14px 16px; background:var(--deep); color:#fff; border-radius:12px; text-decoration:none; font-weight:700; font-size:15px}
.vfn .mnav-allcat span{display:flex; align-items:center; gap:10px}
.vfn .macc{border:none; background:none; width:100%; display:flex; align-items:center; justify-content:space-between; padding:13px 14px; font-family:var(--sans); font-weight:700; font-size:15px; color:var(--char); cursor:pointer; border-radius:10px; text-align:left}
.vfn .macc .chev{width:16px; height:16px; color:var(--muted); transition:.2s; flex-shrink:0}
.vfn .macc.open .chev{transform:rotate(180deg)}
.vfn .macc-body{max-height:0; overflow:hidden; transition:max-height .28s ease}
.vfn .macc.open + .macc-body{max-height:600px}
.vfn .macc-body a{display:block; padding:10px 14px 10px 26px; font-size:14px; font-weight:600; color:var(--char); text-decoration:none}
.vfn .macc-body a:active{background:var(--sage-soft)}
.vfn .mnav-cta{margin:14px 16px 30px; padding:18px; background:linear-gradient(160deg,var(--sage-soft),var(--terra-soft)); border-radius:16px}
.vfn .mnav-cta h5{font-family:var(--serif); font-size:18px; font-weight:600; color:var(--deep); margin:0 0 5px}
.vfn .mnav-cta p{font-size:12.5px; color:var(--char); opacity:.85; margin:0 0 12px; line-height:1.4}
.vfn .mnav-cta .btn{display:flex; width:100%; justify-content:center}

@media(max-width:920px){
  .vfn .vfn-burger{display:flex !important}
}

/* === Pet-safe badge — компактная круглая иконка без текста === */
.vfn .badge.badge-pet{
  width:30px;height:30px;padding:0;border-radius:50%;
  background:var(--sage); color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  box-shadow:0 2px 6px rgba(46,74,59,.18);
  cursor:help; transition:.16s;
}
.vfn .badge.badge-pet svg{width:16px;height:16px;color:#fff;margin:0}
.vfn .badge.badge-pet:hover{background:var(--deep);transform:scale(1.06)}

/* === Card SKU-selector (как в макете 02 catalog) === */
.vfn .card-cta.has-sku-select{display:flex !important; flex-direction:row !important; gap:8px !important; align-items:stretch}
.vfn .card-sku-form{display:flex !important; gap:8px !important; align-items:stretch; width:100% !important; flex:1 1 100% !important; min-width:0; padding:0; margin:0}
.vfn .card-cta .size-select{
  flex:1 1 auto !important; min-width:0;
  appearance:none; -webkit-appearance:none;
  font-family:var(--sans); font-size:12.5px; font-weight:600; color:var(--char);
  background:var(--paper); border:1.5px solid var(--line); border-radius:10px;
  padding:9px 30px 9px 12px; cursor:pointer; height:38px;
  text-overflow:ellipsis;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237A756C' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center;
}
.vfn .card-cta .size-select:hover{border-color:var(--sage)}
.vfn .card-cta .size-select:focus{outline:none; border-color:var(--sage); box-shadow:0 0 0 3px rgba(138,160,123,.16)}
.vfn .card-sku-form .btn.cart-add{flex:0 0 auto !important; width:46px !important; min-width:46px !important; max-width:46px !important; padding:0 !important; height:38px !important; border-radius:10px; display:inline-flex; align-items:center; justify-content:center}
.vfn .card-sku-form .btn.cart-add svg{margin:0 !important; width:17px !important; height:17px !important}
