/* =====================================================
   МАСТЕРСТРОЙ — стили
   ===================================================== */

:root {
  --bg:     #0f1117;
  --bg2:    #161b24;
  --bg3:    #1e2535;
  --accent: #f97316;
  --accent2:#fb923c;
  --text:   #f1f5f9;
  --muted:  #94a3b8;
  --border: rgba(249,115,22,0.2);
}

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Montserrat',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(15,17,23,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 5%}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-icon{width:36px;height:36px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center}
.logo-text{font-size:18px;font-weight:700;color:var(--text);letter-spacing:1px}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:13px;font-weight:600;letter-spacing:.5px;transition:.2s}
.nav-links a:hover{color:var(--accent)}
.nav-cta{background:var(--accent);color:#fff;border:none;padding:10px 22px;border-radius:8px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;cursor:pointer;transition:.2s;letter-spacing:.5px}
.nav-cta:hover{background:var(--accent2);transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:var(--bg2);border-bottom:1px solid var(--border);padding:20px 5%;z-index:99;flex-direction:column;gap:16px}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--text);text-decoration:none;font-size:15px;font-weight:600;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:80px 5% 60px}
.hero-bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1558618666-fcd25c85cd64?w=1600&auto=format&fit=crop&q=60') center/cover no-repeat;opacity:.18;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,17,23,.97) 40%,rgba(15,17,23,.7));z-index:1}
.hero-grid{position:absolute;inset:0;z-index:1;opacity:.06;background-image:linear-gradient(rgba(249,115,22,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(249,115,22,.5) 1px,transparent 1px);background-size:60px 60px}
#hero-canvas{position:absolute;inset:0;z-index:2;pointer-events:none}
.hero-content{position:relative;z-index:3;max-width:1200px;margin:0 auto;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.3);border-radius:40px;padding:6px 16px;margin-bottom:28px}
.hero-badge-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.hero-badge span{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:1px;text-transform:uppercase}
.hero h1{font-size:clamp(36px,6vw,76px);font-weight:900;line-height:1.05;margin-bottom:24px;letter-spacing:-1px}
.hero h1 .accent{color:var(--accent)}
.hero-desc{font-size:clamp(15px,1.5vw,18px);color:var(--muted);max-width:560px;line-height:1.7;margin-bottom:40px;font-weight:500}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.hero-bottom{margin-top:60px;display:flex;gap:40px;flex-wrap:wrap}
.hero-stat{display:flex;flex-direction:column;gap:4px}
.hero-stat-num{font-size:clamp(28px,3vw,40px);font-weight:900;color:var(--accent);line-height:1}
.hero-stat-label{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.hero-stat-sep{width:1px;background:rgba(255,255,255,.1);align-self:stretch}

/* ── КНОПКИ ── */
.btn-primary{background:var(--accent);color:#fff;border:none;padding:16px 36px;border-radius:10px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;cursor:pointer;transition:.25s;letter-spacing:.5px}
.btn-primary:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(249,115,22,.4)}
.btn-outline{background:transparent;color:var(--text);border:2px solid rgba(255,255,255,.2);padding:14px 34px;border-radius:10px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;cursor:pointer;transition:.25s;letter-spacing:.5px}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}

/* ── ОБЩИЕ ДЛЯ СЕКЦИЙ ── */
section{padding:90px 5%}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.section-title{font-size:clamp(26px,3vw,42px);font-weight:900;line-height:1.15;margin-bottom:16px;letter-spacing:-.5px}
.section-sub{font-size:16px;color:var(--muted);max-width:560px;line-height:1.7;font-weight:500;margin-bottom:48px}

/* ── PAYMENT STRIP ── */
.payment-strip{background:rgba(249,115,22,.06);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:22px 5%}
.payment-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:36px;flex-wrap:wrap}
.pay-item{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:var(--text)}
.pay-item svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.pay-sep{width:4px;height:4px;border-radius:50%;background:rgba(249,115,22,.4)}

