@import url('https://fonts.googleapis.com/css2?family=Unbounded:wght@300;400;600;700;900&family=Inter:ital,wght@0,300;0,400;0,500;0,600;1,300&family=Cormorant+Garant:ital,wght@1,700;1,800&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --cream:#f5f0e8;
  --cream2:#ede8df;
  --cream3:#e5dfd4;
  --white:#fdfaf6;
  --red:#d42b2b;
  --red2:#e8192c;
  --dark:#1c1410;
  --dark2:#2d2520;
  --mid:#6b5e54;
  --border:rgba(100,80,60,.12);
  --shadow:rgba(28,20,16,.08);
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Inter',sans-serif;background:var(--white);color:var(--dark);overflow-x:hidden;cursor:none}

/* ─── CUSTOM CURSOR ─── */
.cursor{position:fixed;width:10px;height:10px;background:var(--red);border-radius:50%;pointer-events:none;z-index:9999;transition:transform .15s ease;transform:translate(-50%,-50%)}
.cursor-follow{position:fixed;width:40px;height:40px;border:1.5px solid var(--red);border-radius:50%;pointer-events:none;z-index:9998;transition:transform .4s ease,width .3s,height .3s,opacity .3s;transform:translate(-50%,-50%);opacity:.5}
.cursor-follow.expand{width:60px;height:60px;opacity:.3}

/* ─── LOADER ─── */
.loader{position:fixed;inset:0;background:var(--dark);z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;transition:opacity .6s ease,visibility .6s}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{font-family:'Unbounded',sans-serif;font-size:28px;font-weight:900;color:#fff;letter-spacing:-1px;overflow:hidden}
.loader-logo span{color:var(--red)}
.loader-bar{width:200px;height:2px;background:rgba(255,255,255,.15);border-radius:1px;overflow:hidden}
.loader-fill{height:100%;background:var(--red);border-radius:1px;animation:loaderFill 1.8s ease forwards}
@keyframes loaderFill{0%{width:0}100%{width:100%}}

/* ─── TOPBAR ─── */
.topbar{position:fixed;top:0;left:0;right:0;z-index:201;height:38px;background:var(--dark);display:flex;align-items:center;justify-content:space-between;padding:0 56px;transition:transform .4s}
.topbar.hidden{transform:translateY(-100%)}
.topbar-left{display:flex;align-items:center;gap:24px}
.topbar-item{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.6);font-size:11.5px;font-weight:500;letter-spacing:.3px;text-decoration:none;transition:color .2s}
.topbar-item:hover{color:#fff}
.topbar-item svg{width:13px;height:13px;stroke:var(--red);fill:none;flex-shrink:0}
.topbar-right{display:flex;align-items:center;gap:20px}
.topbar-phone{color:#fff;font-size:12px;font-weight:700;font-family:'Unbounded',sans-serif;letter-spacing:.5px;text-decoration:none;transition:color .2s}
.topbar-phone:hover{color:var(--red)}
.topbar-dot{width:5px;height:5px;background:var(--red);border-radius:50%;animation:pulse 2s infinite}

/* ─── NAV ─── */
nav{position:fixed;top:38px;left:0;right:0;z-index:200;padding:0 56px;height:76px;display:flex;align-items:center;justify-content:space-between;transition:background .4s,box-shadow .4s,top .4s}
nav.scrolled{background:rgba(245,240,232,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border);top:0}
.nav-logo{display:flex;align-items:center;gap:14px;text-decoration:none}
.nav-logo-box{width:44px;height:44px;background:var(--red);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(212,43,43,.35)}
.nav-logo-box svg{width:22px;height:22px;stroke:#fff;fill:none}
.nav-brand{font-family:'Unbounded',sans-serif;font-size:13px;font-weight:700;line-height:1.3;color:var(--dark)}
.nav-brand span{color:var(--red)}
.nav-links{display:flex;gap:36px}
.nav-links a{color:var(--mid);text-decoration:none;font-size:13px;font-weight:500;letter-spacing:.3px;transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--red);transition:width .3s}
.nav-links a:hover{color:var(--dark)}
.nav-links a:hover::after{width:100%}
.nav-btn{background:var(--dark);color:#fff;padding:12px 28px;border-radius:50px;font-size:13px;font-weight:600;text-decoration:none;letter-spacing:.3px;transition:all .3s;font-family:'Unbounded',sans-serif}
.nav-btn:hover{background:var(--red);transform:translateY(-1px);box-shadow:0 8px 24px rgba(212,43,43,.35)}

/* ─── HERO ─── */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:114px 56px 80px;position:relative;overflow:hidden;background:var(--cream)}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-blob{position:absolute;border-radius:50%;filter:blur(80px);animation:blobMove 8s ease-in-out infinite alternate}
.blob1{width:600px;height:600px;background:rgba(212,43,43,.1);top:-100px;right:-100px;animation-delay:0s}
.blob2{width:400px;height:400px;background:rgba(200,160,100,.15);bottom:100px;left:-50px;animation-delay:-3s}
.blob3{width:300px;height:300px;background:rgba(212,43,43,.06);top:50%;left:40%;animation-delay:-6s}
@keyframes blobMove{0%{transform:translate(0,0) scale(1)}100%{transform:translate(40px,30px) scale(1.1)}}

.hero-tag{display:inline-flex;align-items:center;gap:10px;background:rgba(28,20,16,.06);border:1px solid var(--border);padding:8px 20px;border-radius:100px;font-size:12px;font-weight:600;color:var(--mid);letter-spacing:.5px;text-transform:uppercase;margin-bottom:32px;opacity:0;animation:fadeUp .8s .3s forwards}
.hero-tag-dot{width:6px;height:6px;background:var(--red);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}

.hero-title{font-family:'Unbounded',sans-serif;font-size:clamp(52px,8vw,112px);font-weight:900;line-height:.95;letter-spacing:-4px;color:var(--dark);margin-bottom:48px;opacity:0;animation:fadeUp .8s .5s forwards}
.hero-title em{font-style:normal;color:var(--red);display:block}
.hero-title .stroke-text{font-family:'Cormorant Garant',serif;font-style:italic;font-weight:800;color:var(--dark);-webkit-text-stroke:0;letter-spacing:-2px;line-height:.9}

.hero-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;opacity:0;animation:fadeUp .8s .7s forwards}
.hero-desc{max-width:420px;font-size:16px;color:var(--mid);line-height:1.75;font-weight:400}
.hero-actions{display:flex;align-items:center;gap:16px;flex-shrink:0}
.btn-primary{background:var(--red);color:#fff;padding:18px 40px;border-radius:50px;font-size:14px;font-weight:700;text-decoration:none;transition:all .3s;font-family:'Unbounded',sans-serif;letter-spacing:.3px;box-shadow:0 8px 32px rgba(212,43,43,.3);display:inline-flex;align-items:center;gap:10px}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(212,43,43,.45)}
.btn-primary svg{width:16px;height:16px;stroke:#fff;fill:none;transition:transform .3s}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-secondary{background:transparent;color:var(--dark);padding:18px 40px;border-radius:50px;font-size:14px;font-weight:600;text-decoration:none;border:1.5px solid var(--border);transition:all .3s;display:inline-flex;align-items:center;gap:10px}
.btn-secondary:hover{border-color:var(--dark);background:var(--dark);color:#fff}
.btn-secondary svg{width:16px;height:16px;stroke:currentColor;fill:none;transition:transform .3s}
.btn-secondary:hover svg{transform:translateY(2px)}
.btn-bot{background:rgba(212,43,43,.08);color:var(--red);padding:18px 32px;border-radius:50px;font-size:14px;font-weight:600;text-decoration:none;border:1.5px solid rgba(212,43,43,.2);transition:all .3s;display:inline-flex;align-items:center;gap:10px}
.btn-bot:hover{background:var(--red);color:#fff;border-color:var(--red)}
.btn-bot svg{width:16px;height:16px;stroke:currentColor;fill:none}
.topbar-bot{color:rgba(255,255,255,.75)!important;border:1px solid rgba(212,43,43,.4);border-radius:20px;padding:2px 10px!important;transition:all .2s}
.topbar-bot:hover{background:var(--red);color:#fff!important;border-color:var(--red)}

.hero-scroll{position:absolute;bottom:40px;left:56px;display:flex;align-items:center;gap:12px;font-size:12px;color:var(--mid);letter-spacing:1px;text-transform:uppercase;opacity:0;animation:fadeUp .8s .9s forwards}
.scroll-line{width:40px;height:1px;background:var(--mid);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;inset:0;background:var(--red);animation:scrollLine 2s ease infinite}
@keyframes scrollLine{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* ─── MARQUEE ─── */
.marquee-wrap{background:var(--red);padding:18px 0;overflow:hidden;position:relative;z-index:1}
.marquee-track{display:flex;gap:0;animation:marquee 20s linear infinite;width:max-content}
.marquee-item{display:flex;align-items:center;gap:32px;padding:0 32px;font-family:'Unbounded',sans-serif;font-size:13px;font-weight:700;color:#fff;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}
.marquee-dot{width:6px;height:6px;background:rgba(255,255,255,.5);border-radius:50%;flex-shrink:0}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── SECTION BASE ─── */
section{padding:120px 56px;position:relative}
.s-wrap{max-width:1280px;margin:0 auto}
.s-eyebrow{display:flex;align-items:center;gap:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--mid);margin-bottom:20px}
.s-eyebrow::before{content:'';width:24px;height:2px;background:var(--red);border-radius:1px}
.s-headline{font-family:'Unbounded',sans-serif;font-size:clamp(32px,4vw,56px);font-weight:900;letter-spacing:-2px;line-height:1.05;color:var(--dark);margin-bottom:20px}
.s-sub{font-size:16px;color:var(--mid);line-height:1.75;max-width:500px}

/* ─── STATS ─── */
.stats-section{background:var(--dark);padding:80px 56px}
.stats-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);border-radius:24px;overflow:hidden}
.stat-item{padding:48px 40px;background:var(--dark);text-align:center;transition:background .3s;position:relative;overflow:hidden}
.stat-item::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(212,43,43,.08),transparent);opacity:0;transition:opacity .3s}
.stat-item:hover{background:#261e1a}
.stat-item:hover::before{opacity:1}
.stat-num{font-family:'Unbounded',sans-serif;font-size:52px;font-weight:900;color:#fff;letter-spacing:-2px;line-height:1;margin-bottom:10px}
.stat-num .accent{color:var(--red)}
.stat-label{font-size:12px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.stat-icon-wrap{width:44px;height:44px;border-radius:12px;background:rgba(212,43,43,.15);border:1px solid rgba(212,43,43,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.stat-icon-wrap svg{width:20px;height:20px;stroke:var(--red);fill:none}

/* ─── SERVICES ─── */
.services-section{background:var(--white)}
.services-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:72px;gap:40px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--cream3);border-radius:28px;overflow:hidden}
.svc-card{background:var(--white);padding:48px 40px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;cursor:default}
.svc-card::before{content:'';position:absolute;inset:0;background:var(--cream);opacity:0;transition:opacity .4s}
.svc-card:hover{transform:scale(1.01)}
.svc-card:hover::before{opacity:1}
.svc-num{font-family:'Unbounded',sans-serif;font-size:11px;font-weight:700;color:var(--mid);letter-spacing:2px;margin-bottom:28px;opacity:.5;position:relative;z-index:1}
.svc-icon{width:56px;height:56px;border-radius:16px;background:rgba(212,43,43,.08);border:1px solid rgba(212,43,43,.1);display:flex;align-items:center;justify-content:center;margin-bottom:24px;transition:transform .3s,background .3s;position:relative;z-index:1}
.svc-card:hover .svc-icon{transform:rotate(-8deg) scale(1.1);background:rgba(212,43,43,.15)}
.svc-icon svg{width:26px;height:26px;stroke:var(--red);fill:none}
.svc-name{font-family:'Unbounded',sans-serif;font-size:17px;font-weight:700;color:var(--dark);margin-bottom:12px;letter-spacing:-.5px;position:relative;z-index:1}
.svc-desc{font-size:14px;color:var(--mid);line-height:1.7;transition:opacity .35s ease,max-height .35s ease,margin-top .35s ease;position:relative;z-index:1}
/* На десктопе — описание появляется при наведении */
@media(hover:hover){
  .svc-desc{opacity:0;max-height:0;overflow:hidden;margin-top:0}
  .svc-card:hover .svc-desc{opacity:1;max-height:150px;margin-top:12px}
}
.svc-arrow{margin-top:32px;width:40px;height:40px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .3s}
.svc-arrow svg{width:16px;height:16px;stroke:var(--mid);fill:none;transition:transform .3s,stroke .3s}
.svc-card:hover .svc-arrow{background:var(--red);border-color:var(--red)}
.svc-card:hover .svc-arrow svg{stroke:#fff;transform:translate(2px,-2px)}

/* ─── PROCESS ─── */
.process-section{background:var(--cream)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:72px;position:relative}
.process-steps::before{content:'';position:absolute;top:32px;left:calc(12.5% + 20px);right:calc(12.5% + 20px);height:1px;background:linear-gradient(90deg,transparent,var(--red),var(--red),transparent)}
.proc-card{text-align:center;position:relative;z-index:1}
.proc-circle{width:64px;height:64px;border-radius:50%;background:var(--white);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 28px;font-family:'Unbounded',sans-serif;font-size:20px;font-weight:900;color:var(--dark);transition:all .4s;box-shadow:0 4px 16px var(--shadow)}
.proc-card:hover .proc-circle{background:var(--red);border-color:var(--red);color:#fff;transform:scale(1.1);box-shadow:0 12px 32px rgba(212,43,43,.35)}
.proc-name{font-family:'Unbounded',sans-serif;font-size:14px;font-weight:700;margin-bottom:10px;color:var(--dark);letter-spacing:-.3px}
.proc-text{font-size:13px;color:var(--mid);line-height:1.65}

/* ─── PRICING ─── */
.pricing-section{background:var(--white)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:72px}
.price-card{background:var(--cream);border-radius:28px;padding:48px 40px;border:1.5px solid transparent;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}
.price-card:hover{transform:translateY(-8px);border-color:rgba(212,43,43,.2);box-shadow:0 32px 80px rgba(28,20,16,.1)}
.price-card.featured{background:var(--dark);border-color:transparent}
.price-card.featured .price-name,.price-card.featured .price-features li,.price-card.featured .price-per{color:rgba(255,255,255,.5)}
.price-card.featured .price-amount,.price-card.featured .price-title{color:#fff}
.price-card.featured .p-divider{background:rgba(255,255,255,.08)}
.price-card.featured:hover{box-shadow:0 32px 80px rgba(212,43,43,.25)}
.featured-badge{position:absolute;top:24px;right:24px;background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:5px 14px;border-radius:100px;text-transform:uppercase;letter-spacing:1px;font-family:'Unbounded',sans-serif}
.price-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--mid);margin-bottom:24px;font-family:'Unbounded',sans-serif}
.price-amount{font-family:'Unbounded',sans-serif;font-size:56px;font-weight:900;color:var(--dark);letter-spacing:-3px;line-height:1}
.price-amount sub{font-size:16px;font-weight:400;letter-spacing:0}
.price-per{font-size:12px;color:var(--mid);margin:8px 0 28px}
.p-divider{height:1px;background:var(--cream3);margin-bottom:28px}
.price-features{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:36px}
.price-features li{font-size:14px;color:var(--dark);display:flex;align-items:center;gap:12px}
.price-features li svg{width:16px;height:16px;stroke:var(--red);fill:none;flex-shrink:0}
.price-btn{display:block;text-align:center;padding:16px;border-radius:50px;font-size:13px;font-weight:700;text-decoration:none;transition:all .3s;font-family:'Unbounded',sans-serif;letter-spacing:.3px}
.price-btn-dark{background:var(--dark);color:#fff;border:1.5px solid var(--dark)}
.price-btn-dark:hover{background:var(--red);border-color:var(--red)}
.price-btn-outline{border:1.5px solid rgba(255,255,255,.2);color:#fff}
.price-btn-outline:hover{background:#fff;color:var(--dark);border-color:#fff}

/* ─── GALLERY ─── */
.gallery-section{background:var(--cream);padding-bottom:80px}
.gallery-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:240px 240px;gap:12px;margin-top:56px}
.gal-cell{border-radius:20px;background:var(--cream2);border:1.5px dashed var(--cream3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;transition:all .4s;cursor:pointer;overflow:hidden;position:relative}
.gal-cell:first-child{grid-row:span 2}
.gal-cell::after{content:'';position:absolute;inset:0;background:var(--red);opacity:0;transition:opacity .4s}
.gal-cell:hover::after{opacity:.04}
.gal-cell:hover{border-color:var(--red);transform:scale(1.01)}
.gal-cell svg{width:40px;height:40px;stroke:var(--mid);fill:none;opacity:.4;position:relative;z-index:1}
.gal-label{font-size:12px;color:var(--mid);font-weight:500;letter-spacing:.5px;position:relative;z-index:1}

/* ─── REFERRAL ─── */
.referral-section{background:var(--dark);padding:120px 56px;overflow:hidden;position:relative}
.referral-section::before{content:'';position:absolute;width:800px;height:800px;border-radius:50%;background:radial-gradient(circle,rgba(212,43,43,.15),transparent 70%);top:-200px;right:-200px;pointer-events:none}
.ref-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.ref-eyebrow{color:rgba(255,255,255,.4)}
.ref-eyebrow::before{background:rgba(255,255,255,.3)}
.ref-headline{color:#fff}
.ref-sub{color:rgba(255,255,255,.5)}
.ref-steps{margin-top:48px;display:flex;flex-direction:column;gap:0}
.ref-step{display:flex;gap:20px;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.ref-step:last-child{border-bottom:none}
.ref-step-n{width:36px;height:36px;border-radius:50%;background:rgba(212,43,43,.2);border:1px solid rgba(212,43,43,.3);display:flex;align-items:center;justify-content:center;font-family:'Unbounded',sans-serif;font-size:13px;font-weight:900;color:var(--red);flex-shrink:0}
.ref-step-title{font-weight:600;color:#fff;margin-bottom:4px;font-size:15px}
.ref-step-desc{font-size:13px;color:rgba(255,255,255,.4);line-height:1.6}
.ref-card{background:linear-gradient(145deg,#261a16,#1c1410);border:1px solid rgba(212,43,43,.2);border-radius:32px;padding:56px 48px;text-align:center;position:relative;overflow:hidden}
.ref-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),#ff6b6b,var(--red));background-size:200%;animation:shimmer 3s linear infinite}
@keyframes shimmer{0%{background-position:0%}100%{background-position:200%}}
.ref-icon{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--red),#9b1a1a);margin:0 auto 28px;display:flex;align-items:center;justify-content:center;box-shadow:0 16px 48px rgba(212,43,43,.4);animation:floatIcon 4s ease-in-out infinite}
@keyframes floatIcon{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.ref-icon svg{width:44px;height:44px;stroke:#fff;fill:none}
.ref-pct{font-family:'Unbounded',sans-serif;font-size:80px;font-weight:900;color:#fff;line-height:1;letter-spacing:-4px;margin-bottom:6px}
.ref-pct-accent{color:var(--red)}
.ref-pct-sub{font-size:13px;color:rgba(255,255,255,.4);margin-bottom:36px}
.ref-link-row{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.ref-link-txt{font-size:13px;color:rgba(255,255,255,.5);font-family:monospace}
.ref-copy{background:var(--red);color:#fff;border:none;padding:8px 18px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif}
.ref-copy:hover{background:#ff3344}
.ref-share{display:block;width:100%;padding:16px;border-radius:50px;background:#fff;color:var(--dark);font-family:'Unbounded',sans-serif;font-size:13px;font-weight:700;text-decoration:none;text-align:center;transition:all .3s;border:none;cursor:pointer}
.ref-share:hover{background:var(--red);color:#fff;box-shadow:0 12px 32px rgba(212,43,43,.4)}
.ref-copied{display:none;font-size:12px;color:#4ade80;margin-top:10px;font-weight:600}

/* ─── CALCULATOR ─── */
.calc-section{background:var(--cream2);padding-bottom:120px}
.calc-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:64px;align-items:start}
.calc-service-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--mid);margin-bottom:16px}
.calc-services{background:var(--white);border-radius:24px;padding:32px;border:1.5px solid var(--border)}
.calc-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s}
.calc-row:last-of-type{border-bottom:none}
.calc-check{width:18px;height:18px;accent-color:var(--red);cursor:pointer;flex-shrink:0}
.calc-row-name{flex:1;font-size:14px;color:var(--dark);font-weight:500}
.calc-row-price{font-size:13px;color:var(--mid);font-weight:600;white-space:nowrap}
.calc-right{display:flex;flex-direction:column;gap:20px}
.calc-qty-block{background:var(--white);border-radius:24px;padding:28px 32px;border:1.5px solid var(--border)}
.calc-qty-label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--mid);margin-bottom:12px}
.calc-qty-input{width:100%;padding:16px 20px;border:1.5px solid var(--border);border-radius:14px;font-size:24px;font-family:'Unbounded',sans-serif;font-weight:700;color:var(--dark);outline:none;background:var(--cream);transition:border-color .2s}
.calc-qty-input:focus{border-color:var(--red)}
.calc-result-box{background:var(--dark);border-radius:24px;padding:32px}
.calc-result-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.4);margin-bottom:12px}
.calc-result-sum{font-family:'Unbounded',sans-serif;font-size:40px;font-weight:900;color:#fff;letter-spacing:-2px;margin-bottom:16px}
.calc-result-note{font-size:12px;color:rgba(255,255,255,.35);line-height:1.7}
.calc-result-breakdown{font-size:12px;color:rgba(255,255,255,.4);line-height:1.9;margin-bottom:12px;border-top:1px solid rgba(255,255,255,.08);padding-top:12px;display:none}
.calc-result-breakdown.show{display:block}
.calc-storage-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.calc-pallet-input{width:72px;padding:8px 12px;border:1.5px solid var(--border);border-radius:10px;font-size:15px;font-family:'Unbounded',sans-serif;font-weight:700;color:var(--dark);background:var(--cream);outline:none;text-align:center;transition:border-color .2s}
.calc-pallet-input:focus{border-color:var(--red)}

/* ─── CALC DOWNLOAD ─── */
.calc-dl-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px;border-radius:50px;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.15);color:rgba(255,255,255,.7);font-size:13px;font-weight:600;text-decoration:none;transition:all .3s;margin-top:20px;font-family:'Unbounded',sans-serif;letter-spacing:.2px}
.calc-dl-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;flex-shrink:0}
.calc-dl-btn:hover{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.3)}

/* ─── WHY US ─── */
.why-section{background:var(--dark);padding:120px 56px;overflow:hidden;position:relative}
.why-section::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(212,43,43,.15),transparent 70%);top:-200px;right:-100px;pointer-events:none}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:72px;border-radius:28px;overflow:hidden}
.why-card{background:#221a16;padding:44px 36px;position:relative;overflow:hidden;transition:background .3s}
.why-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.why-card:hover{background:#261e1a}
.why-card:hover::after{transform:scaleX(1)}
.why-num{font-family:'Unbounded',sans-serif;font-size:11px;font-weight:700;color:var(--red);letter-spacing:2px;text-transform:uppercase;margin-bottom:24px}
.why-icon{width:52px;height:52px;background:rgba(212,43,43,.12);border:1px solid rgba(212,43,43,.2);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.why-icon svg{width:24px;height:24px;stroke:var(--red);fill:none}
.why-title{font-family:'Unbounded',sans-serif;font-size:16px;font-weight:700;color:#fff;margin-bottom:14px;line-height:1.4;letter-spacing:-.3px}
.why-text{font-size:14px;color:rgba(255,255,255,.45);line-height:1.8}
.why-big-num{font-family:'Unbounded',sans-serif;font-size:72px;font-weight:900;color:var(--red);opacity:.12;position:absolute;bottom:-10px;right:20px;line-height:1;pointer-events:none;user-select:none}

/* ─── REVIEWS ─── */
.reviews-section{background:var(--cream2);padding-bottom:120px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:64px}
.rev-card{background:var(--white);border-radius:24px;padding:36px;border:1.5px solid var(--border);position:relative;transition:box-shadow .3s,transform .3s}
.rev-card:hover{box-shadow:0 24px 64px var(--shadow);transform:translateY(-4px)}
.rev-stars{display:flex;gap:4px;margin-bottom:20px}
.rev-stars svg{width:16px;height:16px;fill:var(--red);stroke:none}
.rev-text{font-size:14px;color:var(--mid);line-height:1.85;margin-bottom:24px;font-style:italic}
.rev-author{display:flex;align-items:center;gap:14px}
.rev-avatar{width:44px;height:44px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;font-family:'Unbounded',sans-serif;font-size:14px;font-weight:900;color:#fff;flex-shrink:0}
.rev-name{font-weight:700;font-size:14px;color:var(--dark)}
.rev-role{font-size:12px;color:var(--mid);margin-top:2px}
.rev-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(212,43,43,.08);border:1px solid rgba(212,43,43,.15);color:var(--red);font-size:11px;font-weight:600;padding:5px 12px;border-radius:100px;position:absolute;top:24px;right:24px;letter-spacing:.3px}
.rev-badge svg{width:11px;height:11px;stroke:var(--red);fill:none}

/* ─── FAQ ─── */
.faq-section{background:var(--white);padding-bottom:120px}
.faq-list{margin-top:64px;max-width:860px;margin-left:auto;margin-right:auto}
.faq-item{border-bottom:1px solid var(--border);overflow:hidden}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:24px 0;cursor:pointer;gap:20px;user-select:none}
.faq-q-text{font-size:16px;font-weight:600;color:var(--dark);line-height:1.5;flex:1}
.faq-icon{width:36px;height:36px;border-radius:50%;background:var(--cream2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s,transform .3s}
.faq-icon svg{width:16px;height:16px;stroke:var(--dark);fill:none;transition:transform .3s}
.faq-item.open .faq-icon{background:var(--red);border-color:var(--red)}
.faq-item.open .faq-icon svg{stroke:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s ease,padding .3s}
.faq-a-inner{padding-bottom:24px;font-size:14px;color:var(--mid);line-height:1.9}
.faq-item.open .faq-a{max-height:400px}

/* ─── MAP ─── */
.map-section{background:var(--white);padding-bottom:120px}
.map-wrap{position:relative;margin-top:56px;border-radius:28px;overflow:hidden;box-shadow:0 24px 80px var(--shadow)}
.map-frame{width:100%;height:480px;border:none;display:block}
.map-badge{position:absolute;bottom:24px;left:24px;background:#fff;border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:14px;box-shadow:0 8px 32px rgba(0,0,0,.15)}
.map-badge svg{width:22px;height:22px;stroke:var(--red);fill:none;flex-shrink:0}
.map-badge-title{font-weight:700;font-size:14px;color:var(--dark);margin-bottom:3px}
.map-badge-addr{font-size:12px;color:var(--mid)}

/* ─── CONTACT ─── */
.contact-section{background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;margin-top:72px;align-items:start}
.c-links{display:flex;flex-direction:column;gap:0;margin-top:36px}
.c-link{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--border);text-decoration:none;transition:all .3s}
.c-link:hover .c-link-icon{background:var(--red);border-color:var(--red)}
.c-link:hover .c-link-icon svg{stroke:#fff}
.c-link-icon{width:46px;height:46px;border-radius:14px;background:var(--white);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s}
.c-link-icon svg{width:20px;height:20px;stroke:var(--dark);fill:none;transition:stroke .3s}
.c-link-name{font-weight:600;color:var(--dark);font-size:15px;margin-bottom:3px}
.c-link-val{font-size:13px;color:var(--mid)}
.c-form{display:flex;flex-direction:column;gap:14px}
.c-field{display:flex;flex-direction:column;gap:5px}
.c-form input,.c-form textarea{width:100%;padding:16px 20px;background:var(--white);border:1.5px solid var(--border);border-radius:14px;font-size:14px;font-family:'Inter',sans-serif;color:var(--dark);outline:none;transition:border-color .2s,box-shadow .2s}
.c-form input::placeholder,.c-form textarea::placeholder{color:var(--mid);opacity:.7}
.c-form input:focus,.c-form textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(212,43,43,.08)}
.c-form input.invalid,.c-form textarea.invalid{border-color:#e53e3e}
.c-form textarea{min-height:110px;resize:none}
.c-err{display:none;font-size:12px;color:#e53e3e;padding-left:4px}
.c-err.show{display:block}
.c-err-global{display:none;background:rgba(229,62,62,.08);border:1px solid rgba(229,62,62,.2);color:#e53e3e;padding:14px;border-radius:14px;text-align:center;font-size:13px;margin-top:4px}
.c-err-global.show{display:block}
.c-submit{width:100%;padding:18px;border-radius:50px;background:var(--dark);color:#fff;font-family:'Unbounded',sans-serif;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:all .3s;letter-spacing:.3px}
.c-submit:hover{background:var(--red);box-shadow:0 12px 36px rgba(212,43,43,.35);transform:translateY(-2px)}
.c-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.c-ok{display:none;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:#16a34a;padding:16px;border-radius:14px;text-align:center;font-weight:500;font-size:14px;margin-top:4px}

/* ─── PERKS ─── */
.perks-section{background:var(--white);padding:120px 56px}
.perks-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px;gap:40px}
.perks-eyebrow::before{background:var(--red)}
.perks-headline{margin-bottom:0}
.perks-headline em{font-style:normal;color:var(--red)}
.perks-cta{align-self:flex-end;flex-shrink:0}
.perks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.perk-card{background:var(--cream);border-radius:28px;padding:40px 32px;border:1.5px solid var(--border);position:relative;overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;gap:0}
.perk-card:hover{transform:translateY(-8px);box-shadow:0 32px 80px rgba(28,20,16,.1);border-color:rgba(212,43,43,.25);background:var(--white)}
.perk-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),#ff6b6b);transform:scaleX(0);transform-origin:left;transition:transform .4s ease;border-radius:0 0 3px 3px}
.perk-card:hover::before{transform:scaleX(1)}
.perk-icon-wrap{width:52px;height:52px;border-radius:16px;background:rgba(212,43,43,.08);border:1px solid rgba(212,43,43,.12);display:flex;align-items:center;justify-content:center;margin-bottom:24px;transition:background .3s,transform .3s}
.perk-card:hover .perk-icon-wrap{background:rgba(212,43,43,.15);transform:rotate(-6deg) scale(1.08)}
.perk-icon-wrap svg{width:24px;height:24px;stroke:var(--red);fill:none}
.perk-name{font-family:'Unbounded',sans-serif;font-size:15px;font-weight:700;color:var(--dark);margin-bottom:14px;letter-spacing:-.4px;line-height:1.4}
.perk-desc{font-size:14px;color:var(--mid);line-height:1.75;flex:1}

/* ─── FOOTER ─── */
footer{background:var(--dark2);padding:56px;border-top:1px solid rgba(255,255,255,.04)}
.footer-inner{max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.f-logo{font-family:'Unbounded',sans-serif;font-size:18px;font-weight:900;color:#fff;letter-spacing:-.5px}
.f-logo span{color:var(--red)}
.f-copy{font-size:12px;color:rgba(255,255,255,.3);letter-spacing:.3px}
.f-tg{color:rgba(255,255,255,.5);text-decoration:none;font-size:13px;font-weight:600;transition:color .2s;font-family:'Unbounded',sans-serif}
.f-tg:hover{color:#fff}

/* ─── REVEAL ANIMATIONS ─── */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal-right.visible{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal-scale.visible{opacity:1;transform:none}
.delay-1{transition-delay:.1s}
.delay-2{transition-delay:.2s}
.delay-3{transition-delay:.3s}
.delay-4{transition-delay:.4s}
.delay-5{transition-delay:.5s}

@keyframes fadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:none}}

/* ─── RESPONSIVE ─── */
@media(max-width:1024px){
  .topbar{padding:0 24px}
  .topbar-left .topbar-item:not(:first-child){display:none}
  nav,section,.stats-section,.referral-section{padding-left:24px;padding-right:24px}
  .hero{padding-left:24px;padding-right:24px;padding-bottom:60px}
  .nav-links{display:none}
  .hero-title{letter-spacing:-2px}
  .hero-bottom{flex-direction:column;align-items:flex-start}
  .stats-grid{grid-template-columns:1fr 1fr}
  .services-top{flex-direction:column;align-items:flex-start}
  .services-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr}
  .process-steps::before{display:none}
  .pricing-grid{grid-template-columns:1fr;max-width:420px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .ref-grid{grid-template-columns:1fr;gap:56px}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .gal-cell:first-child{grid-row:span 1}
  footer{padding:40px 24px}
  .footer-inner{flex-direction:column;text-align:center}
}
@media(max-width:640px){
  .services-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .c-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero-actions{flex-direction:column;align-items:flex-start;width:100%}
  .btn-primary,.btn-secondary,.btn-bot{width:100%;justify-content:center;padding-left:24px;padding-right:24px}
  .why-section{padding:80px 24px}
  .why-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .calc-wrap{grid-template-columns:1fr}
  .faq-q-text{font-size:15px}

  /* ── CURSOR mobile: скрываем кастомный курсор ── */
  .cursor,.cursor-follow{display:none!important}
  body{cursor:auto}

  /* ── TOPBAR mobile: убираем всё лишнее ── */
  .topbar{padding:0 16px}
  .topbar-left{display:none}
  .topbar-bot{display:none!important}
  .topbar-right{gap:10px}
  .topbar-phone{font-size:11px;letter-spacing:0}

  /* ── NAV mobile: убираем текст бренда, компактная кнопка ── */
  nav{padding-left:16px!important;padding-right:16px!important;height:60px}
  .nav-brand{display:none}
  .nav-btn{padding:10px 18px;font-size:11px;letter-spacing:0}

  /* ── HERO mobile ── */
  .hero{padding-top:80px;padding-bottom:48px}
  .hero-title{font-size:clamp(44px,11vw,80px);letter-spacing:-2px;margin-bottom:32px}

  /* ── STATS mobile: меньше шрифт и падинг ── */
  .stats-section{padding:48px 16px}
  .stat-item{padding:28px 12px}
  .stat-num{font-size:22px;letter-spacing:-1px}
  .stat-icon-wrap{width:36px;height:36px;margin-bottom:12px}

  /* ── CALC mobile: кнопки без переноса ── */
  .calc-dl-btn{font-size:11px;padding:12px 14px;letter-spacing:0;gap:7px}
  .c-submit{font-size:11px;letter-spacing:0;padding:14px}
  .calc-result-box{padding:20px}
  .calc-result-sum{font-size:28px}

  /* ── PERKS mobile ── */
  .perks-section{padding:72px 16px}
  .perks-top{flex-direction:column;align-items:flex-start}
  .perks-grid{grid-template-columns:1fr 1fr;gap:12px}
  .perk-num{font-size:34px;letter-spacing:-1px}
  .perk-card{padding:24px 20px;border-radius:20px}

  /* ── REFERRAL mobile ── */
  .referral-section{padding:72px 16px}
  .ref-grid{overflow:hidden}
  .ref-card{padding:32px 24px;border-radius:24px}
  .ref-pct{font-size:56px;letter-spacing:-2px}
  .ref-icon{width:72px;height:72px;margin-bottom:20px}
  .ref-icon svg{width:32px;height:32px}
  .ref-steps{max-width:100%}
  .ref-step-title,.ref-step-desc{word-break:break-word}

  /* ── SECTIONS mobile ── */
  section{padding:72px 16px}
  .stats-section{padding:48px 16px}
  .referral-section,.why-section{padding:72px 16px}
  .contact-section{padding:72px 16px}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .map-frame{height:280px}
  footer{padding:32px 16px}
}