/* ── SERVICES МЕГАМЕНЮ ── */
.services-bg{background:var(--bg2)}
.services-menu{display:flex;background:var(--bg3);border:1px solid var(--border);border-radius:16px;overflow:hidden;min-height:360px}
.services-cats{width:280px;flex-shrink:0;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;padding:8px 0}
.scat-item{display:flex;align-items:center;gap:12px;padding:13px 20px;cursor:pointer;transition:.2s;position:relative}
.scat-item:hover{background:rgba(255,255,255,.04)}
.scat-item.active{background:rgba(249,115,22,.08)}
.scat-item.active::after{content:'';position:absolute;left:0;top:12px;bottom:12px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}
.scat-icon{width:36px;height:36px;background:rgba(255,255,255,.06);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.2s}
.scat-item.active .scat-icon{background:rgba(249,115,22,.15)}
.scat-icon svg{width:18px;height:18px;stroke:var(--muted);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;transition:.2s}
.scat-item.active .scat-icon svg{stroke:var(--accent)}
.scat-name{font-size:14px;font-weight:600;color:var(--muted);transition:.2s;line-height:1.3}
.scat-item.active .scat-name{color:var(--text)}
.services-sub{flex:1;padding:24px 28px;display:none;min-width:0}
.services-sub.active{display:block}
.ssub-title{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.ssub-list{display:flex;flex-direction:column;gap:4px}
.ssub-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;text-decoration:none;transition:.2s;color:var(--text)}
.ssub-item:hover{background:rgba(249,115,22,.07);color:var(--accent)}
.ssub-item-arrow{width:16px;height:16px;color:var(--muted);flex-shrink:0;transition:.2s}
.ssub-item:hover .ssub-item-arrow{color:var(--accent);transform:translateX(3px)}
.ssub-item-text{font-size:14px;font-weight:600;min-width:0}
.ssub-item-price{margin-left:auto;font-size:11px;font-weight:700;color:var(--accent);background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.2);border-radius:4px;padding:2px 8px;white-space:nowrap;flex-shrink:0}

/* ── STATS ── */
.stats-section{background:var(--bg)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:16px;padding:32px 24px;text-align:center;transition:.3s}
.stat-card:hover{border-color:rgba(249,115,22,.4)}
.stat-num{font-size:clamp(36px,4vw,52px);font-weight:900;color:var(--accent);line-height:1;margin-bottom:8px}
.stat-label{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;line-height:1.4}

/* ── GALLERY ── */
.gallery-section{background:var(--bg2)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-item{border-radius:12px;overflow:hidden;position:relative;aspect-ratio:4/3;cursor:pointer}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:.4s;filter:brightness(.85)}
.gallery-item:hover img{transform:scale(1.05);filter:brightness(1)}
.gallery-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,17,23,.65) 0%,transparent 55%);opacity:0;transition:.3s}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-label{position:absolute;bottom:14px;left:14px;font-size:12px;font-weight:700;color:#fff;opacity:0;transition:.3s;letter-spacing:.5px}
.gallery-item:hover .gallery-label{opacity:1}

/* ── WHY ── */
.why-section{background:var(--bg)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.why-visual{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/3}
.why-visual img{width:100%;height:100%;object-fit:cover;filter:brightness(.8)}
.why-badge{position:absolute;bottom:20px;left:20px;background:rgba(15,17,23,.85);border:1px solid var(--border);border-radius:12px;padding:14px 18px;backdrop-filter:blur(8px)}
.why-badge-num{font-size:28px;font-weight:900;color:var(--accent);line-height:1}
.why-badge-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.why-points{display:flex;flex-direction:column;gap:24px}
.why-point{display:flex;gap:16px;align-items:flex-start}
.why-point-icon{width:44px;height:44px;background:rgba(249,115,22,.10);border:1px solid rgba(249,115,22,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.why-point-icon svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.why-point-title{font-size:16px;font-weight:700;margin-bottom:4px}
.why-point-desc{font-size:14px;color:var(--muted);line-height:1.6;font-weight:500}

/* ── FORM ── */
.form-section{background:var(--bg2)}
.form-layout{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.form-info-points{display:flex;flex-direction:column;gap:20px;margin-top:32px}
.form-info-point{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;color:var(--muted)}
.form-info-point-icon{width:36px;height:36px;background:rgba(249,115,22,.10);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.form-info-point-icon svg{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.contact-form{background:var(--bg3);border:1px solid var(--border);border-radius:20px;padding:36px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.form-label{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase}
.form-input,.form-select,.form-textarea{background:var(--bg2);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:13px 16px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:500;color:var(--text);outline:none;transition:.2s;width:100%}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(249,115,22,.12)}
.form-select option{background:var(--bg2)}
.form-textarea{min-height:100px;resize:vertical}
.form-submit{width:100%;background:var(--accent);color:#fff;border:none;padding:16px;border-radius:10px;font-family:'Montserrat',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:.25s;letter-spacing:.5px;margin-top:8px}
.form-submit:hover{background:var(--accent2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(249,115,22,.4)}
.form-note{font-size:12px;color:var(--muted);text-align:center;margin-top:12px;font-weight:500}
.success-msg{display:none;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:10px;padding:16px;text-align:center;font-size:14px;font-weight:600;color:#4ade80;margin-top:12px}

/* ── FOOTER ── */
footer{background:var(--bg);border-top:1px solid var(--border);padding:48px 5% 32px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:32px;flex-wrap:wrap;margin-bottom:40px}
.footer-brand{max-width:280px}
.footer-desc{font-size:13px;color:var(--muted);line-height:1.7;margin-top:12px;font-weight:500}
.footer-links h4{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.footer-links ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{color:var(--muted);text-decoration:none;font-size:13px;font-weight:600;transition:.2s}
.footer-links a:hover{color:var(--text)}
.footer-contact-item{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--muted);font-weight:500;margin-bottom:10px}
.footer-contact-item svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.footer-contact-item strong{color:var(--text)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:12px;color:var(--muted);font-weight:500}

/* ── FLOAT BTN ── */
.float-call{position:fixed;bottom:28px;right:28px;z-index:200;width:56px;height:56px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 20px rgba(249,115,22,.5);animation:floatpulse 2.5s infinite;border:none;transition:transform .2s}
.float-call:hover{transform:scale(1.1)}
.float-call svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
@keyframes floatpulse{0%,100%{box-shadow:0 4px 20px rgba(249,115,22,.5)}50%{box-shadow:0 4px 40px rgba(249,115,22,.75)}}

/* ── POPUP ── */
.cpop-wrap{position:fixed;bottom:96px;right:28px;z-index:300;display:flex;flex-direction:column;align-items:flex-end;pointer-events:none}
.cpop{width:300px;background:var(--bg2);border:1px solid var(--border);border-radius:20px;box-shadow:0 24px 64px rgba(0,0,0,.6),0 0 0 1px rgba(249,115,22,.08);transform:translateY(12px) scale(.97);opacity:0;pointer-events:none;transition:transform .3s cubic-bezier(.34,1.4,.64,1),opacity .22s ease;overflow:hidden}
.cpop.open{transform:translateY(0) scale(1);opacity:1;pointer-events:all}
.cpop-wrap.open{pointer-events:all}
.cpop-head{padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:flex-start;gap:12px}
.cpop-logo{width:40px;height:40px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cpop-logo svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cpop-title-block{flex:1;min-width:0}
.cpop-title{font-size:14px;font-weight:700;line-height:1.3;color:var(--text)}
.cpop-sub{font-size:11px;color:var(--muted);font-weight:500;margin-top:2px;line-height:1.4}
.cpop-close{width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.07);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;transition:.2s;font-size:14px;line-height:1}
.cpop-close:hover{background:rgba(255,255,255,.13);color:var(--text)}
.cpop-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px}
.cpop-btn-order{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--accent);color:#fff;border:none;border-radius:10px;padding:12px 16px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;cursor:pointer;transition:.2s;letter-spacing:.3px;width:100%;text-decoration:none}
.cpop-btn-order:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 6px 18px rgba(249,115,22,.35)}
.cpop-btn-order svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.cpop-phone-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg3);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:11px 14px;text-decoration:none;transition:.2s;gap:8px}
.cpop-phone-row:hover{border-color:rgba(249,115,22,.35);background:rgba(249,115,22,.05)}
.cpop-phone-left{display:flex;align-items:center;gap:9px}
.cpop-phone-left svg{width:14px;height:14px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.cpop-phone-label{font-size:10px;color:var(--muted);font-weight:600;letter-spacing:.3px;display:block;line-height:1.2}
.cpop-phone-num{font-size:13px;font-weight:700;color:var(--text);letter-spacing:.3px;display:block;line-height:1.3}
.cpop-phone-call{font-size:10px;font-weight:700;color:var(--accent);background:rgba(249,115,22,.12);border:1px solid rgba(249,115,22,.2);border-radius:5px;padding:3px 8px;white-space:nowrap;flex-shrink:0}
.cpop-divider{font-size:10px;color:var(--muted);font-weight:600;letter-spacing:2px;text-transform:uppercase;text-align:center;position:relative;padding:2px 0}
.cpop-divider::before,.cpop-divider::after{content:'';position:absolute;top:50%;width:30%;height:1px;background:rgba(255,255,255,.08)}
.cpop-divider::before{left:0}.cpop-divider::after{right:0}
.cpop-note{font-size:10px;color:rgba(148,163,184,.5);line-height:1.5;text-align:center;font-weight:500}

/* ── SERVICE TRIGGER ── */
.form-service-trigger{display:flex;align-items:center;justify-content:space-between;background:var(--bg2);border:2px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:.25s;margin-bottom:16px;gap:12px}
.form-service-trigger:hover{border-color:var(--accent);background:rgba(249,115,22,.04)}
.fst-left{display:flex;align-items:center;gap:12px;min-width:0}
.fst-left svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.fst-label{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.5px;text-transform:uppercase;display:block}
.fst-value{font-size:14px;font-weight:600;color:var(--text);display:block;margin-top:2px}
.fst-arrow{width:18px;height:18px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;transition:.2s}
.form-service-trigger:hover .fst-arrow{transform:translateX(3px)}
.form-service-trigger.has-value{border-color:rgba(249,115,22,.5);background:rgba(249,115,22,.06)}

/* ── МОДАЛЬНАЯ ФОРМА ── */
.modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s ease}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:24px;width:100%;max-width:800px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.7);transform:translateY(24px) scale(.96);transition:transform .35s cubic-bezier(.34,1.3,.64,1),opacity .3s ease;opacity:0;position:relative}
.modal-overlay.open .modal{transform:translateY(0) scale(1);opacity:1}
.modal-step{display:flex;flex-direction:column;overflow:hidden;flex:1}
.modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
.modal-header-text{flex:1;min-width:0}
.modal-label{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:3px}
.modal-title{font-size:20px;font-weight:900;color:var(--text);letter-spacing:-.3px}
.modal-close{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.07);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);flex-shrink:0;transition:.2s}
.modal-close:hover{background:rgba(255,255,255,.13);color:var(--text)}
.modal-close svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.modal-back{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);font-family:'Montserrat',sans-serif;font-size:13px;font-weight:600;cursor:pointer;padding:0;transition:.2s;flex-shrink:0}
.modal-back:hover{color:var(--text)}
.modal-back svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.modal-body{overflow-y:auto;flex:1;padding:16px 24px 24px;scrollbar-width:thin;scrollbar-color:rgba(249,115,22,.3) transparent}
.modal-body::-webkit-scrollbar{width:4px}
.modal-body::-webkit-scrollbar-thumb{background:rgba(249,115,22,.3);border-radius:2px}
.modal-services{display:flex;flex-direction:column;gap:8px}
.msvc-item{display:flex;align-items:center;gap:14px;background:var(--bg3);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:14px 16px;cursor:pointer;transition:.2s;text-align:left;font-family:'Montserrat',sans-serif;width:100%}
.msvc-item:hover{border-color:rgba(249,115,22,.4);background:rgba(249,115,22,.07);transform:translateX(4px)}
.msvc-icon{width:40px;height:40px;background:rgba(249,115,22,.1);border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.msvc-icon svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.msvc-info{flex:1;min-width:0}
.msvc-name{font-size:14px;font-weight:700;color:var(--text);display:block;line-height:1.3}
.msvc-sub{font-size:12px;color:var(--muted);font-weight:500;display:block;margin-top:2px;line-height:1.3}
.msvc-price{font-size:12px;font-weight:700;color:var(--accent);background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.2);border-radius:5px;padding:3px 9px;white-space:nowrap;flex-shrink:0}
.msvc-other{border-style:dashed;border-color:rgba(249,115,22,.25)}
.modal-selected-service{display:flex;align-items:center;gap:12px;background:rgba(249,115,22,.08);border:1px solid rgba(249,115,22,.25);border-radius:12px;padding:14px 16px;margin-bottom:20px}
.modal-selected-service svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.modal-selected-label{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--accent);display:block}
.modal-selected-val{font-size:14px;font-weight:700;color:var(--text);display:block;margin-top:2px}
.modal-fields{display:flex;flex-direction:column;gap:0}
.modal-submit{display:flex;align-items:center;justify-content:center;gap:8px}
.modal-success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;text-align:center;gap:16px;min-height:400px}
.modal-success-icon{width:72px;height:72px;background:rgba(34,197,94,.15);border:2px solid rgba(34,197,94,.3);border-radius:50%;display:flex;align-items:center;justify-content:center}
.modal-success-icon svg{width:32px;height:32px;stroke:#4ade80;fill:none}
.modal-success-title{font-size:28px;font-weight:900;color:var(--text);letter-spacing:-.5px}
.modal-success-sub{font-size:15px;color:var(--muted);line-height:1.6;font-weight:500}
.modal-success-phones{display:flex;flex-direction:column;gap:8px;width:100%;max-width:260px}
.modal-success-phone{display:block;background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:12px 16px;text-align:center;font-size:15px;font-weight:700;color:var(--accent);text-decoration:none;transition:.2s}
.modal-success-phone:hover{border-color:var(--accent);background:rgba(249,115,22,.08)}

/* ── REVEAL АНИМАЦИЯ ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}

/* ══════════════════════════════════════
   МОБИЛЬНЫЙ АДАПТИВ — только телефон
   ══════════════════════════════════════ */

/* планшет */
@media(max-width:900px){
  .why-grid{grid-template-columns:1fr}
  .why-visual{aspect-ratio:16/7}
  .form-layout{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}

/* телефон — базовый */
@media(max-width:640px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}

  /* ── секции — меньше отступы ── */
  section{padding:52px 4%}
  .section-title{font-size:22px}
  .section-sub{font-size:13px;margin-bottom:28px}
  .section-label{font-size:10px;margin-bottom:8px}

  /* ── hero ── */
  .hero{padding:80px 4% 40px;min-height:auto}
  .hero h1{font-size:28px;margin-bottom:14px;letter-spacing:-.5px}
  .hero-desc{font-size:13px;margin-bottom:24px;line-height:1.6}
  .hero-badge{margin-bottom:18px}
  .hero-badge span{font-size:10px}
  .btn-primary{padding:13px 24px;font-size:13px}
  .btn-outline{padding:11px 22px;font-size:13px}
  .hero-btns{gap:10px}
  .hero-bottom{margin-top:32px;gap:16px}
  .hero-stat-num{font-size:24px}
  .hero-stat-label{font-size:10px}

  /* ── payment strip ── */
  .payment-strip{padding:14px 4%}
  .payment-inner{gap:12px;justify-content:flex-start}
  .pay-item{font-size:12px;gap:7px}
  .pay-sep{display:none}

  /* ── меню услуг ── */
  .services-menu{
    flex-direction:column;
    min-height:auto;
    border-radius:12px;
  }
  .services-cats{
    width:100%;
    border-right:none;
    border-bottom:1px solid rgba(255,255,255,.08);
    flex-direction:row;
    overflow-x:auto;
    padding:4px 0 0;
    scrollbar-width:none;
    flex-shrink:0;
  }
  .services-cats::-webkit-scrollbar{display:none}
  .scat-item{
    flex-direction:column;
    gap:5px;
    padding:8px 12px 10px;
    min-width:76px;
    text-align:center;
    white-space:nowrap;
    flex-shrink:0;
    border-radius:0;
  }
  .scat-item.active::after{
    top:auto;bottom:0;
    left:8px;right:8px;
    width:auto;height:2px;
    border-radius:2px 2px 0 0;
  }
  .scat-icon{width:28px;height:28px;border-radius:6px}
  .scat-icon svg{width:14px;height:14px}
  .scat-name{font-size:10px;white-space:normal;line-height:1.2;max-width:72px}

  /* контент категории — строго block/none */
  .services-sub{
    display:none !important;
    width:100%;
    padding:16px 14px;
    border-top:1px solid rgba(255,255,255,.06);
    flex:none;
  }
  .services-sub.active{display:block !important}
  .ssub-title{font-size:10px;margin-bottom:10px}
  .ssub-item{padding:8px 10px;gap:8px}
  .ssub-item-text{font-size:12px}
  .ssub-item-price{font-size:10px;padding:2px 6px}
  .ssub-item-arrow{width:13px;height:13px}

  /* ── статистика ── */
  .stats-grid{grid-template-columns:1fr 1fr;gap:10px}
  .stat-card{padding:20px 14px;border-radius:12px}
  .stat-num{font-size:30px;margin-bottom:5px}
  .stat-label{font-size:11px}

  /* ── галерея ── */
  .gallery-grid{grid-template-columns:1fr 1fr;gap:8px}
  .gallery-label{font-size:11px;bottom:8px;left:8px}

  /* ── why ── */
  .why-visual{display:none} /* скрываем фото на телефоне — экономим место */
  .why-points{gap:16px}
  .why-point-icon{width:36px;height:36px;border-radius:8px}
  .why-point-icon svg{width:18px;height:18px}
  .why-point-title{font-size:14px}
  .why-point-desc{font-size:12px}

  /* ── форма ── */
  .contact-form{padding:20px 16px;border-radius:14px}
  .form-service-trigger{padding:11px 12px}
  .fst-value{font-size:12px}
  .fst-label{font-size:9px}
  .form-input,.form-textarea{padding:11px 12px;font-size:13px}
  .form-submit{padding:13px;font-size:13px}
  .form-label{font-size:11px}
  .form-info-points{gap:14px;margin-top:20px}
  .form-info-point{font-size:12px;gap:10px}
  .form-info-point-icon{width:30px;height:30px;border-radius:7px}
  .form-info-point-icon svg{width:15px;height:15px}

  /* ── футер ── */
  footer{padding:32px 4% 24px}
  .footer-top{flex-direction:column;gap:20px;margin-bottom:24px}
  .footer-links{display:none} /* скрываем ссылки-дубли в футере */
  .footer-contact-item{font-size:12px}
  .footer-copy{font-size:11px}

  /* ── попап ── */
  .cpop{width:calc(100vw - 32px)}
  .cpop-wrap{right:16px;bottom:84px}
  .float-call{bottom:20px;right:16px;width:50px;height:50px}
  .float-call svg{width:22px;height:22px}

  /* ── модалка — снизу как шторка ── */
  .modal-overlay{padding:0;align-items:flex-end}
  .modal{max-height:92vh;border-radius:20px 20px 0 0}
  .modal-title{font-size:16px}
  .modal-header{padding:16px 16px 12px}
  .modal-body{padding:12px 16px 20px}
  .msvc-item{padding:11px 12px;gap:10px;border-radius:10px}
  .msvc-icon{width:34px;height:34px;border-radius:8px}
  .msvc-icon svg{width:17px;height:17px}
  .msvc-name{font-size:13px}
  .msvc-sub{font-size:11px}
  .msvc-price{font-size:11px;padding:2px 7px}
  .modal-success{padding:32px 20px;min-height:300px}
  .modal-success-title{font-size:22px}
  .modal-success-sub{font-size:13px}
}
